1*4882a593Smuzhiyun/* 2*4882a593Smuzhiyun * Copyright (c) 2017 Fuzhou Rockchip Electronics Co., Ltd. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * SPDX-License-Identifier: GPL-2.0+ 5*4882a593Smuzhiyun */ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun#include <dt-bindings/gpio/gpio.h> 8*4882a593Smuzhiyun#include <dt-bindings/interrupt-controller/irq.h> 9*4882a593Smuzhiyun#include <dt-bindings/interrupt-controller/arm-gic.h> 10*4882a593Smuzhiyun#include <dt-bindings/pinctrl/rockchip.h> 11*4882a593Smuzhiyun#include <dt-bindings/clock/rk3228-cru.h> 12*4882a593Smuzhiyun#include <dt-bindings/thermal/thermal.h> 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun/ { 15*4882a593Smuzhiyun #address-cells = <1>; 16*4882a593Smuzhiyun #size-cells = <1>; 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun interrupt-parent = <&gic>; 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun aliases { 21*4882a593Smuzhiyun serial0 = &uart0; 22*4882a593Smuzhiyun serial1 = &uart1; 23*4882a593Smuzhiyun serial2 = &uart2; 24*4882a593Smuzhiyun mmc0 = &emmc; 25*4882a593Smuzhiyun mmc1 = &sdmmc; 26*4882a593Smuzhiyun }; 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun cpus { 29*4882a593Smuzhiyun #address-cells = <1>; 30*4882a593Smuzhiyun #size-cells = <0>; 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun cpu0: cpu@f00 { 33*4882a593Smuzhiyun device_type = "cpu"; 34*4882a593Smuzhiyun compatible = "arm,cortex-a7"; 35*4882a593Smuzhiyun reg = <0xf00>; 36*4882a593Smuzhiyun resets = <&cru SRST_CORE0>; 37*4882a593Smuzhiyun operating-points = < 38*4882a593Smuzhiyun /* KHz uV */ 39*4882a593Smuzhiyun 816000 1000000 40*4882a593Smuzhiyun >; 41*4882a593Smuzhiyun #cooling-cells = <2>; /* min followed by max */ 42*4882a593Smuzhiyun clock-latency = <40000>; 43*4882a593Smuzhiyun clocks = <&cru ARMCLK>; 44*4882a593Smuzhiyun }; 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun cpu1: cpu@f01 { 47*4882a593Smuzhiyun device_type = "cpu"; 48*4882a593Smuzhiyun compatible = "arm,cortex-a7"; 49*4882a593Smuzhiyun reg = <0xf01>; 50*4882a593Smuzhiyun resets = <&cru SRST_CORE1>; 51*4882a593Smuzhiyun }; 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun cpu2: cpu@f02 { 54*4882a593Smuzhiyun device_type = "cpu"; 55*4882a593Smuzhiyun compatible = "arm,cortex-a7"; 56*4882a593Smuzhiyun reg = <0xf02>; 57*4882a593Smuzhiyun resets = <&cru SRST_CORE2>; 58*4882a593Smuzhiyun }; 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun cpu3: cpu@f03 { 61*4882a593Smuzhiyun device_type = "cpu"; 62*4882a593Smuzhiyun compatible = "arm,cortex-a7"; 63*4882a593Smuzhiyun reg = <0xf03>; 64*4882a593Smuzhiyun resets = <&cru SRST_CORE3>; 65*4882a593Smuzhiyun }; 66*4882a593Smuzhiyun }; 67*4882a593Smuzhiyun 68*4882a593Smuzhiyun amba { 69*4882a593Smuzhiyun compatible = "simple-bus"; 70*4882a593Smuzhiyun #address-cells = <1>; 71*4882a593Smuzhiyun #size-cells = <1>; 72*4882a593Smuzhiyun ranges; 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun pdma: pdma@110f0000 { 75*4882a593Smuzhiyun compatible = "arm,pl330", "arm,primecell"; 76*4882a593Smuzhiyun reg = <0x110f0000 0x4000>; 77*4882a593Smuzhiyun interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>, 78*4882a593Smuzhiyun <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>; 79*4882a593Smuzhiyun #dma-cells = <1>; 80*4882a593Smuzhiyun clocks = <&cru ACLK_DMAC>; 81*4882a593Smuzhiyun clock-names = "apb_pclk"; 82*4882a593Smuzhiyun }; 83*4882a593Smuzhiyun }; 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun arm-pmu { 86*4882a593Smuzhiyun compatible = "arm,cortex-a7-pmu"; 87*4882a593Smuzhiyun interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>, 88*4882a593Smuzhiyun <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>, 89*4882a593Smuzhiyun <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>, 90*4882a593Smuzhiyun <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>; 91*4882a593Smuzhiyun interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>; 92*4882a593Smuzhiyun }; 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun memory@60000000 { 95*4882a593Smuzhiyun device_type = "memory"; 96*4882a593Smuzhiyun reg = <0x60000000 0x40000000>; 97*4882a593Smuzhiyun }; 98*4882a593Smuzhiyun 99*4882a593Smuzhiyun psci: psci { 100*4882a593Smuzhiyun compatible = "arm,psci-1.0"; 101*4882a593Smuzhiyun method = "smc"; 102*4882a593Smuzhiyun }; 103*4882a593Smuzhiyun 104*4882a593Smuzhiyun timer { 105*4882a593Smuzhiyun compatible = "arm,armv7-timer"; 106*4882a593Smuzhiyun arm,cpu-registers-not-fw-configured; 107*4882a593Smuzhiyun interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>, 108*4882a593Smuzhiyun <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>, 109*4882a593Smuzhiyun <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>, 110*4882a593Smuzhiyun <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>; 111*4882a593Smuzhiyun clock-frequency = <24000000>; 112*4882a593Smuzhiyun }; 113*4882a593Smuzhiyun 114*4882a593Smuzhiyun xin24m: oscillator { 115*4882a593Smuzhiyun compatible = "fixed-clock"; 116*4882a593Smuzhiyun clock-frequency = <24000000>; 117*4882a593Smuzhiyun clock-output-names = "xin24m"; 118*4882a593Smuzhiyun #clock-cells = <0>; 119*4882a593Smuzhiyun }; 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun bus_intmem@10080000 { 122*4882a593Smuzhiyun compatible = "mmio-sram"; 123*4882a593Smuzhiyun reg = <0x10080000 0x9000>; 124*4882a593Smuzhiyun #address-cells = <1>; 125*4882a593Smuzhiyun #size-cells = <1>; 126*4882a593Smuzhiyun ranges = <0 0x10080000 0x9000>; 127*4882a593Smuzhiyun smp-sram@0 { 128*4882a593Smuzhiyun compatible = "rockchip,rk322x-smp-sram"; 129*4882a593Smuzhiyun reg = <0x00 0x10>; 130*4882a593Smuzhiyun }; 131*4882a593Smuzhiyun ddr_sram: ddr-sram@1000 { 132*4882a593Smuzhiyun compatible = "rockchip,rk322x-ddr-sram"; 133*4882a593Smuzhiyun reg = <0x1000 0x8000>; 134*4882a593Smuzhiyun }; 135*4882a593Smuzhiyun }; 136*4882a593Smuzhiyun 137*4882a593Smuzhiyun crypto: crypto@100a0000 { 138*4882a593Smuzhiyun compatible = "rockchip,rk322x-crypto"; 139*4882a593Smuzhiyun reg = <0x100a0000 0x10000>; 140*4882a593Smuzhiyun clock-names = "sclk_crypto"; 141*4882a593Smuzhiyun clocks = <&cru SCLK_CRYPTO>; 142*4882a593Smuzhiyun status = "disabled"; 143*4882a593Smuzhiyun }; 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun i2s1: i2s1@100b0000 { 146*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2s", "rockchip,rk3066-i2s"; 147*4882a593Smuzhiyun reg = <0x100b0000 0x4000>; 148*4882a593Smuzhiyun interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>; 149*4882a593Smuzhiyun #address-cells = <1>; 150*4882a593Smuzhiyun #size-cells = <0>; 151*4882a593Smuzhiyun clock-names = "i2s_clk", "i2s_hclk"; 152*4882a593Smuzhiyun clocks = <&cru SCLK_I2S1>, <&cru HCLK_I2S1_8CH>; 153*4882a593Smuzhiyun dmas = <&pdma 14>, <&pdma 15>; 154*4882a593Smuzhiyun dma-names = "tx", "rx"; 155*4882a593Smuzhiyun pinctrl-names = "default"; 156*4882a593Smuzhiyun pinctrl-0 = <&i2s1_bus>; 157*4882a593Smuzhiyun status = "disabled"; 158*4882a593Smuzhiyun }; 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun i2s0: i2s0@100c0000 { 161*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2s", "rockchip,rk3066-i2s"; 162*4882a593Smuzhiyun reg = <0x100c0000 0x4000>; 163*4882a593Smuzhiyun interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>; 164*4882a593Smuzhiyun #address-cells = <1>; 165*4882a593Smuzhiyun #size-cells = <0>; 166*4882a593Smuzhiyun clock-names = "i2s_clk", "i2s_hclk"; 167*4882a593Smuzhiyun clocks = <&cru SCLK_I2S0>, <&cru HCLK_I2S0_8CH>; 168*4882a593Smuzhiyun dmas = <&pdma 11>, <&pdma 12>; 169*4882a593Smuzhiyun dma-names = "tx", "rx"; 170*4882a593Smuzhiyun status = "disabled"; 171*4882a593Smuzhiyun }; 172*4882a593Smuzhiyun 173*4882a593Smuzhiyun i2s2: i2s2@100e0000 { 174*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2s", "rockchip,rk3066-i2s"; 175*4882a593Smuzhiyun reg = <0x100e0000 0x4000>; 176*4882a593Smuzhiyun interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>; 177*4882a593Smuzhiyun #address-cells = <1>; 178*4882a593Smuzhiyun #size-cells = <0>; 179*4882a593Smuzhiyun clock-names = "i2s_clk", "i2s_hclk"; 180*4882a593Smuzhiyun clocks = <&cru SCLK_I2S2>, <&cru HCLK_I2S2_2CH>; 181*4882a593Smuzhiyun dmas = <&pdma 0>, <&pdma 1>; 182*4882a593Smuzhiyun dma-names = "tx", "rx"; 183*4882a593Smuzhiyun status = "disabled"; 184*4882a593Smuzhiyun }; 185*4882a593Smuzhiyun 186*4882a593Smuzhiyun grf: syscon@11000000 { 187*4882a593Smuzhiyun compatible = "rockchip,rk3228-grf", "syscon"; 188*4882a593Smuzhiyun reg = <0x11000000 0x1000>; 189*4882a593Smuzhiyun #address-cells = <1>; 190*4882a593Smuzhiyun #size-cells = <1>; 191*4882a593Smuzhiyun 192*4882a593Smuzhiyun u2phy0: usb2-phy@760 { 193*4882a593Smuzhiyun compatible = "rockchip,rk322x-usb2phy"; 194*4882a593Smuzhiyun reg = <0x0760 0x0c>; 195*4882a593Smuzhiyun status = "disabled"; 196*4882a593Smuzhiyun 197*4882a593Smuzhiyun u2phy0_otg: otg-port { 198*4882a593Smuzhiyun #phy-cells = <0>; 199*4882a593Smuzhiyun interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>, 200*4882a593Smuzhiyun <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>, 201*4882a593Smuzhiyun <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>; 202*4882a593Smuzhiyun interrupt-names = "otg-bvalid", "otg-id", 203*4882a593Smuzhiyun "linestate"; 204*4882a593Smuzhiyun status = "disabled"; 205*4882a593Smuzhiyun }; 206*4882a593Smuzhiyun 207*4882a593Smuzhiyun u2phy0_host: host-port { 208*4882a593Smuzhiyun #phy-cells = <0>; 209*4882a593Smuzhiyun interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>; 210*4882a593Smuzhiyun interrupt-names = "linestate"; 211*4882a593Smuzhiyun status = "disabled"; 212*4882a593Smuzhiyun }; 213*4882a593Smuzhiyun }; 214*4882a593Smuzhiyun 215*4882a593Smuzhiyun u2phy1: usb2-phy@800 { 216*4882a593Smuzhiyun compatible = "rockchip,rk322x-usb2phy"; 217*4882a593Smuzhiyun reg = <0x0800 0x0c>; 218*4882a593Smuzhiyun status = "disabled"; 219*4882a593Smuzhiyun 220*4882a593Smuzhiyun u2phy1_otg: otg-port { 221*4882a593Smuzhiyun #phy-cells = <0>; 222*4882a593Smuzhiyun interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>; 223*4882a593Smuzhiyun interrupt-names = "linestate"; 224*4882a593Smuzhiyun status = "disabled"; 225*4882a593Smuzhiyun }; 226*4882a593Smuzhiyun 227*4882a593Smuzhiyun u2phy1_host: host-port { 228*4882a593Smuzhiyun #phy-cells = <0>; 229*4882a593Smuzhiyun interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>; 230*4882a593Smuzhiyun interrupt-names = "linestate"; 231*4882a593Smuzhiyun status = "disabled"; 232*4882a593Smuzhiyun }; 233*4882a593Smuzhiyun }; 234*4882a593Smuzhiyun }; 235*4882a593Smuzhiyun 236*4882a593Smuzhiyun uart0: serial@11010000 { 237*4882a593Smuzhiyun compatible = "snps,dw-apb-uart"; 238*4882a593Smuzhiyun reg = <0x11010000 0x100>; 239*4882a593Smuzhiyun interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>; 240*4882a593Smuzhiyun clock-frequency = <24000000>; 241*4882a593Smuzhiyun clocks = <&cru SCLK_UART0>, <&cru PCLK_UART0>; 242*4882a593Smuzhiyun clock-names = "baudclk", "apb_pclk"; 243*4882a593Smuzhiyun pinctrl-names = "default"; 244*4882a593Smuzhiyun pinctrl-0 = <&uart0_xfer &uart0_cts &uart0_rts>; 245*4882a593Smuzhiyun reg-shift = <2>; 246*4882a593Smuzhiyun reg-io-width = <4>; 247*4882a593Smuzhiyun status = "disabled"; 248*4882a593Smuzhiyun }; 249*4882a593Smuzhiyun 250*4882a593Smuzhiyun uart1: serial@11020000 { 251*4882a593Smuzhiyun compatible = "snps,dw-apb-uart"; 252*4882a593Smuzhiyun reg = <0x11020000 0x100>; 253*4882a593Smuzhiyun interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>; 254*4882a593Smuzhiyun clock-frequency = <24000000>; 255*4882a593Smuzhiyun clocks = <&cru SCLK_UART1>, <&cru PCLK_UART1>; 256*4882a593Smuzhiyun clock-names = "baudclk", "apb_pclk"; 257*4882a593Smuzhiyun pinctrl-names = "default"; 258*4882a593Smuzhiyun pinctrl-0 = <&uart1_xfer>; 259*4882a593Smuzhiyun reg-shift = <2>; 260*4882a593Smuzhiyun reg-io-width = <4>; 261*4882a593Smuzhiyun status = "disabled"; 262*4882a593Smuzhiyun }; 263*4882a593Smuzhiyun 264*4882a593Smuzhiyun uart2: serial@11030000 { 265*4882a593Smuzhiyun compatible = "snps,dw-apb-uart"; 266*4882a593Smuzhiyun reg = <0x11030000 0x100>; 267*4882a593Smuzhiyun interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>; 268*4882a593Smuzhiyun clock-frequency = <24000000>; 269*4882a593Smuzhiyun clocks = <&cru SCLK_UART2>, <&cru PCLK_UART2>; 270*4882a593Smuzhiyun clock-names = "baudclk", "apb_pclk"; 271*4882a593Smuzhiyun pinctrl-names = "default"; 272*4882a593Smuzhiyun pinctrl-0 = <&uart21_xfer>; 273*4882a593Smuzhiyun reg-shift = <2>; 274*4882a593Smuzhiyun reg-io-width = <4>; 275*4882a593Smuzhiyun status = "disabled"; 276*4882a593Smuzhiyun }; 277*4882a593Smuzhiyun 278*4882a593Smuzhiyun efuse: efuse@11040000 { 279*4882a593Smuzhiyun compatible = "rockchip,rk322x-efuse"; 280*4882a593Smuzhiyun reg = <0x11040000 0x20>; 281*4882a593Smuzhiyun #address-cells = <1>; 282*4882a593Smuzhiyun #size-cells = <1>; 283*4882a593Smuzhiyun clocks = <&cru PCLK_EFUSE_256>; 284*4882a593Smuzhiyun clock-names = "pclk_efuse"; 285*4882a593Smuzhiyun 286*4882a593Smuzhiyun /* Data cells */ 287*4882a593Smuzhiyun efuse_id: id@7 { 288*4882a593Smuzhiyun reg = <0x7 0x10>; 289*4882a593Smuzhiyun }; 290*4882a593Smuzhiyun cpu_leakage: cpu_leakage@17 { 291*4882a593Smuzhiyun reg = <0x17 0x1>; 292*4882a593Smuzhiyun }; 293*4882a593Smuzhiyun }; 294*4882a593Smuzhiyun 295*4882a593Smuzhiyun i2c0: i2c@11050000 { 296*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2c"; 297*4882a593Smuzhiyun reg = <0x11050000 0x1000>; 298*4882a593Smuzhiyun interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>; 299*4882a593Smuzhiyun #address-cells = <1>; 300*4882a593Smuzhiyun #size-cells = <0>; 301*4882a593Smuzhiyun clock-names = "i2c"; 302*4882a593Smuzhiyun clocks = <&cru PCLK_I2C0>; 303*4882a593Smuzhiyun pinctrl-names = "default"; 304*4882a593Smuzhiyun pinctrl-0 = <&i2c0_xfer>; 305*4882a593Smuzhiyun status = "disabled"; 306*4882a593Smuzhiyun }; 307*4882a593Smuzhiyun 308*4882a593Smuzhiyun i2c1: i2c@11060000 { 309*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2c"; 310*4882a593Smuzhiyun reg = <0x11060000 0x1000>; 311*4882a593Smuzhiyun interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>; 312*4882a593Smuzhiyun #address-cells = <1>; 313*4882a593Smuzhiyun #size-cells = <0>; 314*4882a593Smuzhiyun clock-names = "i2c"; 315*4882a593Smuzhiyun clocks = <&cru PCLK_I2C1>; 316*4882a593Smuzhiyun pinctrl-names = "default"; 317*4882a593Smuzhiyun pinctrl-0 = <&i2c1_xfer>; 318*4882a593Smuzhiyun status = "disabled"; 319*4882a593Smuzhiyun }; 320*4882a593Smuzhiyun 321*4882a593Smuzhiyun i2c2: i2c@11070000 { 322*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2c"; 323*4882a593Smuzhiyun reg = <0x11070000 0x1000>; 324*4882a593Smuzhiyun interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>; 325*4882a593Smuzhiyun #address-cells = <1>; 326*4882a593Smuzhiyun #size-cells = <0>; 327*4882a593Smuzhiyun clock-names = "i2c"; 328*4882a593Smuzhiyun clocks = <&cru PCLK_I2C2>; 329*4882a593Smuzhiyun pinctrl-names = "default"; 330*4882a593Smuzhiyun pinctrl-0 = <&i2c2_xfer>; 331*4882a593Smuzhiyun status = "disabled"; 332*4882a593Smuzhiyun }; 333*4882a593Smuzhiyun 334*4882a593Smuzhiyun i2c3: i2c@11080000 { 335*4882a593Smuzhiyun compatible = "rockchip,rk3228-i2c"; 336*4882a593Smuzhiyun reg = <0x11080000 0x1000>; 337*4882a593Smuzhiyun interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>; 338*4882a593Smuzhiyun #address-cells = <1>; 339*4882a593Smuzhiyun #size-cells = <0>; 340*4882a593Smuzhiyun clock-names = "i2c"; 341*4882a593Smuzhiyun clocks = <&cru PCLK_I2C3>; 342*4882a593Smuzhiyun pinctrl-names = "default"; 343*4882a593Smuzhiyun pinctrl-0 = <&i2c3_xfer>; 344*4882a593Smuzhiyun status = "disabled"; 345*4882a593Smuzhiyun }; 346*4882a593Smuzhiyun 347*4882a593Smuzhiyun pwm0: pwm@110b0000 { 348*4882a593Smuzhiyun compatible = "rockchip,rk3288-pwm"; 349*4882a593Smuzhiyun reg = <0x110b0000 0x10>; 350*4882a593Smuzhiyun #pwm-cells = <3>; 351*4882a593Smuzhiyun clocks = <&cru PCLK_PWM>; 352*4882a593Smuzhiyun clock-names = "pwm"; 353*4882a593Smuzhiyun pinctrl-names = "active"; 354*4882a593Smuzhiyun pinctrl-0 = <&pwm0_pin>; 355*4882a593Smuzhiyun status = "disabled"; 356*4882a593Smuzhiyun }; 357*4882a593Smuzhiyun 358*4882a593Smuzhiyun pwm1: pwm@110b0010 { 359*4882a593Smuzhiyun compatible = "rockchip,rk3288-pwm"; 360*4882a593Smuzhiyun reg = <0x110b0010 0x10>; 361*4882a593Smuzhiyun #pwm-cells = <3>; 362*4882a593Smuzhiyun clocks = <&cru PCLK_PWM>; 363*4882a593Smuzhiyun clock-names = "pwm"; 364*4882a593Smuzhiyun pinctrl-names = "active"; 365*4882a593Smuzhiyun pinctrl-0 = <&pwm1_pin>; 366*4882a593Smuzhiyun status = "disabled"; 367*4882a593Smuzhiyun }; 368*4882a593Smuzhiyun 369*4882a593Smuzhiyun pwm2: pwm@110b0020 { 370*4882a593Smuzhiyun compatible = "rockchip,rk3288-pwm"; 371*4882a593Smuzhiyun reg = <0x110b0020 0x10>; 372*4882a593Smuzhiyun #pwm-cells = <3>; 373*4882a593Smuzhiyun clocks = <&cru PCLK_PWM>; 374*4882a593Smuzhiyun clock-names = "pwm"; 375*4882a593Smuzhiyun pinctrl-names = "active"; 376*4882a593Smuzhiyun pinctrl-0 = <&pwm2_pin>; 377*4882a593Smuzhiyun status = "disabled"; 378*4882a593Smuzhiyun }; 379*4882a593Smuzhiyun 380*4882a593Smuzhiyun pwm3: pwm@110b0030 { 381*4882a593Smuzhiyun compatible = "rockchip,rk3288-pwm"; 382*4882a593Smuzhiyun reg = <0x110b0030 0x10>; 383*4882a593Smuzhiyun #pwm-cells = <2>; 384*4882a593Smuzhiyun clocks = <&cru PCLK_PWM>; 385*4882a593Smuzhiyun clock-names = "pwm"; 386*4882a593Smuzhiyun pinctrl-names = "active"; 387*4882a593Smuzhiyun pinctrl-0 = <&pwm3_pin>; 388*4882a593Smuzhiyun status = "disabled"; 389*4882a593Smuzhiyun }; 390*4882a593Smuzhiyun 391*4882a593Smuzhiyun timer: timer@110c0000 { 392*4882a593Smuzhiyun compatible = "rockchip,rk3288-timer"; 393*4882a593Smuzhiyun reg = <0x110c0000 0x20>; 394*4882a593Smuzhiyun interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>; 395*4882a593Smuzhiyun clocks = <&xin24m>, <&cru PCLK_TIMER>; 396*4882a593Smuzhiyun clock-names = "timer", "pclk"; 397*4882a593Smuzhiyun }; 398*4882a593Smuzhiyun 399*4882a593Smuzhiyun cru: clock-controller@110e0000 { 400*4882a593Smuzhiyun compatible = "rockchip,rk3228-cru"; 401*4882a593Smuzhiyun reg = <0x110e0000 0x1000>; 402*4882a593Smuzhiyun rockchip,grf = <&grf>; 403*4882a593Smuzhiyun #clock-cells = <1>; 404*4882a593Smuzhiyun #reset-cells = <1>; 405*4882a593Smuzhiyun assigned-clocks = <&cru PLL_GPLL>; 406*4882a593Smuzhiyun assigned-clock-rates = <594000000>; 407*4882a593Smuzhiyun }; 408*4882a593Smuzhiyun 409*4882a593Smuzhiyun thermal-zones { 410*4882a593Smuzhiyun cpu_thermal: cpu-thermal { 411*4882a593Smuzhiyun polling-delay-passive = <100>; /* milliseconds */ 412*4882a593Smuzhiyun polling-delay = <5000>; /* milliseconds */ 413*4882a593Smuzhiyun 414*4882a593Smuzhiyun thermal-sensors = <&tsadc 0>; 415*4882a593Smuzhiyun 416*4882a593Smuzhiyun trips { 417*4882a593Smuzhiyun cpu_alert0: cpu_alert0 { 418*4882a593Smuzhiyun temperature = <70000>; /* millicelsius */ 419*4882a593Smuzhiyun hysteresis = <2000>; /* millicelsius */ 420*4882a593Smuzhiyun type = "passive"; 421*4882a593Smuzhiyun }; 422*4882a593Smuzhiyun cpu_alert1: cpu_alert1 { 423*4882a593Smuzhiyun temperature = <75000>; /* millicelsius */ 424*4882a593Smuzhiyun hysteresis = <2000>; /* millicelsius */ 425*4882a593Smuzhiyun type = "passive"; 426*4882a593Smuzhiyun }; 427*4882a593Smuzhiyun cpu_crit: cpu_crit { 428*4882a593Smuzhiyun temperature = <90000>; /* millicelsius */ 429*4882a593Smuzhiyun hysteresis = <2000>; /* millicelsius */ 430*4882a593Smuzhiyun type = "critical"; 431*4882a593Smuzhiyun }; 432*4882a593Smuzhiyun }; 433*4882a593Smuzhiyun 434*4882a593Smuzhiyun cooling-maps { 435*4882a593Smuzhiyun map0 { 436*4882a593Smuzhiyun trip = <&cpu_alert0>; 437*4882a593Smuzhiyun cooling-device = 438*4882a593Smuzhiyun <&cpu0 THERMAL_NO_LIMIT 6>; 439*4882a593Smuzhiyun }; 440*4882a593Smuzhiyun map1 { 441*4882a593Smuzhiyun trip = <&cpu_alert1>; 442*4882a593Smuzhiyun cooling-device = 443*4882a593Smuzhiyun <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; 444*4882a593Smuzhiyun }; 445*4882a593Smuzhiyun }; 446*4882a593Smuzhiyun }; 447*4882a593Smuzhiyun }; 448*4882a593Smuzhiyun 449*4882a593Smuzhiyun tsadc: tsadc@11150000 { 450*4882a593Smuzhiyun compatible = "rockchip,rk3228-tsadc"; 451*4882a593Smuzhiyun reg = <0x11150000 0x100>; 452*4882a593Smuzhiyun interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>; 453*4882a593Smuzhiyun clocks = <&cru SCLK_TSADC>, <&cru PCLK_TSADC>; 454*4882a593Smuzhiyun clock-names = "tsadc", "apb_pclk"; 455*4882a593Smuzhiyun resets = <&cru SRST_TSADC>; 456*4882a593Smuzhiyun reset-names = "tsadc-apb"; 457*4882a593Smuzhiyun pinctrl-names = "init", "default", "sleep"; 458*4882a593Smuzhiyun pinctrl-0 = <&otp_gpio>; 459*4882a593Smuzhiyun pinctrl-1 = <&otp_out>; 460*4882a593Smuzhiyun pinctrl-2 = <&otp_gpio>; 461*4882a593Smuzhiyun #thermal-sensor-cells = <0>; 462*4882a593Smuzhiyun rockchip,hw-tshut-temp = <95000>; 463*4882a593Smuzhiyun status = "disabled"; 464*4882a593Smuzhiyun }; 465*4882a593Smuzhiyun 466*4882a593Smuzhiyun sdmmc: dwmmc@30000000 { 467*4882a593Smuzhiyun compatible = "rockchip,rk3228-dw-mshc", "rockchip,rk3288-dw-mshc"; 468*4882a593Smuzhiyun reg = <0x30000000 0x4000>; 469*4882a593Smuzhiyun max-frequency = <150000000>; 470*4882a593Smuzhiyun interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>; 471*4882a593Smuzhiyun clocks = <&cru HCLK_SDMMC>, <&cru SCLK_SDMMC>, 472*4882a593Smuzhiyun <&cru SCLK_SDMMC_DRV>, <&cru SCLK_SDMMC_SAMPLE>; 473*4882a593Smuzhiyun clock-names = "biu", "ciu", "ciu-drv", "ciu-sample"; 474*4882a593Smuzhiyun fifo-depth = <0x100>; 475*4882a593Smuzhiyun cd-gpios = <&gpio1 RK_PC1 GPIO_ACTIVE_HIGH>; 476*4882a593Smuzhiyun pinctrl-names = "default"; 477*4882a593Smuzhiyun pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_bus4>; 478*4882a593Smuzhiyun status = "disabled"; 479*4882a593Smuzhiyun }; 480*4882a593Smuzhiyun 481*4882a593Smuzhiyun sdio: dwmmc@30010000 { 482*4882a593Smuzhiyun compatible = "rockchip,rk3228-dw-mshc", "rockchip,rk3288-dw-mshc"; 483*4882a593Smuzhiyun reg = <0x30010000 0x4000>; 484*4882a593Smuzhiyun interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>; 485*4882a593Smuzhiyun clocks = <&cru HCLK_SDIO>, <&cru SCLK_SDIO>, 486*4882a593Smuzhiyun <&cru SCLK_SDIO_DRV>, <&cru SCLK_SDIO_SAMPLE>; 487*4882a593Smuzhiyun clock-names = "biu", "ciu", "ciu-drv", "ciu-sample"; 488*4882a593Smuzhiyun fifo-depth = <0x100>; 489*4882a593Smuzhiyun pinctrl-names = "default"; 490*4882a593Smuzhiyun pinctrl-0 = <&sdio_clk &sdio_cmd &sdio_bus4>; 491*4882a593Smuzhiyun status = "disabled"; 492*4882a593Smuzhiyun }; 493*4882a593Smuzhiyun 494*4882a593Smuzhiyun emmc: dwmmc@30020000 { 495*4882a593Smuzhiyun compatible = "rockchip,rk3288-dw-mshc"; 496*4882a593Smuzhiyun reg = <0x30020000 0x4000>; 497*4882a593Smuzhiyun max-frequency = <150000000>; 498*4882a593Smuzhiyun interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>; 499*4882a593Smuzhiyun clocks = <&cru HCLK_EMMC>, <&cru SCLK_EMMC>, 500*4882a593Smuzhiyun <&cru SCLK_EMMC_DRV>, <&cru SCLK_EMMC_SAMPLE>; 501*4882a593Smuzhiyun clock-names = "biu", "ciu", "ciu-drv", "ciu-sample"; 502*4882a593Smuzhiyun bus-width = <8>; 503*4882a593Smuzhiyun default-sample-phase = <158>; 504*4882a593Smuzhiyun num-slots = <1>; 505*4882a593Smuzhiyun fifo-depth = <0x100>; 506*4882a593Smuzhiyun pinctrl-names = "default"; 507*4882a593Smuzhiyun pinctrl-0 = <&emmc_clk &emmc_cmd &emmc_bus8>; 508*4882a593Smuzhiyun resets = <&cru SRST_EMMC>; 509*4882a593Smuzhiyun reset-names = "reset"; 510*4882a593Smuzhiyun status = "disabled"; 511*4882a593Smuzhiyun }; 512*4882a593Smuzhiyun 513*4882a593Smuzhiyun usb20_otg: usb@30040000 { 514*4882a593Smuzhiyun compatible = "rockchip,rk3229-usb", "rockchip,rk3288-usb", 515*4882a593Smuzhiyun "snps,dwc2"; 516*4882a593Smuzhiyun reg = <0x30040000 0x40000>; 517*4882a593Smuzhiyun interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>; 518*4882a593Smuzhiyun hnp-srp-disable; 519*4882a593Smuzhiyun dr_mode = "otg"; 520*4882a593Smuzhiyun phys = <&u2phy0_otg>; 521*4882a593Smuzhiyun phy-names = "usb2-phy"; 522*4882a593Smuzhiyun status = "disabled"; 523*4882a593Smuzhiyun }; 524*4882a593Smuzhiyun 525*4882a593Smuzhiyun gmac: ethernet@30200000 { 526*4882a593Smuzhiyun compatible = "rockchip,rk3228-gmac"; 527*4882a593Smuzhiyun reg = <0x30200000 0x10000>; 528*4882a593Smuzhiyun interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>; 529*4882a593Smuzhiyun interrupt-names = "macirq"; 530*4882a593Smuzhiyun clocks = <&cru SCLK_MAC>, <&cru SCLK_MAC_RX>, 531*4882a593Smuzhiyun <&cru SCLK_MAC_TX>, <&cru SCLK_MAC_REF>, 532*4882a593Smuzhiyun <&cru SCLK_MAC_REFOUT>, <&cru ACLK_GMAC>, 533*4882a593Smuzhiyun <&cru PCLK_GMAC>, <&cru SCLK_MAC_PHY>; 534*4882a593Smuzhiyun clock-names = "stmmaceth", "mac_clk_rx", 535*4882a593Smuzhiyun "mac_clk_tx", "clk_mac_ref", 536*4882a593Smuzhiyun "clk_mac_refout", "aclk_mac", 537*4882a593Smuzhiyun "pclk_mac", "clk_macphy"; 538*4882a593Smuzhiyun resets = <&cru SRST_GMAC>, <&cru SRST_MACPHY>; 539*4882a593Smuzhiyun reset-names = "stmmaceth", "mac-phy"; 540*4882a593Smuzhiyun rockchip,grf = <&grf>; 541*4882a593Smuzhiyun status = "disabled"; 542*4882a593Smuzhiyun }; 543*4882a593Smuzhiyun 544*4882a593Smuzhiyun gic: interrupt-controller@32010000 { 545*4882a593Smuzhiyun compatible = "arm,gic-400"; 546*4882a593Smuzhiyun interrupt-controller; 547*4882a593Smuzhiyun #interrupt-cells = <3>; 548*4882a593Smuzhiyun #address-cells = <0>; 549*4882a593Smuzhiyun 550*4882a593Smuzhiyun reg = <0x32011000 0x1000>, 551*4882a593Smuzhiyun <0x32012000 0x2000>, 552*4882a593Smuzhiyun <0x32014000 0x2000>, 553*4882a593Smuzhiyun <0x32016000 0x2000>; 554*4882a593Smuzhiyun interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>; 555*4882a593Smuzhiyun }; 556*4882a593Smuzhiyun 557*4882a593Smuzhiyun pinctrl: pinctrl { 558*4882a593Smuzhiyun compatible = "rockchip,rk3228-pinctrl"; 559*4882a593Smuzhiyun rockchip,grf = <&grf>; 560*4882a593Smuzhiyun #address-cells = <1>; 561*4882a593Smuzhiyun #size-cells = <1>; 562*4882a593Smuzhiyun ranges; 563*4882a593Smuzhiyun 564*4882a593Smuzhiyun gpio0: gpio0@11110000 { 565*4882a593Smuzhiyun compatible = "rockchip,gpio-bank"; 566*4882a593Smuzhiyun reg = <0x11110000 0x100>; 567*4882a593Smuzhiyun interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>; 568*4882a593Smuzhiyun clocks = <&cru PCLK_GPIO0>; 569*4882a593Smuzhiyun 570*4882a593Smuzhiyun gpio-controller; 571*4882a593Smuzhiyun #gpio-cells = <2>; 572*4882a593Smuzhiyun 573*4882a593Smuzhiyun interrupt-controller; 574*4882a593Smuzhiyun #interrupt-cells = <2>; 575*4882a593Smuzhiyun }; 576*4882a593Smuzhiyun 577*4882a593Smuzhiyun gpio1: gpio1@11120000 { 578*4882a593Smuzhiyun compatible = "rockchip,gpio-bank"; 579*4882a593Smuzhiyun reg = <0x11120000 0x100>; 580*4882a593Smuzhiyun interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>; 581*4882a593Smuzhiyun clocks = <&cru PCLK_GPIO1>; 582*4882a593Smuzhiyun 583*4882a593Smuzhiyun gpio-controller; 584*4882a593Smuzhiyun #gpio-cells = <2>; 585*4882a593Smuzhiyun 586*4882a593Smuzhiyun interrupt-controller; 587*4882a593Smuzhiyun #interrupt-cells = <2>; 588*4882a593Smuzhiyun }; 589*4882a593Smuzhiyun 590*4882a593Smuzhiyun gpio2: gpio2@11130000 { 591*4882a593Smuzhiyun compatible = "rockchip,gpio-bank"; 592*4882a593Smuzhiyun reg = <0x11130000 0x100>; 593*4882a593Smuzhiyun interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>; 594*4882a593Smuzhiyun clocks = <&cru PCLK_GPIO2>; 595*4882a593Smuzhiyun 596*4882a593Smuzhiyun gpio-controller; 597*4882a593Smuzhiyun #gpio-cells = <2>; 598*4882a593Smuzhiyun 599*4882a593Smuzhiyun interrupt-controller; 600*4882a593Smuzhiyun #interrupt-cells = <2>; 601*4882a593Smuzhiyun }; 602*4882a593Smuzhiyun 603*4882a593Smuzhiyun gpio3: gpio3@11140000 { 604*4882a593Smuzhiyun compatible = "rockchip,gpio-bank"; 605*4882a593Smuzhiyun reg = <0x11140000 0x100>; 606*4882a593Smuzhiyun interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>; 607*4882a593Smuzhiyun clocks = <&cru PCLK_GPIO3>; 608*4882a593Smuzhiyun 609*4882a593Smuzhiyun gpio-controller; 610*4882a593Smuzhiyun #gpio-cells = <2>; 611*4882a593Smuzhiyun 612*4882a593Smuzhiyun interrupt-controller; 613*4882a593Smuzhiyun #interrupt-cells = <2>; 614*4882a593Smuzhiyun }; 615*4882a593Smuzhiyun 616*4882a593Smuzhiyun pcfg_pull_up: pcfg-pull-up { 617*4882a593Smuzhiyun bias-pull-up; 618*4882a593Smuzhiyun }; 619*4882a593Smuzhiyun 620*4882a593Smuzhiyun pcfg_pull_down: pcfg-pull-down { 621*4882a593Smuzhiyun bias-pull-down; 622*4882a593Smuzhiyun }; 623*4882a593Smuzhiyun 624*4882a593Smuzhiyun pcfg_pull_none: pcfg-pull-none { 625*4882a593Smuzhiyun bias-disable; 626*4882a593Smuzhiyun }; 627*4882a593Smuzhiyun 628*4882a593Smuzhiyun pcfg_pull_none_drv_12ma: pcfg-pull-none-drv-12ma { 629*4882a593Smuzhiyun drive-strength = <12>; 630*4882a593Smuzhiyun }; 631*4882a593Smuzhiyun 632*4882a593Smuzhiyun sdmmc { 633*4882a593Smuzhiyun sdmmc_clk: sdmmc-clk { 634*4882a593Smuzhiyun rockchip,pins = <1 16 RK_FUNC_1 &pcfg_pull_none_drv_12ma>; 635*4882a593Smuzhiyun }; 636*4882a593Smuzhiyun 637*4882a593Smuzhiyun sdmmc_cmd: sdmmc-cmd { 638*4882a593Smuzhiyun rockchip,pins = <1 15 RK_FUNC_1 &pcfg_pull_none_drv_12ma>; 639*4882a593Smuzhiyun }; 640*4882a593Smuzhiyun 641*4882a593Smuzhiyun sdmmc_bus4: sdmmc-bus4 { 642*4882a593Smuzhiyun rockchip,pins = <1 18 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 643*4882a593Smuzhiyun <1 19 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 644*4882a593Smuzhiyun <1 20 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 645*4882a593Smuzhiyun <1 21 RK_FUNC_1 &pcfg_pull_none_drv_12ma>; 646*4882a593Smuzhiyun }; 647*4882a593Smuzhiyun }; 648*4882a593Smuzhiyun 649*4882a593Smuzhiyun sdio { 650*4882a593Smuzhiyun sdio_clk: sdio-clk { 651*4882a593Smuzhiyun rockchip,pins = <3 0 RK_FUNC_1 &pcfg_pull_none_drv_12ma>; 652*4882a593Smuzhiyun }; 653*4882a593Smuzhiyun 654*4882a593Smuzhiyun sdio_cmd: sdio-cmd { 655*4882a593Smuzhiyun rockchip,pins = <3 1 RK_FUNC_1 &pcfg_pull_none_drv_12ma>; 656*4882a593Smuzhiyun }; 657*4882a593Smuzhiyun 658*4882a593Smuzhiyun sdio_bus4: sdio-bus4 { 659*4882a593Smuzhiyun rockchip,pins = <3 2 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 660*4882a593Smuzhiyun <3 3 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 661*4882a593Smuzhiyun <3 4 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 662*4882a593Smuzhiyun <3 5 RK_FUNC_1 &pcfg_pull_none_drv_12ma>; 663*4882a593Smuzhiyun }; 664*4882a593Smuzhiyun }; 665*4882a593Smuzhiyun 666*4882a593Smuzhiyun emmc { 667*4882a593Smuzhiyun emmc_clk: emmc-clk { 668*4882a593Smuzhiyun rockchip,pins = <2 RK_PA7 RK_FUNC_2 &pcfg_pull_none>; 669*4882a593Smuzhiyun }; 670*4882a593Smuzhiyun 671*4882a593Smuzhiyun emmc_cmd: emmc-cmd { 672*4882a593Smuzhiyun rockchip,pins = <1 RK_PC6 RK_FUNC_2 &pcfg_pull_none>; 673*4882a593Smuzhiyun }; 674*4882a593Smuzhiyun 675*4882a593Smuzhiyun emmc_bus8: emmc-bus8 { 676*4882a593Smuzhiyun rockchip,pins = <1 RK_PD0 RK_FUNC_2 &pcfg_pull_none>, 677*4882a593Smuzhiyun <1 RK_PD1 RK_FUNC_2 &pcfg_pull_none>, 678*4882a593Smuzhiyun <1 RK_PD2 RK_FUNC_2 &pcfg_pull_none>, 679*4882a593Smuzhiyun <1 RK_PD3 RK_FUNC_2 &pcfg_pull_none>, 680*4882a593Smuzhiyun <1 RK_PD4 RK_FUNC_2 &pcfg_pull_none>, 681*4882a593Smuzhiyun <1 RK_PD5 RK_FUNC_2 &pcfg_pull_none>, 682*4882a593Smuzhiyun <1 RK_PD6 RK_FUNC_2 &pcfg_pull_none>, 683*4882a593Smuzhiyun <1 RK_PD7 RK_FUNC_2 &pcfg_pull_none>; 684*4882a593Smuzhiyun }; 685*4882a593Smuzhiyun }; 686*4882a593Smuzhiyun 687*4882a593Smuzhiyun gmac { 688*4882a593Smuzhiyun rgmii_pins: rgmii-pins { 689*4882a593Smuzhiyun rockchip,pins = <2 RK_PB6 RK_FUNC_1 &pcfg_pull_none>, 690*4882a593Smuzhiyun <2 RK_PB4 RK_FUNC_1 &pcfg_pull_none>, 691*4882a593Smuzhiyun <2 RK_PD1 RK_FUNC_1 &pcfg_pull_none>, 692*4882a593Smuzhiyun <2 RK_PC3 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 693*4882a593Smuzhiyun <2 RK_PC2 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 694*4882a593Smuzhiyun <2 RK_PC6 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 695*4882a593Smuzhiyun <2 RK_PC7 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 696*4882a593Smuzhiyun <2 RK_PB1 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 697*4882a593Smuzhiyun <2 RK_PB5 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 698*4882a593Smuzhiyun <2 RK_PC1 RK_FUNC_1 &pcfg_pull_none>, 699*4882a593Smuzhiyun <2 RK_PC0 RK_FUNC_1 &pcfg_pull_none>, 700*4882a593Smuzhiyun <2 RK_PC5 RK_FUNC_2 &pcfg_pull_none>, 701*4882a593Smuzhiyun <2 RK_PC4 RK_FUNC_2 &pcfg_pull_none>, 702*4882a593Smuzhiyun <2 RK_PB3 RK_FUNC_1 &pcfg_pull_none>, 703*4882a593Smuzhiyun <2 RK_PB0 RK_FUNC_1 &pcfg_pull_none>; 704*4882a593Smuzhiyun }; 705*4882a593Smuzhiyun 706*4882a593Smuzhiyun rmii_pins: rmii-pins { 707*4882a593Smuzhiyun rockchip,pins = <2 RK_PB6 RK_FUNC_1 &pcfg_pull_none>, 708*4882a593Smuzhiyun <2 RK_PB4 RK_FUNC_1 &pcfg_pull_none>, 709*4882a593Smuzhiyun <2 RK_PD1 RK_FUNC_1 &pcfg_pull_none>, 710*4882a593Smuzhiyun <2 RK_PC3 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 711*4882a593Smuzhiyun <2 RK_PC2 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 712*4882a593Smuzhiyun <2 RK_PB5 RK_FUNC_1 &pcfg_pull_none_drv_12ma>, 713*4882a593Smuzhiyun <2 RK_PC1 RK_FUNC_1 &pcfg_pull_none>, 714*4882a593Smuzhiyun <2 RK_PC0 RK_FUNC_1 &pcfg_pull_none>, 715*4882a593Smuzhiyun <2 RK_PB0 RK_FUNC_1 &pcfg_pull_none>, 716*4882a593Smuzhiyun <2 RK_PB7 RK_FUNC_1 &pcfg_pull_none>; 717*4882a593Smuzhiyun }; 718*4882a593Smuzhiyun 719*4882a593Smuzhiyun phy_pins: phy-pins { 720*4882a593Smuzhiyun rockchip,pins = <2 RK_PB6 RK_FUNC_2 &pcfg_pull_none>, 721*4882a593Smuzhiyun <2 RK_PB0 RK_FUNC_2 &pcfg_pull_none>; 722*4882a593Smuzhiyun }; 723*4882a593Smuzhiyun }; 724*4882a593Smuzhiyun 725*4882a593Smuzhiyun i2c0 { 726*4882a593Smuzhiyun i2c0_xfer: i2c0-xfer { 727*4882a593Smuzhiyun rockchip,pins = <0 RK_PA0 RK_FUNC_1 &pcfg_pull_none>, 728*4882a593Smuzhiyun <0 RK_PA1 RK_FUNC_1 &pcfg_pull_none>; 729*4882a593Smuzhiyun }; 730*4882a593Smuzhiyun }; 731*4882a593Smuzhiyun 732*4882a593Smuzhiyun i2c1 { 733*4882a593Smuzhiyun i2c1_xfer: i2c1-xfer { 734*4882a593Smuzhiyun rockchip,pins = <0 RK_PA2 RK_FUNC_1 &pcfg_pull_none>, 735*4882a593Smuzhiyun <0 RK_PA3 RK_FUNC_1 &pcfg_pull_none>; 736*4882a593Smuzhiyun }; 737*4882a593Smuzhiyun }; 738*4882a593Smuzhiyun 739*4882a593Smuzhiyun i2c2 { 740*4882a593Smuzhiyun i2c2_xfer: i2c2-xfer { 741*4882a593Smuzhiyun rockchip,pins = <2 RK_PC4 RK_FUNC_1 &pcfg_pull_none>, 742*4882a593Smuzhiyun <2 RK_PC5 RK_FUNC_1 &pcfg_pull_none>; 743*4882a593Smuzhiyun }; 744*4882a593Smuzhiyun }; 745*4882a593Smuzhiyun 746*4882a593Smuzhiyun i2c3 { 747*4882a593Smuzhiyun i2c3_xfer: i2c3-xfer { 748*4882a593Smuzhiyun rockchip,pins = <0 RK_PA6 RK_FUNC_1 &pcfg_pull_none>, 749*4882a593Smuzhiyun <0 RK_PA7 RK_FUNC_1 &pcfg_pull_none>; 750*4882a593Smuzhiyun }; 751*4882a593Smuzhiyun }; 752*4882a593Smuzhiyun 753*4882a593Smuzhiyun i2s1 { 754*4882a593Smuzhiyun i2s1_bus: i2s1-bus { 755*4882a593Smuzhiyun rockchip,pins = <0 RK_PB0 RK_FUNC_1 &pcfg_pull_none>, 756*4882a593Smuzhiyun <0 RK_PB1 RK_FUNC_1 &pcfg_pull_none>, 757*4882a593Smuzhiyun <0 RK_PB3 RK_FUNC_1 &pcfg_pull_none>, 758*4882a593Smuzhiyun <0 RK_PB4 RK_FUNC_1 &pcfg_pull_none>, 759*4882a593Smuzhiyun <0 RK_PB5 RK_FUNC_1 &pcfg_pull_none>, 760*4882a593Smuzhiyun <0 RK_PB6 RK_FUNC_1 &pcfg_pull_none>, 761*4882a593Smuzhiyun <1 RK_PA2 RK_FUNC_1 &pcfg_pull_none>, 762*4882a593Smuzhiyun <1 RK_PA4 RK_FUNC_1 &pcfg_pull_none>, 763*4882a593Smuzhiyun <1 RK_PA5 RK_FUNC_1 &pcfg_pull_none>; 764*4882a593Smuzhiyun }; 765*4882a593Smuzhiyun }; 766*4882a593Smuzhiyun 767*4882a593Smuzhiyun pwm0 { 768*4882a593Smuzhiyun pwm0_pin: pwm0-pin { 769*4882a593Smuzhiyun rockchip,pins = <3 RK_PC5 RK_FUNC_1 &pcfg_pull_none>; 770*4882a593Smuzhiyun }; 771*4882a593Smuzhiyun }; 772*4882a593Smuzhiyun 773*4882a593Smuzhiyun pwm1 { 774*4882a593Smuzhiyun pwm1_pin: pwm1-pin { 775*4882a593Smuzhiyun rockchip,pins = <0 RK_PD6 RK_FUNC_2 &pcfg_pull_none>; 776*4882a593Smuzhiyun }; 777*4882a593Smuzhiyun }; 778*4882a593Smuzhiyun 779*4882a593Smuzhiyun pwm2 { 780*4882a593Smuzhiyun pwm2_pin: pwm2-pin { 781*4882a593Smuzhiyun rockchip,pins = <1 RK_PB4 RK_FUNC_2 &pcfg_pull_none>; 782*4882a593Smuzhiyun }; 783*4882a593Smuzhiyun }; 784*4882a593Smuzhiyun 785*4882a593Smuzhiyun pwm3 { 786*4882a593Smuzhiyun pwm3_pin: pwm3-pin { 787*4882a593Smuzhiyun rockchip,pins = <1 RK_PB3 RK_FUNC_2 &pcfg_pull_none>; 788*4882a593Smuzhiyun }; 789*4882a593Smuzhiyun }; 790*4882a593Smuzhiyun 791*4882a593Smuzhiyun tsadc { 792*4882a593Smuzhiyun otp_gpio: otp-gpio { 793*4882a593Smuzhiyun rockchip,pins = <0 RK_PD0 RK_FUNC_GPIO &pcfg_pull_none>; 794*4882a593Smuzhiyun }; 795*4882a593Smuzhiyun 796*4882a593Smuzhiyun otp_out: otp-out { 797*4882a593Smuzhiyun rockchip,pins = <0 RK_PD0 RK_FUNC_2 &pcfg_pull_none>; 798*4882a593Smuzhiyun }; 799*4882a593Smuzhiyun }; 800*4882a593Smuzhiyun 801*4882a593Smuzhiyun uart0 { 802*4882a593Smuzhiyun uart0_xfer: uart0-xfer { 803*4882a593Smuzhiyun rockchip,pins = <2 RK_PD2 RK_FUNC_1 &pcfg_pull_none>, 804*4882a593Smuzhiyun <2 RK_PD3 RK_FUNC_1 &pcfg_pull_none>; 805*4882a593Smuzhiyun }; 806*4882a593Smuzhiyun 807*4882a593Smuzhiyun uart0_cts: uart0-cts { 808*4882a593Smuzhiyun rockchip,pins = <2 RK_PD5 RK_FUNC_1 &pcfg_pull_none>; 809*4882a593Smuzhiyun }; 810*4882a593Smuzhiyun 811*4882a593Smuzhiyun uart0_rts: uart0-rts { 812*4882a593Smuzhiyun rockchip,pins = <0 RK_PC1 RK_FUNC_1 &pcfg_pull_none>; 813*4882a593Smuzhiyun }; 814*4882a593Smuzhiyun }; 815*4882a593Smuzhiyun 816*4882a593Smuzhiyun uart1 { 817*4882a593Smuzhiyun uart1_xfer: uart1-xfer { 818*4882a593Smuzhiyun rockchip,pins = <1 RK_PB1 RK_FUNC_1 &pcfg_pull_none>, 819*4882a593Smuzhiyun <1 RK_PB2 RK_FUNC_1 &pcfg_pull_none>; 820*4882a593Smuzhiyun }; 821*4882a593Smuzhiyun 822*4882a593Smuzhiyun uart1_cts: uart1-cts { 823*4882a593Smuzhiyun rockchip,pins = <1 RK_PB0 RK_FUNC_1 &pcfg_pull_none>; 824*4882a593Smuzhiyun }; 825*4882a593Smuzhiyun 826*4882a593Smuzhiyun uart1_rts: uart1-rts { 827*4882a593Smuzhiyun rockchip,pins = <1 RK_PB3 RK_FUNC_1 &pcfg_pull_none>; 828*4882a593Smuzhiyun }; 829*4882a593Smuzhiyun }; 830*4882a593Smuzhiyun 831*4882a593Smuzhiyun uart2 { 832*4882a593Smuzhiyun uart2_xfer: uart2-xfer { 833*4882a593Smuzhiyun rockchip,pins = <1 RK_PC2 RK_FUNC_2 &pcfg_pull_up>, 834*4882a593Smuzhiyun <1 RK_PC3 RK_FUNC_2 &pcfg_pull_none>; 835*4882a593Smuzhiyun }; 836*4882a593Smuzhiyun 837*4882a593Smuzhiyun uart2_cts: uart2-cts { 838*4882a593Smuzhiyun rockchip,pins = <0 RK_PD1 RK_FUNC_1 &pcfg_pull_none>; 839*4882a593Smuzhiyun }; 840*4882a593Smuzhiyun 841*4882a593Smuzhiyun uart2_rts: uart2-rts { 842*4882a593Smuzhiyun rockchip,pins = <0 RK_PD0 RK_FUNC_1 &pcfg_pull_none>; 843*4882a593Smuzhiyun }; 844*4882a593Smuzhiyun }; 845*4882a593Smuzhiyun 846*4882a593Smuzhiyun uart2-1 { 847*4882a593Smuzhiyun uart21_xfer: uart21-xfer { 848*4882a593Smuzhiyun rockchip,pins = <1 10 RK_FUNC_2 &pcfg_pull_up>, 849*4882a593Smuzhiyun <1 9 RK_FUNC_2 &pcfg_pull_none>; 850*4882a593Smuzhiyun }; 851*4882a593Smuzhiyun }; 852*4882a593Smuzhiyun }; 853*4882a593Smuzhiyun 854*4882a593Smuzhiyun dmc: dmc@11200000 { 855*4882a593Smuzhiyun compatible = "rockchip,rk3228-dmc", "syscon"; 856*4882a593Smuzhiyun rockchip,cru = <&cru>; 857*4882a593Smuzhiyun rockchip,grf = <&grf>; 858*4882a593Smuzhiyun rockchip,msch = <&service_msch>; 859*4882a593Smuzhiyun reg = <0x11200000 0x3fc 860*4882a593Smuzhiyun 0x12000000 0x400>; 861*4882a593Smuzhiyun rockchip,sram = <&ddr_sram>; 862*4882a593Smuzhiyun }; 863*4882a593Smuzhiyun 864*4882a593Smuzhiyun service_msch: syscon@31090000 { 865*4882a593Smuzhiyun compatible = "rockchip,rk3228-msch", "syscon"; 866*4882a593Smuzhiyun reg = <0x31090000 0x2000>; 867*4882a593Smuzhiyun }; 868*4882a593Smuzhiyun 869*4882a593Smuzhiyun nandc: nandc@30030000 { 870*4882a593Smuzhiyun compatible = "rockchip,rk-nandc"; 871*4882a593Smuzhiyun reg = <0x30030000 0x4000>; 872*4882a593Smuzhiyun interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>; 873*4882a593Smuzhiyun nandc_id = <0>; 874*4882a593Smuzhiyun clocks = <&cru SCLK_NANDC>, <&cru HCLK_NANDC>; 875*4882a593Smuzhiyun clock-names = "clk_nandc", "hclk_nandc"; 876*4882a593Smuzhiyun status = "disabled"; 877*4882a593Smuzhiyun }; 878*4882a593Smuzhiyun}; 879