blob: 8aa20a8dc676fbc8b28a6a925c89fbee5ad5ba27 [file] [log] [blame]
Subrata Banik2871e0e2020-09-27 11:30:58 +05301/* SPDX-License-Identifier: GPL-2.0-only */
2
3#include <assert.h>
4#include <console/console.h>
Subrata Banik7b523a42021-09-22 16:46:16 +05305#include <cpu/intel/microcode.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +05306#include <device/device.h>
7#include <device/pci.h>
V Sowmya458708f2021-07-09 22:11:04 +05308#include <device/pci_ids.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +05309#include <fsp/api.h>
10#include <fsp/ppi/mp_service_ppi.h>
11#include <fsp/util.h>
Sean Rhodesbc35bed2021-07-13 13:36:28 +010012#include <option.h>
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060013#include <intelblocks/irq.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053014#include <intelblocks/lpss.h>
Tim Wawrzynczakab0e0812021-09-21 10:28:16 -060015#include <intelblocks/pmclib.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053016#include <intelblocks/xdci.h>
17#include <intelpch/lockdown.h>
Deepti Deshatty8e7facf2021-05-12 17:45:37 +053018#include <intelblocks/tcss.h>
Tim Wawrzynczake2b8f302021-07-19 15:35:47 -060019#include <soc/cpu.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053020#include <soc/gpio_soc_defs.h>
21#include <soc/intel/common/vbt.h>
22#include <soc/pci_devs.h>
Eric Lai5b302b22020-12-05 16:49:43 +080023#include <soc/pcie.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053024#include <soc/ramstage.h>
25#include <soc/soc_chip.h>
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060026#include <stdlib.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053027#include <string.h>
Sean Rhodesbc35bed2021-07-13 13:36:28 +010028#include <types.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053029
30/* THC assignment definition */
31#define THC_NONE 0
32#define THC_0 1
33#define THC_1 2
34
35/* SATA DEVSLP idle timeout default values */
36#define DEF_DMVAL 15
37#define DEF_DITOVAL 625
38
V Sowmya458708f2021-07-09 22:11:04 +053039/* VccIn Aux Imon IccMax values in mA */
Curtis Chenea1bb5f2021-11-25 13:17:42 +080040#define MILLIAMPS_TO_AMPS 1000
41#define ICC_MAX_TDP_45W 34250
42#define ICC_MAX_TDP_15W_28W 32000
43#define ICC_MAX_ID_ADL_M_MA 12000
V Sowmya458708f2021-07-09 22:11:04 +053044
Tim Wawrzynczakc0e82e72021-06-17 12:42:35 -060045/*
46 * ME End of Post configuration
47 * 0 - Disable EOP.
48 * 1 - Send in PEI (Applicable for FSP in API mode)
49 * 2 - Send in DXE (Not applicable for FSP in API mode)
50 */
51enum fsp_end_of_post {
52 EOP_DISABLE = 0,
53 EOP_PEI = 1,
54 EOP_DXE = 2,
55};
56
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060057static const struct slot_irq_constraints irq_constraints[] = {
58 {
59 .slot = SA_DEV_SLOT_IGD,
60 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060061 /* INTERRUPT_PIN is RO/0x01 */
62 FIXED_INT_ANY_PIRQ(SA_DEVFN_IGD, PCI_INT_A),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060063 },
64 },
65 {
66 .slot = SA_DEV_SLOT_DPTF,
67 .fns = {
68 ANY_PIRQ(SA_DEVFN_DPTF),
69 },
70 },
71 {
72 .slot = SA_DEV_SLOT_IPU,
73 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060074 /* INTERRUPT_PIN is RO/0x01, and INTERRUPT_LINE is RW,
75 but S0ix fails when not set to 16 (b/193434192) */
76 FIXED_INT_PIRQ(SA_DEVFN_IPU, PCI_INT_A, PIRQ_A),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060077 },
78 },
79 {
80 .slot = SA_DEV_SLOT_CPU_6,
81 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060082 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_0, PCI_INT_A, PIRQ_A),
83 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_2, PCI_INT_C, PIRQ_C),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060084 },
85 },
86 {
87 .slot = SA_DEV_SLOT_TBT,
88 .fns = {
89 ANY_PIRQ(SA_DEVFN_TBT0),
90 ANY_PIRQ(SA_DEVFN_TBT1),
91 ANY_PIRQ(SA_DEVFN_TBT2),
92 ANY_PIRQ(SA_DEVFN_TBT3),
93 },
94 },
95 {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060096 .slot = SA_DEV_SLOT_GNA,
97 .fns = {
98 /* INTERRUPT_PIN is RO/0x01 */
99 FIXED_INT_ANY_PIRQ(SA_DEVFN_GNA, PCI_INT_A),
100 },
101 },
102 {
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600103 .slot = SA_DEV_SLOT_TCSS,
104 .fns = {
105 ANY_PIRQ(SA_DEVFN_TCSS_XHCI),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600106 ANY_PIRQ(SA_DEVFN_TCSS_XDCI),
107 },
108 },
109 {
110 .slot = PCH_DEV_SLOT_SIO0,
111 .fns = {
112 DIRECT_IRQ(PCH_DEVFN_I2C6),
113 DIRECT_IRQ(PCH_DEVFN_I2C7),
114 ANY_PIRQ(PCH_DEVFN_THC0),
115 ANY_PIRQ(PCH_DEVFN_THC1),
116 },
117 },
118 {
119 .slot = PCH_DEV_SLOT_SIO6,
120 .fns = {
121 DIRECT_IRQ(PCH_DEVFN_UART3),
122 DIRECT_IRQ(PCH_DEVFN_UART4),
123 DIRECT_IRQ(PCH_DEVFN_UART5),
124 DIRECT_IRQ(PCH_DEVFN_UART6),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600125 },
126 },
127 {
128 .slot = PCH_DEV_SLOT_ISH,
129 .fns = {
130 DIRECT_IRQ(PCH_DEVFN_ISH),
131 DIRECT_IRQ(PCH_DEVFN_GSPI2),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600132 ANY_PIRQ(PCH_DEVFN_UFS),
133 },
134 },
135 {
136 .slot = PCH_DEV_SLOT_SIO2,
137 .fns = {
138 DIRECT_IRQ(PCH_DEVFN_GSPI3),
139 DIRECT_IRQ(PCH_DEVFN_GSPI4),
140 DIRECT_IRQ(PCH_DEVFN_GSPI5),
141 DIRECT_IRQ(PCH_DEVFN_GSPI6),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600142 },
143 },
144 {
145 .slot = PCH_DEV_SLOT_XHCI,
146 .fns = {
147 ANY_PIRQ(PCH_DEVFN_XHCI),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600148 DIRECT_IRQ(PCH_DEVFN_USBOTG),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600149 ANY_PIRQ(PCH_DEVFN_CNVI_WIFI),
150 },
151 },
152 {
153 .slot = PCH_DEV_SLOT_SIO3,
154 .fns = {
155 DIRECT_IRQ(PCH_DEVFN_I2C0),
156 DIRECT_IRQ(PCH_DEVFN_I2C1),
157 DIRECT_IRQ(PCH_DEVFN_I2C2),
158 DIRECT_IRQ(PCH_DEVFN_I2C3),
159 },
160 },
161 {
162 .slot = PCH_DEV_SLOT_CSE,
163 .fns = {
164 ANY_PIRQ(PCH_DEVFN_CSE),
165 ANY_PIRQ(PCH_DEVFN_CSE_2),
166 ANY_PIRQ(PCH_DEVFN_CSE_IDER),
167 ANY_PIRQ(PCH_DEVFN_CSE_KT),
168 ANY_PIRQ(PCH_DEVFN_CSE_3),
169 ANY_PIRQ(PCH_DEVFN_CSE_4),
170 },
171 },
172 {
173 .slot = PCH_DEV_SLOT_SATA,
174 .fns = {
175 ANY_PIRQ(PCH_DEVFN_SATA),
176 },
177 },
178 {
179 .slot = PCH_DEV_SLOT_SIO4,
180 .fns = {
181 DIRECT_IRQ(PCH_DEVFN_I2C4),
182 DIRECT_IRQ(PCH_DEVFN_I2C5),
183 DIRECT_IRQ(PCH_DEVFN_UART2),
184 },
185 },
186 {
187 .slot = PCH_DEV_SLOT_PCIE,
188 .fns = {
189 FIXED_INT_PIRQ(PCH_DEVFN_PCIE1, PCI_INT_A, PIRQ_A),
190 FIXED_INT_PIRQ(PCH_DEVFN_PCIE2, PCI_INT_B, PIRQ_B),
191 FIXED_INT_PIRQ(PCH_DEVFN_PCIE3, PCI_INT_C, PIRQ_C),
192 FIXED_INT_PIRQ(PCH_DEVFN_PCIE4, PCI_INT_D, PIRQ_D),
193 FIXED_INT_PIRQ(PCH_DEVFN_PCIE5, PCI_INT_A, PIRQ_A),
194 FIXED_INT_PIRQ(PCH_DEVFN_PCIE6, PCI_INT_B, PIRQ_B),
195 FIXED_INT_PIRQ(PCH_DEVFN_PCIE7, PCI_INT_C, PIRQ_C),
196 FIXED_INT_PIRQ(PCH_DEVFN_PCIE8, PCI_INT_D, PIRQ_D),
197 },
198 },
199 {
200 .slot = PCH_DEV_SLOT_PCIE_1,
201 .fns = {
202 FIXED_INT_PIRQ(PCH_DEVFN_PCIE9, PCI_INT_A, PIRQ_A),
203 FIXED_INT_PIRQ(PCH_DEVFN_PCIE10, PCI_INT_B, PIRQ_B),
204 FIXED_INT_PIRQ(PCH_DEVFN_PCIE11, PCI_INT_C, PIRQ_C),
205 FIXED_INT_PIRQ(PCH_DEVFN_PCIE12, PCI_INT_D, PIRQ_D),
206 },
207 },
208 {
209 .slot = PCH_DEV_SLOT_SIO5,
210 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600211 /* UART0 shares an interrupt line with TSN0, so must use
212 a PIRQ */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600213 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART0, PCI_INT_A),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600214 /* UART1 shares an interrupt line with TSN1, so must use
215 a PIRQ */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600216 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART1, PCI_INT_B),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600217 DIRECT_IRQ(PCH_DEVFN_GSPI0),
218 DIRECT_IRQ(PCH_DEVFN_GSPI1),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600219 },
220 },
221 {
222 .slot = PCH_DEV_SLOT_ESPI,
223 .fns = {
224 ANY_PIRQ(PCH_DEVFN_HDA),
225 ANY_PIRQ(PCH_DEVFN_SMBUS),
226 ANY_PIRQ(PCH_DEVFN_GBE),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600227 /* INTERRUPT_PIN is RO/0x01 */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600228 FIXED_INT_ANY_PIRQ(PCH_DEVFN_TRACEHUB, PCI_INT_A),
229 },
230 },
231};
232
233static const SI_PCH_DEVICE_INTERRUPT_CONFIG *pci_irq_to_fsp(size_t *out_count)
234{
235 const struct pci_irq_entry *entry = get_cached_pci_irqs();
236 SI_PCH_DEVICE_INTERRUPT_CONFIG *config;
237 size_t pch_total = 0;
238 size_t cfg_count = 0;
239
240 if (!entry)
241 return NULL;
242
243 /* Count PCH devices */
244 while (entry) {
245 if (PCI_SLOT(entry->devfn) >= MIN_PCH_SLOT)
246 ++pch_total;
247 entry = entry->next;
248 }
249
250 /* Convert PCH device entries to FSP format */
251 config = calloc(pch_total, sizeof(*config));
252 entry = get_cached_pci_irqs();
253 while (entry) {
254 if (PCI_SLOT(entry->devfn) < MIN_PCH_SLOT) {
255 entry = entry->next;
256 continue;
257 }
258
259 config[cfg_count].Device = PCI_SLOT(entry->devfn);
260 config[cfg_count].Function = PCI_FUNC(entry->devfn);
261 config[cfg_count].IntX = (SI_PCH_INT_PIN)entry->pin;
262 config[cfg_count].Irq = entry->irq;
263 ++cfg_count;
264
265 entry = entry->next;
266 }
267
268 *out_count = cfg_count;
269
270 return config;
271}
272
Subrata Banik2871e0e2020-09-27 11:30:58 +0530273/*
274 * Chip config parameter PcieRpL1Substates uses (UPD value + 1)
275 * because UPD value of 0 for PcieRpL1Substates means disabled for FSP.
276 * In order to ensure that mainboard setting does not disable L1 substates
277 * incorrectly, chip config parameter values are offset by 1 with 0 meaning
278 * use FSP UPD default. get_l1_substate_control() ensures that the right UPD
279 * value is set in fsp_params.
280 * 0: Use FSP UPD default
281 * 1: Disable L1 substates
282 * 2: Use L1.1
283 * 3: Use L1.2 (FSP UPD default)
284 */
285static int get_l1_substate_control(enum L1_substates_control ctl)
286{
287 if ((ctl > L1_SS_L1_2) || (ctl == L1_SS_FSP_DEFAULT))
288 ctl = L1_SS_L1_2;
289 return ctl - 1;
290}
291
V Sowmya458708f2021-07-09 22:11:04 +0530292/* This function returns the VccIn Aux Imon IccMax values for ADL-P SKU's */
293static uint16_t get_vccin_aux_imon_iccmax(void)
294{
295 uint16_t mch_id = 0;
Curtis Chenea1bb5f2021-11-25 13:17:42 +0800296 uint8_t tdp;
V Sowmya458708f2021-07-09 22:11:04 +0530297
298 if (!mch_id) {
299 struct device *dev = pcidev_path_on_root(SA_DEVFN_ROOT);
300 mch_id = dev ? pci_read_config16(dev, PCI_DEVICE_ID) : 0xffff;
301 }
302
303 switch (mch_id) {
Curtis Chen0c544612021-11-19 11:38:12 +0800304 case PCI_DEVICE_ID_INTEL_ADL_P_ID_1:
V Sowmya458708f2021-07-09 22:11:04 +0530305 case PCI_DEVICE_ID_INTEL_ADL_P_ID_3:
V Sowmya458708f2021-07-09 22:11:04 +0530306 case PCI_DEVICE_ID_INTEL_ADL_P_ID_5:
Tracy Wu697d6a82021-09-27 16:48:32 +0800307 case PCI_DEVICE_ID_INTEL_ADL_P_ID_6:
V Sowmya458708f2021-07-09 22:11:04 +0530308 case PCI_DEVICE_ID_INTEL_ADL_P_ID_7:
Curtis Chenea1bb5f2021-11-25 13:17:42 +0800309 tdp = get_cpu_tdp();
310 if (tdp == TDP_45W)
311 return ICC_MAX_TDP_45W;
312 return ICC_MAX_TDP_15W_28W;
Bora Guvendik31605952021-09-01 17:32:07 -0700313 case PCI_DEVICE_ID_INTEL_ADL_M_ID_1:
314 case PCI_DEVICE_ID_INTEL_ADL_M_ID_2:
315 return ICC_MAX_ID_ADL_M_MA;
V Sowmya458708f2021-07-09 22:11:04 +0530316 default:
317 printk(BIOS_ERR, "Unknown MCH ID: 0x%4x, skipping VccInAuxImonIccMax config\n",
318 mch_id);
319 return 0;
320 }
321}
322
Subrata Banikb03cadf2021-06-09 22:19:04 +0530323__weak void mainboard_update_soc_chip_config(struct soc_intel_alderlake_config *config)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530324{
Subrata Banikb03cadf2021-06-09 22:19:04 +0530325 /* Override settings per board. */
326}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530327
Subrata Banikb03cadf2021-06-09 22:19:04 +0530328static void fill_fsps_lpss_params(FSP_S_CONFIG *s_cfg,
329 const struct soc_intel_alderlake_config *config)
330{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530331 for (int i = 0; i < CONFIG_SOC_INTEL_I2C_DEV_MAX; i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530332 s_cfg->SerialIoI2cMode[i] = config->SerialIoI2cMode[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530333
334 for (int i = 0; i < CONFIG_SOC_INTEL_COMMON_BLOCK_GSPI_MAX; i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530335 s_cfg->SerialIoSpiMode[i] = config->SerialIoGSpiMode[i];
336 s_cfg->SerialIoSpiCsMode[i] = config->SerialIoGSpiCsMode[i];
337 s_cfg->SerialIoSpiCsState[i] = config->SerialIoGSpiCsState[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530338 }
339
340 for (int i = 0; i < CONFIG_SOC_INTEL_UART_DEV_MAX; i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530341 s_cfg->SerialIoUartMode[i] = config->SerialIoUartMode[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530342}
343
Subrata Banikb03cadf2021-06-09 22:19:04 +0530344static void fill_fsps_cpu_params(FSP_S_CONFIG *s_cfg,
345 const struct soc_intel_alderlake_config *config)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530346{
Subrata Banik99289a82020-12-22 10:54:44 +0530347 const struct microcode *microcode_file;
348 size_t microcode_len;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530349
Subrata Banikb03cadf2021-06-09 22:19:04 +0530350 /* Locate microcode and pass to FSP-S for 2nd microcode loading */
Subrata Banik7b523a42021-09-22 16:46:16 +0530351 microcode_file = intel_microcode_find();
Subrata Banik99289a82020-12-22 10:54:44 +0530352
Selma Bensaid291294d2021-10-11 16:37:36 -0700353 if (microcode_file != NULL) {
354 microcode_len = get_microcode_size(microcode_file);
355 if (microcode_len != 0) {
356 /* Update CPU Microcode patch base address/size */
357 s_cfg->MicrocodeRegionBase = (uint32_t)(uintptr_t)microcode_file;
358 s_cfg->MicrocodeRegionSize = (uint32_t)microcode_len;
359 }
Subrata Banik99289a82020-12-22 10:54:44 +0530360 }
361
Subrata Banikb03cadf2021-06-09 22:19:04 +0530362 /* Use coreboot MP PPI services if Kconfig is enabled */
363 if (CONFIG(USE_INTEL_FSP_TO_CALL_COREBOOT_PUBLISH_MP_PPI))
364 s_cfg->CpuMpPpi = (uintptr_t) mp_fill_ppi_services_data();
365}
366
367static void fill_fsps_igd_params(FSP_S_CONFIG *s_cfg,
368 const struct soc_intel_alderlake_config *config)
369{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530370 /* Load VBT before devicetree-specific config. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530371 s_cfg->GraphicsConfigPtr = (uintptr_t)vbt_get();
Subrata Banik2871e0e2020-09-27 11:30:58 +0530372
373 /* Check if IGD is present and fill Graphics init param accordingly */
Subrata Banikc0983c92021-06-15 13:02:01 +0530374 s_cfg->PeiGraphicsPeimInit = CONFIG(RUN_FSP_GOP) && is_devfn_enabled(SA_DEVFN_IGD);
375 s_cfg->LidStatus = CONFIG(RUN_FSP_GOP);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530376}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530377
Subrata Banikb03cadf2021-06-09 22:19:04 +0530378static void fill_fsps_tcss_params(FSP_S_CONFIG *s_cfg,
379 const struct soc_intel_alderlake_config *config)
380{
Furquan Shaikheafca1f2021-09-22 13:59:39 -0700381 const struct device *tcss_port_arr[] = {
382 DEV_PTR(tcss_usb3_port1),
383 DEV_PTR(tcss_usb3_port2),
384 DEV_PTR(tcss_usb3_port3),
385 DEV_PTR(tcss_usb3_port4),
386 };
387
Subrata Banikc0983c92021-06-15 13:02:01 +0530388 s_cfg->TcssAuxOri = config->TcssAuxOri;
Deepti Deshatty8e7facf2021-05-12 17:45:37 +0530389
390 /* Explicitly clear this field to avoid using defaults */
Subrata Banikc0983c92021-06-15 13:02:01 +0530391 memset(s_cfg->IomTypeCPortPadCfg, 0, sizeof(s_cfg->IomTypeCPortPadCfg));
Subrata Banik2871e0e2020-09-27 11:30:58 +0530392
393 /*
394 * Set FSPS UPD ITbtConnectTopologyTimeoutInMs with value 0. FSP will
395 * evaluate this UPD value and skip sending command. There will be no
396 * delay for command completion.
397 */
Subrata Banikc0983c92021-06-15 13:02:01 +0530398 s_cfg->ITbtConnectTopologyTimeoutInMs = 0;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530399
Subrata Banikb03cadf2021-06-09 22:19:04 +0530400 /* D3Hot and D3Cold for TCSS */
401 s_cfg->D3HotEnable = !config->TcssD3HotDisable;
402 s_cfg->D3ColdEnable = !config->TcssD3ColdDisable;
Bernardo Perez Priego421ce562021-06-09 09:40:31 -0700403
404 s_cfg->UsbTcPortEn = 0;
405 for (int i = 0; i < MAX_TYPE_C_PORTS; i++) {
Furquan Shaikheafca1f2021-09-22 13:59:39 -0700406 if (is_dev_enabled(tcss_port_arr[i]))
Bernardo Perez Priego421ce562021-06-09 09:40:31 -0700407 s_cfg->UsbTcPortEn |= BIT(i);
408 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530409}
410
411static void fill_fsps_chipset_lockdown_params(FSP_S_CONFIG *s_cfg,
412 const struct soc_intel_alderlake_config *config)
413{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530414 /* Chipset Lockdown */
Felix Singerf9d7dc72021-05-03 02:33:15 +0200415 const bool lockdown_by_fsp = get_lockdown_config() == CHIPSET_LOCKDOWN_FSP;
416 s_cfg->PchLockDownGlobalSmi = lockdown_by_fsp;
417 s_cfg->PchLockDownBiosInterface = lockdown_by_fsp;
Subrata Banik393b0932022-01-11 11:59:39 +0530418 s_cfg->PchUnlockGpioPads = lockdown_by_fsp;
Felix Singerf9d7dc72021-05-03 02:33:15 +0200419 s_cfg->RtcMemoryLock = lockdown_by_fsp;
Tim Wawrzynczak091dfa12021-08-24 09:32:09 -0600420 s_cfg->SkipPamLock = !lockdown_by_fsp;
Tim Wawrzynczakc0e82e72021-06-17 12:42:35 -0600421
422 /* coreboot will send EOP before loading payload */
423 s_cfg->EndOfPostMessage = EOP_DISABLE;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530424}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530425
Subrata Banikb03cadf2021-06-09 22:19:04 +0530426static void fill_fsps_xhci_params(FSP_S_CONFIG *s_cfg,
427 const struct soc_intel_alderlake_config *config)
428{
429 int i;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530430 /* USB */
431 for (i = 0; i < ARRAY_SIZE(config->usb2_ports); i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530432 s_cfg->PortUsb20Enable[i] = config->usb2_ports[i].enable;
433 s_cfg->Usb2PhyPetxiset[i] = config->usb2_ports[i].pre_emp_bias;
434 s_cfg->Usb2PhyTxiset[i] = config->usb2_ports[i].tx_bias;
435 s_cfg->Usb2PhyPredeemp[i] = config->usb2_ports[i].tx_emp_enable;
436 s_cfg->Usb2PhyPehalfbit[i] = config->usb2_ports[i].pre_emp_bit;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530437
438 if (config->usb2_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530439 s_cfg->Usb2OverCurrentPin[i] = config->usb2_ports[i].ocpin;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530440 else
Subrata Banikc0983c92021-06-15 13:02:01 +0530441 s_cfg->Usb2OverCurrentPin[i] = OC_SKIP;
Anil Kumarc6b65c12022-02-01 12:59:03 -0800442
443 if (config->usb2_ports[i].type_c)
444 s_cfg->PortResetMessageEnable[i] = 1;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530445 }
446
447 for (i = 0; i < ARRAY_SIZE(config->usb3_ports); i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530448 s_cfg->PortUsb30Enable[i] = config->usb3_ports[i].enable;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530449 if (config->usb3_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530450 s_cfg->Usb3OverCurrentPin[i] = config->usb3_ports[i].ocpin;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530451 else
Subrata Banikc0983c92021-06-15 13:02:01 +0530452 s_cfg->Usb3OverCurrentPin[i] = OC_SKIP;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530453
454 if (config->usb3_ports[i].tx_de_emp) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530455 s_cfg->Usb3HsioTxDeEmphEnable[i] = 1;
456 s_cfg->Usb3HsioTxDeEmph[i] = config->usb3_ports[i].tx_de_emp;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530457 }
458 if (config->usb3_ports[i].tx_downscale_amp) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530459 s_cfg->Usb3HsioTxDownscaleAmpEnable[i] = 1;
460 s_cfg->Usb3HsioTxDownscaleAmp[i] =
Subrata Banik2871e0e2020-09-27 11:30:58 +0530461 config->usb3_ports[i].tx_downscale_amp;
462 }
463 }
464
Maulik V Vaghela69353502021-04-14 14:01:02 +0530465 for (i = 0; i < ARRAY_SIZE(config->tcss_ports); i++) {
466 if (config->tcss_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530467 s_cfg->CpuUsb3OverCurrentPin[i] = config->tcss_ports[i].ocpin;
Maulik V Vaghela69353502021-04-14 14:01:02 +0530468 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530469}
Maulik V Vaghela69353502021-04-14 14:01:02 +0530470
Subrata Banikb03cadf2021-06-09 22:19:04 +0530471static void fill_fsps_xdci_params(FSP_S_CONFIG *s_cfg,
472 const struct soc_intel_alderlake_config *config)
473{
Angel Ponsc7cfe0b2021-06-23 12:39:22 +0200474 s_cfg->XdciEnable = xdci_can_enable(PCH_DEVFN_USBOTG);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530475}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530476
Subrata Banikb03cadf2021-06-09 22:19:04 +0530477static void fill_fsps_uart_params(FSP_S_CONFIG *s_cfg,
478 const struct soc_intel_alderlake_config *config)
479{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530480 /* PCH UART selection for FSP Debug */
Subrata Banikc0983c92021-06-15 13:02:01 +0530481 s_cfg->SerialIoDebugUartNumber = CONFIG_UART_FOR_CONSOLE;
482 ASSERT(ARRAY_SIZE(s_cfg->SerialIoUartAutoFlow) > CONFIG_UART_FOR_CONSOLE);
483 s_cfg->SerialIoUartAutoFlow[CONFIG_UART_FOR_CONSOLE] = 0;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530484}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530485
Subrata Banikb03cadf2021-06-09 22:19:04 +0530486static void fill_fsps_sata_params(FSP_S_CONFIG *s_cfg,
487 const struct soc_intel_alderlake_config *config)
488{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530489 /* SATA */
Subrata Banikc0983c92021-06-15 13:02:01 +0530490 s_cfg->SataEnable = is_devfn_enabled(PCH_DEVFN_SATA);
491 if (s_cfg->SataEnable) {
492 s_cfg->SataMode = config->SataMode;
493 s_cfg->SataSalpSupport = config->SataSalpSupport;
494 memcpy(s_cfg->SataPortsEnable, config->SataPortsEnable,
495 sizeof(s_cfg->SataPortsEnable));
496 memcpy(s_cfg->SataPortsDevSlp, config->SataPortsDevSlp,
497 sizeof(s_cfg->SataPortsDevSlp));
Subrata Banik2871e0e2020-09-27 11:30:58 +0530498 }
499
500 /*
Subrata Banikb03cadf2021-06-09 22:19:04 +0530501 * Power Optimizer for SATA.
502 * SataPwrOptimizeDisable is default to 0.
Subrata Banik2871e0e2020-09-27 11:30:58 +0530503 * Boards not needing the optimizers explicitly disables them by setting
504 * these disable variables to 1 in devicetree overrides.
505 */
Subrata Banikc0983c92021-06-15 13:02:01 +0530506 s_cfg->SataPwrOptEnable = !(config->SataPwrOptimizeDisable);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530507 /*
508 * Enable DEVSLP Idle Timeout settings DmVal and DitoVal.
509 * SataPortsDmVal is the DITO multiplier. Default is 15.
510 * SataPortsDitoVal is the DEVSLP Idle Timeout (DITO), Default is 625ms.
511 * The default values can be changed from devicetree.
512 */
Subrata Banikb03cadf2021-06-09 22:19:04 +0530513 for (size_t i = 0; i < ARRAY_SIZE(config->SataPortsEnableDitoConfig); i++) {
Subrata Banik2871e0e2020-09-27 11:30:58 +0530514 if (config->SataPortsEnableDitoConfig[i]) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530515 s_cfg->SataPortsDmVal[i] = config->SataPortsDmVal[i];
516 s_cfg->SataPortsDitoVal[i] = config->SataPortsDitoVal[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530517 }
518 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530519}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530520
Subrata Banikb03cadf2021-06-09 22:19:04 +0530521static void fill_fsps_thermal_params(FSP_S_CONFIG *s_cfg,
522 const struct soc_intel_alderlake_config *config)
523{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530524 /* Enable TCPU for processor thermal control */
Subrata Banikc0983c92021-06-15 13:02:01 +0530525 s_cfg->Device4Enable = is_devfn_enabled(SA_DEVFN_DPTF);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530526
527 /* Set TccActivationOffset */
Subrata Banikc0983c92021-06-15 13:02:01 +0530528 s_cfg->TccActivationOffset = config->tcc_offset;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530529}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530530
Subrata Banikb03cadf2021-06-09 22:19:04 +0530531static void fill_fsps_lan_params(FSP_S_CONFIG *s_cfg,
532 const struct soc_intel_alderlake_config *config)
533{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530534 /* LAN */
Subrata Banikc0983c92021-06-15 13:02:01 +0530535 s_cfg->PchLanEnable = is_devfn_enabled(PCH_DEVFN_GBE);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530536}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530537
Subrata Banikb03cadf2021-06-09 22:19:04 +0530538static void fill_fsps_cnvi_params(FSP_S_CONFIG *s_cfg,
539 const struct soc_intel_alderlake_config *config)
540{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530541 /* CNVi */
Subrata Banikc0983c92021-06-15 13:02:01 +0530542 s_cfg->CnviMode = is_devfn_enabled(PCH_DEVFN_CNVI_WIFI);
543 s_cfg->CnviBtCore = config->CnviBtCore;
544 s_cfg->CnviBtAudioOffload = config->CnviBtAudioOffload;
Cliff Huangbc1941f2021-02-10 17:41:41 -0800545 /* Assert if CNVi BT is enabled without CNVi being enabled. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530546 assert(s_cfg->CnviMode || !s_cfg->CnviBtCore);
Cliff Huangbc1941f2021-02-10 17:41:41 -0800547 /* Assert if CNVi BT offload is enabled without CNVi BT being enabled. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530548 assert(s_cfg->CnviBtCore || !s_cfg->CnviBtAudioOffload);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530549}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530550
Subrata Banikb03cadf2021-06-09 22:19:04 +0530551static void fill_fsps_vmd_params(FSP_S_CONFIG *s_cfg,
552 const struct soc_intel_alderlake_config *config)
553{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530554 /* VMD */
Subrata Banikc0983c92021-06-15 13:02:01 +0530555 s_cfg->VmdEnable = is_devfn_enabled(SA_DEVFN_VMD);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530556}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530557
Subrata Banikb03cadf2021-06-09 22:19:04 +0530558static void fill_fsps_thc_params(FSP_S_CONFIG *s_cfg,
559 const struct soc_intel_alderlake_config *config)
560{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530561 /* THC */
Subrata Banikc0983c92021-06-15 13:02:01 +0530562 s_cfg->ThcPort0Assignment = is_devfn_enabled(PCH_DEVFN_THC0) ? THC_0 : THC_NONE;
563 s_cfg->ThcPort1Assignment = is_devfn_enabled(PCH_DEVFN_THC1) ? THC_1 : THC_NONE;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530564}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530565
Subrata Banikb03cadf2021-06-09 22:19:04 +0530566static void fill_fsps_tbt_params(FSP_S_CONFIG *s_cfg,
567 const struct soc_intel_alderlake_config *config)
568{
Bernardo Perez Priego095f97b2021-05-18 18:39:19 -0700569 /* USB4/TBT */
Subrata Banikb03cadf2021-06-09 22:19:04 +0530570 for (int i = 0; i < ARRAY_SIZE(s_cfg->ITbtPcieRootPortEn); i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530571 s_cfg->ITbtPcieRootPortEn[i] = is_devfn_enabled(SA_DEVFN_TBT(i));
Subrata Banikb03cadf2021-06-09 22:19:04 +0530572}
Bernardo Perez Priego095f97b2021-05-18 18:39:19 -0700573
Subrata Banikb03cadf2021-06-09 22:19:04 +0530574static void fill_fsps_8254_params(FSP_S_CONFIG *s_cfg,
575 const struct soc_intel_alderlake_config *config)
576{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530577 /* Legacy 8254 timer support */
Sean Rhodesbc35bed2021-07-13 13:36:28 +0100578 bool use_8254 = get_uint_option("legacy_8254_timer", CONFIG(USE_LEGACY_8254_TIMER));
579 s_cfg->Enable8254ClockGating = !use_8254;
580 s_cfg->Enable8254ClockGatingOnS3 = !use_8254;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530581}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530582
Michael Niewöhner0e905802021-09-25 00:10:30 +0200583static void fill_fsps_pm_timer_params(FSP_S_CONFIG *s_cfg,
584 const struct soc_intel_alderlake_config *config)
585{
586 /*
587 * Legacy PM ACPI Timer (and TCO Timer)
588 * This *must* be 1 in any case to keep FSP from
589 * 1) enabling PM ACPI Timer emulation in uCode.
590 * 2) disabling the PM ACPI Timer.
591 * We handle both by ourself!
592 */
593 s_cfg->EnableTcoTimer = 1;
594}
595
Subrata Banikb03cadf2021-06-09 22:19:04 +0530596static void fill_fsps_storage_params(FSP_S_CONFIG *s_cfg,
597 const struct soc_intel_alderlake_config *config)
598{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530599 /* Enable Hybrid storage auto detection */
Subrata Banikc0983c92021-06-15 13:02:01 +0530600 s_cfg->HybridStorageMode = config->HybridStorageMode;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530601}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530602
Subrata Banikb03cadf2021-06-09 22:19:04 +0530603static void fill_fsps_pcie_params(FSP_S_CONFIG *s_cfg,
604 const struct soc_intel_alderlake_config *config)
605{
606 uint32_t enable_mask = pcie_rp_enable_mask(get_pch_pcie_rp_table());
607 for (int i = 0; i < CONFIG_MAX_PCH_ROOT_PORTS; i++) {
Eric Lai5b302b22020-12-05 16:49:43 +0800608 if (!(enable_mask & BIT(i)))
609 continue;
610 const struct pcie_rp_config *rp_cfg = &config->pch_pcie_rp[i];
Subrata Banikc0983c92021-06-15 13:02:01 +0530611 s_cfg->PcieRpL1Substates[i] =
Eric Lai5b302b22020-12-05 16:49:43 +0800612 get_l1_substate_control(rp_cfg->PcieRpL1Substates);
Subrata Banikc0983c92021-06-15 13:02:01 +0530613 s_cfg->PcieRpLtrEnable[i] = !!(rp_cfg->flags & PCIE_RP_LTR);
614 s_cfg->PcieRpAdvancedErrorReporting[i] = !!(rp_cfg->flags & PCIE_RP_AER);
615 s_cfg->PcieRpHotPlug[i] = !!(rp_cfg->flags & PCIE_RP_HOTPLUG);
616 s_cfg->PcieRpClkReqDetect[i] = !!(rp_cfg->flags & PCIE_RP_CLK_REQ_DETECT);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530617 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530618}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530619
Tim Wawrzynczakf9440522021-12-16 15:07:15 -0700620static void fill_fsps_cpu_pcie_params(FSP_S_CONFIG *s_cfg,
621 const struct soc_intel_alderlake_config *config)
622{
623 if (!CONFIG_MAX_CPU_ROOT_PORTS)
624 return;
625
626 const uint32_t enable_mask = pcie_rp_enable_mask(get_cpu_pcie_rp_table());
627 for (int i = 0; i < CONFIG_MAX_CPU_ROOT_PORTS; i++) {
628 if (!(enable_mask & BIT(i)))
629 continue;
630
631 const struct pcie_rp_config *rp_cfg = &config->cpu_pcie_rp[i];
632 s_cfg->CpuPcieRpL1Substates[i] =
633 get_l1_substate_control(rp_cfg->PcieRpL1Substates);
634 s_cfg->CpuPcieRpLtrEnable[i] = !!(rp_cfg->flags & PCIE_RP_LTR);
635 s_cfg->CpuPcieRpAdvancedErrorReporting[i] = !!(rp_cfg->flags & PCIE_RP_AER);
636 s_cfg->CpuPcieRpHotPlug[i] = !!(rp_cfg->flags & PCIE_RP_HOTPLUG);
637 s_cfg->PtmEnabled[i] = 0;
638 }
639}
640
Subrata Banikb03cadf2021-06-09 22:19:04 +0530641static void fill_fsps_misc_power_params(FSP_S_CONFIG *s_cfg,
642 const struct soc_intel_alderlake_config *config)
643{
Subrata Banikd6da4ef2021-10-07 00:39:31 +0530644 /* Skip setting D0I3 bit for all HECI devices */
645 s_cfg->DisableD0I3SettingForHeci = 1;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530646 /*
647 * Power Optimizer for DMI
648 * DmiPwrOptimizeDisable is default to 0.
649 * Boards not needing the optimizers explicitly disables them by setting
650 * these disable variables to 1 in devicetree overrides.
651 */
652 s_cfg->PchPwrOptEnable = !(config->DmiPwrOptimizeDisable);
Subrata Banikc0983c92021-06-15 13:02:01 +0530653 s_cfg->PmSupport = 1;
654 s_cfg->Hwp = 1;
655 s_cfg->Cx = 1;
656 s_cfg->PsOnEnable = 1;
V Sowmya844dcb32021-06-21 10:03:53 +0530657 /* Enable the energy efficient turbo mode */
658 s_cfg->EnergyEfficientTurbo = 1;
V Sowmyaaf429062021-06-21 10:23:33 +0530659 s_cfg->PkgCStateLimit = LIMIT_AUTO;
V Sowmya458708f2021-07-09 22:11:04 +0530660
661 /* VccIn Aux Imon IccMax. Values are in 1/4 Amp increments and range is 0-512. */
662 s_cfg->VccInAuxImonIccImax = get_vccin_aux_imon_iccmax() * 4 / MILLIAMPS_TO_AMPS;
V Sowmyac6d71662021-07-15 08:11:08 +0530663
664 /* VrConfig Settings for IA and GT domains */
665 for (size_t i = 0; i < ARRAY_SIZE(config->domain_vr_config); i++)
666 fill_vr_domain_config(s_cfg, i, &config->domain_vr_config[i]);
Tim Wawrzynczake2b8f302021-07-19 15:35:47 -0600667
Nick Vaccaro577afe62022-01-12 12:03:41 -0800668 s_cfg->PmcLpmS0ixSubStateEnableMask = get_supported_lpm_mask();
Tim Wawrzynczakab0e0812021-09-21 10:28:16 -0600669
670 /* Apply minimum assertion width settings */
671 if (config->pch_slp_s3_min_assertion_width == SLP_S3_ASSERTION_DEFAULT)
672 s_cfg->PchPmSlpS3MinAssert = SLP_S3_ASSERTION_50_MS;
673 else
674 s_cfg->PchPmSlpS3MinAssert = config->pch_slp_s3_min_assertion_width;
675
676 if (config->pch_slp_s4_min_assertion_width == SLP_S4_ASSERTION_DEFAULT)
677 s_cfg->PchPmSlpS4MinAssert = SLP_S4_ASSERTION_1S;
678 else
679 s_cfg->PchPmSlpS4MinAssert = config->pch_slp_s4_min_assertion_width;
680
681 if (config->pch_slp_sus_min_assertion_width == SLP_SUS_ASSERTION_DEFAULT)
682 s_cfg->PchPmSlpSusMinAssert = SLP_SUS_ASSERTION_4_S;
683 else
684 s_cfg->PchPmSlpSusMinAssert = config->pch_slp_sus_min_assertion_width;
685
686 if (config->pch_slp_a_min_assertion_width == SLP_A_ASSERTION_DEFAULT)
687 s_cfg->PchPmSlpAMinAssert = SLP_A_ASSERTION_2_S;
688 else
689 s_cfg->PchPmSlpAMinAssert = config->pch_slp_a_min_assertion_width;
690
691 unsigned int power_cycle_duration = config->pch_reset_power_cycle_duration;
692 if (power_cycle_duration == POWER_CYCLE_DURATION_DEFAULT)
693 power_cycle_duration = POWER_CYCLE_DURATION_4S;
694
695 s_cfg->PchPmPwrCycDur = get_pm_pwr_cyc_dur(s_cfg->PchPmSlpS4MinAssert,
696 s_cfg->PchPmSlpS3MinAssert,
697 s_cfg->PchPmSlpAMinAssert,
698 power_cycle_duration);
Ryan Lin4a48dbe2021-09-28 15:59:34 +0800699
700 /* Set PsysPmax if it is available from DT */
701 if (config->PsysPmax) {
702 printk(BIOS_DEBUG, "PsysPmax = %dW\n", config->PsysPmax);
703 /* PsysPmax is in unit of 1/8 Watt */
704 s_cfg->PsysPmax = config->PsysPmax * 8;
705 }
Subrata Banik6f1cb402021-06-09 22:11:12 +0530706}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530707
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600708static void fill_fsps_irq_params(FSP_S_CONFIG *s_cfg,
709 const struct soc_intel_alderlake_config *config)
710{
711 if (!assign_pci_irqs(irq_constraints, ARRAY_SIZE(irq_constraints)))
712 die("ERROR: Unable to assign PCI IRQs, and no _PRT table available\n");
713
714 size_t pch_count = 0;
715 const SI_PCH_DEVICE_INTERRUPT_CONFIG *upd_irqs = pci_irq_to_fsp(&pch_count);
716
717 s_cfg->DevIntConfigPtr = (UINT32)((uintptr_t)upd_irqs);
718 s_cfg->NumOfDevIntConfig = pch_count;
719 printk(BIOS_INFO, "IRQ: Using dynamically assigned PCI IO-APIC IRQs\n");
720}
721
V Sowmya418d37e2021-06-21 08:47:17 +0530722static void fill_fsps_fivr_params(FSP_S_CONFIG *s_cfg,
723 const struct soc_intel_alderlake_config *config)
724{
725 /* PCH FIVR settings override */
726 if (!config->ext_fivr_settings.configure_ext_fivr)
727 return;
728
729 s_cfg->PchFivrExtV1p05RailEnabledStates =
730 config->ext_fivr_settings.v1p05_enable_bitmap;
731
732 s_cfg->PchFivrExtV1p05RailSupportedVoltageStates =
733 config->ext_fivr_settings.v1p05_supported_voltage_bitmap;
734
735 s_cfg->PchFivrExtVnnRailEnabledStates =
736 config->ext_fivr_settings.vnn_enable_bitmap;
737
738 s_cfg->PchFivrExtVnnRailSupportedVoltageStates =
739 config->ext_fivr_settings.vnn_supported_voltage_bitmap;
740
741 s_cfg->PchFivrExtVnnRailSxEnabledStates =
Bora Guvendikfbf874f2021-10-18 14:17:41 -0700742 config->ext_fivr_settings.vnn_sx_enable_bitmap;
V Sowmya418d37e2021-06-21 08:47:17 +0530743
744 /* Convert the voltages to increments of 2.5mv */
745 s_cfg->PchFivrExtV1p05RailVoltage =
746 (config->ext_fivr_settings.v1p05_voltage_mv * 10) / 25;
747
748 s_cfg->PchFivrExtVnnRailVoltage =
749 (config->ext_fivr_settings.vnn_voltage_mv * 10) / 25;
750
751 s_cfg->PchFivrExtVnnRailSxVoltage =
752 (config->ext_fivr_settings.vnn_sx_voltage_mv * 10 / 25);
753
754 s_cfg->PchFivrExtV1p05RailIccMaximum =
755 config->ext_fivr_settings.v1p05_icc_max_ma;
756
757 s_cfg->PchFivrExtVnnRailIccMaximum =
758 config->ext_fivr_settings.vnn_icc_max_ma;
759}
760
Wisley Chend0cef2a2021-11-01 16:13:55 +0600761static void fill_fsps_fivr_rfi_params(FSP_S_CONFIG *s_cfg,
762 const struct soc_intel_alderlake_config *config)
763{
764 /* transform from Hz to 100 KHz */
765 s_cfg->FivrRfiFrequency = config->FivrRfiFrequency / (100 * KHz);
766 s_cfg->FivrSpreadSpectrum = config->FivrSpreadSpectrum;
767}
768
Wisley Chenc5103462021-11-04 18:12:58 +0600769static void fill_fsps_acoustic_params(FSP_S_CONFIG *s_cfg,
770 const struct soc_intel_alderlake_config *config)
771{
772 s_cfg->AcousticNoiseMitigation = config->AcousticNoiseMitigation;
773
774 if (s_cfg->AcousticNoiseMitigation) {
775 for (int i = 0; i < NUM_VR_DOMAINS; i++) {
776 s_cfg->FastPkgCRampDisable[i] = config->FastPkgCRampDisable[i];
777 s_cfg->SlowSlewRate[i] = config->SlowSlewRate[i];
778 }
779 }
780}
781
Subrata Banikb03cadf2021-06-09 22:19:04 +0530782static void soc_silicon_init_params(FSP_S_CONFIG *s_cfg,
783 struct soc_intel_alderlake_config *config)
784{
785 /* Override settings per board if required. */
786 mainboard_update_soc_chip_config(config);
787
V Sowmya6464c2a2021-06-25 10:20:25 +0530788 const void (*fill_fsps_params[])(FSP_S_CONFIG *s_cfg,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530789 const struct soc_intel_alderlake_config *config) = {
790 fill_fsps_lpss_params,
791 fill_fsps_cpu_params,
792 fill_fsps_igd_params,
793 fill_fsps_tcss_params,
794 fill_fsps_chipset_lockdown_params,
795 fill_fsps_xhci_params,
796 fill_fsps_xdci_params,
797 fill_fsps_uart_params,
798 fill_fsps_sata_params,
799 fill_fsps_thermal_params,
800 fill_fsps_lan_params,
801 fill_fsps_cnvi_params,
802 fill_fsps_vmd_params,
803 fill_fsps_thc_params,
804 fill_fsps_tbt_params,
805 fill_fsps_8254_params,
Michael Niewöhner0e905802021-09-25 00:10:30 +0200806 fill_fsps_pm_timer_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530807 fill_fsps_storage_params,
808 fill_fsps_pcie_params,
Tim Wawrzynczakf9440522021-12-16 15:07:15 -0700809 fill_fsps_cpu_pcie_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530810 fill_fsps_misc_power_params,
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600811 fill_fsps_irq_params,
V Sowmya418d37e2021-06-21 08:47:17 +0530812 fill_fsps_fivr_params,
Wisley Chend0cef2a2021-11-01 16:13:55 +0600813 fill_fsps_fivr_rfi_params,
Wisley Chenc5103462021-11-04 18:12:58 +0600814 fill_fsps_acoustic_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530815 };
816
817 for (size_t i = 0; i < ARRAY_SIZE(fill_fsps_params); i++)
818 fill_fsps_params[i](s_cfg, config);
819}
820
Subrata Banik6f1cb402021-06-09 22:11:12 +0530821/* UPD parameters to be initialized before SiliconInit */
822void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
823{
824 struct soc_intel_alderlake_config *config;
Subrata Banikc0983c92021-06-15 13:02:01 +0530825 FSP_S_CONFIG *s_cfg = &supd->FspsConfig;
Subrata Banik6f1cb402021-06-09 22:11:12 +0530826
827 config = config_of_soc();
Subrata Banikc0983c92021-06-15 13:02:01 +0530828 soc_silicon_init_params(s_cfg, config);
829 mainboard_silicon_init_params(s_cfg);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530830}
831
Subrata Banik2871e0e2020-09-27 11:30:58 +0530832/*
833 * Callbacks for SoC/Mainboard specific overrides for FspMultiPhaseSiInit
834 * This platform supports below MultiPhaseSIInit Phase(s):
835 * Phase | FSP return point | Purpose
836 * ------- + ------------------------------------------------ + -------------------------------
837 * 1 | After TCSS initialization completed | for TCSS specific init
838 */
839void platform_fsp_multi_phase_init_cb(uint32_t phase_index)
840{
841 switch (phase_index) {
842 case 1:
843 /* TCSS specific initialization here */
Deepti Deshatty8e7facf2021-05-12 17:45:37 +0530844 printk(BIOS_DEBUG, "FSP MultiPhaseSiInit %s/%s called\n",
845 __FILE__, __func__);
846
847 if (CONFIG(SOC_INTEL_COMMON_BLOCK_TCSS)) {
848 const config_t *config = config_of_soc();
849 tcss_configure(config->typec_aux_bias_pads);
850 }
Subrata Banik2871e0e2020-09-27 11:30:58 +0530851 break;
852 default:
853 break;
854 }
855}
856
857/* Mainboard GPIO Configuration */
Subrata Banikc0983c92021-06-15 13:02:01 +0530858__weak void mainboard_silicon_init_params(FSP_S_CONFIG *s_cfg)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530859{
860 printk(BIOS_DEBUG, "WEAK: %s/%s called\n", __FILE__, __func__);
861}