|
@@ -70,6 +70,9 @@ static int vdec_op_g_volatile_ctrl(struct v4l2_ctrl *ctrl)
|
|
|
case V4L2_CID_MPEG_VIDEO_DECODER_MPEG4_DEBLOCK_FILTER:
|
|
|
ctrl->val = ctr->post_loop_deb_mode;
|
|
|
break;
|
|
|
+ case V4L2_CID_MIN_BUFFERS_FOR_CAPTURE:
|
|
|
+ ctrl->val = inst->num_output_bufs;
|
|
|
+ break;
|
|
|
default:
|
|
|
return -EINVAL;
|
|
|
};
|
|
@@ -87,7 +90,7 @@ int vdec_ctrl_init(struct venus_inst *inst)
|
|
|
struct v4l2_ctrl *ctrl;
|
|
|
int ret;
|
|
|
|
|
|
- ret = v4l2_ctrl_handler_init(&inst->ctrl_handler, 6);
|
|
|
+ ret = v4l2_ctrl_handler_init(&inst->ctrl_handler, 7);
|
|
|
if (ret)
|
|
|
return ret;
|
|
|
|
|
@@ -135,6 +138,11 @@ int vdec_ctrl_init(struct venus_inst *inst)
|
|
|
v4l2_ctrl_new_std(&inst->ctrl_handler, &vdec_ctrl_ops,
|
|
|
V4L2_CID_MPEG_VIDEO_DECODER_MPEG4_DEBLOCK_FILTER, 0, 1, 1, 0);
|
|
|
|
|
|
+ ctrl = v4l2_ctrl_new_std(&inst->ctrl_handler, &vdec_ctrl_ops,
|
|
|
+ V4L2_CID_MIN_BUFFERS_FOR_CAPTURE, 1, 32, 1, 1);
|
|
|
+ if (ctrl)
|
|
|
+ ctrl->flags |= V4L2_CTRL_FLAG_VOLATILE;
|
|
|
+
|
|
|
ret = inst->ctrl_handler.error;
|
|
|
if (ret) {
|
|
|
v4l2_ctrl_handler_free(&inst->ctrl_handler);
|