blob: 5edfbcc78184e52f49387030f0d1b5ac76c30f83 [file] [log] [blame]
Subrata Banik2871e0e2020-09-27 11:30:58 +05301/* SPDX-License-Identifier: GPL-2.0-only */
2
3#include <assert.h>
Subrata Banik72d616c2023-11-30 19:09:46 +05304#include <bootmode.h>
Subrata Banik0cf26742023-05-16 12:18:00 +05305#include <bootsplash.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +05306#include <console/console.h>
Subrata Banik7b523a42021-09-22 16:46:16 +05307#include <cpu/intel/microcode.h>
Jeremy Compostellaa2a7fec2023-01-19 19:06:09 -07008#include <delay.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +05309#include <device/device.h>
10#include <device/pci.h>
V Sowmya458708f2021-07-09 22:11:04 +053011#include <device/pci_ids.h>
Jeremy Compostellaa2a7fec2023-01-19 19:06:09 -070012#include <device/pci_ops.h>
13#include <drivers/intel/gma/i915_reg.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053014#include <fsp/api.h>
Subrata Banik7cb6d722022-03-23 01:33:27 +053015#include <fsp/fsp_debug_event.h>
Subrata Banik03dfc212023-08-16 02:50:16 +053016#include <fsp/fsp_gop_blt.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053017#include <fsp/ppi/mp_service_ppi.h>
18#include <fsp/util.h>
Dinesh Gehlotd910fec2022-12-25 13:00:04 +000019#include <gpio.h>
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060020#include <intelblocks/irq.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053021#include <intelblocks/lpss.h>
Subrata Banikb6c3a032022-06-05 22:39:34 +053022#include <intelblocks/mp_init.h>
Tim Wawrzynczakab0e0812021-09-21 10:28:16 -060023#include <intelblocks/pmclib.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053024#include <intelblocks/xdci.h>
25#include <intelpch/lockdown.h>
Subrata Banikb6c3a032022-06-05 22:39:34 +053026#include <intelblocks/systemagent.h>
Deepti Deshatty8e7facf2021-05-12 17:45:37 +053027#include <intelblocks/tcss.h>
Dinesh Gehlotd910fec2022-12-25 13:00:04 +000028#include <option.h>
Tim Wawrzynczake2b8f302021-07-19 15:35:47 -060029#include <soc/cpu.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053030#include <soc/intel/common/vbt.h>
31#include <soc/pci_devs.h>
Eric Lai5b302b22020-12-05 16:49:43 +080032#include <soc/pcie.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053033#include <soc/ramstage.h>
34#include <soc/soc_chip.h>
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060035#include <stdlib.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053036#include <string.h>
Sean Rhodesbc35bed2021-07-13 13:36:28 +010037#include <types.h>
Subrata Banik2871e0e2020-09-27 11:30:58 +053038
39/* THC assignment definition */
40#define THC_NONE 0
41#define THC_0 1
42#define THC_1 2
43
44/* SATA DEVSLP idle timeout default values */
45#define DEF_DMVAL 15
46#define DEF_DITOVAL 625
47
V Sowmya458708f2021-07-09 22:11:04 +053048/* VccIn Aux Imon IccMax values in mA */
Curtis Chenea1bb5f2021-11-25 13:17:42 +080049#define MILLIAMPS_TO_AMPS 1000
50#define ICC_MAX_TDP_45W 34250
51#define ICC_MAX_TDP_15W_28W 32000
52#define ICC_MAX_ID_ADL_M_MA 12000
V Sowmya2af96022022-04-05 17:03:04 +053053#define ICC_MAX_ID_ADL_N_MA 27000
Michał Żygowskibda2a152022-04-25 15:02:10 +020054#define ICC_MAX_ADL_S 33000
Max Fritz573e6de2022-11-19 01:54:44 +010055#define ICC_MAX_RPL_S 36000
V Sowmya458708f2021-07-09 22:11:04 +053056
Tim Wawrzynczakc0e82e72021-06-17 12:42:35 -060057/*
58 * ME End of Post configuration
59 * 0 - Disable EOP.
60 * 1 - Send in PEI (Applicable for FSP in API mode)
61 * 2 - Send in DXE (Not applicable for FSP in API mode)
62 */
63enum fsp_end_of_post {
64 EOP_DISABLE = 0,
65 EOP_PEI = 1,
66 EOP_DXE = 2,
67};
68
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060069static const struct slot_irq_constraints irq_constraints[] = {
70 {
Tim Crawfordb739d802022-07-29 12:07:15 -060071 .slot = SA_DEV_SLOT_CPU_1,
72 .fns = {
73 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE1_0, PCI_INT_A, PIRQ_A),
74 },
75 },
76 {
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060077 .slot = SA_DEV_SLOT_IGD,
78 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060079 /* INTERRUPT_PIN is RO/0x01 */
80 FIXED_INT_ANY_PIRQ(SA_DEVFN_IGD, PCI_INT_A),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060081 },
82 },
83 {
84 .slot = SA_DEV_SLOT_DPTF,
85 .fns = {
86 ANY_PIRQ(SA_DEVFN_DPTF),
87 },
88 },
89 {
90 .slot = SA_DEV_SLOT_IPU,
91 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -060092 /* INTERRUPT_PIN is RO/0x01, and INTERRUPT_LINE is RW,
93 but S0ix fails when not set to 16 (b/193434192) */
94 FIXED_INT_PIRQ(SA_DEVFN_IPU, PCI_INT_A, PIRQ_A),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -060095 },
96 },
97 {
98 .slot = SA_DEV_SLOT_CPU_6,
99 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600100 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_0, PCI_INT_A, PIRQ_A),
101 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_2, PCI_INT_C, PIRQ_C),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600102 },
103 },
104 {
105 .slot = SA_DEV_SLOT_TBT,
106 .fns = {
107 ANY_PIRQ(SA_DEVFN_TBT0),
108 ANY_PIRQ(SA_DEVFN_TBT1),
109 ANY_PIRQ(SA_DEVFN_TBT2),
110 ANY_PIRQ(SA_DEVFN_TBT3),
111 },
112 },
113 {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600114 .slot = SA_DEV_SLOT_GNA,
115 .fns = {
116 /* INTERRUPT_PIN is RO/0x01 */
117 FIXED_INT_ANY_PIRQ(SA_DEVFN_GNA, PCI_INT_A),
118 },
119 },
120 {
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600121 .slot = SA_DEV_SLOT_TCSS,
122 .fns = {
123 ANY_PIRQ(SA_DEVFN_TCSS_XHCI),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600124 ANY_PIRQ(SA_DEVFN_TCSS_XDCI),
125 },
126 },
127 {
128 .slot = PCH_DEV_SLOT_SIO0,
129 .fns = {
130 DIRECT_IRQ(PCH_DEVFN_I2C6),
131 DIRECT_IRQ(PCH_DEVFN_I2C7),
132 ANY_PIRQ(PCH_DEVFN_THC0),
133 ANY_PIRQ(PCH_DEVFN_THC1),
134 },
135 },
136 {
137 .slot = PCH_DEV_SLOT_SIO6,
138 .fns = {
139 DIRECT_IRQ(PCH_DEVFN_UART3),
140 DIRECT_IRQ(PCH_DEVFN_UART4),
141 DIRECT_IRQ(PCH_DEVFN_UART5),
142 DIRECT_IRQ(PCH_DEVFN_UART6),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600143 },
144 },
145 {
146 .slot = PCH_DEV_SLOT_ISH,
147 .fns = {
148 DIRECT_IRQ(PCH_DEVFN_ISH),
149 DIRECT_IRQ(PCH_DEVFN_GSPI2),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600150 ANY_PIRQ(PCH_DEVFN_UFS),
151 },
152 },
153 {
154 .slot = PCH_DEV_SLOT_SIO2,
155 .fns = {
156 DIRECT_IRQ(PCH_DEVFN_GSPI3),
157 DIRECT_IRQ(PCH_DEVFN_GSPI4),
158 DIRECT_IRQ(PCH_DEVFN_GSPI5),
159 DIRECT_IRQ(PCH_DEVFN_GSPI6),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600160 },
161 },
162 {
163 .slot = PCH_DEV_SLOT_XHCI,
164 .fns = {
165 ANY_PIRQ(PCH_DEVFN_XHCI),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600166 DIRECT_IRQ(PCH_DEVFN_USBOTG),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600167 ANY_PIRQ(PCH_DEVFN_CNVI_WIFI),
168 },
169 },
170 {
171 .slot = PCH_DEV_SLOT_SIO3,
172 .fns = {
173 DIRECT_IRQ(PCH_DEVFN_I2C0),
174 DIRECT_IRQ(PCH_DEVFN_I2C1),
175 DIRECT_IRQ(PCH_DEVFN_I2C2),
176 DIRECT_IRQ(PCH_DEVFN_I2C3),
177 },
178 },
179 {
180 .slot = PCH_DEV_SLOT_CSE,
181 .fns = {
182 ANY_PIRQ(PCH_DEVFN_CSE),
183 ANY_PIRQ(PCH_DEVFN_CSE_2),
184 ANY_PIRQ(PCH_DEVFN_CSE_IDER),
185 ANY_PIRQ(PCH_DEVFN_CSE_KT),
186 ANY_PIRQ(PCH_DEVFN_CSE_3),
187 ANY_PIRQ(PCH_DEVFN_CSE_4),
188 },
189 },
190 {
191 .slot = PCH_DEV_SLOT_SATA,
192 .fns = {
193 ANY_PIRQ(PCH_DEVFN_SATA),
194 },
195 },
196 {
197 .slot = PCH_DEV_SLOT_SIO4,
198 .fns = {
199 DIRECT_IRQ(PCH_DEVFN_I2C4),
200 DIRECT_IRQ(PCH_DEVFN_I2C5),
201 DIRECT_IRQ(PCH_DEVFN_UART2),
202 },
203 },
Krishna Prasad Bhata6d642f2022-01-16 23:16:24 +0530204#if CONFIG(SOC_INTEL_ALDERLAKE_PCH_N)
205 {
206 .slot = PCH_DEV_SLOT_EMMC,
207 .fns = {
208 ANY_PIRQ(PCH_DEVFN_EMMC),
209 },
210 },
211#endif
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600212 {
213 .slot = PCH_DEV_SLOT_PCIE,
214 .fns = {
215 FIXED_INT_PIRQ(PCH_DEVFN_PCIE1, PCI_INT_A, PIRQ_A),
216 FIXED_INT_PIRQ(PCH_DEVFN_PCIE2, PCI_INT_B, PIRQ_B),
217 FIXED_INT_PIRQ(PCH_DEVFN_PCIE3, PCI_INT_C, PIRQ_C),
218 FIXED_INT_PIRQ(PCH_DEVFN_PCIE4, PCI_INT_D, PIRQ_D),
219 FIXED_INT_PIRQ(PCH_DEVFN_PCIE5, PCI_INT_A, PIRQ_A),
220 FIXED_INT_PIRQ(PCH_DEVFN_PCIE6, PCI_INT_B, PIRQ_B),
221 FIXED_INT_PIRQ(PCH_DEVFN_PCIE7, PCI_INT_C, PIRQ_C),
222 FIXED_INT_PIRQ(PCH_DEVFN_PCIE8, PCI_INT_D, PIRQ_D),
223 },
224 },
225 {
226 .slot = PCH_DEV_SLOT_PCIE_1,
227 .fns = {
228 FIXED_INT_PIRQ(PCH_DEVFN_PCIE9, PCI_INT_A, PIRQ_A),
229 FIXED_INT_PIRQ(PCH_DEVFN_PCIE10, PCI_INT_B, PIRQ_B),
230 FIXED_INT_PIRQ(PCH_DEVFN_PCIE11, PCI_INT_C, PIRQ_C),
231 FIXED_INT_PIRQ(PCH_DEVFN_PCIE12, PCI_INT_D, PIRQ_D),
232 },
233 },
234 {
235 .slot = PCH_DEV_SLOT_SIO5,
236 .fns = {
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600237 /* UART0 shares an interrupt line with TSN0, so must use
238 a PIRQ */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600239 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART0, PCI_INT_A),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600240 /* UART1 shares an interrupt line with TSN1, so must use
241 a PIRQ */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600242 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART1, PCI_INT_B),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600243 DIRECT_IRQ(PCH_DEVFN_GSPI0),
244 DIRECT_IRQ(PCH_DEVFN_GSPI1),
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600245 },
246 },
247 {
248 .slot = PCH_DEV_SLOT_ESPI,
249 .fns = {
250 ANY_PIRQ(PCH_DEVFN_HDA),
251 ANY_PIRQ(PCH_DEVFN_SMBUS),
252 ANY_PIRQ(PCH_DEVFN_GBE),
Tim Wawrzynczak82225b82021-07-09 10:23:10 -0600253 /* INTERRUPT_PIN is RO/0x01 */
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600254 FIXED_INT_ANY_PIRQ(PCH_DEVFN_TRACEHUB, PCI_INT_A),
255 },
256 },
257};
258
Michał Żygowski72704be2022-06-20 18:10:14 +0200259static const struct slot_irq_constraints irq_constraints_pch_s[] = {
260 {
261 .slot = SA_DEV_SLOT_CPU_1,
262 .fns = {
263 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE1_0, PCI_INT_A, PIRQ_A),
264 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE1_1, PCI_INT_B, PIRQ_B),
265 },
266 },
267 {
268 .slot = SA_DEV_SLOT_IGD,
269 .fns = {
270 /* INTERRUPT_PIN is RO/0x01 */
271 FIXED_INT_ANY_PIRQ(SA_DEVFN_IGD, PCI_INT_A),
272 },
273 },
274 {
275 .slot = SA_DEV_SLOT_DPTF,
276 .fns = {
277 ANY_PIRQ(SA_DEVFN_DPTF),
278 },
279 },
280 {
281 .slot = SA_DEV_SLOT_CPU_6,
282 .fns = {
283 FIXED_INT_PIRQ(SA_DEVFN_CPU_PCIE6_0, PCI_INT_D, PIRQ_A),
284 },
285 },
286 {
287 .slot = SA_DEV_SLOT_GNA,
288 .fns = {
289 /* INTERRUPT_PIN is RO/0x01 */
290 FIXED_INT_ANY_PIRQ(SA_DEVFN_GNA, PCI_INT_A),
291 },
292 },
293 {
294 .slot = PCH_DEV_SLOT_SIO6,
295 .fns = {
296 DIRECT_IRQ(PCH_DEVFN_UART3),
297 },
298 },
299 {
300 .slot = PCH_DEV_SLOT_ISH,
301 .fns = {
302 DIRECT_IRQ(PCH_DEVFN_ISH),
303 DIRECT_IRQ(PCH_DEVFN_GSPI2),
304 },
305 },
306 {
307 .slot = PCH_DEV_SLOT_SIO2,
308 .fns = {
309 DIRECT_IRQ(PCH_DEVFN_GSPI3),
310 },
311 },
312 {
313 .slot = PCH_DEV_SLOT_XHCI,
314 .fns = {
315 ANY_PIRQ(PCH_DEVFN_XHCI),
316 DIRECT_IRQ(PCH_DEVFN_USBOTG),
317 ANY_PIRQ(PCH_DEVFN_CNVI_WIFI),
318 },
319 },
320 {
321 .slot = PCH_DEV_SLOT_SIO3,
322 .fns = {
323 DIRECT_IRQ(PCH_DEVFN_I2C0),
324 DIRECT_IRQ(PCH_DEVFN_I2C1),
325 DIRECT_IRQ(PCH_DEVFN_I2C2),
326 DIRECT_IRQ(PCH_DEVFN_I2C3),
327 },
328 },
329 {
330 .slot = PCH_DEV_SLOT_CSE,
331 .fns = {
332 ANY_PIRQ(PCH_DEVFN_CSE),
333 ANY_PIRQ(PCH_DEVFN_CSE_2),
334 ANY_PIRQ(PCH_DEVFN_CSE_IDER),
335 ANY_PIRQ(PCH_DEVFN_CSE_KT),
336 ANY_PIRQ(PCH_DEVFN_CSE_3),
337 ANY_PIRQ(PCH_DEVFN_CSE_4),
338 },
339 },
340 {
341 .slot = PCH_DEV_SLOT_SATA,
342 .fns = {
343 ANY_PIRQ(PCH_DEVFN_SATA),
344 },
345 },
346 {
347 .slot = PCH_DEV_SLOT_SIO4,
348 .fns = {
349 DIRECT_IRQ(PCH_DEVFN_I2C4),
350 DIRECT_IRQ(PCH_DEVFN_I2C5),
351 DIRECT_IRQ(PCH_DEVFN_UART2),
352 },
353 },
354 {
355 .slot = PCH_DEV_SLOT_PCIE,
356 .fns = {
357 FIXED_INT_PIRQ(PCH_DEVFN_PCIE1, PCI_INT_A, PIRQ_A),
358 FIXED_INT_PIRQ(PCH_DEVFN_PCIE2, PCI_INT_B, PIRQ_B),
359 FIXED_INT_PIRQ(PCH_DEVFN_PCIE3, PCI_INT_C, PIRQ_C),
360 FIXED_INT_PIRQ(PCH_DEVFN_PCIE4, PCI_INT_D, PIRQ_D),
361 FIXED_INT_PIRQ(PCH_DEVFN_PCIE5, PCI_INT_A, PIRQ_A),
362 FIXED_INT_PIRQ(PCH_DEVFN_PCIE6, PCI_INT_B, PIRQ_B),
363 FIXED_INT_PIRQ(PCH_DEVFN_PCIE7, PCI_INT_C, PIRQ_C),
364 FIXED_INT_PIRQ(PCH_DEVFN_PCIE8, PCI_INT_D, PIRQ_D),
365 },
366 },
367 {
368 .slot = PCH_DEV_SLOT_PCIE_1,
369 .fns = {
370 FIXED_INT_PIRQ(PCH_DEVFN_PCIE9, PCI_INT_A, PIRQ_A),
371 FIXED_INT_PIRQ(PCH_DEVFN_PCIE10, PCI_INT_B, PIRQ_B),
372 FIXED_INT_PIRQ(PCH_DEVFN_PCIE11, PCI_INT_C, PIRQ_C),
373 FIXED_INT_PIRQ(PCH_DEVFN_PCIE12, PCI_INT_D, PIRQ_D),
374 FIXED_INT_PIRQ(PCH_DEVFN_PCIE13, PCI_INT_A, PIRQ_A),
375 FIXED_INT_PIRQ(PCH_DEVFN_PCIE14, PCI_INT_B, PIRQ_B),
376 FIXED_INT_PIRQ(PCH_DEVFN_PCIE15, PCI_INT_C, PIRQ_C),
377 FIXED_INT_PIRQ(PCH_DEVFN_PCIE16, PCI_INT_D, PIRQ_D),
378 },
379 },
380 {
381 .slot = PCH_DEV_SLOT_PCIE_2,
382 .fns = {
383 FIXED_INT_PIRQ(PCH_DEVFN_PCIE17, PCI_INT_A, PIRQ_A),
384 FIXED_INT_PIRQ(PCH_DEVFN_PCIE18, PCI_INT_B, PIRQ_B),
385 FIXED_INT_PIRQ(PCH_DEVFN_PCIE19, PCI_INT_C, PIRQ_C),
386 FIXED_INT_PIRQ(PCH_DEVFN_PCIE20, PCI_INT_D, PIRQ_D),
387 FIXED_INT_PIRQ(PCH_DEVFN_PCIE21, PCI_INT_A, PIRQ_A),
388 FIXED_INT_PIRQ(PCH_DEVFN_PCIE22, PCI_INT_B, PIRQ_B),
389 FIXED_INT_PIRQ(PCH_DEVFN_PCIE23, PCI_INT_C, PIRQ_C),
390 FIXED_INT_PIRQ(PCH_DEVFN_PCIE24, PCI_INT_D, PIRQ_D),
391 },
392 },
393 {
394 .slot = PCH_DEV_SLOT_PCIE_3,
395 .fns = {
396 FIXED_INT_PIRQ(PCH_DEVFN_PCIE25, PCI_INT_A, PIRQ_A),
397 FIXED_INT_PIRQ(PCH_DEVFN_PCIE26, PCI_INT_B, PIRQ_B),
398 FIXED_INT_PIRQ(PCH_DEVFN_PCIE27, PCI_INT_C, PIRQ_C),
399 FIXED_INT_PIRQ(PCH_DEVFN_PCIE28, PCI_INT_D, PIRQ_D),
400 },
401 },
402 {
403 .slot = PCH_DEV_SLOT_SIO5,
404 .fns = {
405 /* UART0 shares an interrupt line with TSN0, so must use
406 a PIRQ */
407 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART0, PCI_INT_A),
408 /* UART1 shares an interrupt line with TSN1, so must use
409 a PIRQ */
410 FIXED_INT_ANY_PIRQ(PCH_DEVFN_UART1, PCI_INT_B),
411 DIRECT_IRQ(PCH_DEVFN_GSPI0),
412 DIRECT_IRQ(PCH_DEVFN_GSPI1),
413 },
414 },
415 {
416 .slot = PCH_DEV_SLOT_ESPI,
417 .fns = {
418 ANY_PIRQ(PCH_DEVFN_HDA),
419 ANY_PIRQ(PCH_DEVFN_SMBUS),
420 ANY_PIRQ(PCH_DEVFN_GBE),
421 /* INTERRUPT_PIN is RO/0x01 */
422 FIXED_INT_ANY_PIRQ(PCH_DEVFN_TRACEHUB, PCI_INT_A),
423 },
424 },
425};
426
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600427static const SI_PCH_DEVICE_INTERRUPT_CONFIG *pci_irq_to_fsp(size_t *out_count)
428{
429 const struct pci_irq_entry *entry = get_cached_pci_irqs();
430 SI_PCH_DEVICE_INTERRUPT_CONFIG *config;
431 size_t pch_total = 0;
432 size_t cfg_count = 0;
433
434 if (!entry)
435 return NULL;
436
437 /* Count PCH devices */
438 while (entry) {
Kapil Porwal9395cf92022-12-22 23:08:26 +0530439 if (is_pch_slot(entry->devfn))
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600440 ++pch_total;
441 entry = entry->next;
442 }
443
444 /* Convert PCH device entries to FSP format */
445 config = calloc(pch_total, sizeof(*config));
446 entry = get_cached_pci_irqs();
447 while (entry) {
Kapil Porwal9395cf92022-12-22 23:08:26 +0530448 if (!is_pch_slot(entry->devfn)) {
Tim Wawrzynczak43607e42021-05-18 09:04:42 -0600449 entry = entry->next;
450 continue;
451 }
452
453 config[cfg_count].Device = PCI_SLOT(entry->devfn);
454 config[cfg_count].Function = PCI_FUNC(entry->devfn);
455 config[cfg_count].IntX = (SI_PCH_INT_PIN)entry->pin;
456 config[cfg_count].Irq = entry->irq;
457 ++cfg_count;
458
459 entry = entry->next;
460 }
461
462 *out_count = cfg_count;
463
464 return config;
465}
466
Subrata Banik2871e0e2020-09-27 11:30:58 +0530467/*
468 * Chip config parameter PcieRpL1Substates uses (UPD value + 1)
469 * because UPD value of 0 for PcieRpL1Substates means disabled for FSP.
470 * In order to ensure that mainboard setting does not disable L1 substates
471 * incorrectly, chip config parameter values are offset by 1 with 0 meaning
472 * use FSP UPD default. get_l1_substate_control() ensures that the right UPD
473 * value is set in fsp_params.
474 * 0: Use FSP UPD default
475 * 1: Disable L1 substates
476 * 2: Use L1.1
477 * 3: Use L1.2 (FSP UPD default)
478 */
479static int get_l1_substate_control(enum L1_substates_control ctl)
480{
Bora Guvendik8c462322022-11-29 15:45:06 -0800481 if (CONFIG(SOC_INTEL_COMPLIANCE_TEST_MODE))
482 ctl = L1_SS_DISABLED;
483 else if ((ctl > L1_SS_L1_2) || (ctl == L1_SS_FSP_DEFAULT))
Subrata Banik2871e0e2020-09-27 11:30:58 +0530484 ctl = L1_SS_L1_2;
485 return ctl - 1;
486}
487
Kevin Chang6e52c1d2022-03-18 21:04:07 +0800488/*
Jeremy Sollerd59c7992023-05-16 15:04:08 -0600489 * Chip config parameter pcie_rp_aspm uses (UPD value + 1) because
490 * a UPD value of 0 for pcie_rp_aspm means disabled. In order to ensure
491 * that the mainboard setting does not disable ASPM incorrectly, chip
492 * config parameter values are offset by 1 with 0 meaning use FSP UPD default.
Kevin Chang6e52c1d2022-03-18 21:04:07 +0800493 * get_aspm_control() ensures that the right UPD value is set in fsp_params.
Jeremy Sollerd59c7992023-05-16 15:04:08 -0600494 * 0: Use FSP UPD default
495 * 1: Disable ASPM
496 * 2: L0s only
497 * 3: L1 only
498 * 4: L0s and L1
499 * 5: Auto configuration
Kevin Chang6e52c1d2022-03-18 21:04:07 +0800500 */
501static unsigned int get_aspm_control(enum ASPM_control ctl)
502{
Jeremy Sollerd59c7992023-05-16 15:04:08 -0600503 if ((ctl > ASPM_AUTO) || (ctl == ASPM_DEFAULT))
Kevin Chang6e52c1d2022-03-18 21:04:07 +0800504 ctl = ASPM_AUTO;
Jeremy Sollerd59c7992023-05-16 15:04:08 -0600505 return ctl - 1;
Kevin Chang6e52c1d2022-03-18 21:04:07 +0800506}
507
Jeremy Compostella1b44c812022-06-17 15:18:02 -0700508/* This function returns the VccIn Aux Imon IccMax values for ADL and RPL
509 SKU's */
V Sowmya458708f2021-07-09 22:11:04 +0530510static uint16_t get_vccin_aux_imon_iccmax(void)
511{
Jeremy Compostellacb08c792022-06-30 16:31:14 -0700512 struct device *dev = pcidev_path_on_root(SA_DEVFN_ROOT);
513 uint16_t mch_id = dev ? pci_read_config16(dev, PCI_DEVICE_ID) : 0xffff;
Curtis Chenea1bb5f2021-11-25 13:17:42 +0800514 uint8_t tdp;
V Sowmya458708f2021-07-09 22:11:04 +0530515
V Sowmya458708f2021-07-09 22:11:04 +0530516 switch (mch_id) {
Felix Singer43b7f412022-03-07 04:34:52 +0100517 case PCI_DID_INTEL_ADL_P_ID_1:
518 case PCI_DID_INTEL_ADL_P_ID_3:
Curtis Chen3fc3e6c2022-03-10 11:51:38 +0800519 case PCI_DID_INTEL_ADL_P_ID_4:
Felix Singer43b7f412022-03-07 04:34:52 +0100520 case PCI_DID_INTEL_ADL_P_ID_5:
521 case PCI_DID_INTEL_ADL_P_ID_6:
522 case PCI_DID_INTEL_ADL_P_ID_7:
Curtis Chen3fc3e6c2022-03-10 11:51:38 +0800523 case PCI_DID_INTEL_ADL_P_ID_8:
524 case PCI_DID_INTEL_ADL_P_ID_9:
525 case PCI_DID_INTEL_ADL_P_ID_10:
Jeremy Compostella1b44c812022-06-17 15:18:02 -0700526 case PCI_DID_INTEL_RPL_P_ID_1:
527 case PCI_DID_INTEL_RPL_P_ID_2:
528 case PCI_DID_INTEL_RPL_P_ID_3:
Lawrence Chang0a5da512022-10-19 14:38:41 +0800529 case PCI_DID_INTEL_RPL_P_ID_4:
Marx Wang39ede0a2022-12-20 10:48:33 +0800530 case PCI_DID_INTEL_RPL_P_ID_5:
Curtis Chenea1bb5f2021-11-25 13:17:42 +0800531 tdp = get_cpu_tdp();
532 if (tdp == TDP_45W)
533 return ICC_MAX_TDP_45W;
534 return ICC_MAX_TDP_15W_28W;
Felix Singer43b7f412022-03-07 04:34:52 +0100535 case PCI_DID_INTEL_ADL_M_ID_1:
536 case PCI_DID_INTEL_ADL_M_ID_2:
Bora Guvendik31605952021-09-01 17:32:07 -0700537 return ICC_MAX_ID_ADL_M_MA;
V Sowmya2af96022022-04-05 17:03:04 +0530538 case PCI_DID_INTEL_ADL_N_ID_1:
539 case PCI_DID_INTEL_ADL_N_ID_2:
540 case PCI_DID_INTEL_ADL_N_ID_3:
541 case PCI_DID_INTEL_ADL_N_ID_4:
542 return ICC_MAX_ID_ADL_N_MA;
Michał Żygowskibda2a152022-04-25 15:02:10 +0200543 case PCI_DID_INTEL_ADL_S_ID_1:
544 case PCI_DID_INTEL_ADL_S_ID_3:
545 case PCI_DID_INTEL_ADL_S_ID_8:
546 case PCI_DID_INTEL_ADL_S_ID_10:
Michał Żygowskia01b62a2022-07-21 18:08:19 +0200547 case PCI_DID_INTEL_ADL_S_ID_11:
548 case PCI_DID_INTEL_ADL_S_ID_12:
Tim Crawford53c6eea2023-07-07 09:59:56 -0600549 case PCI_DID_INTEL_RPL_HX_ID_1:
550 case PCI_DID_INTEL_RPL_HX_ID_2:
551 case PCI_DID_INTEL_RPL_HX_ID_3:
552 case PCI_DID_INTEL_RPL_HX_ID_4:
553 case PCI_DID_INTEL_RPL_HX_ID_5:
554 case PCI_DID_INTEL_RPL_HX_ID_6:
555 case PCI_DID_INTEL_RPL_HX_ID_7:
556 case PCI_DID_INTEL_RPL_HX_ID_8:
Michał Żygowskibda2a152022-04-25 15:02:10 +0200557 return ICC_MAX_ADL_S;
Max Fritz573e6de2022-11-19 01:54:44 +0100558 case PCI_DID_INTEL_RPL_S_ID_1:
559 case PCI_DID_INTEL_RPL_S_ID_2:
560 case PCI_DID_INTEL_RPL_S_ID_3:
561 case PCI_DID_INTEL_RPL_S_ID_4:
562 case PCI_DID_INTEL_RPL_S_ID_5:
563 return ICC_MAX_RPL_S;
V Sowmya458708f2021-07-09 22:11:04 +0530564 default:
565 printk(BIOS_ERR, "Unknown MCH ID: 0x%4x, skipping VccInAuxImonIccMax config\n",
566 mch_id);
567 return 0;
568 }
569}
570
Subrata Banikb03cadf2021-06-09 22:19:04 +0530571__weak void mainboard_update_soc_chip_config(struct soc_intel_alderlake_config *config)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530572{
Subrata Banikb03cadf2021-06-09 22:19:04 +0530573 /* Override settings per board. */
574}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530575
Subrata Banikb03cadf2021-06-09 22:19:04 +0530576static void fill_fsps_lpss_params(FSP_S_CONFIG *s_cfg,
577 const struct soc_intel_alderlake_config *config)
578{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530579 for (int i = 0; i < CONFIG_SOC_INTEL_I2C_DEV_MAX; i++)
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530580 s_cfg->SerialIoI2cMode[i] = config->serial_io_i2c_mode[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530581
582 for (int i = 0; i < CONFIG_SOC_INTEL_COMMON_BLOCK_GSPI_MAX; i++) {
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530583 s_cfg->SerialIoSpiMode[i] = config->serial_io_gspi_mode[i];
584 s_cfg->SerialIoSpiCsMode[i] = config->serial_io_gspi_cs_mode[i];
585 s_cfg->SerialIoSpiCsState[i] = config->serial_io_gspi_cs_state[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530586 }
587
588 for (int i = 0; i < CONFIG_SOC_INTEL_UART_DEV_MAX; i++)
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530589 s_cfg->SerialIoUartMode[i] = config->serial_io_uart_mode[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530590}
591
Subrata Banikfad1cb02022-08-12 18:12:46 +0530592static void fill_fsps_microcode_params(FSP_S_CONFIG *s_cfg,
Subrata Banikb03cadf2021-06-09 22:19:04 +0530593 const struct soc_intel_alderlake_config *config)
Subrata Banik2871e0e2020-09-27 11:30:58 +0530594{
Subrata Banik99289a82020-12-22 10:54:44 +0530595 const struct microcode *microcode_file;
596 size_t microcode_len;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530597
Subrata Banikb03cadf2021-06-09 22:19:04 +0530598 /* Locate microcode and pass to FSP-S for 2nd microcode loading */
Subrata Banik7b523a42021-09-22 16:46:16 +0530599 microcode_file = intel_microcode_find();
Subrata Banik99289a82020-12-22 10:54:44 +0530600
Selma Bensaid291294d2021-10-11 16:37:36 -0700601 if (microcode_file != NULL) {
602 microcode_len = get_microcode_size(microcode_file);
603 if (microcode_len != 0) {
604 /* Update CPU Microcode patch base address/size */
605 s_cfg->MicrocodeRegionBase = (uint32_t)(uintptr_t)microcode_file;
606 s_cfg->MicrocodeRegionSize = (uint32_t)microcode_len;
607 }
Subrata Banik99289a82020-12-22 10:54:44 +0530608 }
Subrata Banikfad1cb02022-08-12 18:12:46 +0530609}
Subrata Banik99289a82020-12-22 10:54:44 +0530610
Subrata Banikfad1cb02022-08-12 18:12:46 +0530611static void fill_fsps_cpu_params(FSP_S_CONFIG *s_cfg,
612 const struct soc_intel_alderlake_config *config)
613{
Subrata Banik8409f152022-08-15 17:08:13 +0530614 /*
615 * FIXME: FSP assumes ownership of the APs (Application Processors)
616 * upon passing `NULL` pointer to the CpuMpPpi FSP-S UPD.
617 * Hence, pass a valid pointer to the CpuMpPpi UPD unconditionally.
618 * This would avoid APs from getting hijacked by FSP while coreboot
619 * decides to set SkipMpInit UPD.
620 */
Elyes Haouas9018dee2022-11-18 15:07:33 +0100621 s_cfg->CpuMpPpi = (uintptr_t)mp_fill_ppi_services_data();
Subrata Banik8409f152022-08-15 17:08:13 +0530622
Subrata Banika2473192023-02-22 13:03:04 +0000623 if (CONFIG(USE_FSP_FEATURE_PROGRAM_ON_APS))
Subrata Banikceaf9d12022-06-05 19:33:33 +0530624 /*
Subrata Banikfad1cb02022-08-12 18:12:46 +0530625 * Fill `2nd microcode loading FSP UPD` if FSP is running CPU feature
626 * programming.
627 */
628 fill_fsps_microcode_params(s_cfg, config);
Subrata Banik8409f152022-08-15 17:08:13 +0530629 else
Subrata Banikceaf9d12022-06-05 19:33:33 +0530630 s_cfg->SkipMpInit = !CONFIG(USE_INTEL_FSP_MP_INIT);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530631}
632
633static void fill_fsps_igd_params(FSP_S_CONFIG *s_cfg,
634 const struct soc_intel_alderlake_config *config)
635{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530636 /* Load VBT before devicetree-specific config. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530637 s_cfg->GraphicsConfigPtr = (uintptr_t)vbt_get();
Subrata Banik2871e0e2020-09-27 11:30:58 +0530638
639 /* Check if IGD is present and fill Graphics init param accordingly */
Subrata Banikc0983c92021-06-15 13:02:01 +0530640 s_cfg->PeiGraphicsPeimInit = CONFIG(RUN_FSP_GOP) && is_devfn_enabled(SA_DEVFN_IGD);
Subrata Banik72d616c2023-11-30 19:09:46 +0530641 s_cfg->LidStatus = CONFIG(VBOOT_LID_SWITCH) ? get_lid_switch() : CONFIG(RUN_FSP_GOP);
Lean Sheng Tane8df93a2022-04-01 19:07:53 +0200642 s_cfg->PavpEnable = CONFIG(PAVP);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530643}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530644
Michał Kopeć75a49fe2022-04-08 11:28:45 +0200645WEAK_DEV_PTR(tcss_usb3_port1);
646WEAK_DEV_PTR(tcss_usb3_port2);
647WEAK_DEV_PTR(tcss_usb3_port3);
648WEAK_DEV_PTR(tcss_usb3_port4);
649
Subrata Banikb03cadf2021-06-09 22:19:04 +0530650static void fill_fsps_tcss_params(FSP_S_CONFIG *s_cfg,
651 const struct soc_intel_alderlake_config *config)
652{
Furquan Shaikheafca1f2021-09-22 13:59:39 -0700653 const struct device *tcss_port_arr[] = {
654 DEV_PTR(tcss_usb3_port1),
655 DEV_PTR(tcss_usb3_port2),
656 DEV_PTR(tcss_usb3_port3),
657 DEV_PTR(tcss_usb3_port4),
658 };
659
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530660 s_cfg->TcssAuxOri = config->tcss_aux_ori;
Deepti Deshatty8e7facf2021-05-12 17:45:37 +0530661
662 /* Explicitly clear this field to avoid using defaults */
Subrata Banikc0983c92021-06-15 13:02:01 +0530663 memset(s_cfg->IomTypeCPortPadCfg, 0, sizeof(s_cfg->IomTypeCPortPadCfg));
Subrata Banik2871e0e2020-09-27 11:30:58 +0530664
665 /*
666 * Set FSPS UPD ITbtConnectTopologyTimeoutInMs with value 0. FSP will
667 * evaluate this UPD value and skip sending command. There will be no
668 * delay for command completion.
669 */
Subrata Banikc0983c92021-06-15 13:02:01 +0530670 s_cfg->ITbtConnectTopologyTimeoutInMs = 0;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530671
Subrata Banikb03cadf2021-06-09 22:19:04 +0530672 /* D3Hot and D3Cold for TCSS */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530673 s_cfg->D3HotEnable = !config->tcss_d3_hot_disable;
Sean Rhodes6bb11a32023-04-17 20:29:45 +0100674 s_cfg->D3ColdEnable = CONFIG(D3COLD_SUPPORT);
Bernardo Perez Priego421ce562021-06-09 09:40:31 -0700675
676 s_cfg->UsbTcPortEn = 0;
677 for (int i = 0; i < MAX_TYPE_C_PORTS; i++) {
Furquan Shaikheafca1f2021-09-22 13:59:39 -0700678 if (is_dev_enabled(tcss_port_arr[i]))
Bernardo Perez Priego421ce562021-06-09 09:40:31 -0700679 s_cfg->UsbTcPortEn |= BIT(i);
680 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530681}
682
683static void fill_fsps_chipset_lockdown_params(FSP_S_CONFIG *s_cfg,
684 const struct soc_intel_alderlake_config *config)
685{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530686 /* Chipset Lockdown */
Felix Singerf9d7dc72021-05-03 02:33:15 +0200687 const bool lockdown_by_fsp = get_lockdown_config() == CHIPSET_LOCKDOWN_FSP;
688 s_cfg->PchLockDownGlobalSmi = lockdown_by_fsp;
689 s_cfg->PchLockDownBiosInterface = lockdown_by_fsp;
Subrata Banik393b0932022-01-11 11:59:39 +0530690 s_cfg->PchUnlockGpioPads = lockdown_by_fsp;
Felix Singerf9d7dc72021-05-03 02:33:15 +0200691 s_cfg->RtcMemoryLock = lockdown_by_fsp;
Tim Wawrzynczak091dfa12021-08-24 09:32:09 -0600692 s_cfg->SkipPamLock = !lockdown_by_fsp;
Tim Wawrzynczakc0e82e72021-06-17 12:42:35 -0600693
694 /* coreboot will send EOP before loading payload */
695 s_cfg->EndOfPostMessage = EOP_DISABLE;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530696}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530697
Subrata Banikb03cadf2021-06-09 22:19:04 +0530698static void fill_fsps_xhci_params(FSP_S_CONFIG *s_cfg,
699 const struct soc_intel_alderlake_config *config)
700{
701 int i;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530702 /* USB */
703 for (i = 0; i < ARRAY_SIZE(config->usb2_ports); i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530704 s_cfg->PortUsb20Enable[i] = config->usb2_ports[i].enable;
705 s_cfg->Usb2PhyPetxiset[i] = config->usb2_ports[i].pre_emp_bias;
706 s_cfg->Usb2PhyTxiset[i] = config->usb2_ports[i].tx_bias;
707 s_cfg->Usb2PhyPredeemp[i] = config->usb2_ports[i].tx_emp_enable;
708 s_cfg->Usb2PhyPehalfbit[i] = config->usb2_ports[i].pre_emp_bit;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530709
710 if (config->usb2_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530711 s_cfg->Usb2OverCurrentPin[i] = config->usb2_ports[i].ocpin;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530712 else
Subrata Banikc0983c92021-06-15 13:02:01 +0530713 s_cfg->Usb2OverCurrentPin[i] = OC_SKIP;
Anil Kumarc6b65c12022-02-01 12:59:03 -0800714
715 if (config->usb2_ports[i].type_c)
716 s_cfg->PortResetMessageEnable[i] = 1;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530717 }
718
719 for (i = 0; i < ARRAY_SIZE(config->usb3_ports); i++) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530720 s_cfg->PortUsb30Enable[i] = config->usb3_ports[i].enable;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530721 if (config->usb3_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530722 s_cfg->Usb3OverCurrentPin[i] = config->usb3_ports[i].ocpin;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530723 else
Subrata Banikc0983c92021-06-15 13:02:01 +0530724 s_cfg->Usb3OverCurrentPin[i] = OC_SKIP;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530725
726 if (config->usb3_ports[i].tx_de_emp) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530727 s_cfg->Usb3HsioTxDeEmphEnable[i] = 1;
728 s_cfg->Usb3HsioTxDeEmph[i] = config->usb3_ports[i].tx_de_emp;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530729 }
730 if (config->usb3_ports[i].tx_downscale_amp) {
Subrata Banikc0983c92021-06-15 13:02:01 +0530731 s_cfg->Usb3HsioTxDownscaleAmpEnable[i] = 1;
732 s_cfg->Usb3HsioTxDownscaleAmp[i] =
Subrata Banik2871e0e2020-09-27 11:30:58 +0530733 config->usb3_ports[i].tx_downscale_amp;
734 }
735 }
736
Maulik V Vaghela69353502021-04-14 14:01:02 +0530737 for (i = 0; i < ARRAY_SIZE(config->tcss_ports); i++) {
738 if (config->tcss_ports[i].enable)
Subrata Banikc0983c92021-06-15 13:02:01 +0530739 s_cfg->CpuUsb3OverCurrentPin[i] = config->tcss_ports[i].ocpin;
Maulik V Vaghela69353502021-04-14 14:01:02 +0530740 }
Sridhar Siricilla37c33052022-04-02 10:33:00 +0530741
742 s_cfg->PmcUsb2PhySusPgEnable = !config->usb2_phy_sus_pg_disable;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530743}
Maulik V Vaghela69353502021-04-14 14:01:02 +0530744
Subrata Banikb03cadf2021-06-09 22:19:04 +0530745static void fill_fsps_xdci_params(FSP_S_CONFIG *s_cfg,
746 const struct soc_intel_alderlake_config *config)
747{
Angel Ponsc7cfe0b2021-06-23 12:39:22 +0200748 s_cfg->XdciEnable = xdci_can_enable(PCH_DEVFN_USBOTG);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530749}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530750
Subrata Banikb03cadf2021-06-09 22:19:04 +0530751static void fill_fsps_uart_params(FSP_S_CONFIG *s_cfg,
752 const struct soc_intel_alderlake_config *config)
753{
Subrata Banik88381c92022-03-29 11:26:11 +0530754 if (CONFIG(FSP_USES_CB_DEBUG_EVENT_HANDLER) && CONFIG(CONSOLE_SERIAL) &&
755 CONFIG(FSP_ENABLE_SERIAL_DEBUG))
756 s_cfg->FspEventHandler = (UINT32)((FSP_EVENT_HANDLER *)
757 fsp_debug_event_handler);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530758 /* PCH UART selection for FSP Debug */
Subrata Banikc0983c92021-06-15 13:02:01 +0530759 s_cfg->SerialIoDebugUartNumber = CONFIG_UART_FOR_CONSOLE;
760 ASSERT(ARRAY_SIZE(s_cfg->SerialIoUartAutoFlow) > CONFIG_UART_FOR_CONSOLE);
761 s_cfg->SerialIoUartAutoFlow[CONFIG_UART_FOR_CONSOLE] = 0;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530762}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530763
Subrata Banikb03cadf2021-06-09 22:19:04 +0530764static void fill_fsps_sata_params(FSP_S_CONFIG *s_cfg,
765 const struct soc_intel_alderlake_config *config)
766{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530767 /* SATA */
Subrata Banikc0983c92021-06-15 13:02:01 +0530768 s_cfg->SataEnable = is_devfn_enabled(PCH_DEVFN_SATA);
769 if (s_cfg->SataEnable) {
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530770 s_cfg->SataMode = config->sata_mode;
771 s_cfg->SataSalpSupport = config->sata_salp_support;
772 memcpy(s_cfg->SataPortsEnable, config->sata_ports_enable,
Subrata Banikc0983c92021-06-15 13:02:01 +0530773 sizeof(s_cfg->SataPortsEnable));
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530774 memcpy(s_cfg->SataPortsDevSlp, config->sata_ports_dev_slp,
Subrata Banikc0983c92021-06-15 13:02:01 +0530775 sizeof(s_cfg->SataPortsDevSlp));
Subrata Banik2871e0e2020-09-27 11:30:58 +0530776 }
777
778 /*
Subrata Banikb03cadf2021-06-09 22:19:04 +0530779 * Power Optimizer for SATA.
780 * SataPwrOptimizeDisable is default to 0.
Subrata Banik2871e0e2020-09-27 11:30:58 +0530781 * Boards not needing the optimizers explicitly disables them by setting
782 * these disable variables to 1 in devicetree overrides.
783 */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530784 s_cfg->SataPwrOptEnable = !(config->sata_pwr_optimize_disable);
Lean Sheng Tan1ec8f972022-09-07 16:07:33 +0200785 /* Test mode for SATA margining */
786 s_cfg->SataTestMode = CONFIG(ENABLE_SATA_TEST_MODE);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530787 /*
788 * Enable DEVSLP Idle Timeout settings DmVal and DitoVal.
789 * SataPortsDmVal is the DITO multiplier. Default is 15.
790 * SataPortsDitoVal is the DEVSLP Idle Timeout (DITO), Default is 625ms.
791 * The default values can be changed from devicetree.
792 */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530793 for (size_t i = 0; i < ARRAY_SIZE(config->sata_ports_enable_dito_config); i++) {
794 if (config->sata_ports_enable_dito_config[i]) {
795 s_cfg->SataPortsDmVal[i] = config->sata_ports_dm_val[i];
796 s_cfg->SataPortsDitoVal[i] = config->sata_ports_dito_val[i];
Subrata Banik2871e0e2020-09-27 11:30:58 +0530797 }
798 }
Subrata Banikb03cadf2021-06-09 22:19:04 +0530799}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530800
Subrata Banikb03cadf2021-06-09 22:19:04 +0530801static void fill_fsps_thermal_params(FSP_S_CONFIG *s_cfg,
802 const struct soc_intel_alderlake_config *config)
803{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530804 /* Enable TCPU for processor thermal control */
Subrata Banikc0983c92021-06-15 13:02:01 +0530805 s_cfg->Device4Enable = is_devfn_enabled(SA_DEVFN_DPTF);
Subrata Banik2871e0e2020-09-27 11:30:58 +0530806
807 /* Set TccActivationOffset */
Subrata Banikc0983c92021-06-15 13:02:01 +0530808 s_cfg->TccActivationOffset = config->tcc_offset;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530809}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530810
Jeremy Soller9601b1e2022-05-26 10:21:36 -0600811static void fill_fsps_gna_params(FSP_S_CONFIG *s_cfg,
812 const struct soc_intel_alderlake_config *config)
813{
814 s_cfg->GnaEnable = is_devfn_enabled(SA_DEVFN_GNA);
815}
816
Subrata Banikb03cadf2021-06-09 22:19:04 +0530817static void fill_fsps_lan_params(FSP_S_CONFIG *s_cfg,
818 const struct soc_intel_alderlake_config *config)
819{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530820 /* LAN */
Subrata Banikc0983c92021-06-15 13:02:01 +0530821 s_cfg->PchLanEnable = is_devfn_enabled(PCH_DEVFN_GBE);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530822}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530823
Subrata Banikb03cadf2021-06-09 22:19:04 +0530824static void fill_fsps_cnvi_params(FSP_S_CONFIG *s_cfg,
825 const struct soc_intel_alderlake_config *config)
826{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530827 /* CNVi */
Michał Żygowski01025d32023-07-12 13:22:09 +0200828#if CONFIG(FSP_USE_REPO)
829 /* This option is only available in public FSP headers on FSP repo */
Michał Żygowski97074642022-06-30 18:19:27 +0200830 s_cfg->CnviWifiCore = is_devfn_enabled(PCH_DEVFN_CNVI_WIFI);
831#endif
Subrata Banikc0983c92021-06-15 13:02:01 +0530832 s_cfg->CnviMode = is_devfn_enabled(PCH_DEVFN_CNVI_WIFI);
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530833 s_cfg->CnviBtCore = config->cnvi_bt_core;
834 s_cfg->CnviBtAudioOffload = config->cnvi_bt_audio_offload;
Cliff Huangbc1941f2021-02-10 17:41:41 -0800835 /* Assert if CNVi BT is enabled without CNVi being enabled. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530836 assert(s_cfg->CnviMode || !s_cfg->CnviBtCore);
Cliff Huangbc1941f2021-02-10 17:41:41 -0800837 /* Assert if CNVi BT offload is enabled without CNVi BT being enabled. */
Subrata Banikc0983c92021-06-15 13:02:01 +0530838 assert(s_cfg->CnviBtCore || !s_cfg->CnviBtAudioOffload);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530839}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530840
Subrata Banikb03cadf2021-06-09 22:19:04 +0530841static void fill_fsps_vmd_params(FSP_S_CONFIG *s_cfg,
842 const struct soc_intel_alderlake_config *config)
843{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530844 /* VMD */
Subrata Banikc0983c92021-06-15 13:02:01 +0530845 s_cfg->VmdEnable = is_devfn_enabled(SA_DEVFN_VMD);
Subrata Banikb03cadf2021-06-09 22:19:04 +0530846}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530847
Subrata Banikb03cadf2021-06-09 22:19:04 +0530848static void fill_fsps_thc_params(FSP_S_CONFIG *s_cfg,
849 const struct soc_intel_alderlake_config *config)
850{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530851 /* THC */
Subrata Banikc0983c92021-06-15 13:02:01 +0530852 s_cfg->ThcPort0Assignment = is_devfn_enabled(PCH_DEVFN_THC0) ? THC_0 : THC_NONE;
853 s_cfg->ThcPort1Assignment = is_devfn_enabled(PCH_DEVFN_THC1) ? THC_1 : THC_NONE;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530854}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530855
Subrata Banikb03cadf2021-06-09 22:19:04 +0530856static void fill_fsps_tbt_params(FSP_S_CONFIG *s_cfg,
857 const struct soc_intel_alderlake_config *config)
858{
Bernardo Perez Priego095f97b2021-05-18 18:39:19 -0700859 /* USB4/TBT */
Subrata Banikb03cadf2021-06-09 22:19:04 +0530860 for (int i = 0; i < ARRAY_SIZE(s_cfg->ITbtPcieRootPortEn); i++)
Subrata Banikc0983c92021-06-15 13:02:01 +0530861 s_cfg->ITbtPcieRootPortEn[i] = is_devfn_enabled(SA_DEVFN_TBT(i));
Subrata Banikb03cadf2021-06-09 22:19:04 +0530862}
Bernardo Perez Priego095f97b2021-05-18 18:39:19 -0700863
Subrata Banikb03cadf2021-06-09 22:19:04 +0530864static void fill_fsps_8254_params(FSP_S_CONFIG *s_cfg,
865 const struct soc_intel_alderlake_config *config)
866{
Subrata Banik2871e0e2020-09-27 11:30:58 +0530867 /* Legacy 8254 timer support */
Sean Rhodesbc35bed2021-07-13 13:36:28 +0100868 bool use_8254 = get_uint_option("legacy_8254_timer", CONFIG(USE_LEGACY_8254_TIMER));
869 s_cfg->Enable8254ClockGating = !use_8254;
870 s_cfg->Enable8254ClockGatingOnS3 = !use_8254;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530871}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530872
Michael Niewöhner0e905802021-09-25 00:10:30 +0200873static void fill_fsps_pm_timer_params(FSP_S_CONFIG *s_cfg,
874 const struct soc_intel_alderlake_config *config)
875{
876 /*
877 * Legacy PM ACPI Timer (and TCO Timer)
878 * This *must* be 1 in any case to keep FSP from
879 * 1) enabling PM ACPI Timer emulation in uCode.
880 * 2) disabling the PM ACPI Timer.
881 * We handle both by ourself!
882 */
883 s_cfg->EnableTcoTimer = 1;
884}
885
Subrata Banikb03cadf2021-06-09 22:19:04 +0530886static void fill_fsps_storage_params(FSP_S_CONFIG *s_cfg,
887 const struct soc_intel_alderlake_config *config)
888{
Krishna Prasad Bhata6d642f2022-01-16 23:16:24 +0530889#if CONFIG(SOC_INTEL_ALDERLAKE_PCH_N)
890 /* eMMC Configuration */
891 s_cfg->ScsEmmcEnabled = is_devfn_enabled(PCH_DEVFN_EMMC);
892 if (s_cfg->ScsEmmcEnabled)
893 s_cfg->ScsEmmcHs400Enabled = config->emmc_enable_hs400_mode;
894#endif
Meera Ravindranathd8ea3602022-03-16 15:27:00 +0530895
896 /* UFS Configuration */
897 s_cfg->UfsEnable[0] = 0; /* UFS Controller 0 is fuse disabled */
898 s_cfg->UfsEnable[1] = is_devfn_enabled(PCH_DEVFN_UFS);
899
Subrata Banik2871e0e2020-09-27 11:30:58 +0530900 /* Enable Hybrid storage auto detection */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +0530901 s_cfg->HybridStorageMode = config->hybrid_storage_mode;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530902}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530903
Subrata Banikb03cadf2021-06-09 22:19:04 +0530904static void fill_fsps_pcie_params(FSP_S_CONFIG *s_cfg,
905 const struct soc_intel_alderlake_config *config)
906{
907 uint32_t enable_mask = pcie_rp_enable_mask(get_pch_pcie_rp_table());
908 for (int i = 0; i < CONFIG_MAX_PCH_ROOT_PORTS; i++) {
Eric Lai5b302b22020-12-05 16:49:43 +0800909 if (!(enable_mask & BIT(i)))
910 continue;
911 const struct pcie_rp_config *rp_cfg = &config->pch_pcie_rp[i];
Subrata Banikc0983c92021-06-15 13:02:01 +0530912 s_cfg->PcieRpL1Substates[i] =
Eric Lai5b302b22020-12-05 16:49:43 +0800913 get_l1_substate_control(rp_cfg->PcieRpL1Substates);
Subrata Banikc0983c92021-06-15 13:02:01 +0530914 s_cfg->PcieRpLtrEnable[i] = !!(rp_cfg->flags & PCIE_RP_LTR);
915 s_cfg->PcieRpAdvancedErrorReporting[i] = !!(rp_cfg->flags & PCIE_RP_AER);
Sridahr Siricilla096ce142021-09-17 22:25:17 +0530916 s_cfg->PcieRpHotPlug[i] = !!(rp_cfg->flags & PCIE_RP_HOTPLUG)
917 || CONFIG(SOC_INTEL_COMPLIANCE_TEST_MODE);
Subrata Banikc0983c92021-06-15 13:02:01 +0530918 s_cfg->PcieRpClkReqDetect[i] = !!(rp_cfg->flags & PCIE_RP_CLK_REQ_DETECT);
Kevin Chang6e52c1d2022-03-18 21:04:07 +0800919 if (rp_cfg->pcie_rp_aspm)
920 s_cfg->PcieRpAspm[i] = get_aspm_control(rp_cfg->pcie_rp_aspm);
Cliff Huang61a442ec2022-04-28 18:06:54 -0700921 /* PcieRpSlotImplemented default to 1 (slot implemented) in FSP; 0: built-in */
922 if (!!(rp_cfg->flags & PCIE_RP_BUILT_IN))
923 s_cfg->PcieRpSlotImplemented[i] = 0;
924 s_cfg->PcieRpDetectTimeoutMs[i] = rp_cfg->pcie_rp_detect_timeout_ms;
Subrata Banik2871e0e2020-09-27 11:30:58 +0530925 }
Sridahr Siricilla096ce142021-09-17 22:25:17 +0530926 s_cfg->PcieComplianceTestMode = CONFIG(SOC_INTEL_COMPLIANCE_TEST_MODE);
Patrick Rudolphb8abde72023-07-21 09:09:07 +0200927
Michał Żygowski12a1fc22023-08-21 11:12:04 +0200928#if CONFIG(FSP_TYPE_IOT) && !CONFIG(SOC_INTEL_RAPTORLAKE)
Patrick Rudolphb8abde72023-07-21 09:09:07 +0200929 /*
930 * Intel requires that all enabled PCH PCIe ports have a CLK_REQ signal connected.
931 * The CLK_REQ is used to wake the silicon when link entered L1 link-state. L1
932 * link-state is also entered on PCI-PM D3, even with ASPM L1 disabled.
933 * When no CLK_REQ signal is used, for example when it's using a free running
934 * clock the Root port silicon will never wake from L1 link state.
935 * This will trigger a MCE.
936 *
937 * Starting with FSP MR4 the UPD 'PchPcieClockGating' allows to work around
938 * this issue by disabling ClockGating. Disabling ClockGating should be avoided
939 * as the silicon draws more power when it is idle.
940 */
941 for (int i = 0; i < CONFIG_MAX_PCH_ROOT_PORTS; i++) {
942 bool clk_req_missing = false;
943 if (!(enable_mask & BIT(i)))
944 continue;
945 const struct pcie_rp_config *rp_cfg = &config->pch_pcie_rp[i];
946 if (CONFIG(SOC_INTEL_COMPLIANCE_TEST_MODE)) {
947 clk_req_missing = true;
948 } else if (!rp_cfg->flags && rp_cfg->clk_src == 0 && rp_cfg->clk_req == 0) {
949 clk_req_missing = true;
950 } else if (rp_cfg->flags & PCIE_RP_CLK_REQ_UNUSED) {
951 clk_req_missing = true;
952 }
953 if (clk_req_missing) {
954 printk(BIOS_INFO, "PCH PCIe port %d has no CLK_REQ\n", i + 1);
955 printk(BIOS_INFO, "Disabling PCH PCIE ClockGating+PowerGating.\n");
956 s_cfg->PchPcieClockGating = false;
957 s_cfg->PchPciePowerGating = false;
958 break;
959 }
960 }
961#endif
Subrata Banikb03cadf2021-06-09 22:19:04 +0530962}
Subrata Banik2871e0e2020-09-27 11:30:58 +0530963
Tim Wawrzynczakf9440522021-12-16 15:07:15 -0700964static void fill_fsps_cpu_pcie_params(FSP_S_CONFIG *s_cfg,
965 const struct soc_intel_alderlake_config *config)
966{
967 if (!CONFIG_MAX_CPU_ROOT_PORTS)
968 return;
969
970 const uint32_t enable_mask = pcie_rp_enable_mask(get_cpu_pcie_rp_table());
971 for (int i = 0; i < CONFIG_MAX_CPU_ROOT_PORTS; i++) {
972 if (!(enable_mask & BIT(i)))
973 continue;
974
975 const struct pcie_rp_config *rp_cfg = &config->cpu_pcie_rp[i];
976 s_cfg->CpuPcieRpL1Substates[i] =
977 get_l1_substate_control(rp_cfg->PcieRpL1Substates);
978 s_cfg->CpuPcieRpLtrEnable[i] = !!(rp_cfg->flags & PCIE_RP_LTR);
979 s_cfg->CpuPcieRpAdvancedErrorReporting[i] = !!(rp_cfg->flags & PCIE_RP_AER);
Sridahr Siricilla096ce142021-09-17 22:25:17 +0530980 s_cfg->CpuPcieRpHotPlug[i] = !!(rp_cfg->flags & PCIE_RP_HOTPLUG)
981 || CONFIG(SOC_INTEL_COMPLIANCE_TEST_MODE);
Tim Wawrzynczakd6b763c2022-07-27 09:53:58 -0600982 s_cfg->CpuPcieRpDetectTimeoutMs[i] = rp_cfg->pcie_rp_detect_timeout_ms;
Tim Wawrzynczakf9440522021-12-16 15:07:15 -0700983 s_cfg->PtmEnabled[i] = 0;
Tim Wawrzynczakd6b763c2022-07-27 09:53:58 -0600984 if (rp_cfg->pcie_rp_aspm)
985 s_cfg->CpuPcieRpAspm[i] = get_aspm_control(rp_cfg->pcie_rp_aspm);
986
987 if (!!(rp_cfg->flags & PCIE_RP_BUILT_IN))
988 s_cfg->CpuPcieRpSlotImplemented[i] = 0;
Tim Wawrzynczakf9440522021-12-16 15:07:15 -0700989 }
Sridahr Siricilla096ce142021-09-17 22:25:17 +0530990 s_cfg->CpuPcieComplianceTestMode = CONFIG(SOC_INTEL_COMPLIANCE_TEST_MODE);
Tim Wawrzynczakf9440522021-12-16 15:07:15 -0700991}
992
Subrata Banikb03cadf2021-06-09 22:19:04 +0530993static void fill_fsps_misc_power_params(FSP_S_CONFIG *s_cfg,
994 const struct soc_intel_alderlake_config *config)
995{
Anil Kumare822fb32023-02-09 16:55:57 -0800996 u32 cpu_id = cpu_get_cpuid();
Subrata Banikd6da4ef2021-10-07 00:39:31 +0530997 /* Skip setting D0I3 bit for all HECI devices */
998 s_cfg->DisableD0I3SettingForHeci = 1;
Subrata Banikb03cadf2021-06-09 22:19:04 +0530999 /*
1000 * Power Optimizer for DMI
1001 * DmiPwrOptimizeDisable is default to 0.
1002 * Boards not needing the optimizers explicitly disables them by setting
1003 * these disable variables to 1 in devicetree overrides.
1004 */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +05301005 s_cfg->PchPwrOptEnable = !(config->dmi_power_optimize_disable);
Subrata Banikc0983c92021-06-15 13:02:01 +05301006 s_cfg->PmSupport = 1;
1007 s_cfg->Hwp = 1;
1008 s_cfg->Cx = 1;
1009 s_cfg->PsOnEnable = 1;
V Sowmyaaf429062021-06-21 10:23:33 +05301010 s_cfg->PkgCStateLimit = LIMIT_AUTO;
V Sowmya458708f2021-07-09 22:11:04 +05301011
Jeremy Compostella92d38992022-09-14 11:06:06 -07001012 /* Disable Energy Efficient Turbo mode */
1013 s_cfg->EnergyEfficientTurbo = 0;
1014
V Sowmya458708f2021-07-09 22:11:04 +05301015 /* VccIn Aux Imon IccMax. Values are in 1/4 Amp increments and range is 0-512. */
1016 s_cfg->VccInAuxImonIccImax = get_vccin_aux_imon_iccmax() * 4 / MILLIAMPS_TO_AMPS;
V Sowmyac6d71662021-07-15 08:11:08 +05301017
1018 /* VrConfig Settings for IA and GT domains */
1019 for (size_t i = 0; i < ARRAY_SIZE(config->domain_vr_config); i++)
1020 fill_vr_domain_config(s_cfg, i, &config->domain_vr_config[i]);
Tim Wawrzynczake2b8f302021-07-19 15:35:47 -06001021
Nick Vaccaro577afe62022-01-12 12:03:41 -08001022 s_cfg->PmcLpmS0ixSubStateEnableMask = get_supported_lpm_mask();
Tim Wawrzynczakab0e0812021-09-21 10:28:16 -06001023
1024 /* Apply minimum assertion width settings */
1025 if (config->pch_slp_s3_min_assertion_width == SLP_S3_ASSERTION_DEFAULT)
1026 s_cfg->PchPmSlpS3MinAssert = SLP_S3_ASSERTION_50_MS;
1027 else
1028 s_cfg->PchPmSlpS3MinAssert = config->pch_slp_s3_min_assertion_width;
1029
1030 if (config->pch_slp_s4_min_assertion_width == SLP_S4_ASSERTION_DEFAULT)
1031 s_cfg->PchPmSlpS4MinAssert = SLP_S4_ASSERTION_1S;
1032 else
1033 s_cfg->PchPmSlpS4MinAssert = config->pch_slp_s4_min_assertion_width;
1034
1035 if (config->pch_slp_sus_min_assertion_width == SLP_SUS_ASSERTION_DEFAULT)
1036 s_cfg->PchPmSlpSusMinAssert = SLP_SUS_ASSERTION_4_S;
1037 else
1038 s_cfg->PchPmSlpSusMinAssert = config->pch_slp_sus_min_assertion_width;
1039
1040 if (config->pch_slp_a_min_assertion_width == SLP_A_ASSERTION_DEFAULT)
1041 s_cfg->PchPmSlpAMinAssert = SLP_A_ASSERTION_2_S;
1042 else
1043 s_cfg->PchPmSlpAMinAssert = config->pch_slp_a_min_assertion_width;
1044
1045 unsigned int power_cycle_duration = config->pch_reset_power_cycle_duration;
1046 if (power_cycle_duration == POWER_CYCLE_DURATION_DEFAULT)
1047 power_cycle_duration = POWER_CYCLE_DURATION_4S;
1048
1049 s_cfg->PchPmPwrCycDur = get_pm_pwr_cyc_dur(s_cfg->PchPmSlpS4MinAssert,
1050 s_cfg->PchPmSlpS3MinAssert,
1051 s_cfg->PchPmSlpAMinAssert,
1052 power_cycle_duration);
Ryan Lin4a48dbe2021-09-28 15:59:34 +08001053
1054 /* Set PsysPmax if it is available from DT */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +05301055 if (config->platform_pmax) {
1056 printk(BIOS_DEBUG, "PsysPmax = %dW\n", config->platform_pmax);
Ryan Lin4a48dbe2021-09-28 15:59:34 +08001057 /* PsysPmax is in unit of 1/8 Watt */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +05301058 s_cfg->PsysPmax = config->platform_pmax * 8;
Ryan Lin4a48dbe2021-09-28 15:59:34 +08001059 }
MAULIK V VAGHELA99356382022-03-03 13:07:57 +05301060
1061 s_cfg->C1StateAutoDemotion = !config->disable_c1_state_auto_demotion;
Lean Sheng Tan4b45d4c2022-04-01 19:01:59 +02001062
1063 s_cfg->VrPowerDeliveryDesign = config->vr_power_delivery_design;
V Sowmya4be8d9e2022-07-05 20:49:57 +05301064
Sean Rhodes42f8b592023-08-08 13:46:53 +01001065 /* C state demotion must be disabled for Raptorlake J0 and Q0 SKUs */
1066 assert(!(config->s0ix_enable && ((cpu_id == CPUID_RAPTORLAKE_J0) ||
1067 (cpu_id == CPUID_RAPTORLAKE_Q0)) &&
1068 !config->disable_package_c_state_demotion));
1069
1070 s_cfg->PkgCStateDemotion = !config->disable_package_c_state_demotion;
Joey Pengea2a38b2023-04-25 15:18:00 +08001071
Michał Żygowskid54a5b292023-07-03 17:17:32 +02001072 if (cpu_id == CPUID_RAPTORLAKE_J0 || cpu_id == CPUID_RAPTORLAKE_Q0)
Sean Rhodes06f4f652023-08-08 13:56:37 +01001073 s_cfg->C1e = config->enable_c1e;
Joey Pengea2a38b2023-04-25 15:18:00 +08001074 else
1075 s_cfg->C1e = 1;
Michał Żygowski01025d32023-07-12 13:22:09 +02001076#if CONFIG(SOC_INTEL_RAPTORLAKE) && !CONFIG(FSP_USE_REPO)
Bora Guvendik6e64c012023-04-24 18:12:19 -07001077 s_cfg->EnableHwpScalabilityTracking = config->enable_hwp_scalability_tracking;
1078#endif
Subrata Banik6f1cb402021-06-09 22:11:12 +05301079}
Subrata Banik2871e0e2020-09-27 11:30:58 +05301080
Tim Wawrzynczak43607e42021-05-18 09:04:42 -06001081static void fill_fsps_irq_params(FSP_S_CONFIG *s_cfg,
1082 const struct soc_intel_alderlake_config *config)
1083{
Michał Żygowski72704be2022-06-20 18:10:14 +02001084 const struct slot_irq_constraints *constraints;
1085 size_t num_slots;
1086
1087 if (CONFIG(SOC_INTEL_ALDERLAKE_PCH_S)) {
1088 constraints = irq_constraints_pch_s;
1089 num_slots = ARRAY_SIZE(irq_constraints_pch_s);
1090 } else {
1091 constraints = irq_constraints;
1092 num_slots = ARRAY_SIZE(irq_constraints);
1093 }
1094
1095 if (!assign_pci_irqs(constraints, num_slots))
Tim Wawrzynczak43607e42021-05-18 09:04:42 -06001096 die("ERROR: Unable to assign PCI IRQs, and no _PRT table available\n");
1097
1098 size_t pch_count = 0;
1099 const SI_PCH_DEVICE_INTERRUPT_CONFIG *upd_irqs = pci_irq_to_fsp(&pch_count);
1100
1101 s_cfg->DevIntConfigPtr = (UINT32)((uintptr_t)upd_irqs);
1102 s_cfg->NumOfDevIntConfig = pch_count;
1103 printk(BIOS_INFO, "IRQ: Using dynamically assigned PCI IO-APIC IRQs\n");
1104}
1105
V Sowmya418d37e2021-06-21 08:47:17 +05301106static void fill_fsps_fivr_params(FSP_S_CONFIG *s_cfg,
1107 const struct soc_intel_alderlake_config *config)
1108{
1109 /* PCH FIVR settings override */
1110 if (!config->ext_fivr_settings.configure_ext_fivr)
1111 return;
1112
1113 s_cfg->PchFivrExtV1p05RailEnabledStates =
1114 config->ext_fivr_settings.v1p05_enable_bitmap;
1115
1116 s_cfg->PchFivrExtV1p05RailSupportedVoltageStates =
1117 config->ext_fivr_settings.v1p05_supported_voltage_bitmap;
1118
1119 s_cfg->PchFivrExtVnnRailEnabledStates =
1120 config->ext_fivr_settings.vnn_enable_bitmap;
1121
1122 s_cfg->PchFivrExtVnnRailSupportedVoltageStates =
1123 config->ext_fivr_settings.vnn_supported_voltage_bitmap;
1124
1125 s_cfg->PchFivrExtVnnRailSxEnabledStates =
Bora Guvendikfbf874f2021-10-18 14:17:41 -07001126 config->ext_fivr_settings.vnn_sx_enable_bitmap;
V Sowmya418d37e2021-06-21 08:47:17 +05301127
1128 /* Convert the voltages to increments of 2.5mv */
1129 s_cfg->PchFivrExtV1p05RailVoltage =
1130 (config->ext_fivr_settings.v1p05_voltage_mv * 10) / 25;
1131
1132 s_cfg->PchFivrExtVnnRailVoltage =
1133 (config->ext_fivr_settings.vnn_voltage_mv * 10) / 25;
1134
1135 s_cfg->PchFivrExtVnnRailSxVoltage =
1136 (config->ext_fivr_settings.vnn_sx_voltage_mv * 10 / 25);
1137
1138 s_cfg->PchFivrExtV1p05RailIccMaximum =
1139 config->ext_fivr_settings.v1p05_icc_max_ma;
1140
1141 s_cfg->PchFivrExtVnnRailIccMaximum =
1142 config->ext_fivr_settings.vnn_icc_max_ma;
V Sowmya036b16b2022-10-10 12:46:18 +05301143
1144#if CONFIG(SOC_INTEL_ALDERLAKE_PCH_N)
1145 /* Enable the FIVR VCCST ICCMax Control for ADL-N.
1146 * TODO:Right now the UPD is update in partial headers for only ADL-N and when its
1147 * updated for ADL-P then we will remove the config since this needs to be enabled for
1148 * all the Alderlake platforms.
1149 */
1150 s_cfg->PchFivrVccstIccMaxControl = 1;
1151#endif
V Sowmya418d37e2021-06-21 08:47:17 +05301152}
1153
Wisley Chend0cef2a2021-11-01 16:13:55 +06001154static void fill_fsps_fivr_rfi_params(FSP_S_CONFIG *s_cfg,
1155 const struct soc_intel_alderlake_config *config)
1156{
1157 /* transform from Hz to 100 KHz */
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +05301158 s_cfg->FivrRfiFrequency = config->fivr_rfi_frequency / (100 * KHz);
1159 s_cfg->FivrSpreadSpectrum = config->fivr_spread_spectrum;
Wisley Chend0cef2a2021-11-01 16:13:55 +06001160}
1161
Wisley Chenc5103462021-11-04 18:12:58 +06001162static void fill_fsps_acoustic_params(FSP_S_CONFIG *s_cfg,
1163 const struct soc_intel_alderlake_config *config)
1164{
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +05301165 s_cfg->AcousticNoiseMitigation = config->acoustic_noise_mitigation;
Wisley Chenc5103462021-11-04 18:12:58 +06001166
1167 if (s_cfg->AcousticNoiseMitigation) {
leo.chouaef916a2022-05-13 10:41:03 +08001168 s_cfg->PreWake = config->PreWake;
Wisley Chenc5103462021-11-04 18:12:58 +06001169 for (int i = 0; i < NUM_VR_DOMAINS; i++) {
MAULIK V VAGHELA215a97e2022-03-07 18:39:17 +05301170 s_cfg->FastPkgCRampDisable[i] = config->fast_pkg_c_ramp_disable[i];
1171 s_cfg->SlowSlewRate[i] = config->slow_slew_rate[i];
Wisley Chenc5103462021-11-04 18:12:58 +06001172 }
1173 }
1174}
1175
Michał Żygowski46d74772022-04-25 12:15:55 +02001176static void fill_fsps_pci_ssid_params(FSP_S_CONFIG *s_cfg,
1177 const struct soc_intel_alderlake_config *config)
1178{
1179 struct device *dev;
1180 int i;
1181 /*
1182 * Prevent FSP from programming write-once subsystem IDs by providing
1183 * a custom SSID table. Must have at least one entry for the FSP to
1184 * use the table.
1185 */
1186 struct svid_ssid_init_entry {
1187 union {
1188 struct {
1189 uint64_t reg:12; /* Register offset */
1190 uint64_t function:3;
1191 uint64_t device:5;
1192 uint64_t bus:8;
1193 uint64_t :4;
1194 uint64_t segment:16;
1195 uint64_t :16;
1196 };
1197 uint64_t segbusdevfuncregister;
1198 };
1199 struct {
1200 uint16_t svid;
1201 uint16_t ssid;
1202 };
1203 uint32_t reserved;
1204 };
1205
1206 /*
1207 * The xHCI and HDA devices have RW/L rather than RW/O registers for
1208 * subsystem IDs and so must be written before FspSiliconInit locks
1209 * them with their default values.
1210 */
1211 const pci_devfn_t devfn_table[] = { PCH_DEVFN_XHCI, PCH_DEVFN_HDA };
1212 static struct svid_ssid_init_entry ssid_table[ARRAY_SIZE(devfn_table)];
1213
1214 for (i = 0; i < ARRAY_SIZE(devfn_table); i++) {
1215 ssid_table[i].reg = PCI_SUBSYSTEM_VENDOR_ID;
1216 ssid_table[i].device = PCI_SLOT(devfn_table[i]);
1217 ssid_table[i].function = PCI_FUNC(devfn_table[i]);
1218 dev = pcidev_path_on_root(devfn_table[i]);
1219 if (dev) {
1220 ssid_table[i].svid = dev->subsystem_vendor;
1221 ssid_table[i].ssid = dev->subsystem_device;
1222 }
1223 }
1224
1225 s_cfg->SiSsidTablePtr = (uintptr_t)ssid_table;
1226 s_cfg->SiNumberOfSsidTableEntry = ARRAY_SIZE(ssid_table);
1227
1228 /*
1229 * Replace the default SVID:SSID value with the values specified in
1230 * the devicetree for the root device.
1231 */
1232 dev = pcidev_path_on_root(SA_DEVFN_ROOT);
1233 s_cfg->SiCustomizedSvid = dev->subsystem_vendor;
1234 s_cfg->SiCustomizedSsid = dev->subsystem_device;
1235
1236 /* Ensure FSP will program the registers */
1237 s_cfg->SiSkipSsidProgramming = 0;
1238}
1239
Subrata Banikb03cadf2021-06-09 22:19:04 +05301240static void soc_silicon_init_params(FSP_S_CONFIG *s_cfg,
1241 struct soc_intel_alderlake_config *config)
1242{
1243 /* Override settings per board if required. */
1244 mainboard_update_soc_chip_config(config);
1245
Arthur Heymans02967e62022-02-18 13:22:25 +01001246 void (*const fill_fsps_params[])(FSP_S_CONFIG *s_cfg,
Subrata Banikb03cadf2021-06-09 22:19:04 +05301247 const struct soc_intel_alderlake_config *config) = {
1248 fill_fsps_lpss_params,
1249 fill_fsps_cpu_params,
1250 fill_fsps_igd_params,
1251 fill_fsps_tcss_params,
1252 fill_fsps_chipset_lockdown_params,
1253 fill_fsps_xhci_params,
1254 fill_fsps_xdci_params,
1255 fill_fsps_uart_params,
1256 fill_fsps_sata_params,
1257 fill_fsps_thermal_params,
Jeremy Soller9601b1e2022-05-26 10:21:36 -06001258 fill_fsps_gna_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +05301259 fill_fsps_lan_params,
1260 fill_fsps_cnvi_params,
1261 fill_fsps_vmd_params,
1262 fill_fsps_thc_params,
1263 fill_fsps_tbt_params,
1264 fill_fsps_8254_params,
Michael Niewöhner0e905802021-09-25 00:10:30 +02001265 fill_fsps_pm_timer_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +05301266 fill_fsps_storage_params,
1267 fill_fsps_pcie_params,
Tim Wawrzynczakf9440522021-12-16 15:07:15 -07001268 fill_fsps_cpu_pcie_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +05301269 fill_fsps_misc_power_params,
Tim Wawrzynczak43607e42021-05-18 09:04:42 -06001270 fill_fsps_irq_params,
V Sowmya418d37e2021-06-21 08:47:17 +05301271 fill_fsps_fivr_params,
Wisley Chend0cef2a2021-11-01 16:13:55 +06001272 fill_fsps_fivr_rfi_params,
Wisley Chenc5103462021-11-04 18:12:58 +06001273 fill_fsps_acoustic_params,
Michał Żygowski46d74772022-04-25 12:15:55 +02001274 fill_fsps_pci_ssid_params,
Subrata Banikb03cadf2021-06-09 22:19:04 +05301275 };
1276
1277 for (size_t i = 0; i < ARRAY_SIZE(fill_fsps_params); i++)
1278 fill_fsps_params[i](s_cfg, config);
1279}
1280
Jeremy Compostellaa2a7fec2023-01-19 19:06:09 -07001281/*
1282 * The Alder Lake PEIM graphics driver executed as part of the FSP does not wait
1283 * for the panel power cycle to complete before it initializes communication
1284 * with the display. It can result in AUX channel communication time out and
1285 * PEIM graphics driver failing to bring up graphics.
1286 *
1287 * If we have performed some graphics operations in romstage, it is possible
1288 * that a panel power cycle is still in progress. To prevent any issue with the
1289 * PEIM graphics driver it is preferable to ensure that panel power cycle is
1290 * complete.
1291 *
1292 * BUG:b:264526798
1293 */
1294static void wait_for_panel_power_cycle_done(const struct soc_intel_alderlake_config *config)
1295{
1296 const struct i915_gpu_panel_config *panel_cfg;
1297 uint32_t bar0;
1298 void *mmio;
1299
1300 if (!CONFIG(RUN_FSP_GOP))
1301 return;
1302
1303 bar0 = pci_s_read_config32(SA_DEV_IGD, PCI_BASE_ADDRESS_0);
1304 mmio = (void *)(bar0 & ~PCI_BASE_ADDRESS_MEM_ATTR_MASK);
1305 if (!mmio)
1306 return;
1307
1308 panel_cfg = &config->panel_cfg;
1309 for (size_t i = 0;; i++) {
1310 uint32_t status = read32(mmio + PCH_PP_STATUS);
1311 if (!(status & PANEL_POWER_CYCLE_ACTIVE))
1312 break;
1313 if (i == panel_cfg->cycle_delay_ms) {
1314 printk(BIOS_ERR, "Panel power cycle is still active.\n");
1315 break;
1316 }
1317 mdelay(1);
1318 }
1319}
1320
Subrata Banik6f1cb402021-06-09 22:11:12 +05301321/* UPD parameters to be initialized before SiliconInit */
1322void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd)
1323{
1324 struct soc_intel_alderlake_config *config;
Subrata Banikc0983c92021-06-15 13:02:01 +05301325 FSP_S_CONFIG *s_cfg = &supd->FspsConfig;
Subrata Banik6f1cb402021-06-09 22:11:12 +05301326
1327 config = config_of_soc();
Subrata Banikc0983c92021-06-15 13:02:01 +05301328 soc_silicon_init_params(s_cfg, config);
1329 mainboard_silicon_init_params(s_cfg);
Jeremy Compostellaa2a7fec2023-01-19 19:06:09 -07001330
1331 wait_for_panel_power_cycle_done(config);
Subrata Banik2871e0e2020-09-27 11:30:58 +05301332}
1333
Subrata Banik2871e0e2020-09-27 11:30:58 +05301334/*
1335 * Callbacks for SoC/Mainboard specific overrides for FspMultiPhaseSiInit
1336 * This platform supports below MultiPhaseSIInit Phase(s):
1337 * Phase | FSP return point | Purpose
1338 * ------- + ------------------------------------------------ + -------------------------------
1339 * 1 | After TCSS initialization completed | for TCSS specific init
Subrata Banikb6c3a032022-06-05 22:39:34 +05301340 * 2 | Before BIOS Reset CPL is set by FSP-S | for CPU specific init
Subrata Banik2871e0e2020-09-27 11:30:58 +05301341 */
1342void platform_fsp_multi_phase_init_cb(uint32_t phase_index)
1343{
1344 switch (phase_index) {
1345 case 1:
1346 /* TCSS specific initialization here */
Deepti Deshatty8e7facf2021-05-12 17:45:37 +05301347 printk(BIOS_DEBUG, "FSP MultiPhaseSiInit %s/%s called\n",
1348 __FILE__, __func__);
1349
1350 if (CONFIG(SOC_INTEL_COMMON_BLOCK_TCSS)) {
1351 const config_t *config = config_of_soc();
1352 tcss_configure(config->typec_aux_bias_pads);
1353 }
Subrata Banik2871e0e2020-09-27 11:30:58 +05301354 break;
Subrata Banikb6c3a032022-06-05 22:39:34 +05301355 case 2:
1356 /* CPU specific initialization here */
1357 printk(BIOS_DEBUG, "FSP MultiPhaseSiInit %s/%s called\n",
1358 __FILE__, __func__);
1359 before_post_cpus_init();
1360 /* Enable BIOS Reset CPL */
1361 enable_bios_reset_cpl();
1362 break;
Subrata Banik2871e0e2020-09-27 11:30:58 +05301363 default:
1364 break;
1365 }
1366}
1367
1368/* Mainboard GPIO Configuration */
Subrata Banikc0983c92021-06-15 13:02:01 +05301369__weak void mainboard_silicon_init_params(FSP_S_CONFIG *s_cfg)
Subrata Banik2871e0e2020-09-27 11:30:58 +05301370{
1371 printk(BIOS_DEBUG, "WEAK: %s/%s called\n", __FILE__, __func__);
1372}
Subrata Banik0cf26742023-05-16 12:18:00 +05301373
1374/* Handle FSP logo params */
1375void soc_load_logo(FSPS_UPD *supd)
1376{
Subrata Banik03dfc212023-08-16 02:50:16 +05301377 fsp_convert_bmp_to_gop_blt(&supd->FspsConfig.LogoPtr,
1378 &supd->FspsConfig.LogoSize,
1379 &supd->FspsConfig.BltBufferAddress,
1380 &supd->FspsConfig.BltBufferSize,
1381 &supd->FspsConfig.LogoPixelHeight,
1382 &supd->FspsConfig.LogoPixelWidth);
Subrata Banik0cf26742023-05-16 12:18:00 +05301383}