media: adv7511-v4l2: correctly report EDIDs of 1 block
authorHans Verkuil <hverkuil-cisco@xs4all.nl>
Fri, 26 Mar 2021 09:03:32 +0000 (10:03 +0100)
committerMauro Carvalho Chehab <mchehab+huawei@kernel.org>
Tue, 6 Apr 2021 17:35:26 +0000 (19:35 +0200)
If the EDID has an odd number of blocks (usually just 1, but the
same problem occurs with 3 blocks), then VIDIOC_G_EDID reported 2
(or 4) blocks. Fix this.

Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
drivers/media/i2c/adv7511-v4l2.c

index 9183003ae22ddef76b20dc7da339a328726c86e5..992db5c79b1333ad2c1e4e7d73a990b6fddba96e 100644 (file)
@@ -1196,21 +1196,21 @@ static int adv7511_get_edid(struct v4l2_subdev *sd, struct v4l2_edid *edid)
                return -EINVAL;
 
        if (edid->start_block == 0 && edid->blocks == 0) {
-               edid->blocks = state->edid.segments * 2;
+               edid->blocks = state->edid.blocks;
                return 0;
        }
 
-       if (state->edid.segments == 0)
+       if (state->edid.blocks == 0)
                return -ENODATA;
 
-       if (edid->start_block >= state->edid.segments * 2)
+       if (edid->start_block >= state->edid.blocks)
                return -EINVAL;
 
-       if (edid->start_block + edid->blocks > state->edid.segments * 2)
-               edid->blocks = state->edid.segments * 2 - edid->start_block;
+       if (edid->start_block + edid->blocks > state->edid.blocks)
+               edid->blocks = state->edid.blocks - edid->start_block;
 
        memcpy(edid->edid, &state->edid.data[edid->start_block * 128],
-                       128 * edid->blocks);
+              128 * edid->blocks);
 
        return 0;
 }