1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT) 1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2 2 3 #include <dt-bindings/gpio/gpio.h> 3 #include <dt-bindings/gpio/gpio.h> 4 #include <dt-bindings/input/gpio-keys.h> 4 #include <dt-bindings/input/gpio-keys.h> 5 #include <dt-bindings/input/input.h> 5 #include <dt-bindings/input/input.h> 6 #include <dt-bindings/leds/common.h> 6 #include <dt-bindings/leds/common.h> 7 #include <dt-bindings/pinctrl/rockchip.h> 7 #include <dt-bindings/pinctrl/rockchip.h> 8 8 9 #include "rk3566.dtsi" 9 #include "rk3566.dtsi" 10 10 11 / { 11 / { 12 aliases { 12 aliases { 13 mmc0 = &sdhci; 13 mmc0 = &sdhci; 14 }; 14 }; 15 15 16 chosen { 16 chosen { 17 stdout-path = "serial2:1500000 17 stdout-path = "serial2:1500000n8"; 18 }; 18 }; 19 19 20 adc-keys { 20 adc-keys { 21 compatible = "adc-keys"; 21 compatible = "adc-keys"; 22 io-channels = <&saradc 0>; 22 io-channels = <&saradc 0>; 23 io-channel-names = "buttons"; 23 io-channel-names = "buttons"; 24 keyup-threshold-microvolt = <1 24 keyup-threshold-microvolt = <1750000>; 25 25 26 button-recovery { 26 button-recovery { 27 label = "recovery"; 27 label = "recovery"; 28 linux,code = <KEY_VEND 28 linux,code = <KEY_VENDOR>; 29 press-threshold-microv 29 press-threshold-microvolt = <0>; 30 }; 30 }; 31 }; 31 }; 32 32 33 spk_amp: audio-amplifier { 33 spk_amp: audio-amplifier { 34 compatible = "simple-audio-amp 34 compatible = "simple-audio-amplifier"; 35 enable-gpios = <&gpio3 RK_PC4 35 enable-gpios = <&gpio3 RK_PC4 GPIO_ACTIVE_HIGH>; 36 pinctrl-0 = <&spk_amp_enable_h 36 pinctrl-0 = <&spk_amp_enable_h>; 37 pinctrl-names = "default"; 37 pinctrl-names = "default"; 38 sound-name-prefix = "Speaker A 38 sound-name-prefix = "Speaker Amp"; 39 }; 39 }; 40 40 41 dmic_codec: dmic-codec { 41 dmic_codec: dmic-codec { 42 compatible = "dmic-codec"; 42 compatible = "dmic-codec"; 43 num-channels = <6>; 43 num-channels = <6>; 44 #sound-dai-cells = <0>; 44 #sound-dai-cells = <0>; 45 }; 45 }; 46 46 47 gpio-keys { 47 gpio-keys { 48 compatible = "gpio-keys"; 48 compatible = "gpio-keys"; 49 pinctrl-0 = <&hall_int_l>; 49 pinctrl-0 = <&hall_int_l>; 50 pinctrl-names = "default"; 50 pinctrl-names = "default"; 51 51 52 switch-cover { 52 switch-cover { 53 label = "cover"; 53 label = "cover"; 54 gpios = <&gpio0 RK_PC7 54 gpios = <&gpio0 RK_PC7 GPIO_ACTIVE_LOW>; 55 linux,input-type = <EV 55 linux,input-type = <EV_SW>; 56 linux,code = <SW_MACHI 56 linux,code = <SW_MACHINE_COVER>; 57 linux,can-disable; 57 linux,can-disable; 58 wakeup-event-action = 58 wakeup-event-action = <EV_ACT_DEASSERTED>; 59 wakeup-source; 59 wakeup-source; 60 }; 60 }; 61 }; 61 }; 62 62 63 gpio-leds { 63 gpio-leds { 64 compatible = "gpio-leds"; 64 compatible = "gpio-leds"; 65 pinctrl-0 = <&led_pin>; 65 pinctrl-0 = <&led_pin>; 66 pinctrl-names = "default"; 66 pinctrl-names = "default"; 67 67 68 led-0 { 68 led-0 { 69 color = <LED_COLOR_ID_ 69 color = <LED_COLOR_ID_WHITE>; 70 function = LED_FUNCTIO 70 function = LED_FUNCTION_CHARGING; 71 gpios = <&gpio3 RK_PC5 71 gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>; 72 }; 72 }; 73 }; 73 }; 74 74 75 sdio_pwrseq: sdio-pwrseq { 75 sdio_pwrseq: sdio-pwrseq { 76 compatible = "mmc-pwrseq-simpl 76 compatible = "mmc-pwrseq-simple"; 77 clocks = <&rk817 1>; 77 clocks = <&rk817 1>; 78 clock-names = "ext_clock"; 78 clock-names = "ext_clock"; 79 pinctrl-0 = <&wifi_enable_h>; 79 pinctrl-0 = <&wifi_enable_h>; 80 pinctrl-names = "default"; 80 pinctrl-names = "default"; 81 reset-gpios = <&gpio0 RK_PC6 G 81 reset-gpios = <&gpio0 RK_PC6 GPIO_ACTIVE_LOW>; 82 }; 82 }; 83 83 84 sound { 84 sound { 85 compatible = "simple-audio-car 85 compatible = "simple-audio-card"; 86 simple-audio-card,name = "Pine 86 simple-audio-card,name = "PineNote"; 87 simple-audio-card,aux-devs = < 87 simple-audio-card,aux-devs = <&spk_amp>; 88 simple-audio-card,widgets = "H 88 simple-audio-card,widgets = "Headphone", "Headphones", 89 "S 89 "Speaker", "Internal Speakers"; 90 simple-audio-card,routing = "H 90 simple-audio-card,routing = "Headphones", "HPOL", 91 "H 91 "Headphones", "HPOR", 92 "I 92 "Internal Speakers", "Speaker Amp OUTL", 93 "I 93 "Internal Speakers", "Speaker Amp OUTR", 94 "S 94 "Speaker Amp INL", "HPOL", 95 "S 95 "Speaker Amp INR", "HPOR"; 96 simple-audio-card,pin-switches 96 simple-audio-card,pin-switches = "Internal Speakers"; 97 #address-cells = <1>; 97 #address-cells = <1>; 98 #size-cells = <0>; 98 #size-cells = <0>; 99 99 100 simple-audio-card,dai-link@0 { 100 simple-audio-card,dai-link@0 { 101 reg = <0>; 101 reg = <0>; 102 bitclock-master = <&li 102 bitclock-master = <&link0_cpu>; 103 format = "i2s"; 103 format = "i2s"; 104 frame-master = <&link0 104 frame-master = <&link0_cpu>; 105 mclk-fs = <256>; 105 mclk-fs = <256>; 106 106 107 link0_cpu: cpu { 107 link0_cpu: cpu { 108 sound-dai = <& 108 sound-dai = <&i2s1_8ch>; 109 }; 109 }; 110 110 111 link0_codec: codec { 111 link0_codec: codec { 112 sound-dai = <& 112 sound-dai = <&rk817>; 113 }; 113 }; 114 }; 114 }; 115 115 116 simple-audio-card,dai-link@1 { 116 simple-audio-card,dai-link@1 { 117 reg = <1>; 117 reg = <1>; 118 bitclock-master = <&li 118 bitclock-master = <&link1_cpu>; 119 format = "pdm"; 119 format = "pdm"; 120 frame-master = <&link1 120 frame-master = <&link1_cpu>; 121 121 122 link1_cpu: cpu { 122 link1_cpu: cpu { 123 sound-dai = <& 123 sound-dai = <&pdm>; 124 }; 124 }; 125 125 126 link1_codec: codec { 126 link1_codec: codec { 127 sound-dai = <& 127 sound-dai = <&dmic_codec>; 128 }; 128 }; 129 }; 129 }; 130 }; 130 }; 131 131 132 vbat_4g: vbat-4g { 132 vbat_4g: vbat-4g { 133 compatible = "regulator-fixed" 133 compatible = "regulator-fixed"; 134 regulator-name = "vbat_4g"; 134 regulator-name = "vbat_4g"; 135 regulator-min-microvolt = <380 135 regulator-min-microvolt = <3800000>; 136 regulator-max-microvolt = <380 136 regulator-max-microvolt = <3800000>; 137 /* powered by vcc_bat, enabled 137 /* powered by vcc_bat, enabled by vbat_4g_en */ 138 vin-supply = <&vbat_4g_en>; 138 vin-supply = <&vbat_4g_en>; 139 }; 139 }; 140 140 141 vcc_1v8: vcc-1v8 { 141 vcc_1v8: vcc-1v8 { 142 compatible = "regulator-fixed" 142 compatible = "regulator-fixed"; 143 regulator-name = "vcc_1v8"; 143 regulator-name = "vcc_1v8"; 144 regulator-always-on; 144 regulator-always-on; 145 regulator-min-microvolt = <180 145 regulator-min-microvolt = <1800000>; 146 regulator-max-microvolt = <180 146 regulator-max-microvolt = <1800000>; 147 /* powered by vcc_sys, enabled 147 /* powered by vcc_sys, enabled by vcc_1v8_en */ 148 vin-supply = <&vcc_1v8_en>; 148 vin-supply = <&vcc_1v8_en>; 149 }; 149 }; 150 150 151 vcc_bat: vcc-bat { 151 vcc_bat: vcc-bat { 152 compatible = "regulator-fixed" 152 compatible = "regulator-fixed"; 153 regulator-name = "vcc_bat"; 153 regulator-name = "vcc_bat"; 154 regulator-always-on; 154 regulator-always-on; 155 regulator-min-microvolt = <380 155 regulator-min-microvolt = <3800000>; 156 regulator-max-microvolt = <380 156 regulator-max-microvolt = <3800000>; 157 }; 157 }; 158 158 159 vcc_hall_3v3: vcc-hall-3v3 { 159 vcc_hall_3v3: vcc-hall-3v3 { 160 compatible = "regulator-fixed" 160 compatible = "regulator-fixed"; 161 regulator-name = "vcc_hall_3v3 161 regulator-name = "vcc_hall_3v3"; 162 regulator-always-on; 162 regulator-always-on; 163 regulator-min-microvolt = <330 163 regulator-min-microvolt = <3300000>; 164 regulator-max-microvolt = <330 164 regulator-max-microvolt = <3300000>; 165 vin-supply = <&vcc_sys>; 165 vin-supply = <&vcc_sys>; 166 }; 166 }; 167 167 168 vcc_sys: vcc-sys { 168 vcc_sys: vcc-sys { 169 compatible = "regulator-fixed" 169 compatible = "regulator-fixed"; 170 regulator-name = "vcc_sys"; 170 regulator-name = "vcc_sys"; 171 regulator-always-on; 171 regulator-always-on; 172 regulator-min-microvolt = <380 172 regulator-min-microvolt = <3800000>; 173 regulator-max-microvolt = <380 173 regulator-max-microvolt = <3800000>; 174 vin-supply = <&vcc_bat>; 174 vin-supply = <&vcc_bat>; 175 }; 175 }; 176 176 177 vcc_wl: vcc-wl { 177 vcc_wl: vcc-wl { 178 compatible = "regulator-fixed" 178 compatible = "regulator-fixed"; 179 enable-active-high; 179 enable-active-high; 180 gpio = <&gpio0 RK_PA0 GPIO_ACT 180 gpio = <&gpio0 RK_PA0 GPIO_ACTIVE_HIGH>; 181 pinctrl-0 = <&vcc_wl_pin>; 181 pinctrl-0 = <&vcc_wl_pin>; 182 pinctrl-names = "default"; 182 pinctrl-names = "default"; 183 regulator-name = "vcc_wl"; 183 regulator-name = "vcc_wl"; 184 regulator-min-microvolt = <330 184 regulator-min-microvolt = <3300000>; 185 regulator-max-microvolt = <330 185 regulator-max-microvolt = <3300000>; 186 vin-supply = <&vcc_bat>; 186 vin-supply = <&vcc_bat>; 187 }; 187 }; 188 188 189 vdda_0v9: vdda-0v9 { 189 vdda_0v9: vdda-0v9 { 190 compatible = "regulator-fixed" 190 compatible = "regulator-fixed"; 191 regulator-name = "vdda_0v9"; 191 regulator-name = "vdda_0v9"; 192 regulator-always-on; 192 regulator-always-on; 193 regulator-min-microvolt = <900 193 regulator-min-microvolt = <900000>; 194 regulator-max-microvolt = <900 194 regulator-max-microvolt = <900000>; 195 /* powered by vcc_sys, enabled 195 /* powered by vcc_sys, enabled by vcc_1v8_en */ 196 vin-supply = <&vcc_1v8_en>; 196 vin-supply = <&vcc_1v8_en>; 197 }; 197 }; 198 }; 198 }; 199 199 200 &cpu0 { 200 &cpu0 { 201 cpu-supply = <&vdd_cpu>; 201 cpu-supply = <&vdd_cpu>; 202 }; 202 }; 203 203 204 &cpu1 { 204 &cpu1 { 205 cpu-supply = <&vdd_cpu>; 205 cpu-supply = <&vdd_cpu>; 206 }; 206 }; 207 207 208 &cpu2 { 208 &cpu2 { 209 cpu-supply = <&vdd_cpu>; 209 cpu-supply = <&vdd_cpu>; 210 }; 210 }; 211 211 212 &cpu3 { 212 &cpu3 { 213 cpu-supply = <&vdd_cpu>; 213 cpu-supply = <&vdd_cpu>; 214 }; 214 }; 215 215 216 &i2c0 { 216 &i2c0 { 217 status = "okay"; 217 status = "okay"; 218 218 219 vdd_cpu: regulator@1c { 219 vdd_cpu: regulator@1c { 220 compatible = "tcs,tcs4525"; 220 compatible = "tcs,tcs4525"; 221 reg = <0x1c>; 221 reg = <0x1c>; 222 fcs,suspend-voltage-selector = 222 fcs,suspend-voltage-selector = <0>; 223 regulator-name = "vdd_cpu"; 223 regulator-name = "vdd_cpu"; 224 regulator-min-microvolt = <712 224 regulator-min-microvolt = <712500>; 225 regulator-max-microvolt = <139 225 regulator-max-microvolt = <1390000>; 226 regulator-ramp-delay = <2300>; 226 regulator-ramp-delay = <2300>; 227 regulator-always-on; 227 regulator-always-on; 228 vin-supply = <&vcc_sys>; 228 vin-supply = <&vcc_sys>; 229 229 230 regulator-state-mem { 230 regulator-state-mem { 231 regulator-on-in-suspen 231 regulator-on-in-suspend; 232 }; 232 }; 233 }; 233 }; 234 234 235 rk817: pmic@20 { 235 rk817: pmic@20 { 236 compatible = "rockchip,rk817"; 236 compatible = "rockchip,rk817"; 237 reg = <0x20>; 237 reg = <0x20>; 238 interrupt-parent = <&gpio0>; 238 interrupt-parent = <&gpio0>; 239 interrupts = <RK_PA3 IRQ_TYPE_ 239 interrupts = <RK_PA3 IRQ_TYPE_LEVEL_LOW>; 240 assigned-clocks = <&cru I2S1_M 240 assigned-clocks = <&cru I2S1_MCLKOUT_TX>; 241 assigned-clock-parents = <&cru 241 assigned-clock-parents = <&cru CLK_I2S1_8CH_TX>; 242 clocks = <&cru I2S1_MCLKOUT_TX 242 clocks = <&cru I2S1_MCLKOUT_TX>; 243 clock-names = "mclk"; 243 clock-names = "mclk"; 244 #clock-cells = <1>; 244 #clock-cells = <1>; 245 pinctrl-0 = <&i2s1m0_mclk>, <& 245 pinctrl-0 = <&i2s1m0_mclk>, <&pmic_int_l>, <&pmic_sleep>; 246 pinctrl-names = "default"; 246 pinctrl-names = "default"; 247 rockchip,system-power-controll 247 rockchip,system-power-controller; 248 #sound-dai-cells = <0>; 248 #sound-dai-cells = <0>; 249 wakeup-source; 249 wakeup-source; 250 250 251 vcc1-supply = <&vcc_sys>; 251 vcc1-supply = <&vcc_sys>; 252 vcc2-supply = <&vcc_sys>; 252 vcc2-supply = <&vcc_sys>; 253 vcc3-supply = <&vcc_sys>; 253 vcc3-supply = <&vcc_sys>; 254 vcc4-supply = <&vcc_sys>; 254 vcc4-supply = <&vcc_sys>; 255 vcc5-supply = <&vcc_sys>; 255 vcc5-supply = <&vcc_sys>; 256 vcc6-supply = <&vcc_sys>; 256 vcc6-supply = <&vcc_sys>; 257 vcc7-supply = <&vcc_sys>; 257 vcc7-supply = <&vcc_sys>; 258 vcc8-supply = <&vcc_sys>; 258 vcc8-supply = <&vcc_sys>; 259 vcc9-supply = <&dcdc_boost>; 259 vcc9-supply = <&dcdc_boost>; 260 260 261 regulators { 261 regulators { 262 vdd_logic: DCDC_REG1 { 262 vdd_logic: DCDC_REG1 { 263 regulator-name 263 regulator-name = "vdd_logic"; 264 regulator-alwa 264 regulator-always-on; 265 regulator-min- 265 regulator-min-microvolt = <500000>; 266 regulator-max- 266 regulator-max-microvolt = <1350000>; >> 267 regulator-init-microvolt = <900000>; 267 regulator-ramp 268 regulator-ramp-delay = <6001>; 268 regulator-init 269 regulator-initial-mode = <0x2>; 269 270 270 regulator-stat 271 regulator-state-mem { 271 regula 272 regulator-off-in-suspend; 272 regula 273 regulator-suspend-microvolt = <900000>; 273 }; 274 }; 274 }; 275 }; 275 276 276 vdd_gpu_npu: DCDC_REG2 277 vdd_gpu_npu: DCDC_REG2 { 277 regulator-name 278 regulator-name = "vdd_gpu_npu"; 278 regulator-min- 279 regulator-min-microvolt = <500000>; 279 regulator-max- 280 regulator-max-microvolt = <1350000>; >> 281 regulator-init-microvolt = <900000>; 280 regulator-ramp 282 regulator-ramp-delay = <6001>; 281 regulator-init 283 regulator-initial-mode = <0x2>; 282 284 283 regulator-stat 285 regulator-state-mem { 284 regula 286 regulator-off-in-suspend; 285 }; 287 }; 286 }; 288 }; 287 289 288 vcc_ddr: DCDC_REG3 { 290 vcc_ddr: DCDC_REG3 { 289 regulator-name 291 regulator-name = "vcc_ddr"; 290 regulator-alwa 292 regulator-always-on; 291 regulator-init 293 regulator-initial-mode = <0x2>; 292 294 293 regulator-stat 295 regulator-state-mem { 294 regula 296 regulator-on-in-suspend; 295 }; 297 }; 296 }; 298 }; 297 299 298 vcc_3v3: DCDC_REG4 { 300 vcc_3v3: DCDC_REG4 { 299 regulator-name 301 regulator-name = "vcc_3v3"; 300 regulator-alwa 302 regulator-always-on; 301 regulator-min- 303 regulator-min-microvolt = <3300000>; 302 regulator-max- 304 regulator-max-microvolt = <3300000>; 303 regulator-init 305 regulator-initial-mode = <0x2>; 304 306 305 regulator-stat 307 regulator-state-mem { 306 regula 308 regulator-off-in-suspend; 307 }; 309 }; 308 }; 310 }; 309 311 310 vcca_1v8_pmu: LDO_REG1 312 vcca_1v8_pmu: LDO_REG1 { 311 regulator-name 313 regulator-name = "vcca_1v8_pmu"; 312 regulator-alwa 314 regulator-always-on; 313 regulator-min- 315 regulator-min-microvolt = <1800000>; 314 regulator-max- 316 regulator-max-microvolt = <1800000>; 315 317 316 regulator-stat 318 regulator-state-mem { 317 regula 319 regulator-on-in-suspend; 318 }; 320 }; 319 }; 321 }; 320 322 321 /* unused */ 323 /* unused */ 322 vdda_0v9_ldo: LDO_REG2 324 vdda_0v9_ldo: LDO_REG2 { 323 regulator-name 325 regulator-name = "vdda_0v9_ldo"; 324 regulator-min- 326 regulator-min-microvolt = <900000>; 325 regulator-max- 327 regulator-max-microvolt = <900000>; 326 328 327 regulator-stat 329 regulator-state-mem { 328 regula 330 regulator-off-in-suspend; 329 }; 331 }; 330 }; 332 }; 331 333 332 vdda_0v9_pmu: LDO_REG3 334 vdda_0v9_pmu: LDO_REG3 { 333 regulator-name 335 regulator-name = "vdda_0v9_pmu"; 334 regulator-alwa 336 regulator-always-on; 335 regulator-min- 337 regulator-min-microvolt = <900000>; 336 regulator-max- 338 regulator-max-microvolt = <900000>; 337 339 338 regulator-stat 340 regulator-state-mem { 339 regula 341 regulator-on-in-suspend; 340 }; 342 }; 341 }; 343 }; 342 344 343 vccio_acodec: LDO_REG4 345 vccio_acodec: LDO_REG4 { 344 regulator-name 346 regulator-name = "vccio_acodec"; 345 regulator-alwa 347 regulator-always-on; 346 regulator-min- 348 regulator-min-microvolt = <3300000>; 347 regulator-max- 349 regulator-max-microvolt = <3300000>; 348 350 349 regulator-stat 351 regulator-state-mem { 350 regula 352 regulator-off-in-suspend; 351 }; 353 }; 352 }; 354 }; 353 355 354 /* unused */ 356 /* unused */ 355 vccio_sd: LDO_REG5 { 357 vccio_sd: LDO_REG5 { 356 regulator-name 358 regulator-name = "vccio_sd"; 357 regulator-min- 359 regulator-min-microvolt = <1800000>; 358 regulator-max- 360 regulator-max-microvolt = <3300000>; 359 361 360 regulator-stat 362 regulator-state-mem { 361 regula 363 regulator-off-in-suspend; 362 }; 364 }; 363 }; 365 }; 364 366 365 vcc_3v3_pmu: LDO_REG6 367 vcc_3v3_pmu: LDO_REG6 { 366 regulator-name 368 regulator-name = "vcc_3v3_pmu"; 367 regulator-alwa 369 regulator-always-on; 368 regulator-min- 370 regulator-min-microvolt = <3300000>; 369 regulator-max- 371 regulator-max-microvolt = <3300000>; 370 372 371 regulator-stat 373 regulator-state-mem { 372 regula 374 regulator-on-in-suspend; 373 }; 375 }; 374 }; 376 }; 375 377 376 vcc_1v8_en: LDO_REG7 { 378 vcc_1v8_en: LDO_REG7 { 377 regulator-name 379 regulator-name = "vcc_1v8_en"; 378 regulator-min- 380 regulator-min-microvolt = <1800000>; 379 regulator-max- 381 regulator-max-microvolt = <1800000>; 380 382 381 regulator-stat 383 regulator-state-mem { 382 regula 384 regulator-off-in-suspend; 383 }; 385 }; 384 }; 386 }; 385 387 386 vbat_4g_en: LDO_REG8 { 388 vbat_4g_en: LDO_REG8 { 387 regulator-name 389 regulator-name = "vbat_4g_en"; 388 regulator-min- 390 regulator-min-microvolt = <1800000>; 389 regulator-max- 391 regulator-max-microvolt = <1800000>; 390 392 391 regulator-stat 393 regulator-state-mem { 392 regula 394 regulator-off-in-suspend; 393 }; 395 }; 394 }; 396 }; 395 397 396 sleep_sta_ctl: LDO_REG 398 sleep_sta_ctl: LDO_REG9 { 397 regulator-name 399 regulator-name = "sleep_sta_ctl"; 398 regulator-min- 400 regulator-min-microvolt = <1800000>; 399 regulator-max- 401 regulator-max-microvolt = <1800000>; 400 402 401 regulator-stat 403 regulator-state-mem { 402 regula 404 regulator-on-in-suspend; 403 }; 405 }; 404 }; 406 }; 405 407 406 dcdc_boost: BOOST { 408 dcdc_boost: BOOST { 407 regulator-name 409 regulator-name = "boost"; 408 regulator-min- 410 regulator-min-microvolt = <5000000>; 409 regulator-max- 411 regulator-max-microvolt = <5000000>; 410 412 411 regulator-stat 413 regulator-state-mem { 412 regula 414 regulator-off-in-suspend; 413 }; 415 }; 414 }; 416 }; 415 417 416 otg_switch: OTG_SWITCH 418 otg_switch: OTG_SWITCH { 417 regulator-name 419 regulator-name = "otg_switch"; 418 420 419 regulator-stat 421 regulator-state-mem { 420 regula 422 regulator-off-in-suspend; 421 }; 423 }; 422 }; 424 }; 423 }; 425 }; 424 }; 426 }; 425 }; 427 }; 426 428 427 &i2c1 { 429 &i2c1 { 428 status = "okay"; 430 status = "okay"; 429 431 430 digitizer@9 { 432 digitizer@9 { 431 compatible = "wacom,w9013", "h 433 compatible = "wacom,w9013", "hid-over-i2c"; 432 reg = <0x09>; 434 reg = <0x09>; 433 interrupt-parent = <&gpio0>; 435 interrupt-parent = <&gpio0>; 434 interrupts = <RK_PB6 IRQ_TYPE_ 436 interrupts = <RK_PB6 IRQ_TYPE_LEVEL_LOW>; 435 hid-descr-addr = <0x1>; 437 hid-descr-addr = <0x1>; 436 pinctrl-0 = <&pen_fwe>, <&pen_ 438 pinctrl-0 = <&pen_fwe>, <&pen_irq_l>, <&pen_rst_l>; 437 pinctrl-names = "default"; 439 pinctrl-names = "default"; 438 vdd-supply = <&vcc_3v3_pmu>; 440 vdd-supply = <&vcc_3v3_pmu>; 439 }; 441 }; 440 }; 442 }; 441 443 442 &i2c3 { 444 &i2c3 { 443 pinctrl-0 = <&i2c3m1_xfer>; 445 pinctrl-0 = <&i2c3m1_xfer>; 444 status = "okay"; 446 status = "okay"; 445 447 446 led-controller@36 { 448 led-controller@36 { 447 compatible = "ti,lm3630a"; 449 compatible = "ti,lm3630a"; 448 reg = <0x36>; 450 reg = <0x36>; 449 enable-gpios = <&gpio0 RK_PB7 451 enable-gpios = <&gpio0 RK_PB7 GPIO_ACTIVE_HIGH>; 450 pinctrl-0 = <&backlight_hwen_h 452 pinctrl-0 = <&backlight_hwen_h>; 451 pinctrl-names = "default"; 453 pinctrl-names = "default"; 452 #address-cells = <1>; 454 #address-cells = <1>; 453 #size-cells = <0>; 455 #size-cells = <0>; 454 456 455 led@0 { 457 led@0 { 456 reg = <0>; 458 reg = <0>; 457 label = "backlight_coo 459 label = "backlight_cool"; 458 default-brightness = < 460 default-brightness = <0>; 459 }; 461 }; 460 462 461 led@1 { 463 led@1 { 462 reg = <1>; 464 reg = <1>; 463 label = "backlight_war 465 label = "backlight_warm"; 464 default-brightness = < 466 default-brightness = <0>; 465 }; 467 }; 466 }; 468 }; 467 469 468 wusb3801: tcpc@60 { 470 wusb3801: tcpc@60 { 469 compatible = "willsemi,wusb380 471 compatible = "willsemi,wusb3801"; 470 reg = <0x60>; 472 reg = <0x60>; 471 interrupt-parent = <&gpio0>; 473 interrupt-parent = <&gpio0>; 472 interrupts = <RK_PA4 IRQ_TYPE_ 474 interrupts = <RK_PA4 IRQ_TYPE_LEVEL_LOW>; 473 pinctrl-0 = <&tcpc_int_l>; 475 pinctrl-0 = <&tcpc_int_l>; 474 pinctrl-names = "default"; 476 pinctrl-names = "default"; 475 477 476 connector { 478 connector { 477 compatible = "usb-c-co 479 compatible = "usb-c-connector"; 478 label = "USB-C"; 480 label = "USB-C"; 479 vbus-supply = <&otg_sw 481 vbus-supply = <&otg_switch>; 480 power-role = "dual"; 482 power-role = "dual"; 481 try-power-role = "sink 483 try-power-role = "sink"; 482 data-role = "dual"; 484 data-role = "dual"; 483 typec-power-opmode = " 485 typec-power-opmode = "default"; 484 pd-disable; 486 pd-disable; 485 487 486 ports { 488 ports { 487 #address-cells 489 #address-cells = <0x1>; 488 #size-cells = 490 #size-cells = <0x0>; 489 491 490 port@0 { 492 port@0 { 491 reg = 493 reg = <0x0>; 492 494 493 typec_ 495 typec_hs_usb2phy0: endpoint { 494 496 remote-endpoint = <&usb2phy0_typec_hs>; 495 }; 497 }; 496 }; 498 }; 497 }; 499 }; 498 }; 500 }; 499 }; 501 }; 500 }; 502 }; 501 503 502 &i2c5 { 504 &i2c5 { 503 status = "okay"; 505 status = "okay"; 504 506 505 accelerometer@18 { 507 accelerometer@18 { 506 compatible = "silan,sc7a20"; 508 compatible = "silan,sc7a20"; 507 reg = <0x18>; 509 reg = <0x18>; 508 interrupt-parent = <&gpio3>; 510 interrupt-parent = <&gpio3>; 509 interrupts = <RK_PB2 IRQ_TYPE_ 511 interrupts = <RK_PB2 IRQ_TYPE_LEVEL_LOW>; 510 pinctrl-0 = <&accelerometer_in 512 pinctrl-0 = <&accelerometer_int_l>; 511 pinctrl-names = "default"; 513 pinctrl-names = "default"; 512 st,drdy-int-pin = <1>; 514 st,drdy-int-pin = <1>; 513 vdd-supply = <&vcc_3v3>; 515 vdd-supply = <&vcc_3v3>; 514 vddio-supply = <&vcc_3v3>; 516 vddio-supply = <&vcc_3v3>; 515 }; 517 }; 516 }; 518 }; 517 519 518 &i2s1_8ch { 520 &i2s1_8ch { 519 pinctrl-0 = <&i2s1m0_lrcktx>, <&i2s1m0 521 pinctrl-0 = <&i2s1m0_lrcktx>, <&i2s1m0_sclktx>, <&i2s1m0_sdi0>, <&i2s1m0_sdo0>; 520 rockchip,trcm-sync-tx-only; 522 rockchip,trcm-sync-tx-only; 521 status = "okay"; 523 status = "okay"; 522 }; 524 }; 523 525 524 &pdm { 526 &pdm { 525 pinctrl-0 = <&pdmm0_clk1>, <&pdmm0_sdi 527 pinctrl-0 = <&pdmm0_clk1>, <&pdmm0_sdi1>, <&pdmm0_sdi2>; 526 /* microphones are on channels 1 and 2 528 /* microphones are on channels 1 and 2 */ 527 rockchip,path-map = <1>, <2>, <0>, <3> 529 rockchip,path-map = <1>, <2>, <0>, <3>; 528 status = "okay"; 530 status = "okay"; 529 }; 531 }; 530 532 531 &pinctrl { 533 &pinctrl { 532 accelerometer { 534 accelerometer { 533 accelerometer_int_l: accelerom 535 accelerometer_int_l: accelerometer-int-l { 534 rockchip,pins = <3 RK_ 536 rockchip,pins = <3 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>; 535 }; 537 }; 536 }; 538 }; 537 539 538 audio-amplifier { 540 audio-amplifier { 539 spk_amp_enable_h: spk-amp-enab 541 spk_amp_enable_h: spk-amp-enable-h { 540 rockchip,pins = <3 RK_ 542 rockchip,pins = <3 RK_PC4 RK_FUNC_GPIO &pcfg_pull_none>; 541 }; 543 }; 542 }; 544 }; 543 545 544 backlight { 546 backlight { 545 backlight_hwen_h: backlight-hw 547 backlight_hwen_h: backlight-hwen-h { 546 rockchip,pins = <0 RK_ 548 rockchip,pins = <0 RK_PB7 RK_FUNC_GPIO &pcfg_pull_none>; 547 }; 549 }; 548 }; 550 }; 549 551 550 bt { 552 bt { 551 bt_enable_h: bt-enable-h { 553 bt_enable_h: bt-enable-h { 552 rockchip,pins = <0 RK_ 554 rockchip,pins = <0 RK_PC4 RK_FUNC_GPIO &pcfg_pull_none>; 553 }; 555 }; 554 556 555 bt_host_wake_l: bt-host-wake-l 557 bt_host_wake_l: bt-host-wake-l { 556 rockchip,pins = <0 RK_ 558 rockchip,pins = <0 RK_PC3 RK_FUNC_GPIO &pcfg_pull_up>; 557 }; 559 }; 558 560 559 bt_wake_h: bt-wake-h { 561 bt_wake_h: bt-wake-h { 560 rockchip,pins = <0 RK_ 562 rockchip,pins = <0 RK_PC2 RK_FUNC_GPIO &pcfg_pull_none>; 561 }; 563 }; 562 }; 564 }; 563 565 564 led { 566 led { 565 led_pin: led-pin { 567 led_pin: led-pin { 566 rockchip,pins = <3 RK_ 568 rockchip,pins = <3 RK_PC5 RK_FUNC_GPIO &pcfg_pull_none>; 567 }; 569 }; 568 }; 570 }; 569 571 570 hall { 572 hall { 571 hall_int_l: hall-int-l { 573 hall_int_l: hall-int-l { 572 rockchip,pins = <0 RK_ 574 rockchip,pins = <0 RK_PC7 RK_FUNC_GPIO &pcfg_pull_none>; 573 }; 575 }; 574 }; 576 }; 575 577 576 pen { 578 pen { 577 pen_fwe: pen-fwe { 579 pen_fwe: pen-fwe { 578 rockchip,pins = <3 RK_ 580 rockchip,pins = <3 RK_PB7 RK_FUNC_GPIO &pcfg_pull_down>; 579 }; 581 }; 580 582 581 pen_irq_l: pen-irq-l { 583 pen_irq_l: pen-irq-l { 582 rockchip,pins = <0 RK_ 584 rockchip,pins = <0 RK_PB6 RK_FUNC_GPIO &pcfg_pull_none>; 583 }; 585 }; 584 586 585 pen_rst_l: pen-rst-l { 587 pen_rst_l: pen-rst-l { 586 rockchip,pins = <0 RK_ 588 rockchip,pins = <0 RK_PC1 RK_FUNC_GPIO &pcfg_pull_none>; 587 }; 589 }; 588 }; 590 }; 589 591 590 pmic { 592 pmic { 591 pmic_int_l: pmic-int-l { 593 pmic_int_l: pmic-int-l { 592 rockchip,pins = <0 RK_ 594 rockchip,pins = <0 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>; 593 }; 595 }; 594 596 595 pmic_sleep: pmic-sleep { 597 pmic_sleep: pmic-sleep { 596 rockchip,pins = <0 RK_ 598 rockchip,pins = <0 RK_PA2 1 &pcfg_pull_none>; 597 }; 599 }; 598 }; 600 }; 599 601 600 sdio-pwrseq { 602 sdio-pwrseq { 601 wifi_enable_h: wifi-enable-h { 603 wifi_enable_h: wifi-enable-h { 602 rockchip,pins = <0 RK_ 604 rockchip,pins = <0 RK_PC6 RK_FUNC_GPIO &pcfg_pull_none>; 603 }; 605 }; 604 }; 606 }; 605 607 606 tcpc { 608 tcpc { 607 tcpc_int_l: tcpc-int-l { 609 tcpc_int_l: tcpc-int-l { 608 rockchip,pins = <0 RK_ 610 rockchip,pins = <0 RK_PA4 RK_FUNC_GPIO &pcfg_pull_up>; 609 }; 611 }; 610 }; 612 }; 611 613 612 vcc-wl { 614 vcc-wl { 613 vcc_wl_pin: vcc-wl-pin { 615 vcc_wl_pin: vcc-wl-pin { 614 rockchip,pins = <0 RK_ 616 rockchip,pins = <0 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>; 615 }; 617 }; 616 }; 618 }; 617 619 618 wifi { 620 wifi { 619 wifi_host_wake_l: wifi-host-wa 621 wifi_host_wake_l: wifi-host-wake-l { 620 rockchip,pins = <0 RK_ 622 rockchip,pins = <0 RK_PC5 RK_FUNC_GPIO &pcfg_pull_up>; 621 }; 623 }; 622 }; 624 }; 623 }; 625 }; 624 626 625 &pmu_io_domains { 627 &pmu_io_domains { 626 pmuio1-supply = <&vcc_3v3_pmu>; 628 pmuio1-supply = <&vcc_3v3_pmu>; 627 pmuio2-supply = <&vcc_3v3_pmu>; 629 pmuio2-supply = <&vcc_3v3_pmu>; 628 vccio1-supply = <&vccio_acodec>; 630 vccio1-supply = <&vccio_acodec>; 629 vccio2-supply = <&vcc_1v8>; 631 vccio2-supply = <&vcc_1v8>; 630 vccio3-supply = <&vcc_3v3>; 632 vccio3-supply = <&vcc_3v3>; 631 vccio4-supply = <&vcca_1v8_pmu>; 633 vccio4-supply = <&vcca_1v8_pmu>; 632 vccio5-supply = <&vcc_3v3>; 634 vccio5-supply = <&vcc_3v3>; 633 vccio6-supply = <&vcc_3v3>; 635 vccio6-supply = <&vcc_3v3>; 634 status = "okay"; 636 status = "okay"; 635 }; 637 }; 636 638 637 &saradc { 639 &saradc { 638 vref-supply = <&vcc_1v8>; 640 vref-supply = <&vcc_1v8>; 639 status = "okay"; 641 status = "okay"; 640 }; 642 }; 641 643 642 &sdhci { 644 &sdhci { 643 bus-width = <8>; 645 bus-width = <8>; 644 mmc-hs200-1_8v; 646 mmc-hs200-1_8v; 645 non-removable; 647 non-removable; 646 pinctrl-0 = <&emmc_bus8>, <&emmc_clk>, 648 pinctrl-0 = <&emmc_bus8>, <&emmc_clk>, <&emmc_cmd>, <&emmc_datastrobe>, <&emmc_rstnout>; 647 pinctrl-names = "default"; 649 pinctrl-names = "default"; 648 vmmc-supply = <&vcc_3v3>; 650 vmmc-supply = <&vcc_3v3>; 649 vqmmc-supply = <&vcc_1v8>; 651 vqmmc-supply = <&vcc_1v8>; 650 status = "okay"; 652 status = "okay"; 651 }; 653 }; 652 654 653 &sdmmc1 { 655 &sdmmc1 { 654 bus-width = <4>; 656 bus-width = <4>; 655 cap-sd-highspeed; 657 cap-sd-highspeed; 656 cap-sdio-irq; 658 cap-sdio-irq; 657 keep-power-in-suspend; 659 keep-power-in-suspend; 658 mmc-pwrseq = <&sdio_pwrseq>; 660 mmc-pwrseq = <&sdio_pwrseq>; 659 non-removable; 661 non-removable; 660 pinctrl-0 = <&sdmmc1_bus4>, <&sdmmc1_c 662 pinctrl-0 = <&sdmmc1_bus4>, <&sdmmc1_clk>, <&sdmmc1_cmd>; 661 pinctrl-names = "default"; 663 pinctrl-names = "default"; 662 sd-uhs-sdr104; 664 sd-uhs-sdr104; 663 vmmc-supply = <&vcc_wl>; 665 vmmc-supply = <&vcc_wl>; 664 vqmmc-supply = <&vcca_1v8_pmu>; 666 vqmmc-supply = <&vcca_1v8_pmu>; 665 status = "okay"; 667 status = "okay"; 666 }; 668 }; 667 669 668 &tsadc { 670 &tsadc { 669 /* tshut mode 0:CRU 1:GPIO */ 671 /* tshut mode 0:CRU 1:GPIO */ 670 rockchip,hw-tshut-mode = <1>; 672 rockchip,hw-tshut-mode = <1>; 671 /* tshut polarity 0:LOW 1:HIGH */ 673 /* tshut polarity 0:LOW 1:HIGH */ 672 rockchip,hw-tshut-polarity = <0>; 674 rockchip,hw-tshut-polarity = <0>; 673 status = "okay"; 675 status = "okay"; 674 }; 676 }; 675 677 676 &uart1 { 678 &uart1 { 677 dma-names = "tx", "rx"; << 678 pinctrl-0 = <&uart1m0_ctsn>, <&uart1m0 679 pinctrl-0 = <&uart1m0_ctsn>, <&uart1m0_rtsn>, <&uart1m0_xfer>; 679 pinctrl-names = "default"; 680 pinctrl-names = "default"; 680 uart-has-rtscts; 681 uart-has-rtscts; 681 status = "okay"; 682 status = "okay"; 682 683 683 bluetooth { 684 bluetooth { 684 compatible = "brcm,bcm43438-bt 685 compatible = "brcm,bcm43438-bt"; 685 clocks = <&rk817 1>; 686 clocks = <&rk817 1>; 686 clock-names = "lpo"; 687 clock-names = "lpo"; 687 device-wakeup-gpios = <&gpio0 !! 688 device-wake-gpios = <&gpio0 RK_PC2 GPIO_ACTIVE_HIGH>; 688 host-wakeup-gpios = <&gpio0 RK !! 689 host-wake-gpios = <&gpio0 RK_PC3 GPIO_ACTIVE_HIGH>; >> 690 reset-gpios = <&gpio0 RK_PC4 GPIO_ACTIVE_LOW>; 689 pinctrl-0 = <&bt_enable_h>, <& 691 pinctrl-0 = <&bt_enable_h>, <&bt_host_wake_l>, <&bt_wake_h>; 690 pinctrl-names = "default"; 692 pinctrl-names = "default"; 691 shutdown-gpios = <&gpio0 RK_PC << 692 vbat-supply = <&vcc_wl>; 693 vbat-supply = <&vcc_wl>; 693 vddio-supply = <&vcca_1v8_pmu> 694 vddio-supply = <&vcca_1v8_pmu>; 694 }; 695 }; 695 }; 696 }; 696 697 697 &uart2 { 698 &uart2 { 698 status = "okay"; 699 status = "okay"; 699 }; 700 }; 700 701 701 &usb_host0_xhci { 702 &usb_host0_xhci { 702 dr_mode = "otg"; 703 dr_mode = "otg"; 703 status = "okay"; 704 status = "okay"; 704 }; 705 }; 705 706 706 &usb2phy0 { 707 &usb2phy0 { 707 status = "okay"; 708 status = "okay"; 708 }; 709 }; 709 710 710 &usb2phy0_otg { 711 &usb2phy0_otg { 711 status = "okay"; 712 status = "okay"; 712 713 713 port { 714 port { 714 usb2phy0_typec_hs: endpoint { 715 usb2phy0_typec_hs: endpoint { 715 remote-endpoint = <&ty 716 remote-endpoint = <&typec_hs_usb2phy0>; 716 }; 717 }; 717 }; 718 }; 718 }; 719 };
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.