blob: fa99de8c8fc24f4a1d42ad49b9683bfd2f238310 [file] [log] [blame]
Nick Vaccarof9781912020-01-28 18:43:28 -08001chip soc/intel/tigerlake
2
3 device cpu_cluster 0 on
4 device lapic 0 on end
5 end
6
7 # GPE configuration
8 # Note that GPE events called out in ASL code rely on this
9 # route. i.e. If this route changes then the affected GPE
10 # offset bits also need to be changed.
11 register "pmc_gpe0_dw0" = "GPP_C"
12 register "pmc_gpe0_dw1" = "GPP_D"
13 register "pmc_gpe0_dw2" = "GPP_E"
14
15 # FSP configuration
16 register "SaGv" = "SaGv_Disabled"
17 register "SmbusEnable" = "0"
18
19 register "usb2_ports[0]" = "USB2_PORT_MID(OC_SKIP)" # Type-A Port A0
20 register "usb2_ports[1]" = "USB2_PORT_MID(OC_SKIP)" # Type-A Port A1
21 register "usb2_ports[2]" = "USB2_PORT_MID(OC_SKIP)" # M.2 WWAN
22 register "usb2_ports[3]" = "USB2_PORT_MID(OC_SKIP)" # Type-A / Type-C Cl
23 register "usb2_ports[4]" = "USB2_PORT_MID(OC_SKIP)" # M.2 Camera
24 register "usb2_ports[5]" = "USB2_PORT_EMPTY" # Type-A / Type-C Not Used
25 register "usb2_ports[6]" = "USB2_PORT_EMPTY" # Type-A / Type-C Not Used
26 register "usb2_ports[7]" = "USB2_PORT_EMPTY" # Type-A / Type-C Not Used
27 register "usb2_ports[8]" = "USB2_PORT_MID(OC_SKIP)" # Type-A / Type-C Co
28 register "usb2_ports[9]" = "USB2_PORT_MID(OC_SKIP)" # M.2 Bluetooth
29
30 register "usb3_ports[0]" = "USB3_PORT_DEFAULT(OC1)" # USB3/2 Type A port A0
31 register "usb3_ports[1]" = "USB3_PORT_DEFAULT(OC2)" # USB3/2 Type A port A1
32 register "usb3_ports[2]" = "USB3_PORT_DEFAULT(OC_SKIP)" # M.2 WWAN
33 register "usb3_ports[3]" = "USB3_PORT_DEFAULT(OC_SKIP)" # M.2 Camera
34
35 # Enable Pch iSCLK
36 register "pch_isclk" = "1"
37
38 # EC host command ranges are in 0x800-0x8ff & 0x200-0x20f
39 register "gen1_dec" = "0x00fc0801"
40 register "gen2_dec" = "0x000c0201"
41 # EC memory map range is 0x900-0x9ff
42 register "gen3_dec" = "0x00fc0901"
43
44 # Enable NVMe PCIE 9 using clk 0
45 register "PcieRpEnable[8]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070046 register "PcieRpLtrEnable[8]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080047 register "PcieClkSrcUsage[0]" = "8"
48 register "PcieClkSrcClkReq[0]" = "0"
49
Venkata Krishna Nimmagaddac34bb382020-01-15 10:13:26 -080050 # Enable Optane PCIE 11 using clk 0
51 register "PcieRpEnable[10]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070052 register "PcieRpLtrEnable[10]" = "1"
Venkata Krishna Nimmagaddac34bb382020-01-15 10:13:26 -080053 register "HybridStorageMode" = "1"
54
Nick Vaccarof9781912020-01-28 18:43:28 -080055 # Enable SD Card PCIE 8 using clk 3
56 register "PcieRpEnable[7]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070057 register "PcieRpLtrEnable[7]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080058 register "PcieClkSrcUsage[3]" = "7"
59 register "PcieClkSrcClkReq[3]" = "3"
60
61 # Enable WLAN PCIE 7 using clk 1
62 register "PcieRpEnable[6]" = "1"
Wonkyu Kime3bf8ba2020-04-07 23:34:12 -070063 register "PcieRpLtrEnable[6]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080064 register "PcieClkSrcUsage[1]" = "6"
65 register "PcieClkSrcClkReq[1]" = "1"
66
Nick Vaccarof9781912020-01-28 18:43:28 -080067 # Mark SRCCLKREQ pins as unused that are routed for a Non-Clkreq functionality
Alex Levina53dbd42020-03-09 16:52:59 -070068 register "PcieClkSrcUsage[2]" = "0xFF"
Nick Vaccarof9781912020-01-28 18:43:28 -080069 register "PcieClkSrcUsage[4]" = "0xFF"
70 register "PcieClkSrcUsage[5]" = "0xFF"
71 register "PcieClkSrcUsage[6]" = "0xFF"
72
73 # Enable SATA
74 register "SataEnable" = "1"
75 register "SataMode" = "0"
76 register "SataSalpSupport" = "1"
77 register "SataPortsEnable[0]" = "0"
78 register "SataPortsEnable[1]" = "1"
79 register "SataPortsDevSlp[0]" = "0"
Wonkyu Kimb8bfe142020-04-21 17:07:57 -070080 register "SataPortsDevSlp[1]" = "1"
Nick Vaccarof9781912020-01-28 18:43:28 -080081
82 register "SerialIoI2cMode" = "{
83 [PchSerialIoIndexI2C0] = PchSerialIoPci,
84 [PchSerialIoIndexI2C1] = PchSerialIoPci,
85 [PchSerialIoIndexI2C2] = PchSerialIoPci,
86 [PchSerialIoIndexI2C3] = PchSerialIoPci,
87 [PchSerialIoIndexI2C4] = PchSerialIoDisabled,
88 [PchSerialIoIndexI2C5] = PchSerialIoPci,
89 }"
90
91 register "SerialIoGSpiMode" = "{
92 [PchSerialIoIndexGSPI0] = PchSerialIoPci,
93 [PchSerialIoIndexGSPI1] = PchSerialIoPci,
94 [PchSerialIoIndexGSPI2] = PchSerialIoDisabled,
95 [PchSerialIoIndexGSPI3] = PchSerialIoDisabled,
96 }"
97
98 register "SerialIoGSpiCsMode" = "{
99 [PchSerialIoIndexGSPI0] = 1,
100 [PchSerialIoIndexGSPI1] = 1,
101 [PchSerialIoIndexGSPI2] = 0,
102 [PchSerialIoIndexGSPI3] = 0,
103 }"
104
105 register "SerialIoGSpiCsState" = "{
106 [PchSerialIoIndexGSPI0] = 0,
107 [PchSerialIoIndexGSPI1] = 0,
108 [PchSerialIoIndexGSPI2] = 0,
109 [PchSerialIoIndexGSPI3] = 0,
110 }"
111
112 register "SerialIoUartMode" = "{
113 [PchSerialIoIndexUART0] = PchSerialIoPci,
114 [PchSerialIoIndexUART1] = PchSerialIoDisabled,
115 [PchSerialIoIndexUART2] = PchSerialIoDisabled,
116 }"
117
Srinidhi N Kaushik22d5b072020-03-06 10:47:17 -0800118 # HD Audio
119 register "PchHdaDspEnable" = "1"
120 register "PchHdaAudioLinkHdaEnable" = "0"
121 register "PchHdaAudioLinkDmicEnable[0]" = "1"
122 register "PchHdaAudioLinkDmicEnable[1]" = "1"
123 register "PchHdaAudioLinkSspEnable[0]" = "1"
124 register "PchHdaAudioLinkSspEnable[1]" = "1"
Srinidhi N Kaushik22d5b072020-03-06 10:47:17 -0800125
Brandon Breitenstein01ec7132020-03-06 10:51:30 -0800126 # TCSS USB3
127 register "TcssXhciEn" = "1"
Brandon Breitensteinb7911c82020-04-06 15:34:19 -0700128 register "TcssAuxOri" = "1"
129 register "IomTypeCPortPadCfg[0]" = "0x090E000A"
130 register "IomTypeCPortPadCfg[1]" = "0x090E000D"
131 register "IomTypeCPortPadCfg[2]" = "0x0"
132 register "IomTypeCPortPadCfg[3]" = "0x0"
133 register "IomTypeCPortPadCfg[4]" = "0x0"
134 register "IomTypeCPortPadCfg[5]" = "0x0"
135 register "IomTypeCPortPadCfg[6]" = "0x0"
136 register "IomTypeCPortPadCfg[7]" = "0x0"
137
Brandon Breitenstein01ec7132020-03-06 10:51:30 -0800138
Nick Vaccarof9781912020-01-28 18:43:28 -0800139 # DP port
140 register "DdiPortAConfig" = "1" # eDP
141 register "DdiPortBConfig" = "0"
142
143 register "DdiPortAHpd" = "1"
144 register "DdiPortBHpd" = "1"
145 register "DdiPortCHpd" = "0"
146 register "DdiPort1Hpd" = "1"
147 register "DdiPort2Hpd" = "1"
148 register "DdiPort3Hpd" = "0"
149 register "DdiPort4Hpd" = "0"
150
151 register "DdiPortADdc" = "0"
152 register "DdiPortBDdc" = "1"
153 register "DdiPortCDdc" = "0"
154 register "DdiPort1Ddc" = "0"
155 register "DdiPort2Ddc" = "0"
156 register "DdiPort3Ddc" = "0"
157 register "DdiPort4Ddc" = "0"
158
159 # Disable PM to allow for shorter irq pulses
160 register "gpio_override_pm" = "1"
161 register "gpio_pm[0]" = "0"
162 register "gpio_pm[1]" = "0"
163 register "gpio_pm[2]" = "0"
164 register "gpio_pm[3]" = "0"
165 register "gpio_pm[4]" = "0"
166
167 # Enable "Intel Speed Shift Technology"
168 register "speed_shift_enable" = "1"
169
170 # Enable S0ix
171 register "s0ix_enable" = "1"
172
173 # Intel Common SoC Config
174 #+-------------------+---------------------------+
175 #| Field | Value |
176 #+-------------------+---------------------------+
177 #| chipset_lockdown | CHIPSET_LOCKDOWN_COREBOOT |
178 #| GSPI0 | cr50 TPM. Early init is |
179 #| | required to set up a BAR |
180 #| | for TPM communication |
181 #| | before memory is up |
Alex Levin3bc41cf2020-03-06 10:54:10 -0800182 #| GSPI1 | Fingerprint MCU |
Nick Vaccarof9781912020-01-28 18:43:28 -0800183 #| I2C0 | Audio |
184 #| I2C1 | Touchscreen |
185 #| I2C2 | WLAN, SAR0 |
186 #| I2C3 | Camera, SAR1 |
187 #| I2C5 | Trackpad |
188 #+-------------------+---------------------------+
189 register "common_soc_config" = "{
190 .chipset_lockdown = CHIPSET_LOCKDOWN_COREBOOT,
191 .gspi[0] = {
192 .speed_mhz = 1,
193 .early_init = 1,
194 },
195 .i2c[0] = {
196 .speed = I2C_SPEED_FAST,
197 },
198 .i2c[1] = {
199 .speed = I2C_SPEED_FAST,
200 },
201 .i2c[2] = {
202 .speed = I2C_SPEED_FAST,
203 },
204 .i2c[3] = {
205 .speed = I2C_SPEED_FAST,
206 },
207 .i2c[5] = {
208 .speed = I2C_SPEED_FAST,
209 },
210 }"
211
212 device domain 0 on
213 #From EDS(575683)
214 device pci 00.0 on end # Host Bridge 0x9A14:U/0x9A12:Y
215 device pci 02.0 on end # Graphics
216 device pci 04.0 on end # DPTF 0x9A03
217 device pci 05.0 off end # IPU 0x9A19
218 device pci 06.0 off end # PEG60 0x9A09
219 device pci 07.0 on end # TBT_PCIe0 0x9A23
220 device pci 07.1 on end # TBT_PCIe1 0x9A25
221 device pci 07.2 on end # TBT_PCIe2 0x9A27
222 device pci 07.3 on end # TBT_PCIe3 0x9A29
223 device pci 08.0 on end # GNA 0x9A11
224 device pci 09.0 off end # NPK 0x9A33
225 device pci 0a.0 off end # Crash-log SRAM 0x9A0D
226 device pci 0d.0 on end # USB xHCI 0x9A13
227 device pci 0d.1 off end # USB xDCI (OTG) 0x9A15
228 device pci 0d.2 off end # TBT DMA0 0x9A1B
229 device pci 0d.3 off end # TBT DMA1 0x9A1D
230 device pci 0e.0 off end # VMD 0x9A0B
231
232 # From PCH EDS(576591)
Nick Vaccarof9781912020-01-28 18:43:28 -0800233 device pci 10.2 on end # CNVi: BT 0xA0F5 - A0F7
234 device pci 10.6 off end # THC0 0xA0D0
235 device pci 10.7 off end # THC1 0xA0D1
236
Nick Vaccarof9781912020-01-28 18:43:28 -0800237 device pci 12.0 off end # SensorHUB 0xA0FC
238 device pci 12.6 off end # GSPI2 0x34FB
239
240 device pci 13.0 off end # GSPI3 0xA0FD
Nick Vaccarof9781912020-01-28 18:43:28 -0800241
242 device pci 14.0 on end # USB3.1 xHCI 0xA0ED
243 device pci 14.1 off end # USB3.1 xDCI 0xA0EE
244 device pci 14.2 on end # Shared RAM 0xA0EF
Srinidhi N Kaushikac7d6b42020-03-05 17:19:51 -0800245 chip drivers/intel/wifi
246 register "wake" = "GPE0_PME_B0"
247 device pci 14.3 on end # CNVi: WiFi 0xA0F0 - A0F3
248 end
Nick Vaccarof9781912020-01-28 18:43:28 -0800249
250 device pci 15.0 on
251 chip drivers/i2c/generic
252 register "hid" = ""10EC5682""
253 register "name" = ""RT58""
254 register "desc" = ""Realtek RT5682""
Shaunak Saha022d9352020-05-12 10:37:59 -0700255 register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_F8)"
Nick Vaccarof9781912020-01-28 18:43:28 -0800256 # Set the jd_src to RT5668_JD1 for jack detection
257 register "property_count" = "1"
258 register "property_list[0].type" = "ACPI_DP_TYPE_INTEGER"
259 register "property_list[0].name" = ""realtek,jd-src""
260 register "property_list[0].integer" = "1"
261 device i2c 1a on end
262 end
263 end # I2C #0 0xA0E8
Alex Levin34d9e682020-04-20 21:55:24 -0700264 device pci 15.1 on
265 chip drivers/i2c/hid
266 register "generic.hid" = ""GDIX0000""
267 register "generic.desc" = ""Goodix Touchscreen""
268 register "generic.irq" = "ACPI_IRQ_EDGE_LOW(GPP_E7_IRQ)"
269 register "generic.probed" = "1"
270 register "generic.reset_gpio" =
271 "ACPI_GPIO_OUTPUT_ACTIVE_LOW(GPP_C10)"
272 register "generic.reset_delay_ms" = "120"
273 register "generic.reset_off_delay_ms" = "3"
274 register "generic.enable_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_A8)"
275 register "generic.enable_delay_ms" = "12"
276 register "generic.has_power_resource" = "1"
277 register "hid_desc_reg_offset" = "0x01"
278 device i2c 14 on end
279 end
280 chip drivers/i2c/hid
281 register "generic.hid" = ""ELAN90FC""
282 register "generic.desc" = ""ELAN Touchscreen""
283 register "generic.irq" = "ACPI_IRQ_EDGE_LOW(GPP_E7_IRQ)"
284 register "generic.probed" = "1"
285 register "generic.reset_gpio" =
286 "ACPI_GPIO_OUTPUT_ACTIVE_LOW(GPP_C10)"
287 register "generic.enable_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_A8)"
288 register "generic.reset_delay_ms" = "20"
289 register "generic.has_power_resource" = "1"
290 register "generic.disable_gpio_export_in_crs" = "1"
291 register "hid_desc_reg_offset" = "0x01"
292 device i2c 10 on end
293 end
294 end # I2C1 0xA0E9
Nick Vaccarof9781912020-01-28 18:43:28 -0800295 device pci 15.2 on
296 chip drivers/i2c/sx9310
297 register "desc" = ""SAR0 Proximity Sensor""
298 register "irq" = "ACPI_IRQ_LEVEL_LOW(GPP_F14_IRQ)"
299 register "speed" = "I2C_SPEED_FAST"
300 register "uid" = "0"
301 register "reg_prox_ctrl0" = "0x10"
302 register "reg_prox_ctrl1" = "0x00"
303 register "reg_prox_ctrl2" = "0x84"
304 register "reg_prox_ctrl3" = "0x0e"
305 register "reg_prox_ctrl4" = "0x07"
306 register "reg_prox_ctrl5" = "0xc6"
307 register "reg_prox_ctrl6" = "0x20"
308 register "reg_prox_ctrl7" = "0x0d"
309 register "reg_prox_ctrl8" = "0x8d"
310 register "reg_prox_ctrl9" = "0x43"
311 register "reg_prox_ctrl10" = "0x1f"
312 register "reg_prox_ctrl11" = "0x00"
313 register "reg_prox_ctrl12" = "0x00"
314 register "reg_prox_ctrl13" = "0x00"
315 register "reg_prox_ctrl14" = "0x00"
316 register "reg_prox_ctrl15" = "0x00"
317 register "reg_prox_ctrl16" = "0x00"
318 register "reg_prox_ctrl17" = "0x00"
319 register "reg_prox_ctrl18" = "0x00"
320 register "reg_prox_ctrl19" = "0x00"
321 register "reg_sar_ctrl0" = "0x50"
322 register "reg_sar_ctrl1" = "0x8a"
323 register "reg_sar_ctrl2" = "0x3c"
324 device i2c 28 on end
325 end
326 end # I2C2 0xA0EA
327 device pci 15.3 on end # I2C3 0xA0EB
328
329 device pci 16.0 on end # HECI1 0xA0E0
330 device pci 16.1 off end # HECI2 0xA0E1
331 device pci 16.2 off end # CSME 0xA0E2
332 device pci 16.3 off end # CSME 0xA0E3
333 device pci 16.4 off end # HECI3 0xA0E4
334 device pci 16.5 off end # HECI4 0xA0E5
335
336 device pci 17.0 on end # SATA 0xA0D3
337
338 device pci 19.0 on end # I2C4 0xA0C5
339 device pci 19.1 on
340 chip drivers/i2c/generic
341 register "hid" = ""ELAN0000""
342 register "desc" = ""ELAN Touchpad""
343 register "irq" = "ACPI_IRQ_LEVEL_LOW(GPP_E15_IRQ)"
344 register "probed" = "1"
345 device i2c 15 on end
346 end
347 end # I2C5 0xA0C6
348 device pci 19.2 off end # UART2 0xA0C7
349
350 device pci 1c.0 on end # RP1 0xA0B8
351 device pci 1c.1 off end # RP2 0xA0B9
352 device pci 1c.2 off end # RP3 0xA0BA
353 device pci 1c.3 off end # RP4 0xA0BB
354 device pci 1c.4 off end # RP5 0xA0BC
Alex Levina53dbd42020-03-09 16:52:59 -0700355 device pci 1c.5 off end # WWAN RP6 0xA0BD
Nick Vaccarof9781912020-01-28 18:43:28 -0800356 device pci 1c.6 on end # RP7 0xA0BE
357 device pci 1c.7 on end # SD Card RP8 0xA0BF
358
359 device pci 1d.0 on end # RP9 0xA0B0
360 device pci 1d.1 off end # RP10 0xA0B1
Venkata Krishna Nimmagaddac34bb382020-01-15 10:13:26 -0800361 device pci 1d.2 on end # RP11 0xA0B2
Nick Vaccarof9781912020-01-28 18:43:28 -0800362 device pci 1d.3 off end # RP12 0xA0B3
Nick Vaccarof9781912020-01-28 18:43:28 -0800363
364 device pci 1e.0 on end # UART0 0xA0A8
365 device pci 1e.1 off end # UART1 0xA0A9
366 device pci 1e.2 on
367 chip drivers/spi/acpi
368 register "hid" = "ACPI_DT_NAMESPACE_HID"
369 register "compat_string" = ""google,cr50""
370 register "irq" = "ACPI_IRQ_EDGE_LOW(GPP_C21_IRQ)"
371 device spi 0 on end
372 end
373 end # GSPI0 0xA0AA
Alex Levin3bc41cf2020-03-06 10:54:10 -0800374 device pci 1e.3 on
375 chip drivers/spi/acpi
376 register "name" = ""CRFP""
377 register "hid" = "ACPI_DT_NAMESPACE_HID"
378 register "uid" = "1"
379 register "compat_string" = ""google,cros-ec-spi""
380 register "irq_gpio" = "ACPI_GPIO_IRQ_LEVEL_LOW_WAKE(GPP_C20)"
381 device spi 0 on end
382 end # FPMCU
383 end # GSPI1 0xA0AB
Nick Vaccaro9a3486e2020-04-17 10:14:57 -0700384 device pci 1f.0 on
385 chip ec/google/chromeec
386 device pnp 0c09.0 on end
387 end
388 end # eSPI 0xA080 - A09F
Nick Vaccarof9781912020-01-28 18:43:28 -0800389 device pci 1f.1 off end # P2SB 0xA0A0
390 device pci 1f.2 on end # PMC 0xA0A1
391 device pci 1f.3 on
392 chip drivers/generic/max98357a
Aamir Bohraa1c82c52020-03-16 18:57:48 +0530393 register "hid" = ""MX98357A""
Nick Vaccarof9781912020-01-28 18:43:28 -0800394 register "sdmode_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_A10)"
395 register "sdmode_delay" = "5"
396 device generic 0 on end
397 end
398 end # Intel HD audio 0xA0C8-A0CF
399 device pci 1f.4 off end # SMBus 0xA0A3
400 device pci 1f.5 on end # SPI 0xA0A4
401 device pci 1f.6 off end # GbE 0x15E1/0x15E2
402 device pci 1f.7 off end # TH 0xA0A6
403 end
404end