blob: efa256fb1489a44b6d72987e8add5895ee04ceeb [file] [log] [blame]
Angel Ponsae593872020-04-04 18:50:57 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Marshall Dawson9df969a2017-07-25 18:46:46 -06002
Arthur Heymansbab9e2e2021-05-29 07:30:33 +02003#include <acpi/acpi.h>
Kyösti Mälkki021c6212021-01-26 11:28:47 +02004#include <amdblocks/acpi.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +02005#include <amdblocks/agesawrapper_call.h>
Elyes Haouasf743e0c2022-10-31 13:46:00 +01006#include <amdblocks/agesawrapper.h>
Michał Żygowski5a662022019-12-02 17:02:00 +01007#include <amdblocks/biosram.h>
Martin Roth81804272022-11-20 20:30:18 -07008#include <amdblocks/post_codes.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +02009#include <amdblocks/psp.h>
Kyösti Mälkkia963acd2019-08-16 20:34:25 +030010#include <arch/romstage.h>
Marshall Dawson9df969a2017-07-25 18:46:46 -060011#include <cbmem.h>
Marshall Dawson18b477e2017-09-21 12:27:12 -060012#include <commonlib/helpers.h>
Marshall Dawson9df969a2017-07-25 18:46:46 -060013#include <console/console.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020014#include <cpu/amd/mtrr.h>
Elyes Haouasf743e0c2022-10-31 13:46:00 +010015#include <cpu/cpu.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020016#include <cpu/x86/msr.h>
17#include <cpu/x86/mtrr.h>
18#include <cpu/x86/smm.h>
Marshall Dawson3e4e4c52017-11-10 16:08:37 -070019#include <device/device.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020020#include <device/pci_ops.h>
Daniel Kurtzc6c89722018-05-24 17:57:37 -060021#include <elog.h>
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020022#include <program_loading.h>
23#include <romstage_common.h>
24#include <romstage_handoff.h>
Marshall Dawson9df969a2017-07-25 18:46:46 -060025#include <soc/northbridge.h>
Felix Helddba32292020-03-31 23:54:44 +020026#include <soc/pci_devs.h>
Marc Jonesdfeb1c42017-08-07 19:08:24 -060027#include <soc/southbridge.h>
Arthur Heymans796147f2022-02-15 10:59:41 +010028#include <stdint.h>
Marshall Dawson9df969a2017-07-25 18:46:46 -060029
Elyes HAOUASc3385072019-03-21 15:38:06 +010030#include "chip.h"
31
Kyösti Mälkki9e591c42021-01-09 12:37:25 +020032void __weak mainboard_romstage_entry(void)
Martin Roth2c3e3ef2018-04-11 16:35:08 -060033{
34 /* By default, don't do anything */
35}
36
Raul E Rangel873b4e72018-06-12 10:53:55 -060037static void agesa_call(void)
38{
Martin Roth81804272022-11-20 20:30:18 -070039 post_code(POST_AGESA_AMDINITRESET);
Kyösti Mälkki6e512c42018-06-14 06:57:05 +030040 do_agesawrapper(AMD_INIT_RESET, "amdinitreset");
Raul E Rangel873b4e72018-06-12 10:53:55 -060041
Martin Roth81804272022-11-20 20:30:18 -070042 post_code(POST_AGESA_AMDINITEARLY);
Raul E Rangel873b4e72018-06-12 10:53:55 -060043 /* APs will not exit amdinitearly */
Kyösti Mälkki6e512c42018-06-14 06:57:05 +030044 do_agesawrapper(AMD_INIT_EARLY, "amdinitearly");
Raul E Rangel873b4e72018-06-12 10:53:55 -060045}
46
47static void bsp_agesa_call(void)
48{
49 set_ap_entry_ptr(agesa_call); /* indicate the path to the AP */
50 agesa_call();
51}
Arthur Heymansbab9e2e2021-05-29 07:30:33 +020052void __noreturn romstage_main(void)
Marshall Dawson9df969a2017-07-25 18:46:46 -060053{
Marshall Dawsona7bfbbe2017-09-13 17:24:53 -060054 msr_t base, mask;
55 msr_t mtrr_cap = rdmsr(MTRR_CAP_MSR);
56 int vmtrrs = mtrr_cap.lo & MTRR_CAP_VCNT;
Kyösti Mälkki9e591c42021-01-09 12:37:25 +020057 int s3_resume = acpi_is_wakeup_s3();
Marshall Dawsona7bfbbe2017-09-13 17:24:53 -060058 int i;
59
Felix Helddba32292020-03-31 23:54:44 +020060 soc_enable_psp_early();
Julius Wernercd49cce2019-03-05 16:53:33 -080061 if (CONFIG(SOC_AMD_PSP_SELECTABLE_SMU_FW))
Felix Helddba32292020-03-31 23:54:44 +020062 psp_load_named_blob(BLOB_SMU_FW, "smu_fw");
Raul E Rangel873b4e72018-06-12 10:53:55 -060063
Kyösti Mälkki9e591c42021-01-09 12:37:25 +020064 mainboard_romstage_entry();
Kyösti Mälkki7f50afb2019-09-11 17:12:26 +030065 elog_boot_notify(s3_resume);
Raul E Rangel873b4e72018-06-12 10:53:55 -060066
67 bsp_agesa_call();
68
Marshall Dawson8f2a7e02017-11-01 11:44:48 -060069 if (!s3_resume) {
Martin Roth81804272022-11-20 20:30:18 -070070 post_code(POST_AGESA_AMDINITPOST);
Kyösti Mälkki6e512c42018-06-14 06:57:05 +030071 do_agesawrapper(AMD_INIT_POST, "amdinitpost");
Marshall Dawson9df969a2017-07-25 18:46:46 -060072
Martin Roth81804272022-11-20 20:30:18 -070073 post_code(POST_AGESA_AMDINITPOST_DONE);
Marshall Dawson8f2a7e02017-11-01 11:44:48 -060074 /*
75 * TODO: This is a hack to work around current AGESA behavior.
76 * AGESA needs to change to reflect that coreboot owns
77 * the MTRRs.
78 *
79 * After setting up DRAM, AGESA also completes the configuration
80 * of the MTRRs, setting regions to WB. Anything written to
Elyes HAOUASba4dbf82021-01-16 15:02:17 +010081 * memory between now and when CAR is dismantled will be
Marshall Dawson8f2a7e02017-11-01 11:44:48 -060082 * in cache and lost. For now, set the regions UC to ensure
83 * the writes get to DRAM.
84 */
85 for (i = 0 ; i < vmtrrs ; i++) {
86 base = rdmsr(MTRR_PHYS_BASE(i));
87 mask = rdmsr(MTRR_PHYS_MASK(i));
88 if (!(mask.lo & MTRR_PHYS_MASK_VALID))
89 continue;
Marshall Dawsona7bfbbe2017-09-13 17:24:53 -060090
Marshall Dawson8f2a7e02017-11-01 11:44:48 -060091 if ((base.lo & 0x7) == MTRR_TYPE_WRBACK) {
92 base.lo &= ~0x7;
93 base.lo |= MTRR_TYPE_UNCACHEABLE;
94 wrmsr(MTRR_PHYS_BASE(i), base);
95 }
Marshall Dawsona7bfbbe2017-09-13 17:24:53 -060096 }
Marshall Dawson8f2a7e02017-11-01 11:44:48 -060097 /* Disable WB from to region 4GB-TOM2. */
98 msr_t sys_cfg = rdmsr(SYSCFG_MSR);
99 sys_cfg.lo &= ~SYSCFG_MSR_TOM2WB;
100 wrmsr(SYSCFG_MSR, sys_cfg);
101 } else {
102 printk(BIOS_INFO, "S3 detected\n");
Martin Roth81804272022-11-20 20:30:18 -0700103 post_code(POST_AGESA_AMDINITRESUME);
Kyösti Mälkki6e512c42018-06-14 06:57:05 +0300104 do_agesawrapper(AMD_INIT_RESUME, "amdinitresume");
Marshall Dawson8f2a7e02017-11-01 11:44:48 -0600105
Martin Roth81804272022-11-20 20:30:18 -0700106 post_code(POST_AGESA_AMDINITRESUME_DONE);
Marshall Dawsona7bfbbe2017-09-13 17:24:53 -0600107 }
Marshall Dawson9df969a2017-07-25 18:46:46 -0600108
Martin Roth81804272022-11-20 20:30:18 -0700109 post_code(POST_PSP_NOTIFY_DRAM);
Marshall Dawsona7bfbbe2017-09-13 17:24:53 -0600110 psp_notify_dram();
111
Martin Roth81804272022-11-20 20:30:18 -0700112 post_code(POST_PSP_NOTIFY_DRAM_DONE);
Marshall Dawson8f2a7e02017-11-01 11:44:48 -0600113 if (cbmem_recovery(s3_resume))
114 printk(BIOS_CRIT, "Failed to recover cbmem\n");
115 if (romstage_handoff_init(s3_resume))
116 printk(BIOS_ERR, "Failed to set romstage handoff data\n");
Marshall Dawson9df969a2017-07-25 18:46:46 -0600117
Kyösti Mälkki7cdb0472019-08-08 11:16:06 +0300118 if (CONFIG(SMM_TSEG))
119 smm_list_regions();
120
Martin Roth81804272022-11-20 20:30:18 -0700121 post_code(POST_ROMSTAGE_RUN_POSTCAR);
Arthur Heymans876a1b42022-02-15 11:06:10 +0100122 prepare_and_run_postcar();
Arthur Heymans796147f2022-02-15 10:59:41 +0100123}
Marshall Dawson18b477e2017-09-21 12:27:12 -0600124
Arthur Heymans796147f2022-02-15 10:59:41 +0100125void fill_postcar_frame(struct postcar_frame *pcf)
126{
127 uintptr_t top_of_ram = (uintptr_t)cbmem_top();
128 postcar_frame_add_mtrr(pcf, top_of_ram - 16 * MiB, 16 * MiB, MTRR_TYPE_WRBACK);
Marshall Dawson9df969a2017-07-25 18:46:46 -0600129
Subrata Banik3eff0372019-09-10 15:51:17 +0530130 /* Cache the TSEG region */
Arthur Heymans796147f2022-02-15 10:59:41 +0100131 postcar_enable_tseg_cache(pcf);
Marshall Dawson9df969a2017-07-25 18:46:46 -0600132}
Richard Spiegel67c2a7b2017-11-09 16:04:35 -0700133
134void SetMemParams(AMD_POST_PARAMS *PostParams)
135{
136 const struct soc_amd_stoneyridge_config *cfg;
Kyösti Mälkkie7377552018-06-21 16:20:55 +0300137 const struct device *dev = pcidev_path_on_root(GNB_DEVFN);
Richard Spiegel67c2a7b2017-11-09 16:04:35 -0700138
139 if (!dev || !dev->chip_info) {
Julius Wernere9665952022-01-21 17:06:20 -0800140 printk(BIOS_ERR, "Cannot find SoC devicetree config\n");
Aaron Durbin36dbf1d2017-11-10 13:16:23 -0700141 /* In case of a BIOS error, only attempt to set UMA. */
Julius Wernercd49cce2019-03-05 16:53:33 -0800142 PostParams->MemConfig.UmaMode = CONFIG(GFXUMA) ?
Aaron Durbin36dbf1d2017-11-10 13:16:23 -0700143 UMA_AUTO : UMA_NONE;
Richard Spiegel67c2a7b2017-11-09 16:04:35 -0700144 return;
145 }
146
147 cfg = dev->chip_info;
Aaron Durbin36dbf1d2017-11-10 13:16:23 -0700148
Richard Spiegel67c2a7b2017-11-09 16:04:35 -0700149 PostParams->MemConfig.EnableMemClr = cfg->dram_clear_on_reset;
Aaron Durbin36dbf1d2017-11-10 13:16:23 -0700150
151 switch (cfg->uma_mode) {
152 case UMAMODE_NONE:
153 PostParams->MemConfig.UmaMode = UMA_NONE;
154 break;
155 case UMAMODE_SPECIFIED_SIZE:
156 PostParams->MemConfig.UmaMode = UMA_SPECIFIED;
157 /* 64 KiB blocks. */
158 PostParams->MemConfig.UmaSize = cfg->uma_size / (64 * KiB);
159 break;
160 case UMAMODE_AUTO_LEGACY:
161 PostParams->MemConfig.UmaMode = UMA_AUTO;
162 PostParams->MemConfig.UmaVersion = UMA_LEGACY;
163 break;
164 case UMAMODE_AUTO_NON_LEGACY:
165 PostParams->MemConfig.UmaMode = UMA_AUTO;
166 PostParams->MemConfig.UmaVersion = UMA_NON_LEGACY;
167 break;
168 }
Richard Spiegel67c2a7b2017-11-09 16:04:35 -0700169}
Richard Spiegeldd9b1d12018-09-20 14:50:11 -0700170
171void soc_customize_init_early(AMD_EARLY_PARAMS *InitEarly)
172{
173 const struct soc_amd_stoneyridge_config *cfg;
Kyösti Mälkkie7377552018-06-21 16:20:55 +0300174 const struct device *dev = pcidev_path_on_root(GNB_DEVFN);
Richard Spiegeldd9b1d12018-09-20 14:50:11 -0700175 struct _PLATFORM_CONFIGURATION *platform;
176
177 if (!dev || !dev->chip_info) {
Julius Wernere9665952022-01-21 17:06:20 -0800178 printk(BIOS_WARNING, "Cannot find SoC devicetree"
Richard Spiegeldd9b1d12018-09-20 14:50:11 -0700179 " config, STAPM unchanged\n");
180 return;
181 }
182 cfg = dev->chip_info;
183 platform = &InitEarly->PlatformConfig;
Richard Spiegelde5d0402018-10-11 08:15:43 -0700184 if ((cfg->stapm_percent) && (cfg->stapm_time_ms) &&
185 (cfg->stapm_power_mw)) {
Richard Spiegeldd9b1d12018-09-20 14:50:11 -0700186 platform->PlatStapmConfig.CfgStapmScalar = cfg->stapm_percent;
187 platform->PlatStapmConfig.CfgStapmTimeConstant =
Richard Spiegelde5d0402018-10-11 08:15:43 -0700188 cfg->stapm_time_ms;
189 platform->PkgPwrLimitDC = cfg->stapm_power_mw;
190 platform->PkgPwrLimitAC = cfg->stapm_power_mw;
Richard Spiegeldd9b1d12018-09-20 14:50:11 -0700191 platform->PlatStapmConfig.CfgStapmBoost = StapmBoostEnabled;
192 }
193}
Kyösti Mälkki021c6212021-01-26 11:28:47 +0200194
195static void migrate_power_state(int is_recovery)
196{
197 struct chipset_power_state *state;
198 state = cbmem_add(CBMEM_ID_POWER_STATE, sizeof(*state));
199 if (state) {
200 acpi_fill_pm_gpe_state(&state->gpe_state);
201 acpi_pm_gpe_add_events_print_events();
202 }
Kyösti Mälkki021c6212021-01-26 11:28:47 +0200203}
Kyösti Mälkkifa3bc042022-03-31 07:40:10 +0300204CBMEM_CREATION_HOOK(migrate_power_state);