1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0 2*4882a593Smuzhiyun#include <dt-bindings/clock/tegra124-car.h> 3*4882a593Smuzhiyun#include <dt-bindings/gpio/tegra-gpio.h> 4*4882a593Smuzhiyun#include <dt-bindings/memory/tegra124-mc.h> 5*4882a593Smuzhiyun#include <dt-bindings/pinctrl/pinctrl-tegra.h> 6*4882a593Smuzhiyun#include <dt-bindings/interrupt-controller/arm-gic.h> 7*4882a593Smuzhiyun#include <dt-bindings/reset/tegra124-car.h> 8*4882a593Smuzhiyun#include <dt-bindings/thermal/tegra124-soctherm.h> 9*4882a593Smuzhiyun#include <dt-bindings/soc/tegra-pmc.h> 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun/ { 12*4882a593Smuzhiyun compatible = "nvidia,tegra124"; 13*4882a593Smuzhiyun interrupt-parent = <&lic>; 14*4882a593Smuzhiyun #address-cells = <2>; 15*4882a593Smuzhiyun #size-cells = <2>; 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun memory@80000000 { 18*4882a593Smuzhiyun device_type = "memory"; 19*4882a593Smuzhiyun reg = <0x0 0x80000000 0x0 0x0>; 20*4882a593Smuzhiyun }; 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun pcie@1003000 { 23*4882a593Smuzhiyun compatible = "nvidia,tegra124-pcie"; 24*4882a593Smuzhiyun device_type = "pci"; 25*4882a593Smuzhiyun reg = <0x0 0x01003000 0x0 0x00000800>, /* PADS registers */ 26*4882a593Smuzhiyun <0x0 0x01003800 0x0 0x00000800>, /* AFI registers */ 27*4882a593Smuzhiyun <0x0 0x02000000 0x0 0x10000000>; /* configuration space */ 28*4882a593Smuzhiyun reg-names = "pads", "afi", "cs"; 29*4882a593Smuzhiyun interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, /* controller interrupt */ 30*4882a593Smuzhiyun <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */ 31*4882a593Smuzhiyun interrupt-names = "intr", "msi"; 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun #interrupt-cells = <1>; 34*4882a593Smuzhiyun interrupt-map-mask = <0 0 0 0>; 35*4882a593Smuzhiyun interrupt-map = <0 0 0 0 &gic GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun bus-range = <0x00 0xff>; 38*4882a593Smuzhiyun #address-cells = <3>; 39*4882a593Smuzhiyun #size-cells = <2>; 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun ranges = <0x02000000 0 0x01000000 0x0 0x01000000 0 0x00001000>, /* port 0 configuration space */ 42*4882a593Smuzhiyun <0x02000000 0 0x01001000 0x0 0x01001000 0 0x00001000>, /* port 1 configuration space */ 43*4882a593Smuzhiyun <0x01000000 0 0x0 0x0 0x12000000 0 0x00010000>, /* downstream I/O (64 KiB) */ 44*4882a593Smuzhiyun <0x02000000 0 0x13000000 0x0 0x13000000 0 0x0d000000>, /* non-prefetchable memory (208 MiB) */ 45*4882a593Smuzhiyun <0x42000000 0 0x20000000 0x0 0x20000000 0 0x20000000>; /* prefetchable memory (512 MiB) */ 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_PCIE>, 48*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_AFI>, 49*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_E>, 50*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_CML0>; 51*4882a593Smuzhiyun clock-names = "pex", "afi", "pll_e", "cml"; 52*4882a593Smuzhiyun resets = <&tegra_car 70>, 53*4882a593Smuzhiyun <&tegra_car 72>, 54*4882a593Smuzhiyun <&tegra_car 74>; 55*4882a593Smuzhiyun reset-names = "pex", "afi", "pcie_x"; 56*4882a593Smuzhiyun status = "disabled"; 57*4882a593Smuzhiyun 58*4882a593Smuzhiyun pci@1,0 { 59*4882a593Smuzhiyun device_type = "pci"; 60*4882a593Smuzhiyun assigned-addresses = <0x82000800 0 0x01000000 0 0x1000>; 61*4882a593Smuzhiyun reg = <0x000800 0 0 0 0>; 62*4882a593Smuzhiyun bus-range = <0x00 0xff>; 63*4882a593Smuzhiyun status = "disabled"; 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun #address-cells = <3>; 66*4882a593Smuzhiyun #size-cells = <2>; 67*4882a593Smuzhiyun ranges; 68*4882a593Smuzhiyun 69*4882a593Smuzhiyun nvidia,num-lanes = <2>; 70*4882a593Smuzhiyun }; 71*4882a593Smuzhiyun 72*4882a593Smuzhiyun pci@2,0 { 73*4882a593Smuzhiyun device_type = "pci"; 74*4882a593Smuzhiyun assigned-addresses = <0x82001000 0 0x01001000 0 0x1000>; 75*4882a593Smuzhiyun reg = <0x001000 0 0 0 0>; 76*4882a593Smuzhiyun bus-range = <0x00 0xff>; 77*4882a593Smuzhiyun status = "disabled"; 78*4882a593Smuzhiyun 79*4882a593Smuzhiyun #address-cells = <3>; 80*4882a593Smuzhiyun #size-cells = <2>; 81*4882a593Smuzhiyun ranges; 82*4882a593Smuzhiyun 83*4882a593Smuzhiyun nvidia,num-lanes = <1>; 84*4882a593Smuzhiyun }; 85*4882a593Smuzhiyun }; 86*4882a593Smuzhiyun 87*4882a593Smuzhiyun host1x@50000000 { 88*4882a593Smuzhiyun compatible = "nvidia,tegra124-host1x"; 89*4882a593Smuzhiyun reg = <0x0 0x50000000 0x0 0x00034000>; 90*4882a593Smuzhiyun interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */ 91*4882a593Smuzhiyun <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */ 92*4882a593Smuzhiyun interrupt-names = "syncpt", "host1x"; 93*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_HOST1X>; 94*4882a593Smuzhiyun clock-names = "host1x"; 95*4882a593Smuzhiyun resets = <&tegra_car 28>; 96*4882a593Smuzhiyun reset-names = "host1x"; 97*4882a593Smuzhiyun iommus = <&mc TEGRA_SWGROUP_HC>; 98*4882a593Smuzhiyun 99*4882a593Smuzhiyun #address-cells = <2>; 100*4882a593Smuzhiyun #size-cells = <2>; 101*4882a593Smuzhiyun 102*4882a593Smuzhiyun ranges = <0 0x54000000 0 0x54000000 0 0x01000000>; 103*4882a593Smuzhiyun 104*4882a593Smuzhiyun dc@54200000 { 105*4882a593Smuzhiyun compatible = "nvidia,tegra124-dc"; 106*4882a593Smuzhiyun reg = <0x0 0x54200000 0x0 0x00040000>; 107*4882a593Smuzhiyun interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>; 108*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_DISP1>; 109*4882a593Smuzhiyun clock-names = "dc"; 110*4882a593Smuzhiyun resets = <&tegra_car 27>; 111*4882a593Smuzhiyun reset-names = "dc"; 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun iommus = <&mc TEGRA_SWGROUP_DC>; 114*4882a593Smuzhiyun 115*4882a593Smuzhiyun nvidia,head = <0>; 116*4882a593Smuzhiyun }; 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun dc@54240000 { 119*4882a593Smuzhiyun compatible = "nvidia,tegra124-dc"; 120*4882a593Smuzhiyun reg = <0x0 0x54240000 0x0 0x00040000>; 121*4882a593Smuzhiyun interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>; 122*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_DISP2>; 123*4882a593Smuzhiyun clock-names = "dc"; 124*4882a593Smuzhiyun resets = <&tegra_car 26>; 125*4882a593Smuzhiyun reset-names = "dc"; 126*4882a593Smuzhiyun 127*4882a593Smuzhiyun iommus = <&mc TEGRA_SWGROUP_DCB>; 128*4882a593Smuzhiyun 129*4882a593Smuzhiyun nvidia,head = <1>; 130*4882a593Smuzhiyun }; 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun hdmi: hdmi@54280000 { 133*4882a593Smuzhiyun compatible = "nvidia,tegra124-hdmi"; 134*4882a593Smuzhiyun reg = <0x0 0x54280000 0x0 0x00040000>; 135*4882a593Smuzhiyun interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>; 136*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_HDMI>, 137*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_D2_OUT0>; 138*4882a593Smuzhiyun clock-names = "hdmi", "parent"; 139*4882a593Smuzhiyun resets = <&tegra_car 51>; 140*4882a593Smuzhiyun reset-names = "hdmi"; 141*4882a593Smuzhiyun status = "disabled"; 142*4882a593Smuzhiyun }; 143*4882a593Smuzhiyun 144*4882a593Smuzhiyun vic@54340000 { 145*4882a593Smuzhiyun compatible = "nvidia,tegra124-vic"; 146*4882a593Smuzhiyun reg = <0x0 0x54340000 0x0 0x00040000>; 147*4882a593Smuzhiyun interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>; 148*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_VIC03>; 149*4882a593Smuzhiyun clock-names = "vic"; 150*4882a593Smuzhiyun resets = <&tegra_car 178>; 151*4882a593Smuzhiyun reset-names = "vic"; 152*4882a593Smuzhiyun 153*4882a593Smuzhiyun iommus = <&mc TEGRA_SWGROUP_VIC>; 154*4882a593Smuzhiyun }; 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun sor@54540000 { 157*4882a593Smuzhiyun compatible = "nvidia,tegra124-sor"; 158*4882a593Smuzhiyun reg = <0x0 0x54540000 0x0 0x00040000>; 159*4882a593Smuzhiyun interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>; 160*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SOR0>, 161*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_SOR0_OUT>, 162*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_D_OUT0>, 163*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_DP>, 164*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_CLK_M>; 165*4882a593Smuzhiyun clock-names = "sor", "out", "parent", "dp", "safe"; 166*4882a593Smuzhiyun resets = <&tegra_car 182>; 167*4882a593Smuzhiyun reset-names = "sor"; 168*4882a593Smuzhiyun status = "disabled"; 169*4882a593Smuzhiyun }; 170*4882a593Smuzhiyun 171*4882a593Smuzhiyun dpaux: dpaux@545c0000 { 172*4882a593Smuzhiyun compatible = "nvidia,tegra124-dpaux"; 173*4882a593Smuzhiyun reg = <0x0 0x545c0000 0x0 0x00040000>; 174*4882a593Smuzhiyun interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>; 175*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_DPAUX>, 176*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_DP>; 177*4882a593Smuzhiyun clock-names = "dpaux", "parent"; 178*4882a593Smuzhiyun resets = <&tegra_car 181>; 179*4882a593Smuzhiyun reset-names = "dpaux"; 180*4882a593Smuzhiyun status = "disabled"; 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun i2c-bus { 183*4882a593Smuzhiyun #address-cells = <1>; 184*4882a593Smuzhiyun #size-cells = <0>; 185*4882a593Smuzhiyun }; 186*4882a593Smuzhiyun }; 187*4882a593Smuzhiyun }; 188*4882a593Smuzhiyun 189*4882a593Smuzhiyun gic: interrupt-controller@50041000 { 190*4882a593Smuzhiyun compatible = "arm,cortex-a15-gic"; 191*4882a593Smuzhiyun #interrupt-cells = <3>; 192*4882a593Smuzhiyun interrupt-controller; 193*4882a593Smuzhiyun reg = <0x0 0x50041000 0x0 0x1000>, 194*4882a593Smuzhiyun <0x0 0x50042000 0x0 0x1000>, 195*4882a593Smuzhiyun <0x0 0x50044000 0x0 0x2000>, 196*4882a593Smuzhiyun <0x0 0x50046000 0x0 0x2000>; 197*4882a593Smuzhiyun interrupts = <GIC_PPI 9 198*4882a593Smuzhiyun (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>; 199*4882a593Smuzhiyun interrupt-parent = <&gic>; 200*4882a593Smuzhiyun }; 201*4882a593Smuzhiyun 202*4882a593Smuzhiyun /* 203*4882a593Smuzhiyun * Please keep the following 0, notation in place as a former mainline 204*4882a593Smuzhiyun * U-Boot version was looking for that particular notation in order to 205*4882a593Smuzhiyun * perform required fix-ups on that GPU node. 206*4882a593Smuzhiyun */ 207*4882a593Smuzhiyun gpu@0,57000000 { 208*4882a593Smuzhiyun compatible = "nvidia,gk20a"; 209*4882a593Smuzhiyun reg = <0x0 0x57000000 0x0 0x01000000>, 210*4882a593Smuzhiyun <0x0 0x58000000 0x0 0x01000000>; 211*4882a593Smuzhiyun interrupts = <GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>, 212*4882a593Smuzhiyun <GIC_SPI 158 IRQ_TYPE_LEVEL_HIGH>; 213*4882a593Smuzhiyun interrupt-names = "stall", "nonstall"; 214*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_GPU>, 215*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_P_OUT5>; 216*4882a593Smuzhiyun clock-names = "gpu", "pwr"; 217*4882a593Smuzhiyun resets = <&tegra_car 184>; 218*4882a593Smuzhiyun reset-names = "gpu"; 219*4882a593Smuzhiyun 220*4882a593Smuzhiyun iommus = <&mc TEGRA_SWGROUP_GPU>; 221*4882a593Smuzhiyun 222*4882a593Smuzhiyun status = "disabled"; 223*4882a593Smuzhiyun }; 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun lic: interrupt-controller@60004000 { 226*4882a593Smuzhiyun compatible = "nvidia,tegra124-ictlr", "nvidia,tegra30-ictlr"; 227*4882a593Smuzhiyun reg = <0x0 0x60004000 0x0 0x100>, 228*4882a593Smuzhiyun <0x0 0x60004100 0x0 0x100>, 229*4882a593Smuzhiyun <0x0 0x60004200 0x0 0x100>, 230*4882a593Smuzhiyun <0x0 0x60004300 0x0 0x100>, 231*4882a593Smuzhiyun <0x0 0x60004400 0x0 0x100>; 232*4882a593Smuzhiyun interrupt-controller; 233*4882a593Smuzhiyun #interrupt-cells = <3>; 234*4882a593Smuzhiyun interrupt-parent = <&gic>; 235*4882a593Smuzhiyun }; 236*4882a593Smuzhiyun 237*4882a593Smuzhiyun timer@60005000 { 238*4882a593Smuzhiyun compatible = "nvidia,tegra124-timer", "nvidia,tegra30-timer", "nvidia,tegra20-timer"; 239*4882a593Smuzhiyun reg = <0x0 0x60005000 0x0 0x400>; 240*4882a593Smuzhiyun interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>, 241*4882a593Smuzhiyun <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>, 242*4882a593Smuzhiyun <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>, 243*4882a593Smuzhiyun <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>, 244*4882a593Smuzhiyun <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>, 245*4882a593Smuzhiyun <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>; 246*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_TIMER>; 247*4882a593Smuzhiyun }; 248*4882a593Smuzhiyun 249*4882a593Smuzhiyun tegra_car: clock@60006000 { 250*4882a593Smuzhiyun compatible = "nvidia,tegra124-car"; 251*4882a593Smuzhiyun reg = <0x0 0x60006000 0x0 0x1000>; 252*4882a593Smuzhiyun #clock-cells = <1>; 253*4882a593Smuzhiyun #reset-cells = <1>; 254*4882a593Smuzhiyun nvidia,external-memory-controller = <&emc>; 255*4882a593Smuzhiyun }; 256*4882a593Smuzhiyun 257*4882a593Smuzhiyun flow-controller@60007000 { 258*4882a593Smuzhiyun compatible = "nvidia,tegra124-flowctrl"; 259*4882a593Smuzhiyun reg = <0x0 0x60007000 0x0 0x1000>; 260*4882a593Smuzhiyun }; 261*4882a593Smuzhiyun 262*4882a593Smuzhiyun actmon@6000c800 { 263*4882a593Smuzhiyun compatible = "nvidia,tegra124-actmon"; 264*4882a593Smuzhiyun reg = <0x0 0x6000c800 0x0 0x400>; 265*4882a593Smuzhiyun interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>; 266*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_ACTMON>, 267*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_EMC>; 268*4882a593Smuzhiyun clock-names = "actmon", "emc"; 269*4882a593Smuzhiyun resets = <&tegra_car 119>; 270*4882a593Smuzhiyun reset-names = "actmon"; 271*4882a593Smuzhiyun }; 272*4882a593Smuzhiyun 273*4882a593Smuzhiyun gpio: gpio@6000d000 { 274*4882a593Smuzhiyun compatible = "nvidia,tegra124-gpio", "nvidia,tegra30-gpio"; 275*4882a593Smuzhiyun reg = <0x0 0x6000d000 0x0 0x1000>; 276*4882a593Smuzhiyun interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 277*4882a593Smuzhiyun <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>, 278*4882a593Smuzhiyun <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>, 279*4882a593Smuzhiyun <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>, 280*4882a593Smuzhiyun <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>, 281*4882a593Smuzhiyun <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>, 282*4882a593Smuzhiyun <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>, 283*4882a593Smuzhiyun <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>; 284*4882a593Smuzhiyun #gpio-cells = <2>; 285*4882a593Smuzhiyun gpio-controller; 286*4882a593Smuzhiyun #interrupt-cells = <2>; 287*4882a593Smuzhiyun interrupt-controller; 288*4882a593Smuzhiyun /* 289*4882a593Smuzhiyun gpio-ranges = <&pinmux 0 0 251>; 290*4882a593Smuzhiyun */ 291*4882a593Smuzhiyun }; 292*4882a593Smuzhiyun 293*4882a593Smuzhiyun apbdma: dma@60020000 { 294*4882a593Smuzhiyun compatible = "nvidia,tegra124-apbdma", "nvidia,tegra148-apbdma"; 295*4882a593Smuzhiyun reg = <0x0 0x60020000 0x0 0x1400>; 296*4882a593Smuzhiyun interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>, 297*4882a593Smuzhiyun <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>, 298*4882a593Smuzhiyun <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>, 299*4882a593Smuzhiyun <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>, 300*4882a593Smuzhiyun <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>, 301*4882a593Smuzhiyun <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>, 302*4882a593Smuzhiyun <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>, 303*4882a593Smuzhiyun <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>, 304*4882a593Smuzhiyun <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>, 305*4882a593Smuzhiyun <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>, 306*4882a593Smuzhiyun <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>, 307*4882a593Smuzhiyun <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>, 308*4882a593Smuzhiyun <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>, 309*4882a593Smuzhiyun <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>, 310*4882a593Smuzhiyun <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>, 311*4882a593Smuzhiyun <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>, 312*4882a593Smuzhiyun <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>, 313*4882a593Smuzhiyun <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>, 314*4882a593Smuzhiyun <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>, 315*4882a593Smuzhiyun <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>, 316*4882a593Smuzhiyun <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>, 317*4882a593Smuzhiyun <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>, 318*4882a593Smuzhiyun <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>, 319*4882a593Smuzhiyun <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>, 320*4882a593Smuzhiyun <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>, 321*4882a593Smuzhiyun <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>, 322*4882a593Smuzhiyun <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>, 323*4882a593Smuzhiyun <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>, 324*4882a593Smuzhiyun <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>, 325*4882a593Smuzhiyun <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>, 326*4882a593Smuzhiyun <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>, 327*4882a593Smuzhiyun <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>; 328*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_APBDMA>; 329*4882a593Smuzhiyun resets = <&tegra_car 34>; 330*4882a593Smuzhiyun reset-names = "dma"; 331*4882a593Smuzhiyun #dma-cells = <1>; 332*4882a593Smuzhiyun }; 333*4882a593Smuzhiyun 334*4882a593Smuzhiyun apbmisc@70000800 { 335*4882a593Smuzhiyun compatible = "nvidia,tegra124-apbmisc", "nvidia,tegra20-apbmisc"; 336*4882a593Smuzhiyun reg = <0x0 0x70000800 0x0 0x64>, /* Chip revision */ 337*4882a593Smuzhiyun <0x0 0x7000e864 0x0 0x04>; /* Strapping options */ 338*4882a593Smuzhiyun }; 339*4882a593Smuzhiyun 340*4882a593Smuzhiyun pinmux: pinmux@70000868 { 341*4882a593Smuzhiyun compatible = "nvidia,tegra124-pinmux"; 342*4882a593Smuzhiyun reg = <0x0 0x70000868 0x0 0x164>, /* Pad control registers */ 343*4882a593Smuzhiyun <0x0 0x70003000 0x0 0x434>, /* Mux registers */ 344*4882a593Smuzhiyun <0x0 0x70000820 0x0 0x008>; /* MIPI pad control */ 345*4882a593Smuzhiyun }; 346*4882a593Smuzhiyun 347*4882a593Smuzhiyun /* 348*4882a593Smuzhiyun * There are two serial driver i.e. 8250 based simple serial 349*4882a593Smuzhiyun * driver and APB DMA based serial driver for higher baudrate 350*4882a593Smuzhiyun * and performace. To enable the 8250 based driver, the compatible 351*4882a593Smuzhiyun * is "nvidia,tegra124-uart", "nvidia,tegra20-uart" and to enable 352*4882a593Smuzhiyun * the APB DMA based serial driver, the compatible is 353*4882a593Smuzhiyun * "nvidia,tegra124-hsuart", "nvidia,tegra30-hsuart". 354*4882a593Smuzhiyun */ 355*4882a593Smuzhiyun uarta: serial@70006000 { 356*4882a593Smuzhiyun compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart"; 357*4882a593Smuzhiyun reg = <0x0 0x70006000 0x0 0x40>; 358*4882a593Smuzhiyun reg-shift = <2>; 359*4882a593Smuzhiyun interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>; 360*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_UARTA>; 361*4882a593Smuzhiyun resets = <&tegra_car 6>; 362*4882a593Smuzhiyun reset-names = "serial"; 363*4882a593Smuzhiyun dmas = <&apbdma 8>, <&apbdma 8>; 364*4882a593Smuzhiyun dma-names = "rx", "tx"; 365*4882a593Smuzhiyun status = "disabled"; 366*4882a593Smuzhiyun }; 367*4882a593Smuzhiyun 368*4882a593Smuzhiyun uartb: serial@70006040 { 369*4882a593Smuzhiyun compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart"; 370*4882a593Smuzhiyun reg = <0x0 0x70006040 0x0 0x40>; 371*4882a593Smuzhiyun reg-shift = <2>; 372*4882a593Smuzhiyun interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>; 373*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_UARTB>; 374*4882a593Smuzhiyun resets = <&tegra_car 7>; 375*4882a593Smuzhiyun reset-names = "serial"; 376*4882a593Smuzhiyun dmas = <&apbdma 9>, <&apbdma 9>; 377*4882a593Smuzhiyun dma-names = "rx", "tx"; 378*4882a593Smuzhiyun status = "disabled"; 379*4882a593Smuzhiyun }; 380*4882a593Smuzhiyun 381*4882a593Smuzhiyun uartc: serial@70006200 { 382*4882a593Smuzhiyun compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart"; 383*4882a593Smuzhiyun reg = <0x0 0x70006200 0x0 0x40>; 384*4882a593Smuzhiyun reg-shift = <2>; 385*4882a593Smuzhiyun interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>; 386*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_UARTC>; 387*4882a593Smuzhiyun resets = <&tegra_car 55>; 388*4882a593Smuzhiyun reset-names = "serial"; 389*4882a593Smuzhiyun dmas = <&apbdma 10>, <&apbdma 10>; 390*4882a593Smuzhiyun dma-names = "rx", "tx"; 391*4882a593Smuzhiyun status = "disabled"; 392*4882a593Smuzhiyun }; 393*4882a593Smuzhiyun 394*4882a593Smuzhiyun uartd: serial@70006300 { 395*4882a593Smuzhiyun compatible = "nvidia,tegra124-uart", "nvidia,tegra20-uart"; 396*4882a593Smuzhiyun reg = <0x0 0x70006300 0x0 0x40>; 397*4882a593Smuzhiyun reg-shift = <2>; 398*4882a593Smuzhiyun interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>; 399*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_UARTD>; 400*4882a593Smuzhiyun resets = <&tegra_car 65>; 401*4882a593Smuzhiyun reset-names = "serial"; 402*4882a593Smuzhiyun dmas = <&apbdma 19>, <&apbdma 19>; 403*4882a593Smuzhiyun dma-names = "rx", "tx"; 404*4882a593Smuzhiyun status = "disabled"; 405*4882a593Smuzhiyun }; 406*4882a593Smuzhiyun 407*4882a593Smuzhiyun pwm: pwm@7000a000 { 408*4882a593Smuzhiyun compatible = "nvidia,tegra124-pwm", "nvidia,tegra20-pwm"; 409*4882a593Smuzhiyun reg = <0x0 0x7000a000 0x0 0x100>; 410*4882a593Smuzhiyun #pwm-cells = <2>; 411*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_PWM>; 412*4882a593Smuzhiyun resets = <&tegra_car 17>; 413*4882a593Smuzhiyun reset-names = "pwm"; 414*4882a593Smuzhiyun status = "disabled"; 415*4882a593Smuzhiyun }; 416*4882a593Smuzhiyun 417*4882a593Smuzhiyun i2c@7000c000 { 418*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c"; 419*4882a593Smuzhiyun reg = <0x0 0x7000c000 0x0 0x100>; 420*4882a593Smuzhiyun interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>; 421*4882a593Smuzhiyun #address-cells = <1>; 422*4882a593Smuzhiyun #size-cells = <0>; 423*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2C1>; 424*4882a593Smuzhiyun clock-names = "div-clk"; 425*4882a593Smuzhiyun resets = <&tegra_car 12>; 426*4882a593Smuzhiyun reset-names = "i2c"; 427*4882a593Smuzhiyun dmas = <&apbdma 21>, <&apbdma 21>; 428*4882a593Smuzhiyun dma-names = "rx", "tx"; 429*4882a593Smuzhiyun status = "disabled"; 430*4882a593Smuzhiyun }; 431*4882a593Smuzhiyun 432*4882a593Smuzhiyun i2c@7000c400 { 433*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c"; 434*4882a593Smuzhiyun reg = <0x0 0x7000c400 0x0 0x100>; 435*4882a593Smuzhiyun interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>; 436*4882a593Smuzhiyun #address-cells = <1>; 437*4882a593Smuzhiyun #size-cells = <0>; 438*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2C2>; 439*4882a593Smuzhiyun clock-names = "div-clk"; 440*4882a593Smuzhiyun resets = <&tegra_car 54>; 441*4882a593Smuzhiyun reset-names = "i2c"; 442*4882a593Smuzhiyun dmas = <&apbdma 22>, <&apbdma 22>; 443*4882a593Smuzhiyun dma-names = "rx", "tx"; 444*4882a593Smuzhiyun status = "disabled"; 445*4882a593Smuzhiyun }; 446*4882a593Smuzhiyun 447*4882a593Smuzhiyun i2c@7000c500 { 448*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c"; 449*4882a593Smuzhiyun reg = <0x0 0x7000c500 0x0 0x100>; 450*4882a593Smuzhiyun interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>; 451*4882a593Smuzhiyun #address-cells = <1>; 452*4882a593Smuzhiyun #size-cells = <0>; 453*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2C3>; 454*4882a593Smuzhiyun clock-names = "div-clk"; 455*4882a593Smuzhiyun resets = <&tegra_car 67>; 456*4882a593Smuzhiyun reset-names = "i2c"; 457*4882a593Smuzhiyun dmas = <&apbdma 23>, <&apbdma 23>; 458*4882a593Smuzhiyun dma-names = "rx", "tx"; 459*4882a593Smuzhiyun status = "disabled"; 460*4882a593Smuzhiyun }; 461*4882a593Smuzhiyun 462*4882a593Smuzhiyun i2c@7000c700 { 463*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c"; 464*4882a593Smuzhiyun reg = <0x0 0x7000c700 0x0 0x100>; 465*4882a593Smuzhiyun interrupts = <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>; 466*4882a593Smuzhiyun #address-cells = <1>; 467*4882a593Smuzhiyun #size-cells = <0>; 468*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2C4>; 469*4882a593Smuzhiyun clock-names = "div-clk"; 470*4882a593Smuzhiyun resets = <&tegra_car 103>; 471*4882a593Smuzhiyun reset-names = "i2c"; 472*4882a593Smuzhiyun dmas = <&apbdma 26>, <&apbdma 26>; 473*4882a593Smuzhiyun dma-names = "rx", "tx"; 474*4882a593Smuzhiyun status = "disabled"; 475*4882a593Smuzhiyun }; 476*4882a593Smuzhiyun 477*4882a593Smuzhiyun i2c@7000d000 { 478*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c"; 479*4882a593Smuzhiyun reg = <0x0 0x7000d000 0x0 0x100>; 480*4882a593Smuzhiyun interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>; 481*4882a593Smuzhiyun #address-cells = <1>; 482*4882a593Smuzhiyun #size-cells = <0>; 483*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2C5>; 484*4882a593Smuzhiyun clock-names = "div-clk"; 485*4882a593Smuzhiyun resets = <&tegra_car 47>; 486*4882a593Smuzhiyun reset-names = "i2c"; 487*4882a593Smuzhiyun dmas = <&apbdma 24>, <&apbdma 24>; 488*4882a593Smuzhiyun dma-names = "rx", "tx"; 489*4882a593Smuzhiyun status = "disabled"; 490*4882a593Smuzhiyun }; 491*4882a593Smuzhiyun 492*4882a593Smuzhiyun i2c@7000d100 { 493*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2c", "nvidia,tegra114-i2c"; 494*4882a593Smuzhiyun reg = <0x0 0x7000d100 0x0 0x100>; 495*4882a593Smuzhiyun interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>; 496*4882a593Smuzhiyun #address-cells = <1>; 497*4882a593Smuzhiyun #size-cells = <0>; 498*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2C6>; 499*4882a593Smuzhiyun clock-names = "div-clk"; 500*4882a593Smuzhiyun resets = <&tegra_car 166>; 501*4882a593Smuzhiyun reset-names = "i2c"; 502*4882a593Smuzhiyun dmas = <&apbdma 30>, <&apbdma 30>; 503*4882a593Smuzhiyun dma-names = "rx", "tx"; 504*4882a593Smuzhiyun status = "disabled"; 505*4882a593Smuzhiyun }; 506*4882a593Smuzhiyun 507*4882a593Smuzhiyun spi@7000d400 { 508*4882a593Smuzhiyun compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi"; 509*4882a593Smuzhiyun reg = <0x0 0x7000d400 0x0 0x200>; 510*4882a593Smuzhiyun interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>; 511*4882a593Smuzhiyun #address-cells = <1>; 512*4882a593Smuzhiyun #size-cells = <0>; 513*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SBC1>; 514*4882a593Smuzhiyun clock-names = "spi"; 515*4882a593Smuzhiyun resets = <&tegra_car 41>; 516*4882a593Smuzhiyun reset-names = "spi"; 517*4882a593Smuzhiyun dmas = <&apbdma 15>, <&apbdma 15>; 518*4882a593Smuzhiyun dma-names = "rx", "tx"; 519*4882a593Smuzhiyun status = "disabled"; 520*4882a593Smuzhiyun }; 521*4882a593Smuzhiyun 522*4882a593Smuzhiyun spi@7000d600 { 523*4882a593Smuzhiyun compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi"; 524*4882a593Smuzhiyun reg = <0x0 0x7000d600 0x0 0x200>; 525*4882a593Smuzhiyun interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>; 526*4882a593Smuzhiyun #address-cells = <1>; 527*4882a593Smuzhiyun #size-cells = <0>; 528*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SBC2>; 529*4882a593Smuzhiyun clock-names = "spi"; 530*4882a593Smuzhiyun resets = <&tegra_car 44>; 531*4882a593Smuzhiyun reset-names = "spi"; 532*4882a593Smuzhiyun dmas = <&apbdma 16>, <&apbdma 16>; 533*4882a593Smuzhiyun dma-names = "rx", "tx"; 534*4882a593Smuzhiyun status = "disabled"; 535*4882a593Smuzhiyun }; 536*4882a593Smuzhiyun 537*4882a593Smuzhiyun spi@7000d800 { 538*4882a593Smuzhiyun compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi"; 539*4882a593Smuzhiyun reg = <0x0 0x7000d800 0x0 0x200>; 540*4882a593Smuzhiyun interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>; 541*4882a593Smuzhiyun #address-cells = <1>; 542*4882a593Smuzhiyun #size-cells = <0>; 543*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SBC3>; 544*4882a593Smuzhiyun clock-names = "spi"; 545*4882a593Smuzhiyun resets = <&tegra_car 46>; 546*4882a593Smuzhiyun reset-names = "spi"; 547*4882a593Smuzhiyun dmas = <&apbdma 17>, <&apbdma 17>; 548*4882a593Smuzhiyun dma-names = "rx", "tx"; 549*4882a593Smuzhiyun status = "disabled"; 550*4882a593Smuzhiyun }; 551*4882a593Smuzhiyun 552*4882a593Smuzhiyun spi@7000da00 { 553*4882a593Smuzhiyun compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi"; 554*4882a593Smuzhiyun reg = <0x0 0x7000da00 0x0 0x200>; 555*4882a593Smuzhiyun interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>; 556*4882a593Smuzhiyun #address-cells = <1>; 557*4882a593Smuzhiyun #size-cells = <0>; 558*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SBC4>; 559*4882a593Smuzhiyun clock-names = "spi"; 560*4882a593Smuzhiyun resets = <&tegra_car 68>; 561*4882a593Smuzhiyun reset-names = "spi"; 562*4882a593Smuzhiyun dmas = <&apbdma 18>, <&apbdma 18>; 563*4882a593Smuzhiyun dma-names = "rx", "tx"; 564*4882a593Smuzhiyun status = "disabled"; 565*4882a593Smuzhiyun }; 566*4882a593Smuzhiyun 567*4882a593Smuzhiyun spi@7000dc00 { 568*4882a593Smuzhiyun compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi"; 569*4882a593Smuzhiyun reg = <0x0 0x7000dc00 0x0 0x200>; 570*4882a593Smuzhiyun interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>; 571*4882a593Smuzhiyun #address-cells = <1>; 572*4882a593Smuzhiyun #size-cells = <0>; 573*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SBC5>; 574*4882a593Smuzhiyun clock-names = "spi"; 575*4882a593Smuzhiyun resets = <&tegra_car 104>; 576*4882a593Smuzhiyun reset-names = "spi"; 577*4882a593Smuzhiyun dmas = <&apbdma 27>, <&apbdma 27>; 578*4882a593Smuzhiyun dma-names = "rx", "tx"; 579*4882a593Smuzhiyun status = "disabled"; 580*4882a593Smuzhiyun }; 581*4882a593Smuzhiyun 582*4882a593Smuzhiyun spi@7000de00 { 583*4882a593Smuzhiyun compatible = "nvidia,tegra124-spi", "nvidia,tegra114-spi"; 584*4882a593Smuzhiyun reg = <0x0 0x7000de00 0x0 0x200>; 585*4882a593Smuzhiyun interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>; 586*4882a593Smuzhiyun #address-cells = <1>; 587*4882a593Smuzhiyun #size-cells = <0>; 588*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SBC6>; 589*4882a593Smuzhiyun clock-names = "spi"; 590*4882a593Smuzhiyun resets = <&tegra_car 105>; 591*4882a593Smuzhiyun reset-names = "spi"; 592*4882a593Smuzhiyun dmas = <&apbdma 28>, <&apbdma 28>; 593*4882a593Smuzhiyun dma-names = "rx", "tx"; 594*4882a593Smuzhiyun status = "disabled"; 595*4882a593Smuzhiyun }; 596*4882a593Smuzhiyun 597*4882a593Smuzhiyun rtc@7000e000 { 598*4882a593Smuzhiyun compatible = "nvidia,tegra124-rtc", "nvidia,tegra20-rtc"; 599*4882a593Smuzhiyun reg = <0x0 0x7000e000 0x0 0x100>; 600*4882a593Smuzhiyun interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; 601*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_RTC>; 602*4882a593Smuzhiyun }; 603*4882a593Smuzhiyun 604*4882a593Smuzhiyun tegra_pmc: pmc@7000e400 { 605*4882a593Smuzhiyun compatible = "nvidia,tegra124-pmc"; 606*4882a593Smuzhiyun reg = <0x0 0x7000e400 0x0 0x400>; 607*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_PCLK>, <&clk32k_in>; 608*4882a593Smuzhiyun clock-names = "pclk", "clk32k_in"; 609*4882a593Smuzhiyun #clock-cells = <1>; 610*4882a593Smuzhiyun }; 611*4882a593Smuzhiyun 612*4882a593Smuzhiyun fuse@7000f800 { 613*4882a593Smuzhiyun compatible = "nvidia,tegra124-efuse"; 614*4882a593Smuzhiyun reg = <0x0 0x7000f800 0x0 0x400>; 615*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_FUSE>; 616*4882a593Smuzhiyun clock-names = "fuse"; 617*4882a593Smuzhiyun resets = <&tegra_car 39>; 618*4882a593Smuzhiyun reset-names = "fuse"; 619*4882a593Smuzhiyun }; 620*4882a593Smuzhiyun 621*4882a593Smuzhiyun mc: memory-controller@70019000 { 622*4882a593Smuzhiyun compatible = "nvidia,tegra124-mc"; 623*4882a593Smuzhiyun reg = <0x0 0x70019000 0x0 0x1000>; 624*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_MC>; 625*4882a593Smuzhiyun clock-names = "mc"; 626*4882a593Smuzhiyun 627*4882a593Smuzhiyun interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>; 628*4882a593Smuzhiyun 629*4882a593Smuzhiyun #iommu-cells = <1>; 630*4882a593Smuzhiyun #reset-cells = <1>; 631*4882a593Smuzhiyun }; 632*4882a593Smuzhiyun 633*4882a593Smuzhiyun emc: external-memory-controller@7001b000 { 634*4882a593Smuzhiyun compatible = "nvidia,tegra124-emc"; 635*4882a593Smuzhiyun reg = <0x0 0x7001b000 0x0 0x1000>; 636*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_EMC>; 637*4882a593Smuzhiyun clock-names = "emc"; 638*4882a593Smuzhiyun 639*4882a593Smuzhiyun nvidia,memory-controller = <&mc>; 640*4882a593Smuzhiyun }; 641*4882a593Smuzhiyun 642*4882a593Smuzhiyun sata@70020000 { 643*4882a593Smuzhiyun compatible = "nvidia,tegra124-ahci"; 644*4882a593Smuzhiyun reg = <0x0 0x70027000 0x0 0x2000>, /* AHCI */ 645*4882a593Smuzhiyun <0x0 0x70020000 0x0 0x7000>; /* SATA */ 646*4882a593Smuzhiyun interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>; 647*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SATA>, 648*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_SATA_OOB>, 649*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_CML1>, 650*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_E>; 651*4882a593Smuzhiyun clock-names = "sata", "sata-oob", "cml1", "pll_e"; 652*4882a593Smuzhiyun resets = <&tegra_car 124>, 653*4882a593Smuzhiyun <&tegra_car 123>, 654*4882a593Smuzhiyun <&tegra_car 129>; 655*4882a593Smuzhiyun reset-names = "sata", "sata-oob", "sata-cold"; 656*4882a593Smuzhiyun status = "disabled"; 657*4882a593Smuzhiyun }; 658*4882a593Smuzhiyun 659*4882a593Smuzhiyun hda@70030000 { 660*4882a593Smuzhiyun compatible = "nvidia,tegra124-hda", "nvidia,tegra30-hda"; 661*4882a593Smuzhiyun reg = <0x0 0x70030000 0x0 0x10000>; 662*4882a593Smuzhiyun interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>; 663*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_HDA>, 664*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_HDA2HDMI>, 665*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_HDA2CODEC_2X>; 666*4882a593Smuzhiyun clock-names = "hda", "hda2hdmi", "hda2codec_2x"; 667*4882a593Smuzhiyun resets = <&tegra_car 125>, /* hda */ 668*4882a593Smuzhiyun <&tegra_car 128>, /* hda2hdmi */ 669*4882a593Smuzhiyun <&tegra_car 111>; /* hda2codec_2x */ 670*4882a593Smuzhiyun reset-names = "hda", "hda2hdmi", "hda2codec_2x"; 671*4882a593Smuzhiyun status = "disabled"; 672*4882a593Smuzhiyun }; 673*4882a593Smuzhiyun 674*4882a593Smuzhiyun usb@70090000 { 675*4882a593Smuzhiyun compatible = "nvidia,tegra124-xusb"; 676*4882a593Smuzhiyun reg = <0x0 0x70090000 0x0 0x8000>, 677*4882a593Smuzhiyun <0x0 0x70098000 0x0 0x1000>, 678*4882a593Smuzhiyun <0x0 0x70099000 0x0 0x1000>; 679*4882a593Smuzhiyun reg-names = "hcd", "fpci", "ipfs"; 680*4882a593Smuzhiyun 681*4882a593Smuzhiyun interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>, 682*4882a593Smuzhiyun <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>; 683*4882a593Smuzhiyun 684*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_XUSB_HOST>, 685*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_HOST_SRC>, 686*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_FALCON_SRC>, 687*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_SS>, 688*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_SS_SRC>, 689*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_SS_DIV2>, 690*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_HS_SRC>, 691*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_XUSB_FS_SRC>, 692*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_U_480M>, 693*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_CLK_M>, 694*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_E>; 695*4882a593Smuzhiyun clock-names = "xusb_host", "xusb_host_src", 696*4882a593Smuzhiyun "xusb_falcon_src", "xusb_ss", 697*4882a593Smuzhiyun "xusb_ss_src", "xusb_ss_div2", 698*4882a593Smuzhiyun "xusb_hs_src", "xusb_fs_src", 699*4882a593Smuzhiyun "pll_u_480m", "clk_m", "pll_e"; 700*4882a593Smuzhiyun resets = <&tegra_car 89>, <&tegra_car 156>, 701*4882a593Smuzhiyun <&tegra_car 143>; 702*4882a593Smuzhiyun reset-names = "xusb_host", "xusb_ss", "xusb_src"; 703*4882a593Smuzhiyun 704*4882a593Smuzhiyun nvidia,xusb-padctl = <&padctl>; 705*4882a593Smuzhiyun 706*4882a593Smuzhiyun status = "disabled"; 707*4882a593Smuzhiyun }; 708*4882a593Smuzhiyun 709*4882a593Smuzhiyun padctl: padctl@7009f000 { 710*4882a593Smuzhiyun compatible = "nvidia,tegra124-xusb-padctl"; 711*4882a593Smuzhiyun reg = <0x0 0x7009f000 0x0 0x1000>; 712*4882a593Smuzhiyun resets = <&tegra_car 142>; 713*4882a593Smuzhiyun reset-names = "padctl"; 714*4882a593Smuzhiyun 715*4882a593Smuzhiyun pads { 716*4882a593Smuzhiyun usb2 { 717*4882a593Smuzhiyun status = "disabled"; 718*4882a593Smuzhiyun 719*4882a593Smuzhiyun lanes { 720*4882a593Smuzhiyun usb2-0 { 721*4882a593Smuzhiyun status = "disabled"; 722*4882a593Smuzhiyun #phy-cells = <0>; 723*4882a593Smuzhiyun }; 724*4882a593Smuzhiyun 725*4882a593Smuzhiyun usb2-1 { 726*4882a593Smuzhiyun status = "disabled"; 727*4882a593Smuzhiyun #phy-cells = <0>; 728*4882a593Smuzhiyun }; 729*4882a593Smuzhiyun 730*4882a593Smuzhiyun usb2-2 { 731*4882a593Smuzhiyun status = "disabled"; 732*4882a593Smuzhiyun #phy-cells = <0>; 733*4882a593Smuzhiyun }; 734*4882a593Smuzhiyun }; 735*4882a593Smuzhiyun }; 736*4882a593Smuzhiyun 737*4882a593Smuzhiyun ulpi { 738*4882a593Smuzhiyun status = "disabled"; 739*4882a593Smuzhiyun 740*4882a593Smuzhiyun lanes { 741*4882a593Smuzhiyun ulpi-0 { 742*4882a593Smuzhiyun status = "disabled"; 743*4882a593Smuzhiyun #phy-cells = <0>; 744*4882a593Smuzhiyun }; 745*4882a593Smuzhiyun }; 746*4882a593Smuzhiyun }; 747*4882a593Smuzhiyun 748*4882a593Smuzhiyun hsic { 749*4882a593Smuzhiyun status = "disabled"; 750*4882a593Smuzhiyun 751*4882a593Smuzhiyun lanes { 752*4882a593Smuzhiyun hsic-0 { 753*4882a593Smuzhiyun status = "disabled"; 754*4882a593Smuzhiyun #phy-cells = <0>; 755*4882a593Smuzhiyun }; 756*4882a593Smuzhiyun 757*4882a593Smuzhiyun hsic-1 { 758*4882a593Smuzhiyun status = "disabled"; 759*4882a593Smuzhiyun #phy-cells = <0>; 760*4882a593Smuzhiyun }; 761*4882a593Smuzhiyun }; 762*4882a593Smuzhiyun }; 763*4882a593Smuzhiyun 764*4882a593Smuzhiyun pcie { 765*4882a593Smuzhiyun status = "disabled"; 766*4882a593Smuzhiyun 767*4882a593Smuzhiyun lanes { 768*4882a593Smuzhiyun pcie-0 { 769*4882a593Smuzhiyun status = "disabled"; 770*4882a593Smuzhiyun #phy-cells = <0>; 771*4882a593Smuzhiyun }; 772*4882a593Smuzhiyun 773*4882a593Smuzhiyun pcie-1 { 774*4882a593Smuzhiyun status = "disabled"; 775*4882a593Smuzhiyun #phy-cells = <0>; 776*4882a593Smuzhiyun }; 777*4882a593Smuzhiyun 778*4882a593Smuzhiyun pcie-2 { 779*4882a593Smuzhiyun status = "disabled"; 780*4882a593Smuzhiyun #phy-cells = <0>; 781*4882a593Smuzhiyun }; 782*4882a593Smuzhiyun 783*4882a593Smuzhiyun pcie-3 { 784*4882a593Smuzhiyun status = "disabled"; 785*4882a593Smuzhiyun #phy-cells = <0>; 786*4882a593Smuzhiyun }; 787*4882a593Smuzhiyun 788*4882a593Smuzhiyun pcie-4 { 789*4882a593Smuzhiyun status = "disabled"; 790*4882a593Smuzhiyun #phy-cells = <0>; 791*4882a593Smuzhiyun }; 792*4882a593Smuzhiyun }; 793*4882a593Smuzhiyun }; 794*4882a593Smuzhiyun 795*4882a593Smuzhiyun sata { 796*4882a593Smuzhiyun status = "disabled"; 797*4882a593Smuzhiyun 798*4882a593Smuzhiyun lanes { 799*4882a593Smuzhiyun sata-0 { 800*4882a593Smuzhiyun status = "disabled"; 801*4882a593Smuzhiyun #phy-cells = <0>; 802*4882a593Smuzhiyun }; 803*4882a593Smuzhiyun }; 804*4882a593Smuzhiyun }; 805*4882a593Smuzhiyun }; 806*4882a593Smuzhiyun 807*4882a593Smuzhiyun ports { 808*4882a593Smuzhiyun usb2-0 { 809*4882a593Smuzhiyun status = "disabled"; 810*4882a593Smuzhiyun }; 811*4882a593Smuzhiyun 812*4882a593Smuzhiyun usb2-1 { 813*4882a593Smuzhiyun status = "disabled"; 814*4882a593Smuzhiyun }; 815*4882a593Smuzhiyun 816*4882a593Smuzhiyun usb2-2 { 817*4882a593Smuzhiyun status = "disabled"; 818*4882a593Smuzhiyun }; 819*4882a593Smuzhiyun 820*4882a593Smuzhiyun ulpi-0 { 821*4882a593Smuzhiyun status = "disabled"; 822*4882a593Smuzhiyun }; 823*4882a593Smuzhiyun 824*4882a593Smuzhiyun hsic-0 { 825*4882a593Smuzhiyun status = "disabled"; 826*4882a593Smuzhiyun }; 827*4882a593Smuzhiyun 828*4882a593Smuzhiyun hsic-1 { 829*4882a593Smuzhiyun status = "disabled"; 830*4882a593Smuzhiyun }; 831*4882a593Smuzhiyun 832*4882a593Smuzhiyun usb3-0 { 833*4882a593Smuzhiyun status = "disabled"; 834*4882a593Smuzhiyun }; 835*4882a593Smuzhiyun 836*4882a593Smuzhiyun usb3-1 { 837*4882a593Smuzhiyun status = "disabled"; 838*4882a593Smuzhiyun }; 839*4882a593Smuzhiyun }; 840*4882a593Smuzhiyun }; 841*4882a593Smuzhiyun 842*4882a593Smuzhiyun mmc@700b0000 { 843*4882a593Smuzhiyun compatible = "nvidia,tegra124-sdhci"; 844*4882a593Smuzhiyun reg = <0x0 0x700b0000 0x0 0x200>; 845*4882a593Smuzhiyun interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>; 846*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SDMMC1>; 847*4882a593Smuzhiyun clock-names = "sdhci"; 848*4882a593Smuzhiyun resets = <&tegra_car 14>; 849*4882a593Smuzhiyun reset-names = "sdhci"; 850*4882a593Smuzhiyun status = "disabled"; 851*4882a593Smuzhiyun }; 852*4882a593Smuzhiyun 853*4882a593Smuzhiyun mmc@700b0200 { 854*4882a593Smuzhiyun compatible = "nvidia,tegra124-sdhci"; 855*4882a593Smuzhiyun reg = <0x0 0x700b0200 0x0 0x200>; 856*4882a593Smuzhiyun interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>; 857*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SDMMC2>; 858*4882a593Smuzhiyun clock-names = "sdhci"; 859*4882a593Smuzhiyun resets = <&tegra_car 9>; 860*4882a593Smuzhiyun reset-names = "sdhci"; 861*4882a593Smuzhiyun status = "disabled"; 862*4882a593Smuzhiyun }; 863*4882a593Smuzhiyun 864*4882a593Smuzhiyun mmc@700b0400 { 865*4882a593Smuzhiyun compatible = "nvidia,tegra124-sdhci"; 866*4882a593Smuzhiyun reg = <0x0 0x700b0400 0x0 0x200>; 867*4882a593Smuzhiyun interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>; 868*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SDMMC3>; 869*4882a593Smuzhiyun clock-names = "sdhci"; 870*4882a593Smuzhiyun resets = <&tegra_car 69>; 871*4882a593Smuzhiyun reset-names = "sdhci"; 872*4882a593Smuzhiyun status = "disabled"; 873*4882a593Smuzhiyun }; 874*4882a593Smuzhiyun 875*4882a593Smuzhiyun mmc@700b0600 { 876*4882a593Smuzhiyun compatible = "nvidia,tegra124-sdhci"; 877*4882a593Smuzhiyun reg = <0x0 0x700b0600 0x0 0x200>; 878*4882a593Smuzhiyun interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>; 879*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_SDMMC4>; 880*4882a593Smuzhiyun clock-names = "sdhci"; 881*4882a593Smuzhiyun resets = <&tegra_car 15>; 882*4882a593Smuzhiyun reset-names = "sdhci"; 883*4882a593Smuzhiyun status = "disabled"; 884*4882a593Smuzhiyun }; 885*4882a593Smuzhiyun 886*4882a593Smuzhiyun cec@70015000 { 887*4882a593Smuzhiyun compatible = "nvidia,tegra124-cec"; 888*4882a593Smuzhiyun reg = <0x0 0x70015000 0x0 0x00001000>; 889*4882a593Smuzhiyun interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; 890*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_CEC>; 891*4882a593Smuzhiyun clock-names = "cec"; 892*4882a593Smuzhiyun status = "disabled"; 893*4882a593Smuzhiyun hdmi-phandle = <&hdmi>; 894*4882a593Smuzhiyun }; 895*4882a593Smuzhiyun 896*4882a593Smuzhiyun soctherm: thermal-sensor@700e2000 { 897*4882a593Smuzhiyun compatible = "nvidia,tegra124-soctherm"; 898*4882a593Smuzhiyun reg = <0x0 0x700e2000 0x0 0x600>, /* SOC_THERM reg_base */ 899*4882a593Smuzhiyun <0x0 0x60006000 0x0 0x400>; /* CAR reg_base */ 900*4882a593Smuzhiyun reg-names = "soctherm-reg", "car-reg"; 901*4882a593Smuzhiyun interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>; 902*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_TSENSOR>, 903*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_SOC_THERM>; 904*4882a593Smuzhiyun clock-names = "tsensor", "soctherm"; 905*4882a593Smuzhiyun resets = <&tegra_car 78>; 906*4882a593Smuzhiyun reset-names = "soctherm"; 907*4882a593Smuzhiyun #thermal-sensor-cells = <1>; 908*4882a593Smuzhiyun 909*4882a593Smuzhiyun throttle-cfgs { 910*4882a593Smuzhiyun throttle_heavy: heavy { 911*4882a593Smuzhiyun nvidia,priority = <100>; 912*4882a593Smuzhiyun nvidia,cpu-throt-percent = <85>; 913*4882a593Smuzhiyun 914*4882a593Smuzhiyun #cooling-cells = <2>; 915*4882a593Smuzhiyun }; 916*4882a593Smuzhiyun }; 917*4882a593Smuzhiyun }; 918*4882a593Smuzhiyun 919*4882a593Smuzhiyun dfll: clock@70110000 { 920*4882a593Smuzhiyun compatible = "nvidia,tegra124-dfll"; 921*4882a593Smuzhiyun reg = <0 0x70110000 0 0x100>, /* DFLL control */ 922*4882a593Smuzhiyun <0 0x70110000 0 0x100>, /* I2C output control */ 923*4882a593Smuzhiyun <0 0x70110100 0 0x100>, /* Integrated I2C controller */ 924*4882a593Smuzhiyun <0 0x70110200 0 0x100>; /* Look-up table RAM */ 925*4882a593Smuzhiyun interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>; 926*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_DFLL_SOC>, 927*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_DFLL_REF>, 928*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_I2C5>; 929*4882a593Smuzhiyun clock-names = "soc", "ref", "i2c"; 930*4882a593Smuzhiyun resets = <&tegra_car TEGRA124_RST_DFLL_DVCO>; 931*4882a593Smuzhiyun reset-names = "dvco"; 932*4882a593Smuzhiyun #clock-cells = <0>; 933*4882a593Smuzhiyun clock-output-names = "dfllCPU_out"; 934*4882a593Smuzhiyun nvidia,sample-rate = <12500>; 935*4882a593Smuzhiyun nvidia,droop-ctrl = <0x00000f00>; 936*4882a593Smuzhiyun nvidia,force-mode = <1>; 937*4882a593Smuzhiyun nvidia,cf = <10>; 938*4882a593Smuzhiyun nvidia,ci = <0>; 939*4882a593Smuzhiyun nvidia,cg = <2>; 940*4882a593Smuzhiyun status = "disabled"; 941*4882a593Smuzhiyun }; 942*4882a593Smuzhiyun 943*4882a593Smuzhiyun ahub@70300000 { 944*4882a593Smuzhiyun compatible = "nvidia,tegra124-ahub"; 945*4882a593Smuzhiyun reg = <0x0 0x70300000 0x0 0x200>, 946*4882a593Smuzhiyun <0x0 0x70300800 0x0 0x800>, 947*4882a593Smuzhiyun <0x0 0x70300200 0x0 0x600>; 948*4882a593Smuzhiyun interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>; 949*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_D_AUDIO>, 950*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_APBIF>; 951*4882a593Smuzhiyun clock-names = "d_audio", "apbif"; 952*4882a593Smuzhiyun resets = <&tegra_car 106>, /* d_audio */ 953*4882a593Smuzhiyun <&tegra_car 107>, /* apbif */ 954*4882a593Smuzhiyun <&tegra_car 30>, /* i2s0 */ 955*4882a593Smuzhiyun <&tegra_car 11>, /* i2s1 */ 956*4882a593Smuzhiyun <&tegra_car 18>, /* i2s2 */ 957*4882a593Smuzhiyun <&tegra_car 101>, /* i2s3 */ 958*4882a593Smuzhiyun <&tegra_car 102>, /* i2s4 */ 959*4882a593Smuzhiyun <&tegra_car 108>, /* dam0 */ 960*4882a593Smuzhiyun <&tegra_car 109>, /* dam1 */ 961*4882a593Smuzhiyun <&tegra_car 110>, /* dam2 */ 962*4882a593Smuzhiyun <&tegra_car 10>, /* spdif */ 963*4882a593Smuzhiyun <&tegra_car 153>, /* amx */ 964*4882a593Smuzhiyun <&tegra_car 185>, /* amx1 */ 965*4882a593Smuzhiyun <&tegra_car 154>, /* adx */ 966*4882a593Smuzhiyun <&tegra_car 180>, /* adx1 */ 967*4882a593Smuzhiyun <&tegra_car 186>, /* afc0 */ 968*4882a593Smuzhiyun <&tegra_car 187>, /* afc1 */ 969*4882a593Smuzhiyun <&tegra_car 188>, /* afc2 */ 970*4882a593Smuzhiyun <&tegra_car 189>, /* afc3 */ 971*4882a593Smuzhiyun <&tegra_car 190>, /* afc4 */ 972*4882a593Smuzhiyun <&tegra_car 191>; /* afc5 */ 973*4882a593Smuzhiyun reset-names = "d_audio", "apbif", "i2s0", "i2s1", "i2s2", 974*4882a593Smuzhiyun "i2s3", "i2s4", "dam0", "dam1", "dam2", 975*4882a593Smuzhiyun "spdif", "amx", "amx1", "adx", "adx1", 976*4882a593Smuzhiyun "afc0", "afc1", "afc2", "afc3", "afc4", "afc5"; 977*4882a593Smuzhiyun dmas = <&apbdma 1>, <&apbdma 1>, 978*4882a593Smuzhiyun <&apbdma 2>, <&apbdma 2>, 979*4882a593Smuzhiyun <&apbdma 3>, <&apbdma 3>, 980*4882a593Smuzhiyun <&apbdma 4>, <&apbdma 4>, 981*4882a593Smuzhiyun <&apbdma 6>, <&apbdma 6>, 982*4882a593Smuzhiyun <&apbdma 7>, <&apbdma 7>, 983*4882a593Smuzhiyun <&apbdma 12>, <&apbdma 12>, 984*4882a593Smuzhiyun <&apbdma 13>, <&apbdma 13>, 985*4882a593Smuzhiyun <&apbdma 14>, <&apbdma 14>, 986*4882a593Smuzhiyun <&apbdma 29>, <&apbdma 29>; 987*4882a593Smuzhiyun dma-names = "rx0", "tx0", "rx1", "tx1", "rx2", "tx2", 988*4882a593Smuzhiyun "rx3", "tx3", "rx4", "tx4", "rx5", "tx5", 989*4882a593Smuzhiyun "rx6", "tx6", "rx7", "tx7", "rx8", "tx8", 990*4882a593Smuzhiyun "rx9", "tx9"; 991*4882a593Smuzhiyun ranges; 992*4882a593Smuzhiyun #address-cells = <2>; 993*4882a593Smuzhiyun #size-cells = <2>; 994*4882a593Smuzhiyun 995*4882a593Smuzhiyun tegra_i2s0: i2s@70301000 { 996*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2s"; 997*4882a593Smuzhiyun reg = <0x0 0x70301000 0x0 0x100>; 998*4882a593Smuzhiyun nvidia,ahub-cif-ids = <4 4>; 999*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2S0>; 1000*4882a593Smuzhiyun resets = <&tegra_car 30>; 1001*4882a593Smuzhiyun reset-names = "i2s"; 1002*4882a593Smuzhiyun status = "disabled"; 1003*4882a593Smuzhiyun }; 1004*4882a593Smuzhiyun 1005*4882a593Smuzhiyun tegra_i2s1: i2s@70301100 { 1006*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2s"; 1007*4882a593Smuzhiyun reg = <0x0 0x70301100 0x0 0x100>; 1008*4882a593Smuzhiyun nvidia,ahub-cif-ids = <5 5>; 1009*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2S1>; 1010*4882a593Smuzhiyun resets = <&tegra_car 11>; 1011*4882a593Smuzhiyun reset-names = "i2s"; 1012*4882a593Smuzhiyun status = "disabled"; 1013*4882a593Smuzhiyun }; 1014*4882a593Smuzhiyun 1015*4882a593Smuzhiyun tegra_i2s2: i2s@70301200 { 1016*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2s"; 1017*4882a593Smuzhiyun reg = <0x0 0x70301200 0x0 0x100>; 1018*4882a593Smuzhiyun nvidia,ahub-cif-ids = <6 6>; 1019*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2S2>; 1020*4882a593Smuzhiyun resets = <&tegra_car 18>; 1021*4882a593Smuzhiyun reset-names = "i2s"; 1022*4882a593Smuzhiyun status = "disabled"; 1023*4882a593Smuzhiyun }; 1024*4882a593Smuzhiyun 1025*4882a593Smuzhiyun tegra_i2s3: i2s@70301300 { 1026*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2s"; 1027*4882a593Smuzhiyun reg = <0x0 0x70301300 0x0 0x100>; 1028*4882a593Smuzhiyun nvidia,ahub-cif-ids = <7 7>; 1029*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2S3>; 1030*4882a593Smuzhiyun resets = <&tegra_car 101>; 1031*4882a593Smuzhiyun reset-names = "i2s"; 1032*4882a593Smuzhiyun status = "disabled"; 1033*4882a593Smuzhiyun }; 1034*4882a593Smuzhiyun 1035*4882a593Smuzhiyun tegra_i2s4: i2s@70301400 { 1036*4882a593Smuzhiyun compatible = "nvidia,tegra124-i2s"; 1037*4882a593Smuzhiyun reg = <0x0 0x70301400 0x0 0x100>; 1038*4882a593Smuzhiyun nvidia,ahub-cif-ids = <8 8>; 1039*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_I2S4>; 1040*4882a593Smuzhiyun resets = <&tegra_car 102>; 1041*4882a593Smuzhiyun reset-names = "i2s"; 1042*4882a593Smuzhiyun status = "disabled"; 1043*4882a593Smuzhiyun }; 1044*4882a593Smuzhiyun }; 1045*4882a593Smuzhiyun 1046*4882a593Smuzhiyun usb@7d000000 { 1047*4882a593Smuzhiyun compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci"; 1048*4882a593Smuzhiyun reg = <0x0 0x7d000000 0x0 0x4000>; 1049*4882a593Smuzhiyun interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>; 1050*4882a593Smuzhiyun phy_type = "utmi"; 1051*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_USBD>; 1052*4882a593Smuzhiyun resets = <&tegra_car 22>; 1053*4882a593Smuzhiyun reset-names = "usb"; 1054*4882a593Smuzhiyun nvidia,phy = <&phy1>; 1055*4882a593Smuzhiyun status = "disabled"; 1056*4882a593Smuzhiyun }; 1057*4882a593Smuzhiyun 1058*4882a593Smuzhiyun phy1: usb-phy@7d000000 { 1059*4882a593Smuzhiyun compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy"; 1060*4882a593Smuzhiyun reg = <0x0 0x7d000000 0x0 0x4000>, 1061*4882a593Smuzhiyun <0x0 0x7d000000 0x0 0x4000>; 1062*4882a593Smuzhiyun phy_type = "utmi"; 1063*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_USBD>, 1064*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_U>, 1065*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_USBD>; 1066*4882a593Smuzhiyun clock-names = "reg", "pll_u", "utmi-pads"; 1067*4882a593Smuzhiyun resets = <&tegra_car 22>, <&tegra_car 22>; 1068*4882a593Smuzhiyun reset-names = "usb", "utmi-pads"; 1069*4882a593Smuzhiyun #phy-cells = <0>; 1070*4882a593Smuzhiyun nvidia,hssync-start-delay = <0>; 1071*4882a593Smuzhiyun nvidia,idle-wait-delay = <17>; 1072*4882a593Smuzhiyun nvidia,elastic-limit = <16>; 1073*4882a593Smuzhiyun nvidia,term-range-adj = <6>; 1074*4882a593Smuzhiyun nvidia,xcvr-setup = <9>; 1075*4882a593Smuzhiyun nvidia,xcvr-lsfslew = <0>; 1076*4882a593Smuzhiyun nvidia,xcvr-lsrslew = <3>; 1077*4882a593Smuzhiyun nvidia,hssquelch-level = <2>; 1078*4882a593Smuzhiyun nvidia,hsdiscon-level = <5>; 1079*4882a593Smuzhiyun nvidia,xcvr-hsslew = <12>; 1080*4882a593Smuzhiyun nvidia,has-utmi-pad-registers; 1081*4882a593Smuzhiyun status = "disabled"; 1082*4882a593Smuzhiyun }; 1083*4882a593Smuzhiyun 1084*4882a593Smuzhiyun usb@7d004000 { 1085*4882a593Smuzhiyun compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci"; 1086*4882a593Smuzhiyun reg = <0x0 0x7d004000 0x0 0x4000>; 1087*4882a593Smuzhiyun interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>; 1088*4882a593Smuzhiyun phy_type = "utmi"; 1089*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_USB2>; 1090*4882a593Smuzhiyun resets = <&tegra_car 58>; 1091*4882a593Smuzhiyun reset-names = "usb"; 1092*4882a593Smuzhiyun nvidia,phy = <&phy2>; 1093*4882a593Smuzhiyun status = "disabled"; 1094*4882a593Smuzhiyun }; 1095*4882a593Smuzhiyun 1096*4882a593Smuzhiyun phy2: usb-phy@7d004000 { 1097*4882a593Smuzhiyun compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy"; 1098*4882a593Smuzhiyun reg = <0x0 0x7d004000 0x0 0x4000>, 1099*4882a593Smuzhiyun <0x0 0x7d000000 0x0 0x4000>; 1100*4882a593Smuzhiyun phy_type = "utmi"; 1101*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_USB2>, 1102*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_U>, 1103*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_USBD>; 1104*4882a593Smuzhiyun clock-names = "reg", "pll_u", "utmi-pads"; 1105*4882a593Smuzhiyun resets = <&tegra_car 58>, <&tegra_car 22>; 1106*4882a593Smuzhiyun reset-names = "usb", "utmi-pads"; 1107*4882a593Smuzhiyun #phy-cells = <0>; 1108*4882a593Smuzhiyun nvidia,hssync-start-delay = <0>; 1109*4882a593Smuzhiyun nvidia,idle-wait-delay = <17>; 1110*4882a593Smuzhiyun nvidia,elastic-limit = <16>; 1111*4882a593Smuzhiyun nvidia,term-range-adj = <6>; 1112*4882a593Smuzhiyun nvidia,xcvr-setup = <9>; 1113*4882a593Smuzhiyun nvidia,xcvr-lsfslew = <0>; 1114*4882a593Smuzhiyun nvidia,xcvr-lsrslew = <3>; 1115*4882a593Smuzhiyun nvidia,hssquelch-level = <2>; 1116*4882a593Smuzhiyun nvidia,hsdiscon-level = <5>; 1117*4882a593Smuzhiyun nvidia,xcvr-hsslew = <12>; 1118*4882a593Smuzhiyun status = "disabled"; 1119*4882a593Smuzhiyun }; 1120*4882a593Smuzhiyun 1121*4882a593Smuzhiyun usb@7d008000 { 1122*4882a593Smuzhiyun compatible = "nvidia,tegra124-ehci", "nvidia,tegra30-ehci", "usb-ehci"; 1123*4882a593Smuzhiyun reg = <0x0 0x7d008000 0x0 0x4000>; 1124*4882a593Smuzhiyun interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>; 1125*4882a593Smuzhiyun phy_type = "utmi"; 1126*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_USB3>; 1127*4882a593Smuzhiyun resets = <&tegra_car 59>; 1128*4882a593Smuzhiyun reset-names = "usb"; 1129*4882a593Smuzhiyun nvidia,phy = <&phy3>; 1130*4882a593Smuzhiyun status = "disabled"; 1131*4882a593Smuzhiyun }; 1132*4882a593Smuzhiyun 1133*4882a593Smuzhiyun phy3: usb-phy@7d008000 { 1134*4882a593Smuzhiyun compatible = "nvidia,tegra124-usb-phy", "nvidia,tegra30-usb-phy"; 1135*4882a593Smuzhiyun reg = <0x0 0x7d008000 0x0 0x4000>, 1136*4882a593Smuzhiyun <0x0 0x7d000000 0x0 0x4000>; 1137*4882a593Smuzhiyun phy_type = "utmi"; 1138*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_USB3>, 1139*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_U>, 1140*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_USBD>; 1141*4882a593Smuzhiyun clock-names = "reg", "pll_u", "utmi-pads"; 1142*4882a593Smuzhiyun resets = <&tegra_car 59>, <&tegra_car 22>; 1143*4882a593Smuzhiyun reset-names = "usb", "utmi-pads"; 1144*4882a593Smuzhiyun #phy-cells = <0>; 1145*4882a593Smuzhiyun nvidia,hssync-start-delay = <0>; 1146*4882a593Smuzhiyun nvidia,idle-wait-delay = <17>; 1147*4882a593Smuzhiyun nvidia,elastic-limit = <16>; 1148*4882a593Smuzhiyun nvidia,term-range-adj = <6>; 1149*4882a593Smuzhiyun nvidia,xcvr-setup = <9>; 1150*4882a593Smuzhiyun nvidia,xcvr-lsfslew = <0>; 1151*4882a593Smuzhiyun nvidia,xcvr-lsrslew = <3>; 1152*4882a593Smuzhiyun nvidia,hssquelch-level = <2>; 1153*4882a593Smuzhiyun nvidia,hsdiscon-level = <5>; 1154*4882a593Smuzhiyun nvidia,xcvr-hsslew = <12>; 1155*4882a593Smuzhiyun status = "disabled"; 1156*4882a593Smuzhiyun }; 1157*4882a593Smuzhiyun 1158*4882a593Smuzhiyun cpus { 1159*4882a593Smuzhiyun #address-cells = <1>; 1160*4882a593Smuzhiyun #size-cells = <0>; 1161*4882a593Smuzhiyun 1162*4882a593Smuzhiyun cpu@0 { 1163*4882a593Smuzhiyun device_type = "cpu"; 1164*4882a593Smuzhiyun compatible = "arm,cortex-a15"; 1165*4882a593Smuzhiyun reg = <0>; 1166*4882a593Smuzhiyun 1167*4882a593Smuzhiyun clocks = <&tegra_car TEGRA124_CLK_CCLK_G>, 1168*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_CCLK_LP>, 1169*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_X>, 1170*4882a593Smuzhiyun <&tegra_car TEGRA124_CLK_PLL_P>, 1171*4882a593Smuzhiyun <&dfll>; 1172*4882a593Smuzhiyun clock-names = "cpu_g", "cpu_lp", "pll_x", "pll_p", "dfll"; 1173*4882a593Smuzhiyun /* FIXME: what's the actual transition time? */ 1174*4882a593Smuzhiyun clock-latency = <300000>; 1175*4882a593Smuzhiyun }; 1176*4882a593Smuzhiyun 1177*4882a593Smuzhiyun cpu@1 { 1178*4882a593Smuzhiyun device_type = "cpu"; 1179*4882a593Smuzhiyun compatible = "arm,cortex-a15"; 1180*4882a593Smuzhiyun reg = <1>; 1181*4882a593Smuzhiyun }; 1182*4882a593Smuzhiyun 1183*4882a593Smuzhiyun cpu@2 { 1184*4882a593Smuzhiyun device_type = "cpu"; 1185*4882a593Smuzhiyun compatible = "arm,cortex-a15"; 1186*4882a593Smuzhiyun reg = <2>; 1187*4882a593Smuzhiyun }; 1188*4882a593Smuzhiyun 1189*4882a593Smuzhiyun cpu@3 { 1190*4882a593Smuzhiyun device_type = "cpu"; 1191*4882a593Smuzhiyun compatible = "arm,cortex-a15"; 1192*4882a593Smuzhiyun reg = <3>; 1193*4882a593Smuzhiyun }; 1194*4882a593Smuzhiyun }; 1195*4882a593Smuzhiyun 1196*4882a593Smuzhiyun pmu { 1197*4882a593Smuzhiyun compatible = "arm,cortex-a15-pmu"; 1198*4882a593Smuzhiyun interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>, 1199*4882a593Smuzhiyun <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>, 1200*4882a593Smuzhiyun <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>, 1201*4882a593Smuzhiyun <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>; 1202*4882a593Smuzhiyun interrupt-affinity = <&{/cpus/cpu@0}>, 1203*4882a593Smuzhiyun <&{/cpus/cpu@1}>, 1204*4882a593Smuzhiyun <&{/cpus/cpu@2}>, 1205*4882a593Smuzhiyun <&{/cpus/cpu@3}>; 1206*4882a593Smuzhiyun }; 1207*4882a593Smuzhiyun 1208*4882a593Smuzhiyun thermal-zones { 1209*4882a593Smuzhiyun cpu { 1210*4882a593Smuzhiyun polling-delay-passive = <1000>; 1211*4882a593Smuzhiyun polling-delay = <1000>; 1212*4882a593Smuzhiyun 1213*4882a593Smuzhiyun thermal-sensors = 1214*4882a593Smuzhiyun <&soctherm TEGRA124_SOCTHERM_SENSOR_CPU>; 1215*4882a593Smuzhiyun 1216*4882a593Smuzhiyun trips { 1217*4882a593Smuzhiyun cpu-shutdown-trip { 1218*4882a593Smuzhiyun temperature = <103000>; 1219*4882a593Smuzhiyun hysteresis = <0>; 1220*4882a593Smuzhiyun type = "critical"; 1221*4882a593Smuzhiyun }; 1222*4882a593Smuzhiyun cpu_throttle_trip: throttle-trip { 1223*4882a593Smuzhiyun temperature = <100000>; 1224*4882a593Smuzhiyun hysteresis = <1000>; 1225*4882a593Smuzhiyun type = "hot"; 1226*4882a593Smuzhiyun }; 1227*4882a593Smuzhiyun }; 1228*4882a593Smuzhiyun 1229*4882a593Smuzhiyun cooling-maps { 1230*4882a593Smuzhiyun map0 { 1231*4882a593Smuzhiyun trip = <&cpu_throttle_trip>; 1232*4882a593Smuzhiyun cooling-device = <&throttle_heavy 1 1>; 1233*4882a593Smuzhiyun }; 1234*4882a593Smuzhiyun }; 1235*4882a593Smuzhiyun }; 1236*4882a593Smuzhiyun 1237*4882a593Smuzhiyun mem { 1238*4882a593Smuzhiyun polling-delay-passive = <1000>; 1239*4882a593Smuzhiyun polling-delay = <1000>; 1240*4882a593Smuzhiyun 1241*4882a593Smuzhiyun thermal-sensors = 1242*4882a593Smuzhiyun <&soctherm TEGRA124_SOCTHERM_SENSOR_MEM>; 1243*4882a593Smuzhiyun 1244*4882a593Smuzhiyun trips { 1245*4882a593Smuzhiyun mem-shutdown-trip { 1246*4882a593Smuzhiyun temperature = <103000>; 1247*4882a593Smuzhiyun hysteresis = <0>; 1248*4882a593Smuzhiyun type = "critical"; 1249*4882a593Smuzhiyun }; 1250*4882a593Smuzhiyun }; 1251*4882a593Smuzhiyun 1252*4882a593Smuzhiyun cooling-maps { 1253*4882a593Smuzhiyun /* 1254*4882a593Smuzhiyun * There are currently no cooling maps, 1255*4882a593Smuzhiyun * because there are no cooling devices. 1256*4882a593Smuzhiyun */ 1257*4882a593Smuzhiyun }; 1258*4882a593Smuzhiyun }; 1259*4882a593Smuzhiyun 1260*4882a593Smuzhiyun gpu { 1261*4882a593Smuzhiyun polling-delay-passive = <1000>; 1262*4882a593Smuzhiyun polling-delay = <1000>; 1263*4882a593Smuzhiyun 1264*4882a593Smuzhiyun thermal-sensors = 1265*4882a593Smuzhiyun <&soctherm TEGRA124_SOCTHERM_SENSOR_GPU>; 1266*4882a593Smuzhiyun 1267*4882a593Smuzhiyun trips { 1268*4882a593Smuzhiyun gpu-shutdown-trip { 1269*4882a593Smuzhiyun temperature = <101000>; 1270*4882a593Smuzhiyun hysteresis = <0>; 1271*4882a593Smuzhiyun type = "critical"; 1272*4882a593Smuzhiyun }; 1273*4882a593Smuzhiyun gpu_throttle_trip: throttle-trip { 1274*4882a593Smuzhiyun temperature = <99000>; 1275*4882a593Smuzhiyun hysteresis = <1000>; 1276*4882a593Smuzhiyun type = "hot"; 1277*4882a593Smuzhiyun }; 1278*4882a593Smuzhiyun }; 1279*4882a593Smuzhiyun 1280*4882a593Smuzhiyun cooling-maps { 1281*4882a593Smuzhiyun map0 { 1282*4882a593Smuzhiyun trip = <&gpu_throttle_trip>; 1283*4882a593Smuzhiyun cooling-device = <&throttle_heavy 1 1>; 1284*4882a593Smuzhiyun }; 1285*4882a593Smuzhiyun }; 1286*4882a593Smuzhiyun }; 1287*4882a593Smuzhiyun 1288*4882a593Smuzhiyun pllx { 1289*4882a593Smuzhiyun polling-delay-passive = <1000>; 1290*4882a593Smuzhiyun polling-delay = <1000>; 1291*4882a593Smuzhiyun 1292*4882a593Smuzhiyun thermal-sensors = 1293*4882a593Smuzhiyun <&soctherm TEGRA124_SOCTHERM_SENSOR_PLLX>; 1294*4882a593Smuzhiyun 1295*4882a593Smuzhiyun trips { 1296*4882a593Smuzhiyun pllx-shutdown-trip { 1297*4882a593Smuzhiyun temperature = <103000>; 1298*4882a593Smuzhiyun hysteresis = <0>; 1299*4882a593Smuzhiyun type = "critical"; 1300*4882a593Smuzhiyun }; 1301*4882a593Smuzhiyun }; 1302*4882a593Smuzhiyun 1303*4882a593Smuzhiyun cooling-maps { 1304*4882a593Smuzhiyun /* 1305*4882a593Smuzhiyun * There are currently no cooling maps, 1306*4882a593Smuzhiyun * because there are no cooling devices. 1307*4882a593Smuzhiyun */ 1308*4882a593Smuzhiyun }; 1309*4882a593Smuzhiyun }; 1310*4882a593Smuzhiyun }; 1311*4882a593Smuzhiyun 1312*4882a593Smuzhiyun timer { 1313*4882a593Smuzhiyun compatible = "arm,armv7-timer"; 1314*4882a593Smuzhiyun interrupts = <GIC_PPI 13 1315*4882a593Smuzhiyun (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 1316*4882a593Smuzhiyun <GIC_PPI 14 1317*4882a593Smuzhiyun (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 1318*4882a593Smuzhiyun <GIC_PPI 11 1319*4882a593Smuzhiyun (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 1320*4882a593Smuzhiyun <GIC_PPI 10 1321*4882a593Smuzhiyun (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>; 1322*4882a593Smuzhiyun interrupt-parent = <&gic>; 1323*4882a593Smuzhiyun }; 1324*4882a593Smuzhiyun}; 1325