blob: 8c3d473c50e7abaf1f2a8f6ee6164da5bd1f49ea [file] [log] [blame]
Tony Huangdc0eb652022-01-19 09:28:27 +08001fw_config
2 field AUDIO_CODEC_SOURCE 8 10
3 option AUDIO_CODEC_UNPROVISIONED 0
4 option AUDIO_CODEC_ALC5682 1
5 option AUDIO_CODEC_ALC5682I_VS 2
6 end
7end
8
Tony Huangbfb18e12020-09-01 15:45:39 +08009chip soc/intel/cannonlake
10
Tony Huangc34c15b2020-12-01 18:45:13 +080011 register "power_limits_config" = "{
12 .tdp_pl1_override = 25,
13 .tdp_pl2_override = 49,
14 }"
15
Tony Huangbfb18e12020-09-01 15:45:39 +080016 # Auto-switch between X4 NVMe and X2 NVMe.
17 register "TetonGlacierMode" = "1"
18
19 register "SerialIoDevMode" = "{
Tony Huang8a1e2e12021-01-04 16:24:13 +080020 [PchSerialIoIndexI2C0] = PchSerialIoPci,
Tony Huangbfb18e12020-09-01 15:45:39 +080021 [PchSerialIoIndexI2C1] = PchSerialIoDisabled,
22 [PchSerialIoIndexI2C2] = PchSerialIoPci,
23 [PchSerialIoIndexI2C3] = PchSerialIoPci,
24 [PchSerialIoIndexI2C4] = PchSerialIoPci,
25 [PchSerialIoIndexI2C5] = PchSerialIoPci,
26 [PchSerialIoIndexSPI0] = PchSerialIoPci,
27 [PchSerialIoIndexSPI1] = PchSerialIoPci,
28 [PchSerialIoIndexSPI2] = PchSerialIoDisabled,
29 [PchSerialIoIndexUART0] = PchSerialIoSkipInit,
30 [PchSerialIoIndexUART1] = PchSerialIoDisabled,
31 [PchSerialIoIndexUART2] = PchSerialIoDisabled,
32 }"
33
34 # USB configuration
35 register "usb2_ports[0]" = "{
36 .enable = 1,
37 .ocpin = OC2,
38 .tx_bias = USB2_BIAS_0MV,
39 .tx_emp_enable = USB2_PRE_EMP_ON,
40 .pre_emp_bias = USB2_BIAS_11P25MV,
41 .pre_emp_bit = USB2_HALF_BIT_PRE_EMP,
Tony Huang51f01642020-10-07 16:23:23 +080042 }" # Type-A Port 0
Tony Huangb37f2e92020-11-17 19:09:47 +080043 register "usb2_ports[1]" = "{
44 .enable = 1,
45 .ocpin = OC_SKIP,
46 .tx_bias = USB2_BIAS_0MV,
47 .tx_emp_enable = USB2_PRE_EMP_ON,
48 .pre_emp_bias = USB2_BIAS_28P15MV,
49 .pre_emp_bit = USB2_HALF_BIT_PRE_EMP,
50 }" # Type-C Port 0
Tony Huangbfb18e12020-09-01 15:45:39 +080051 register "usb2_ports[2]" = "{
52 .enable = 1,
53 .ocpin = OC3,
54 .tx_bias = USB2_BIAS_0MV,
55 .tx_emp_enable = USB2_PRE_EMP_ON,
56 .pre_emp_bias = USB2_BIAS_28P15MV,
57 .pre_emp_bit = USB2_HALF_BIT_PRE_EMP,
Tony Huang51f01642020-10-07 16:23:23 +080058 }" # Type-A Port 1
59 register "usb2_ports[3]" = "USB2_PORT_EMPTY"
Tony Huangb37f2e92020-11-17 19:09:47 +080060 register "usb2_ports[4]" = "{
61 .enable = 1,
62 .ocpin = OC_SKIP,
63 .tx_bias = USB2_BIAS_0MV,
64 .tx_emp_enable = USB2_PRE_EMP_ON,
65 .pre_emp_bias = USB2_BIAS_28P15MV,
66 .pre_emp_bit = USB2_HALF_BIT_PRE_EMP,
67 }" # Type-C Port 1
Tony Huang51f01642020-10-07 16:23:23 +080068 register "usb2_ports[5]" = "USB2_PORT_LONG(OC_SKIP)" # USB cam
Tony Huangbfb18e12020-09-01 15:45:39 +080069 register "usb2_ports[6]" = "USB2_PORT_EMPTY"
70 register "usb2_ports[7]" = "USB2_PORT_EMPTY"
71 register "usb2_ports[8]" = "USB2_PORT_EMPTY"
Tony Huang51f01642020-10-07 16:23:23 +080072 register "usb2_ports[9]" = "USB2_PORT_MID(OC_SKIP)" # BT
Tony Huangbfb18e12020-09-01 15:45:39 +080073
Tony Huang51f01642020-10-07 16:23:23 +080074 register "usb3_ports[0]" = "USB3_PORT_DEFAULT(OC0)" # Type-A Port 0
75 register "usb3_ports[1]" = "USB3_PORT_DEFAULT(OC1)" # Type-A Port 1
76 register "usb3_ports[2]" = "USB3_PORT_DEFAULT(OC_SKIP)" # Type-C Port 1
77 register "usb3_ports[3]" = "USB3_PORT_DEFAULT(OC_SKIP)" # Type-C Port 0
78 register "usb3_ports[4]" = "USB3_PORT_EMPTY"
79 register "usb3_ports[5]" = "USB3_PORT_EMPTY"
Tony Huangbfb18e12020-09-01 15:45:39 +080080
81 # Bitmap for Wake Enable on USB attach/detach
Felix Singer21b5a9a2023-10-23 07:26:28 +020082 register "usb2_wake_enable_bitmap" = "USB_PORT_WAKE_ENABLE(1) |
Tony Huang51f01642020-10-07 16:23:23 +080083 USB_PORT_WAKE_ENABLE(3)"
Felix Singer21b5a9a2023-10-23 07:26:28 +020084 register "usb3_wake_enable_bitmap" = "USB_PORT_WAKE_ENABLE(1) |
Tony Huang51f01642020-10-07 16:23:23 +080085 USB_PORT_WAKE_ENABLE(2)"
Tony Huangbfb18e12020-09-01 15:45:39 +080086
87 # Enable eMMC HS400
88 register "ScsEmmcHs400Enabled" = "1"
89
90 # EMMC Tx CMD Delay
91 # Refer to EDS-Vol2-14.3.7.
92 # [14:8] steps of delay for DDR mode, each 125ps, range: 0 - 39.
93 # [6:0] steps of delay for SDR mode, each 125ps, range: 0 - 39.
94 register "common_soc_config.emmc_dll.emmc_tx_cmd_cntl" = "0x505"
95
96 # EMMC TX DATA Delay 1
97 # Refer to EDS-Vol2-14.3.8.
98 # [14:8] steps of delay for HS400, each 125ps, range: 0 - 78.
99 # [6:0] steps of delay for SDR104/HS200, each 125ps, range: 0 - 79.
100 register "common_soc_config.emmc_dll.emmc_tx_data_cntl1" = "0x911"
101
102 # EMMC TX DATA Delay 2
103 # Refer to EDS-Vol2-14.3.9.
104 # [30:24] steps of delay for SDR50, each 125ps, range: 0 - 79.
105 # [22:16] steps of delay for DDR50, each 125ps, range: 0 - 78.
106 # [14:8] steps of delay for SDR25/HS50, each 125ps, range: 0 -79.
107 # [6:0] steps of delay for SDR12, each 125ps. Range: 0 - 79.
108 register "common_soc_config.emmc_dll.emmc_tx_data_cntl2" = "0x1C262828"
109
110 # EMMC RX CMD/DATA Delay 1
111 # Refer to EDS-Vol2-14.3.10.
112 # [30:24] steps of delay for SDR50, each 125ps, range: 0 - 119.
113 # [22:16] steps of delay for DDR50, each 125ps, range: 0 - 78.
114 # [14:8] steps of delay for SDR25/HS50, each 125ps, range: 0 - 119.
115 # [6:0] steps of delay for SDR12, each 125ps, range: 0 - 119.
116 register "common_soc_config.emmc_dll.emmc_rx_cmd_data_cntl1" = "0x1C16583b"
117
118 # EMMC RX CMD/DATA Delay 2
119 # Refer to EDS-Vol2-14.3.12.
120 # [17:16] stands for Rx Clock before Output Buffer,
121 # 00: Rx clock after output buffer,
122 # 01: Rx clock before output buffer,
123 # 10: Automatic selection based on working mode.
124 # 11: Reserved
125 # [14:8] steps of delay for Auto Tuning Mode, each 125ps, range: 0 - 39.
126 # [6:0] steps of delay for HS200, each 125ps, range: 0 - 79.
127 register "common_soc_config.emmc_dll.emmc_rx_cmd_data_cntl2" = "0x1001D"
128
129 # EMMC Rx Strobe Delay
130 # Refer to EDS-Vol2-14.3.11.
131 # [14:8] Rx Strobe Delay DLL 1(HS400 Mode), each 125ps, range: 0 - 39.
132 # [6:0] Rx Strobe Delay DLL 2(HS400 Mode), each 125ps, range: 0 - 39.
133 register "common_soc_config.emmc_dll.emmc_rx_strobe_cntl" = "0x1515"
134
Tony Huangbfb18e12020-09-01 15:45:39 +0800135 # Intel Common SoC Config
136 #+-------------------+---------------------------+
137 #| Field | Value |
138 #+-------------------+---------------------------+
139 #| GSPI0 | cr50 TPM. Early init is |
140 #| | required to set up a BAR |
141 #| | for TPM communication |
142 #| | before memory is up |
Tony Huangf60ce242020-10-12 10:45:35 +0800143 #| I2C0 | ALC 1015 |
144 #| I2C2 | Lvds |
145 #| I2C3 | Touchscreen |
146 #| I2C4 | RT5682 |
Tony Huangbfb18e12020-09-01 15:45:39 +0800147 #+-------------------+---------------------------+
148 register "common_soc_config" = "{
149 .gspi[0] = {
150 .speed_mhz = 1,
151 .early_init = 1,
152 },
153 .i2c[0] = {
154 .speed = I2C_SPEED_FAST,
Tony Huang83e41052020-11-03 18:00:59 +0800155 .rise_time_ns = 60,
156 .fall_time_ns = 60,
Tony Huangbfb18e12020-09-01 15:45:39 +0800157 },
158 .i2c[2] = {
159 .speed = I2C_SPEED_FAST,
160 .rise_time_ns = 60,
161 .fall_time_ns = 60,
162 },
163 .i2c[3] = {
164 .speed = I2C_SPEED_FAST,
165 .rise_time_ns = 60,
166 .fall_time_ns = 60,
167 },
168 .i2c[4] = {
169 .speed = I2C_SPEED_FAST,
170 .rise_time_ns = 60,
171 .fall_time_ns = 60,
172 },
173 }"
174
Tony Huangbfb18e12020-09-01 15:45:39 +0800175 # PCIe port 11 (x2) for NVMe hybrid storage devices
176 register "PcieRpEnable[10]" = "1"
177 register "PcieRpLtrEnable[10]" = "1"
178 # Uses CLK SRC 0
179 register "PcieClkSrcUsage[0]" = "6"
180 register "PcieClkSrcClkReq[0]" = "0"
181
Tony Huangbfb18e12020-09-01 15:45:39 +0800182 # SATA port 1 Gen3 Strength
183 # Port1 Tx De-Emphasis = 20*log(0x20/64) = -6dB
184 register "sata_port[1].TxGen3DeEmphEnable" = "1"
185 register "sata_port[1].TxGen3DeEmph" = "0x20"
186
187 device domain 0 on
Felix Singerd571ea22024-01-17 21:51:07 +0100188 device ref dptf on
Tony Huangbfb18e12020-09-01 15:45:39 +0800189 chip drivers/intel/dptf
190 ## Active Policy
191 register "policies.active[0]" = "{.target=DPTF_CPU,
Tony Huangc34c15b2020-12-01 18:45:13 +0800192 .thresholds={TEMP_PCT(90, 0),}}"
Tony Huangbfb18e12020-09-01 15:45:39 +0800193 register "policies.active[1]" = "{.target=DPTF_TEMP_SENSOR_0,
Tony Huangc34c15b2020-12-01 18:45:13 +0800194 .thresholds={TEMP_PCT(75, 60),
195 TEMP_PCT(65, 50),
196 TEMP_PCT(45, 40),
197 TEMP_PCT(30, 30),}}"
Tony Huangbfb18e12020-09-01 15:45:39 +0800198
199 ## Passive Policy
Tony Huang043426c2021-05-20 16:41:28 +0800200 register "policies.passive[0]" = "DPTF_PASSIVE(CPU, CPU, 85, 60000)"
Tony Huangc34c15b2020-12-01 18:45:13 +0800201 register "policies.passive[1]" = "DPTF_PASSIVE(CPU, TEMP_SENSOR_0, 76, 60000)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800202
203 ## Critical Policy
Tony Huangc34c15b2020-12-01 18:45:13 +0800204 register "policies.critical[0]" = "DPTF_CRITICAL(CPU, 105, SHUTDOWN)"
205 register "policies.critical[1]" = "DPTF_CRITICAL(TEMP_SENSOR_0, 78, SHUTDOWN)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800206
207 ## Power Limits Control
Tony Huangc34c15b2020-12-01 18:45:13 +0800208 # 15-25W PL1 in 1000mW increments, avg over 28-32s interval
209 # 40-49W PL2 in 1000mW increments, avg over 28-32s interval
Tony Huangbfb18e12020-09-01 15:45:39 +0800210 register "controls.power_limits.pl1" = "{
211 .min_power = 15000,
Tony Huangc34c15b2020-12-01 18:45:13 +0800212 .max_power = 25000,
Tony Huangbfb18e12020-09-01 15:45:39 +0800213 .time_window_min = 28 * MSECS_PER_SEC,
214 .time_window_max = 32 * MSECS_PER_SEC,
215 .granularity = 1000,}"
Tony Huangc34c15b2020-12-01 18:45:13 +0800216 register "controls.power_limits.pl2" = "{
217 .min_power = 40000,
218 .max_power = 49000,
219 .time_window_min = 28 * MSECS_PER_SEC,
220 .time_window_max = 32 * MSECS_PER_SEC,
221 .granularity = 1000,}"
Tony Huangbfb18e12020-09-01 15:45:39 +0800222
223 ## Fan Performance Control (Percent, Speed, Noise, Power)
224 register "controls.fan_perf[0]" = "{ 90, 6700, 220, 2200, }"
225 register "controls.fan_perf[1]" = "{ 80, 5800, 180, 1800, }"
226 register "controls.fan_perf[2]" = "{ 70, 5000, 145, 1450, }"
227 register "controls.fan_perf[3]" = "{ 60, 4900, 115, 1150, }"
228 register "controls.fan_perf[4]" = "{ 50, 3838, 90, 900, }"
229 register "controls.fan_perf[5]" = "{ 40, 2904, 55, 550, }"
230 register "controls.fan_perf[6]" = "{ 30, 2337, 30, 300, }"
231 register "controls.fan_perf[7]" = "{ 20, 1608, 15, 150, }"
232 register "controls.fan_perf[8]" = "{ 10, 800, 10, 100, }"
233 register "controls.fan_perf[9]" = "{ 0, 0, 0, 50, }"
234
235 # Fan options
236 register "options.fan.fine_grained_control" = "1"
237 register "options.fan.step_size" = "2"
238
239 device generic 0 on end
240 end
Felix Singerd571ea22024-01-17 21:51:07 +0100241 end
242 device ref xhci on
Tony Huangbfb18e12020-09-01 15:45:39 +0800243 chip drivers/usb/acpi
244 device usb 0.0 on
245 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800246 register "desc" = ""USB2 Type-A Port 0""
Tony Huangbfb18e12020-09-01 15:45:39 +0800247 register "type" = "UPC_TYPE_A"
Tony Huang51f01642020-10-07 16:23:23 +0800248 register "group" = "ACPI_PLD_GROUP(1, 1)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800249 device usb 2.0 on end
250 end
251 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800252 register "desc" = ""USB2 Type-C Port 0""
Tony Huangbfb18e12020-09-01 15:45:39 +0800253 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
Tony Huang51f01642020-10-07 16:23:23 +0800254 register "group" = "ACPI_PLD_GROUP(2, 1)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800255 device usb 2.1 on end
256 end
257 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800258 register "desc" = ""USB2 Type-A Port 1""
Tony Huangbfb18e12020-09-01 15:45:39 +0800259 register "type" = "UPC_TYPE_A"
Tony Huang51f01642020-10-07 16:23:23 +0800260 register "group" = "ACPI_PLD_GROUP(1, 2)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800261 device usb 2.2 on end
262 end
263 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800264 device usb 2.3 off end
265 end
Tony Huangbfb18e12020-09-01 15:45:39 +0800266 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800267 register "desc" = ""USB2 Type-C Port 1""
268 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
269 register "group" = "ACPI_PLD_GROUP(2, 2)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800270 device usb 2.4 on end
271 end
272 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800273 register "desc" = ""Camera""
274 register "type" = "UPC_TYPE_INTERNAL"
Tony Huangbfb18e12020-09-01 15:45:39 +0800275 device usb 2.5 on end
276 end
277 chip drivers/usb/acpi
278 device usb 2.6 off end
279 end
280 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800281 register "desc" = ""USB3 Type-A Port 0""
Tony Huangbfb18e12020-09-01 15:45:39 +0800282 register "type" = "UPC_TYPE_USB3_A"
Tony Huang51f01642020-10-07 16:23:23 +0800283 register "group" = "ACPI_PLD_GROUP(1, 1)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800284 device usb 3.0 on end
285 end
286 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800287 register "desc" = ""USB3 Type-A Port 1""
Tony Huangbfb18e12020-09-01 15:45:39 +0800288 register "type" = "UPC_TYPE_USB3_A"
Tony Huang51f01642020-10-07 16:23:23 +0800289 register "group" = "ACPI_PLD_GROUP(1, 2)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800290 device usb 3.1 on end
291 end
292 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800293 register "desc" = ""USB3 Type-C Port 1""
294 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
295 register "group" = "ACPI_PLD_GROUP(2, 2)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800296 device usb 3.2 on end
297 end
298 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800299 register "desc" = ""USB3 Type-C Port 0""
Tony Huangbfb18e12020-09-01 15:45:39 +0800300 register "type" = "UPC_TYPE_C_USB2_SS_SWITCH"
Tony Huang51f01642020-10-07 16:23:23 +0800301 register "group" = "ACPI_PLD_GROUP(2, 1)"
Tony Huangbfb18e12020-09-01 15:45:39 +0800302 device usb 3.3 on end
303 end
304 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800305 device usb 3.4 off end
Tony Huangbfb18e12020-09-01 15:45:39 +0800306 end
307 chip drivers/usb/acpi
Tony Huang51f01642020-10-07 16:23:23 +0800308 device usb 3.5 off end
Tony Huangbfb18e12020-09-01 15:45:39 +0800309 end
310 end
311 end
Felix Singerd571ea22024-01-17 21:51:07 +0100312 end
313 device ref sdxc off end
314 device ref i2c0 on
315 # ALC1015
Tony Huangf60ce242020-10-12 10:45:35 +0800316 chip drivers/i2c/generic
317 register "hid" = ""10EC1015""
318 register "desc" = ""Realtek SPK AMP L""
319 register "uid" = "0"
320 device i2c 28 on end
321 end
322 chip drivers/i2c/generic
323 register "hid" = ""10EC1015""
324 register "desc" = ""Realtek SPK AMP R""
325 register "uid" = "1"
326 device i2c 29 on end
327 end
Felix Singerd571ea22024-01-17 21:51:07 +0100328 end
329 device ref i2c1 off end
330 device ref i2c2 on end # LVDS
331 device ref i2c3 on
332 # Touchscreen
Tony Huang2e731752020-11-05 16:53:56 +0800333 chip drivers/i2c/hid
334 register "generic.hid" = ""WDHT2002""
335 register "generic.desc" = ""WDT Touchscreen""
Karthikeyan Ramasubramanian86dc4b72020-11-10 13:46:26 -0700336 register "generic.irq" = "ACPI_IRQ_LEVEL_LOW(GPP_A20_IRQ)"
Tony Huang2e731752020-11-05 16:53:56 +0800337 register "generic.probed" = "1"
338 register "generic.reset_gpio" = "ACPI_GPIO_OUTPUT_ACTIVE_LOW(GPP_D15)"
339 register "generic.reset_delay_ms" = "100"
Tony Huangbce4f2f2021-04-28 15:26:43 +0800340 register "generic.wake" = "GPE0_DW0_20"
Tony Huang2e731752020-11-05 16:53:56 +0800341 register "generic.has_power_resource" = "1"
Tony Huang2e731752020-11-05 16:53:56 +0800342 register "hid_desc_reg_offset" = "0x20"
343 device i2c 2c on end
344 end
Felix Singerd571ea22024-01-17 21:51:07 +0100345 end
346 device ref heci1 on end
347 device ref i2c4 on
Tony Huangbfb18e12020-09-01 15:45:39 +0800348 chip drivers/i2c/generic
349 register "hid" = ""10EC5682""
350 register "name" = ""RT58""
351 register "desc" = ""Realtek RT5682""
352 register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_H0)"
353 register "property_count" = "1"
354 # Set the jd_src to RT5668_JD1 for jack detection
355 register "property_list[0].type" = "ACPI_DP_TYPE_INTEGER"
356 register "property_list[0].name" = ""realtek,jd-src""
357 register "property_list[0].integer" = "1"
Tony Huangdc0eb652022-01-19 09:28:27 +0800358 device i2c 1a on
359 probe AUDIO_CODEC_SOURCE AUDIO_CODEC_UNPROVISIONED
360 probe AUDIO_CODEC_SOURCE AUDIO_CODEC_ALC5682
361 end
362 end
363 chip drivers/i2c/generic
364 register "hid" = ""RTL5682""
365 register "name" = ""RT58""
366 register "desc" = ""Realtek RT5682""
367 register "irq_gpio" = "ACPI_GPIO_IRQ_EDGE_BOTH(GPP_H0)"
368 register "property_count" = "1"
369 register "property_list[0].type" = "ACPI_DP_TYPE_INTEGER"
370 register "property_list[0].name" = ""realtek,jd-src""
371 register "property_list[0].integer" = "1"
372 device i2c 1a on
373 probe AUDIO_CODEC_SOURCE AUDIO_CODEC_ALC5682I_VS
374 end
Tony Huangbfb18e12020-09-01 15:45:39 +0800375 end
Ben Zhangf8b0eb82021-05-16 08:44:47 -0400376 chip drivers/generic/gpio_keys
377 register "name" = ""MUTE""
378 register "label" = ""mic_mute_switch""
379 register "gpio" = "ACPI_GPIO_INPUT_ACTIVE_LOW(GPP_D16)"
380 register "key.wakeup_route" = "WAKEUP_ROUTE_DISABLED"
381 register "key.dev_name" = ""MMSW""
382 register "key.linux_code" = "SW_MUTE_DEVICE"
383 register "key.linux_input_type" = "EV_SW"
384 register "key.label" = ""mic_mute_switch_key""
385 device generic 0 on end
386 end
Felix Singerd571ea22024-01-17 21:51:07 +0100387 end
388 device ref emmc on end
389 device ref pcie_rp11 on
390 # X2 NVMe
Tony Huangbfb18e12020-09-01 15:45:39 +0800391 register "PcieRpSlotImplemented[10]" = "1"
392 end
Felix Singerd571ea22024-01-17 21:51:07 +0100393 device ref gspi1 off end
394 device ref hda on
Matt DeVillier1d876382023-01-17 12:25:45 -0600395 chip drivers/sof
396 register "spkr_tplg" = "rt1015"
397 register "jack_tplg" = "rt5682"
398 register "mic_tplg" = "_2ch_pdm0"
399 device generic 0 on end
400 end
Felix Singerd571ea22024-01-17 21:51:07 +0100401 end
Tony Huangbfb18e12020-09-01 15:45:39 +0800402 end
403
404 # VR Settings Configuration for 4 Domains
405 #+----------------+-------+-------+-------+-------+
406 #| Domain/Setting | SA | IA | GTUS | GTS |
407 #+----------------+-------+-------+-------+-------+
408 #| Psi1Threshold | 20A | 20A | 20A | 20A |
409 #| Psi2Threshold | 5A | 5A | 5A | 5A |
410 #| Psi3Threshold | 1A | 1A | 1A | 1A |
411 #| Psi3Enable | 1 | 1 | 1 | 1 |
412 #| Psi4Enable | 1 | 1 | 1 | 1 |
413 #| ImonSlope | 0 | 0 | 0 | 0 |
414 #| ImonOffset | 0 | 0 | 0 | 0 |
415 #| VrVoltageLimit | 1.52V | 1.52V | 1.52V | 1.52V |
416 #| AcLoadline | 10.04 | 1.81 | 3.19 | 3.19 |
417 #| DcLoadline | 10.04 | 1.81 | 3.19 | 3.19 |
418 #+----------------+-------+-------+-------+-------+
419 #Note: IccMax settings are moved to SoC code
420 register "domain_vr_config[VR_SYSTEM_AGENT]" = "{
421 .vr_config_enable = 1,
422 .psi1threshold = VR_CFG_AMP(20),
423 .psi2threshold = VR_CFG_AMP(5),
424 .psi3threshold = VR_CFG_AMP(1),
425 .psi3enable = 1,
426 .psi4enable = 1,
427 .imon_slope = 0x0,
428 .imon_offset = 0x0,
429 .icc_max = 0,
430 .voltage_limit = 1520,
431 .ac_loadline = 1004,
432 .dc_loadline = 1004,
433 }"
434
435 register "domain_vr_config[VR_IA_CORE]" = "{
436 .vr_config_enable = 1,
437 .psi1threshold = VR_CFG_AMP(20),
438 .psi2threshold = VR_CFG_AMP(5),
439 .psi3threshold = VR_CFG_AMP(1),
440 .psi3enable = 1,
441 .psi4enable = 1,
442 .imon_slope = 0x0,
443 .imon_offset = 0x0,
444 .icc_max = 0,
445 .voltage_limit = 1520,
446 .ac_loadline = 181,
447 .dc_loadline = 181,
448 }"
449
450 register "domain_vr_config[VR_GT_UNSLICED]" = "{
451 .vr_config_enable = 1,
452 .psi1threshold = VR_CFG_AMP(20),
453 .psi2threshold = VR_CFG_AMP(5),
454 .psi3threshold = VR_CFG_AMP(1),
455 .psi3enable = 1,
456 .psi4enable = 1,
457 .imon_slope = 0x0,
458 .imon_offset = 0x0,
459 .icc_max = 0,
460 .voltage_limit = 1520,
461 .ac_loadline = 319,
462 .dc_loadline = 319,
463 }"
464
465 register "domain_vr_config[VR_GT_SLICED]" = "{
466 .vr_config_enable = 1,
467 .psi1threshold = VR_CFG_AMP(20),
468 .psi2threshold = VR_CFG_AMP(5),
469 .psi3threshold = VR_CFG_AMP(1),
470 .psi3enable = 1,
471 .psi4enable = 1,
472 .imon_slope = 0x0,
473 .imon_offset = 0x0,
474 .icc_max = 0,
475 .voltage_limit = 1520,
476 .ac_loadline = 319,
477 .dc_loadline = 319,
478 }"
479
480end