soc/mediatek/mt8183: add dphy reset after setting lanes number

Add dphy reset after setting lanes number to avoid dphy fifo error.

BUG=b:139150763
BRANCH=kukui
TEST=Boots correctly on kukui

Change-Id: Ib83576f3700ef98c90f0b4dd101dcaa237d562f9
Signed-off-by: Jitao Shi <jitao.shi@mediatek.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/36223
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Hung-Te Lin <hungte@chromium.org>
This commit is contained in:
Jitao Shi 2019-10-22 10:15:34 +08:00 committed by Patrick Georgi
parent 19e961e83c
commit b6ca93839d
2 changed files with 9 additions and 0 deletions

View File

@ -392,6 +392,12 @@ static void mtk_dsi_send_init_commands(const u8 *buf)
} }
} }
static void mtk_dsi_reset_dphy(void)
{
setbits_le32(&dsi0->dsi_con_ctrl, DPHY_RESET);
clrbits_le32(&dsi0->dsi_con_ctrl, DPHY_RESET);
}
int mtk_dsi_init(u32 mode_flags, u32 format, u32 lanes, const struct edid *edid, int mtk_dsi_init(u32 mode_flags, u32 format, u32 lanes, const struct edid *edid,
const u8 *init_commands) const u8 *init_commands)
{ {
@ -407,6 +413,8 @@ int mtk_dsi_init(u32 mode_flags, u32 format, u32 lanes, const struct edid *edid,
struct mtk_phy_timing phy_timing; struct mtk_phy_timing phy_timing;
mtk_dsi_phy_timing(data_rate, &phy_timing); mtk_dsi_phy_timing(data_rate, &phy_timing);
mtk_dsi_rxtx_control(mode_flags, lanes); mtk_dsi_rxtx_control(mode_flags, lanes);
mdelay(1);
mtk_dsi_reset_dphy();
mtk_dsi_clk_hs_mode_disable(); mtk_dsi_clk_hs_mode_disable();
mtk_dsi_config_vdo_timing(mode_flags, format, lanes, edid, &phy_timing); mtk_dsi_config_vdo_timing(mode_flags, format, lanes, edid, &phy_timing);
mtk_dsi_clk_hs_mode_enable(); mtk_dsi_clk_hs_mode_enable();

View File

@ -115,6 +115,7 @@ enum {
enum { enum {
DSI_RESET = BIT(0), DSI_RESET = BIT(0),
DSI_EN = BIT(1), DSI_EN = BIT(1),
DPHY_RESET = BIT(2),
DSI_DUAL = BIT(4), DSI_DUAL = BIT(4),
}; };