提交 27f402d6 编写于 作者: D Dave Stevenson 提交者: Zheng Zengkai

drm/panel/raspberrypi-touchscreen: Initialise the bridge in prepare

stable inclusion
from stable-v5.10.113
commit 405d98427416849cf37c84c0c70bd5008b686a1e
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I5ISAH

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=405d98427416849cf37c84c0c70bd5008b686a1e

--------------------------------

[ Upstream commit 5f18c078 ]

The panel has a prepare call which is before video starts, and an
enable call which is after.
The Toshiba bridge should be configured before video, so move
the relevant power and initialisation calls to prepare.

Fixes: 2f733d61 ("drm/panel: Add support for the Raspberry Pi 7" Touchscreen.")
Signed-off-by: NDave Stevenson <dave.stevenson@raspberrypi.com>
Signed-off-by: NStefan Wahren <stefan.wahren@i2se.com>
Signed-off-by: NMaxime Ripard <maxime@cerno.tech>
Link: https://patchwork.freedesktop.org/patch/msgid/20220415162513.42190-3-stefan.wahren@i2se.comSigned-off-by: NSasha Levin <sashal@kernel.org>
Signed-off-by: NZheng Zengkai <zhengzengkai@huawei.com>
Acked-by: NXie XiuQi <xiexiuqi@huawei.com>
上级 5f70f8f0
...@@ -265,7 +265,7 @@ static int rpi_touchscreen_noop(struct drm_panel *panel) ...@@ -265,7 +265,7 @@ static int rpi_touchscreen_noop(struct drm_panel *panel)
return 0; return 0;
} }
static int rpi_touchscreen_enable(struct drm_panel *panel) static int rpi_touchscreen_prepare(struct drm_panel *panel)
{ {
struct rpi_touchscreen *ts = panel_to_ts(panel); struct rpi_touchscreen *ts = panel_to_ts(panel);
int i; int i;
...@@ -295,6 +295,13 @@ static int rpi_touchscreen_enable(struct drm_panel *panel) ...@@ -295,6 +295,13 @@ static int rpi_touchscreen_enable(struct drm_panel *panel)
rpi_touchscreen_write(ts, DSI_STARTDSI, 0x01); rpi_touchscreen_write(ts, DSI_STARTDSI, 0x01);
msleep(100); msleep(100);
return 0;
}
static int rpi_touchscreen_enable(struct drm_panel *panel)
{
struct rpi_touchscreen *ts = panel_to_ts(panel);
/* Turn on the backlight. */ /* Turn on the backlight. */
rpi_touchscreen_i2c_write(ts, REG_PWM, 255); rpi_touchscreen_i2c_write(ts, REG_PWM, 255);
...@@ -349,7 +356,7 @@ static int rpi_touchscreen_get_modes(struct drm_panel *panel, ...@@ -349,7 +356,7 @@ static int rpi_touchscreen_get_modes(struct drm_panel *panel,
static const struct drm_panel_funcs rpi_touchscreen_funcs = { static const struct drm_panel_funcs rpi_touchscreen_funcs = {
.disable = rpi_touchscreen_disable, .disable = rpi_touchscreen_disable,
.unprepare = rpi_touchscreen_noop, .unprepare = rpi_touchscreen_noop,
.prepare = rpi_touchscreen_noop, .prepare = rpi_touchscreen_prepare,
.enable = rpi_touchscreen_enable, .enable = rpi_touchscreen_enable,
.get_modes = rpi_touchscreen_get_modes, .get_modes = rpi_touchscreen_get_modes,
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册