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:
		
				
					committed by
					
						 Julius Werner
						Julius Werner
					
				
			
			
				
	
			
			
			
						parent
						
							1876f3ae45
						
					
				
				
					commit
					bb9bdeb594
				
			| @@ -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: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user