On 8/14/19 9:59 PM, Ezequiel Garcia wrote:
> The cedrus VPU is slice-based and expects V4L2_PIX_FMT_H264_SLICE
> buffers to contain H264 slices with no start code.
> 
> Expose this to userspace with the newly added menu control.
> 
> These two controls are specified as mandatory for applications,
> but we mark them as non-required on the driver side for
> backwards compatibility.
> 
> Signed-off-by: Ezequiel Garcia <ezequ...@collabora.com>
> ---
> Changes in v6:
> * Adjust to control renames.
> Changes in v5:
> * Clarify commit log.
> Changes in v4:
> * New patch.
> ---
>  drivers/staging/media/sunxi/cedrus/cedrus.c | 20 ++++++++++++++++++++
>  1 file changed, 20 insertions(+)
> 
> diff --git a/drivers/staging/media/sunxi/cedrus/cedrus.c 
> b/drivers/staging/media/sunxi/cedrus/cedrus.c
> index 7bdc413bf727..69a836aa11ef 100644
> --- a/drivers/staging/media/sunxi/cedrus/cedrus.c
> +++ b/drivers/staging/media/sunxi/cedrus/cedrus.c
> @@ -77,6 +77,26 @@ static const struct cedrus_control cedrus_controls[] = {
>               .codec          = CEDRUS_CODEC_H264,
>               .required       = true,
>       },
> +     {
> +             .cfg = {
> +                     .id     = V4L2_CID_MPEG_VIDEO_H264_DECODE_MODE,
> +                     .max    = V4L2_MPEG_VIDEO_H264_DECODE_MODE_SLICE_BASED,
> +                     .def    = V4L2_MPEG_VIDEO_H264_DECODE_MODE_SLICE_BASED,
> +                     .menu_skip_mask = 
> BIT(V4L2_MPEG_VIDEO_H264_DECODE_MODE_FRAME_BASED),

You don't need this: DECODE_MODE_FRAME_BASED > DECODE_MODE_SLICE_BASED (the max
value). So no need to set the skip_mask since it is out of range.

> +             },
> +             .codec          = CEDRUS_CODEC_H264,
> +             .required       = false,
> +     },
> +     {
> +             .cfg = {
> +                     .id     = V4L2_CID_MPEG_VIDEO_H264_START_CODE,
> +                     .max    = V4L2_MPEG_VIDEO_H264_START_CODE_NONE,
> +                     .def    = V4L2_MPEG_VIDEO_H264_START_CODE_NONE,
> +                     .menu_skip_mask = 
> BIT(V4L2_MPEG_VIDEO_H264_START_CODE_ANNEX_B),

Ditto.

Regards,

        Hans

> +             },
> +             .codec          = CEDRUS_CODEC_H264,
> +             .required       = false,
> +     },
>  };
>  
>  #define CEDRUS_CONTROLS_COUNT        ARRAY_SIZE(cedrus_controls)
> 

Reply via email to