1f9010b0eSMarkus Reichl// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2f9010b0eSMarkus Reichl/* 3f9010b0eSMarkus Reichl * Copyright (c) 2017 T-Chip Intelligent Technology Co., Ltd 4f9010b0eSMarkus Reichl */ 5f9010b0eSMarkus Reichl 6f9010b0eSMarkus Reichl/dts-v1/; 7f9010b0eSMarkus Reichl#include <dt-bindings/input/linux-event-codes.h> 8f9010b0eSMarkus Reichl#include <dt-bindings/pwm/pwm.h> 9f9010b0eSMarkus Reichl#include "rk3399.dtsi" 10f9010b0eSMarkus Reichl#include "rk3399-opp.dtsi" 11f9010b0eSMarkus Reichl 12f9010b0eSMarkus Reichl/ { 13f9010b0eSMarkus Reichl model = "Firefly ROC-RK3399-PC Board"; 14f9010b0eSMarkus Reichl compatible = "firefly,roc-rk3399-pc", "rockchip,rk3399"; 15f9010b0eSMarkus Reichl 16f9010b0eSMarkus Reichl chosen { 17f9010b0eSMarkus Reichl stdout-path = "serial2:1500000n8"; 18f9010b0eSMarkus Reichl }; 19f9010b0eSMarkus Reichl 20f9010b0eSMarkus Reichl backlight: backlight { 21f9010b0eSMarkus Reichl compatible = "pwm-backlight"; 22f9010b0eSMarkus Reichl pwms = <&pwm0 0 25000 0>; 23f9010b0eSMarkus Reichl }; 24f9010b0eSMarkus Reichl 25f9010b0eSMarkus Reichl clkin_gmac: external-gmac-clock { 26f9010b0eSMarkus Reichl compatible = "fixed-clock"; 27f9010b0eSMarkus Reichl clock-frequency = <125000000>; 28f9010b0eSMarkus Reichl clock-output-names = "clkin_gmac"; 29f9010b0eSMarkus Reichl #clock-cells = <0>; 30f9010b0eSMarkus Reichl }; 31f9010b0eSMarkus Reichl 32f9010b0eSMarkus Reichl adc-keys { 33f9010b0eSMarkus Reichl compatible = "adc-keys"; 34f9010b0eSMarkus Reichl io-channels = <&saradc 1>; 35f9010b0eSMarkus Reichl io-channel-names = "buttons"; 36f9010b0eSMarkus Reichl keyup-threshold-microvolt = <1500000>; 37f9010b0eSMarkus Reichl poll-interval = <100>; 38f9010b0eSMarkus Reichl 39f9010b0eSMarkus Reichl recovery { 40f9010b0eSMarkus Reichl label = "Recovery"; 41f9010b0eSMarkus Reichl linux,code = <KEY_VENDOR>; 42f9010b0eSMarkus Reichl press-threshold-microvolt = <18000>; 43f9010b0eSMarkus Reichl }; 44f9010b0eSMarkus Reichl }; 45f9010b0eSMarkus Reichl 46f9010b0eSMarkus Reichl gpio-keys { 47f9010b0eSMarkus Reichl compatible = "gpio-keys"; 48f9010b0eSMarkus Reichl autorepeat; 49f9010b0eSMarkus Reichl pinctrl-names = "default"; 50f9010b0eSMarkus Reichl pinctrl-0 = <&pwr_key_l>; 51f9010b0eSMarkus Reichl 52f9010b0eSMarkus Reichl power { 53f9010b0eSMarkus Reichl debounce-interval = <100>; 54f9010b0eSMarkus Reichl gpios = <&gpio0 RK_PA5 GPIO_ACTIVE_LOW>; 55f9010b0eSMarkus Reichl label = "GPIO Key Power"; 56f9010b0eSMarkus Reichl linux,code = <KEY_POWER>; 57f9010b0eSMarkus Reichl wakeup-source; 58f9010b0eSMarkus Reichl }; 59f9010b0eSMarkus Reichl }; 60f9010b0eSMarkus Reichl 61f9010b0eSMarkus Reichl leds { 62f9010b0eSMarkus Reichl compatible = "gpio-leds"; 63f9010b0eSMarkus Reichl pinctrl-names = "default"; 646dd5e12cSJohan Jonker pinctrl-0 = <&work_led_pin>, <&diy_led_pin>, <&yellow_led_pin>; 65f9010b0eSMarkus Reichl 666dd5e12cSJohan Jonker work_led: led-0 { 67f9010b0eSMarkus Reichl label = "green:work"; 68f9010b0eSMarkus Reichl gpios = <&gpio2 RK_PD3 GPIO_ACTIVE_HIGH>; 69f9010b0eSMarkus Reichl default-state = "on"; 70f9010b0eSMarkus Reichl linux,default-trigger = "heartbeat"; 71f9010b0eSMarkus Reichl }; 72f9010b0eSMarkus Reichl 736dd5e12cSJohan Jonker diy_led: led-1 { 74f9010b0eSMarkus Reichl label = "red:diy"; 75f9010b0eSMarkus Reichl gpios = <&gpio0 RK_PB5 GPIO_ACTIVE_HIGH>; 76f9010b0eSMarkus Reichl default-state = "off"; 777327c8b9SMarkus Reichl linux,default-trigger = "mmc2"; 78f9010b0eSMarkus Reichl }; 79f9010b0eSMarkus Reichl 806dd5e12cSJohan Jonker yellow_led: led-2 { 81f9010b0eSMarkus Reichl label = "yellow:yellow-led"; 82f9010b0eSMarkus Reichl gpios = <&gpio0 RK_PA2 GPIO_ACTIVE_HIGH>; 83f9010b0eSMarkus Reichl default-state = "off"; 847327c8b9SMarkus Reichl linux,default-trigger = "mmc1"; 85f9010b0eSMarkus Reichl }; 86f9010b0eSMarkus Reichl }; 87f9010b0eSMarkus Reichl 88f9010b0eSMarkus Reichl sdio_pwrseq: sdio-pwrseq { 89f9010b0eSMarkus Reichl compatible = "mmc-pwrseq-simple"; 90f9010b0eSMarkus Reichl clocks = <&rk808 1>; 91f9010b0eSMarkus Reichl clock-names = "ext_clock"; 92f9010b0eSMarkus Reichl pinctrl-names = "default"; 93f9010b0eSMarkus Reichl pinctrl-0 = <&wifi_enable_h>; 94f9010b0eSMarkus Reichl 95f9010b0eSMarkus Reichl /* 96f9010b0eSMarkus Reichl * On the module itself this is one of these (depending 97f9010b0eSMarkus Reichl * on the actual card populated): 98f9010b0eSMarkus Reichl * - SDIO_RESET_L_WL_REG_ON 99f9010b0eSMarkus Reichl * - PDN (power down when low) 100f9010b0eSMarkus Reichl */ 101f9010b0eSMarkus Reichl reset-gpios = <&gpio0 RK_PB2 GPIO_ACTIVE_LOW>; 102f9010b0eSMarkus Reichl }; 103f9010b0eSMarkus Reichl 104f9010b0eSMarkus Reichl vcc_vbus_typec0: vcc-vbus-typec0 { 105f9010b0eSMarkus Reichl compatible = "regulator-fixed"; 106f9010b0eSMarkus Reichl regulator-name = "vcc_vbus_typec0"; 107f9010b0eSMarkus Reichl regulator-always-on; 108f9010b0eSMarkus Reichl regulator-boot-on; 109f9010b0eSMarkus Reichl regulator-min-microvolt = <5000000>; 110f9010b0eSMarkus Reichl regulator-max-microvolt = <5000000>; 111f9010b0eSMarkus Reichl }; 112f9010b0eSMarkus Reichl 113bd77d0adSJagan Teki sys_12v: sys-12v { 114bd77d0adSJagan Teki compatible = "regulator-fixed"; 115bd77d0adSJagan Teki regulator-name = "sys_12v"; 116bd77d0adSJagan Teki regulator-always-on; 117bd77d0adSJagan Teki regulator-boot-on; 118bd77d0adSJagan Teki vin-supply = <&dc_12v>; 119bd77d0adSJagan Teki }; 120bd77d0adSJagan Teki 121f9010b0eSMarkus Reichl /* switched by pmic_sleep */ 122f9010b0eSMarkus Reichl vcc1v8_s3: vcca1v8_s3: vcc1v8-s3 { 123f9010b0eSMarkus Reichl compatible = "regulator-fixed"; 124f9010b0eSMarkus Reichl regulator-name = "vcc1v8_s3"; 125f9010b0eSMarkus Reichl regulator-always-on; 126f9010b0eSMarkus Reichl regulator-boot-on; 127f9010b0eSMarkus Reichl regulator-min-microvolt = <1800000>; 128f9010b0eSMarkus Reichl regulator-max-microvolt = <1800000>; 129f9010b0eSMarkus Reichl vin-supply = <&vcc_1v8>; 130f9010b0eSMarkus Reichl }; 131f9010b0eSMarkus Reichl 132140e816aSMarkus Reichl vcc3v0_sd: vcc3v0-sd { 133140e816aSMarkus Reichl compatible = "regulator-fixed"; 134140e816aSMarkus Reichl enable-active-high; 135140e816aSMarkus Reichl gpio = <&gpio4 RK_PD6 GPIO_ACTIVE_HIGH>; 136140e816aSMarkus Reichl pinctrl-names = "default"; 137140e816aSMarkus Reichl pinctrl-0 = <&vcc3v0_sd_en>; 138140e816aSMarkus Reichl regulator-name = "vcc3v0_sd"; 139140e816aSMarkus Reichl regulator-boot-on; 140140e816aSMarkus Reichl regulator-min-microvolt = <3000000>; 141140e816aSMarkus Reichl regulator-max-microvolt = <3000000>; 142140e816aSMarkus Reichl vin-supply = <&vcc3v3_sys>; 143140e816aSMarkus Reichl }; 144140e816aSMarkus Reichl 145f9010b0eSMarkus Reichl vcc3v3_sys: vcc3v3-sys { 146f9010b0eSMarkus Reichl compatible = "regulator-fixed"; 147f9010b0eSMarkus Reichl regulator-name = "vcc3v3_sys"; 148f9010b0eSMarkus Reichl regulator-always-on; 149f9010b0eSMarkus Reichl regulator-boot-on; 150f9010b0eSMarkus Reichl regulator-min-microvolt = <3300000>; 151f9010b0eSMarkus Reichl regulator-max-microvolt = <3300000>; 152bd77d0adSJagan Teki vin-supply = <&sys_12v>; 153f9010b0eSMarkus Reichl }; 154f9010b0eSMarkus Reichl 155ec5b0af7SMarkus Reichl vcca_0v9: vcca-0v9 { 156ec5b0af7SMarkus Reichl compatible = "regulator-fixed"; 157ec5b0af7SMarkus Reichl regulator-name = "vcca_0v9"; 158ec5b0af7SMarkus Reichl regulator-always-on; 159ec5b0af7SMarkus Reichl regulator-boot-on; 160ec5b0af7SMarkus Reichl regulator-min-microvolt = <900000>; 161ec5b0af7SMarkus Reichl regulator-max-microvolt = <900000>; 162ec5b0af7SMarkus Reichl vin-supply = <&vcc3v3_sys>; 163ec5b0af7SMarkus Reichl }; 164ec5b0af7SMarkus Reichl 165f9010b0eSMarkus Reichl /* Actually 3 regulators (host0, 1, 2) controlled by the same gpio */ 166f9010b0eSMarkus Reichl vcc5v0_host: vcc5v0-host-regulator { 167f9010b0eSMarkus Reichl compatible = "regulator-fixed"; 168f9010b0eSMarkus Reichl enable-active-high; 169f9010b0eSMarkus Reichl gpio = <&gpio1 RK_PA0 GPIO_ACTIVE_HIGH>; 170f9010b0eSMarkus Reichl pinctrl-names = "default"; 171f9010b0eSMarkus Reichl pinctrl-0 = <&vcc5v0_host_en &hub_rst>; 172f9010b0eSMarkus Reichl regulator-name = "vcc5v0_host"; 173f9010b0eSMarkus Reichl vin-supply = <&vcc_sys>; 174f9010b0eSMarkus Reichl }; 175f9010b0eSMarkus Reichl 176f9010b0eSMarkus Reichl vcc_vbus_typec1: vcc-vbus-typec1 { 177f9010b0eSMarkus Reichl compatible = "regulator-fixed"; 178f9010b0eSMarkus Reichl enable-active-high; 179f9010b0eSMarkus Reichl gpio = <&gpio1 RK_PB5 GPIO_ACTIVE_HIGH>; 180f9010b0eSMarkus Reichl pinctrl-names = "default"; 181f9010b0eSMarkus Reichl pinctrl-0 = <&vcc_vbus_typec1_en>; 182f9010b0eSMarkus Reichl regulator-name = "vcc_vbus_typec1"; 183f9010b0eSMarkus Reichl regulator-always-on; 184f9010b0eSMarkus Reichl vin-supply = <&vcc_sys>; 185f9010b0eSMarkus Reichl }; 186f9010b0eSMarkus Reichl 187f9010b0eSMarkus Reichl vcc_sys: vcc-sys { 188f9010b0eSMarkus Reichl compatible = "regulator-fixed"; 189f9010b0eSMarkus Reichl enable-active-high; 190f9010b0eSMarkus Reichl gpio = <&gpio2 RK_PA6 GPIO_ACTIVE_HIGH>; 191f9010b0eSMarkus Reichl pinctrl-names = "default"; 192f9010b0eSMarkus Reichl pinctrl-0 = <&vcc_sys_en>; 193f9010b0eSMarkus Reichl regulator-name = "vcc_sys"; 194f9010b0eSMarkus Reichl regulator-boot-on; 195f9010b0eSMarkus Reichl regulator-min-microvolt = <5000000>; 196f9010b0eSMarkus Reichl regulator-max-microvolt = <5000000>; 197bd77d0adSJagan Teki vin-supply = <&sys_12v>; 198f9010b0eSMarkus Reichl }; 199f9010b0eSMarkus Reichl 200f9010b0eSMarkus Reichl vdd_log: vdd-log { 201f9010b0eSMarkus Reichl compatible = "pwm-regulator"; 202f9010b0eSMarkus Reichl pwms = <&pwm2 0 25000 1>; 203f9010b0eSMarkus Reichl regulator-name = "vdd_log"; 204f9010b0eSMarkus Reichl regulator-always-on; 205f9010b0eSMarkus Reichl regulator-boot-on; 206c38d8009SMarkus Reichl regulator-min-microvolt = <450000>; 207f9010b0eSMarkus Reichl regulator-max-microvolt = <1400000>; 208c38d8009SMarkus Reichl pwm-supply = <&vcc3v3_sys>; 209f9010b0eSMarkus Reichl }; 210f9010b0eSMarkus Reichl}; 211f9010b0eSMarkus Reichl 212f9010b0eSMarkus Reichl&cpu_l0 { 213f9010b0eSMarkus Reichl cpu-supply = <&vdd_cpu_l>; 214f9010b0eSMarkus Reichl}; 215f9010b0eSMarkus Reichl 216f9010b0eSMarkus Reichl&cpu_l1 { 217f9010b0eSMarkus Reichl cpu-supply = <&vdd_cpu_l>; 218f9010b0eSMarkus Reichl}; 219f9010b0eSMarkus Reichl 220f9010b0eSMarkus Reichl&cpu_l2 { 221f9010b0eSMarkus Reichl cpu-supply = <&vdd_cpu_l>; 222f9010b0eSMarkus Reichl}; 223f9010b0eSMarkus Reichl 224f9010b0eSMarkus Reichl&cpu_l3 { 225f9010b0eSMarkus Reichl cpu-supply = <&vdd_cpu_l>; 226f9010b0eSMarkus Reichl}; 227f9010b0eSMarkus Reichl 228f9010b0eSMarkus Reichl&cpu_b0 { 229f9010b0eSMarkus Reichl cpu-supply = <&vdd_cpu_b>; 230f9010b0eSMarkus Reichl}; 231f9010b0eSMarkus Reichl 232f9010b0eSMarkus Reichl&cpu_b1 { 233f9010b0eSMarkus Reichl cpu-supply = <&vdd_cpu_b>; 234f9010b0eSMarkus Reichl}; 235f9010b0eSMarkus Reichl 236f9010b0eSMarkus Reichl&emmc_phy { 237f9010b0eSMarkus Reichl status = "okay"; 238f9010b0eSMarkus Reichl}; 239f9010b0eSMarkus Reichl 240f9010b0eSMarkus Reichl&gmac { 241f9010b0eSMarkus Reichl assigned-clocks = <&cru SCLK_RMII_SRC>; 242f9010b0eSMarkus Reichl assigned-clock-parents = <&clkin_gmac>; 243f9010b0eSMarkus Reichl clock_in_out = "input"; 244f9010b0eSMarkus Reichl phy-supply = <&vcc_lan>; 245f9010b0eSMarkus Reichl phy-mode = "rgmii"; 246f9010b0eSMarkus Reichl pinctrl-names = "default"; 247f9010b0eSMarkus Reichl pinctrl-0 = <&rgmii_pins>; 248f9010b0eSMarkus Reichl snps,reset-gpio = <&gpio3 RK_PB7 GPIO_ACTIVE_LOW>; 249f9010b0eSMarkus Reichl snps,reset-active-low; 250f9010b0eSMarkus Reichl snps,reset-delays-us = <0 10000 50000>; 251f9010b0eSMarkus Reichl tx_delay = <0x28>; 252f9010b0eSMarkus Reichl rx_delay = <0x11>; 253f9010b0eSMarkus Reichl status = "okay"; 254f9010b0eSMarkus Reichl}; 255f9010b0eSMarkus Reichl 256ec7d731dSMarkus Reichl&gpu { 257ec7d731dSMarkus Reichl mali-supply = <&vdd_gpu>; 258ec7d731dSMarkus Reichl status = "okay"; 259ec7d731dSMarkus Reichl}; 260ec7d731dSMarkus Reichl 261f9010b0eSMarkus Reichl&hdmi { 262f9010b0eSMarkus Reichl ddc-i2c-bus = <&i2c3>; 263f9010b0eSMarkus Reichl pinctrl-names = "default"; 264f9010b0eSMarkus Reichl pinctrl-0 = <&hdmi_cec>; 265f9010b0eSMarkus Reichl status = "okay"; 266f9010b0eSMarkus Reichl}; 267f9010b0eSMarkus Reichl 268e748d355SMarkus Reichl&hdmi_sound { 269e748d355SMarkus Reichl status = "okay"; 270e748d355SMarkus Reichl}; 271e748d355SMarkus Reichl 272f9010b0eSMarkus Reichl&i2c0 { 273f9010b0eSMarkus Reichl clock-frequency = <400000>; 274f9010b0eSMarkus Reichl i2c-scl-rising-time-ns = <168>; 275f9010b0eSMarkus Reichl i2c-scl-falling-time-ns = <4>; 276f9010b0eSMarkus Reichl status = "okay"; 277f9010b0eSMarkus Reichl 278f9010b0eSMarkus Reichl rk808: pmic@1b { 279f9010b0eSMarkus Reichl compatible = "rockchip,rk808"; 280f9010b0eSMarkus Reichl reg = <0x1b>; 281f9010b0eSMarkus Reichl interrupt-parent = <&gpio1>; 282f9010b0eSMarkus Reichl interrupts = <21 IRQ_TYPE_LEVEL_LOW>; 283f9010b0eSMarkus Reichl #clock-cells = <1>; 284f9010b0eSMarkus Reichl clock-output-names = "xin32k", "rk808-clkout2"; 285f9010b0eSMarkus Reichl pinctrl-names = "default"; 286f9010b0eSMarkus Reichl pinctrl-0 = <&pmic_int_l>; 287f9010b0eSMarkus Reichl rockchip,system-power-controller; 288f9010b0eSMarkus Reichl wakeup-source; 289f9010b0eSMarkus Reichl 290f9010b0eSMarkus Reichl vcc1-supply = <&vcc3v3_sys>; 291f9010b0eSMarkus Reichl vcc2-supply = <&vcc3v3_sys>; 292f9010b0eSMarkus Reichl vcc3-supply = <&vcc3v3_sys>; 293f9010b0eSMarkus Reichl vcc4-supply = <&vcc3v3_sys>; 294f9010b0eSMarkus Reichl vcc6-supply = <&vcc3v3_sys>; 295f9010b0eSMarkus Reichl vcc7-supply = <&vcc3v3_sys>; 296f9010b0eSMarkus Reichl vcc8-supply = <&vcc3v3_sys>; 297f9010b0eSMarkus Reichl vcc9-supply = <&vcc3v3_sys>; 298f9010b0eSMarkus Reichl vcc10-supply = <&vcc3v3_sys>; 299f9010b0eSMarkus Reichl vcc11-supply = <&vcc3v3_sys>; 300f9010b0eSMarkus Reichl vcc12-supply = <&vcc3v3_sys>; 301f9010b0eSMarkus Reichl vcc13-supply = <&vcc3v3_sys>; 302f9010b0eSMarkus Reichl vcc14-supply = <&vcc3v3_sys>; 303f9010b0eSMarkus Reichl vddio-supply = <&vcc_3v0>; 304f9010b0eSMarkus Reichl 305f9010b0eSMarkus Reichl regulators { 306f9010b0eSMarkus Reichl vdd_center: DCDC_REG1 { 307f9010b0eSMarkus Reichl regulator-name = "vdd_center"; 308f9010b0eSMarkus Reichl regulator-always-on; 309f9010b0eSMarkus Reichl regulator-boot-on; 310f9010b0eSMarkus Reichl regulator-min-microvolt = <750000>; 311f9010b0eSMarkus Reichl regulator-max-microvolt = <1350000>; 312f9010b0eSMarkus Reichl regulator-ramp-delay = <6001>; 313f9010b0eSMarkus Reichl regulator-state-mem { 314f9010b0eSMarkus Reichl regulator-off-in-suspend; 315f9010b0eSMarkus Reichl }; 316f9010b0eSMarkus Reichl }; 317f9010b0eSMarkus Reichl 318f9010b0eSMarkus Reichl vdd_cpu_l: DCDC_REG2 { 319f9010b0eSMarkus Reichl regulator-name = "vdd_cpu_l"; 320f9010b0eSMarkus Reichl regulator-always-on; 321f9010b0eSMarkus Reichl regulator-boot-on; 322f9010b0eSMarkus Reichl regulator-min-microvolt = <750000>; 323f9010b0eSMarkus Reichl regulator-max-microvolt = <1350000>; 324f9010b0eSMarkus Reichl regulator-ramp-delay = <6001>; 325f9010b0eSMarkus Reichl regulator-state-mem { 326f9010b0eSMarkus Reichl regulator-off-in-suspend; 327f9010b0eSMarkus Reichl }; 328f9010b0eSMarkus Reichl }; 329f9010b0eSMarkus Reichl 330f9010b0eSMarkus Reichl vcc_ddr: DCDC_REG3 { 331f9010b0eSMarkus Reichl regulator-name = "vcc_ddr"; 332f9010b0eSMarkus Reichl regulator-always-on; 333f9010b0eSMarkus Reichl regulator-boot-on; 334f9010b0eSMarkus Reichl regulator-state-mem { 335f9010b0eSMarkus Reichl regulator-on-in-suspend; 336f9010b0eSMarkus Reichl }; 337f9010b0eSMarkus Reichl }; 338f9010b0eSMarkus Reichl 339f9010b0eSMarkus Reichl vcc_1v8: DCDC_REG4 { 340f9010b0eSMarkus Reichl regulator-name = "vcc_1v8"; 341f9010b0eSMarkus Reichl regulator-always-on; 342f9010b0eSMarkus Reichl regulator-boot-on; 343f9010b0eSMarkus Reichl regulator-min-microvolt = <1800000>; 344f9010b0eSMarkus Reichl regulator-max-microvolt = <1800000>; 345f9010b0eSMarkus Reichl regulator-state-mem { 346f9010b0eSMarkus Reichl regulator-on-in-suspend; 347f9010b0eSMarkus Reichl regulator-suspend-microvolt = <1800000>; 348f9010b0eSMarkus Reichl }; 349f9010b0eSMarkus Reichl }; 350f9010b0eSMarkus Reichl 351f9010b0eSMarkus Reichl vcca1v8_codec: LDO_REG1 { 352f9010b0eSMarkus Reichl regulator-name = "vcca1v8_codec"; 353f9010b0eSMarkus Reichl regulator-always-on; 354f9010b0eSMarkus Reichl regulator-boot-on; 355f9010b0eSMarkus Reichl regulator-min-microvolt = <1800000>; 356f9010b0eSMarkus Reichl regulator-max-microvolt = <1800000>; 357f9010b0eSMarkus Reichl regulator-state-mem { 358f9010b0eSMarkus Reichl regulator-off-in-suspend; 359f9010b0eSMarkus Reichl }; 360f9010b0eSMarkus Reichl }; 361f9010b0eSMarkus Reichl 362f9010b0eSMarkus Reichl vcc1v8_hdmi: LDO_REG2 { 363f9010b0eSMarkus Reichl regulator-name = "vcc1v8_hdmi"; 364f9010b0eSMarkus Reichl regulator-always-on; 365f9010b0eSMarkus Reichl regulator-boot-on; 366f9010b0eSMarkus Reichl regulator-min-microvolt = <1800000>; 367f9010b0eSMarkus Reichl regulator-max-microvolt = <1800000>; 368f9010b0eSMarkus Reichl regulator-state-mem { 369f9010b0eSMarkus Reichl regulator-off-in-suspend; 370f9010b0eSMarkus Reichl }; 371f9010b0eSMarkus Reichl }; 372f9010b0eSMarkus Reichl 373f9010b0eSMarkus Reichl vcc1v8_pmu: LDO_REG3 { 374f9010b0eSMarkus Reichl regulator-name = "vcc1v8_pmu"; 375f9010b0eSMarkus Reichl regulator-always-on; 376f9010b0eSMarkus Reichl regulator-boot-on; 377f9010b0eSMarkus Reichl regulator-min-microvolt = <1800000>; 378f9010b0eSMarkus Reichl regulator-max-microvolt = <1800000>; 379f9010b0eSMarkus Reichl regulator-state-mem { 380f9010b0eSMarkus Reichl regulator-on-in-suspend; 381f9010b0eSMarkus Reichl regulator-suspend-microvolt = <1800000>; 382f9010b0eSMarkus Reichl }; 383f9010b0eSMarkus Reichl }; 384f9010b0eSMarkus Reichl 385f9010b0eSMarkus Reichl vcc_sdio: LDO_REG4 { 386f9010b0eSMarkus Reichl regulator-name = "vcc_sdio"; 387f9010b0eSMarkus Reichl regulator-boot-on; 388f9010b0eSMarkus Reichl regulator-min-microvolt = <1800000>; 389f9010b0eSMarkus Reichl regulator-max-microvolt = <3000000>; 390f9010b0eSMarkus Reichl regulator-state-mem { 391f9010b0eSMarkus Reichl regulator-on-in-suspend; 392f9010b0eSMarkus Reichl regulator-suspend-microvolt = <3000000>; 393f9010b0eSMarkus Reichl }; 394f9010b0eSMarkus Reichl }; 395f9010b0eSMarkus Reichl 396f9010b0eSMarkus Reichl vcca3v0_codec: LDO_REG5 { 397f9010b0eSMarkus Reichl regulator-name = "vcca3v0_codec"; 398f9010b0eSMarkus Reichl regulator-always-on; 399f9010b0eSMarkus Reichl regulator-boot-on; 400f9010b0eSMarkus Reichl regulator-min-microvolt = <3000000>; 401f9010b0eSMarkus Reichl regulator-max-microvolt = <3000000>; 402f9010b0eSMarkus Reichl regulator-state-mem { 403f9010b0eSMarkus Reichl regulator-off-in-suspend; 404f9010b0eSMarkus Reichl }; 405f9010b0eSMarkus Reichl }; 406f9010b0eSMarkus Reichl 407f9010b0eSMarkus Reichl vcc_1v5: LDO_REG6 { 408f9010b0eSMarkus Reichl regulator-name = "vcc_1v5"; 409f9010b0eSMarkus Reichl regulator-always-on; 410f9010b0eSMarkus Reichl regulator-boot-on; 411f9010b0eSMarkus Reichl regulator-min-microvolt = <1500000>; 412f9010b0eSMarkus Reichl regulator-max-microvolt = <1500000>; 413f9010b0eSMarkus Reichl regulator-state-mem { 414f9010b0eSMarkus Reichl regulator-on-in-suspend; 415f9010b0eSMarkus Reichl regulator-suspend-microvolt = <1500000>; 416f9010b0eSMarkus Reichl }; 417f9010b0eSMarkus Reichl }; 418f9010b0eSMarkus Reichl 419f9010b0eSMarkus Reichl vcca0v9_hdmi: LDO_REG7 { 420f9010b0eSMarkus Reichl regulator-name = "vcca0v9_hdmi"; 421f9010b0eSMarkus Reichl regulator-always-on; 422f9010b0eSMarkus Reichl regulator-boot-on; 423f9010b0eSMarkus Reichl regulator-min-microvolt = <900000>; 424f9010b0eSMarkus Reichl regulator-max-microvolt = <900000>; 425f9010b0eSMarkus Reichl regulator-state-mem { 426f9010b0eSMarkus Reichl regulator-off-in-suspend; 427f9010b0eSMarkus Reichl }; 428f9010b0eSMarkus Reichl }; 429f9010b0eSMarkus Reichl 430f9010b0eSMarkus Reichl vcc_3v0: LDO_REG8 { 431f9010b0eSMarkus Reichl regulator-name = "vcc_3v0"; 432f9010b0eSMarkus Reichl regulator-always-on; 433f9010b0eSMarkus Reichl regulator-boot-on; 434f9010b0eSMarkus Reichl regulator-min-microvolt = <3000000>; 435f9010b0eSMarkus Reichl regulator-max-microvolt = <3000000>; 436f9010b0eSMarkus Reichl regulator-state-mem { 437f9010b0eSMarkus Reichl regulator-on-in-suspend; 438f9010b0eSMarkus Reichl regulator-suspend-microvolt = <3000000>; 439f9010b0eSMarkus Reichl }; 440f9010b0eSMarkus Reichl }; 441f9010b0eSMarkus Reichl 442f9010b0eSMarkus Reichl vcc3v3_s3: vcc_lan: SWITCH_REG1 { 443f9010b0eSMarkus Reichl regulator-name = "vcc3v3_s3"; 444f9010b0eSMarkus Reichl regulator-always-on; 445f9010b0eSMarkus Reichl regulator-boot-on; 446f9010b0eSMarkus Reichl regulator-state-mem { 447f9010b0eSMarkus Reichl regulator-off-in-suspend; 448f9010b0eSMarkus Reichl }; 449f9010b0eSMarkus Reichl }; 450f9010b0eSMarkus Reichl 451f9010b0eSMarkus Reichl vcc3v3_s0: SWITCH_REG2 { 452f9010b0eSMarkus Reichl regulator-name = "vcc3v3_s0"; 453f9010b0eSMarkus Reichl regulator-always-on; 454f9010b0eSMarkus Reichl regulator-boot-on; 455f9010b0eSMarkus Reichl regulator-state-mem { 456f9010b0eSMarkus Reichl regulator-off-in-suspend; 457f9010b0eSMarkus Reichl }; 458f9010b0eSMarkus Reichl }; 459f9010b0eSMarkus Reichl }; 460f9010b0eSMarkus Reichl }; 461f9010b0eSMarkus Reichl 462f9010b0eSMarkus Reichl vdd_cpu_b: regulator@40 { 463f9010b0eSMarkus Reichl compatible = "silergy,syr827"; 464f9010b0eSMarkus Reichl reg = <0x40>; 465f9010b0eSMarkus Reichl fcs,suspend-voltage-selector = <1>; 466f9010b0eSMarkus Reichl pinctrl-names = "default"; 4672bc65fefSJohan Jonker pinctrl-0 = <&vsel1_pin>; 468f9010b0eSMarkus Reichl regulator-name = "vdd_cpu_b"; 469f9010b0eSMarkus Reichl regulator-min-microvolt = <712500>; 470f9010b0eSMarkus Reichl regulator-max-microvolt = <1500000>; 471f9010b0eSMarkus Reichl regulator-ramp-delay = <1000>; 472f9010b0eSMarkus Reichl regulator-always-on; 473f9010b0eSMarkus Reichl regulator-boot-on; 474f9010b0eSMarkus Reichl vin-supply = <&vcc3v3_sys>; 475f9010b0eSMarkus Reichl 476f9010b0eSMarkus Reichl regulator-state-mem { 477f9010b0eSMarkus Reichl regulator-off-in-suspend; 478f9010b0eSMarkus Reichl }; 479f9010b0eSMarkus Reichl }; 480f9010b0eSMarkus Reichl 481f9010b0eSMarkus Reichl vdd_gpu: regulator@41 { 482f9010b0eSMarkus Reichl compatible = "silergy,syr828"; 483f9010b0eSMarkus Reichl reg = <0x41>; 484f9010b0eSMarkus Reichl fcs,suspend-voltage-selector = <1>; 485f9010b0eSMarkus Reichl pinctrl-names = "default"; 4862bc65fefSJohan Jonker pinctrl-0 = <&vsel2_pin>; 487f9010b0eSMarkus Reichl regulator-name = "vdd_gpu"; 488f9010b0eSMarkus Reichl regulator-min-microvolt = <712500>; 489f9010b0eSMarkus Reichl regulator-max-microvolt = <1500000>; 490f9010b0eSMarkus Reichl regulator-ramp-delay = <1000>; 491f9010b0eSMarkus Reichl vin-supply = <&vcc3v3_sys>; 492f9010b0eSMarkus Reichl 493f9010b0eSMarkus Reichl regulator-state-mem { 494f9010b0eSMarkus Reichl regulator-off-in-suspend; 495f9010b0eSMarkus Reichl }; 496f9010b0eSMarkus Reichl }; 497f9010b0eSMarkus Reichl}; 498f9010b0eSMarkus Reichl 499f9010b0eSMarkus Reichl&i2c1 { 500f9010b0eSMarkus Reichl i2c-scl-rising-time-ns = <300>; 501f9010b0eSMarkus Reichl i2c-scl-falling-time-ns = <15>; 502f9010b0eSMarkus Reichl status = "okay"; 503f9010b0eSMarkus Reichl}; 504f9010b0eSMarkus Reichl 505f9010b0eSMarkus Reichl&i2c3 { 506f9010b0eSMarkus Reichl i2c-scl-rising-time-ns = <450>; 507f9010b0eSMarkus Reichl i2c-scl-falling-time-ns = <15>; 508f9010b0eSMarkus Reichl status = "okay"; 509f9010b0eSMarkus Reichl}; 510f9010b0eSMarkus Reichl 511f9010b0eSMarkus Reichl&i2c4 { 512f9010b0eSMarkus Reichl i2c-scl-rising-time-ns = <600>; 513f9010b0eSMarkus Reichl i2c-scl-falling-time-ns = <20>; 514f9010b0eSMarkus Reichl status = "okay"; 515f9010b0eSMarkus Reichl 516f9010b0eSMarkus Reichl fusb1: usb-typec@22 { 517f9010b0eSMarkus Reichl compatible = "fcs,fusb302"; 518f9010b0eSMarkus Reichl reg = <0x22>; 519f9010b0eSMarkus Reichl interrupt-parent = <&gpio1>; 520f9010b0eSMarkus Reichl interrupts = <1 IRQ_TYPE_LEVEL_LOW>; 521f9010b0eSMarkus Reichl pinctrl-names = "default"; 522f9010b0eSMarkus Reichl pinctrl-0 = <&fusb1_int>; 523f9010b0eSMarkus Reichl vbus-supply = <&vcc_vbus_typec1>; 524f9010b0eSMarkus Reichl status = "okay"; 525f9010b0eSMarkus Reichl }; 526f9010b0eSMarkus Reichl}; 527f9010b0eSMarkus Reichl 528f9010b0eSMarkus Reichl&i2c7 { 529f9010b0eSMarkus Reichl i2c-scl-rising-time-ns = <600>; 530f9010b0eSMarkus Reichl i2c-scl-falling-time-ns = <20>; 531f9010b0eSMarkus Reichl status = "okay"; 532f9010b0eSMarkus Reichl 533f9010b0eSMarkus Reichl fusb0: usb-typec@22 { 534f9010b0eSMarkus Reichl compatible = "fcs,fusb302"; 535f9010b0eSMarkus Reichl reg = <0x22>; 536f9010b0eSMarkus Reichl interrupt-parent = <&gpio1>; 537f9010b0eSMarkus Reichl interrupts = <2 IRQ_TYPE_LEVEL_LOW>; 538f9010b0eSMarkus Reichl pinctrl-names = "default"; 539f9010b0eSMarkus Reichl pinctrl-0 = <&fusb0_int>; 540f9010b0eSMarkus Reichl vbus-supply = <&vcc_vbus_typec0>; 541f9010b0eSMarkus Reichl status = "okay"; 542f9010b0eSMarkus Reichl }; 5431fc61ed0SMarkus Reichl 5441fc61ed0SMarkus Reichl mp8859: regulator@66 { 5451fc61ed0SMarkus Reichl compatible = "mps,mp8859"; 5461fc61ed0SMarkus Reichl reg = <0x66>; 5471fc61ed0SMarkus Reichl dc_12v: mp8859_dcdc { 5481fc61ed0SMarkus Reichl regulator-name = "dc_12v"; 5491fc61ed0SMarkus Reichl regulator-min-microvolt = <12000000>; 5501fc61ed0SMarkus Reichl regulator-max-microvolt = <12000000>; 5511fc61ed0SMarkus Reichl regulator-always-on; 5521fc61ed0SMarkus Reichl regulator-boot-on; 5531fc61ed0SMarkus Reichl vin-supply = <&vcc_vbus_typec0>; 5541fc61ed0SMarkus Reichl 5551fc61ed0SMarkus Reichl regulator-state-mem { 5561fc61ed0SMarkus Reichl regulator-on-in-suspend; 5571fc61ed0SMarkus Reichl regulator-suspend-microvolt = <12000000>; 5581fc61ed0SMarkus Reichl }; 5591fc61ed0SMarkus Reichl }; 5601fc61ed0SMarkus Reichl }; 561f9010b0eSMarkus Reichl}; 562f9010b0eSMarkus Reichl 563f9010b0eSMarkus Reichl&i2s0 { 564f9010b0eSMarkus Reichl rockchip,playback-channels = <8>; 565f9010b0eSMarkus Reichl rockchip,capture-channels = <8>; 566f9010b0eSMarkus Reichl status = "okay"; 567f9010b0eSMarkus Reichl}; 568f9010b0eSMarkus Reichl 569f9010b0eSMarkus Reichl&i2s1 { 570f9010b0eSMarkus Reichl rockchip,playback-channels = <2>; 571f9010b0eSMarkus Reichl rockchip,capture-channels = <2>; 572f9010b0eSMarkus Reichl status = "okay"; 573f9010b0eSMarkus Reichl}; 574f9010b0eSMarkus Reichl 575f9010b0eSMarkus Reichl&i2s2 { 576f9010b0eSMarkus Reichl status = "okay"; 577f9010b0eSMarkus Reichl}; 578f9010b0eSMarkus Reichl 579f9010b0eSMarkus Reichl&io_domains { 580f9010b0eSMarkus Reichl audio-supply = <&vcca1v8_codec>; 581f9010b0eSMarkus Reichl bt656-supply = <&vcc_3v0>; 582f9010b0eSMarkus Reichl gpio1830-supply = <&vcc_3v0>; 583f9010b0eSMarkus Reichl sdmmc-supply = <&vcc_sdio>; 584f9010b0eSMarkus Reichl status = "okay"; 585f9010b0eSMarkus Reichl}; 586f9010b0eSMarkus Reichl 587f9010b0eSMarkus Reichl&pmu_io_domains { 588f9010b0eSMarkus Reichl pmu1830-supply = <&vcc_3v0>; 589f9010b0eSMarkus Reichl status = "okay"; 590f9010b0eSMarkus Reichl}; 591f9010b0eSMarkus Reichl 592f9010b0eSMarkus Reichl&pinctrl { 593f9010b0eSMarkus Reichl buttons { 594f9010b0eSMarkus Reichl pwr_key_l: pwr-key-l { 595f9010b0eSMarkus Reichl rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>; 596f9010b0eSMarkus Reichl }; 597f9010b0eSMarkus Reichl }; 598f9010b0eSMarkus Reichl 599f9010b0eSMarkus Reichl lcd-panel { 600f9010b0eSMarkus Reichl lcd_panel_reset: lcd-panel-reset { 601a308163aSMarkus Reichl rockchip,pins = <4 RK_PD5 RK_FUNC_GPIO &pcfg_pull_up>; 602f9010b0eSMarkus Reichl }; 603f9010b0eSMarkus Reichl }; 604f9010b0eSMarkus Reichl 605f9010b0eSMarkus Reichl leds { 6066dd5e12cSJohan Jonker diy_led_pin: diy-led-pin { 607f9010b0eSMarkus Reichl rockchip,pins = <0 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>; 608f9010b0eSMarkus Reichl }; 609f9010b0eSMarkus Reichl 6106dd5e12cSJohan Jonker work_led_pin: work-led-pin { 611f9010b0eSMarkus Reichl rockchip,pins = <2 RK_PD3 RK_FUNC_GPIO &pcfg_pull_none>; 612f9010b0eSMarkus Reichl }; 613f9010b0eSMarkus Reichl 6146dd5e12cSJohan Jonker yellow_led_pin: yellow-led-pin { 615f9010b0eSMarkus Reichl rockchip,pins = <0 RK_PA2 RK_FUNC_GPIO &pcfg_pull_none>; 616f9010b0eSMarkus Reichl }; 617f9010b0eSMarkus Reichl }; 618f9010b0eSMarkus Reichl 619f9010b0eSMarkus Reichl pmic { 6202bc65fefSJohan Jonker vsel1_pin: vsel1-pin { 621f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PC2 RK_FUNC_GPIO &pcfg_pull_down>; 622f9010b0eSMarkus Reichl }; 623f9010b0eSMarkus Reichl 6242bc65fefSJohan Jonker vsel2_pin: vsel2-pin { 625f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PB6 RK_FUNC_GPIO &pcfg_pull_down>; 626f9010b0eSMarkus Reichl }; 627f9010b0eSMarkus Reichl }; 628f9010b0eSMarkus Reichl 629f9010b0eSMarkus Reichl sdio-pwrseq { 630f9010b0eSMarkus Reichl wifi_enable_h: wifi-enable-h { 631f9010b0eSMarkus Reichl rockchip,pins = <0 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>; 632f9010b0eSMarkus Reichl }; 633f9010b0eSMarkus Reichl }; 634f9010b0eSMarkus Reichl 635140e816aSMarkus Reichl sdmmc { 636140e816aSMarkus Reichl vcc3v0_sd_en: vcc3v0-sd-en { 637140e816aSMarkus Reichl rockchip,pins = <4 RK_PD6 RK_FUNC_GPIO &pcfg_pull_none>; 638140e816aSMarkus Reichl }; 639140e816aSMarkus Reichl }; 640140e816aSMarkus Reichl 641f9010b0eSMarkus Reichl pmic { 642f9010b0eSMarkus Reichl pmic_int_l: pmic-int-l { 643f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PC5 RK_FUNC_GPIO &pcfg_pull_up>; 644f9010b0eSMarkus Reichl }; 645f9010b0eSMarkus Reichl }; 646f9010b0eSMarkus Reichl 647f9010b0eSMarkus Reichl usb2 { 648f9010b0eSMarkus Reichl vcc5v0_host_en: vcc5v0-host-en { 649f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>; 650f9010b0eSMarkus Reichl }; 651f9010b0eSMarkus Reichl 652f9010b0eSMarkus Reichl vcc_sys_en: vcc-sys-en { 653f9010b0eSMarkus Reichl rockchip,pins = <2 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>; 654f9010b0eSMarkus Reichl }; 655f9010b0eSMarkus Reichl 656f9010b0eSMarkus Reichl hub_rst: hub-rst { 657f9010b0eSMarkus Reichl rockchip,pins = <2 RK_PA4 RK_FUNC_GPIO &pcfg_output_high>; 658f9010b0eSMarkus Reichl }; 659f9010b0eSMarkus Reichl }; 660f9010b0eSMarkus Reichl 661f9010b0eSMarkus Reichl usb-typec { 662f9010b0eSMarkus Reichl vcc_vbus_typec1_en: vcc-vbus-typec1-en { 663f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>; 664f9010b0eSMarkus Reichl }; 665f9010b0eSMarkus Reichl }; 666f9010b0eSMarkus Reichl 667f9010b0eSMarkus Reichl fusb30x { 668f9010b0eSMarkus Reichl fusb0_int: fusb0-int { 669f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PA2 RK_FUNC_GPIO &pcfg_pull_up>; 670f9010b0eSMarkus Reichl }; 671f9010b0eSMarkus Reichl 672f9010b0eSMarkus Reichl fusb1_int: fusb1-int { 673f9010b0eSMarkus Reichl rockchip,pins = <1 RK_PA1 RK_FUNC_GPIO &pcfg_pull_up>; 674f9010b0eSMarkus Reichl }; 675f9010b0eSMarkus Reichl }; 676f9010b0eSMarkus Reichl}; 677f9010b0eSMarkus Reichl 678f9010b0eSMarkus Reichl&pwm0 { 679f9010b0eSMarkus Reichl status = "okay"; 680f9010b0eSMarkus Reichl}; 681f9010b0eSMarkus Reichl 682f9010b0eSMarkus Reichl&pwm2 { 683f9010b0eSMarkus Reichl status = "okay"; 684f9010b0eSMarkus Reichl}; 685f9010b0eSMarkus Reichl 686f9010b0eSMarkus Reichl&saradc { 687f9010b0eSMarkus Reichl vref-supply = <&vcca1v8_s3>; 688f9010b0eSMarkus Reichl status = "okay"; 689f9010b0eSMarkus Reichl}; 690f9010b0eSMarkus Reichl 691f9010b0eSMarkus Reichl&sdmmc { 692f9010b0eSMarkus Reichl bus-width = <4>; 693f9010b0eSMarkus Reichl cap-sd-highspeed; 694f9010b0eSMarkus Reichl cd-gpios = <&gpio0 RK_PA7 GPIO_ACTIVE_LOW>; 695f9010b0eSMarkus Reichl disable-wp; 696f9010b0eSMarkus Reichl max-frequency = <150000000>; 697f9010b0eSMarkus Reichl pinctrl-names = "default"; 698f9010b0eSMarkus Reichl pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_bus4>; 699140e816aSMarkus Reichl sd-uhs-sdr104; 700140e816aSMarkus Reichl vmmc-supply = <&vcc3v0_sd>; 701140e816aSMarkus Reichl vqmmc-supply = <&vcc_sdio>; 702f9010b0eSMarkus Reichl status = "okay"; 703f9010b0eSMarkus Reichl}; 704f9010b0eSMarkus Reichl 705f9010b0eSMarkus Reichl&sdhci { 706f9010b0eSMarkus Reichl bus-width = <8>; 707f9010b0eSMarkus Reichl non-removable; 708f9010b0eSMarkus Reichl status = "okay"; 709f9010b0eSMarkus Reichl}; 710f9010b0eSMarkus Reichl 711a43e2909SMarkus Reichl&spi1 { 712a43e2909SMarkus Reichl status = "okay"; 713a43e2909SMarkus Reichl 714a43e2909SMarkus Reichl flash@0 { 715a43e2909SMarkus Reichl compatible = "jedec,spi-nor"; 716a43e2909SMarkus Reichl reg = <0>; 717a43e2909SMarkus Reichl spi-max-frequency = <10000000>; 718a43e2909SMarkus Reichl }; 719a43e2909SMarkus Reichl}; 720a43e2909SMarkus Reichl 721f9010b0eSMarkus Reichl&tcphy0 { 722f9010b0eSMarkus Reichl status = "okay"; 723f9010b0eSMarkus Reichl}; 724f9010b0eSMarkus Reichl 725f9010b0eSMarkus Reichl&tcphy1 { 726f9010b0eSMarkus Reichl status = "okay"; 727f9010b0eSMarkus Reichl}; 728f9010b0eSMarkus Reichl 729f9010b0eSMarkus Reichl&tsadc { 730f9010b0eSMarkus Reichl /* tshut mode 0:CRU 1:GPIO */ 731f9010b0eSMarkus Reichl rockchip,hw-tshut-mode = <1>; 732f9010b0eSMarkus Reichl /* tshut polarity 0:LOW 1:HIGH */ 733f9010b0eSMarkus Reichl rockchip,hw-tshut-polarity = <1>; 734f9010b0eSMarkus Reichl status = "okay"; 735f9010b0eSMarkus Reichl}; 736f9010b0eSMarkus Reichl 737f9010b0eSMarkus Reichl&u2phy0 { 738f9010b0eSMarkus Reichl status = "okay"; 739f9010b0eSMarkus Reichl 740f9010b0eSMarkus Reichl u2phy0_otg: otg-port { 741f9010b0eSMarkus Reichl phy-supply = <&vcc_vbus_typec0>; 742f9010b0eSMarkus Reichl status = "okay"; 743f9010b0eSMarkus Reichl }; 744f9010b0eSMarkus Reichl 745f9010b0eSMarkus Reichl u2phy0_host: host-port { 746f9010b0eSMarkus Reichl phy-supply = <&vcc5v0_host>; 747f9010b0eSMarkus Reichl status = "okay"; 748f9010b0eSMarkus Reichl }; 749f9010b0eSMarkus Reichl}; 750f9010b0eSMarkus Reichl 751f9010b0eSMarkus Reichl&u2phy1 { 752f9010b0eSMarkus Reichl status = "okay"; 753f9010b0eSMarkus Reichl 754f9010b0eSMarkus Reichl u2phy1_otg: otg-port { 755f9010b0eSMarkus Reichl phy-supply = <&vcc_vbus_typec1>; 756f9010b0eSMarkus Reichl status = "okay"; 757f9010b0eSMarkus Reichl }; 758f9010b0eSMarkus Reichl 759f9010b0eSMarkus Reichl u2phy1_host: host-port { 760f9010b0eSMarkus Reichl phy-supply = <&vcc5v0_host>; 761f9010b0eSMarkus Reichl status = "okay"; 762f9010b0eSMarkus Reichl }; 763f9010b0eSMarkus Reichl}; 764f9010b0eSMarkus Reichl 765f9010b0eSMarkus Reichl&uart0 { 766f9010b0eSMarkus Reichl pinctrl-names = "default"; 767f9010b0eSMarkus Reichl pinctrl-0 = <&uart0_xfer &uart0_cts>; 768f9010b0eSMarkus Reichl status = "okay"; 769f9010b0eSMarkus Reichl}; 770f9010b0eSMarkus Reichl 771f9010b0eSMarkus Reichl&uart2 { 772f9010b0eSMarkus Reichl status = "okay"; 773f9010b0eSMarkus Reichl}; 774f9010b0eSMarkus Reichl 775f9010b0eSMarkus Reichl&usb_host0_ehci { 776f9010b0eSMarkus Reichl status = "okay"; 777f9010b0eSMarkus Reichl}; 778f9010b0eSMarkus Reichl 779f9010b0eSMarkus Reichl&usb_host0_ohci { 780f9010b0eSMarkus Reichl status = "okay"; 781f9010b0eSMarkus Reichl}; 782f9010b0eSMarkus Reichl 783f9010b0eSMarkus Reichl&usb_host1_ehci { 784f9010b0eSMarkus Reichl status = "okay"; 785f9010b0eSMarkus Reichl}; 786f9010b0eSMarkus Reichl 787f9010b0eSMarkus Reichl&usb_host1_ohci { 788f9010b0eSMarkus Reichl status = "okay"; 789f9010b0eSMarkus Reichl}; 790f9010b0eSMarkus Reichl 791f9010b0eSMarkus Reichl&usbdrd3_0 { 792f9010b0eSMarkus Reichl status = "okay"; 793f9010b0eSMarkus Reichl}; 794f9010b0eSMarkus Reichl 795f9010b0eSMarkus Reichl&usbdrd_dwc3_0 { 796f9010b0eSMarkus Reichl status = "okay"; 797f9010b0eSMarkus Reichl}; 798f9010b0eSMarkus Reichl 799f9010b0eSMarkus Reichl&usbdrd3_1 { 800f9010b0eSMarkus Reichl status = "okay"; 801f9010b0eSMarkus Reichl}; 802f9010b0eSMarkus Reichl 803f9010b0eSMarkus Reichl&usbdrd_dwc3_1 { 804f9010b0eSMarkus Reichl status = "okay"; 805f9010b0eSMarkus Reichl dr_mode = "host"; 806f9010b0eSMarkus Reichl}; 807f9010b0eSMarkus Reichl 808f9010b0eSMarkus Reichl&vopb { 809f9010b0eSMarkus Reichl status = "okay"; 810f9010b0eSMarkus Reichl}; 811f9010b0eSMarkus Reichl 812f9010b0eSMarkus Reichl&vopb_mmu { 813f9010b0eSMarkus Reichl status = "okay"; 814f9010b0eSMarkus Reichl}; 815f9010b0eSMarkus Reichl 816f9010b0eSMarkus Reichl&vopl { 817f9010b0eSMarkus Reichl status = "okay"; 818f9010b0eSMarkus Reichl}; 819f9010b0eSMarkus Reichl 820f9010b0eSMarkus Reichl&vopl_mmu { 821f9010b0eSMarkus Reichl status = "okay"; 822f9010b0eSMarkus Reichl}; 823