soc/intel/cannonlake: Set DISB after Dram init
DRAM Initialization Scratchpad Bit needs to be set after Dram Initialization finished, according to Cannonlake PCH-LP EDS(#565870) chapter 5.3.1. BUG=None Change-Id: I16dd3787cb743bc5b7492042f3c3757534e1a51c Signed-off-by: Lijian Zhao <lijian.zhao@intel.com> Reviewed-on: https://review.coreboot.org/25704 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Subrata Banik <subrata.banik@intel.com> Reviewed-by: Kin Wai Ng <kin.wai.ng@intel.com>
This commit is contained in:
		
				
					committed by
					
						 Patrick Georgi
						Patrick Georgi
					
				
			
			
				
	
			
			
			
						parent
						
							afabaede2c
						
					
				
				
					commit
					26be35a507
				
			| @@ -128,6 +128,21 @@ const char *const *soc_std_gpe_sts_array(size_t *a) | |||||||
| 	return gpe_sts_bits; | 	return gpe_sts_bits; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void pmc_set_disb(void) | ||||||
|  | { | ||||||
|  | 	/* Set the DISB after DRAM init */ | ||||||
|  | 	uint8_t disb_val; | ||||||
|  | 	/* Only care about bits [23:16] of register GEN_PMCON_A */ | ||||||
|  | 	uint8_t *addr = (void *)(pmc_mmio_regs() + GEN_PMCON_A + 2); | ||||||
|  |  | ||||||
|  | 	disb_val = read8(addr); | ||||||
|  | 	disb_val |= (DISB >> 16); | ||||||
|  |  | ||||||
|  | 	/* Don't clear bits that are write-1-to-clear */ | ||||||
|  | 	disb_val &= ~((MS4V | SUS_PWR_FLR) >> 16); | ||||||
|  | 	write8(addr, disb_val); | ||||||
|  | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * PMC controller gets hidden from PCI bus |  * PMC controller gets hidden from PCI bus | ||||||
|  * during FSP-Silicon init call. Hence PWRMBASE |  * during FSP-Silicon init call. Hence PWRMBASE | ||||||
|   | |||||||
| @@ -123,6 +123,7 @@ asmlinkage void car_stage_entry(void) | |||||||
| 	timestamp_add_now(TS_START_ROMSTAGE); | 	timestamp_add_now(TS_START_ROMSTAGE); | ||||||
| 	s3wake = pmc_fill_power_state(ps) == ACPI_S3; | 	s3wake = pmc_fill_power_state(ps) == ACPI_S3; | ||||||
| 	fsp_memory_init(s3wake); | 	fsp_memory_init(s3wake); | ||||||
|  | 	pmc_set_disb(); | ||||||
| 	if (!s3wake) | 	if (!s3wake) | ||||||
| 		save_dimm_info(); | 		save_dimm_info(); | ||||||
| 	if (postcar_frame_init(&pcf, 1 * KiB)) | 	if (postcar_frame_init(&pcf, 1 * KiB)) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user