blob: 046c351f774b959546f8cb134eb3de54d836ae81 [file] [log] [blame]
Felix Held3c44c622022-01-10 20:57:29 +01001/* SPDX-License-Identifier: GPL-2.0-only */
2
Felix Held3c44c622022-01-10 20:57:29 +01003#include <acpi/acpi.h>
4#include <amdblocks/acpimmio.h>
5#include <amdblocks/memmap.h>
6#include <amdblocks/pmlib.h>
Martin Roth81804272022-11-20 20:30:18 -07007#include <amdblocks/post_codes.h>
Martin Roth300338f2022-10-14 14:55:25 -06008#include <amdblocks/stb.h>
Felix Held3c44c622022-01-10 20:57:29 +01009#include <console/console.h>
Elyes Haouasf743e0c2022-10-31 13:46:00 +010010#include <cpu/cpu.h>
Felix Held3c44c622022-01-10 20:57:29 +010011#include <fsp/api.h>
12#include <program_loading.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020013#include <romstage_common.h>
Felix Held3c44c622022-01-10 20:57:29 +010014
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020015void __noreturn romstage_main(void)
Felix Held3c44c622022-01-10 20:57:29 +010016{
Martin Roth81804272022-11-20 20:30:18 -070017 post_code(POST_ROMSTAGE_MAIN);
Felix Held3c44c622022-01-10 20:57:29 +010018
Martin Roth300338f2022-10-14 14:55:25 -060019 if (CONFIG(WRITE_STB_BUFFER_TO_CONSOLE))
20 write_stb_to_console();
21
Felix Held3c44c622022-01-10 20:57:29 +010022 /* Snapshot chipset state prior to any FSP call */
23 fill_chipset_state();
24
25 fsp_memory_init(acpi_is_wakeup_s3());
26
27 /* Fixup settings FSP-M should not be changing */
28 fch_disable_legacy_dma_io();
29
30 memmap_stash_early_dram_usage();
31
32 run_ramstage();
Felix Held3c44c622022-01-10 20:57:29 +010033}