blob: 9dec31c66b8bf109d992d6b38756dc36e34559e9 [file] [log] [blame]
Subrata Banik2871e0e2020-09-27 11:30:58 +05301/* SPDX-License-Identifier: GPL-2.0-only */
2
3#include <assert.h>
Subrata Banik99289a82020-12-22 10:54:44 +05304#include <cbfs.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +05305#include <console/console.h>
6#include <device/device.h>
7#include <device/pci.h>
8#include <fsp/api.h>
9#include <fsp/ppi/mp_service_ppi.h>
10#include <fsp/util.h>
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060011#include <intelblocks/irq.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053012#include <intelblocks/lpss.h>
13#include <intelblocks/xdci.h>
14#include <intelpch/lockdown.h>
15#include <intelblocks/mp_init.h>
Deepti Deshatty8e7facf2021-05-12 17:45:37 +053016#include <intelblocks/tcss.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053017#include <soc/gpio_soc_defs.h>
18#include <soc/intel/common/vbt.h>
19#include <soc/pci_devs.h>
Eric Lai5b302b22020-12-05 16:49:43 +080020#include <soc/pcie.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053021#include <soc/ramstage.h>
22#include <soc/soc_chip.h>
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060023#include <stdlib.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053024#include <string.h>
25
26/* THC assignment definition */
27#define THC_NONE 0
28#define THC_0 1
29#define THC_1 2
30
31/* SATA DEVSLP idle timeout default values */
32#define DEF_DMVAL 15
33#define DEF_DITOVAL 625
34
Tim Wawrzynczakc0e82e72021-06-17 12:42:35 -060035/*
36 * ME End of Post configuration
37 * 0 - Disable EOP.
38 * 1 - Send in PEI (Applicable for FSP in API mode)
39 * 2 - Send in DXE (Not applicable for FSP in API mode)
40 */
41enum fsp_end_of_post {
42 EOP_DISABLE = 0,
43 EOP_PEI = 1,
44 EOP_DXE = 2,
45};
46
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060047static const struct slot_irq_constraints irq_constraints[] = {
48 {
49 .slot = SA_DEV_SLOT_IGD,
50 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060051 /* INTERRUPT_PIN is RO/0x01 */
52 FIXED_INT_ANY_PIRQ(SA_DEVFN_IGD, PCI_INT_A),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060053 },
54 },
55 {
56 .slot = SA_DEV_SLOT_DPTF,
57 .fns = {
58 ANY_PIRQ(SA_DEVFN_DPTF),
59 },
60 },
61 {
62 .slot = SA_DEV_SLOT_IPU,
63 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060064 /* INTERRUPT_PIN is RO/0x01, and INTERRUPT_LINE is RW,
65 but S0ix fails when not set to 16 (b/193434192) */
66 FIXED_INT_PIRQ(SA_DEVFN_IPU, PCI_INT_A, PIRQ_A),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060067 },
68 },
69 {
70 .slot = SA_DEV_SLOT_CPU_6,
71 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060072 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_0, PCI_INT_A, PIRQ_A),
73 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_2, PCI_INT_C, PIRQ_C),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060074 },
75 },
76 {
77 .slot = SA_DEV_SLOT_TBT,
78 .fns = {
79 ANY_PIRQ(SA_DEVFN_TBT0),
80 ANY_PIRQ(SA_DEVFN_TBT1),
81 ANY_PIRQ(SA_DEVFN_TBT2),
82 ANY_PIRQ(SA_DEVFN_TBT3),
83 },
84 },
85 {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060086 .slot = SA_DEV_SLOT_GNA,
87 .fns = {
88 /* INTERRUPT_PIN is RO/0x01 */
89 FIXED_INT_ANY_PIRQ(SA_DEVFN_GNA, PCI_INT_A),
90 },
91 },
92 {
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060093 .slot = SA_DEV_SLOT_TCSS,
94 .fns = {
95 ANY_PIRQ(SA_DEVFN_TCSS_XHCI),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060096 ANY_PIRQ(SA_DEVFN_TCSS_XDCI),
97 },
98 },
99 {
100 .slot = PCH_DEV_SLOT_SIO0,
101 .fns = {
102 DIRECT_IRQ(PCH_DEVFN_I2C6),
103 DIRECT_IRQ(PCH_DEVFN_I2C7),
104 ANY_PIRQ(PCH_DEVFN_THC0),
105 ANY_PIRQ(PCH_DEVFN_THC1),
106 },
107 },
108 {
109 .slot = PCH_DEV_SLOT_SIO6,
110 .fns = {
111 DIRECT_IRQ(PCH_DEVFN_UART3),
112 DIRECT_IRQ(PCH_DEVFN_UART4),
113 DIRECT_IRQ(PCH_DEVFN_UART5),
114 DIRECT_IRQ(PCH_DEVFN_UART6),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600115 },
116 },
117 {
118 .slot = PCH_DEV_SLOT_ISH,
119 .fns = {
120 DIRECT_IRQ(PCH_DEVFN_ISH),
121 DIRECT_IRQ(PCH_DEVFN_GSPI2),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600122 ANY_PIRQ(PCH_DEVFN_UFS),
123 },
124 },
125 {
126 .slot = PCH_DEV_SLOT_SIO2,
127 .fns = {
128 DIRECT_IRQ(PCH_DEVFN_GSPI3),
129 DIRECT_IRQ(PCH_DEVFN_GSPI4),
130 DIRECT_IRQ(PCH_DEVFN_GSPI5),
131 DIRECT_IRQ(PCH_DEVFN_GSPI6),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600132 },
133 },
134 {
135 .slot = PCH_DEV_SLOT_XHCI,
136 .fns = {
137 ANY_PIRQ(PCH_DEVFN_XHCI),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600138 DIRECT_IRQ(PCH_DEVFN_USBOTG),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600139 ANY_PIRQ(PCH_DEVFN_CNVI_WIFI),
140 },
141 },
142 {
143 .slot = PCH_DEV_SLOT_SIO3,
144 .fns = {
145 DIRECT_IRQ(PCH_DEVFN_I2C0),
146 DIRECT_IRQ(PCH_DEVFN_I2C1),
147 DIRECT_IRQ(PCH_DEVFN_I2C2),
148 DIRECT_IRQ(PCH_DEVFN_I2C3),
149 },
150 },
151 {
152 .slot = PCH_DEV_SLOT_CSE,
153 .fns = {
154 ANY_PIRQ(PCH_DEVFN_CSE),
155 ANY_PIRQ(PCH_DEVFN_CSE_2),
156 ANY_PIRQ(PCH_DEVFN_CSE_IDER),
157 ANY_PIRQ(PCH_DEVFN_CSE_KT),
158 ANY_PIRQ(PCH_DEVFN_CSE_3),
159 ANY_PIRQ(PCH_DEVFN_CSE_4),
160 },
161 },
162 {
163 .slot = PCH_DEV_SLOT_SATA,
164 .fns = {
165 ANY_PIRQ(PCH_DEVFN_SATA),
166 },
167 },
168 {
169 .slot = PCH_DEV_SLOT_SIO4,
170 .fns = {
171 DIRECT_IRQ(PCH_DEVFN_I2C4),
172 DIRECT_IRQ(PCH_DEVFN_I2C5),
173 DIRECT_IRQ(PCH_DEVFN_UART2),
174 },
175 },
176 {
177 .slot = PCH_DEV_SLOT_PCIE,
178 .fns = {
179 FIXED_INT_PIRQ(PCH_DEVFN_PCIE1, PCI_INT_A, PIRQ_A),
180 FIXED_INT_PIRQ(PCH_DEVFN_PCIE2, PCI_INT_B, PIRQ_B),
181 FIXED_INT_PIRQ(PCH_DEVFN_PCIE3, PCI_INT_C, PIRQ_C),
182 FIXED_INT_PIRQ(PCH_DEVFN_PCIE4, PCI_INT_D, PIRQ_D),
183 FIXED_INT_PIRQ(PCH_DEVFN_PCIE5, PCI_INT_A, PIRQ_A),
184 FIXED_INT_PIRQ(PCH_DEVFN_PCIE6, PCI_INT_B, PIRQ_B),
185 FIXED_INT_PIRQ(PCH_DEVFN_PCIE7, PCI_INT_C, PIRQ_C),
186 FIXED_INT_PIRQ(PCH_DEVFN_PCIE8, PCI_INT_D, PIRQ_D),
187 },
188 },
189 {
190 .slot = PCH_DEV_SLOT_PCIE_1,
191 .fns = {
192 FIXED_INT_PIRQ(PCH_DEVFN_PCIE9, PCI_INT_A, PIRQ_A),
193 FIXED_INT_PIRQ(PCH_DEVFN_PCIE10, PCI_INT_B, PIRQ_B),
194 FIXED_INT_PIRQ(PCH_DEVFN_PCIE11, PCI_INT_C, PIRQ_C),
195 FIXED_INT_PIRQ(PCH_DEVFN_PCIE12, PCI_INT_D, PIRQ_D),
196 },
197 },
198 {
199 .slot = PCH_DEV_SLOT_SIO5,
200 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600201 /* UART0 shares an interrupt line with TSN0, so must use
202 a PIRQ */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600203 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART0, PCI_INT_A),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600204 /* UART1 shares an interrupt line with TSN1, so must use
205 a PIRQ */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600206 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART1, PCI_INT_B),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600207 DIRECT_IRQ(PCH_DEVFN_GSPI0),
208 DIRECT_IRQ(PCH_DEVFN_GSPI1),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600209 },
210 },
211 {
212 .slot = PCH_DEV_SLOT_ESPI,
213 .fns = {
214 ANY_PIRQ(PCH_DEVFN_HDA),
215 ANY_PIRQ(PCH_DEVFN_SMBUS),
216 ANY_PIRQ(PCH_DEVFN_GBE),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600217 /* INTERRUPT_PIN is RO/0x01 */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600218 FIXED_INT_ANY_PIRQ(PCH_DEVFN_TRACEHUB, PCI_INT_A),
219 },
220 },
221};
222
223static const SI_PCH_DEVICE_INTERRUPT_CONFIG *pci_irq_to_fsp(size_t *out_count)
224{
225 const struct pci_irq_entry *entry = get_cached_pci_irqs();
226 SI_PCH_DEVICE_INTERRUPT_CONFIG *config;
227 size_t pch_total = 0;
228 size_t cfg_count = 0;
229
230 if (!entry)
231 return NULL;
232
233 /* Count PCH devices */
234 while (entry) {
235 if (PCI_SLOT(entry->devfn) >= MIN_PCH_SLOT)
236 ++pch_total;
237 entry = entry->next;
238 }
239
240 /* Convert PCH device entries to FSP format */
241 config = calloc(pch_total, sizeof(*config));
242 entry = get_cached_pci_irqs();
243 while (entry) {
244 if (PCI_SLOT(entry->devfn) < MIN_PCH_SLOT) {
245 entry = entry->next;
246 continue;
247 }
248
249 config[cfg_count].Device = PCI_SLOT(entry->devfn);
250 config[cfg_count].Function = PCI_FUNC(entry->devfn);
251 config[cfg_count].IntX = (SI_PCH_INT_PIN)entry->pin;
252 config[cfg_count].Irq = entry->irq;
253 ++cfg_count;
254
255 entry = entry->next;
256 }
257
258 *out_count = cfg_count;
259
260 return config;
261}
262
Subrata Banik2871e0e2020-09-27 11:30:58 +0530263/*
264 * Chip config parameter PcieRpL1Substates uses (UPD value + 1)
265 * because UPD value of 0 for PcieRpL1Substates means disabled for FSP.
266 * In order to ensure that mainboard setting does not disable L1 substates
267 * incorrectly, chip config parameter values are offset by 1 with 0 meaning
268 * use FSP UPD default. get_l1_substate_control() ensures that the right UPD
269 * value is set in fsp_params.
270 * 0: Use FSP UPD default
271 * 1: Disable L1 substates
272 * 2: Use L1.1
273 * 3: Use L1.2 (FSP UPD default)
274 */
275static int get_l1_substate_control(enum L1_substates_control ctl)
276{
277 if ((ctl > L1_SS_L1_2) || (ctl == L1_SS_FSP_DEFAULT))
278 ctl = L1_SS_L1_2;
279 return ctl - 1;
280}
281
Subrata Banikb03cadf2021-06-09 22:19:04 +0530282__weak void mainboard_update_soc_chip_config(struct soc_intel_alderlake_config *config)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530283{
Subrata Banikb03cadf2021-06-09 22:19:04 +0530284 /* Override settings per board. */
285}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530286
Subrata Banikb03cadf2021-06-09 22:19:04 +0530287static void fill_fsps_lpss_params(FSP_S_CONFIG *s_cfg,
288 const struct soc_intel_alderlake_config *config)
289{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530290 for (int i = 0; i < CONFIG_SOC_INTEL_I2C_DEV_MAX; i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530291 s_cfg->SerialIoI2cMode[i] = config->SerialIoI2cMode[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530292
293 for (int i = 0; i < CONFIG_SOC_INTEL_COMMON_BLOCK_GSPI_MAX; i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530294 s_cfg->SerialIoSpiMode[i] = config->SerialIoGSpiMode[i];
295 s_cfg->SerialIoSpiCsMode[i] = config->SerialIoGSpiCsMode[i];
296 s_cfg->SerialIoSpiCsState[i] = config->SerialIoGSpiCsState[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530297 }
298
299 for (int i = 0; i < CONFIG_SOC_INTEL_UART_DEV_MAX; i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530300 s_cfg->SerialIoUartMode[i] = config->SerialIoUartMode[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530301}
302
Subrata Banikb03cadf2021-06-09 22:19:04 +0530303static void fill_fsps_cpu_params(FSP_S_CONFIG *s_cfg,
304 const struct soc_intel_alderlake_config *config)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530305{
Subrata Banik99289a82020-12-22 10:54:44 +0530306 const struct microcode *microcode_file;
307 size_t microcode_len;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530308
Subrata Banikb03cadf2021-06-09 22:19:04 +0530309 /* Locate microcode and pass to FSP-S for 2nd microcode loading */
Subrata Banik99289a82020-12-22 10:54:44 +0530310 microcode_file = cbfs_map("cpu_microcode_blob.bin", &microcode_len);
311
312 if ((microcode_file != NULL) && (microcode_len != 0)) {
313 /* Update CPU Microcode patch base address/size */
Subrata Banikc0983c92021-06-15 13:02:01 +0530314 s_cfg->MicrocodeRegionBase = (uint32_t)microcode_file;
315 s_cfg->MicrocodeRegionSize = (uint32_t)microcode_len;
Subrata Banik99289a82020-12-22 10:54:44 +0530316 }
317
Subrata Banikb03cadf2021-06-09 22:19:04 +0530318 /* Use coreboot MP PPI services if Kconfig is enabled */
319 if (CONFIG(USE_INTEL_FSP_TO_CALL_COREBOOT_PUBLISH_MP_PPI))
320 s_cfg->CpuMpPpi = (uintptr_t) mp_fill_ppi_services_data();
321}
322
323static void fill_fsps_igd_params(FSP_S_CONFIG *s_cfg,
324 const struct soc_intel_alderlake_config *config)
325{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530326 /* Load VBT before devicetree-specific config. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530327 s_cfg->GraphicsConfigPtr = (uintptr_t)vbt_get();
Subrata Banik2871e0e2020-09-27 11:30:58 +0530328
329 /* Check if IGD is present and fill Graphics init param accordingly */
Subrata Banikc0983c92021-06-15 13:02:01 +0530330 s_cfg->PeiGraphicsPeimInit = CONFIG(RUN_FSP_GOP) && is_devfn_enabled(SA_DEVFN_IGD);
331 s_cfg->LidStatus = CONFIG(RUN_FSP_GOP);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530332}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530333
Subrata Banikb03cadf2021-06-09 22:19:04 +0530334static void fill_fsps_tcss_params(FSP_S_CONFIG *s_cfg,
335 const struct soc_intel_alderlake_config *config)
336{
Subrata Banikc0983c92021-06-15 13:02:01 +0530337 s_cfg->TcssAuxOri = config->TcssAuxOri;
Deepti Deshatty8e7facf2021-05-12 17:45:37 +0530338
339 /* Explicitly clear this field to avoid using defaults */
Subrata Banikc0983c92021-06-15 13:02:01 +0530340 memset(s_cfg->IomTypeCPortPadCfg, 0, sizeof(s_cfg->IomTypeCPortPadCfg));
Subrata Banik2871e0e2020-09-27 11:30:58 +0530341
342 /*
343 * Set FSPS UPD ITbtConnectTopologyTimeoutInMs with value 0. FSP will
344 * evaluate this UPD value and skip sending command. There will be no
345 * delay for command completion.
346 */
Subrata Banikc0983c92021-06-15 13:02:01 +0530347 s_cfg->ITbtConnectTopologyTimeoutInMs = 0;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530348
Subrata Banikb03cadf2021-06-09 22:19:04 +0530349 /* D3Hot and D3Cold for TCSS */
350 s_cfg->D3HotEnable = !config->TcssD3HotDisable;
351 s_cfg->D3ColdEnable = !config->TcssD3ColdDisable;
Bernardo Perez Priego421ce562021-06-09 09:40:31 -0700352
353 s_cfg->UsbTcPortEn = 0;
354 for (int i = 0; i < MAX_TYPE_C_PORTS; i++) {
355 /* TCSS xHCI --> Root Hub --> Type-C Port */
356 const struct device_path port_path[] = {
357 {.type = DEVICE_PATH_PCI, .pci.devfn = SA_DEVFN_TCSS_XHCI},
358 {.type = DEVICE_PATH_USB, .usb.port_type = 0, .usb.port_id = 0},
359 {.type = DEVICE_PATH_USB, .usb.port_type = 3, .usb.port_id = i} };
360 const struct device *port = find_dev_nested_path(pci_root_bus(), port_path,
361 ARRAY_SIZE(port_path));
362
363 if (is_dev_enabled(port))
364 s_cfg->UsbTcPortEn |= BIT(i);
365 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530366}
367
368static void fill_fsps_chipset_lockdown_params(FSP_S_CONFIG *s_cfg,
369 const struct soc_intel_alderlake_config *config)
370{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530371 /* Chipset Lockdown */
372 if (get_lockdown_config() == CHIPSET_LOCKDOWN_COREBOOT) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530373 s_cfg->PchLockDownGlobalSmi = 0;
374 s_cfg->PchLockDownBiosInterface = 0;
375 s_cfg->PchUnlockGpioPads = 1;
376 s_cfg->RtcMemoryLock = 0;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530377 } else {
Subrata Banikc0983c92021-06-15 13:02:01 +0530378 s_cfg->PchLockDownGlobalSmi = 1;
379 s_cfg->PchLockDownBiosInterface = 1;
380 s_cfg->PchUnlockGpioPads = 0;
381 s_cfg->RtcMemoryLock = 1;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530382 }
Tim Wawrzynczakc0e82e72021-06-17 12:42:35 -0600383
384 /* coreboot will send EOP before loading payload */
385 s_cfg->EndOfPostMessage = EOP_DISABLE;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530386}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530387
Subrata Banikb03cadf2021-06-09 22:19:04 +0530388static void fill_fsps_xhci_params(FSP_S_CONFIG *s_cfg,
389 const struct soc_intel_alderlake_config *config)
390{
391 int i;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530392 /* USB */
393 for (i = 0; i < ARRAY_SIZE(config->usb2_ports); i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530394 s_cfg->PortUsb20Enable[i] = config->usb2_ports[i].enable;
395 s_cfg->Usb2PhyPetxiset[i] = config->usb2_ports[i].pre_emp_bias;
396 s_cfg->Usb2PhyTxiset[i] = config->usb2_ports[i].tx_bias;
397 s_cfg->Usb2PhyPredeemp[i] = config->usb2_ports[i].tx_emp_enable;
398 s_cfg->Usb2PhyPehalfbit[i] = config->usb2_ports[i].pre_emp_bit;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530399
400 if (config->usb2_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530401 s_cfg->Usb2OverCurrentPin[i] = config->usb2_ports[i].ocpin;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530402 else
Subrata Banikc0983c92021-06-15 13:02:01 +0530403 s_cfg->Usb2OverCurrentPin[i] = OC_SKIP;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530404 }
405
406 for (i = 0; i < ARRAY_SIZE(config->usb3_ports); i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530407 s_cfg->PortUsb30Enable[i] = config->usb3_ports[i].enable;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530408 if (config->usb3_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530409 s_cfg->Usb3OverCurrentPin[i] = config->usb3_ports[i].ocpin;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530410 else
Subrata Banikc0983c92021-06-15 13:02:01 +0530411 s_cfg->Usb3OverCurrentPin[i] = OC_SKIP;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530412
413 if (config->usb3_ports[i].tx_de_emp) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530414 s_cfg->Usb3HsioTxDeEmphEnable[i] = 1;
415 s_cfg->Usb3HsioTxDeEmph[i] = config->usb3_ports[i].tx_de_emp;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530416 }
417 if (config->usb3_ports[i].tx_downscale_amp) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530418 s_cfg->Usb3HsioTxDownscaleAmpEnable[i] = 1;
419 s_cfg->Usb3HsioTxDownscaleAmp[i] =
Subrata Banik2871e0e2020-09-27 11:30:58 +0530420 config->usb3_ports[i].tx_downscale_amp;
421 }
422 }
423
Maulik V Vaghela69353502021-04-14 14:01:02 +0530424 for (i = 0; i < ARRAY_SIZE(config->tcss_ports); i++) {
425 if (config->tcss_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530426 s_cfg->CpuUsb3OverCurrentPin[i] = config->tcss_ports[i].ocpin;
Maulik V Vaghela69353502021-04-14 14:01:02 +0530427 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530428}
Maulik V Vaghela69353502021-04-14 14:01:02 +0530429
Subrata Banikb03cadf2021-06-09 22:19:04 +0530430static void fill_fsps_xdci_params(FSP_S_CONFIG *s_cfg,
431 const struct soc_intel_alderlake_config *config)
432{
Angel Ponsc7cfe0b2021-06-23 12:39:22 +0200433 s_cfg->XdciEnable = xdci_can_enable(PCH_DEVFN_USBOTG);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530434}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530435
Subrata Banikb03cadf2021-06-09 22:19:04 +0530436static void fill_fsps_uart_params(FSP_S_CONFIG *s_cfg,
437 const struct soc_intel_alderlake_config *config)
438{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530439 /* PCH UART selection for FSP Debug */
Subrata Banikc0983c92021-06-15 13:02:01 +0530440 s_cfg->SerialIoDebugUartNumber = CONFIG_UART_FOR_CONSOLE;
441 ASSERT(ARRAY_SIZE(s_cfg->SerialIoUartAutoFlow) > CONFIG_UART_FOR_CONSOLE);
442 s_cfg->SerialIoUartAutoFlow[CONFIG_UART_FOR_CONSOLE] = 0;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530443}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530444
Subrata Banikb03cadf2021-06-09 22:19:04 +0530445static void fill_fsps_sata_params(FSP_S_CONFIG *s_cfg,
446 const struct soc_intel_alderlake_config *config)
447{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530448 /* SATA */
Subrata Banikc0983c92021-06-15 13:02:01 +0530449 s_cfg->SataEnable = is_devfn_enabled(PCH_DEVFN_SATA);
450 if (s_cfg->SataEnable) {
451 s_cfg->SataMode = config->SataMode;
452 s_cfg->SataSalpSupport = config->SataSalpSupport;
453 memcpy(s_cfg->SataPortsEnable, config->SataPortsEnable,
454 sizeof(s_cfg->SataPortsEnable));
455 memcpy(s_cfg->SataPortsDevSlp, config->SataPortsDevSlp,
456 sizeof(s_cfg->SataPortsDevSlp));
Subrata Banik2871e0e2020-09-27 11:30:58 +0530457 }
458
459 /*
Subrata Banikb03cadf2021-06-09 22:19:04 +0530460 * Power Optimizer for SATA.
461 * SataPwrOptimizeDisable is default to 0.
Subrata Banik2871e0e2020-09-27 11:30:58 +0530462 * Boards not needing the optimizers explicitly disables them by setting
463 * these disable variables to 1 in devicetree overrides.
464 */
Subrata Banikc0983c92021-06-15 13:02:01 +0530465 s_cfg->SataPwrOptEnable = !(config->SataPwrOptimizeDisable);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530466 /*
467 * Enable DEVSLP Idle Timeout settings DmVal and DitoVal.
468 * SataPortsDmVal is the DITO multiplier. Default is 15.
469 * SataPortsDitoVal is the DEVSLP Idle Timeout (DITO), Default is 625ms.
470 * The default values can be changed from devicetree.
471 */
Subrata Banikb03cadf2021-06-09 22:19:04 +0530472 for (size_t i = 0; i < ARRAY_SIZE(config->SataPortsEnableDitoConfig); i++) {
Subrata Banik2871e0e2020-09-27 11:30:58 +0530473 if (config->SataPortsEnableDitoConfig[i]) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530474 s_cfg->SataPortsDmVal[i] = config->SataPortsDmVal[i];
475 s_cfg->SataPortsDitoVal[i] = config->SataPortsDitoVal[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530476 }
477 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530478}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530479
Subrata Banikb03cadf2021-06-09 22:19:04 +0530480static void fill_fsps_thermal_params(FSP_S_CONFIG *s_cfg,
481 const struct soc_intel_alderlake_config *config)
482{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530483 /* Enable TCPU for processor thermal control */
Subrata Banikc0983c92021-06-15 13:02:01 +0530484 s_cfg->Device4Enable = is_devfn_enabled(SA_DEVFN_DPTF);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530485
486 /* Set TccActivationOffset */
Subrata Banikc0983c92021-06-15 13:02:01 +0530487 s_cfg->TccActivationOffset = config->tcc_offset;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530488}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530489
Subrata Banikb03cadf2021-06-09 22:19:04 +0530490static void fill_fsps_lan_params(FSP_S_CONFIG *s_cfg,
491 const struct soc_intel_alderlake_config *config)
492{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530493 /* LAN */
Subrata Banikc0983c92021-06-15 13:02:01 +0530494 s_cfg->PchLanEnable = is_devfn_enabled(PCH_DEVFN_GBE);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530495}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530496
Subrata Banikb03cadf2021-06-09 22:19:04 +0530497static void fill_fsps_cnvi_params(FSP_S_CONFIG *s_cfg,
498 const struct soc_intel_alderlake_config *config)
499{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530500 /* CNVi */
Subrata Banikc0983c92021-06-15 13:02:01 +0530501 s_cfg->CnviMode = is_devfn_enabled(PCH_DEVFN_CNVI_WIFI);
502 s_cfg->CnviBtCore = config->CnviBtCore;
503 s_cfg->CnviBtAudioOffload = config->CnviBtAudioOffload;
Cliff Huangbc1941f2021-02-10 17:41:41 -0800504 /* Assert if CNVi BT is enabled without CNVi being enabled. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530505 assert(s_cfg->CnviMode || !s_cfg->CnviBtCore);
Cliff Huangbc1941f2021-02-10 17:41:41 -0800506 /* Assert if CNVi BT offload is enabled without CNVi BT being enabled. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530507 assert(s_cfg->CnviBtCore || !s_cfg->CnviBtAudioOffload);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530508}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530509
Subrata Banikb03cadf2021-06-09 22:19:04 +0530510static void fill_fsps_vmd_params(FSP_S_CONFIG *s_cfg,
511 const struct soc_intel_alderlake_config *config)
512{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530513 /* VMD */
Subrata Banikc0983c92021-06-15 13:02:01 +0530514 s_cfg->VmdEnable = is_devfn_enabled(SA_DEVFN_VMD);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530515}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530516
Subrata Banikb03cadf2021-06-09 22:19:04 +0530517static void fill_fsps_thc_params(FSP_S_CONFIG *s_cfg,
518 const struct soc_intel_alderlake_config *config)
519{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530520 /* THC */
Subrata Banikc0983c92021-06-15 13:02:01 +0530521 s_cfg->ThcPort0Assignment = is_devfn_enabled(PCH_DEVFN_THC0) ? THC_0 : THC_NONE;
522 s_cfg->ThcPort1Assignment = is_devfn_enabled(PCH_DEVFN_THC1) ? THC_1 : THC_NONE;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530523}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530524
Subrata Banikb03cadf2021-06-09 22:19:04 +0530525static void fill_fsps_tbt_params(FSP_S_CONFIG *s_cfg,
526 const struct soc_intel_alderlake_config *config)
527{
Bernardo Perez Priego095f97b2021-05-18 18:39:19 -0700528 /* USB4/TBT */
Subrata Banikb03cadf2021-06-09 22:19:04 +0530529 for (int i = 0; i < ARRAY_SIZE(s_cfg->ITbtPcieRootPortEn); i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530530 s_cfg->ITbtPcieRootPortEn[i] = is_devfn_enabled(SA_DEVFN_TBT(i));
Subrata Banikb03cadf2021-06-09 22:19:04 +0530531}
Bernardo Perez Priego095f97b2021-05-18 18:39:19 -0700532
Subrata Banikb03cadf2021-06-09 22:19:04 +0530533static void fill_fsps_8254_params(FSP_S_CONFIG *s_cfg,
534 const struct soc_intel_alderlake_config *config)
535{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530536 /* Legacy 8254 timer support */
Subrata Banikc0983c92021-06-15 13:02:01 +0530537 s_cfg->Enable8254ClockGating = !CONFIG(USE_LEGACY_8254_TIMER);
538 s_cfg->Enable8254ClockGatingOnS3 = !CONFIG(USE_LEGACY_8254_TIMER);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530539}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530540
Subrata Banikb03cadf2021-06-09 22:19:04 +0530541static void fill_fsps_storage_params(FSP_S_CONFIG *s_cfg,
542 const struct soc_intel_alderlake_config *config)
543{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530544 /* Enable Hybrid storage auto detection */
Subrata Banikc0983c92021-06-15 13:02:01 +0530545 s_cfg->HybridStorageMode = config->HybridStorageMode;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530546}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530547
Subrata Banikb03cadf2021-06-09 22:19:04 +0530548static void fill_fsps_pcie_params(FSP_S_CONFIG *s_cfg,
549 const struct soc_intel_alderlake_config *config)
550{
551 uint32_t enable_mask = pcie_rp_enable_mask(get_pch_pcie_rp_table());
552 for (int i = 0; i < CONFIG_MAX_PCH_ROOT_PORTS; i++) {
Eric Lai5b302b22020-12-05 16:49:43 +0800553 if (!(enable_mask & BIT(i)))
554 continue;
555 const struct pcie_rp_config *rp_cfg = &config->pch_pcie_rp[i];
Subrata Banikc0983c92021-06-15 13:02:01 +0530556 s_cfg->PcieRpL1Substates[i] =
Eric Lai5b302b22020-12-05 16:49:43 +0800557 get_l1_substate_control(rp_cfg->PcieRpL1Substates);
Subrata Banikc0983c92021-06-15 13:02:01 +0530558 s_cfg->PcieRpLtrEnable[i] = !!(rp_cfg->flags & PCIE_RP_LTR);
559 s_cfg->PcieRpAdvancedErrorReporting[i] = !!(rp_cfg->flags & PCIE_RP_AER);
560 s_cfg->PcieRpHotPlug[i] = !!(rp_cfg->flags & PCIE_RP_HOTPLUG);
561 s_cfg->PcieRpClkReqDetect[i] = !!(rp_cfg->flags & PCIE_RP_CLK_REQ_DETECT);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530562 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530563}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530564
Subrata Banikb03cadf2021-06-09 22:19:04 +0530565static void fill_fsps_misc_power_params(FSP_S_CONFIG *s_cfg,
566 const struct soc_intel_alderlake_config *config)
567{
568 /*
569 * Power Optimizer for DMI
570 * DmiPwrOptimizeDisable is default to 0.
571 * Boards not needing the optimizers explicitly disables them by setting
572 * these disable variables to 1 in devicetree overrides.
573 */
574 s_cfg->PchPwrOptEnable = !(config->DmiPwrOptimizeDisable);
Subrata Banikc0983c92021-06-15 13:02:01 +0530575 s_cfg->PmSupport = 1;
576 s_cfg->Hwp = 1;
577 s_cfg->Cx = 1;
578 s_cfg->PsOnEnable = 1;
V Sowmya844dcb32021-06-21 10:03:53 +0530579 /* Enable the energy efficient turbo mode */
580 s_cfg->EnergyEfficientTurbo = 1;
V Sowmyaaf429062021-06-21 10:23:33 +0530581 s_cfg->PkgCStateLimit = LIMIT_AUTO;
Subrata Banik6f1cb402021-06-09 22:11:12 +0530582}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530583
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600584static void fill_fsps_irq_params(FSP_S_CONFIG *s_cfg,
585 const struct soc_intel_alderlake_config *config)
586{
587 if (!assign_pci_irqs(irq_constraints, ARRAY_SIZE(irq_constraints)))
588 die("ERROR: Unable to assign PCI IRQs, and no _PRT table available\n");
589
590 size_t pch_count = 0;
591 const SI_PCH_DEVICE_INTERRUPT_CONFIG *upd_irqs = pci_irq_to_fsp(&pch_count);
592
593 s_cfg->DevIntConfigPtr = (UINT32)((uintptr_t)upd_irqs);
594 s_cfg->NumOfDevIntConfig = pch_count;
595 printk(BIOS_INFO, "IRQ: Using dynamically assigned PCI IO-APIC IRQs\n");
596}
597
V Sowmya418d37e2021-06-21 08:47:17 +0530598static void fill_fsps_fivr_params(FSP_S_CONFIG *s_cfg,
599 const struct soc_intel_alderlake_config *config)
600{
601 /* PCH FIVR settings override */
602 if (!config->ext_fivr_settings.configure_ext_fivr)
603 return;
604
605 s_cfg->PchFivrExtV1p05RailEnabledStates =
606 config->ext_fivr_settings.v1p05_enable_bitmap;
607
608 s_cfg->PchFivrExtV1p05RailSupportedVoltageStates =
609 config->ext_fivr_settings.v1p05_supported_voltage_bitmap;
610
611 s_cfg->PchFivrExtVnnRailEnabledStates =
612 config->ext_fivr_settings.vnn_enable_bitmap;
613
614 s_cfg->PchFivrExtVnnRailSupportedVoltageStates =
615 config->ext_fivr_settings.vnn_supported_voltage_bitmap;
616
617 s_cfg->PchFivrExtVnnRailSxEnabledStates =
618 config->ext_fivr_settings.vnn_enable_bitmap;
619
620 /* Convert the voltages to increments of 2.5mv */
621 s_cfg->PchFivrExtV1p05RailVoltage =
622 (config->ext_fivr_settings.v1p05_voltage_mv * 10) / 25;
623
624 s_cfg->PchFivrExtVnnRailVoltage =
625 (config->ext_fivr_settings.vnn_voltage_mv * 10) / 25;
626
627 s_cfg->PchFivrExtVnnRailSxVoltage =
628 (config->ext_fivr_settings.vnn_sx_voltage_mv * 10 / 25);
629
630 s_cfg->PchFivrExtV1p05RailIccMaximum =
631 config->ext_fivr_settings.v1p05_icc_max_ma;
632
633 s_cfg->PchFivrExtVnnRailIccMaximum =
634 config->ext_fivr_settings.vnn_icc_max_ma;
635}
636
Subrata Banik6f1cb402021-06-09 22:11:12 +0530637static void arch_silicon_init_params(FSPS_ARCH_UPD *s_arch_cfg)
638{
639 /* EnableMultiPhaseSiliconInit for running MultiPhaseSiInit */
640 s_arch_cfg->EnableMultiPhaseSiliconInit = 1;
641}
642
Subrata Banikb03cadf2021-06-09 22:19:04 +0530643static void soc_silicon_init_params(FSP_S_CONFIG *s_cfg,
644 struct soc_intel_alderlake_config *config)
645{
646 /* Override settings per board if required. */
647 mainboard_update_soc_chip_config(config);
648
V Sowmya6464c2a2021-06-25 10:20:25 +0530649 const void (*fill_fsps_params[])(FSP_S_CONFIG *s_cfg,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530650 const struct soc_intel_alderlake_config *config) = {
651 fill_fsps_lpss_params,
652 fill_fsps_cpu_params,
653 fill_fsps_igd_params,
654 fill_fsps_tcss_params,
655 fill_fsps_chipset_lockdown_params,
656 fill_fsps_xhci_params,
657 fill_fsps_xdci_params,
658 fill_fsps_uart_params,
659 fill_fsps_sata_params,
660 fill_fsps_thermal_params,
661 fill_fsps_lan_params,
662 fill_fsps_cnvi_params,
663 fill_fsps_vmd_params,
664 fill_fsps_thc_params,
665 fill_fsps_tbt_params,
666 fill_fsps_8254_params,
667 fill_fsps_storage_params,
668 fill_fsps_pcie_params,
669 fill_fsps_misc_power_params,
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600670 fill_fsps_irq_params,
V Sowmya418d37e2021-06-21 08:47:17 +0530671 fill_fsps_fivr_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530672 };
673
674 for (size_t i = 0; i < ARRAY_SIZE(fill_fsps_params); i++)
675 fill_fsps_params[i](s_cfg, config);
676}
677
Subrata Banik6f1cb402021-06-09 22:11:12 +0530678/* UPD parameters to be initialized before SiliconInit */
679void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
680{
681 struct soc_intel_alderlake_config *config;
Subrata Banikc0983c92021-06-15 13:02:01 +0530682 FSP_S_CONFIG *s_cfg = &supd->FspsConfig;
Subrata Banik6f1cb402021-06-09 22:11:12 +0530683 FSPS_ARCH_UPD *s_arch_cfg = &supd->FspsArchUpd;
684
685 config = config_of_soc();
Subrata Banik6f1cb402021-06-09 22:11:12 +0530686 arch_silicon_init_params(s_arch_cfg);
Subrata Banikc0983c92021-06-15 13:02:01 +0530687 soc_silicon_init_params(s_cfg, config);
688 mainboard_silicon_init_params(s_cfg);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530689}
690
Subrata Banik2871e0e2020-09-27 11:30:58 +0530691/*
692 * Callbacks for SoC/Mainboard specific overrides for FspMultiPhaseSiInit
693 * This platform supports below MultiPhaseSIInit Phase(s):
694 * Phase | FSP return point | Purpose
695 * ------- + ------------------------------------------------ + -------------------------------
696 * 1 | After TCSS initialization completed | for TCSS specific init
697 */
698void platform_fsp_multi_phase_init_cb(uint32_t phase_index)
699{
700 switch (phase_index) {
701 case 1:
702 /* TCSS specific initialization here */
Deepti Deshatty8e7facf2021-05-12 17:45:37 +0530703 printk(BIOS_DEBUG, "FSP MultiPhaseSiInit %s/%s called\n",
704 __FILE__, __func__);
705
706 if (CONFIG(SOC_INTEL_COMMON_BLOCK_TCSS)) {
707 const config_t *config = config_of_soc();
708 tcss_configure(config->typec_aux_bias_pads);
709 }
Subrata Banik2871e0e2020-09-27 11:30:58 +0530710 break;
711 default:
712 break;
713 }
714}
715
716/* Mainboard GPIO Configuration */
Subrata Banikc0983c92021-06-15 13:02:01 +0530717__weak void mainboard_silicon_init_params(FSP_S_CONFIG *s_cfg)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530718{
719 printk(BIOS_DEBUG, "WEAK: %s/%s called\n", __FILE__, __func__);
720}