6681bf2
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
59aac79
From: Ondrej Jirman <megous@megous.com>
59aac79
Date: Fri, 26 Jun 2020 02:55:58 +0200
6681bf2
Subject: [PATCH] drm/panel: st7703: Enter sleep after display off
59aac79
59aac79
The datasheet suggests to issue sleep in after display off
59aac79
as a part of the panel's shutdown sequence.
59aac79
59aac79
Signed-off-by: Ondrej Jirman <megous@megous.com>
59aac79
---
59aac79
 drivers/gpu/drm/panel/panel-sitronix-st7703.c | 13 ++++++++++++-
59aac79
 1 file changed, 12 insertions(+), 1 deletion(-)
59aac79
59aac79
diff --git a/drivers/gpu/drm/panel/panel-sitronix-st7703.c b/drivers/gpu/drm/panel/panel-sitronix-st7703.c
6681bf2
index 33611419059a..e771281eb547 100644
59aac79
--- a/drivers/gpu/drm/panel/panel-sitronix-st7703.c
59aac79
+++ b/drivers/gpu/drm/panel/panel-sitronix-st7703.c
59aac79
@@ -394,8 +394,19 @@ static int st7703_disable(struct drm_panel *panel)
59aac79
 {
59aac79
 	struct st7703 *ctx = panel_to_st7703(panel);
59aac79
 	struct mipi_dsi_device *dsi = to_mipi_dsi_device(ctx->dev);
59aac79
+	int ret;
59aac79
+
59aac79
+	ret = mipi_dsi_dcs_set_display_off(dsi);
59aac79
+	if (ret < 0)
59aac79
+		DRM_DEV_ERROR(ctx->dev,
59aac79
+			      "Failed to turn off the display: %d\n", ret);
6681bf2
59aac79
-	return mipi_dsi_dcs_set_display_off(dsi);
59aac79
+	ret = mipi_dsi_dcs_enter_sleep_mode(dsi);
59aac79
+	if (ret < 0)
59aac79
+		DRM_DEV_ERROR(ctx->dev,
59aac79
+			      "Failed to enter sleep mode: %d\n", ret);
59aac79
+
59aac79
+	return 0;
59aac79
 }
6681bf2
59aac79
 static int st7703_unprepare(struct drm_panel *panel)
59aac79
-- 
59aac79
2.26.2
59aac79