Re: [PATCH] media: venus: remove invalid compat_ioctl32 handler

From: Stanimir Varbanov
Date: Wed Nov 06 2019 - 05:09:46 EST


Hi Arnd,

Thanks for the catch!

On 11/6/19 11:06 AM, Arnd Bergmann wrote:
> v4l2_compat_ioctl32() is the function that calls into
> v4l2_file_operations->compat_ioctl32(), so setting that back to the same
> function leads to a trivial endless loop, followed by a kernel
> stack overrun.
>
> Remove the incorrect assignment.
>
> Cc: stable@xxxxxxxxxxxxxxx
> Fixes: 7472c1c69138 ("[media] media: venus: vdec: add video decoder files")
> Fixes: aaaa93eda64b ("[media] media: venus: venc: add video encoder files")
> Signed-off-by: Arnd Bergmann <arnd@xxxxxxxx>

Acked-by: Stanimir Varbanov <stanimir.varbanov@xxxxxxxxxx>

> ---
> drivers/media/platform/qcom/venus/vdec.c | 3 ---
> drivers/media/platform/qcom/venus/venc.c | 3 ---
> 2 files changed, 6 deletions(-)
>
> diff --git a/drivers/media/platform/qcom/venus/vdec.c b/drivers/media/platform/qcom/venus/vdec.c
> index 7f4660555ddb..59ae7a1e63bc 100644
> --- a/drivers/media/platform/qcom/venus/vdec.c
> +++ b/drivers/media/platform/qcom/venus/vdec.c
> @@ -1412,9 +1412,6 @@ static const struct v4l2_file_operations vdec_fops = {
> .unlocked_ioctl = video_ioctl2,
> .poll = v4l2_m2m_fop_poll,
> .mmap = v4l2_m2m_fop_mmap,
> -#ifdef CONFIG_COMPAT
> - .compat_ioctl32 = v4l2_compat_ioctl32,
> -#endif
> };
>
> static int vdec_probe(struct platform_device *pdev)
> diff --git a/drivers/media/platform/qcom/venus/venc.c b/drivers/media/platform/qcom/venus/venc.c
> index 1b7fb2d5887c..30028ceb548b 100644
> --- a/drivers/media/platform/qcom/venus/venc.c
> +++ b/drivers/media/platform/qcom/venus/venc.c
> @@ -1235,9 +1235,6 @@ static const struct v4l2_file_operations venc_fops = {
> .unlocked_ioctl = video_ioctl2,
> .poll = v4l2_m2m_fop_poll,
> .mmap = v4l2_m2m_fop_mmap,
> -#ifdef CONFIG_COMPAT
> - .compat_ioctl32 = v4l2_compat_ioctl32,
> -#endif
> };
>
> static int venc_probe(struct platform_device *pdev)
>

--
regards,
Stan