blob: 300fb7e7291f7ae49c2d1511033c7ed0348d5532 [file] [log] [blame]
Duncan Laurie9db8c252020-05-10 11:16:45 -07001fw_config
Nick Vaccaro2cc06002020-06-18 12:19:08 -07002 field DB_USB 0 3
3 option USB_ABSENT 0
4 option USB4_GEN2 1
5 option USB3_ACTIVE 2
6 option USB4_GEN3 3
7 option USB3_PASSIVE 4
8 option USB3_NO_A 5
Duncan Laurie9db8c252020-05-10 11:16:45 -07009 end
10 field THERMAL 4 7 end
11 field AUDIO 8 10
12 option NONE 0
13 option MAX98357_ALC5682I_I2S 1
14 option MAX98373_ALC5682I_I2S 2
15 option MAX98373_ALC5682_SNDW 3
16 end
17 field TABLETMODE 11
Nick Vaccaro2cc06002020-06-18 12:19:08 -070018 option TABLETMODE_DISABLED 0
19 option TABLETMODE_ENABLED 1
Duncan Laurie9db8c252020-05-10 11:16:45 -070020 end
Nick Vaccaro2cc06002020-06-18 12:19:08 -070021 field DB_LTE 12 13
22 option LTE_ABSENT 0
23 option LTE_PRESENT 1
24 end
25 field DB_SD 16 19
26 option SD_ABSENT 0
27 option SD_GL9755S 1
28 option SD_RTS5261 2
Duncan Laurie9db8c252020-05-10 11:16:45 -070029 end
30end
31
Nick Vaccarof9781912020-01-28 18:43:28 -080032chip soc/intel/tigerlake
33
34 device cpu_cluster 0 on
35 device lapic 0 on end
36 end
37
38 # GPE configuration
39 # Note that GPE events called out in ASL code rely on this
40 # route. i.e. If this route changes then the affected GPE
41 # offset bits also need to be changed.
42 register "pmc_gpe0_dw0" = "GPP_C"
43 register "pmc_gpe0_dw1" = "GPP_D"
44 register "pmc_gpe0_dw2" = "GPP_E"
45
Jamie Ryu154625b2020-06-12 02:59:26 -070046 # Enable heci communication
47 register "HeciEnabled" = "1"
48
Nick Vaccarof9781912020-01-28 18:43:28 -080049 # FSP configuration
50 register "SaGv" = "SaGv_Disabled"
51 register "SmbusEnable" = "0"
52
53 register "usb2_ports[0]" = "USB2_PORT_MID(OC_SKIP)" # Type-A Port A0
54 register "usb2_ports[1]" = "USB2_PORT_MID(OC_SKIP)" # Type-A Port A1
55 register "usb2_ports[2]" = "USB2_PORT_MID(OC_SKIP)" # M.2 WWAN
56 register "usb2_ports[3]" = "USB2_PORT_MID(OC_SKIP)" # Type-A / Type-C Cl
57 register "usb2_ports[4]" = "USB2_PORT_MID(OC_SKIP)" # M.2 Camera
58 register "usb2_ports[5]" = "USB2_PORT_EMPTY" # Type-A / Type-C Not Used
59 register "usb2_ports[6]" = "USB2_PORT_EMPTY" # Type-A / Type-C Not Used
60 register "usb2_ports[7]" = "USB2_PORT_EMPTY" # Type-A / Type-C Not Used
61 register "usb2_ports[8]" = "USB2_PORT_MID(OC_SKIP)" # Type-A / Type-C Co
62 register "usb2_ports[9]" = "USB2_PORT_MID(OC_SKIP)" # M.2 Bluetooth
63
64 register "usb3_ports[0]" = "USB3_PORT_DEFAULT(OC1)" # USB3/2 Type A port A0
65 register "usb3_ports[1]" = "USB3_PORT_DEFAULT(OC2)" # USB3/2 Type A port A1
66 register "usb3_ports[2]" = "USB3_PORT_DEFAULT(OC_SKIP)" # M.2 WWAN
67 register "usb3_ports[3]" = "USB3_PORT_DEFAULT(OC_SKIP)" # M.2 Camera
68
Nick Vaccarof9781912020-01-28 18:43:28 -080069 # EC host command ranges are in 0x800-0x8ff & 0x200-0x20f
70 register "gen1_dec" = "0x00fc0801"
71 register "gen2_dec" = "0x000c0201"
72 # EC memory map range is 0x900-0x9ff
73 register "gen3_dec" = "0x00fc0901"
74
75 # Enable NVMe PCIE 9 using clk 0
76 register "PcieRpEnable[8]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070077 register "PcieRpLtrEnable[8]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080078 register "PcieClkSrcUsage[0]" = "8"
79 register "PcieClkSrcClkReq[0]" = "0"
80
Venkata Krishna Nimmagaddac34bb382020-01-15 10:13:26 -080081 # Enable Optane PCIE 11 using clk 0
82 register "PcieRpEnable[10]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070083 register "PcieRpLtrEnable[10]" = "1"
Venkata Krishna Nimmagaddac34bb382020-01-15 10:13:26 -080084 register "HybridStorageMode" = "1"
85
Nick Vaccarof9781912020-01-28 18:43:28 -080086 # Enable SD Card PCIE 8 using clk 3
87 register "PcieRpEnable[7]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070088 register "PcieRpLtrEnable[7]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080089 register "PcieClkSrcUsage[3]" = "7"
90 register "PcieClkSrcClkReq[3]" = "3"
91
92 # Enable WLAN PCIE 7 using clk 1
93 register "PcieRpEnable[6]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070094 register "PcieRpLtrEnable[6]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080095 register "PcieClkSrcUsage[1]" = "6"
96 register "PcieClkSrcClkReq[1]" = "1"
97
Nick Vaccarof9781912020-01-28 18:43:28 -080098 # Mark SRCCLKREQ pins as unused that are routed for a Non-Clkreq functionality
Alex Levina53dbd42020-03-09 16:52:59 -070099 register "PcieClkSrcUsage[2]" = "0xFF"
Nick Vaccarof9781912020-01-28 18:43:28 -0800100 register "PcieClkSrcUsage[4]" = "0xFF"
101 register "PcieClkSrcUsage[5]" = "0xFF"
102 register "PcieClkSrcUsage[6]" = "0xFF"
103
104 # Enable SATA
105 register "SataEnable" = "1"
106 register "SataMode" = "0"
107 register "SataSalpSupport" = "1"
108 register "SataPortsEnable[0]" = "0"
109 register "SataPortsEnable[1]" = "1"
110 register "SataPortsDevSlp[0]" = "0"
Wonkyu Kimb8bfe142020-04-21 17:07:57 -0700111 register "SataPortsDevSlp[1]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -0800112
113 register "SerialIoI2cMode" = "{
114 [PchSerialIoIndexI2C0] = PchSerialIoPci,
115 [PchSerialIoIndexI2C1] = PchSerialIoPci,
116 [PchSerialIoIndexI2C2] = PchSerialIoPci,
117 [PchSerialIoIndexI2C3] = PchSerialIoPci,
118 [PchSerialIoIndexI2C4] = PchSerialIoDisabled,
119 [PchSerialIoIndexI2C5] = PchSerialIoPci,
120 }"
121
122 register "SerialIoGSpiMode" = "{
123 [PchSerialIoIndexGSPI0] = PchSerialIoPci,
124 [PchSerialIoIndexGSPI1] = PchSerialIoPci,
125 [PchSerialIoIndexGSPI2] = PchSerialIoDisabled,
126 [PchSerialIoIndexGSPI3] = PchSerialIoDisabled,
127 }"
128
129 register "SerialIoGSpiCsMode" = "{
130 [PchSerialIoIndexGSPI0] = 1,
131 [PchSerialIoIndexGSPI1] = 1,
132 [PchSerialIoIndexGSPI2] = 0,
133 [PchSerialIoIndexGSPI3] = 0,
134 }"
135
136 register "SerialIoGSpiCsState" = "{
137 [PchSerialIoIndexGSPI0] = 0,
138 [PchSerialIoIndexGSPI1] = 0,
139 [PchSerialIoIndexGSPI2] = 0,
140 [PchSerialIoIndexGSPI3] = 0,
141 }"
142
143 register "SerialIoUartMode" = "{
144 [PchSerialIoIndexUART0] = PchSerialIoPci,
145 [PchSerialIoIndexUART1] = PchSerialIoDisabled,
146 [PchSerialIoIndexUART2] = PchSerialIoDisabled,
147 }"
148
Srinidhi N Kaushik22d5b072020-03-06 10:47:17 -0800149 # HD Audio
150 register "PchHdaDspEnable" = "1"
151 register "PchHdaAudioLinkHdaEnable" = "0"
Duncan Laurie4dffa9c2020-05-10 11:20:20 -0700152 register "PchHdaAudioLinkDmicEnable[0]" = "0"
153 register "PchHdaAudioLinkDmicEnable[1]" = "0"
154 register "PchHdaAudioLinkSspEnable[0]" = "0"
155 register "PchHdaAudioLinkSspEnable[1]" = "0"
156 register "PchHdaAudioLinkSndwEnable[0]" = "0"
157 register "PchHdaAudioLinkSndwEnable[1]" = "0"
Srinidhi N Kaushik22d5b072020-03-06 10:47:17 -0800158
Brandon Breitenstein01ec7132020-03-06 10:51:30 -0800159 # TCSS USB3
160 register "TcssXhciEn" = "1"
Brandon Breitensteinb7911c82020-04-06 15:34:19 -0700161 register "TcssAuxOri" = "1"
162 register "IomTypeCPortPadCfg[0]" = "0x090E000A"
163 register "IomTypeCPortPadCfg[1]" = "0x090E000D"
Brandon Breitensteinc9a34512020-06-10 17:04:29 -0700164 register "IomTypeCPortPadCfg[2]" = "0x09000000"
165 register "IomTypeCPortPadCfg[3]" = "0x09000000"
166 register "IomTypeCPortPadCfg[4]" = "0x09000000"
167 register "IomTypeCPortPadCfg[5]" = "0x09000000"
168 register "IomTypeCPortPadCfg[6]" = "0x09000000"
169 register "IomTypeCPortPadCfg[7]" = "0x09000000"
Brandon Breitensteinb7911c82020-04-06 15:34:19 -0700170
John Zhaof5b33c02020-05-19 15:29:07 -0700171 # D3Hot and D3Cold for TCSS
172 register "TcssD3HotEnable" = "1"
John Zhao2c807ff2020-06-18 00:25:51 -0700173 register "TcssD3ColdEnable" = "0"
John Zhaof5b33c02020-05-19 15:29:07 -0700174
Nick Vaccarof9781912020-01-28 18:43:28 -0800175 # DP port
176 register "DdiPortAConfig" = "1" # eDP
177 register "DdiPortBConfig" = "0"
178
179 register "DdiPortAHpd" = "1"
180 register "DdiPortBHpd" = "1"
181 register "DdiPortCHpd" = "0"
182 register "DdiPort1Hpd" = "1"
183 register "DdiPort2Hpd" = "1"
184 register "DdiPort3Hpd" = "0"
185 register "DdiPort4Hpd" = "0"
186
187 register "DdiPortADdc" = "0"
188 register "DdiPortBDdc" = "1"
189 register "DdiPortCDdc" = "0"
190 register "DdiPort1Ddc" = "0"
191 register "DdiPort2Ddc" = "0"
192 register "DdiPort3Ddc" = "0"
193 register "DdiPort4Ddc" = "0"
194
195 # Disable PM to allow for shorter irq pulses
196 register "gpio_override_pm" = "1"
197 register "gpio_pm[0]" = "0"
198 register "gpio_pm[1]" = "0"
199 register "gpio_pm[2]" = "0"
200 register "gpio_pm[3]" = "0"
201 register "gpio_pm[4]" = "0"
202
203 # Enable "Intel Speed Shift Technology"
204 register "speed_shift_enable" = "1"
205
206 # Enable S0ix
207 register "s0ix_enable" = "1"
208
Sumeet R Pawnikar7d6bc602020-05-08 19:22:07 +0530209 # Enable DPTF
210 register "dptf_enable" = "1"
211
Tim Wawrzynczak2dcca0f2020-06-16 10:50:47 -0600212 register "power_limits_config[POWER_LIMITS_U_4_CORE]" = "{
Sumeet R Pawnikar7d6bc602020-05-08 19:22:07 +0530213 .tdp_pl1_override = 15,
214 .tdp_pl2_override = 60,
Tim Wawrzynczak2dcca0f2020-06-16 10:50:47 -0600215 .tdp_pl4 = 105,
216 }"
217 register "power_limits_config[POWER_LIMITS_U_2_CORE]" = "{
218 .tdp_pl1_override = 15,
219 .tdp_pl2_override = 38,
220 .tdp_pl4 = 71,
Sumeet R Pawnikar7d6bc602020-05-08 19:22:07 +0530221 }"
222
223 register "Device4Enable" = "1"
224
Sumeet R Pawnikar9f9b97e2020-06-30 14:18:41 +0530225 register "tcc_offset" = "10" # TCC of 90
226
Nick Vaccarof9781912020-01-28 18:43:28 -0800227 # Intel Common SoC Config
228 #+-------------------+---------------------------+
229 #| Field | Value |
230 #+-------------------+---------------------------+
231 #| chipset_lockdown | CHIPSET_LOCKDOWN_COREBOOT |
232 #| GSPI0 | cr50 TPM. Early init is |
233 #| | required to set up a BAR |
234 #| | for TPM communication |
235 #| | before memory is up |
Alex Levin3bc41cf2020-03-06 10:54:10 -0800236 #| GSPI1 | Fingerprint MCU |
Nick Vaccarof9781912020-01-28 18:43:28 -0800237 #| I2C0 | Audio |
238 #| I2C1 | Touchscreen |
239 #| I2C2 | WLAN, SAR0 |
240 #| I2C3 | Camera, SAR1 |
241 #| I2C5 | Trackpad |
242 #+-------------------+---------------------------+
243 register "common_soc_config" = "{
244 .chipset_lockdown = CHIPSET_LOCKDOWN_COREBOOT,
245 .gspi[0] = {
246 .speed_mhz = 1,
247 .early_init = 1,
248 },
249 .i2c[0] = {
250 .speed = I2C_SPEED_FAST,
251 },
252 .i2c[1] = {
253 .speed = I2C_SPEED_FAST,
254 },
255 .i2c[2] = {
256 .speed = I2C_SPEED_FAST,
257 },
258 .i2c[3] = {
259 .speed = I2C_SPEED_FAST,
260 },
261 .i2c[5] = {
262 .speed = I2C_SPEED_FAST,
263 },
264 }"
265
Venkata Krishna Nimmagadda7368da32020-06-09 00:11:34 -0700266 register "ext_fivr_settings" = "{
267 .configure_ext_fivr = 1,
268 .v1p05_enable_bitmap = FIVR_ENABLE_ALL_SX,
269 .vnn_enable_bitmap = FIVR_ENABLE_ALL_SX,
270 .v1p05_supported_voltage_bitmap = FIVR_VOLTAGE_NORMAL |
271 FIVR_VOLTAGE_MIN_ACTIVE |
272 FIVR_VOLTAGE_MIN_RETENTION,
273 .vnn_supported_voltage_bitmap = FIVR_VOLTAGE_NORMAL |
274 FIVR_VOLTAGE_MIN_ACTIVE |
275 FIVR_VOLTAGE_MIN_RETENTION,
276 .v1p05_icc_max_ma = 500,
277 .vnn_sx_voltage_mv = 1250,
278 }"
279
Nick Vaccarof9781912020-01-28 18:43:28 -0800280 device domain 0 on
281 #From EDS(575683)
282 device pci 00.0 on end # Host Bridge 0x9A14:U/0x9A12:Y
283 device pci 02.0 on end # Graphics
284 device pci 04.0 on end # DPTF 0x9A03
285 device pci 05.0 off end # IPU 0x9A19
286 device pci 06.0 off end # PEG60 0x9A09
John Zhao5d79a0c2020-05-13 16:44:38 -0700287 device pci 07.0 on end # TBT_PCIe0 0x9A23
288 device pci 07.1 on end # TBT_PCIe1 0x9A25
289 device pci 07.2 off end # TBT_PCIe2 0x9A27
290 device pci 07.3 off end # TBT_PCIe3 0x9A29
Nick Vaccarof9781912020-01-28 18:43:28 -0800291 device pci 08.0 on end # GNA 0x9A11
292 device pci 09.0 off end # NPK 0x9A33
293 device pci 0a.0 off end # Crash-log SRAM 0x9A0D
294 device pci 0d.0 on end # USB xHCI 0x9A13
295 device pci 0d.1 off end # USB xDCI (OTG) 0x9A15
John Zhao5d79a0c2020-05-13 16:44:38 -0700296 device pci 0d.2 on end # TBT DMA0 0x9A1B
Nick Vaccarof9781912020-01-28 18:43:28 -0800297 device pci 0d.3 off end # TBT DMA1 0x9A1D
298 device pci 0e.0 off end # VMD 0x9A0B
299
300 # From PCH EDS(576591)
Nick Vaccarof9781912020-01-28 18:43:28 -0800301 device pci 10.2 on end # CNVi: BT 0xA0F5 - A0F7
302 device pci 10.6 off end # THC0 0xA0D0
303 device pci 10.7 off end # THC1 0xA0D1
304
Nick Vaccarof9781912020-01-28 18:43:28 -0800305 device pci 12.0 off end # SensorHUB 0xA0FC
306 device pci 12.6 off end # GSPI2 0x34FB
307
308 device pci 13.0 off end # GSPI3 0xA0FD
Nick Vaccarof9781912020-01-28 18:43:28 -0800309
310 device pci 14.0 on end # USB3.1 xHCI 0xA0ED
311 device pci 14.1 off end # USB3.1 xDCI 0xA0EE
312 device pci 14.2 on end # Shared RAM 0xA0EF
Srinidhi N Kaushikac7d6b42020-03-05 17:19:51 -0800313 chip drivers/intel/wifi
314 register "wake" = "GPE0_PME_B0"
315 device pci 14.3 on end # CNVi: WiFi 0xA0F0 - A0F3
316 end
Nick Vaccarof3d399e2020-06-18 18:30:31 -0700317 device pci 15.0 on end # I2C #0 0xA0E8
318 device pci 15.1 on end # I2C1 0xA0E9
319 device pci 15.2 on end # I2C2 0xA0EA
Nick Vaccarof9781912020-01-28 18:43:28 -0800320 device pci 15.3 on end # I2C3 0xA0EB
321
322 device pci 16.0 on end # HECI1 0xA0E0
323 device pci 16.1 off end # HECI2 0xA0E1
324 device pci 16.2 off end # CSME 0xA0E2
325 device pci 16.3 off end # CSME 0xA0E3
326 device pci 16.4 off end # HECI3 0xA0E4
327 device pci 16.5 off end # HECI4 0xA0E5
328
329 device pci 17.0 on end # SATA 0xA0D3
330
331 device pci 19.0 on end # I2C4 0xA0C5
Nick Vaccarof3d399e2020-06-18 18:30:31 -0700332 device pci 19.1 on end # I2C5 0xA0C6
Nick Vaccarof9781912020-01-28 18:43:28 -0800333 device pci 19.2 off end # UART2 0xA0C7
334
335 device pci 1c.0 on end # RP1 0xA0B8
336 device pci 1c.1 off end # RP2 0xA0B9
337 device pci 1c.2 off end # RP3 0xA0BA
338 device pci 1c.3 off end # RP4 0xA0BB
339 device pci 1c.4 off end # RP5 0xA0BC
Alex Levina53dbd42020-03-09 16:52:59 -0700340 device pci 1c.5 off end # WWAN RP6 0xA0BD
Nick Vaccarof9781912020-01-28 18:43:28 -0800341 device pci 1c.6 on end # RP7 0xA0BE
342 device pci 1c.7 on end # SD Card RP8 0xA0BF
343
344 device pci 1d.0 on end # RP9 0xA0B0
345 device pci 1d.1 off end # RP10 0xA0B1
Venkata Krishna Nimmagaddac34bb382020-01-15 10:13:26 -0800346 device pci 1d.2 on end # RP11 0xA0B2
Nick Vaccarof9781912020-01-28 18:43:28 -0800347 device pci 1d.3 off end # RP12 0xA0B3
Nick Vaccarof9781912020-01-28 18:43:28 -0800348
349 device pci 1e.0 on end # UART0 0xA0A8
350 device pci 1e.1 off end # UART1 0xA0A9
351 device pci 1e.2 on
352 chip drivers/spi/acpi
353 register "hid" = "ACPI_DT_NAMESPACE_HID"
354 register "compat_string" = ""google,cr50""
355 register "irq" = "ACPI_IRQ_EDGE_LOW(GPP_C21_IRQ)"
356 device spi 0 on end
357 end
Tim Wawrzynczak6d20d0c2020-05-13 17:00:33 -0600358 end # GSPI0 0xA0AA
Alex Levin3bc41cf2020-03-06 10:54:10 -0800359 device pci 1e.3 on
360 chip drivers/spi/acpi
361 register "name" = ""CRFP""
362 register "hid" = "ACPI_DT_NAMESPACE_HID"
363 register "uid" = "1"
364 register "compat_string" = ""google,cros-ec-spi""
365 register "irq_gpio" = "ACPI_GPIO_IRQ_LEVEL_LOW_WAKE(GPP_C20)"
366 device spi 0 on end
367 end # FPMCU
Tim Wawrzynczak6d20d0c2020-05-13 17:00:33 -0600368 end # GSPI1 0xA0AB
Nick Vaccaro9a3486e2020-04-17 10:14:57 -0700369 device pci 1f.0 on
370 chip ec/google/chromeec
371 device pnp 0c09.0 on end
372 end
Tim Wawrzynczak6d20d0c2020-05-13 17:00:33 -0600373 end # eSPI 0xA080 - A09F
Nick Vaccarof9781912020-01-28 18:43:28 -0800374 device pci 1f.1 off end # P2SB 0xA0A0
Tim Wawrzynczak6d20d0c2020-05-13 17:00:33 -0600375 device pci 1f.2 hidden end # PMC 0xA0A1
Duncan Laurie4dffa9c2020-05-10 11:20:20 -0700376 device pci 1f.3 on end # Intel HD audio 0xA0C8-A0CF
Nick Vaccarof9781912020-01-28 18:43:28 -0800377 device pci 1f.4 off end # SMBus 0xA0A3
378 device pci 1f.5 on end # SPI 0xA0A4
379 device pci 1f.6 off end # GbE 0x15E1/0x15E2
380 device pci 1f.7 off end # TH 0xA0A6
381 end
382end