soc/amd/common: add and use fch_enable_ioapic_decode

The default value of this bit is 0, so set it right before calling
setup_ioapic to make sure that it's set and not to have to rely on FSP
doing the right thing.

Change-Id: Ife886451a6927965769282fc5644c2085abb9585
Signed-off-by: Felix Held <felix-coreboot@felixheld.de>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/50513
Reviewed-by: Raul Rangel <rrangel@chromium.org>
Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Felix Held 2021-02-11 03:01:18 +01:00 committed by Martin Roth
parent 428a682abe
commit 1b33205909
3 changed files with 8 additions and 0 deletions

View file

@ -74,6 +74,11 @@ void fch_io_enable_legacy_io(void)
pm_io_write32(PM_DECODE_EN, pm_io_read32(PM_DECODE_EN) | LEGACY_IO_EN); pm_io_write32(PM_DECODE_EN, pm_io_read32(PM_DECODE_EN) | LEGACY_IO_EN);
} }
void fch_enable_ioapic_decode(void)
{
pm_write32(PM_DECODE_EN, pm_read32(PM_DECODE_EN) | FCH_IOAPIC_EN);
}
/* PM registers are accessed a byte at a time via CD6/CD7 */ /* PM registers are accessed a byte at a time via CD6/CD7 */
uint8_t pm_io_read8(uint8_t reg) uint8_t pm_io_read8(uint8_t reg)
{ {

View file

@ -17,6 +17,7 @@
#define PM_DECODE_EN 0x00 #define PM_DECODE_EN 0x00
#define SMBUS_ASF_IO_BASE_SHIFT 8 #define SMBUS_ASF_IO_BASE_SHIFT 8
#define SMBUS_ASF_IO_BASE_MASK (0xff << SMBUS_ASF_IO_BASE_SHIFT) #define SMBUS_ASF_IO_BASE_MASK (0xff << SMBUS_ASF_IO_BASE_SHIFT)
#define FCH_IOAPIC_EN (1 << 5)
#define SMBUS_ASF_IO_EN (1 << 4) #define SMBUS_ASF_IO_EN (1 << 4)
#define CF9_IO_EN (1 << 1) #define CF9_IO_EN (1 << 1)
#define LEGACY_IO_EN (1 << 0) #define LEGACY_IO_EN (1 << 0)
@ -75,6 +76,7 @@ void enable_acpimmio_decode_pm04(void);
void fch_enable_cf9_io(void); void fch_enable_cf9_io(void);
void fch_enable_legacy_io(void); void fch_enable_legacy_io(void);
void fch_io_enable_legacy_io(void); void fch_io_enable_legacy_io(void);
void fch_enable_ioapic_decode(void);
/* Access PM registers using IO cycles */ /* Access PM registers using IO cycles */
uint8_t pm_io_read8(uint8_t reg); uint8_t pm_io_read8(uint8_t reg);

View file

@ -11,6 +11,7 @@
static void sm_init(struct device *dev) static void sm_init(struct device *dev)
{ {
fch_enable_ioapic_decode();
setup_ioapic(VIO_APIC_VADDR, CONFIG_MAX_CPUS); setup_ioapic(VIO_APIC_VADDR, CONFIG_MAX_CPUS);
} }