]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
drm/panel: boe-tv101wum-nl6: use wrapped MIPI DCS functions
authorDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Sat, 11 May 2024 23:00:20 +0000 (02:00 +0300)
committerNeil Armstrong <neil.armstrong@linaro.org>
Fri, 17 May 2024 19:36:19 +0000 (21:36 +0200)
Remove conditional code and always use mipi_dsi_dcs_*multi() wrappers to
simplify driver's init/exit code.

Reviewed-by: Douglas Anderson <dianders@chromium.org>
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Link: https://lore.kernel.org/r/20240512-dsi-panels-upd-api-v2-3-e31ca14d102e@linaro.org
Signed-off-by: Neil Armstrong <neil.armstrong@linaro.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20240512-dsi-panels-upd-api-v2-3-e31ca14d102e@linaro.org
drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c

index 4b4b125a6c6bbdfa5e78aad9cbd98cba8c727009..8e839a1749e43bf5a1b2bcba438b2de201afebcf 100644 (file)
@@ -448,22 +448,16 @@ static int boe_tv110c9m_init(struct boe_panel *boe)
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x55, 0x00);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xbb, 0x13);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x3b, 0x03, 0x96, 0x1a, 0x04, 0x04);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(100);
+       mipi_dsi_msleep(&ctx, 100);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x11);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(200);
+       mipi_dsi_msleep(&ctx, 200);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x29);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(100);
+       mipi_dsi_msleep(&ctx, 100);
 
        return 0;
 };
@@ -893,22 +887,16 @@ static int inx_hj110iz_init(struct boe_panel *boe)
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xb0, 0x01);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x35, 0x00);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x3b, 0x03, 0xae, 0x1a, 0x04, 0x04);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(100);
+       mipi_dsi_msleep(&ctx, 100);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x11);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(200);
+       mipi_dsi_msleep(&ctx, 200);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x29);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(100);
+       mipi_dsi_msleep(&ctx, 100);
 
        return 0;
 };
@@ -1207,10 +1195,8 @@ static int boe_init(struct boe_panel *boe)
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xb3, 0x08);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xb0, 0x04);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xb8, 0x68);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(150);
+       mipi_dsi_msleep(&ctx, 150);
 
        return 0;
 };
@@ -1222,16 +1208,12 @@ static int auo_kd101n80_45na_init(struct boe_panel *boe)
        msleep(24);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x11);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(120);
+       mipi_dsi_msleep(&ctx, 120);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0x29);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(120);
+       mipi_dsi_msleep(&ctx, 120);
 
        return 0;
 };
@@ -1283,10 +1265,8 @@ static int auo_b101uan08_3_init(struct boe_panel *boe)
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xe5, 0x4f);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xe6, 0x41);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xe7, 0x41);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(150);
+       mipi_dsi_msleep(&ctx, 150);
 
        return 0;
 };
@@ -1385,16 +1365,12 @@ static int starry_qfh032011_53g_init(struct boe_panel *boe)
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xe1, 0x23);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0xe2, 0x07);
        mipi_dsi_dcs_write_seq_multi(&ctx, 0X11);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(120);
+       mipi_dsi_msleep(&ctx, 120);
 
        mipi_dsi_dcs_write_seq_multi(&ctx, 0X29);
-       if (ctx.accum_err)
-               return ctx.accum_err;
 
-       msleep(80);
+       mipi_dsi_msleep(&ctx, 80);
 
        return 0;
 };
@@ -1404,38 +1380,19 @@ static inline struct boe_panel *to_boe_panel(struct drm_panel *panel)
        return container_of(panel, struct boe_panel, base);
 }
 
-static int boe_panel_enter_sleep_mode(struct boe_panel *boe)
-{
-       struct mipi_dsi_device *dsi = boe->dsi;
-       int ret;
-
-       dsi->mode_flags &= ~MIPI_DSI_MODE_LPM;
-
-       ret = mipi_dsi_dcs_set_display_off(dsi);
-       if (ret < 0)
-               return ret;
-
-       ret = mipi_dsi_dcs_enter_sleep_mode(dsi);
-       if (ret < 0)
-               return ret;
-
-       return 0;
-}
-
 static int boe_panel_disable(struct drm_panel *panel)
 {
        struct boe_panel *boe = to_boe_panel(panel);
-       int ret;
+       struct mipi_dsi_multi_context ctx = { .dsi = boe->dsi };
 
-       ret = boe_panel_enter_sleep_mode(boe);
-       if (ret < 0) {
-               dev_err(panel->dev, "failed to set panel off: %d\n", ret);
-               return ret;
-       }
+       boe->dsi->mode_flags &= ~MIPI_DSI_MODE_LPM;
 
-       msleep(150);
+       mipi_dsi_dcs_set_display_off_multi(&ctx);
+       mipi_dsi_dcs_enter_sleep_mode_multi(&ctx);
 
-       return 0;
+       mipi_dsi_msleep(&ctx, 150);
+
+       return ctx.accum_err;
 }
 
 static int boe_panel_unprepare(struct drm_panel *panel)