media: vcodec: Fix potential array out-of-bounds in encoder queue_setup
authorWei Chen <harperchen1110@gmail.com>
Thu, 10 Aug 2023 08:23:33 +0000 (08:23 +0000)
committerHans Verkuil <hverkuil-cisco@xs4all.nl>
Wed, 23 Aug 2023 07:56:08 +0000 (09:56 +0200)
variable *nplanes is provided by user via system call argument. The
possible value of q_data->fmt->num_planes is 1-3, while the value
of *nplanes can be 1-8. The array access by index i can cause array
out-of-bounds.

Fix this bug by checking *nplanes against the array size.

Fixes: 4e855a6efa54 ("[media] vcodec: mediatek: Add Mediatek V4L2 Video Encoder Driver")
Signed-off-by: Wei Chen <harperchen1110@gmail.com>
Cc: stable@vger.kernel.org
Reviewed-by: Chen-Yu Tsai <wenst@chromium.org>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
drivers/media/platform/mediatek/vcodec/mtk_vcodec_enc.c

index 9ff439a..315e97a 100644 (file)
@@ -821,6 +821,8 @@ static int vb2ops_venc_queue_setup(struct vb2_queue *vq,
                return -EINVAL;
 
        if (*nplanes) {
+               if (*nplanes != q_data->fmt->num_planes)
+                       return -EINVAL;
                for (i = 0; i < *nplanes; i++)
                        if (sizes[i] < q_data->sizeimage[i])
                                return -EINVAL;