sb/intel/common/spi.c: Port to i82801gx
Offsets are a little different. Change-Id: I39199f3279a8b76e290b6693adc50dc2ac0ccf23 Signed-off-by: Arthur Heymans <arthur@aheymans.xyz> Reviewed-on: https://review.coreboot.org/21113 Reviewed-by: Nico Huber <nico.h@gmx.de> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
		
				
					committed by
					
						 Nico Huber
						Nico Huber
					
				
			
			
				
	
			
			
			
						parent
						
							524d497355
						
					
				
				
					commit
					c88e370f85
				
			| @@ -294,6 +294,7 @@ void spi_init(void) | |||||||
| 	uint8_t bios_cntl; | 	uint8_t bios_cntl; | ||||||
| 	device_t dev; | 	device_t dev; | ||||||
| 	ich9_spi_regs *ich9_spi; | 	ich9_spi_regs *ich9_spi; | ||||||
|  | 	ich7_spi_regs *ich7_spi; | ||||||
| 	uint16_t hsfs; | 	uint16_t hsfs; | ||||||
|  |  | ||||||
| #ifdef __SMM__ | #ifdef __SMM__ | ||||||
| @@ -305,6 +306,20 @@ void spi_init(void) | |||||||
| 	pci_read_config_dword(dev, 0xf0, &rcba); | 	pci_read_config_dword(dev, 0xf0, &rcba); | ||||||
| 	/* Bits 31-14 are the base address, 13-1 are reserved, 0 is enable. */ | 	/* Bits 31-14 are the base address, 13-1 are reserved, 0 is enable. */ | ||||||
| 	rcrb = (uint8_t *)(rcba & 0xffffc000); | 	rcrb = (uint8_t *)(rcba & 0xffffc000); | ||||||
|  | 	if (IS_ENABLED(CONFIG_SOUTHBRIDGE_INTEL_I82801GX)) { | ||||||
|  | 		ich7_spi = (ich7_spi_regs *)(rcrb + 0x3020); | ||||||
|  | 		cntlr.opmenu = ich7_spi->opmenu; | ||||||
|  | 		cntlr.menubytes = sizeof(ich7_spi->opmenu); | ||||||
|  | 		cntlr.optype = &ich7_spi->optype; | ||||||
|  | 		cntlr.addr = &ich7_spi->spia; | ||||||
|  | 		cntlr.data = (uint8_t *)ich7_spi->spid; | ||||||
|  | 		cntlr.databytes = sizeof(ich7_spi->spid); | ||||||
|  | 		cntlr.status = (uint8_t *)&ich7_spi->spis; | ||||||
|  | 		ichspi_lock = readw_(&ich7_spi->spis) & HSFS_FLOCKDN; | ||||||
|  | 		cntlr.control = &ich7_spi->spic; | ||||||
|  | 		cntlr.bbar = &ich7_spi->bbar; | ||||||
|  | 		cntlr.preop = &ich7_spi->preop; | ||||||
|  | 	} else { | ||||||
| 		ich9_spi = (ich9_spi_regs *)(rcrb + 0x3800); | 		ich9_spi = (ich9_spi_regs *)(rcrb + 0x3800); | ||||||
| 		cntlr.ich9_spi = ich9_spi; | 		cntlr.ich9_spi = ich9_spi; | ||||||
| 		hsfs = readw_(&ich9_spi->hsfs); | 		hsfs = readw_(&ich9_spi->hsfs); | ||||||
| @@ -321,11 +336,11 @@ void spi_init(void) | |||||||
| 		cntlr.bbar = &ich9_spi->bbar; | 		cntlr.bbar = &ich9_spi->bbar; | ||||||
| 		cntlr.preop = &ich9_spi->preop; | 		cntlr.preop = &ich9_spi->preop; | ||||||
|  |  | ||||||
| 	if (cntlr.hsfs & HSFS_FDV) | 		if (cntlr.hsfs & HSFS_FDV) { | ||||||
| 	{ |  | ||||||
| 			writel_ (4, &ich9_spi->fdoc); | 			writel_ (4, &ich9_spi->fdoc); | ||||||
| 			cntlr.flmap0 = readl_(&ich9_spi->fdod); | 			cntlr.flmap0 = readl_(&ich9_spi->fdod); | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	ich_set_bbar(0); | 	ich_set_bbar(0); | ||||||
|  |  | ||||||
| @@ -897,6 +912,9 @@ static int spi_flash_programmer_probe(const struct spi_slave *spi, | |||||||
| { | { | ||||||
| 	uint32_t flcomp; | 	uint32_t flcomp; | ||||||
|  |  | ||||||
|  | 	if (IS_ENABLED(CONFIG_SOUTHBRIDGE_INTEL_I82801GX)) | ||||||
|  | 		return spi_flash_generic_probe(spi, flash); | ||||||
|  |  | ||||||
| 	/* Try generic probing first if spi_is_multichip returns 0. */ | 	/* Try generic probing first if spi_is_multichip returns 0. */ | ||||||
| 	if (!spi_is_multichip() && !spi_flash_generic_probe(spi, flash)) | 	if (!spi_is_multichip() && !spi_flash_generic_probe(spi, flash)) | ||||||
| 		return 0; | 		return 0; | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ config SOUTHBRIDGE_INTEL_I82801GX | |||||||
| 	select USE_WATCHDOG_ON_BOOT | 	select USE_WATCHDOG_ON_BOOT | ||||||
| 	select HAVE_SMI_HANDLER | 	select HAVE_SMI_HANDLER | ||||||
| 	select COMMON_FADT | 	select COMMON_FADT | ||||||
|  | 	select SPI_FLASH | ||||||
| 	select SOUTHBRIDGE_INTEL_COMMON_GPIO | 	select SOUTHBRIDGE_INTEL_COMMON_GPIO | ||||||
| 	select SOUTHBRIDGE_INTEL_COMMON_SMBUS | 	select SOUTHBRIDGE_INTEL_COMMON_SMBUS | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ ramstage-y += sata.c | |||||||
| ramstage-y += smbus.c | ramstage-y += smbus.c | ||||||
| ramstage-y += usb.c | ramstage-y += usb.c | ||||||
| ramstage-y += usb_ehci.c | ramstage-y += usb_ehci.c | ||||||
|  | ramstage-y += ../common/spi.c | ||||||
|  |  | ||||||
| ramstage-srcs += src/mainboard/$(MAINBOARDDIR)/hda_verb.c | ramstage-srcs += src/mainboard/$(MAINBOARDDIR)/hda_verb.c | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user