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:
parent
428a682abe
commit
1b33205909
3 changed files with 8 additions and 0 deletions
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue