at91sam9n12.dtsi revision 270864
1262569Simp/* 2262569Simp * at91sam9n12.dtsi - Device Tree include file for AT91SAM9N12 SoC 3262569Simp * 4262569Simp * Copyright (C) 2012 Atmel, 5262569Simp * 2012 Hong Xu <hong.xu@atmel.com> 6262569Simp * 7262569Simp * Licensed under GPLv2 or later. 8262569Simp */ 9262569Simp 10262569Simp#include "skeleton.dtsi" 11262569Simp#include <dt-bindings/dma/at91.h> 12262569Simp#include <dt-bindings/pinctrl/at91.h> 13262569Simp#include <dt-bindings/interrupt-controller/irq.h> 14262569Simp#include <dt-bindings/gpio/gpio.h> 15270864Simp#include <dt-bindings/clock/at91.h> 16262569Simp 17262569Simp/ { 18262569Simp model = "Atmel AT91SAM9N12 SoC"; 19262569Simp compatible = "atmel,at91sam9n12"; 20262569Simp interrupt-parent = <&aic>; 21262569Simp 22262569Simp aliases { 23262569Simp serial0 = &dbgu; 24262569Simp serial1 = &usart0; 25262569Simp serial2 = &usart1; 26262569Simp serial3 = &usart2; 27262569Simp serial4 = &usart3; 28262569Simp gpio0 = &pioA; 29262569Simp gpio1 = &pioB; 30262569Simp gpio2 = &pioC; 31262569Simp gpio3 = &pioD; 32262569Simp tcb0 = &tcb0; 33262569Simp tcb1 = &tcb1; 34262569Simp i2c0 = &i2c0; 35262569Simp i2c1 = &i2c1; 36262569Simp ssc0 = &ssc0; 37262569Simp pwm0 = &pwm0; 38262569Simp }; 39262569Simp cpus { 40262569Simp #address-cells = <0>; 41262569Simp #size-cells = <0>; 42262569Simp 43262569Simp cpu { 44262569Simp compatible = "arm,arm926ej-s"; 45262569Simp device_type = "cpu"; 46262569Simp }; 47262569Simp }; 48262569Simp 49262569Simp memory { 50262569Simp reg = <0x20000000 0x10000000>; 51262569Simp }; 52262569Simp 53270864Simp clocks { 54270864Simp slow_xtal: slow_xtal { 55270864Simp compatible = "fixed-clock"; 56270864Simp #clock-cells = <0>; 57270864Simp clock-frequency = <0>; 58270864Simp }; 59270864Simp 60270864Simp main_xtal: main_xtal { 61270864Simp compatible = "fixed-clock"; 62270864Simp #clock-cells = <0>; 63270864Simp clock-frequency = <0>; 64270864Simp }; 65270864Simp }; 66270864Simp 67262569Simp ahb { 68262569Simp compatible = "simple-bus"; 69262569Simp #address-cells = <1>; 70262569Simp #size-cells = <1>; 71262569Simp ranges; 72262569Simp 73262569Simp apb { 74262569Simp compatible = "simple-bus"; 75262569Simp #address-cells = <1>; 76262569Simp #size-cells = <1>; 77262569Simp ranges; 78262569Simp 79262569Simp aic: interrupt-controller@fffff000 { 80262569Simp #interrupt-cells = <3>; 81262569Simp compatible = "atmel,at91rm9200-aic"; 82262569Simp interrupt-controller; 83262569Simp reg = <0xfffff000 0x200>; 84262569Simp atmel,external-irqs = <31>; 85262569Simp }; 86262569Simp 87262569Simp ramc0: ramc@ffffe800 { 88262569Simp compatible = "atmel,at91sam9g45-ddramc"; 89262569Simp reg = <0xffffe800 0x200>; 90262569Simp }; 91262569Simp 92262569Simp pmc: pmc@fffffc00 { 93270864Simp compatible = "atmel,at91sam9n12-pmc"; 94270864Simp reg = <0xfffffc00 0x200>; 95270864Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 96270864Simp interrupt-controller; 97270864Simp #address-cells = <1>; 98270864Simp #size-cells = <0>; 99270864Simp #interrupt-cells = <1>; 100270864Simp 101270864Simp main_rc_osc: main_rc_osc { 102270864Simp compatible = "atmel,at91sam9x5-clk-main-rc-osc"; 103270864Simp #clock-cells = <0>; 104270864Simp interrupts-extended = <&pmc AT91_PMC_MOSCRCS>; 105270864Simp clock-frequency = <12000000>; 106270864Simp clock-accuracy = <50000000>; 107270864Simp }; 108270864Simp 109270864Simp main_osc: main_osc { 110270864Simp compatible = "atmel,at91rm9200-clk-main-osc"; 111270864Simp #clock-cells = <0>; 112270864Simp interrupts-extended = <&pmc AT91_PMC_MOSCS>; 113270864Simp clocks = <&main_xtal>; 114270864Simp }; 115270864Simp 116270864Simp main: mainck { 117270864Simp compatible = "atmel,at91sam9x5-clk-main"; 118270864Simp #clock-cells = <0>; 119270864Simp interrupts-extended = <&pmc AT91_PMC_MOSCSELS>; 120270864Simp clocks = <&main_rc_osc>, <&main_osc>; 121270864Simp }; 122270864Simp 123270864Simp plla: pllack { 124270864Simp compatible = "atmel,at91rm9200-clk-pll"; 125270864Simp #clock-cells = <0>; 126270864Simp interrupts-extended = <&pmc AT91_PMC_LOCKA>; 127270864Simp clocks = <&main>; 128270864Simp reg = <0>; 129270864Simp atmel,clk-input-range = <2000000 32000000>; 130270864Simp #atmel,pll-clk-output-range-cells = <4>; 131270864Simp atmel,pll-clk-output-ranges = <745000000 800000000 0 0>, 132270864Simp <695000000 750000000 1 0>, 133270864Simp <645000000 700000000 2 0>, 134270864Simp <595000000 650000000 3 0>, 135270864Simp <545000000 600000000 0 1>, 136270864Simp <495000000 555000000 1 1>, 137270864Simp <445000000 500000000 2 1>, 138270864Simp <400000000 450000000 3 1>; 139270864Simp }; 140270864Simp 141270864Simp plladiv: plladivck { 142270864Simp compatible = "atmel,at91sam9x5-clk-plldiv"; 143270864Simp #clock-cells = <0>; 144270864Simp clocks = <&plla>; 145270864Simp }; 146270864Simp 147270864Simp pllb: pllbck { 148270864Simp compatible = "atmel,at91rm9200-clk-pll"; 149270864Simp #clock-cells = <0>; 150270864Simp interrupts-extended = <&pmc AT91_PMC_LOCKB>; 151270864Simp clocks = <&main>; 152270864Simp reg = <1>; 153270864Simp atmel,clk-input-range = <2000000 32000000>; 154270864Simp #atmel,pll-clk-output-range-cells = <3>; 155270864Simp atmel,pll-clk-output-ranges = <30000000 100000000 0>; 156270864Simp }; 157270864Simp 158270864Simp mck: masterck { 159270864Simp compatible = "atmel,at91sam9x5-clk-master"; 160270864Simp #clock-cells = <0>; 161270864Simp interrupts-extended = <&pmc AT91_PMC_MCKRDY>; 162270864Simp clocks = <&clk32k>, <&main>, <&plladiv>, <&pllb>; 163270864Simp atmel,clk-output-range = <0 133333333>; 164270864Simp atmel,clk-divisors = <1 2 4 3>; 165270864Simp atmel,master-clk-have-div3-pres; 166270864Simp }; 167270864Simp 168270864Simp usb: usbck { 169270864Simp compatible = "atmel,at91sam9n12-clk-usb"; 170270864Simp #clock-cells = <0>; 171270864Simp clocks = <&pllb>; 172270864Simp }; 173270864Simp 174270864Simp prog: progck { 175270864Simp compatible = "atmel,at91sam9x5-clk-programmable"; 176270864Simp #address-cells = <1>; 177270864Simp #size-cells = <0>; 178270864Simp interrupt-parent = <&pmc>; 179270864Simp clocks = <&clk32k>, <&main>, <&plladiv>, <&pllb>, <&mck>; 180270864Simp 181270864Simp prog0: prog0 { 182270864Simp #clock-cells = <0>; 183270864Simp reg = <0>; 184270864Simp interrupts = <AT91_PMC_PCKRDY(0)>; 185270864Simp }; 186270864Simp 187270864Simp prog1: prog1 { 188270864Simp #clock-cells = <0>; 189270864Simp reg = <1>; 190270864Simp interrupts = <AT91_PMC_PCKRDY(1)>; 191270864Simp }; 192270864Simp }; 193270864Simp 194270864Simp systemck { 195270864Simp compatible = "atmel,at91rm9200-clk-system"; 196270864Simp #address-cells = <1>; 197270864Simp #size-cells = <0>; 198270864Simp 199270864Simp ddrck: ddrck { 200270864Simp #clock-cells = <0>; 201270864Simp reg = <2>; 202270864Simp clocks = <&mck>; 203270864Simp }; 204270864Simp 205270864Simp lcdck: lcdck { 206270864Simp #clock-cells = <0>; 207270864Simp reg = <3>; 208270864Simp clocks = <&mck>; 209270864Simp }; 210270864Simp 211270864Simp uhpck: uhpck { 212270864Simp #clock-cells = <0>; 213270864Simp reg = <6>; 214270864Simp clocks = <&usb>; 215270864Simp }; 216270864Simp 217270864Simp udpck: udpck { 218270864Simp #clock-cells = <0>; 219270864Simp reg = <7>; 220270864Simp clocks = <&usb>; 221270864Simp }; 222270864Simp 223270864Simp pck0: pck0 { 224270864Simp #clock-cells = <0>; 225270864Simp reg = <8>; 226270864Simp clocks = <&prog0>; 227270864Simp }; 228270864Simp 229270864Simp pck1: pck1 { 230270864Simp #clock-cells = <0>; 231270864Simp reg = <9>; 232270864Simp clocks = <&prog1>; 233270864Simp }; 234270864Simp }; 235270864Simp 236270864Simp periphck { 237270864Simp compatible = "atmel,at91sam9x5-clk-peripheral"; 238270864Simp #address-cells = <1>; 239270864Simp #size-cells = <0>; 240270864Simp clocks = <&mck>; 241270864Simp 242270864Simp pioAB_clk: pioAB_clk { 243270864Simp #clock-cells = <0>; 244270864Simp reg = <2>; 245270864Simp }; 246270864Simp 247270864Simp pioCD_clk: pioCD_clk { 248270864Simp #clock-cells = <0>; 249270864Simp reg = <3>; 250270864Simp }; 251270864Simp 252270864Simp fuse_clk: fuse_clk { 253270864Simp #clock-cells = <0>; 254270864Simp reg = <4>; 255270864Simp }; 256270864Simp 257270864Simp usart0_clk: usart0_clk { 258270864Simp #clock-cells = <0>; 259270864Simp reg = <5>; 260270864Simp }; 261270864Simp 262270864Simp usart1_clk: usart1_clk { 263270864Simp #clock-cells = <0>; 264270864Simp reg = <6>; 265270864Simp }; 266270864Simp 267270864Simp usart2_clk: usart2_clk { 268270864Simp #clock-cells = <0>; 269270864Simp reg = <7>; 270270864Simp }; 271270864Simp 272270864Simp usart3_clk: usart3_clk { 273270864Simp #clock-cells = <0>; 274270864Simp reg = <8>; 275270864Simp }; 276270864Simp 277270864Simp twi0_clk: twi0_clk { 278270864Simp reg = <9>; 279270864Simp #clock-cells = <0>; 280270864Simp }; 281270864Simp 282270864Simp twi1_clk: twi1_clk { 283270864Simp #clock-cells = <0>; 284270864Simp reg = <10>; 285270864Simp }; 286270864Simp 287270864Simp mci0_clk: mci0_clk { 288270864Simp #clock-cells = <0>; 289270864Simp reg = <12>; 290270864Simp }; 291270864Simp 292270864Simp spi0_clk: spi0_clk { 293270864Simp #clock-cells = <0>; 294270864Simp reg = <13>; 295270864Simp }; 296270864Simp 297270864Simp spi1_clk: spi1_clk { 298270864Simp #clock-cells = <0>; 299270864Simp reg = <14>; 300270864Simp }; 301270864Simp 302270864Simp uart0_clk: uart0_clk { 303270864Simp #clock-cells = <0>; 304270864Simp reg = <15>; 305270864Simp }; 306270864Simp 307270864Simp uart1_clk: uart1_clk { 308270864Simp #clock-cells = <0>; 309270864Simp reg = <16>; 310270864Simp }; 311270864Simp 312270864Simp tcb_clk: tcb_clk { 313270864Simp #clock-cells = <0>; 314270864Simp reg = <17>; 315270864Simp }; 316270864Simp 317270864Simp pwm_clk: pwm_clk { 318270864Simp #clock-cells = <0>; 319270864Simp reg = <18>; 320270864Simp }; 321270864Simp 322270864Simp adc_clk: adc_clk { 323270864Simp #clock-cells = <0>; 324270864Simp reg = <19>; 325270864Simp }; 326270864Simp 327270864Simp dma0_clk: dma0_clk { 328270864Simp #clock-cells = <0>; 329270864Simp reg = <20>; 330270864Simp }; 331270864Simp 332270864Simp uhphs_clk: uhphs_clk { 333270864Simp #clock-cells = <0>; 334270864Simp reg = <22>; 335270864Simp }; 336270864Simp 337270864Simp udphs_clk: udphs_clk { 338270864Simp #clock-cells = <0>; 339270864Simp reg = <23>; 340270864Simp }; 341270864Simp 342270864Simp lcdc_clk: lcdc_clk { 343270864Simp #clock-cells = <0>; 344270864Simp reg = <25>; 345270864Simp }; 346270864Simp 347270864Simp sha_clk: sha_clk { 348270864Simp #clock-cells = <0>; 349270864Simp reg = <27>; 350270864Simp }; 351270864Simp 352270864Simp ssc0_clk: ssc0_clk { 353270864Simp #clock-cells = <0>; 354270864Simp reg = <28>; 355270864Simp }; 356270864Simp 357270864Simp aes_clk: aes_clk { 358270864Simp #clock-cells = <0>; 359270864Simp reg = <29>; 360270864Simp }; 361270864Simp 362270864Simp trng_clk: trng_clk { 363270864Simp #clock-cells = <0>; 364270864Simp reg = <30>; 365270864Simp }; 366270864Simp }; 367262569Simp }; 368262569Simp 369262569Simp rstc@fffffe00 { 370262569Simp compatible = "atmel,at91sam9g45-rstc"; 371262569Simp reg = <0xfffffe00 0x10>; 372262569Simp }; 373262569Simp 374262569Simp pit: timer@fffffe30 { 375262569Simp compatible = "atmel,at91sam9260-pit"; 376262569Simp reg = <0xfffffe30 0xf>; 377262569Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 378270864Simp clocks = <&mck>; 379262569Simp }; 380262569Simp 381262569Simp shdwc@fffffe10 { 382262569Simp compatible = "atmel,at91sam9x5-shdwc"; 383262569Simp reg = <0xfffffe10 0x10>; 384262569Simp }; 385262569Simp 386270864Simp sckc@fffffe50 { 387270864Simp compatible = "atmel,at91sam9x5-sckc"; 388270864Simp reg = <0xfffffe50 0x4>; 389270864Simp 390270864Simp slow_osc: slow_osc { 391270864Simp compatible = "atmel,at91sam9x5-clk-slow-osc"; 392270864Simp #clock-cells = <0>; 393270864Simp clocks = <&slow_xtal>; 394270864Simp }; 395270864Simp 396270864Simp slow_rc_osc: slow_rc_osc { 397270864Simp compatible = "atmel,at91sam9x5-clk-slow-rc-osc"; 398270864Simp #clock-cells = <0>; 399270864Simp clock-frequency = <32768>; 400270864Simp clock-accuracy = <50000000>; 401270864Simp }; 402270864Simp 403270864Simp clk32k: slck { 404270864Simp compatible = "atmel,at91sam9x5-clk-slow"; 405270864Simp #clock-cells = <0>; 406270864Simp clocks = <&slow_rc_osc>, <&slow_osc>; 407270864Simp }; 408270864Simp }; 409270864Simp 410262569Simp mmc0: mmc@f0008000 { 411262569Simp compatible = "atmel,hsmci"; 412262569Simp reg = <0xf0008000 0x600>; 413262569Simp interrupts = <12 IRQ_TYPE_LEVEL_HIGH 0>; 414262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(0)>; 415262569Simp dma-names = "rxtx"; 416270864Simp clocks = <&mci0_clk>; 417270864Simp clock-names = "mci_clk"; 418262569Simp #address-cells = <1>; 419262569Simp #size-cells = <0>; 420262569Simp status = "disabled"; 421262569Simp }; 422262569Simp 423262569Simp tcb0: timer@f8008000 { 424262569Simp compatible = "atmel,at91sam9x5-tcb"; 425262569Simp reg = <0xf8008000 0x100>; 426262569Simp interrupts = <17 IRQ_TYPE_LEVEL_HIGH 0>; 427270864Simp clocks = <&tcb_clk>; 428270864Simp clock-names = "t0_clk"; 429262569Simp }; 430262569Simp 431262569Simp tcb1: timer@f800c000 { 432262569Simp compatible = "atmel,at91sam9x5-tcb"; 433262569Simp reg = <0xf800c000 0x100>; 434262569Simp interrupts = <17 IRQ_TYPE_LEVEL_HIGH 0>; 435270864Simp clocks = <&tcb_clk>; 436270864Simp clock-names = "t0_clk"; 437262569Simp }; 438262569Simp 439262569Simp dma: dma-controller@ffffec00 { 440262569Simp compatible = "atmel,at91sam9g45-dma"; 441262569Simp reg = <0xffffec00 0x200>; 442262569Simp interrupts = <20 IRQ_TYPE_LEVEL_HIGH 0>; 443262569Simp #dma-cells = <2>; 444270864Simp clocks = <&dma0_clk>; 445270864Simp clock-names = "dma_clk"; 446262569Simp }; 447262569Simp 448262569Simp pinctrl@fffff400 { 449262569Simp #address-cells = <1>; 450262569Simp #size-cells = <1>; 451262569Simp compatible = "atmel,at91sam9x5-pinctrl", "atmel,at91rm9200-pinctrl", "simple-bus"; 452262569Simp ranges = <0xfffff400 0xfffff400 0x800>; 453262569Simp 454262569Simp atmel,mux-mask = < 455262569Simp /* A B C */ 456262569Simp 0xffffffff 0xffe07983 0x00000000 /* pioA */ 457262569Simp 0x00040000 0x00047e0f 0x00000000 /* pioB */ 458262569Simp 0xfdffffff 0x07c00000 0xb83fffff /* pioC */ 459262569Simp 0x003fffff 0x003f8000 0x00000000 /* pioD */ 460262569Simp >; 461262569Simp 462262569Simp /* shared pinctrl settings */ 463262569Simp dbgu { 464262569Simp pinctrl_dbgu: dbgu-0 { 465262569Simp atmel,pins = 466262569Simp <AT91_PIOA 9 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA9 periph A */ 467262569Simp AT91_PIOA 10 AT91_PERIPH_A AT91_PINCTRL_PULL_UP>; /* PA10 periph with pullup */ 468262569Simp }; 469262569Simp }; 470262569Simp 471262569Simp usart0 { 472262569Simp pinctrl_usart0: usart0-0 { 473262569Simp atmel,pins = 474262569Simp <AT91_PIOA 1 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA1 periph A with pullup */ 475262569Simp AT91_PIOA 0 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA0 periph A */ 476262569Simp }; 477262569Simp 478262569Simp pinctrl_usart0_rts: usart0_rts-0 { 479262569Simp atmel,pins = 480262569Simp <AT91_PIOA 2 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA2 periph A */ 481262569Simp }; 482262569Simp 483262569Simp pinctrl_usart0_cts: usart0_cts-0 { 484262569Simp atmel,pins = 485262569Simp <AT91_PIOA 3 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA3 periph A */ 486262569Simp }; 487262569Simp }; 488262569Simp 489262569Simp usart1 { 490262569Simp pinctrl_usart1: usart1-0 { 491262569Simp atmel,pins = 492262569Simp <AT91_PIOA 6 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA6 periph A with pullup */ 493262569Simp AT91_PIOA 5 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA5 periph A */ 494262569Simp }; 495262569Simp }; 496262569Simp 497262569Simp usart2 { 498262569Simp pinctrl_usart2: usart2-0 { 499262569Simp atmel,pins = 500262569Simp <AT91_PIOA 8 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA8 periph A with pullup */ 501262569Simp AT91_PIOA 7 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA7 periph A */ 502262569Simp }; 503262569Simp 504262569Simp pinctrl_usart2_rts: usart2_rts-0 { 505262569Simp atmel,pins = 506262569Simp <AT91_PIOB 0 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PB0 periph B */ 507262569Simp }; 508262569Simp 509262569Simp pinctrl_usart2_cts: usart2_cts-0 { 510262569Simp atmel,pins = 511262569Simp <AT91_PIOB 1 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PB1 periph B */ 512262569Simp }; 513262569Simp }; 514262569Simp 515262569Simp usart3 { 516262569Simp pinctrl_usart3: usart3-0 { 517262569Simp atmel,pins = 518262569Simp <AT91_PIOC 23 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PC23 periph B with pullup */ 519262569Simp AT91_PIOC 22 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PC22 periph B */ 520262569Simp }; 521262569Simp 522262569Simp pinctrl_usart3_rts: usart3_rts-0 { 523262569Simp atmel,pins = 524262569Simp <AT91_PIOC 24 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PC24 periph B */ 525262569Simp }; 526262569Simp 527262569Simp pinctrl_usart3_cts: usart3_cts-0 { 528262569Simp atmel,pins = 529262569Simp <AT91_PIOC 25 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PC25 periph B */ 530262569Simp }; 531262569Simp }; 532262569Simp 533262569Simp uart0 { 534262569Simp pinctrl_uart0: uart0-0 { 535262569Simp atmel,pins = 536262569Simp <AT91_PIOC 9 AT91_PERIPH_C AT91_PINCTRL_PULL_UP /* PC9 periph C with pullup */ 537262569Simp AT91_PIOC 8 AT91_PERIPH_C AT91_PINCTRL_NONE>; /* PC8 periph C */ 538262569Simp }; 539262569Simp }; 540262569Simp 541262569Simp uart1 { 542262569Simp pinctrl_uart1: uart1-0 { 543262569Simp atmel,pins = 544262569Simp <AT91_PIOC 16 AT91_PERIPH_C AT91_PINCTRL_PULL_UP /* PC17 periph C with pullup */ 545262569Simp AT91_PIOC 17 AT91_PERIPH_C AT91_PINCTRL_NONE>; /* PC16 periph C */ 546262569Simp }; 547262569Simp }; 548262569Simp 549262569Simp nand { 550262569Simp pinctrl_nand: nand-0 { 551262569Simp atmel,pins = 552262569Simp <AT91_PIOD 5 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP /* PD5 gpio RDY pin pull_up*/ 553262569Simp AT91_PIOD 4 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP>; /* PD4 gpio enable pin pull_up */ 554262569Simp }; 555262569Simp }; 556262569Simp 557262569Simp mmc0 { 558262569Simp pinctrl_mmc0_slot0_clk_cmd_dat0: mmc0_slot0_clk_cmd_dat0-0 { 559262569Simp atmel,pins = 560262569Simp <AT91_PIOA 17 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA17 periph A */ 561262569Simp AT91_PIOA 16 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA16 periph A with pullup */ 562262569Simp AT91_PIOA 15 AT91_PERIPH_A AT91_PINCTRL_PULL_UP>; /* PA15 periph A with pullup */ 563262569Simp }; 564262569Simp 565262569Simp pinctrl_mmc0_slot0_dat1_3: mmc0_slot0_dat1_3-0 { 566262569Simp atmel,pins = 567262569Simp <AT91_PIOA 18 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA18 periph A with pullup */ 568262569Simp AT91_PIOA 19 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA19 periph A with pullup */ 569262569Simp AT91_PIOA 20 AT91_PERIPH_A AT91_PINCTRL_PULL_UP>; /* PA20 periph A with pullup */ 570262569Simp }; 571262569Simp 572262569Simp pinctrl_mmc0_slot0_dat4_7: mmc0_slot0_dat4_7-0 { 573262569Simp atmel,pins = 574262569Simp <AT91_PIOA 11 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PA11 periph B with pullup */ 575262569Simp AT91_PIOA 12 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PA12 periph B with pullup */ 576262569Simp AT91_PIOA 13 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PA13 periph B with pullup */ 577262569Simp AT91_PIOA 14 AT91_PERIPH_B AT91_PINCTRL_PULL_UP>; /* PA14 periph B with pullup */ 578262569Simp }; 579262569Simp }; 580262569Simp 581262569Simp ssc0 { 582262569Simp pinctrl_ssc0_tx: ssc0_tx-0 { 583262569Simp atmel,pins = 584262569Simp <AT91_PIOA 24 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA24 periph B */ 585262569Simp AT91_PIOA 25 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA25 periph B */ 586262569Simp AT91_PIOA 26 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PA26 periph B */ 587262569Simp }; 588262569Simp 589262569Simp pinctrl_ssc0_rx: ssc0_rx-0 { 590262569Simp atmel,pins = 591262569Simp <AT91_PIOA 27 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA27 periph B */ 592262569Simp AT91_PIOA 28 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA28 periph B */ 593262569Simp AT91_PIOA 29 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PA29 periph B */ 594262569Simp }; 595262569Simp }; 596262569Simp 597262569Simp spi0 { 598262569Simp pinctrl_spi0: spi0-0 { 599262569Simp atmel,pins = 600262569Simp <AT91_PIOA 11 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA11 periph A SPI0_MISO pin */ 601262569Simp AT91_PIOA 12 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA12 periph A SPI0_MOSI pin */ 602262569Simp AT91_PIOA 13 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA13 periph A SPI0_SPCK pin */ 603262569Simp }; 604262569Simp }; 605262569Simp 606262569Simp spi1 { 607262569Simp pinctrl_spi1: spi1-0 { 608262569Simp atmel,pins = 609262569Simp <AT91_PIOA 21 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA21 periph B SPI1_MISO pin */ 610262569Simp AT91_PIOA 22 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA22 periph B SPI1_MOSI pin */ 611262569Simp AT91_PIOA 23 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PA23 periph B SPI1_SPCK pin */ 612262569Simp }; 613262569Simp }; 614262569Simp 615262569Simp i2c0 { 616262569Simp pinctrl_i2c0: i2c0-0 { 617262569Simp atmel,pins = 618262569Simp <AT91_PIOA 30 AT91_PERIPH_A AT91_PINCTRL_NONE 619262569Simp AT91_PIOA 31 AT91_PERIPH_A AT91_PINCTRL_NONE>; 620262569Simp }; 621262569Simp }; 622262569Simp 623262569Simp i2c1 { 624262569Simp pinctrl_i2c1: i2c1-0 { 625262569Simp atmel,pins = 626262569Simp <AT91_PIOC 0 AT91_PERIPH_C AT91_PINCTRL_NONE 627262569Simp AT91_PIOC 1 AT91_PERIPH_C AT91_PINCTRL_NONE>; 628262569Simp }; 629262569Simp }; 630262569Simp 631262569Simp tcb0 { 632262569Simp pinctrl_tcb0_tclk0: tcb0_tclk0-0 { 633262569Simp atmel,pins = <AT91_PIOA 24 AT91_PERIPH_A AT91_PINCTRL_NONE>; 634262569Simp }; 635262569Simp 636262569Simp pinctrl_tcb0_tclk1: tcb0_tclk1-0 { 637262569Simp atmel,pins = <AT91_PIOA 25 AT91_PERIPH_A AT91_PINCTRL_NONE>; 638262569Simp }; 639262569Simp 640262569Simp pinctrl_tcb0_tclk2: tcb0_tclk2-0 { 641262569Simp atmel,pins = <AT91_PIOA 26 AT91_PERIPH_A AT91_PINCTRL_NONE>; 642262569Simp }; 643262569Simp 644262569Simp pinctrl_tcb0_tioa0: tcb0_tioa0-0 { 645262569Simp atmel,pins = <AT91_PIOA 21 AT91_PERIPH_A AT91_PINCTRL_NONE>; 646262569Simp }; 647262569Simp 648262569Simp pinctrl_tcb0_tioa1: tcb0_tioa1-0 { 649262569Simp atmel,pins = <AT91_PIOA 22 AT91_PERIPH_A AT91_PINCTRL_NONE>; 650262569Simp }; 651262569Simp 652262569Simp pinctrl_tcb0_tioa2: tcb0_tioa2-0 { 653262569Simp atmel,pins = <AT91_PIOA 23 AT91_PERIPH_A AT91_PINCTRL_NONE>; 654262569Simp }; 655262569Simp 656262569Simp pinctrl_tcb0_tiob0: tcb0_tiob0-0 { 657262569Simp atmel,pins = <AT91_PIOA 27 AT91_PERIPH_A AT91_PINCTRL_NONE>; 658262569Simp }; 659262569Simp 660262569Simp pinctrl_tcb0_tiob1: tcb0_tiob1-0 { 661262569Simp atmel,pins = <AT91_PIOA 28 AT91_PERIPH_A AT91_PINCTRL_NONE>; 662262569Simp }; 663262569Simp 664262569Simp pinctrl_tcb0_tiob2: tcb0_tiob2-0 { 665262569Simp atmel,pins = <AT91_PIOA 29 AT91_PERIPH_A AT91_PINCTRL_NONE>; 666262569Simp }; 667262569Simp }; 668262569Simp 669262569Simp tcb1 { 670262569Simp pinctrl_tcb1_tclk0: tcb1_tclk0-0 { 671262569Simp atmel,pins = <AT91_PIOC 4 AT91_PERIPH_C AT91_PINCTRL_NONE>; 672262569Simp }; 673262569Simp 674262569Simp pinctrl_tcb1_tclk1: tcb1_tclk1-0 { 675262569Simp atmel,pins = <AT91_PIOC 7 AT91_PERIPH_C AT91_PINCTRL_NONE>; 676262569Simp }; 677262569Simp 678262569Simp pinctrl_tcb1_tclk2: tcb1_tclk2-0 { 679262569Simp atmel,pins = <AT91_PIOC 14 AT91_PERIPH_C AT91_PINCTRL_NONE>; 680262569Simp }; 681262569Simp 682262569Simp pinctrl_tcb1_tioa0: tcb1_tioa0-0 { 683262569Simp atmel,pins = <AT91_PIOC 2 AT91_PERIPH_C AT91_PINCTRL_NONE>; 684262569Simp }; 685262569Simp 686262569Simp pinctrl_tcb1_tioa1: tcb1_tioa1-0 { 687262569Simp atmel,pins = <AT91_PIOC 5 AT91_PERIPH_C AT91_PINCTRL_NONE>; 688262569Simp }; 689262569Simp 690262569Simp pinctrl_tcb1_tioa2: tcb1_tioa2-0 { 691262569Simp atmel,pins = <AT91_PIOC 12 AT91_PERIPH_C AT91_PINCTRL_NONE>; 692262569Simp }; 693262569Simp 694262569Simp pinctrl_tcb1_tiob0: tcb1_tiob0-0 { 695262569Simp atmel,pins = <AT91_PIOC 3 AT91_PERIPH_C AT91_PINCTRL_NONE>; 696262569Simp }; 697262569Simp 698262569Simp pinctrl_tcb1_tiob1: tcb1_tiob1-0 { 699262569Simp atmel,pins = <AT91_PIOC 6 AT91_PERIPH_C AT91_PINCTRL_NONE>; 700262569Simp }; 701262569Simp 702262569Simp pinctrl_tcb1_tiob2: tcb1_tiob2-0 { 703262569Simp atmel,pins = <AT91_PIOC 13 AT91_PERIPH_C AT91_PINCTRL_NONE>; 704262569Simp }; 705262569Simp }; 706262569Simp 707262569Simp pioA: gpio@fffff400 { 708262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 709262569Simp reg = <0xfffff400 0x200>; 710262569Simp interrupts = <2 IRQ_TYPE_LEVEL_HIGH 1>; 711262569Simp #gpio-cells = <2>; 712262569Simp gpio-controller; 713262569Simp interrupt-controller; 714262569Simp #interrupt-cells = <2>; 715270864Simp clocks = <&pioAB_clk>; 716262569Simp }; 717262569Simp 718262569Simp pioB: gpio@fffff600 { 719262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 720262569Simp reg = <0xfffff600 0x200>; 721262569Simp interrupts = <2 IRQ_TYPE_LEVEL_HIGH 1>; 722262569Simp #gpio-cells = <2>; 723262569Simp gpio-controller; 724262569Simp interrupt-controller; 725262569Simp #interrupt-cells = <2>; 726270864Simp clocks = <&pioAB_clk>; 727262569Simp }; 728262569Simp 729262569Simp pioC: gpio@fffff800 { 730262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 731262569Simp reg = <0xfffff800 0x200>; 732262569Simp interrupts = <3 IRQ_TYPE_LEVEL_HIGH 1>; 733262569Simp #gpio-cells = <2>; 734262569Simp gpio-controller; 735262569Simp interrupt-controller; 736262569Simp #interrupt-cells = <2>; 737270864Simp clocks = <&pioCD_clk>; 738262569Simp }; 739262569Simp 740262569Simp pioD: gpio@fffffa00 { 741262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 742262569Simp reg = <0xfffffa00 0x200>; 743262569Simp interrupts = <3 IRQ_TYPE_LEVEL_HIGH 1>; 744262569Simp #gpio-cells = <2>; 745262569Simp gpio-controller; 746262569Simp interrupt-controller; 747262569Simp #interrupt-cells = <2>; 748270864Simp clocks = <&pioCD_clk>; 749262569Simp }; 750262569Simp }; 751262569Simp 752262569Simp dbgu: serial@fffff200 { 753262569Simp compatible = "atmel,at91sam9260-usart"; 754262569Simp reg = <0xfffff200 0x200>; 755262569Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 756262569Simp pinctrl-names = "default"; 757262569Simp pinctrl-0 = <&pinctrl_dbgu>; 758270864Simp clocks = <&mck>; 759270864Simp clock-names = "usart"; 760262569Simp status = "disabled"; 761262569Simp }; 762262569Simp 763262569Simp ssc0: ssc@f0010000 { 764262569Simp compatible = "atmel,at91sam9g45-ssc"; 765262569Simp reg = <0xf0010000 0x4000>; 766262569Simp interrupts = <28 IRQ_TYPE_LEVEL_HIGH 5>; 767262569Simp dmas = <&dma 0 AT91_DMA_CFG_PER_ID(21)>, 768262569Simp <&dma 0 AT91_DMA_CFG_PER_ID(22)>; 769262569Simp dma-names = "tx", "rx"; 770262569Simp pinctrl-names = "default"; 771262569Simp pinctrl-0 = <&pinctrl_ssc0_tx &pinctrl_ssc0_rx>; 772270864Simp clocks = <&ssc0_clk>; 773270864Simp clock-names = "pclk"; 774262569Simp status = "disabled"; 775262569Simp }; 776262569Simp 777262569Simp usart0: serial@f801c000 { 778262569Simp compatible = "atmel,at91sam9260-usart"; 779262569Simp reg = <0xf801c000 0x4000>; 780262569Simp interrupts = <5 IRQ_TYPE_LEVEL_HIGH 5>; 781262569Simp pinctrl-names = "default"; 782262569Simp pinctrl-0 = <&pinctrl_usart0>; 783270864Simp clocks = <&usart0_clk>; 784270864Simp clock-names = "usart"; 785262569Simp status = "disabled"; 786262569Simp }; 787262569Simp 788262569Simp usart1: serial@f8020000 { 789262569Simp compatible = "atmel,at91sam9260-usart"; 790262569Simp reg = <0xf8020000 0x4000>; 791262569Simp interrupts = <6 IRQ_TYPE_LEVEL_HIGH 5>; 792262569Simp pinctrl-names = "default"; 793262569Simp pinctrl-0 = <&pinctrl_usart1>; 794270864Simp clocks = <&usart1_clk>; 795270864Simp clock-names = "usart"; 796262569Simp status = "disabled"; 797262569Simp }; 798262569Simp 799262569Simp usart2: serial@f8024000 { 800262569Simp compatible = "atmel,at91sam9260-usart"; 801262569Simp reg = <0xf8024000 0x4000>; 802262569Simp interrupts = <7 IRQ_TYPE_LEVEL_HIGH 5>; 803262569Simp pinctrl-names = "default"; 804262569Simp pinctrl-0 = <&pinctrl_usart2>; 805270864Simp clocks = <&usart2_clk>; 806270864Simp clock-names = "usart"; 807262569Simp status = "disabled"; 808262569Simp }; 809262569Simp 810262569Simp usart3: serial@f8028000 { 811262569Simp compatible = "atmel,at91sam9260-usart"; 812262569Simp reg = <0xf8028000 0x4000>; 813262569Simp interrupts = <8 IRQ_TYPE_LEVEL_HIGH 5>; 814262569Simp pinctrl-names = "default"; 815262569Simp pinctrl-0 = <&pinctrl_usart3>; 816270864Simp clocks = <&usart3_clk>; 817270864Simp clock-names = "usart"; 818262569Simp status = "disabled"; 819262569Simp }; 820262569Simp 821262569Simp i2c0: i2c@f8010000 { 822262569Simp compatible = "atmel,at91sam9x5-i2c"; 823262569Simp reg = <0xf8010000 0x100>; 824262569Simp interrupts = <9 IRQ_TYPE_LEVEL_HIGH 6>; 825262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(13)>, 826262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(14)>; 827262569Simp dma-names = "tx", "rx"; 828262569Simp #address-cells = <1>; 829262569Simp #size-cells = <0>; 830262569Simp pinctrl-names = "default"; 831262569Simp pinctrl-0 = <&pinctrl_i2c0>; 832270864Simp clocks = <&twi0_clk>; 833262569Simp status = "disabled"; 834262569Simp }; 835262569Simp 836262569Simp i2c1: i2c@f8014000 { 837262569Simp compatible = "atmel,at91sam9x5-i2c"; 838262569Simp reg = <0xf8014000 0x100>; 839262569Simp interrupts = <10 IRQ_TYPE_LEVEL_HIGH 6>; 840262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(15)>, 841262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(16)>; 842262569Simp dma-names = "tx", "rx"; 843262569Simp #address-cells = <1>; 844262569Simp #size-cells = <0>; 845262569Simp pinctrl-names = "default"; 846262569Simp pinctrl-0 = <&pinctrl_i2c1>; 847270864Simp clocks = <&twi1_clk>; 848262569Simp status = "disabled"; 849262569Simp }; 850262569Simp 851262569Simp spi0: spi@f0000000 { 852262569Simp #address-cells = <1>; 853262569Simp #size-cells = <0>; 854262569Simp compatible = "atmel,at91rm9200-spi"; 855262569Simp reg = <0xf0000000 0x100>; 856262569Simp interrupts = <13 IRQ_TYPE_LEVEL_HIGH 3>; 857262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(1)>, 858262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(2)>; 859262569Simp dma-names = "tx", "rx"; 860262569Simp pinctrl-names = "default"; 861262569Simp pinctrl-0 = <&pinctrl_spi0>; 862270864Simp clocks = <&spi0_clk>; 863270864Simp clock-names = "spi_clk"; 864262569Simp status = "disabled"; 865262569Simp }; 866262569Simp 867262569Simp spi1: spi@f0004000 { 868262569Simp #address-cells = <1>; 869262569Simp #size-cells = <0>; 870262569Simp compatible = "atmel,at91rm9200-spi"; 871262569Simp reg = <0xf0004000 0x100>; 872262569Simp interrupts = <14 IRQ_TYPE_LEVEL_HIGH 3>; 873262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(3)>, 874262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(4)>; 875262569Simp dma-names = "tx", "rx"; 876262569Simp pinctrl-names = "default"; 877262569Simp pinctrl-0 = <&pinctrl_spi1>; 878270864Simp clocks = <&spi1_clk>; 879270864Simp clock-names = "spi_clk"; 880262569Simp status = "disabled"; 881262569Simp }; 882262569Simp 883262569Simp watchdog@fffffe40 { 884262569Simp compatible = "atmel,at91sam9260-wdt"; 885262569Simp reg = <0xfffffe40 0x10>; 886262569Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 887262569Simp atmel,watchdog-type = "hardware"; 888262569Simp atmel,reset-type = "all"; 889262569Simp atmel,dbg-halt; 890262569Simp atmel,idle-halt; 891262569Simp status = "disabled"; 892262569Simp }; 893262569Simp 894262569Simp pwm0: pwm@f8034000 { 895262569Simp compatible = "atmel,at91sam9rl-pwm"; 896262569Simp reg = <0xf8034000 0x300>; 897262569Simp interrupts = <18 IRQ_TYPE_LEVEL_HIGH 4>; 898262569Simp #pwm-cells = <3>; 899270864Simp clocks = <&pwm_clk>; 900262569Simp status = "disabled"; 901262569Simp }; 902262569Simp }; 903262569Simp 904262569Simp nand0: nand@40000000 { 905262569Simp compatible = "atmel,at91rm9200-nand"; 906262569Simp #address-cells = <1>; 907262569Simp #size-cells = <1>; 908262569Simp reg = < 0x40000000 0x10000000 909262569Simp 0xffffe000 0x00000600 910262569Simp 0xffffe600 0x00000200 911262569Simp 0x00108000 0x00018000 912262569Simp >; 913262569Simp atmel,pmecc-lookup-table-offset = <0x0 0x8000>; 914262569Simp atmel,nand-addr-offset = <21>; 915262569Simp atmel,nand-cmd-offset = <22>; 916270864Simp atmel,nand-has-dma; 917262569Simp pinctrl-names = "default"; 918262569Simp pinctrl-0 = <&pinctrl_nand>; 919262569Simp gpios = <&pioD 5 GPIO_ACTIVE_HIGH 920262569Simp &pioD 4 GPIO_ACTIVE_HIGH 921262569Simp 0 922262569Simp >; 923262569Simp status = "disabled"; 924262569Simp }; 925262569Simp 926262569Simp usb0: ohci@00500000 { 927262569Simp compatible = "atmel,at91rm9200-ohci", "usb-ohci"; 928262569Simp reg = <0x00500000 0x00100000>; 929262569Simp interrupts = <22 IRQ_TYPE_LEVEL_HIGH 2>; 930270864Simp clocks = <&usb>, <&uhphs_clk>, <&uhphs_clk>, 931270864Simp <&uhpck>; 932270864Simp clock-names = "usb_clk", "ohci_clk", "hclk", "uhpck"; 933262569Simp status = "disabled"; 934262569Simp }; 935262569Simp }; 936262569Simp 937262569Simp i2c@0 { 938262569Simp compatible = "i2c-gpio"; 939262569Simp gpios = <&pioA 30 GPIO_ACTIVE_HIGH /* sda */ 940262569Simp &pioA 31 GPIO_ACTIVE_HIGH /* scl */ 941262569Simp >; 942262569Simp i2c-gpio,sda-open-drain; 943262569Simp i2c-gpio,scl-open-drain; 944262569Simp i2c-gpio,delay-us = <2>; /* ~100 kHz */ 945262569Simp #address-cells = <1>; 946262569Simp #size-cells = <0>; 947262569Simp status = "disabled"; 948262569Simp }; 949262569Simp}; 950