1#include <dt-bindings/clock/tegra20-car.h> 2#include <dt-bindings/gpio/tegra-gpio.h> 3#include <dt-bindings/pinctrl/pinctrl-tegra.h> 4#include <dt-bindings/interrupt-controller/arm-gic.h> 5 6#include "skeleton.dtsi" 7 8/ { 9 compatible = "nvidia,tegra20"; 10 interrupt-parent = <&lic>; 11 12 host1x@50000000 { 13 compatible = "nvidia,tegra20-host1x", "simple-bus"; 14 reg = <0x50000000 0x00024000>; 15 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, /* syncpt */ 16 <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>; /* general */ 17 clocks = <&tegra_car TEGRA20_CLK_HOST1X>; 18 resets = <&tegra_car 28>; 19 reset-names = "host1x"; 20 21 #address-cells = <1>; 22 #size-cells = <1>; 23 24 ranges = <0x54000000 0x54000000 0x04000000>; 25 26 mpe@54040000 { 27 compatible = "nvidia,tegra20-mpe"; 28 reg = <0x54040000 0x00040000>; 29 interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>; 30 clocks = <&tegra_car TEGRA20_CLK_MPE>; 31 resets = <&tegra_car 60>; 32 reset-names = "mpe"; 33 }; 34 35 vi@54080000 { 36 compatible = "nvidia,tegra20-vi"; 37 reg = <0x54080000 0x00040000>; 38 interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>; 39 clocks = <&tegra_car TEGRA20_CLK_VI>; 40 resets = <&tegra_car 20>; 41 reset-names = "vi"; 42 }; 43 44 epp@540c0000 { 45 compatible = "nvidia,tegra20-epp"; 46 reg = <0x540c0000 0x00040000>; 47 interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>; 48 clocks = <&tegra_car TEGRA20_CLK_EPP>; 49 resets = <&tegra_car 19>; 50 reset-names = "epp"; 51 }; 52 53 isp@54100000 { 54 compatible = "nvidia,tegra20-isp"; 55 reg = <0x54100000 0x00040000>; 56 interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>; 57 clocks = <&tegra_car TEGRA20_CLK_ISP>; 58 resets = <&tegra_car 23>; 59 reset-names = "isp"; 60 }; 61 62 gr2d@54140000 { 63 compatible = "nvidia,tegra20-gr2d"; 64 reg = <0x54140000 0x00040000>; 65 interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>; 66 clocks = <&tegra_car TEGRA20_CLK_GR2D>; 67 resets = <&tegra_car 21>; 68 reset-names = "2d"; 69 }; 70 71 gr3d@54180000 { 72 compatible = "nvidia,tegra20-gr3d"; 73 reg = <0x54180000 0x00040000>; 74 clocks = <&tegra_car TEGRA20_CLK_GR3D>; 75 resets = <&tegra_car 24>; 76 reset-names = "3d"; 77 }; 78 79 dc@54200000 { 80 compatible = "nvidia,tegra20-dc"; 81 reg = <0x54200000 0x00040000>; 82 interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>; 83 clocks = <&tegra_car TEGRA20_CLK_DISP1>, 84 <&tegra_car TEGRA20_CLK_PLL_P>; 85 clock-names = "dc", "parent"; 86 resets = <&tegra_car 27>; 87 reset-names = "dc"; 88 89 nvidia,head = <0>; 90 91 rgb { 92 status = "disabled"; 93 }; 94 }; 95 96 dc@54240000 { 97 compatible = "nvidia,tegra20-dc"; 98 reg = <0x54240000 0x00040000>; 99 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>; 100 clocks = <&tegra_car TEGRA20_CLK_DISP2>, 101 <&tegra_car TEGRA20_CLK_PLL_P>; 102 clock-names = "dc", "parent"; 103 resets = <&tegra_car 26>; 104 reset-names = "dc"; 105 106 nvidia,head = <1>; 107 108 rgb { 109 status = "disabled"; 110 }; 111 }; 112 113 hdmi@54280000 { 114 compatible = "nvidia,tegra20-hdmi"; 115 reg = <0x54280000 0x00040000>; 116 interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>; 117 clocks = <&tegra_car TEGRA20_CLK_HDMI>, 118 <&tegra_car TEGRA20_CLK_PLL_D_OUT0>; 119 clock-names = "hdmi", "parent"; 120 resets = <&tegra_car 51>; 121 reset-names = "hdmi"; 122 status = "disabled"; 123 }; 124 125 tvo@542c0000 { 126 compatible = "nvidia,tegra20-tvo"; 127 reg = <0x542c0000 0x00040000>; 128 interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>; 129 clocks = <&tegra_car TEGRA20_CLK_TVO>; 130 status = "disabled"; 131 }; 132 133 dsi@54300000 { 134 compatible = "nvidia,tegra20-dsi"; 135 reg = <0x54300000 0x00040000>; 136 clocks = <&tegra_car TEGRA20_CLK_DSI>; 137 resets = <&tegra_car 48>; 138 reset-names = "dsi"; 139 status = "disabled"; 140 }; 141 }; 142 143 timer@50040600 { 144 compatible = "arm,cortex-a9-twd-timer"; 145 interrupt-parent = <&intc>; 146 reg = <0x50040600 0x20>; 147 interrupts = <GIC_PPI 13 148 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_EDGE_RISING)>; 149 clocks = <&tegra_car TEGRA20_CLK_TWD>; 150 }; 151 152 intc: interrupt-controller@50041000 { 153 compatible = "arm,cortex-a9-gic"; 154 reg = <0x50041000 0x1000 155 0x50040100 0x0100>; 156 interrupt-controller; 157 #interrupt-cells = <3>; 158 interrupt-parent = <&intc>; 159 }; 160 161 cache-controller@50043000 { 162 compatible = "arm,pl310-cache"; 163 reg = <0x50043000 0x1000>; 164 arm,data-latency = <5 5 2>; 165 arm,tag-latency = <4 4 2>; 166 cache-unified; 167 cache-level = <2>; 168 }; 169 170 lic: interrupt-controller@60004000 { 171 compatible = "nvidia,tegra20-ictlr"; 172 reg = <0x60004000 0x100>, 173 <0x60004100 0x50>, 174 <0x60004200 0x50>, 175 <0x60004300 0x50>; 176 interrupt-controller; 177 #interrupt-cells = <3>; 178 interrupt-parent = <&intc>; 179 }; 180 181 timer@60005000 { 182 compatible = "nvidia,tegra20-timer"; 183 reg = <0x60005000 0x60>; 184 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>, 185 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>, 186 <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>, 187 <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>; 188 clocks = <&tegra_car TEGRA20_CLK_TIMER>; 189 }; 190 191 tegra_car: clock@60006000 { 192 compatible = "nvidia,tegra20-car"; 193 reg = <0x60006000 0x1000>; 194 #clock-cells = <1>; 195 #reset-cells = <1>; 196 }; 197 198 flow-controller@60007000 { 199 compatible = "nvidia,tegra20-flowctrl"; 200 reg = <0x60007000 0x1000>; 201 }; 202 203 apbdma: dma@6000a000 { 204 compatible = "nvidia,tegra20-apbdma"; 205 reg = <0x6000a000 0x1200>; 206 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>, 207 <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>, 208 <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>, 209 <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>, 210 <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>, 211 <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>, 212 <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>, 213 <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>, 214 <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>, 215 <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>, 216 <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>, 217 <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>, 218 <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>, 219 <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>, 220 <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>, 221 <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>; 222 clocks = <&tegra_car TEGRA20_CLK_APBDMA>; 223 resets = <&tegra_car 34>; 224 reset-names = "dma"; 225 #dma-cells = <1>; 226 }; 227 228 ahb@6000c000 { 229 compatible = "nvidia,tegra20-ahb"; 230 reg = <0x6000c000 0x110>; /* AHB Arbitration + Gizmo Controller */ 231 }; 232 233 gpio: gpio@6000d000 { 234 compatible = "nvidia,tegra20-gpio"; 235 reg = <0x6000d000 0x1000>; 236 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>, 237 <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>, 238 <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>, 239 <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>, 240 <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>, 241 <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>, 242 <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>; 243 #gpio-cells = <2>; 244 gpio-controller; 245 #interrupt-cells = <2>; 246 interrupt-controller; 247 /* 248 gpio-ranges = <&pinmux 0 0 224>; 249 */ 250 }; 251 252 apbmisc@70000800 { 253 compatible = "nvidia,tegra20-apbmisc"; 254 reg = <0x70000800 0x64 /* Chip revision */ 255 0x70000008 0x04>; /* Strapping options */ 256 }; 257 258 pinmux: pinmux@70000014 { 259 compatible = "nvidia,tegra20-pinmux"; 260 reg = <0x70000014 0x10 /* Tri-state registers */ 261 0x70000080 0x20 /* Mux registers */ 262 0x700000a0 0x14 /* Pull-up/down registers */ 263 0x70000868 0xa8>; /* Pad control registers */ 264 }; 265 266 das@70000c00 { 267 compatible = "nvidia,tegra20-das"; 268 reg = <0x70000c00 0x80>; 269 }; 270 271 tegra_ac97: ac97@70002000 { 272 compatible = "nvidia,tegra20-ac97"; 273 reg = <0x70002000 0x200>; 274 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>; 275 clocks = <&tegra_car TEGRA20_CLK_AC97>; 276 resets = <&tegra_car 3>; 277 reset-names = "ac97"; 278 dmas = <&apbdma 12>, <&apbdma 12>; 279 dma-names = "rx", "tx"; 280 status = "disabled"; 281 }; 282 283 tegra_i2s1: i2s@70002800 { 284 compatible = "nvidia,tegra20-i2s"; 285 reg = <0x70002800 0x200>; 286 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>; 287 clocks = <&tegra_car TEGRA20_CLK_I2S1>; 288 resets = <&tegra_car 11>; 289 reset-names = "i2s"; 290 dmas = <&apbdma 2>, <&apbdma 2>; 291 dma-names = "rx", "tx"; 292 status = "disabled"; 293 }; 294 295 tegra_i2s2: i2s@70002a00 { 296 compatible = "nvidia,tegra20-i2s"; 297 reg = <0x70002a00 0x200>; 298 interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; 299 clocks = <&tegra_car TEGRA20_CLK_I2S2>; 300 resets = <&tegra_car 18>; 301 reset-names = "i2s"; 302 dmas = <&apbdma 1>, <&apbdma 1>; 303 dma-names = "rx", "tx"; 304 status = "disabled"; 305 }; 306 307 /* 308 * There are two serial driver i.e. 8250 based simple serial 309 * driver and APB DMA based serial driver for higher baudrate 310 * and performace. To enable the 8250 based driver, the compatible 311 * is "nvidia,tegra20-uart" and to enable the APB DMA based serial 312 * driver, the compatible is "nvidia,tegra20-hsuart". 313 */ 314 uarta: serial@70006000 { 315 compatible = "nvidia,tegra20-uart"; 316 reg = <0x70006000 0x40>; 317 reg-shift = <2>; 318 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>; 319 clocks = <&tegra_car TEGRA20_CLK_UARTA>; 320 resets = <&tegra_car 6>; 321 reset-names = "serial"; 322 dmas = <&apbdma 8>, <&apbdma 8>; 323 dma-names = "rx", "tx"; 324 status = "disabled"; 325 }; 326 327 uartb: serial@70006040 { 328 compatible = "nvidia,tegra20-uart"; 329 reg = <0x70006040 0x40>; 330 reg-shift = <2>; 331 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>; 332 clocks = <&tegra_car TEGRA20_CLK_UARTB>; 333 resets = <&tegra_car 7>; 334 reset-names = "serial"; 335 dmas = <&apbdma 9>, <&apbdma 9>; 336 dma-names = "rx", "tx"; 337 status = "disabled"; 338 }; 339 340 uartc: serial@70006200 { 341 compatible = "nvidia,tegra20-uart"; 342 reg = <0x70006200 0x100>; 343 reg-shift = <2>; 344 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>; 345 clocks = <&tegra_car TEGRA20_CLK_UARTC>; 346 resets = <&tegra_car 55>; 347 reset-names = "serial"; 348 dmas = <&apbdma 10>, <&apbdma 10>; 349 dma-names = "rx", "tx"; 350 status = "disabled"; 351 }; 352 353 uartd: serial@70006300 { 354 compatible = "nvidia,tegra20-uart"; 355 reg = <0x70006300 0x100>; 356 reg-shift = <2>; 357 interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>; 358 clocks = <&tegra_car TEGRA20_CLK_UARTD>; 359 resets = <&tegra_car 65>; 360 reset-names = "serial"; 361 dmas = <&apbdma 19>, <&apbdma 19>; 362 dma-names = "rx", "tx"; 363 status = "disabled"; 364 }; 365 366 uarte: serial@70006400 { 367 compatible = "nvidia,tegra20-uart"; 368 reg = <0x70006400 0x100>; 369 reg-shift = <2>; 370 interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>; 371 clocks = <&tegra_car TEGRA20_CLK_UARTE>; 372 resets = <&tegra_car 66>; 373 reset-names = "serial"; 374 dmas = <&apbdma 20>, <&apbdma 20>; 375 dma-names = "rx", "tx"; 376 status = "disabled"; 377 }; 378 379 nand: nand-controller@70008000 { 380 #address-cells = <1>; 381 #size-cells = <0>; 382 compatible = "nvidia,tegra20-nand"; 383 reg = <0x70008000 0x100>; 384 }; 385 386 pwm: pwm@7000a000 { 387 compatible = "nvidia,tegra20-pwm"; 388 reg = <0x7000a000 0x100>; 389 #pwm-cells = <2>; 390 clocks = <&tegra_car TEGRA20_CLK_PWM>; 391 resets = <&tegra_car 17>; 392 reset-names = "pwm"; 393 status = "disabled"; 394 }; 395 396 rtc@7000e000 { 397 compatible = "nvidia,tegra20-rtc"; 398 reg = <0x7000e000 0x100>; 399 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; 400 clocks = <&tegra_car TEGRA20_CLK_RTC>; 401 }; 402 403 i2c@7000c000 { 404 compatible = "nvidia,tegra20-i2c"; 405 reg = <0x7000c000 0x100>; 406 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>; 407 #address-cells = <1>; 408 #size-cells = <0>; 409 clocks = <&tegra_car TEGRA20_CLK_I2C1>, 410 <&tegra_car TEGRA20_CLK_PLL_P_OUT3>; 411 clock-names = "div-clk", "fast-clk"; 412 resets = <&tegra_car 12>; 413 reset-names = "i2c"; 414 dmas = <&apbdma 21>, <&apbdma 21>; 415 dma-names = "rx", "tx"; 416 status = "disabled"; 417 }; 418 419 spi@7000c380 { 420 compatible = "nvidia,tegra20-sflash"; 421 reg = <0x7000c380 0x80>; 422 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>; 423 #address-cells = <1>; 424 #size-cells = <0>; 425 clocks = <&tegra_car TEGRA20_CLK_SPI>; 426 resets = <&tegra_car 43>; 427 reset-names = "spi"; 428 dmas = <&apbdma 11>, <&apbdma 11>; 429 dma-names = "rx", "tx"; 430 status = "disabled"; 431 }; 432 433 i2c@7000c400 { 434 compatible = "nvidia,tegra20-i2c"; 435 reg = <0x7000c400 0x100>; 436 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>; 437 #address-cells = <1>; 438 #size-cells = <0>; 439 clocks = <&tegra_car TEGRA20_CLK_I2C2>, 440 <&tegra_car TEGRA20_CLK_PLL_P_OUT3>; 441 clock-names = "div-clk", "fast-clk"; 442 resets = <&tegra_car 54>; 443 reset-names = "i2c"; 444 dmas = <&apbdma 22>, <&apbdma 22>; 445 dma-names = "rx", "tx"; 446 status = "disabled"; 447 }; 448 449 i2c@7000c500 { 450 compatible = "nvidia,tegra20-i2c"; 451 reg = <0x7000c500 0x100>; 452 interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>; 453 #address-cells = <1>; 454 #size-cells = <0>; 455 clocks = <&tegra_car TEGRA20_CLK_I2C3>, 456 <&tegra_car TEGRA20_CLK_PLL_P_OUT3>; 457 clock-names = "div-clk", "fast-clk"; 458 resets = <&tegra_car 67>; 459 reset-names = "i2c"; 460 dmas = <&apbdma 23>, <&apbdma 23>; 461 dma-names = "rx", "tx"; 462 status = "disabled"; 463 }; 464 465 i2c@7000d000 { 466 compatible = "nvidia,tegra20-i2c-dvc"; 467 reg = <0x7000d000 0x200>; 468 interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>; 469 #address-cells = <1>; 470 #size-cells = <0>; 471 clocks = <&tegra_car TEGRA20_CLK_DVC>, 472 <&tegra_car TEGRA20_CLK_PLL_P_OUT3>; 473 clock-names = "div-clk", "fast-clk"; 474 resets = <&tegra_car 47>; 475 reset-names = "i2c"; 476 dmas = <&apbdma 24>, <&apbdma 24>; 477 dma-names = "rx", "tx"; 478 status = "disabled"; 479 }; 480 481 spi@7000d400 { 482 compatible = "nvidia,tegra20-slink"; 483 reg = <0x7000d400 0x200>; 484 interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>; 485 #address-cells = <1>; 486 #size-cells = <0>; 487 clocks = <&tegra_car TEGRA20_CLK_SBC1>; 488 resets = <&tegra_car 41>; 489 reset-names = "spi"; 490 dmas = <&apbdma 15>, <&apbdma 15>; 491 dma-names = "rx", "tx"; 492 status = "disabled"; 493 }; 494 495 spi@7000d600 { 496 compatible = "nvidia,tegra20-slink"; 497 reg = <0x7000d600 0x200>; 498 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>; 499 #address-cells = <1>; 500 #size-cells = <0>; 501 clocks = <&tegra_car TEGRA20_CLK_SBC2>; 502 resets = <&tegra_car 44>; 503 reset-names = "spi"; 504 dmas = <&apbdma 16>, <&apbdma 16>; 505 dma-names = "rx", "tx"; 506 status = "disabled"; 507 }; 508 509 spi@7000d800 { 510 compatible = "nvidia,tegra20-slink"; 511 reg = <0x7000d800 0x200>; 512 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>; 513 #address-cells = <1>; 514 #size-cells = <0>; 515 clocks = <&tegra_car TEGRA20_CLK_SBC3>; 516 resets = <&tegra_car 46>; 517 reset-names = "spi"; 518 dmas = <&apbdma 17>, <&apbdma 17>; 519 dma-names = "rx", "tx"; 520 status = "disabled"; 521 }; 522 523 spi@7000da00 { 524 compatible = "nvidia,tegra20-slink"; 525 reg = <0x7000da00 0x200>; 526 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>; 527 #address-cells = <1>; 528 #size-cells = <0>; 529 clocks = <&tegra_car TEGRA20_CLK_SBC4>; 530 resets = <&tegra_car 68>; 531 reset-names = "spi"; 532 dmas = <&apbdma 18>, <&apbdma 18>; 533 dma-names = "rx", "tx"; 534 status = "disabled"; 535 }; 536 537 kbc@7000e200 { 538 compatible = "nvidia,tegra20-kbc"; 539 reg = <0x7000e200 0x100>; 540 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>; 541 clocks = <&tegra_car TEGRA20_CLK_KBC>; 542 resets = <&tegra_car 36>; 543 reset-names = "kbc"; 544 status = "disabled"; 545 }; 546 547 pmc@7000e400 { 548 compatible = "nvidia,tegra20-pmc"; 549 reg = <0x7000e400 0x400>; 550 clocks = <&tegra_car TEGRA20_CLK_PCLK>, <&clk32k_in>; 551 clock-names = "pclk", "clk32k_in"; 552 }; 553 554 memory-controller@7000f000 { 555 compatible = "nvidia,tegra20-mc"; 556 reg = <0x7000f000 0x024 557 0x7000f03c 0x3c4>; 558 interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>; 559 }; 560 561 iommu@7000f024 { 562 compatible = "nvidia,tegra20-gart"; 563 reg = <0x7000f024 0x00000018 /* controller registers */ 564 0x58000000 0x02000000>; /* GART aperture */ 565 }; 566 567 memory-controller@7000f400 { 568 compatible = "nvidia,tegra20-emc"; 569 reg = <0x7000f400 0x200>; 570 #address-cells = <1>; 571 #size-cells = <0>; 572 }; 573 574 fuse@7000f800 { 575 compatible = "nvidia,tegra20-efuse"; 576 reg = <0x7000f800 0x400>; 577 clocks = <&tegra_car TEGRA20_CLK_FUSE>; 578 clock-names = "fuse"; 579 resets = <&tegra_car 39>; 580 reset-names = "fuse"; 581 }; 582 583 pcie-controller@80003000 { 584 compatible = "nvidia,tegra20-pcie"; 585 device_type = "pci"; 586 reg = <0x80003000 0x00000800 /* PADS registers */ 587 0x80003800 0x00000200 /* AFI registers */ 588 0x90000000 0x10000000>; /* configuration space */ 589 reg-names = "pads", "afi", "cs"; 590 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH /* controller interrupt */ 591 GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; /* MSI interrupt */ 592 interrupt-names = "intr", "msi"; 593 594 #interrupt-cells = <1>; 595 interrupt-map-mask = <0 0 0 0>; 596 interrupt-map = <0 0 0 0 &intc GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>; 597 598 bus-range = <0x00 0xff>; 599 #address-cells = <3>; 600 #size-cells = <2>; 601 602 ranges = <0x82000000 0 0x80000000 0x80000000 0 0x00001000 /* port 0 registers */ 603 0x82000000 0 0x80001000 0x80001000 0 0x00001000 /* port 1 registers */ 604 0x81000000 0 0 0x82000000 0 0x00010000 /* downstream I/O */ 605 0x82000000 0 0xa0000000 0xa0000000 0 0x08000000 /* non-prefetchable memory */ 606 0xc2000000 0 0xa8000000 0xa8000000 0 0x18000000>; /* prefetchable memory */ 607 608 clocks = <&tegra_car TEGRA20_CLK_PEX>, 609 <&tegra_car TEGRA20_CLK_AFI>, 610 <&tegra_car TEGRA20_CLK_PLL_E>; 611 clock-names = "pex", "afi", "pll_e"; 612 resets = <&tegra_car 70>, 613 <&tegra_car 72>, 614 <&tegra_car 74>; 615 reset-names = "pex", "afi", "pcie_x"; 616 status = "disabled"; 617 618 pci@1,0 { 619 device_type = "pci"; 620 assigned-addresses = <0x82000800 0 0x80000000 0 0x1000>; 621 reg = <0x000800 0 0 0 0>; 622 status = "disabled"; 623 624 #address-cells = <3>; 625 #size-cells = <2>; 626 ranges; 627 628 nvidia,num-lanes = <2>; 629 }; 630 631 pci@2,0 { 632 device_type = "pci"; 633 assigned-addresses = <0x82001000 0 0x80001000 0 0x1000>; 634 reg = <0x001000 0 0 0 0>; 635 status = "disabled"; 636 637 #address-cells = <3>; 638 #size-cells = <2>; 639 ranges; 640 641 nvidia,num-lanes = <2>; 642 }; 643 }; 644 645 usb@c5000000 { 646 compatible = "nvidia,tegra20-ehci", "usb-ehci"; 647 reg = <0xc5000000 0x4000>; 648 interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>; 649 phy_type = "utmi"; 650 nvidia,has-legacy-mode; 651 clocks = <&tegra_car TEGRA20_CLK_USBD>; 652 resets = <&tegra_car 22>; 653 reset-names = "usb"; 654 nvidia,needs-double-reset; 655 nvidia,phy = <&phy1>; 656 status = "disabled"; 657 }; 658 659 phy1: usb-phy@c5000000 { 660 compatible = "nvidia,tegra20-usb-phy"; 661 reg = <0xc5000000 0x4000 0xc5000000 0x4000>; 662 phy_type = "utmi"; 663 clocks = <&tegra_car TEGRA20_CLK_USBD>, 664 <&tegra_car TEGRA20_CLK_PLL_U>, 665 <&tegra_car TEGRA20_CLK_CLK_M>, 666 <&tegra_car TEGRA20_CLK_USBD>; 667 clock-names = "reg", "pll_u", "timer", "utmi-pads"; 668 resets = <&tegra_car 22>, <&tegra_car 22>; 669 reset-names = "usb", "utmi-pads"; 670 nvidia,has-legacy-mode; 671 nvidia,hssync-start-delay = <9>; 672 nvidia,idle-wait-delay = <17>; 673 nvidia,elastic-limit = <16>; 674 nvidia,term-range-adj = <6>; 675 nvidia,xcvr-setup = <9>; 676 nvidia,xcvr-lsfslew = <1>; 677 nvidia,xcvr-lsrslew = <1>; 678 nvidia,has-utmi-pad-registers; 679 status = "disabled"; 680 }; 681 682 usb@c5004000 { 683 compatible = "nvidia,tegra20-ehci", "usb-ehci"; 684 reg = <0xc5004000 0x4000>; 685 interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>; 686 phy_type = "ulpi"; 687 clocks = <&tegra_car TEGRA20_CLK_USB2>; 688 resets = <&tegra_car 58>; 689 reset-names = "usb"; 690 nvidia,phy = <&phy2>; 691 status = "disabled"; 692 }; 693 694 phy2: usb-phy@c5004000 { 695 compatible = "nvidia,tegra20-usb-phy"; 696 reg = <0xc5004000 0x4000>; 697 phy_type = "ulpi"; 698 clocks = <&tegra_car TEGRA20_CLK_USB2>, 699 <&tegra_car TEGRA20_CLK_PLL_U>, 700 <&tegra_car TEGRA20_CLK_CDEV2>; 701 clock-names = "reg", "pll_u", "ulpi-link"; 702 resets = <&tegra_car 58>, <&tegra_car 22>; 703 reset-names = "usb", "utmi-pads"; 704 status = "disabled"; 705 }; 706 707 usb@c5008000 { 708 compatible = "nvidia,tegra20-ehci", "usb-ehci"; 709 reg = <0xc5008000 0x4000>; 710 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>; 711 phy_type = "utmi"; 712 clocks = <&tegra_car TEGRA20_CLK_USB3>; 713 resets = <&tegra_car 59>; 714 reset-names = "usb"; 715 nvidia,phy = <&phy3>; 716 status = "disabled"; 717 }; 718 719 phy3: usb-phy@c5008000 { 720 compatible = "nvidia,tegra20-usb-phy"; 721 reg = <0xc5008000 0x4000 0xc5000000 0x4000>; 722 phy_type = "utmi"; 723 clocks = <&tegra_car TEGRA20_CLK_USB3>, 724 <&tegra_car TEGRA20_CLK_PLL_U>, 725 <&tegra_car TEGRA20_CLK_CLK_M>, 726 <&tegra_car TEGRA20_CLK_USBD>; 727 clock-names = "reg", "pll_u", "timer", "utmi-pads"; 728 resets = <&tegra_car 59>, <&tegra_car 22>; 729 reset-names = "usb", "utmi-pads"; 730 nvidia,hssync-start-delay = <9>; 731 nvidia,idle-wait-delay = <17>; 732 nvidia,elastic-limit = <16>; 733 nvidia,term-range-adj = <6>; 734 nvidia,xcvr-setup = <9>; 735 nvidia,xcvr-lsfslew = <2>; 736 nvidia,xcvr-lsrslew = <2>; 737 status = "disabled"; 738 }; 739 740 sdhci@c8000000 { 741 compatible = "nvidia,tegra20-sdhci"; 742 reg = <0xc8000000 0x200>; 743 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>; 744 clocks = <&tegra_car TEGRA20_CLK_SDMMC1>; 745 resets = <&tegra_car 14>; 746 reset-names = "sdhci"; 747 status = "disabled"; 748 }; 749 750 sdhci@c8000200 { 751 compatible = "nvidia,tegra20-sdhci"; 752 reg = <0xc8000200 0x200>; 753 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>; 754 clocks = <&tegra_car TEGRA20_CLK_SDMMC2>; 755 resets = <&tegra_car 9>; 756 reset-names = "sdhci"; 757 status = "disabled"; 758 }; 759 760 sdhci@c8000400 { 761 compatible = "nvidia,tegra20-sdhci"; 762 reg = <0xc8000400 0x200>; 763 interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>; 764 clocks = <&tegra_car TEGRA20_CLK_SDMMC3>; 765 resets = <&tegra_car 69>; 766 reset-names = "sdhci"; 767 status = "disabled"; 768 }; 769 770 sdhci@c8000600 { 771 compatible = "nvidia,tegra20-sdhci"; 772 reg = <0xc8000600 0x200>; 773 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>; 774 clocks = <&tegra_car TEGRA20_CLK_SDMMC4>; 775 resets = <&tegra_car 15>; 776 reset-names = "sdhci"; 777 status = "disabled"; 778 }; 779 780 cpus { 781 #address-cells = <1>; 782 #size-cells = <0>; 783 784 cpu@0 { 785 device_type = "cpu"; 786 compatible = "arm,cortex-a9"; 787 reg = <0>; 788 }; 789 790 cpu@1 { 791 device_type = "cpu"; 792 compatible = "arm,cortex-a9"; 793 reg = <1>; 794 }; 795 }; 796 797 pmu { 798 compatible = "arm,cortex-a9-pmu"; 799 interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>, 800 <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>; 801 }; 802}; 803