sb/intel/common/spi: Add Baytrail/Braswell support
The mechanism for getting the SPIBAR is little different. Tested on Intel Minnowboard Turbot. Change-Id: Ib14f185eab8bf708ad82b06c7a7ce586744318fd Signed-off-by: Arthur Heymans <arthur@aheymans.xyz> Reviewed-on: https://review.coreboot.org/c/coreboot/+/36342 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Nico Huber <nico.h@gmx.de>
This commit is contained in:
parent
a3eb125238
commit
47a6603f34
9 changed files with 55 additions and 19 deletions
|
@ -20,7 +20,7 @@ config CPU_SPECIFIC_OPTIONS
|
||||||
select HAVE_SMI_HANDLER
|
select HAVE_SMI_HANDLER
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RESET
|
select SOUTHBRIDGE_INTEL_COMMON_RESET
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RTC
|
select SOUTHBRIDGE_INTEL_COMMON_RTC
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9
|
||||||
select HAVE_USBDEBUG
|
select HAVE_USBDEBUG
|
||||||
select IOAPIC
|
select IOAPIC
|
||||||
select REG_SCRIPT
|
select REG_SCRIPT
|
||||||
|
|
|
@ -27,7 +27,7 @@ config SOUTH_BRIDGE_OPTIONS # dummy
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_FINALIZE
|
select SOUTHBRIDGE_INTEL_COMMON_FINALIZE
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RTC
|
select SOUTHBRIDGE_INTEL_COMMON_RTC
|
||||||
|
|
|
@ -24,6 +24,18 @@ config SOUTHBRIDGE_INTEL_COMMON_SPI
|
||||||
select SPI_FLASH
|
select SPI_FLASH
|
||||||
select BOOT_DEVICE_SUPPORTS_WRITES
|
select BOOT_DEVICE_SUPPORTS_WRITES
|
||||||
|
|
||||||
|
config SOUTHBRIDGE_INTEL_COMMON_SPI_ICH7
|
||||||
|
def_bool n
|
||||||
|
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
||||||
|
|
||||||
|
config SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9
|
||||||
|
def_bool n
|
||||||
|
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
||||||
|
|
||||||
|
config SOUTHBRIDGE_INTEL_COMMON_SPI_SILVERMONT
|
||||||
|
def_bool n
|
||||||
|
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
||||||
|
|
||||||
config SOUTHBRIDGE_INTEL_COMMON_PIRQ_ACPI_GEN
|
config SOUTHBRIDGE_INTEL_COMMON_PIRQ_ACPI_GEN
|
||||||
def_bool n
|
def_bool n
|
||||||
|
|
||||||
|
|
|
@ -271,11 +271,36 @@ static void ich_set_bbar(uint32_t minaddr)
|
||||||
#define MENU_BYTES member_size(struct ich9_spi_regs, opmenu)
|
#define MENU_BYTES member_size(struct ich9_spi_regs, opmenu)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define RCBA 0xf0
|
||||||
|
#define SBASE 0x54
|
||||||
|
|
||||||
|
#ifdef __SIMPLE_DEVICE__
|
||||||
|
static void *get_spi_bar(pci_devfn_t dev)
|
||||||
|
#else
|
||||||
|
static void *get_spi_bar(struct device *dev)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
uintptr_t rcba; /* Root Complex Register Block */
|
||||||
|
uintptr_t sbase;
|
||||||
|
|
||||||
|
if (CONFIG(SOUTHBRIDGE_INTEL_I82801GX)) {
|
||||||
|
rcba = pci_read_config32(dev, RCBA);
|
||||||
|
return (void *)((rcba & 0xffffc000) + 0x3020);
|
||||||
|
}
|
||||||
|
if (CONFIG(SOUTHBRIDGE_INTEL_COMMON_SPI_SILVERMONT)) {
|
||||||
|
sbase = pci_read_config32(dev, SBASE);
|
||||||
|
sbase &= ~0x1ff;
|
||||||
|
return (void *)sbase;
|
||||||
|
}
|
||||||
|
if (CONFIG(SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9)) {
|
||||||
|
rcba = pci_read_config32(dev, RCBA);
|
||||||
|
return (void *)((rcba & 0xffffc000) + 0x3800);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void spi_init(void)
|
void spi_init(void)
|
||||||
{
|
{
|
||||||
struct ich_spi_controller *cntlr = car_get_var_ptr(&g_cntlr);
|
struct ich_spi_controller *cntlr = car_get_var_ptr(&g_cntlr);
|
||||||
uint8_t *rcrb; /* Root Complex Register Block */
|
|
||||||
uint32_t rcba; /* Root Complex Base Address */
|
|
||||||
uint8_t bios_cntl;
|
uint8_t bios_cntl;
|
||||||
struct ich9_spi_regs *ich9_spi;
|
struct ich9_spi_regs *ich9_spi;
|
||||||
struct ich7_spi_regs *ich7_spi;
|
struct ich7_spi_regs *ich7_spi;
|
||||||
|
@ -287,11 +312,8 @@ void spi_init(void)
|
||||||
struct device *dev = pcidev_on_root(31, 0);
|
struct device *dev = pcidev_on_root(31, 0);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
rcba = pci_read_config32(dev, 0xf0);
|
|
||||||
/* Bits 31-14 are the base address, 13-1 are reserved, 0 is enable. */
|
|
||||||
rcrb = (uint8_t *)(rcba & 0xffffc000);
|
|
||||||
if (CONFIG(SOUTHBRIDGE_INTEL_I82801GX)) {
|
if (CONFIG(SOUTHBRIDGE_INTEL_I82801GX)) {
|
||||||
ich7_spi = (struct ich7_spi_regs *)(rcrb + 0x3020);
|
ich7_spi = get_spi_bar(dev);
|
||||||
cntlr->ich7_spi = ich7_spi;
|
cntlr->ich7_spi = ich7_spi;
|
||||||
cntlr->opmenu = ich7_spi->opmenu;
|
cntlr->opmenu = ich7_spi->opmenu;
|
||||||
cntlr->menubytes = sizeof(ich7_spi->opmenu);
|
cntlr->menubytes = sizeof(ich7_spi->opmenu);
|
||||||
|
@ -306,7 +328,7 @@ void spi_init(void)
|
||||||
cntlr->fpr = &ich7_spi->pbr[0];
|
cntlr->fpr = &ich7_spi->pbr[0];
|
||||||
cntlr->fpr_max = 3;
|
cntlr->fpr_max = 3;
|
||||||
} else {
|
} else {
|
||||||
ich9_spi = (struct ich9_spi_regs *)(rcrb + 0x3800);
|
ich9_spi = get_spi_bar(dev);
|
||||||
cntlr->ich9_spi = ich9_spi;
|
cntlr->ich9_spi = ich9_spi;
|
||||||
hsfs = readw_(&ich9_spi->hsfs);
|
hsfs = readw_(&ich9_spi->hsfs);
|
||||||
cntlr->hsfs = hsfs;
|
cntlr->hsfs = hsfs;
|
||||||
|
@ -333,12 +355,14 @@ void spi_init(void)
|
||||||
|
|
||||||
ich_set_bbar(0);
|
ich_set_bbar(0);
|
||||||
|
|
||||||
|
if (CONFIG(SOUTHBRIDGE_INTEL_I82801GX) || CONFIG(SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9)) {
|
||||||
/* Disable the BIOS write protect so write commands are allowed. */
|
/* Disable the BIOS write protect so write commands are allowed. */
|
||||||
bios_cntl = pci_read_config8(dev, 0xdc);
|
bios_cntl = pci_read_config8(dev, 0xdc);
|
||||||
/* Deassert SMM BIOS Write Protect Disable. */
|
/* Deassert SMM BIOS Write Protect Disable. */
|
||||||
bios_cntl &= ~(1 << 5);
|
bios_cntl &= ~(1 << 5);
|
||||||
pci_write_config8(dev, 0xdc, bios_cntl | 0x1);
|
pci_write_config8(dev, 0xdc, bios_cntl | 0x1);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static int spi_locked(void)
|
static int spi_locked(void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -22,7 +22,7 @@ config SOUTHBRIDGE_INTEL_I82801GX
|
||||||
select COMMON_FADT
|
select COMMON_FADT
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_GPIO
|
select SOUTHBRIDGE_INTEL_COMMON_GPIO
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI if BOOT_DEVICE_SPI_FLASH
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH7 if BOOT_DEVICE_SPI_FLASH
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
||||||
select HAVE_INTEL_CHIPSET_LOCKDOWN
|
select HAVE_INTEL_CHIPSET_LOCKDOWN
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
config SOUTHBRIDGE_INTEL_I82801IX
|
config SOUTHBRIDGE_INTEL_I82801IX
|
||||||
bool
|
bool
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI if !BOARD_EMULATION_QEMU_X86_Q35
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9 if !BOARD_EMULATION_QEMU_X86_Q35
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RTC
|
select SOUTHBRIDGE_INTEL_COMMON_RTC
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
config SOUTHBRIDGE_INTEL_I82801JX
|
config SOUTHBRIDGE_INTEL_I82801JX
|
||||||
bool
|
bool
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
||||||
|
|
|
@ -29,7 +29,7 @@ config SOUTH_BRIDGE_OPTIONS # dummy
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_FINALIZE
|
select SOUTHBRIDGE_INTEL_COMMON_FINALIZE
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
select SOUTHBRIDGE_INTEL_COMMON_RCBA_PIRQ
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMM
|
select SOUTHBRIDGE_INTEL_COMMON_SMM
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
select SOUTHBRIDGE_INTEL_COMMON_PMBASE
|
||||||
|
|
|
@ -22,7 +22,7 @@ config SOUTH_BRIDGE_OPTIONS # dummy
|
||||||
def_bool y
|
def_bool y
|
||||||
select ACPI_INTEL_HARDWARE_SLEEP_VALUES
|
select ACPI_INTEL_HARDWARE_SLEEP_VALUES
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
select SOUTHBRIDGE_INTEL_COMMON_SMBUS
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_SPI
|
select SOUTHBRIDGE_INTEL_COMMON_SPI_ICH9
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_ACPI_MADT
|
select SOUTHBRIDGE_INTEL_COMMON_ACPI_MADT
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_FINALIZE
|
select SOUTHBRIDGE_INTEL_COMMON_FINALIZE
|
||||||
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
select SOUTHBRIDGE_INTEL_COMMON_PMCLIB
|
||||||
|
|
Loading…
Reference in a new issue