soc/rockchip/rk3399: Ensure full eDP init sequence

This patch fixes 2 edp display issues:

1. When rk_edp_prepare fails >3 times, edp_init isn't run because
while-condition is not satisfied. Then, only a partial init sequence is
ran. This causes all aux transactions to fail.
2. If rk_edp_prepare never succeeds, coreboot never leaves link training
stage due to infinite loop. Boot process is stuck.

TEST=Boot past eDP initialization stage and make sure AP logs don't have
show aux transaction fails.

Change-Id: I44c3f53e8786558c43078d4afe9acde4d64796e7
Signed-off-by: Ege Mihmanli <egemih@google.com>
Reviewed-on: https://review.coreboot.org/23152
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Julius Werner <jwerner@chromium.org>
This commit is contained in:
Ege Mihmanli 2018-01-07 18:03:07 -08:00 committed by Julius Werner
parent 1876f3ae45
commit bb9bdeb594

View file

@ -45,7 +45,7 @@ static void reset_edp(void)
udelay(1); udelay(1);
write32(&cru_ptr->softrst_con[17], write32(&cru_ptr->softrst_con[17],
RK_CLRBITS(1 << 12 | 1 << 13)); RK_CLRBITS(1 << 12 | 1 << 13));
printk(BIOS_WARNING, "Retrying epd initialization.\n"); printk(BIOS_WARNING, "Retrying EDP initialization.\n");
} }
void rk_display_init(device_t dev) void rk_display_init(device_t dev)
@ -53,8 +53,9 @@ void rk_display_init(device_t dev)
struct edid edid; struct edid edid;
struct soc_rockchip_rk3399_config *conf = dev->chip_info; struct soc_rockchip_rk3399_config *conf = dev->chip_info;
enum vop_modes detected_mode = VOP_MODE_UNKNOWN; enum vop_modes detected_mode = VOP_MODE_UNKNOWN;
int retry_count = 0;
const struct mipi_panel_data *panel_data = NULL; const struct mipi_panel_data *panel_data = NULL;
int retry_count_init = 0;
int retry_count_edp_prepare = 0;
/* let's use vop0 in rk3399 */ /* let's use vop0 in rk3399 */
uint32_t vop_id = 0; uint32_t vop_id = 0;
@ -77,14 +78,17 @@ void rk_display_init(device_t dev)
write32(&rk3399_grf->soc_con25, RK_SETBITS(1 << 11)); write32(&rk3399_grf->soc_con25, RK_SETBITS(1 << 11));
retry_edp: retry_edp:
while (retry_count++ < 3) { /* Reset in case code jumped here. */
retry_count_init = 0;
while (retry_count_init++ < 3) {
rk_edp_init(); rk_edp_init();
if (rk_edp_get_edid(&edid) == 0) { if (rk_edp_get_edid(&edid) == 0) {
detected_mode = VOP_MODE_EDP; detected_mode = VOP_MODE_EDP;
break; break;
} }
if (retry_count == 3) { if (retry_count_init == 3) {
printk(BIOS_WARNING, "Warning: epd initialization failed.\n"); printk(BIOS_WARNING,
"Warning: EDP initialization failed.\n");
return; return;
} else { } else {
reset_edp(); reset_edp();
@ -159,8 +163,13 @@ retry_edp:
case VOP_MODE_EDP: case VOP_MODE_EDP:
/* will enable edp in depthcharge */ /* will enable edp in depthcharge */
if (rk_edp_prepare()) { if (rk_edp_prepare()) {
reset_edp(); if (retry_count_edp_prepare++ < 3) {
goto retry_edp; /* Rerun entire init sequence */ reset_edp();
/* Rerun entire init sequence */
goto retry_edp;
}
printk(BIOS_ERR, "EDP preparation failed.");
return;
} }
break; break;
default: default: