media: ipu3-cio2 Check num_planes and sizes in queue_setup
authorRicardo Ribalda <ribalda@chromium.org>
Wed, 6 Oct 2021 22:26:18 +0000 (00:26 +0200)
committerMauro Carvalho Chehab <mchehab+huawei@kernel.org>
Fri, 8 Oct 2021 11:27:07 +0000 (13:27 +0200)
If num_planes is different than zero num_planes and sizes must be
checked to support the format.

Fix the following v4l2-compliance error:

Buffer ioctls (Input 0):
    fail: v4l2-test-buffers.cpp(717): q.create_bufs(node, 1, &fmt) != EINVAL
  test VIDIOC_REQBUFS/CREATE_BUFS/QUERYBUF: FAIL

Reviewed-by: Bingbu Cao <bingbu.cao@intel.com>
Signed-off-by: Ricardo Ribalda <ribalda@chromium.org>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
drivers/media/pci/intel/ipu3/ipu3-cio2-main.c

index 98cb3bc..356ea96 100644 (file)
@@ -797,13 +797,17 @@ static int cio2_vb2_queue_setup(struct vb2_queue *vq,
        struct cio2_queue *q = vb2q_to_cio2_queue(vq);
        unsigned int i;
 
-       *num_planes = q->format.num_planes;
+       if (*num_planes && *num_planes < q->format.num_planes)
+               return -EINVAL;
 
-       for (i = 0; i < *num_planes; ++i) {
+       for (i = 0; i < q->format.num_planes; ++i) {
+               if (*num_planes && sizes[i] < q->format.plane_fmt[i].sizeimage)
+                       return -EINVAL;
                sizes[i] = q->format.plane_fmt[i].sizeimage;
                alloc_devs[i] = dev;
        }
 
+       *num_planes = q->format.num_planes;
        *num_buffers = clamp_val(*num_buffers, 1, CIO2_MAX_BUFFERS);
 
        /* Initialize buffer queue */