1*96cbdfddSJohn Clark// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2*96cbdfddSJohn Clark/* 3*96cbdfddSJohn Clark * Copyright (c) 2025 FriendlyElec Computer Tech. Co., Ltd. 4*96cbdfddSJohn Clark * Copyright (c) 2025 John Clark <inindev@gmail.com> 5*96cbdfddSJohn Clark */ 6*96cbdfddSJohn Clark 7*96cbdfddSJohn Clark/dts-v1/; 8*96cbdfddSJohn Clark 9*96cbdfddSJohn Clark#include <dt-bindings/gpio/gpio.h> 10*96cbdfddSJohn Clark#include <dt-bindings/input/input.h> 11*96cbdfddSJohn Clark#include <dt-bindings/leds/common.h> 12*96cbdfddSJohn Clark#include <dt-bindings/pinctrl/rockchip.h> 13*96cbdfddSJohn Clark#include <dt-bindings/pwm/pwm.h> 14*96cbdfddSJohn Clark#include <dt-bindings/soc/rockchip,vop2.h> 15*96cbdfddSJohn Clark#include <dt-bindings/usb/pd.h> 16*96cbdfddSJohn Clark#include "rk3576.dtsi" 17*96cbdfddSJohn Clark 18*96cbdfddSJohn Clark/ { 19*96cbdfddSJohn Clark model = "FriendlyElec NanoPi M5"; 20*96cbdfddSJohn Clark compatible = "friendlyarm,nanopi-m5", "rockchip,rk3576"; 21*96cbdfddSJohn Clark 22*96cbdfddSJohn Clark aliases { 23*96cbdfddSJohn Clark ethernet0 = &gmac0; 24*96cbdfddSJohn Clark ethernet1 = &gmac1; 25*96cbdfddSJohn Clark mmc0 = &sdmmc; 26*96cbdfddSJohn Clark }; 27*96cbdfddSJohn Clark 28*96cbdfddSJohn Clark chosen { 29*96cbdfddSJohn Clark stdout-path = "serial0:1500000n8"; 30*96cbdfddSJohn Clark }; 31*96cbdfddSJohn Clark 32*96cbdfddSJohn Clark hdmi-con { 33*96cbdfddSJohn Clark compatible = "hdmi-connector"; 34*96cbdfddSJohn Clark hdmi-pwr-supply = <&vcc5v_hdmi_tx>; 35*96cbdfddSJohn Clark type = "a"; 36*96cbdfddSJohn Clark 37*96cbdfddSJohn Clark port { 38*96cbdfddSJohn Clark hdmi_con_in: endpoint { 39*96cbdfddSJohn Clark remote-endpoint = <&hdmi_out_con>; 40*96cbdfddSJohn Clark }; 41*96cbdfddSJohn Clark }; 42*96cbdfddSJohn Clark }; 43*96cbdfddSJohn Clark 44*96cbdfddSJohn Clark keys { 45*96cbdfddSJohn Clark compatible = "gpio-keys"; 46*96cbdfddSJohn Clark 47*96cbdfddSJohn Clark usr_button: key-1 { 48*96cbdfddSJohn Clark debounce-interval = <50>; 49*96cbdfddSJohn Clark gpios = <&gpio1 RK_PA0 GPIO_ACTIVE_LOW>; 50*96cbdfddSJohn Clark label = "user"; 51*96cbdfddSJohn Clark linux,code = <BTN_1>; 52*96cbdfddSJohn Clark pinctrl-names = "default"; 53*96cbdfddSJohn Clark pinctrl-0 = <&usr_button_l>; 54*96cbdfddSJohn Clark wakeup-source; 55*96cbdfddSJohn Clark }; 56*96cbdfddSJohn Clark }; 57*96cbdfddSJohn Clark 58*96cbdfddSJohn Clark leds { 59*96cbdfddSJohn Clark compatible = "gpio-leds"; 60*96cbdfddSJohn Clark 61*96cbdfddSJohn Clark led_sys: led-0 { 62*96cbdfddSJohn Clark color = <LED_COLOR_ID_RED>; 63*96cbdfddSJohn Clark function = LED_FUNCTION_HEARTBEAT; 64*96cbdfddSJohn Clark gpios = <&gpio2 RK_PB3 GPIO_ACTIVE_HIGH>; 65*96cbdfddSJohn Clark label = "sys"; 66*96cbdfddSJohn Clark linux,default-trigger = "heartbeat"; 67*96cbdfddSJohn Clark pinctrl-names = "default"; 68*96cbdfddSJohn Clark pinctrl-0 = <&led_sys_h>; 69*96cbdfddSJohn Clark }; 70*96cbdfddSJohn Clark 71*96cbdfddSJohn Clark led1: led-1 { 72*96cbdfddSJohn Clark color = <LED_COLOR_ID_GREEN>; 73*96cbdfddSJohn Clark function = LED_FUNCTION_LAN; 74*96cbdfddSJohn Clark gpios = <&gpio4 RK_PC5 GPIO_ACTIVE_HIGH>; 75*96cbdfddSJohn Clark label = "led1"; 76*96cbdfddSJohn Clark linux,default-trigger = "netdev"; 77*96cbdfddSJohn Clark pinctrl-names = "default"; 78*96cbdfddSJohn Clark pinctrl-0 = <&led1_h>; 79*96cbdfddSJohn Clark }; 80*96cbdfddSJohn Clark 81*96cbdfddSJohn Clark led2: led-2 { 82*96cbdfddSJohn Clark color = <LED_COLOR_ID_GREEN>; 83*96cbdfddSJohn Clark function = LED_FUNCTION_LAN; 84*96cbdfddSJohn Clark gpios = <&gpio2 RK_PB0 GPIO_ACTIVE_HIGH>; 85*96cbdfddSJohn Clark label = "led2"; 86*96cbdfddSJohn Clark linux,default-trigger = "netdev"; 87*96cbdfddSJohn Clark pinctrl-names = "default"; 88*96cbdfddSJohn Clark pinctrl-0 = <&led2_h>; 89*96cbdfddSJohn Clark }; 90*96cbdfddSJohn Clark }; 91*96cbdfddSJohn Clark 92*96cbdfddSJohn Clark usb3_port2_5v: regulator-usb3-port2-5v { 93*96cbdfddSJohn Clark compatible = "regulator-fixed"; 94*96cbdfddSJohn Clark enable-active-high; 95*96cbdfddSJohn Clark gpios = <&gpio0 RK_PC7 GPIO_ACTIVE_HIGH>; 96*96cbdfddSJohn Clark pinctrl-names = "default"; 97*96cbdfddSJohn Clark pinctrl-0 = <&usb3_host_pwren_h>; 98*96cbdfddSJohn Clark regulator-min-microvolt = <5000000>; 99*96cbdfddSJohn Clark regulator-max-microvolt = <5000000>; 100*96cbdfddSJohn Clark regulator-name = "usb3_port2_5v"; 101*96cbdfddSJohn Clark vin-supply = <&vcc5v0_sys_s5>; 102*96cbdfddSJohn Clark }; 103*96cbdfddSJohn Clark 104*96cbdfddSJohn Clark vcc12v_dcin: regulator-vcc12v-dcin { 105*96cbdfddSJohn Clark compatible = "regulator-fixed"; 106*96cbdfddSJohn Clark regulator-always-on; 107*96cbdfddSJohn Clark regulator-boot-on; 108*96cbdfddSJohn Clark regulator-min-microvolt = <12000000>; 109*96cbdfddSJohn Clark regulator-max-microvolt = <12000000>; 110*96cbdfddSJohn Clark regulator-name = "vcc12v_dcin"; 111*96cbdfddSJohn Clark }; 112*96cbdfddSJohn Clark 113*96cbdfddSJohn Clark vcc3v3_m2_keym: regulator-vcc3v3-m2-keym { 114*96cbdfddSJohn Clark compatible = "regulator-fixed"; 115*96cbdfddSJohn Clark enable-active-high; 116*96cbdfddSJohn Clark gpios = <&gpio0 RK_PD3 GPIO_ACTIVE_HIGH>; 117*96cbdfddSJohn Clark pinctrl-names = "default"; 118*96cbdfddSJohn Clark pinctrl-0 = <&pcie0_pwren_h>; 119*96cbdfddSJohn Clark regulator-min-microvolt = <3300000>; 120*96cbdfddSJohn Clark regulator-max-microvolt = <3300000>; 121*96cbdfddSJohn Clark regulator-name = "vcc3v3_m2_keym"; 122*96cbdfddSJohn Clark vin-supply = <&vcc5v0_sys_s5>; 123*96cbdfddSJohn Clark }; 124*96cbdfddSJohn Clark 125*96cbdfddSJohn Clark vcc3v3_sd_s0: regulator-vcc3v3-sd-s0 { 126*96cbdfddSJohn Clark compatible = "regulator-fixed"; 127*96cbdfddSJohn Clark enable-active-high; 128*96cbdfddSJohn Clark gpios = <&gpio0 RK_PB6 GPIO_ACTIVE_HIGH>; 129*96cbdfddSJohn Clark pinctrl-names = "default"; 130*96cbdfddSJohn Clark pinctrl-0 = <&sdmmc0_pwren_h>; 131*96cbdfddSJohn Clark regulator-boot-on; 132*96cbdfddSJohn Clark regulator-min-microvolt = <3300000>; 133*96cbdfddSJohn Clark regulator-max-microvolt = <3300000>; 134*96cbdfddSJohn Clark regulator-name = "vcc3v3_sd_s0"; 135*96cbdfddSJohn Clark vin-supply = <&vcc_3v3_s3>; 136*96cbdfddSJohn Clark }; 137*96cbdfddSJohn Clark 138*96cbdfddSJohn Clark vcc5v0_sys_s5: regulator-vcc5v0-sys-s5 { 139*96cbdfddSJohn Clark compatible = "regulator-fixed"; 140*96cbdfddSJohn Clark regulator-always-on; 141*96cbdfddSJohn Clark regulator-boot-on; 142*96cbdfddSJohn Clark regulator-min-microvolt = <5000000>; 143*96cbdfddSJohn Clark regulator-max-microvolt = <5000000>; 144*96cbdfddSJohn Clark regulator-name = "vcc5v0_sys_s5"; 145*96cbdfddSJohn Clark vin-supply = <&vcc12v_dcin>; 146*96cbdfddSJohn Clark }; 147*96cbdfddSJohn Clark 148*96cbdfddSJohn Clark vcc5v0_usb_otg0: regulator-vcc5v0-usb-otg0 { 149*96cbdfddSJohn Clark compatible = "regulator-fixed"; 150*96cbdfddSJohn Clark enable-active-high; 151*96cbdfddSJohn Clark gpios = <&gpio0 RK_PD1 GPIO_ACTIVE_HIGH>; 152*96cbdfddSJohn Clark pinctrl-names = "default"; 153*96cbdfddSJohn Clark pinctrl-0 = <&usb_otg0_pwren_h>; 154*96cbdfddSJohn Clark regulator-min-microvolt = <5000000>; 155*96cbdfddSJohn Clark regulator-max-microvolt = <5000000>; 156*96cbdfddSJohn Clark regulator-name = "vcc5v0_usb_otg0"; 157*96cbdfddSJohn Clark vin-supply = <&vcc5v0_sys_s5>; 158*96cbdfddSJohn Clark }; 159*96cbdfddSJohn Clark 160*96cbdfddSJohn Clark vcc5v_hdmi_tx: regulator-vcc5v-hdmi-tx { 161*96cbdfddSJohn Clark compatible = "regulator-fixed"; 162*96cbdfddSJohn Clark regulator-always-on; 163*96cbdfddSJohn Clark regulator-min-microvolt = <5000000>; 164*96cbdfddSJohn Clark regulator-max-microvolt = <5000000>; 165*96cbdfddSJohn Clark regulator-name = "vcc5v_hdmi_tx"; 166*96cbdfddSJohn Clark vin-supply = <&vcc5v0_sys_s5>; 167*96cbdfddSJohn Clark }; 168*96cbdfddSJohn Clark 169*96cbdfddSJohn Clark vcc_1v1_nldo_s3: regulator-vcc-1v1-nldo-s3 { 170*96cbdfddSJohn Clark compatible = "regulator-fixed"; 171*96cbdfddSJohn Clark regulator-always-on; 172*96cbdfddSJohn Clark regulator-boot-on; 173*96cbdfddSJohn Clark regulator-min-microvolt = <1100000>; 174*96cbdfddSJohn Clark regulator-max-microvolt = <1100000>; 175*96cbdfddSJohn Clark regulator-name = "vcc_1v1_nldo_s3"; 176*96cbdfddSJohn Clark vin-supply = <&vcc5v0_sys_s5>; 177*96cbdfddSJohn Clark }; 178*96cbdfddSJohn Clark 179*96cbdfddSJohn Clark vcc_2v0_pldo_s3: regulator-vcc-2v0-pldo-s3 { 180*96cbdfddSJohn Clark compatible = "regulator-fixed"; 181*96cbdfddSJohn Clark regulator-always-on; 182*96cbdfddSJohn Clark regulator-boot-on; 183*96cbdfddSJohn Clark regulator-min-microvolt = <2000000>; 184*96cbdfddSJohn Clark regulator-max-microvolt = <2000000>; 185*96cbdfddSJohn Clark regulator-name = "vcc_2v0_pldo_s3"; 186*96cbdfddSJohn Clark vin-supply = <&vcc5v0_sys_s5>; 187*96cbdfddSJohn Clark }; 188*96cbdfddSJohn Clark 189*96cbdfddSJohn Clark vcc_3v3_s0: regulator-vcc-3v3-s0 { 190*96cbdfddSJohn Clark compatible = "regulator-fixed"; 191*96cbdfddSJohn Clark regulator-always-on; 192*96cbdfddSJohn Clark regulator-boot-on; 193*96cbdfddSJohn Clark regulator-min-microvolt = <3300000>; 194*96cbdfddSJohn Clark regulator-max-microvolt = <3300000>; 195*96cbdfddSJohn Clark regulator-name = "vcc_3v3_s0"; 196*96cbdfddSJohn Clark vin-supply = <&vcc_3v3_s3>; 197*96cbdfddSJohn Clark }; 198*96cbdfddSJohn Clark 199*96cbdfddSJohn Clark sound { 200*96cbdfddSJohn Clark compatible = "simple-audio-card"; 201*96cbdfddSJohn Clark pinctrl-names = "default"; 202*96cbdfddSJohn Clark pinctrl-0 = <&hp_det_l>; 203*96cbdfddSJohn Clark 204*96cbdfddSJohn Clark simple-audio-card,format = "i2s"; 205*96cbdfddSJohn Clark simple-audio-card,hp-det-gpios = <&gpio2 RK_PD6 GPIO_ACTIVE_LOW>; 206*96cbdfddSJohn Clark simple-audio-card,mclk-fs = <256>; 207*96cbdfddSJohn Clark simple-audio-card,name = "realtek,rt5616-codec"; 208*96cbdfddSJohn Clark 209*96cbdfddSJohn Clark simple-audio-card,routing = 210*96cbdfddSJohn Clark "Headphones", "HPOL", 211*96cbdfddSJohn Clark "Headphones", "HPOR", 212*96cbdfddSJohn Clark "IN1P", "Microphone Jack"; 213*96cbdfddSJohn Clark simple-audio-card,widgets = 214*96cbdfddSJohn Clark "Headphone", "Headphone Jack", 215*96cbdfddSJohn Clark "Microphone", "Microphone Jack"; 216*96cbdfddSJohn Clark 217*96cbdfddSJohn Clark simple-audio-card,codec { 218*96cbdfddSJohn Clark sound-dai = <&rt5616>; 219*96cbdfddSJohn Clark }; 220*96cbdfddSJohn Clark 221*96cbdfddSJohn Clark simple-audio-card,cpu { 222*96cbdfddSJohn Clark sound-dai = <&sai2>; 223*96cbdfddSJohn Clark }; 224*96cbdfddSJohn Clark }; 225*96cbdfddSJohn Clark}; 226*96cbdfddSJohn Clark 227*96cbdfddSJohn Clark&combphy0_ps { 228*96cbdfddSJohn Clark status = "okay"; 229*96cbdfddSJohn Clark}; 230*96cbdfddSJohn Clark 231*96cbdfddSJohn Clark&combphy1_psu { 232*96cbdfddSJohn Clark status = "okay"; 233*96cbdfddSJohn Clark}; 234*96cbdfddSJohn Clark 235*96cbdfddSJohn Clark&cpu_b0 { 236*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_big_s0>; 237*96cbdfddSJohn Clark}; 238*96cbdfddSJohn Clark 239*96cbdfddSJohn Clark&cpu_b1 { 240*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_big_s0>; 241*96cbdfddSJohn Clark}; 242*96cbdfddSJohn Clark 243*96cbdfddSJohn Clark&cpu_b2 { 244*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_big_s0>; 245*96cbdfddSJohn Clark}; 246*96cbdfddSJohn Clark 247*96cbdfddSJohn Clark&cpu_b3 { 248*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_big_s0>; 249*96cbdfddSJohn Clark}; 250*96cbdfddSJohn Clark 251*96cbdfddSJohn Clark&cpu_l0 { 252*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_lit_s0>; 253*96cbdfddSJohn Clark}; 254*96cbdfddSJohn Clark 255*96cbdfddSJohn Clark&cpu_l1 { 256*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_lit_s0>; 257*96cbdfddSJohn Clark}; 258*96cbdfddSJohn Clark 259*96cbdfddSJohn Clark&cpu_l2 { 260*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_lit_s0>; 261*96cbdfddSJohn Clark}; 262*96cbdfddSJohn Clark 263*96cbdfddSJohn Clark&cpu_l3 { 264*96cbdfddSJohn Clark cpu-supply = <&vdd_cpu_lit_s0>; 265*96cbdfddSJohn Clark}; 266*96cbdfddSJohn Clark 267*96cbdfddSJohn Clark&fspi1m1_pins { 268*96cbdfddSJohn Clark /* gpio1_d5, gpio1_c4-c7 (clk, d0-d4) are for spi nor flash */ 269*96cbdfddSJohn Clark /* gpio1_d0-d4 muxed to sai2 audio functions */ 270*96cbdfddSJohn Clark rockchip,pins = 271*96cbdfddSJohn Clark <1 RK_PD5 3 &pcfg_pull_none>, 272*96cbdfddSJohn Clark <1 RK_PC4 3 &pcfg_pull_none>, 273*96cbdfddSJohn Clark <1 RK_PC5 3 &pcfg_pull_none>, 274*96cbdfddSJohn Clark <1 RK_PC6 3 &pcfg_pull_none>, 275*96cbdfddSJohn Clark <1 RK_PC7 3 &pcfg_pull_none>; 276*96cbdfddSJohn Clark}; 277*96cbdfddSJohn Clark 278*96cbdfddSJohn Clark&gmac0 { 279*96cbdfddSJohn Clark clock_in_out = "output"; 280*96cbdfddSJohn Clark phy-handle = <&rgmii_phy0>; 281*96cbdfddSJohn Clark phy-mode = "rgmii-id"; 282*96cbdfddSJohn Clark phy-supply = <&vcc_3v3_s3>; 283*96cbdfddSJohn Clark pinctrl-names = "default"; 284*96cbdfddSJohn Clark pinctrl-0 = <ð0m0_miim>, 285*96cbdfddSJohn Clark <ð0m0_tx_bus2>, 286*96cbdfddSJohn Clark <ð0m0_rx_bus2>, 287*96cbdfddSJohn Clark <ð0m0_rgmii_clk>, 288*96cbdfddSJohn Clark <ð0m0_rgmii_bus>; 289*96cbdfddSJohn Clark status = "okay"; 290*96cbdfddSJohn Clark}; 291*96cbdfddSJohn Clark 292*96cbdfddSJohn Clark&gmac1 { 293*96cbdfddSJohn Clark clock_in_out = "output"; 294*96cbdfddSJohn Clark phy-handle = <&rgmii_phy1>; 295*96cbdfddSJohn Clark phy-mode = "rgmii-id"; 296*96cbdfddSJohn Clark phy-supply = <&vcc_3v3_s3>; 297*96cbdfddSJohn Clark pinctrl-names = "default"; 298*96cbdfddSJohn Clark pinctrl-0 = <ð1m0_miim>, 299*96cbdfddSJohn Clark <ð1m0_tx_bus2>, 300*96cbdfddSJohn Clark <ð1m0_rx_bus2>, 301*96cbdfddSJohn Clark <ð1m0_rgmii_clk>, 302*96cbdfddSJohn Clark <ð1m0_rgmii_bus>; 303*96cbdfddSJohn Clark status = "okay"; 304*96cbdfddSJohn Clark}; 305*96cbdfddSJohn Clark 306*96cbdfddSJohn Clark&gpu { 307*96cbdfddSJohn Clark mali-supply = <&vdd_gpu_s0>; 308*96cbdfddSJohn Clark status = "okay"; 309*96cbdfddSJohn Clark}; 310*96cbdfddSJohn Clark 311*96cbdfddSJohn Clark&hdmi { 312*96cbdfddSJohn Clark status = "okay"; 313*96cbdfddSJohn Clark}; 314*96cbdfddSJohn Clark 315*96cbdfddSJohn Clark&hdmi_in { 316*96cbdfddSJohn Clark hdmi_in_vp0: endpoint { 317*96cbdfddSJohn Clark remote-endpoint = <&vp0_out_hdmi>; 318*96cbdfddSJohn Clark }; 319*96cbdfddSJohn Clark}; 320*96cbdfddSJohn Clark 321*96cbdfddSJohn Clark&hdmi_out { 322*96cbdfddSJohn Clark hdmi_out_con: endpoint { 323*96cbdfddSJohn Clark remote-endpoint = <&hdmi_con_in>; 324*96cbdfddSJohn Clark }; 325*96cbdfddSJohn Clark}; 326*96cbdfddSJohn Clark 327*96cbdfddSJohn Clark&hdptxphy { 328*96cbdfddSJohn Clark status = "okay"; 329*96cbdfddSJohn Clark}; 330*96cbdfddSJohn Clark 331*96cbdfddSJohn Clark&i2c1 { 332*96cbdfddSJohn Clark status = "okay"; 333*96cbdfddSJohn Clark 334*96cbdfddSJohn Clark pmic@23 { 335*96cbdfddSJohn Clark compatible = "rockchip,rk806"; 336*96cbdfddSJohn Clark reg = <0x23>; 337*96cbdfddSJohn Clark #gpio-cells = <2>; 338*96cbdfddSJohn Clark gpio-controller; 339*96cbdfddSJohn Clark interrupt-parent = <&gpio0>; 340*96cbdfddSJohn Clark interrupts = <6 IRQ_TYPE_LEVEL_LOW>; 341*96cbdfddSJohn Clark pinctrl-names = "default"; 342*96cbdfddSJohn Clark pinctrl-0 = <&pmic_pins>, <&rk806_dvs1_null>, 343*96cbdfddSJohn Clark <&rk806_dvs2_null>, <&rk806_dvs3_null>; 344*96cbdfddSJohn Clark system-power-controller; 345*96cbdfddSJohn Clark 346*96cbdfddSJohn Clark vcc1-supply = <&vcc5v0_sys_s5>; 347*96cbdfddSJohn Clark vcc2-supply = <&vcc5v0_sys_s5>; 348*96cbdfddSJohn Clark vcc3-supply = <&vcc5v0_sys_s5>; 349*96cbdfddSJohn Clark vcc4-supply = <&vcc5v0_sys_s5>; 350*96cbdfddSJohn Clark vcc5-supply = <&vcc5v0_sys_s5>; 351*96cbdfddSJohn Clark vcc6-supply = <&vcc5v0_sys_s5>; 352*96cbdfddSJohn Clark vcc7-supply = <&vcc5v0_sys_s5>; 353*96cbdfddSJohn Clark vcc8-supply = <&vcc5v0_sys_s5>; 354*96cbdfddSJohn Clark vcc9-supply = <&vcc5v0_sys_s5>; 355*96cbdfddSJohn Clark vcc10-supply = <&vcc5v0_sys_s5>; 356*96cbdfddSJohn Clark vcc11-supply = <&vcc_2v0_pldo_s3>; 357*96cbdfddSJohn Clark vcc12-supply = <&vcc5v0_sys_s5>; 358*96cbdfddSJohn Clark vcc13-supply = <&vcc_1v1_nldo_s3>; 359*96cbdfddSJohn Clark vcc14-supply = <&vcc_1v1_nldo_s3>; 360*96cbdfddSJohn Clark vcca-supply = <&vcc5v0_sys_s5>; 361*96cbdfddSJohn Clark 362*96cbdfddSJohn Clark rk806_dvs1_null: dvs1-null-pins { 363*96cbdfddSJohn Clark pins = "gpio_pwrctrl1"; 364*96cbdfddSJohn Clark function = "pin_fun0"; 365*96cbdfddSJohn Clark }; 366*96cbdfddSJohn Clark 367*96cbdfddSJohn Clark rk806_dvs1_slp: dvs1-slp-pins { 368*96cbdfddSJohn Clark pins = "gpio_pwrctrl1"; 369*96cbdfddSJohn Clark function = "pin_fun1"; 370*96cbdfddSJohn Clark }; 371*96cbdfddSJohn Clark 372*96cbdfddSJohn Clark rk806_dvs1_pwrdn: dvs1-pwrdn-pins { 373*96cbdfddSJohn Clark pins = "gpio_pwrctrl1"; 374*96cbdfddSJohn Clark function = "pin_fun2"; 375*96cbdfddSJohn Clark }; 376*96cbdfddSJohn Clark 377*96cbdfddSJohn Clark rk806_dvs1_rst: dvs1-rst-pins { 378*96cbdfddSJohn Clark pins = "gpio_pwrctrl1"; 379*96cbdfddSJohn Clark function = "pin_fun3"; 380*96cbdfddSJohn Clark }; 381*96cbdfddSJohn Clark 382*96cbdfddSJohn Clark rk806_dvs2_null: dvs2-null-pins { 383*96cbdfddSJohn Clark pins = "gpio_pwrctrl2"; 384*96cbdfddSJohn Clark function = "pin_fun0"; 385*96cbdfddSJohn Clark }; 386*96cbdfddSJohn Clark 387*96cbdfddSJohn Clark rk806_dvs2_slp: dvs2-slp-pins { 388*96cbdfddSJohn Clark pins = "gpio_pwrctrl2"; 389*96cbdfddSJohn Clark function = "pin_fun1"; 390*96cbdfddSJohn Clark }; 391*96cbdfddSJohn Clark 392*96cbdfddSJohn Clark rk806_dvs2_pwrdn: dvs2-pwrdn-pins { 393*96cbdfddSJohn Clark pins = "gpio_pwrctrl2"; 394*96cbdfddSJohn Clark function = "pin_fun2"; 395*96cbdfddSJohn Clark }; 396*96cbdfddSJohn Clark 397*96cbdfddSJohn Clark rk806_dvs2_rst: dvs2-rst-pins { 398*96cbdfddSJohn Clark pins = "gpio_pwrctrl2"; 399*96cbdfddSJohn Clark function = "pin_fun3"; 400*96cbdfddSJohn Clark }; 401*96cbdfddSJohn Clark 402*96cbdfddSJohn Clark rk806_dvs2_dvs: dvs2-dvs-pins { 403*96cbdfddSJohn Clark pins = "gpio_pwrctrl2"; 404*96cbdfddSJohn Clark function = "pin_fun4"; 405*96cbdfddSJohn Clark }; 406*96cbdfddSJohn Clark 407*96cbdfddSJohn Clark rk806_dvs2_gpio: dvs2-gpio-pins { 408*96cbdfddSJohn Clark pins = "gpio_pwrctrl2"; 409*96cbdfddSJohn Clark function = "pin_fun5"; 410*96cbdfddSJohn Clark }; 411*96cbdfddSJohn Clark 412*96cbdfddSJohn Clark rk806_dvs3_null: dvs3-null-pins { 413*96cbdfddSJohn Clark pins = "gpio_pwrctrl3"; 414*96cbdfddSJohn Clark function = "pin_fun0"; 415*96cbdfddSJohn Clark }; 416*96cbdfddSJohn Clark 417*96cbdfddSJohn Clark rk806_dvs3_slp: dvs3-slp-pins { 418*96cbdfddSJohn Clark pins = "gpio_pwrctrl3"; 419*96cbdfddSJohn Clark function = "pin_fun1"; 420*96cbdfddSJohn Clark }; 421*96cbdfddSJohn Clark 422*96cbdfddSJohn Clark rk806_dvs3_pwrdn: dvs3-pwrdn-pins { 423*96cbdfddSJohn Clark pins = "gpio_pwrctrl3"; 424*96cbdfddSJohn Clark function = "pin_fun2"; 425*96cbdfddSJohn Clark }; 426*96cbdfddSJohn Clark 427*96cbdfddSJohn Clark rk806_dvs3_rst: dvs3-rst-pins { 428*96cbdfddSJohn Clark pins = "gpio_pwrctrl3"; 429*96cbdfddSJohn Clark function = "pin_fun3"; 430*96cbdfddSJohn Clark }; 431*96cbdfddSJohn Clark 432*96cbdfddSJohn Clark rk806_dvs3_dvs: dvs3-dvs-pins { 433*96cbdfddSJohn Clark pins = "gpio_pwrctrl3"; 434*96cbdfddSJohn Clark function = "pin_fun4"; 435*96cbdfddSJohn Clark }; 436*96cbdfddSJohn Clark 437*96cbdfddSJohn Clark rk806_dvs3_gpio: dvs3-gpio-pins { 438*96cbdfddSJohn Clark pins = "gpio_pwrctrl3"; 439*96cbdfddSJohn Clark function = "pin_fun5"; 440*96cbdfddSJohn Clark }; 441*96cbdfddSJohn Clark 442*96cbdfddSJohn Clark regulators { 443*96cbdfddSJohn Clark vdd_cpu_big_s0: dcdc-reg1 { 444*96cbdfddSJohn Clark regulator-always-on; 445*96cbdfddSJohn Clark regulator-boot-on; 446*96cbdfddSJohn Clark regulator-enable-ramp-delay = <400>; 447*96cbdfddSJohn Clark regulator-min-microvolt = <550000>; 448*96cbdfddSJohn Clark regulator-max-microvolt = <950000>; 449*96cbdfddSJohn Clark regulator-name = "vdd_cpu_big_s0"; 450*96cbdfddSJohn Clark regulator-ramp-delay = <12500>; 451*96cbdfddSJohn Clark 452*96cbdfddSJohn Clark regulator-state-mem { 453*96cbdfddSJohn Clark regulator-off-in-suspend; 454*96cbdfddSJohn Clark }; 455*96cbdfddSJohn Clark }; 456*96cbdfddSJohn Clark 457*96cbdfddSJohn Clark vdd_npu_s0: dcdc-reg2 { 458*96cbdfddSJohn Clark regulator-boot-on; 459*96cbdfddSJohn Clark regulator-enable-ramp-delay = <400>; 460*96cbdfddSJohn Clark regulator-min-microvolt = <550000>; 461*96cbdfddSJohn Clark regulator-max-microvolt = <950000>; 462*96cbdfddSJohn Clark regulator-name = "vdd_npu_s0"; 463*96cbdfddSJohn Clark regulator-ramp-delay = <12500>; 464*96cbdfddSJohn Clark 465*96cbdfddSJohn Clark regulator-state-mem { 466*96cbdfddSJohn Clark regulator-off-in-suspend; 467*96cbdfddSJohn Clark }; 468*96cbdfddSJohn Clark }; 469*96cbdfddSJohn Clark 470*96cbdfddSJohn Clark vdd_cpu_lit_s0: dcdc-reg3 { 471*96cbdfddSJohn Clark regulator-always-on; 472*96cbdfddSJohn Clark regulator-boot-on; 473*96cbdfddSJohn Clark regulator-min-microvolt = <550000>; 474*96cbdfddSJohn Clark regulator-max-microvolt = <950000>; 475*96cbdfddSJohn Clark regulator-name = "vdd_cpu_lit_s0"; 476*96cbdfddSJohn Clark regulator-ramp-delay = <12500>; 477*96cbdfddSJohn Clark 478*96cbdfddSJohn Clark regulator-state-mem { 479*96cbdfddSJohn Clark regulator-off-in-suspend; 480*96cbdfddSJohn Clark regulator-suspend-microvolt = <750000>; 481*96cbdfddSJohn Clark }; 482*96cbdfddSJohn Clark }; 483*96cbdfddSJohn Clark 484*96cbdfddSJohn Clark vcc_3v3_s3: dcdc-reg4 { 485*96cbdfddSJohn Clark regulator-always-on; 486*96cbdfddSJohn Clark regulator-boot-on; 487*96cbdfddSJohn Clark regulator-min-microvolt = <3300000>; 488*96cbdfddSJohn Clark regulator-max-microvolt = <3300000>; 489*96cbdfddSJohn Clark regulator-name = "vcc_3v3_s3"; 490*96cbdfddSJohn Clark 491*96cbdfddSJohn Clark regulator-state-mem { 492*96cbdfddSJohn Clark regulator-on-in-suspend; 493*96cbdfddSJohn Clark regulator-suspend-microvolt = <3300000>; 494*96cbdfddSJohn Clark }; 495*96cbdfddSJohn Clark }; 496*96cbdfddSJohn Clark 497*96cbdfddSJohn Clark vdd_gpu_s0: dcdc-reg5 { 498*96cbdfddSJohn Clark regulator-boot-on; 499*96cbdfddSJohn Clark regulator-enable-ramp-delay = <400>; 500*96cbdfddSJohn Clark regulator-min-microvolt = <550000>; 501*96cbdfddSJohn Clark regulator-max-microvolt = <900000>; 502*96cbdfddSJohn Clark regulator-name = "vdd_gpu_s0"; 503*96cbdfddSJohn Clark regulator-ramp-delay = <12500>; 504*96cbdfddSJohn Clark 505*96cbdfddSJohn Clark regulator-state-mem { 506*96cbdfddSJohn Clark regulator-off-in-suspend; 507*96cbdfddSJohn Clark regulator-suspend-microvolt = <850000>; 508*96cbdfddSJohn Clark }; 509*96cbdfddSJohn Clark }; 510*96cbdfddSJohn Clark 511*96cbdfddSJohn Clark vddq_ddr_s0: dcdc-reg6 { 512*96cbdfddSJohn Clark regulator-always-on; 513*96cbdfddSJohn Clark regulator-boot-on; 514*96cbdfddSJohn Clark regulator-name = "vddq_ddr_s0"; 515*96cbdfddSJohn Clark 516*96cbdfddSJohn Clark regulator-state-mem { 517*96cbdfddSJohn Clark regulator-off-in-suspend; 518*96cbdfddSJohn Clark }; 519*96cbdfddSJohn Clark }; 520*96cbdfddSJohn Clark 521*96cbdfddSJohn Clark vdd_logic_s0: dcdc-reg7 { 522*96cbdfddSJohn Clark regulator-always-on; 523*96cbdfddSJohn Clark regulator-boot-on; 524*96cbdfddSJohn Clark regulator-min-microvolt = <550000>; 525*96cbdfddSJohn Clark regulator-max-microvolt = <800000>; 526*96cbdfddSJohn Clark regulator-name = "vdd_logic_s0"; 527*96cbdfddSJohn Clark 528*96cbdfddSJohn Clark regulator-state-mem { 529*96cbdfddSJohn Clark regulator-off-in-suspend; 530*96cbdfddSJohn Clark }; 531*96cbdfddSJohn Clark }; 532*96cbdfddSJohn Clark 533*96cbdfddSJohn Clark vcc_1v8_s3: dcdc-reg8 { 534*96cbdfddSJohn Clark regulator-always-on; 535*96cbdfddSJohn Clark regulator-boot-on; 536*96cbdfddSJohn Clark regulator-min-microvolt = <1800000>; 537*96cbdfddSJohn Clark regulator-max-microvolt = <1800000>; 538*96cbdfddSJohn Clark regulator-name = "vcc_1v8_s3"; 539*96cbdfddSJohn Clark 540*96cbdfddSJohn Clark regulator-state-mem { 541*96cbdfddSJohn Clark regulator-on-in-suspend; 542*96cbdfddSJohn Clark regulator-suspend-microvolt = <1800000>; 543*96cbdfddSJohn Clark }; 544*96cbdfddSJohn Clark }; 545*96cbdfddSJohn Clark 546*96cbdfddSJohn Clark vdd2_ddr_s3: dcdc-reg9 { 547*96cbdfddSJohn Clark regulator-always-on; 548*96cbdfddSJohn Clark regulator-boot-on; 549*96cbdfddSJohn Clark regulator-name = "vdd2_ddr_s3"; 550*96cbdfddSJohn Clark 551*96cbdfddSJohn Clark regulator-state-mem { 552*96cbdfddSJohn Clark regulator-on-in-suspend; 553*96cbdfddSJohn Clark }; 554*96cbdfddSJohn Clark }; 555*96cbdfddSJohn Clark 556*96cbdfddSJohn Clark vdd_ddr_s0: dcdc-reg10 { 557*96cbdfddSJohn Clark regulator-always-on; 558*96cbdfddSJohn Clark regulator-boot-on; 559*96cbdfddSJohn Clark regulator-min-microvolt = <550000>; 560*96cbdfddSJohn Clark regulator-max-microvolt = <1200000>; 561*96cbdfddSJohn Clark regulator-name = "vdd_ddr_s0"; 562*96cbdfddSJohn Clark 563*96cbdfddSJohn Clark regulator-state-mem { 564*96cbdfddSJohn Clark regulator-off-in-suspend; 565*96cbdfddSJohn Clark }; 566*96cbdfddSJohn Clark }; 567*96cbdfddSJohn Clark 568*96cbdfddSJohn Clark vcca_1v8_s0: pldo-reg1 { 569*96cbdfddSJohn Clark regulator-always-on; 570*96cbdfddSJohn Clark regulator-boot-on; 571*96cbdfddSJohn Clark regulator-min-microvolt = <1800000>; 572*96cbdfddSJohn Clark regulator-max-microvolt = <1800000>; 573*96cbdfddSJohn Clark regulator-name = "vcca_1v8_s0"; 574*96cbdfddSJohn Clark 575*96cbdfddSJohn Clark regulator-state-mem { 576*96cbdfddSJohn Clark regulator-off-in-suspend; 577*96cbdfddSJohn Clark }; 578*96cbdfddSJohn Clark }; 579*96cbdfddSJohn Clark 580*96cbdfddSJohn Clark vcca1v8_pldo2_s0: pldo-reg2 { 581*96cbdfddSJohn Clark regulator-always-on; 582*96cbdfddSJohn Clark regulator-boot-on; 583*96cbdfddSJohn Clark regulator-min-microvolt = <1800000>; 584*96cbdfddSJohn Clark regulator-max-microvolt = <1800000>; 585*96cbdfddSJohn Clark regulator-name = "vcca1v8_pldo2_s0"; 586*96cbdfddSJohn Clark 587*96cbdfddSJohn Clark regulator-state-mem { 588*96cbdfddSJohn Clark regulator-off-in-suspend; 589*96cbdfddSJohn Clark }; 590*96cbdfddSJohn Clark }; 591*96cbdfddSJohn Clark 592*96cbdfddSJohn Clark vdda_1v2_s0: pldo-reg3 { 593*96cbdfddSJohn Clark regulator-always-on; 594*96cbdfddSJohn Clark regulator-boot-on; 595*96cbdfddSJohn Clark regulator-min-microvolt = <1200000>; 596*96cbdfddSJohn Clark regulator-max-microvolt = <1200000>; 597*96cbdfddSJohn Clark regulator-name = "vdda_1v2_s0"; 598*96cbdfddSJohn Clark 599*96cbdfddSJohn Clark regulator-state-mem { 600*96cbdfddSJohn Clark regulator-off-in-suspend; 601*96cbdfddSJohn Clark }; 602*96cbdfddSJohn Clark }; 603*96cbdfddSJohn Clark 604*96cbdfddSJohn Clark vcca_3v3_s0: pldo-reg4 { 605*96cbdfddSJohn Clark regulator-always-on; 606*96cbdfddSJohn Clark regulator-boot-on; 607*96cbdfddSJohn Clark regulator-min-microvolt = <3300000>; 608*96cbdfddSJohn Clark regulator-max-microvolt = <3300000>; 609*96cbdfddSJohn Clark regulator-name = "vcca_3v3_s0"; 610*96cbdfddSJohn Clark 611*96cbdfddSJohn Clark regulator-state-mem { 612*96cbdfddSJohn Clark regulator-off-in-suspend; 613*96cbdfddSJohn Clark }; 614*96cbdfddSJohn Clark }; 615*96cbdfddSJohn Clark 616*96cbdfddSJohn Clark vccio_sd_s0: pldo-reg5 { 617*96cbdfddSJohn Clark regulator-always-on; 618*96cbdfddSJohn Clark regulator-boot-on; 619*96cbdfddSJohn Clark regulator-min-microvolt = <1800000>; 620*96cbdfddSJohn Clark regulator-max-microvolt = <3300000>; 621*96cbdfddSJohn Clark regulator-name = "vccio_sd_s0"; 622*96cbdfddSJohn Clark 623*96cbdfddSJohn Clark regulator-state-mem { 624*96cbdfddSJohn Clark regulator-off-in-suspend; 625*96cbdfddSJohn Clark }; 626*96cbdfddSJohn Clark }; 627*96cbdfddSJohn Clark 628*96cbdfddSJohn Clark vcca1v8_pldo6_s3: pldo-reg6 { 629*96cbdfddSJohn Clark regulator-always-on; 630*96cbdfddSJohn Clark regulator-boot-on; 631*96cbdfddSJohn Clark regulator-min-microvolt = <1800000>; 632*96cbdfddSJohn Clark regulator-max-microvolt = <1800000>; 633*96cbdfddSJohn Clark regulator-name = "vcca1v8_pldo6_s3"; 634*96cbdfddSJohn Clark 635*96cbdfddSJohn Clark regulator-state-mem { 636*96cbdfddSJohn Clark regulator-on-in-suspend; 637*96cbdfddSJohn Clark regulator-suspend-microvolt = <1800000>; 638*96cbdfddSJohn Clark }; 639*96cbdfddSJohn Clark }; 640*96cbdfddSJohn Clark 641*96cbdfddSJohn Clark vdd_0v75_s3: nldo-reg1 { 642*96cbdfddSJohn Clark regulator-always-on; 643*96cbdfddSJohn Clark regulator-boot-on; 644*96cbdfddSJohn Clark regulator-min-microvolt = <750000>; 645*96cbdfddSJohn Clark regulator-max-microvolt = <750000>; 646*96cbdfddSJohn Clark regulator-name = "vdd_0v75_s3"; 647*96cbdfddSJohn Clark 648*96cbdfddSJohn Clark regulator-state-mem { 649*96cbdfddSJohn Clark regulator-on-in-suspend; 650*96cbdfddSJohn Clark regulator-suspend-microvolt = <750000>; 651*96cbdfddSJohn Clark }; 652*96cbdfddSJohn Clark }; 653*96cbdfddSJohn Clark 654*96cbdfddSJohn Clark vdda_ddr_pll_s0: nldo-reg2 { 655*96cbdfddSJohn Clark regulator-always-on; 656*96cbdfddSJohn Clark regulator-boot-on; 657*96cbdfddSJohn Clark regulator-min-microvolt = <850000>; 658*96cbdfddSJohn Clark regulator-max-microvolt = <850000>; 659*96cbdfddSJohn Clark regulator-name = "vdda_ddr_pll_s0"; 660*96cbdfddSJohn Clark 661*96cbdfddSJohn Clark regulator-state-mem { 662*96cbdfddSJohn Clark regulator-off-in-suspend; 663*96cbdfddSJohn Clark }; 664*96cbdfddSJohn Clark }; 665*96cbdfddSJohn Clark 666*96cbdfddSJohn Clark vdda0v75_hdmi_s0: nldo-reg3 { 667*96cbdfddSJohn Clark regulator-always-on; 668*96cbdfddSJohn Clark regulator-boot-on; 669*96cbdfddSJohn Clark regulator-min-microvolt = <837500>; 670*96cbdfddSJohn Clark regulator-max-microvolt = <837500>; 671*96cbdfddSJohn Clark regulator-name = "vdda0v75_hdmi_s0"; 672*96cbdfddSJohn Clark 673*96cbdfddSJohn Clark regulator-state-mem { 674*96cbdfddSJohn Clark regulator-off-in-suspend; 675*96cbdfddSJohn Clark }; 676*96cbdfddSJohn Clark }; 677*96cbdfddSJohn Clark 678*96cbdfddSJohn Clark vdda_0v85_s0: nldo-reg4 { 679*96cbdfddSJohn Clark regulator-always-on; 680*96cbdfddSJohn Clark regulator-boot-on; 681*96cbdfddSJohn Clark regulator-min-microvolt = <850000>; 682*96cbdfddSJohn Clark regulator-max-microvolt = <850000>; 683*96cbdfddSJohn Clark regulator-name = "vdda_0v85_s0"; 684*96cbdfddSJohn Clark 685*96cbdfddSJohn Clark regulator-state-mem { 686*96cbdfddSJohn Clark regulator-off-in-suspend; 687*96cbdfddSJohn Clark }; 688*96cbdfddSJohn Clark }; 689*96cbdfddSJohn Clark 690*96cbdfddSJohn Clark vdda_0v75_s0: nldo-reg5 { 691*96cbdfddSJohn Clark regulator-always-on; 692*96cbdfddSJohn Clark regulator-boot-on; 693*96cbdfddSJohn Clark regulator-min-microvolt = <750000>; 694*96cbdfddSJohn Clark regulator-max-microvolt = <750000>; 695*96cbdfddSJohn Clark regulator-name = "vdda_0v75_s0"; 696*96cbdfddSJohn Clark 697*96cbdfddSJohn Clark regulator-state-mem { 698*96cbdfddSJohn Clark regulator-off-in-suspend; 699*96cbdfddSJohn Clark }; 700*96cbdfddSJohn Clark }; 701*96cbdfddSJohn Clark }; 702*96cbdfddSJohn Clark }; 703*96cbdfddSJohn Clark}; 704*96cbdfddSJohn Clark 705*96cbdfddSJohn Clark&i2c2 { 706*96cbdfddSJohn Clark status = "okay"; 707*96cbdfddSJohn Clark 708*96cbdfddSJohn Clark hym8563: rtc@51 { 709*96cbdfddSJohn Clark compatible = "haoyu,hym8563"; 710*96cbdfddSJohn Clark reg = <0x51>; 711*96cbdfddSJohn Clark #clock-cells = <0>; 712*96cbdfddSJohn Clark clock-output-names = "hym8563"; 713*96cbdfddSJohn Clark interrupt-parent = <&gpio0>; 714*96cbdfddSJohn Clark interrupts = <RK_PA5 IRQ_TYPE_LEVEL_LOW>; 715*96cbdfddSJohn Clark pinctrl-names = "default"; 716*96cbdfddSJohn Clark pinctrl-0 = <&hym8563_int>; 717*96cbdfddSJohn Clark wakeup-source; 718*96cbdfddSJohn Clark }; 719*96cbdfddSJohn Clark}; 720*96cbdfddSJohn Clark 721*96cbdfddSJohn Clark&i2c5 { 722*96cbdfddSJohn Clark clock-frequency = <200000>; 723*96cbdfddSJohn Clark pinctrl-names = "default"; 724*96cbdfddSJohn Clark pinctrl-0 = <&i2c5m3_xfer>; 725*96cbdfddSJohn Clark status = "okay"; 726*96cbdfddSJohn Clark 727*96cbdfddSJohn Clark rt5616: audio-codec@1b { 728*96cbdfddSJohn Clark compatible = "realtek,rt5616"; 729*96cbdfddSJohn Clark reg = <0x1b>; 730*96cbdfddSJohn Clark assigned-clocks = <&cru CLK_SAI2_MCLKOUT>; 731*96cbdfddSJohn Clark assigned-clock-rates = <12288000>; 732*96cbdfddSJohn Clark clocks = <&cru CLK_SAI2_MCLKOUT>; 733*96cbdfddSJohn Clark clock-names = "mclk"; 734*96cbdfddSJohn Clark #sound-dai-cells = <0>; 735*96cbdfddSJohn Clark }; 736*96cbdfddSJohn Clark}; 737*96cbdfddSJohn Clark 738*96cbdfddSJohn Clark&mdio0 { 739*96cbdfddSJohn Clark rgmii_phy0: phy@1 { 740*96cbdfddSJohn Clark compatible = "ethernet-phy-ieee802.3-c22"; 741*96cbdfddSJohn Clark reg = <0x1>; 742*96cbdfddSJohn Clark clocks = <&cru REFCLKO25M_GMAC0_OUT>; 743*96cbdfddSJohn Clark interrupt-parent = <&gpio2>; 744*96cbdfddSJohn Clark interrupts = <RK_PB1 IRQ_TYPE_LEVEL_LOW>; 745*96cbdfddSJohn Clark pinctrl-names = "default"; 746*96cbdfddSJohn Clark pinctrl-0 = <&gmac0_int>, <&gmac0_rst>; 747*96cbdfddSJohn Clark reset-assert-us = <20000>; 748*96cbdfddSJohn Clark reset-deassert-us = <100000>; 749*96cbdfddSJohn Clark reset-gpios = <&gpio2 RK_PB5 GPIO_ACTIVE_LOW>; 750*96cbdfddSJohn Clark }; 751*96cbdfddSJohn Clark}; 752*96cbdfddSJohn Clark 753*96cbdfddSJohn Clark&mdio1 { 754*96cbdfddSJohn Clark rgmii_phy1: phy@1 { 755*96cbdfddSJohn Clark compatible = "ethernet-phy-ieee802.3-c22"; 756*96cbdfddSJohn Clark reg = <0x1>; 757*96cbdfddSJohn Clark clocks = <&cru REFCLKO25M_GMAC1_OUT>; 758*96cbdfddSJohn Clark interrupt-parent = <&gpio3>; 759*96cbdfddSJohn Clark interrupts = <RK_PA2 IRQ_TYPE_LEVEL_LOW>; 760*96cbdfddSJohn Clark pinctrl-names = "default"; 761*96cbdfddSJohn Clark pinctrl-0 = <&gmac1_int>, <&gmac1_rst>; 762*96cbdfddSJohn Clark reset-assert-us = <20000>; 763*96cbdfddSJohn Clark reset-deassert-us = <100000>; 764*96cbdfddSJohn Clark reset-gpios = <&gpio3 RK_PA3 GPIO_ACTIVE_LOW>; 765*96cbdfddSJohn Clark }; 766*96cbdfddSJohn Clark}; 767*96cbdfddSJohn Clark 768*96cbdfddSJohn Clark&pcie0 { 769*96cbdfddSJohn Clark pinctrl-names = "default"; 770*96cbdfddSJohn Clark pinctrl-0 = <&pcie0_perstn>; 771*96cbdfddSJohn Clark reset-gpios = <&gpio2 RK_PB4 GPIO_ACTIVE_HIGH>; 772*96cbdfddSJohn Clark vpcie3v3-supply = <&vcc3v3_m2_keym>; 773*96cbdfddSJohn Clark status = "okay"; 774*96cbdfddSJohn Clark}; 775*96cbdfddSJohn Clark 776*96cbdfddSJohn Clark&pinctrl { 777*96cbdfddSJohn Clark gmac { 778*96cbdfddSJohn Clark gmac0_int: gmac0-int { 779*96cbdfddSJohn Clark rockchip,pins = <2 RK_PB1 RK_FUNC_GPIO &pcfg_pull_up>; 780*96cbdfddSJohn Clark }; 781*96cbdfddSJohn Clark gmac0_rst: gmac0-rst { 782*96cbdfddSJohn Clark rockchip,pins = <2 RK_PB5 RK_FUNC_GPIO &pcfg_pull_none>; 783*96cbdfddSJohn Clark }; 784*96cbdfddSJohn Clark gmac1_int: gmac1-int { 785*96cbdfddSJohn Clark rockchip,pins = <3 RK_PA2 RK_FUNC_GPIO &pcfg_pull_up>; 786*96cbdfddSJohn Clark }; 787*96cbdfddSJohn Clark gmac1_rst: gmac1-rst { 788*96cbdfddSJohn Clark rockchip,pins = <3 RK_PA3 RK_FUNC_GPIO &pcfg_pull_none>; 789*96cbdfddSJohn Clark }; 790*96cbdfddSJohn Clark }; 791*96cbdfddSJohn Clark 792*96cbdfddSJohn Clark hym8563 { 793*96cbdfddSJohn Clark hym8563_int: hym8563-int { 794*96cbdfddSJohn Clark rockchip,pins = <0 RK_PA5 RK_FUNC_GPIO &pcfg_pull_up>; 795*96cbdfddSJohn Clark }; 796*96cbdfddSJohn Clark }; 797*96cbdfddSJohn Clark 798*96cbdfddSJohn Clark keys { 799*96cbdfddSJohn Clark usr_button_l: usr-button-l { 800*96cbdfddSJohn Clark rockchip,pins = <1 RK_PA0 RK_FUNC_GPIO &pcfg_pull_up>; 801*96cbdfddSJohn Clark }; 802*96cbdfddSJohn Clark }; 803*96cbdfddSJohn Clark 804*96cbdfddSJohn Clark leds { 805*96cbdfddSJohn Clark led_sys_h: led-sys-h { 806*96cbdfddSJohn Clark rockchip,pins = <2 RK_PB3 RK_FUNC_GPIO &pcfg_pull_none>; 807*96cbdfddSJohn Clark }; 808*96cbdfddSJohn Clark led1_h: led1-h { 809*96cbdfddSJohn Clark rockchip,pins = <4 RK_PC5 RK_FUNC_GPIO &pcfg_pull_none>; 810*96cbdfddSJohn Clark }; 811*96cbdfddSJohn Clark led2_h: led2-h { 812*96cbdfddSJohn Clark rockchip,pins = <2 RK_PB0 RK_FUNC_GPIO &pcfg_pull_none>; 813*96cbdfddSJohn Clark }; 814*96cbdfddSJohn Clark }; 815*96cbdfddSJohn Clark 816*96cbdfddSJohn Clark pcie { 817*96cbdfddSJohn Clark pcie0_pwren_h: pcie0-pwren-h { 818*96cbdfddSJohn Clark rockchip,pins = <0 RK_PD3 RK_FUNC_GPIO &pcfg_pull_none>; 819*96cbdfddSJohn Clark }; 820*96cbdfddSJohn Clark pcie0_perstn: pcie0-perstn { 821*96cbdfddSJohn Clark rockchip,pins = <2 RK_PB4 RK_FUNC_GPIO &pcfg_pull_up>; 822*96cbdfddSJohn Clark }; 823*96cbdfddSJohn Clark }; 824*96cbdfddSJohn Clark 825*96cbdfddSJohn Clark sdmmc { 826*96cbdfddSJohn Clark sdmmc0_pwren_h: sdmmc0-pwren-h { 827*96cbdfddSJohn Clark rockchip,pins = <0 RK_PB6 RK_FUNC_GPIO &pcfg_pull_up>; 828*96cbdfddSJohn Clark }; 829*96cbdfddSJohn Clark }; 830*96cbdfddSJohn Clark 831*96cbdfddSJohn Clark sound { 832*96cbdfddSJohn Clark hp_det_l: hp-det-l { 833*96cbdfddSJohn Clark rockchip,pins = <2 RK_PD6 RK_FUNC_GPIO &pcfg_pull_none>; 834*96cbdfddSJohn Clark }; 835*96cbdfddSJohn Clark }; 836*96cbdfddSJohn Clark 837*96cbdfddSJohn Clark usb { 838*96cbdfddSJohn Clark usb3_host_pwren_h: usb3-host-pwren-h { 839*96cbdfddSJohn Clark rockchip,pins = <0 RK_PC7 RK_FUNC_GPIO &pcfg_pull_none>; 840*96cbdfddSJohn Clark }; 841*96cbdfddSJohn Clark usb_otg0_pwren_h: usb-otg0-pwren-h { 842*96cbdfddSJohn Clark rockchip,pins = <0 RK_PD1 RK_FUNC_GPIO &pcfg_pull_none>; 843*96cbdfddSJohn Clark }; 844*96cbdfddSJohn Clark }; 845*96cbdfddSJohn Clark}; 846*96cbdfddSJohn Clark 847*96cbdfddSJohn Clark&sai2 { 848*96cbdfddSJohn Clark status = "okay"; 849*96cbdfddSJohn Clark}; 850*96cbdfddSJohn Clark 851*96cbdfddSJohn Clark&saradc { 852*96cbdfddSJohn Clark vref-supply = <&vcca_1v8_s0>; 853*96cbdfddSJohn Clark status = "okay"; 854*96cbdfddSJohn Clark}; 855*96cbdfddSJohn Clark 856*96cbdfddSJohn Clark&sdmmc { 857*96cbdfddSJohn Clark bus-width = <4>; 858*96cbdfddSJohn Clark cap-mmc-highspeed; 859*96cbdfddSJohn Clark cap-sd-highspeed; 860*96cbdfddSJohn Clark disable-wp; 861*96cbdfddSJohn Clark no-mmc; 862*96cbdfddSJohn Clark no-sdio; 863*96cbdfddSJohn Clark pinctrl-names = "default"; 864*96cbdfddSJohn Clark pinctrl-0 = <&sdmmc0_clk>, <&sdmmc0_cmd>, <&sdmmc0_det>, <&sdmmc0_bus4>; 865*96cbdfddSJohn Clark sd-uhs-sdr104; 866*96cbdfddSJohn Clark vmmc-supply = <&vcc_3v3_s3>; 867*96cbdfddSJohn Clark vqmmc-supply = <&vcc3v3_sd_s0>; 868*96cbdfddSJohn Clark status = "okay"; 869*96cbdfddSJohn Clark}; 870*96cbdfddSJohn Clark 871*96cbdfddSJohn Clark&sfc1 { 872*96cbdfddSJohn Clark pinctrl-names = "default"; 873*96cbdfddSJohn Clark pinctrl-0 = <&fspi1m1_csn0>, <&fspi1m1_pins>; 874*96cbdfddSJohn Clark status = "okay"; 875*96cbdfddSJohn Clark 876*96cbdfddSJohn Clark flash@0 { 877*96cbdfddSJohn Clark compatible = "jedec,spi-nor"; 878*96cbdfddSJohn Clark reg = <0>; 879*96cbdfddSJohn Clark m25p,fast-read; 880*96cbdfddSJohn Clark spi-max-frequency = <50000000>; 881*96cbdfddSJohn Clark spi-rx-bus-width = <4>; 882*96cbdfddSJohn Clark spi-tx-bus-width = <1>; 883*96cbdfddSJohn Clark vcc-supply = <&vcc_1v8_s3>; 884*96cbdfddSJohn Clark }; 885*96cbdfddSJohn Clark}; 886*96cbdfddSJohn Clark 887*96cbdfddSJohn Clark&u2phy0 { 888*96cbdfddSJohn Clark status = "okay"; 889*96cbdfddSJohn Clark}; 890*96cbdfddSJohn Clark 891*96cbdfddSJohn Clark&u2phy0_otg { 892*96cbdfddSJohn Clark phy-supply = <&vcc5v0_usb_otg0>; 893*96cbdfddSJohn Clark status = "okay"; 894*96cbdfddSJohn Clark}; 895*96cbdfddSJohn Clark 896*96cbdfddSJohn Clark&u2phy1 { 897*96cbdfddSJohn Clark status = "okay"; 898*96cbdfddSJohn Clark}; 899*96cbdfddSJohn Clark 900*96cbdfddSJohn Clark&u2phy1_otg { 901*96cbdfddSJohn Clark phy-supply = <&usb3_port2_5v>; 902*96cbdfddSJohn Clark status = "okay"; 903*96cbdfddSJohn Clark}; 904*96cbdfddSJohn Clark 905*96cbdfddSJohn Clark&uart0 { 906*96cbdfddSJohn Clark status = "okay"; 907*96cbdfddSJohn Clark}; 908*96cbdfddSJohn Clark 909*96cbdfddSJohn Clark&usbdp_phy { 910*96cbdfddSJohn Clark status = "okay"; 911*96cbdfddSJohn Clark}; 912*96cbdfddSJohn Clark 913*96cbdfddSJohn Clark&usb_drd0_dwc3 { 914*96cbdfddSJohn Clark dr_mode = "otg"; 915*96cbdfddSJohn Clark extcon = <&u2phy0>; 916*96cbdfddSJohn Clark status = "okay"; 917*96cbdfddSJohn Clark}; 918*96cbdfddSJohn Clark 919*96cbdfddSJohn Clark&usb_drd1_dwc3 { 920*96cbdfddSJohn Clark dr_mode = "host"; 921*96cbdfddSJohn Clark status = "okay"; 922*96cbdfddSJohn Clark}; 923*96cbdfddSJohn Clark 924*96cbdfddSJohn Clark&vop { 925*96cbdfddSJohn Clark status = "okay"; 926*96cbdfddSJohn Clark}; 927*96cbdfddSJohn Clark 928*96cbdfddSJohn Clark&vop_mmu { 929*96cbdfddSJohn Clark status = "okay"; 930*96cbdfddSJohn Clark}; 931*96cbdfddSJohn Clark 932*96cbdfddSJohn Clark&vp0 { 933*96cbdfddSJohn Clark vp0_out_hdmi: endpoint@ROCKCHIP_VOP2_EP_HDMI0 { 934*96cbdfddSJohn Clark reg = <ROCKCHIP_VOP2_EP_HDMI0>; 935*96cbdfddSJohn Clark remote-endpoint = <&hdmi_in_vp0>; 936*96cbdfddSJohn Clark }; 937*96cbdfddSJohn Clark}; 938*96cbdfddSJohn Clark 939*96cbdfddSJohn Clark&wdt { 940*96cbdfddSJohn Clark status = "okay"; 941*96cbdfddSJohn Clark}; 942