soc/amd/genoa_poc: rely less on boot state hooks

Call setup_opensil, opensil_entry, and fch_init in the right order from
the init method of the SoC's chip operations. This brings this SoC both
more in line with the other SoCs and avoids using boot state hooks for
this which also makes the sequence in which those functions are called
easier to understand. Previously the boot states were used so that
setup_opensil was run before configure_mpio which was run before
opensil_entry(SIL_TP1), but since configure_mpio is called from
setup_opensil, this is no longer necessary.

TEST=Onyx still boots to the payload and the MPIO configuration reported
from the openSIL code is still the same. The FCH init code now runs
before the resource allocation like on the AMD SoCs that rely on FSP.

Signed-off-by: Felix Held <felix-coreboot@felixheld.de>
Change-Id: Ic752635da5eaa9e333cfb927836f0d260d2ac049
Reviewed-on: https://review.coreboot.org/c/coreboot/+/79985
Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
This commit is contained in:
Felix Held 2024-01-16 00:50:46 +01:00
parent e5197e1778
commit dc12a3817a
5 changed files with 16 additions and 15 deletions

View file

@ -3,10 +3,17 @@
#include <device/device.h> #include <device/device.h>
#include <soc/southbridge.h> #include <soc/southbridge.h>
#include <soc/acpi.h> #include <soc/acpi.h>
#include <soc/southbridge.h>
#include <vendorcode/amd/opensil/genoa_poc/opensil.h>
static void soc_init(void *chip_info) static void soc_init(void *chip_info)
{ {
default_dev_ops_root.write_acpi_tables = soc_acpi_write_tables; default_dev_ops_root.write_acpi_tables = soc_acpi_write_tables;
setup_opensil();
opensil_entry(SIL_TP1);
fch_init(chip_info);
} }
static void soc_final(void *chip_info) static void soc_final(void *chip_info)

View file

@ -81,14 +81,8 @@ static void fch_init_acpi_ports(void)
configure_smi(SMITYPE_SMI_CMD_PORT, SMI_MODE_SMI); configure_smi(SMITYPE_SMI_CMD_PORT, SMI_MODE_SMI);
} }
static void fch_init(void *unused) void fch_init(void *chip_info)
{ {
set_pci_irqs(); set_pci_irqs();
fch_init_acpi_ports(); fch_init_acpi_ports();
} }
/*
* Hook this function into the PCI state machine on entry into BS_DEV_ENABLE.
* TODO: can this be done without using BOOT_STATE_INIT_ENTRY?
*/
BOOT_STATE_INIT_ENTRY(BS_DEV_ENABLE, BS_ON_ENTRY, fch_init, NULL);

View file

@ -117,5 +117,6 @@
void fch_pre_init(void); void fch_pre_init(void);
void fch_early_init(void); void fch_early_init(void);
void fch_init(void *chip_info);
#endif /* AMD_GENOA_POC_SOUTHBRIDGE_H */ #endif /* AMD_GENOA_POC_SOUTHBRIDGE_H */

View file

@ -4,6 +4,7 @@
#define _OPENSIL_H_ #define _OPENSIL_H_
#include <acpi/acpi.h> #include <acpi/acpi.h>
#include <xSIM-api.h>
void SIL_STATUS_report(const char *function, const int status); void SIL_STATUS_report(const char *function, const int status);
// Add the memory map to dev, starting at index idx, returns last use idx // Add the memory map to dev, starting at index idx, returns last use idx
@ -13,4 +14,7 @@ void opensil_fill_fadt_io_ports(acpi_fadt_t *fadt);
void configure_mpio(void); void configure_mpio(void);
void setup_opensil(void);
void opensil_entry(SIL_TIMEPOINT timepoint);
#endif #endif

View file

@ -112,7 +112,7 @@ static void configure_sata(void)
} }
} }
static void setup_opensil(void *unused) void setup_opensil(void)
{ {
const SIL_STATUS debug_ret = SilDebugSetup(HostDebugService); const SIL_STATUS debug_ret = SilDebugSetup(HostDebugService);
SIL_STATUS_report("SilDebugSetup", debug_ret); SIL_STATUS_report("SilDebugSetup", debug_ret);
@ -129,9 +129,7 @@ static void setup_opensil(void *unused)
configure_mpio(); configure_mpio();
} }
BOOT_STATE_INIT_ENTRY(BS_DEV_INIT_CHIPS, BS_ON_ENTRY, setup_opensil, NULL); void opensil_entry(SIL_TIMEPOINT timepoint)
static void opensil_entry(void *timepoint)
{ {
SIL_STATUS ret; SIL_STATUS ret;
SIL_TIMEPOINT tp = (uintptr_t)timepoint; SIL_TIMEPOINT tp = (uintptr_t)timepoint;
@ -162,7 +160,4 @@ static void opensil_entry(void *timepoint)
} }
} }
/* TODO: look into calling these functions from some SoC device operations instead of using /* TODO: also call timepoints 2 and 3 from coreboot. Are they NOOP? */
* BOOT_STATE_INIT_ENTRY */
BOOT_STATE_INIT_ENTRY(BS_DEV_INIT_CHIPS, BS_ON_EXIT, opensil_entry, (void *)SIL_TP1);
/* TODO add other timepoints later. Are they NOOP? */