drm/bridge: anx7625: Fix edid_read break case in sp_tx_edid_read()
authorHsin-Yi Wang <hsinyi@chromium.org>
Thu, 18 Nov 2021 19:30:02 +0000 (03:30 +0800)
committerRobert Foss <robert.foss@linaro.org>
Wed, 24 Nov 2021 12:32:53 +0000 (13:32 +0100)
edid_read() was assumed to return 0 on success. After commit
7f16d0f3b8e2("drm/bridge: anx7625: Propagate errors from sp_tx_rst_aux()"),
the function will return > 0 for successful case, representing the i2c
read bytes. Otherwise -EIO on failure cases. Update the g_edid_break
break condition accordingly.

Fixes: 7f16d0f3b8e2("drm/bridge: anx7625: Propagate errors from sp_tx_rst_aux()")
Signed-off-by: Hsin-Yi Wang <hsinyi@chromium.org>
Reviewed-by: Robert Foss <robert.foss@linaro.org>
Reviewed-by: Xin Ji <xji@analogixsemi.com>
Signed-off-by: Robert Foss <robert.foss@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20211118193002.407168-1-hsinyi@chromium.org
drivers/gpu/drm/bridge/analogix/anx7625.c

index 001fb39d9919a0a543b01e0f0f30722911432427..4e94856f626e77ee7204acfceb775d11f05ec8d5 100644 (file)
@@ -850,7 +850,7 @@ static int sp_tx_edid_read(struct anx7625_data *ctx,
        int count, blocks_num;
        u8 pblock_buf[MAX_DPCD_BUFFER_SIZE];
        u8 i, j;
-       u8 g_edid_break = 0;
+       int g_edid_break = 0;
        int ret;
        struct device *dev = &ctx->client->dev;
 
@@ -881,7 +881,7 @@ static int sp_tx_edid_read(struct anx7625_data *ctx,
                                g_edid_break = edid_read(ctx, offset,
                                                         pblock_buf);
 
-                               if (g_edid_break)
+                               if (g_edid_break < 0)
                                        break;
 
                                memcpy(&pedid_blocks_buf[offset],