mb/google/nissa/var/rull: add ssd timing and modify ssd GPIO pins of rtd3
[coreboot2.git] / src / mainboard / google / brya / variants / rull / overridetree.cb
blob1896d94638447adaaeb44361b6d13e5270a97636
1 fw_config
2 field THERMAL 18 18
3 option THERMAL_6W 0
4 option THERMAL_15W 1
5 end
6 field WIFI 8 9
7 option WIFI_CNVI_WIFI6E 0
8 option WIFI_PCIE_WIFI7 1
9 end
11 end
13 chip soc/intel/alderlake
14 register "sagv" = "SaGv_Enabled"
16 # EMMC Tx CMD Delay
17 # Refer to EDS-Vol2-42.3.7.
18 # [14:8] steps of delay for DDR mode, each 125ps, range: 0 - 39.
19 # [6:0] steps of delay for SDR mode, each 125ps, range: 0 - 39.
20 register "common_soc_config.emmc_dll.emmc_tx_cmd_cntl" = "0x505"
22 # EMMC TX DATA Delay 1
23 # Refer to EDS-Vol2-42.3.8.
24 # [14:8] steps of delay for HS400, each 125ps, range: 0 - 78.
25 # [6:0] steps of delay for SDR104/HS200, each 125ps, range: 0 - 79.
26 register "common_soc_config.emmc_dll.emmc_tx_data_cntl1" = "0x909"
28 # EMMC TX DATA Delay 2
29 # Refer to EDS-Vol2-42.3.9.
30 # [30:24] steps of delay for SDR50, each 125ps, range: 0 - 79.
31 # [22:16] steps of delay for DDR50, each 125ps, range: 0 - 78.
32 # [14:8] steps of delay for SDR25/HS50, each 125ps, range: 0 -79.
33 # [6:0] steps of delay for SDR12, each 125ps. Range: 0 - 79.
34 register "common_soc_config.emmc_dll.emmc_tx_data_cntl2" = "0x1C2A2828"
36 # EMMC RX CMD/DATA Delay 1
37 # Refer to EDS-Vol2-42.3.10.
38 # [30:24] steps of delay for SDR50, each 125ps, range: 0 - 119.
39 # [22:16] steps of delay for DDR50, each 125ps, range: 0 - 78.
40 # [14:8] steps of delay for SDR25/HS50, each 125ps, range: 0 - 119.
41 # [6:0] steps of delay for SDR12, each 125ps, range: 0 - 119.
42 register "common_soc_config.emmc_dll.emmc_rx_cmd_data_cntl1" = "0x1C1B4F1B"
44 # EMMC RX CMD/DATA Delay 2
45 # Refer to EDS-Vol2-42.3.12.
46 # [17:16] stands for Rx Clock before Output Buffer,
47 # 00: Rx clock after output buffer,
48 # 01: Rx clock before output buffer,
49 # 10: Automatic selection based on working mode.
50 # 11: Reserved
51 # [14:8] steps of delay for Auto Tuning Mode, each 125ps, range: 0 - 39.
52 # [6:0] steps of delay for HS200, each 125ps, range: 0 - 79.
53 register "common_soc_config.emmc_dll.emmc_rx_cmd_data_cntl2" = "0x1004C"
55 # EMMC Rx Strobe Delay
56 # Refer to EDS-Vol2-42.3.11.
57 # [14:8] Rx Strobe Delay DLL 1(HS400 Mode), each 125ps, range: 0 - 39.
58 # [6:0] Rx Strobe Delay DLL 2(HS400 Mode), each 125ps, range: 0 - 39.
59 register "common_soc_config.emmc_dll.emmc_rx_strobe_cntl" = "0x01515"
61 # SOC Aux orientation override:
62 # This is a bitfield that corresponds to up to 4 TCSS ports.
63 # Bits (0,1) allocated for TCSS Port1 configuration and Bits (2,3)for TCSS Port2.
64 # TcssAuxOri = 0100b
65 # Bit0 set to "0" indicates has retimer on USBC Port0, on the DB.
66 # Bit2 set to "1" indicates no retimer on USBC Port1, on the MB.
67 # Bit1,Bit3 set to "0" indicates Aux lines are not swapped on the
68 # motherboard to USBC connector
69 register "tcss_aux_ori" = "5"
71 register "typec_aux_bias_pads[0]" = "{
72 .pad_auxp_dc = GPP_A19,
73 .pad_auxn_dc = GPP_A20
76 register "typec_aux_bias_pads[1]" = "{
77 .pad_auxp_dc = GPP_E22,
78 .pad_auxn_dc = GPP_E23
81 # FIVR configurations for rull are disabled since the board doesn't have V1p05 and Vnn
82 # bypass rails implemented.
83 register "ext_fivr_settings" = "{
84 .configure_ext_fivr = 0,
87 # Enable the Cnvi BT Audio Offload
88 register "cnvi_bt_audio_offload" = "1"
90 # Intel Common SoC Config
91 #+-------------+------------------------------+
92 #| Field | Value |
93 #+-------------+------------------------------+
94 #| I2C0 | TPM. Early init is |
95 #| | required to set up a BAR |
96 #| | for TPM communication |
97 #| I2C1 | Touchscreen |
98 #| I2C3 | Audio |
99 #| I2C5 | Trackpad |
100 #+-------------+------------------------------+
101 register "common_soc_config" = "{
102 .i2c[0] = {
103 .early_init = 1,
104 .speed = I2C_SPEED_FAST_PLUS,
105 .speed_config[0] = {
106 .speed = I2C_SPEED_FAST_PLUS,
107 .scl_lcnt = 55,
108 .scl_hcnt = 30,
109 .sda_hold = 7,
112 .i2c[1] = {
113 .speed = I2C_SPEED_FAST,
114 .speed_config[0] = {
115 .speed = I2C_SPEED_FAST,
116 .scl_lcnt = 160,
117 .scl_hcnt = 79,
118 .sda_hold = 7,
121 .i2c[3] = {
122 .speed = I2C_SPEED_FAST,
123 .speed_config[0] = {
124 .speed = I2C_SPEED_FAST,
125 .scl_lcnt = 157,
126 .scl_hcnt = 79,
127 .sda_hold = 7,
130 .i2c[5] = {
131 .speed = I2C_SPEED_FAST,
132 .speed_config[0] = {
133 .speed = I2C_SPEED_FAST,
134 .scl_lcnt = 152,
135 .scl_hcnt = 79,
136 .sda_hold = 7,
141 # Power limit config
142 register "power_limits_config[ADL_N_041_6W_CORE]" = "{
143 .tdp_pl1_override = 15,
144 .tdp_pl2_override = 25,
145 .tdp_pl4 = 78,
148 device domain 0 on
149 device ref dtt on
150 chip drivers/intel/dptf
151 ## sensor information
152 register "options.tsr[0].desc" = ""CPU_VR""
153 register "options.tsr[1].desc" = ""CPU""
154 register "options.tsr[2].desc" = ""Ambient""
155 register "options.tsr[3].desc" = ""Charger""
157 # TODO: below values are initial reference values only
158 ## Passive Policy
159 register "policies.passive" = "{
160 [0] = DPTF_PASSIVE(CPU, CPU, 95, 5000),
161 [1] = DPTF_PASSIVE(CPU, TEMP_SENSOR_0, 75, 5000),
162 [2] = DPTF_PASSIVE(CPU, TEMP_SENSOR_1, 75, 5000),
163 [3] = DPTF_PASSIVE(CPU, TEMP_SENSOR_2, 75, 5000),
164 [4] = DPTF_PASSIVE(CHARGER, TEMP_SENSOR_3, 75, 5000),
167 ## Critical Policy
168 register "policies.critical" = "{
169 [0] = DPTF_CRITICAL(TEMP_SENSOR_1, 100, SHUTDOWN),
170 [1] = DPTF_CRITICAL(TEMP_SENSOR_2, 80, SHUTDOWN),
173 register "controls.power_limits" = "{
174 .pl1 = {
175 .min_power = 6000,
176 .max_power = 15000,
177 .time_window_min = 28 * MSECS_PER_SEC,
178 .time_window_max = 32 * MSECS_PER_SEC,
179 .granularity = 200
181 .pl2 = {
182 .min_power = 25000,
183 .max_power = 25000,
184 .time_window_min = 28 * MSECS_PER_SEC,
185 .time_window_max = 32 * MSECS_PER_SEC,
186 .granularity = 1000
190 ## Charger Performance Control (Control, mA)
191 register "controls.charger_perf" = "{
192 [0] = { 255, 3000 },
193 [1] = { 24, 1500 },
194 [2] = { 16, 1000 },
195 [3] = { 8, 500 }
198 device generic 0 on end
201 device ref igpu on
202 chip drivers/gfx/generic
203 register "device_count" = "4"
204 # DDIA for eDP
205 register "device[0].name" = ""LCD0""
206 # Internal panel on the first port of the graphics chip
207 register "device[0].type" = "panel"
208 # DDIB for HDMI
209 # If HDMI is not enumerated in the kernel, then no GFX device should be added for DDIB
210 register "device[1].name" = ""DD01""
211 # TCP0 (DP-1) for port C0
212 register "device[2].name" = ""DD02""
213 register "device[2].use_pld" = "true"
214 register "device[2].pld" = "ACPI_PLD_TYPE_C(LEFT, RIGHT, ACPI_PLD_GROUP(1, 1))"
215 # TCP1 (DP-2) for port C1
216 register "device[3].name" = ""DD03""
217 register "device[3].use_pld" = "true"
218 register "device[3].pld" = "ACPI_PLD_TYPE_C(RIGHT, LEFT, ACPI_PLD_GROUP(2, 1))"
219 device generic 0 on end
222 device ref i2c1 off end # Touchscreen
223 device ref i2c3 on
224 chip drivers/i2c/rt5645
225 register "hid" = ""10EC5650""
226 register "name" = ""RT58""
227 register "desc" = ""Realtek RT5650""
228 register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_A23)"
229 register "cbj_sleeve" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_A11)"
230 register "jd_mode" = "2"
231 device i2c 1a on end
234 device ref i2c5 off end # Touchpad
235 device ref cnvi_wifi on
236 chip drivers/wifi/generic
237 register "wake" = "GPE0_PME_B0"
238 register "enable_cnvi_ddr_rfim" = "true"
239 register "add_acpi_dma_property" = "true"
240 device generic 0 on end
242 probe WIFI WIFI_CNVI_WIFI6E
243 probe unprovisioned
245 device ref pcie_rp4 on
246 # PCIe 4 WLAN
247 register "pch_pcie_rp[PCH_RP(4)]" = "{
248 .clk_src = 2,
249 .clk_req = 2,
250 .flags = PCIE_RP_LTR | PCIE_RP_AER,
252 chip drivers/wifi/generic
253 register "wake" = "GPE0_DW1_03"
254 register "add_acpi_dma_property" = "true"
255 device pci 00.0 on end
257 probe WIFI WIFI_PCIE_WIFI7
258 probe unprovisioned
260 device ref pch_espi on
261 chip ec/google/chromeec
262 use conn0 as mux_conn[0]
263 use conn1 as mux_conn[1]
264 device pnp 0c09.0 on end
267 device ref pmc hidden
268 chip drivers/intel/pmc_mux
269 device generic 0 on
270 chip drivers/intel/pmc_mux/conn
271 use usb2_port1 as usb2_port
272 use tcss_usb3_port2 as usb3_port
273 device generic 0 alias conn0 on end
275 chip drivers/intel/pmc_mux/conn
276 use usb2_port2 as usb2_port
277 use tcss_usb3_port1 as usb3_port
278 device generic 1 alias conn1 on end
283 device ref tcss_xhci on
284 chip drivers/usb/acpi
285 device ref tcss_root_hub on
286 chip drivers/usb/acpi
287 register "desc" = ""USB3 Type-C Port C0 (MLB)""
288 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
289 register "use_custom_pld" = "true"
290 register "custom_pld" = "ACPI_PLD_TYPE_C(LEFT, LEFT, ACPI_PLD_GROUP(1, 1))"
291 device ref tcss_usb3_port2 on end
293 chip drivers/usb/acpi
294 register "desc" = ""USB3 Type-C Port C1 (DB)""
295 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
296 register "use_custom_pld" = "true"
297 register "custom_pld" = "ACPI_PLD_TYPE_C(RIGHT, RIGHT, ACPI_PLD_GROUP(2, 1))"
298 device ref tcss_usb3_port1 on end
303 device ref xhci on
304 register "usb2_ports[0]" = "USB2_PORT_TYPE_C(OC_SKIP)" # Type-C MB (7.5 inch)
305 register "usb2_ports[1]" = "USB2_PORT_TYPE_C(OC_SKIP)" # Type-C DB (7.1 inch)
306 register "usb2_ports[2]" = "USB2_PORT_MID(OC_SKIP)" # Type-A MB (6.4 inch)
307 register "usb2_ports[3]" = "USB2_PORT_MID(OC_SKIP)" # Type-A DB (6.2 inch)
308 register "usb2_ports[4]" = "USB2_PORT_SHORT(OC_SKIP)" # LTE (3.3 inch)
309 register "usb2_ports[5]" = "USB2_PORT_SHORT(OC_SKIP)" # UFC (3.7 inch)
310 register "usb2_ports[7]" = "USB2_PORT_MID(OC_SKIP)" # Bluetooth port for PCIe WLAN (2.5 inch)
311 register "usb2_ports[9]" = "USB2_PORT_MID(OC_SKIP)" # Bluetooth port for CNVi WLAN
313 register "usb3_ports[0]" = "USB3_PORT_DEFAULT(OC_SKIP)" # USB3 Type-A port A0(MLB)
314 register "usb3_ports[1]" = "USB3_PORT_DEFAULT(OC_SKIP)" # USB3 Type-A port A1(DB)
315 register "usb3_ports[2]" = "USB3_PORT_DEFAULT(OC_SKIP)" # USB3 WWAN(LTE)
316 chip drivers/usb/acpi
317 device ref xhci_root_hub on
318 chip drivers/usb/acpi
319 register "desc" = ""USB2 Type-C Port C0 (MLB)""
320 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
321 register "use_custom_pld" = "true"
322 register "custom_pld" = "ACPI_PLD_TYPE_C(LEFT, LEFT, ACPI_PLD_GROUP(1, 1))"
323 device ref usb2_port1 on end
325 chip drivers/usb/acpi
326 register "desc" = ""USB2 Type-C Port C1 (DB)""
327 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
328 register "use_custom_pld" = "true"
329 register "custom_pld" = "ACPI_PLD_TYPE_C(RIGHT, RIGHT, ACPI_PLD_GROUP(2, 1))"
330 device ref usb2_port2 on end
332 chip drivers/usb/acpi
333 register "desc" = ""USB2 Type-A Port A0 (MLB)""
334 register "type" = "UPC_TYPE_A"
335 register "use_custom_pld" = "true"
336 register "custom_pld" = "ACPI_PLD_TYPE_A(LEFT, RIGHT, ACPI_PLD_GROUP(3, 1))"
337 device ref usb2_port3 on end
339 chip drivers/usb/acpi
340 register "desc" = ""USB2 Type-A Port A1 (DB)""
341 register "type" = "UPC_TYPE_A"
342 register "use_custom_pld" = "true"
343 register "custom_pld" = "ACPI_PLD_TYPE_A(RIGHT, LEFT, ACPI_PLD_GROUP(4, 1))"
344 device ref usb2_port4 on end
346 chip drivers/usb/acpi
347 register "desc" = ""USB2 LTE""
348 register "type" = "UPC_TYPE_INTERNAL"
349 device ref usb2_port5 on end
351 chip drivers/usb/acpi
352 register "desc" = ""USB2 UFC""
353 register "type" = "UPC_TYPE_INTERNAL"
354 device ref usb2_port6 on end
356 chip drivers/usb/acpi
357 register "desc" = ""PCIe Bluetooth""
358 register "type" = "UPC_TYPE_INTERNAL"
359 register "reset_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_LOW(GPP_D4)"
360 device ref usb2_port8 on end
362 chip drivers/usb/acpi
363 register "desc" = ""CNVi Bluetooth""
364 register "type" = "UPC_TYPE_INTERNAL"
365 register "reset_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_LOW(GPP_D4)"
366 device ref usb2_port10 on
367 probe WIFI WIFI_CNVI_WIFI6E
370 chip drivers/usb/acpi
371 register "desc" = ""USB3 Type-A Port A0 (MLB)""
372 register "type" = "UPC_TYPE_USB3_A"
373 register "use_custom_pld" = "true"
374 register "custom_pld" = "ACPI_PLD_TYPE_A(LEFT, RIGHT, ACPI_PLD_GROUP(3, 1))"
375 device ref usb3_port1 on end
377 chip drivers/usb/acpi
378 register "desc" = ""USB3 Type-A Port A1 (DB)""
379 register "type" = "UPC_TYPE_USB3_A"
380 register "use_custom_pld" = "true"
381 register "custom_pld" = "ACPI_PLD_TYPE_A(RIGHT, LEFT, ACPI_PLD_GROUP(4, 1))"
382 device ref usb3_port2 on end
384 chip drivers/usb/acpi
385 register "desc" = ""USB3 WWAN""
386 register "type" = "UPC_TYPE_INTERNAL"
387 device ref usb3_port3 on end
389 chip drivers/usb/acpi
390 register "desc" = ""USB3 WLAN""
391 register "type" = "UPC_TYPE_INTERNAL"
392 device ref usb3_port4 on end
397 device ref pcie_rp7 off end # SDCard
398 device ref pcie_rp9 on
399 # Enable NVMe SSD PCIe 9-12 using clk 1
400 register "pch_pcie_rp[PCH_RP(9)]" = "{
401 .clk_src = 1,
402 .clk_req = 1,
403 .flags = PCIE_RP_LTR | PCIE_RP_AER,
404 .pcie_rp_aspm = ASPM_L1,
406 chip soc/intel/common/block/pcie/rtd3
407 # enable_gpio is EN_PP3300_SSD
408 register "enable_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_HIGH(GPP_D11)"
409 register "reset_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_LOW(GPP_B4)"
410 register "srcclk_pin" = "1"
411 device generic 0 on
412 probe STORAGE STORAGE_NVME
413 probe unprovisioned
417 device ref emmc on
418 probe STORAGE STORAGE_EMMC
419 probe unprovisioned
421 device ref hda on
422 chip drivers/sof
423 register "spkr_tplg" = "rt5650_sp"
424 register "jack_tplg" = "rt5650_hp"
425 register "mic_tplg" = "_2ch_pdm0"
426 device generic 0 on end