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 67284090Sian sram: sram@00300000 { 68284090Sian compatible = "mmio-sram"; 69284090Sian reg = <0x00300000 0x8000>; 70284090Sian }; 71284090Sian 72262569Simp ahb { 73262569Simp compatible = "simple-bus"; 74262569Simp #address-cells = <1>; 75262569Simp #size-cells = <1>; 76262569Simp ranges; 77262569Simp 78262569Simp apb { 79262569Simp compatible = "simple-bus"; 80262569Simp #address-cells = <1>; 81262569Simp #size-cells = <1>; 82262569Simp ranges; 83262569Simp 84262569Simp aic: interrupt-controller@fffff000 { 85262569Simp #interrupt-cells = <3>; 86262569Simp compatible = "atmel,at91rm9200-aic"; 87262569Simp interrupt-controller; 88262569Simp reg = <0xfffff000 0x200>; 89262569Simp atmel,external-irqs = <31>; 90262569Simp }; 91262569Simp 92262569Simp ramc0: ramc@ffffe800 { 93262569Simp compatible = "atmel,at91sam9g45-ddramc"; 94262569Simp reg = <0xffffe800 0x200>; 95284090Sian clocks = <&ddrck>; 96284090Sian clock-names = "ddrck"; 97262569Simp }; 98262569Simp 99262569Simp pmc: pmc@fffffc00 { 100270864Simp compatible = "atmel,at91sam9n12-pmc"; 101270864Simp reg = <0xfffffc00 0x200>; 102270864Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 103270864Simp interrupt-controller; 104270864Simp #address-cells = <1>; 105270864Simp #size-cells = <0>; 106270864Simp #interrupt-cells = <1>; 107270864Simp 108270864Simp main_rc_osc: main_rc_osc { 109270864Simp compatible = "atmel,at91sam9x5-clk-main-rc-osc"; 110270864Simp #clock-cells = <0>; 111270864Simp interrupts-extended = <&pmc AT91_PMC_MOSCRCS>; 112270864Simp clock-frequency = <12000000>; 113270864Simp clock-accuracy = <50000000>; 114270864Simp }; 115270864Simp 116270864Simp main_osc: main_osc { 117270864Simp compatible = "atmel,at91rm9200-clk-main-osc"; 118270864Simp #clock-cells = <0>; 119270864Simp interrupts-extended = <&pmc AT91_PMC_MOSCS>; 120270864Simp clocks = <&main_xtal>; 121270864Simp }; 122270864Simp 123270864Simp main: mainck { 124270864Simp compatible = "atmel,at91sam9x5-clk-main"; 125270864Simp #clock-cells = <0>; 126270864Simp interrupts-extended = <&pmc AT91_PMC_MOSCSELS>; 127270864Simp clocks = <&main_rc_osc>, <&main_osc>; 128270864Simp }; 129270864Simp 130270864Simp plla: pllack { 131270864Simp compatible = "atmel,at91rm9200-clk-pll"; 132270864Simp #clock-cells = <0>; 133270864Simp interrupts-extended = <&pmc AT91_PMC_LOCKA>; 134270864Simp clocks = <&main>; 135270864Simp reg = <0>; 136270864Simp atmel,clk-input-range = <2000000 32000000>; 137270864Simp #atmel,pll-clk-output-range-cells = <4>; 138270864Simp atmel,pll-clk-output-ranges = <745000000 800000000 0 0>, 139270864Simp <695000000 750000000 1 0>, 140270864Simp <645000000 700000000 2 0>, 141270864Simp <595000000 650000000 3 0>, 142270864Simp <545000000 600000000 0 1>, 143270864Simp <495000000 555000000 1 1>, 144270864Simp <445000000 500000000 2 1>, 145270864Simp <400000000 450000000 3 1>; 146270864Simp }; 147270864Simp 148270864Simp plladiv: plladivck { 149270864Simp compatible = "atmel,at91sam9x5-clk-plldiv"; 150270864Simp #clock-cells = <0>; 151270864Simp clocks = <&plla>; 152270864Simp }; 153270864Simp 154270864Simp pllb: pllbck { 155270864Simp compatible = "atmel,at91rm9200-clk-pll"; 156270864Simp #clock-cells = <0>; 157270864Simp interrupts-extended = <&pmc AT91_PMC_LOCKB>; 158270864Simp clocks = <&main>; 159270864Simp reg = <1>; 160270864Simp atmel,clk-input-range = <2000000 32000000>; 161270864Simp #atmel,pll-clk-output-range-cells = <3>; 162270864Simp atmel,pll-clk-output-ranges = <30000000 100000000 0>; 163270864Simp }; 164270864Simp 165270864Simp mck: masterck { 166270864Simp compatible = "atmel,at91sam9x5-clk-master"; 167270864Simp #clock-cells = <0>; 168270864Simp interrupts-extended = <&pmc AT91_PMC_MCKRDY>; 169270864Simp clocks = <&clk32k>, <&main>, <&plladiv>, <&pllb>; 170270864Simp atmel,clk-output-range = <0 133333333>; 171270864Simp atmel,clk-divisors = <1 2 4 3>; 172270864Simp atmel,master-clk-have-div3-pres; 173270864Simp }; 174270864Simp 175270864Simp usb: usbck { 176270864Simp compatible = "atmel,at91sam9n12-clk-usb"; 177270864Simp #clock-cells = <0>; 178270864Simp clocks = <&pllb>; 179270864Simp }; 180270864Simp 181270864Simp prog: progck { 182270864Simp compatible = "atmel,at91sam9x5-clk-programmable"; 183270864Simp #address-cells = <1>; 184270864Simp #size-cells = <0>; 185270864Simp interrupt-parent = <&pmc>; 186270864Simp clocks = <&clk32k>, <&main>, <&plladiv>, <&pllb>, <&mck>; 187270864Simp 188270864Simp prog0: prog0 { 189270864Simp #clock-cells = <0>; 190270864Simp reg = <0>; 191270864Simp interrupts = <AT91_PMC_PCKRDY(0)>; 192270864Simp }; 193270864Simp 194270864Simp prog1: prog1 { 195270864Simp #clock-cells = <0>; 196270864Simp reg = <1>; 197270864Simp interrupts = <AT91_PMC_PCKRDY(1)>; 198270864Simp }; 199270864Simp }; 200270864Simp 201270864Simp systemck { 202270864Simp compatible = "atmel,at91rm9200-clk-system"; 203270864Simp #address-cells = <1>; 204270864Simp #size-cells = <0>; 205270864Simp 206270864Simp ddrck: ddrck { 207270864Simp #clock-cells = <0>; 208270864Simp reg = <2>; 209270864Simp clocks = <&mck>; 210270864Simp }; 211270864Simp 212270864Simp lcdck: lcdck { 213270864Simp #clock-cells = <0>; 214270864Simp reg = <3>; 215270864Simp clocks = <&mck>; 216270864Simp }; 217270864Simp 218270864Simp uhpck: uhpck { 219270864Simp #clock-cells = <0>; 220270864Simp reg = <6>; 221270864Simp clocks = <&usb>; 222270864Simp }; 223270864Simp 224270864Simp udpck: udpck { 225270864Simp #clock-cells = <0>; 226270864Simp reg = <7>; 227270864Simp clocks = <&usb>; 228270864Simp }; 229270864Simp 230270864Simp pck0: pck0 { 231270864Simp #clock-cells = <0>; 232270864Simp reg = <8>; 233270864Simp clocks = <&prog0>; 234270864Simp }; 235270864Simp 236270864Simp pck1: pck1 { 237270864Simp #clock-cells = <0>; 238270864Simp reg = <9>; 239270864Simp clocks = <&prog1>; 240270864Simp }; 241270864Simp }; 242270864Simp 243270864Simp periphck { 244270864Simp compatible = "atmel,at91sam9x5-clk-peripheral"; 245270864Simp #address-cells = <1>; 246270864Simp #size-cells = <0>; 247270864Simp clocks = <&mck>; 248270864Simp 249270864Simp pioAB_clk: pioAB_clk { 250270864Simp #clock-cells = <0>; 251270864Simp reg = <2>; 252270864Simp }; 253270864Simp 254270864Simp pioCD_clk: pioCD_clk { 255270864Simp #clock-cells = <0>; 256270864Simp reg = <3>; 257270864Simp }; 258270864Simp 259270864Simp fuse_clk: fuse_clk { 260270864Simp #clock-cells = <0>; 261270864Simp reg = <4>; 262270864Simp }; 263270864Simp 264270864Simp usart0_clk: usart0_clk { 265270864Simp #clock-cells = <0>; 266270864Simp reg = <5>; 267270864Simp }; 268270864Simp 269270864Simp usart1_clk: usart1_clk { 270270864Simp #clock-cells = <0>; 271270864Simp reg = <6>; 272270864Simp }; 273270864Simp 274270864Simp usart2_clk: usart2_clk { 275270864Simp #clock-cells = <0>; 276270864Simp reg = <7>; 277270864Simp }; 278270864Simp 279270864Simp usart3_clk: usart3_clk { 280270864Simp #clock-cells = <0>; 281270864Simp reg = <8>; 282270864Simp }; 283270864Simp 284270864Simp twi0_clk: twi0_clk { 285270864Simp reg = <9>; 286270864Simp #clock-cells = <0>; 287270864Simp }; 288270864Simp 289270864Simp twi1_clk: twi1_clk { 290270864Simp #clock-cells = <0>; 291270864Simp reg = <10>; 292270864Simp }; 293270864Simp 294270864Simp mci0_clk: mci0_clk { 295270864Simp #clock-cells = <0>; 296270864Simp reg = <12>; 297270864Simp }; 298270864Simp 299270864Simp spi0_clk: spi0_clk { 300270864Simp #clock-cells = <0>; 301270864Simp reg = <13>; 302270864Simp }; 303270864Simp 304270864Simp spi1_clk: spi1_clk { 305270864Simp #clock-cells = <0>; 306270864Simp reg = <14>; 307270864Simp }; 308270864Simp 309270864Simp uart0_clk: uart0_clk { 310270864Simp #clock-cells = <0>; 311270864Simp reg = <15>; 312270864Simp }; 313270864Simp 314270864Simp uart1_clk: uart1_clk { 315270864Simp #clock-cells = <0>; 316270864Simp reg = <16>; 317270864Simp }; 318270864Simp 319270864Simp tcb_clk: tcb_clk { 320270864Simp #clock-cells = <0>; 321270864Simp reg = <17>; 322270864Simp }; 323270864Simp 324270864Simp pwm_clk: pwm_clk { 325270864Simp #clock-cells = <0>; 326270864Simp reg = <18>; 327270864Simp }; 328270864Simp 329270864Simp adc_clk: adc_clk { 330270864Simp #clock-cells = <0>; 331270864Simp reg = <19>; 332270864Simp }; 333270864Simp 334270864Simp dma0_clk: dma0_clk { 335270864Simp #clock-cells = <0>; 336270864Simp reg = <20>; 337270864Simp }; 338270864Simp 339270864Simp uhphs_clk: uhphs_clk { 340270864Simp #clock-cells = <0>; 341270864Simp reg = <22>; 342270864Simp }; 343270864Simp 344270864Simp udphs_clk: udphs_clk { 345270864Simp #clock-cells = <0>; 346270864Simp reg = <23>; 347270864Simp }; 348270864Simp 349270864Simp lcdc_clk: lcdc_clk { 350270864Simp #clock-cells = <0>; 351270864Simp reg = <25>; 352270864Simp }; 353270864Simp 354270864Simp sha_clk: sha_clk { 355270864Simp #clock-cells = <0>; 356270864Simp reg = <27>; 357270864Simp }; 358270864Simp 359270864Simp ssc0_clk: ssc0_clk { 360270864Simp #clock-cells = <0>; 361270864Simp reg = <28>; 362270864Simp }; 363270864Simp 364270864Simp aes_clk: aes_clk { 365270864Simp #clock-cells = <0>; 366270864Simp reg = <29>; 367270864Simp }; 368270864Simp 369270864Simp trng_clk: trng_clk { 370270864Simp #clock-cells = <0>; 371270864Simp reg = <30>; 372270864Simp }; 373270864Simp }; 374262569Simp }; 375262569Simp 376262569Simp rstc@fffffe00 { 377262569Simp compatible = "atmel,at91sam9g45-rstc"; 378262569Simp reg = <0xfffffe00 0x10>; 379262569Simp }; 380262569Simp 381262569Simp pit: timer@fffffe30 { 382262569Simp compatible = "atmel,at91sam9260-pit"; 383262569Simp reg = <0xfffffe30 0xf>; 384262569Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 385270864Simp clocks = <&mck>; 386262569Simp }; 387262569Simp 388262569Simp shdwc@fffffe10 { 389262569Simp compatible = "atmel,at91sam9x5-shdwc"; 390262569Simp reg = <0xfffffe10 0x10>; 391262569Simp }; 392262569Simp 393270864Simp sckc@fffffe50 { 394270864Simp compatible = "atmel,at91sam9x5-sckc"; 395270864Simp reg = <0xfffffe50 0x4>; 396270864Simp 397270864Simp slow_osc: slow_osc { 398270864Simp compatible = "atmel,at91sam9x5-clk-slow-osc"; 399270864Simp #clock-cells = <0>; 400270864Simp clocks = <&slow_xtal>; 401270864Simp }; 402270864Simp 403270864Simp slow_rc_osc: slow_rc_osc { 404270864Simp compatible = "atmel,at91sam9x5-clk-slow-rc-osc"; 405270864Simp #clock-cells = <0>; 406270864Simp clock-frequency = <32768>; 407270864Simp clock-accuracy = <50000000>; 408270864Simp }; 409270864Simp 410270864Simp clk32k: slck { 411270864Simp compatible = "atmel,at91sam9x5-clk-slow"; 412270864Simp #clock-cells = <0>; 413270864Simp clocks = <&slow_rc_osc>, <&slow_osc>; 414270864Simp }; 415270864Simp }; 416270864Simp 417262569Simp mmc0: mmc@f0008000 { 418262569Simp compatible = "atmel,hsmci"; 419262569Simp reg = <0xf0008000 0x600>; 420262569Simp interrupts = <12 IRQ_TYPE_LEVEL_HIGH 0>; 421262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(0)>; 422262569Simp dma-names = "rxtx"; 423270864Simp clocks = <&mci0_clk>; 424270864Simp clock-names = "mci_clk"; 425262569Simp #address-cells = <1>; 426262569Simp #size-cells = <0>; 427262569Simp status = "disabled"; 428262569Simp }; 429262569Simp 430262569Simp tcb0: timer@f8008000 { 431262569Simp compatible = "atmel,at91sam9x5-tcb"; 432262569Simp reg = <0xf8008000 0x100>; 433262569Simp interrupts = <17 IRQ_TYPE_LEVEL_HIGH 0>; 434270864Simp clocks = <&tcb_clk>; 435270864Simp clock-names = "t0_clk"; 436262569Simp }; 437262569Simp 438262569Simp tcb1: timer@f800c000 { 439262569Simp compatible = "atmel,at91sam9x5-tcb"; 440262569Simp reg = <0xf800c000 0x100>; 441262569Simp interrupts = <17 IRQ_TYPE_LEVEL_HIGH 0>; 442270864Simp clocks = <&tcb_clk>; 443270864Simp clock-names = "t0_clk"; 444262569Simp }; 445262569Simp 446262569Simp dma: dma-controller@ffffec00 { 447262569Simp compatible = "atmel,at91sam9g45-dma"; 448262569Simp reg = <0xffffec00 0x200>; 449262569Simp interrupts = <20 IRQ_TYPE_LEVEL_HIGH 0>; 450262569Simp #dma-cells = <2>; 451270864Simp clocks = <&dma0_clk>; 452270864Simp clock-names = "dma_clk"; 453262569Simp }; 454262569Simp 455262569Simp pinctrl@fffff400 { 456262569Simp #address-cells = <1>; 457262569Simp #size-cells = <1>; 458262569Simp compatible = "atmel,at91sam9x5-pinctrl", "atmel,at91rm9200-pinctrl", "simple-bus"; 459262569Simp ranges = <0xfffff400 0xfffff400 0x800>; 460262569Simp 461262569Simp atmel,mux-mask = < 462262569Simp /* A B C */ 463262569Simp 0xffffffff 0xffe07983 0x00000000 /* pioA */ 464262569Simp 0x00040000 0x00047e0f 0x00000000 /* pioB */ 465262569Simp 0xfdffffff 0x07c00000 0xb83fffff /* pioC */ 466262569Simp 0x003fffff 0x003f8000 0x00000000 /* pioD */ 467262569Simp >; 468262569Simp 469262569Simp /* shared pinctrl settings */ 470262569Simp dbgu { 471262569Simp pinctrl_dbgu: dbgu-0 { 472262569Simp atmel,pins = 473262569Simp <AT91_PIOA 9 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA9 periph A */ 474262569Simp AT91_PIOA 10 AT91_PERIPH_A AT91_PINCTRL_PULL_UP>; /* PA10 periph with pullup */ 475262569Simp }; 476262569Simp }; 477262569Simp 478262569Simp usart0 { 479262569Simp pinctrl_usart0: usart0-0 { 480262569Simp atmel,pins = 481262569Simp <AT91_PIOA 1 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA1 periph A with pullup */ 482262569Simp AT91_PIOA 0 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA0 periph A */ 483262569Simp }; 484262569Simp 485262569Simp pinctrl_usart0_rts: usart0_rts-0 { 486262569Simp atmel,pins = 487262569Simp <AT91_PIOA 2 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA2 periph A */ 488262569Simp }; 489262569Simp 490262569Simp pinctrl_usart0_cts: usart0_cts-0 { 491262569Simp atmel,pins = 492262569Simp <AT91_PIOA 3 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA3 periph A */ 493262569Simp }; 494262569Simp }; 495262569Simp 496262569Simp usart1 { 497262569Simp pinctrl_usart1: usart1-0 { 498262569Simp atmel,pins = 499262569Simp <AT91_PIOA 6 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA6 periph A with pullup */ 500262569Simp AT91_PIOA 5 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA5 periph A */ 501262569Simp }; 502262569Simp }; 503262569Simp 504262569Simp usart2 { 505262569Simp pinctrl_usart2: usart2-0 { 506262569Simp atmel,pins = 507262569Simp <AT91_PIOA 8 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA8 periph A with pullup */ 508262569Simp AT91_PIOA 7 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA7 periph A */ 509262569Simp }; 510262569Simp 511262569Simp pinctrl_usart2_rts: usart2_rts-0 { 512262569Simp atmel,pins = 513262569Simp <AT91_PIOB 0 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PB0 periph B */ 514262569Simp }; 515262569Simp 516262569Simp pinctrl_usart2_cts: usart2_cts-0 { 517262569Simp atmel,pins = 518262569Simp <AT91_PIOB 1 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PB1 periph B */ 519262569Simp }; 520262569Simp }; 521262569Simp 522262569Simp usart3 { 523262569Simp pinctrl_usart3: usart3-0 { 524262569Simp atmel,pins = 525262569Simp <AT91_PIOC 23 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PC23 periph B with pullup */ 526262569Simp AT91_PIOC 22 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PC22 periph B */ 527262569Simp }; 528262569Simp 529262569Simp pinctrl_usart3_rts: usart3_rts-0 { 530262569Simp atmel,pins = 531262569Simp <AT91_PIOC 24 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PC24 periph B */ 532262569Simp }; 533262569Simp 534262569Simp pinctrl_usart3_cts: usart3_cts-0 { 535262569Simp atmel,pins = 536262569Simp <AT91_PIOC 25 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PC25 periph B */ 537262569Simp }; 538262569Simp }; 539262569Simp 540262569Simp uart0 { 541262569Simp pinctrl_uart0: uart0-0 { 542262569Simp atmel,pins = 543262569Simp <AT91_PIOC 9 AT91_PERIPH_C AT91_PINCTRL_PULL_UP /* PC9 periph C with pullup */ 544262569Simp AT91_PIOC 8 AT91_PERIPH_C AT91_PINCTRL_NONE>; /* PC8 periph C */ 545262569Simp }; 546262569Simp }; 547262569Simp 548262569Simp uart1 { 549262569Simp pinctrl_uart1: uart1-0 { 550262569Simp atmel,pins = 551262569Simp <AT91_PIOC 16 AT91_PERIPH_C AT91_PINCTRL_PULL_UP /* PC17 periph C with pullup */ 552262569Simp AT91_PIOC 17 AT91_PERIPH_C AT91_PINCTRL_NONE>; /* PC16 periph C */ 553262569Simp }; 554262569Simp }; 555262569Simp 556262569Simp nand { 557262569Simp pinctrl_nand: nand-0 { 558262569Simp atmel,pins = 559262569Simp <AT91_PIOD 5 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP /* PD5 gpio RDY pin pull_up*/ 560262569Simp AT91_PIOD 4 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP>; /* PD4 gpio enable pin pull_up */ 561262569Simp }; 562262569Simp }; 563262569Simp 564262569Simp mmc0 { 565262569Simp pinctrl_mmc0_slot0_clk_cmd_dat0: mmc0_slot0_clk_cmd_dat0-0 { 566262569Simp atmel,pins = 567262569Simp <AT91_PIOA 17 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA17 periph A */ 568262569Simp AT91_PIOA 16 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA16 periph A with pullup */ 569262569Simp AT91_PIOA 15 AT91_PERIPH_A AT91_PINCTRL_PULL_UP>; /* PA15 periph A with pullup */ 570262569Simp }; 571262569Simp 572262569Simp pinctrl_mmc0_slot0_dat1_3: mmc0_slot0_dat1_3-0 { 573262569Simp atmel,pins = 574262569Simp <AT91_PIOA 18 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA18 periph A with pullup */ 575262569Simp AT91_PIOA 19 AT91_PERIPH_A AT91_PINCTRL_PULL_UP /* PA19 periph A with pullup */ 576262569Simp AT91_PIOA 20 AT91_PERIPH_A AT91_PINCTRL_PULL_UP>; /* PA20 periph A with pullup */ 577262569Simp }; 578262569Simp 579262569Simp pinctrl_mmc0_slot0_dat4_7: mmc0_slot0_dat4_7-0 { 580262569Simp atmel,pins = 581262569Simp <AT91_PIOA 11 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PA11 periph B with pullup */ 582262569Simp AT91_PIOA 12 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PA12 periph B with pullup */ 583262569Simp AT91_PIOA 13 AT91_PERIPH_B AT91_PINCTRL_PULL_UP /* PA13 periph B with pullup */ 584262569Simp AT91_PIOA 14 AT91_PERIPH_B AT91_PINCTRL_PULL_UP>; /* PA14 periph B with pullup */ 585262569Simp }; 586262569Simp }; 587262569Simp 588262569Simp ssc0 { 589262569Simp pinctrl_ssc0_tx: ssc0_tx-0 { 590262569Simp atmel,pins = 591262569Simp <AT91_PIOA 24 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA24 periph B */ 592262569Simp AT91_PIOA 25 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA25 periph B */ 593262569Simp AT91_PIOA 26 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PA26 periph B */ 594262569Simp }; 595262569Simp 596262569Simp pinctrl_ssc0_rx: ssc0_rx-0 { 597262569Simp atmel,pins = 598262569Simp <AT91_PIOA 27 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA27 periph B */ 599262569Simp AT91_PIOA 28 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA28 periph B */ 600262569Simp AT91_PIOA 29 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PA29 periph B */ 601262569Simp }; 602262569Simp }; 603262569Simp 604262569Simp spi0 { 605262569Simp pinctrl_spi0: spi0-0 { 606262569Simp atmel,pins = 607262569Simp <AT91_PIOA 11 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA11 periph A SPI0_MISO pin */ 608262569Simp AT91_PIOA 12 AT91_PERIPH_A AT91_PINCTRL_NONE /* PA12 periph A SPI0_MOSI pin */ 609262569Simp AT91_PIOA 13 AT91_PERIPH_A AT91_PINCTRL_NONE>; /* PA13 periph A SPI0_SPCK pin */ 610262569Simp }; 611262569Simp }; 612262569Simp 613262569Simp spi1 { 614262569Simp pinctrl_spi1: spi1-0 { 615262569Simp atmel,pins = 616262569Simp <AT91_PIOA 21 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA21 periph B SPI1_MISO pin */ 617262569Simp AT91_PIOA 22 AT91_PERIPH_B AT91_PINCTRL_NONE /* PA22 periph B SPI1_MOSI pin */ 618262569Simp AT91_PIOA 23 AT91_PERIPH_B AT91_PINCTRL_NONE>; /* PA23 periph B SPI1_SPCK pin */ 619262569Simp }; 620262569Simp }; 621262569Simp 622262569Simp i2c0 { 623262569Simp pinctrl_i2c0: i2c0-0 { 624262569Simp atmel,pins = 625262569Simp <AT91_PIOA 30 AT91_PERIPH_A AT91_PINCTRL_NONE 626262569Simp AT91_PIOA 31 AT91_PERIPH_A AT91_PINCTRL_NONE>; 627262569Simp }; 628262569Simp }; 629262569Simp 630262569Simp i2c1 { 631262569Simp pinctrl_i2c1: i2c1-0 { 632262569Simp atmel,pins = 633262569Simp <AT91_PIOC 0 AT91_PERIPH_C AT91_PINCTRL_NONE 634262569Simp AT91_PIOC 1 AT91_PERIPH_C AT91_PINCTRL_NONE>; 635262569Simp }; 636262569Simp }; 637262569Simp 638262569Simp tcb0 { 639262569Simp pinctrl_tcb0_tclk0: tcb0_tclk0-0 { 640262569Simp atmel,pins = <AT91_PIOA 24 AT91_PERIPH_A AT91_PINCTRL_NONE>; 641262569Simp }; 642262569Simp 643262569Simp pinctrl_tcb0_tclk1: tcb0_tclk1-0 { 644262569Simp atmel,pins = <AT91_PIOA 25 AT91_PERIPH_A AT91_PINCTRL_NONE>; 645262569Simp }; 646262569Simp 647262569Simp pinctrl_tcb0_tclk2: tcb0_tclk2-0 { 648262569Simp atmel,pins = <AT91_PIOA 26 AT91_PERIPH_A AT91_PINCTRL_NONE>; 649262569Simp }; 650262569Simp 651262569Simp pinctrl_tcb0_tioa0: tcb0_tioa0-0 { 652262569Simp atmel,pins = <AT91_PIOA 21 AT91_PERIPH_A AT91_PINCTRL_NONE>; 653262569Simp }; 654262569Simp 655262569Simp pinctrl_tcb0_tioa1: tcb0_tioa1-0 { 656262569Simp atmel,pins = <AT91_PIOA 22 AT91_PERIPH_A AT91_PINCTRL_NONE>; 657262569Simp }; 658262569Simp 659262569Simp pinctrl_tcb0_tioa2: tcb0_tioa2-0 { 660262569Simp atmel,pins = <AT91_PIOA 23 AT91_PERIPH_A AT91_PINCTRL_NONE>; 661262569Simp }; 662262569Simp 663262569Simp pinctrl_tcb0_tiob0: tcb0_tiob0-0 { 664262569Simp atmel,pins = <AT91_PIOA 27 AT91_PERIPH_A AT91_PINCTRL_NONE>; 665262569Simp }; 666262569Simp 667262569Simp pinctrl_tcb0_tiob1: tcb0_tiob1-0 { 668262569Simp atmel,pins = <AT91_PIOA 28 AT91_PERIPH_A AT91_PINCTRL_NONE>; 669262569Simp }; 670262569Simp 671262569Simp pinctrl_tcb0_tiob2: tcb0_tiob2-0 { 672262569Simp atmel,pins = <AT91_PIOA 29 AT91_PERIPH_A AT91_PINCTRL_NONE>; 673262569Simp }; 674262569Simp }; 675262569Simp 676262569Simp tcb1 { 677262569Simp pinctrl_tcb1_tclk0: tcb1_tclk0-0 { 678262569Simp atmel,pins = <AT91_PIOC 4 AT91_PERIPH_C AT91_PINCTRL_NONE>; 679262569Simp }; 680262569Simp 681262569Simp pinctrl_tcb1_tclk1: tcb1_tclk1-0 { 682262569Simp atmel,pins = <AT91_PIOC 7 AT91_PERIPH_C AT91_PINCTRL_NONE>; 683262569Simp }; 684262569Simp 685262569Simp pinctrl_tcb1_tclk2: tcb1_tclk2-0 { 686262569Simp atmel,pins = <AT91_PIOC 14 AT91_PERIPH_C AT91_PINCTRL_NONE>; 687262569Simp }; 688262569Simp 689262569Simp pinctrl_tcb1_tioa0: tcb1_tioa0-0 { 690262569Simp atmel,pins = <AT91_PIOC 2 AT91_PERIPH_C AT91_PINCTRL_NONE>; 691262569Simp }; 692262569Simp 693262569Simp pinctrl_tcb1_tioa1: tcb1_tioa1-0 { 694262569Simp atmel,pins = <AT91_PIOC 5 AT91_PERIPH_C AT91_PINCTRL_NONE>; 695262569Simp }; 696262569Simp 697262569Simp pinctrl_tcb1_tioa2: tcb1_tioa2-0 { 698262569Simp atmel,pins = <AT91_PIOC 12 AT91_PERIPH_C AT91_PINCTRL_NONE>; 699262569Simp }; 700262569Simp 701262569Simp pinctrl_tcb1_tiob0: tcb1_tiob0-0 { 702262569Simp atmel,pins = <AT91_PIOC 3 AT91_PERIPH_C AT91_PINCTRL_NONE>; 703262569Simp }; 704262569Simp 705262569Simp pinctrl_tcb1_tiob1: tcb1_tiob1-0 { 706262569Simp atmel,pins = <AT91_PIOC 6 AT91_PERIPH_C AT91_PINCTRL_NONE>; 707262569Simp }; 708262569Simp 709262569Simp pinctrl_tcb1_tiob2: tcb1_tiob2-0 { 710262569Simp atmel,pins = <AT91_PIOC 13 AT91_PERIPH_C AT91_PINCTRL_NONE>; 711262569Simp }; 712262569Simp }; 713262569Simp 714262569Simp pioA: gpio@fffff400 { 715262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 716262569Simp reg = <0xfffff400 0x200>; 717262569Simp interrupts = <2 IRQ_TYPE_LEVEL_HIGH 1>; 718262569Simp #gpio-cells = <2>; 719262569Simp gpio-controller; 720262569Simp interrupt-controller; 721262569Simp #interrupt-cells = <2>; 722270864Simp clocks = <&pioAB_clk>; 723262569Simp }; 724262569Simp 725262569Simp pioB: gpio@fffff600 { 726262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 727262569Simp reg = <0xfffff600 0x200>; 728262569Simp interrupts = <2 IRQ_TYPE_LEVEL_HIGH 1>; 729262569Simp #gpio-cells = <2>; 730262569Simp gpio-controller; 731262569Simp interrupt-controller; 732262569Simp #interrupt-cells = <2>; 733270864Simp clocks = <&pioAB_clk>; 734262569Simp }; 735262569Simp 736262569Simp pioC: gpio@fffff800 { 737262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 738262569Simp reg = <0xfffff800 0x200>; 739262569Simp interrupts = <3 IRQ_TYPE_LEVEL_HIGH 1>; 740262569Simp #gpio-cells = <2>; 741262569Simp gpio-controller; 742262569Simp interrupt-controller; 743262569Simp #interrupt-cells = <2>; 744270864Simp clocks = <&pioCD_clk>; 745262569Simp }; 746262569Simp 747262569Simp pioD: gpio@fffffa00 { 748262569Simp compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; 749262569Simp reg = <0xfffffa00 0x200>; 750262569Simp interrupts = <3 IRQ_TYPE_LEVEL_HIGH 1>; 751262569Simp #gpio-cells = <2>; 752262569Simp gpio-controller; 753262569Simp interrupt-controller; 754262569Simp #interrupt-cells = <2>; 755270864Simp clocks = <&pioCD_clk>; 756262569Simp }; 757262569Simp }; 758262569Simp 759262569Simp dbgu: serial@fffff200 { 760262569Simp compatible = "atmel,at91sam9260-usart"; 761262569Simp reg = <0xfffff200 0x200>; 762262569Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 763262569Simp pinctrl-names = "default"; 764262569Simp pinctrl-0 = <&pinctrl_dbgu>; 765270864Simp clocks = <&mck>; 766270864Simp clock-names = "usart"; 767262569Simp status = "disabled"; 768262569Simp }; 769262569Simp 770262569Simp ssc0: ssc@f0010000 { 771262569Simp compatible = "atmel,at91sam9g45-ssc"; 772262569Simp reg = <0xf0010000 0x4000>; 773262569Simp interrupts = <28 IRQ_TYPE_LEVEL_HIGH 5>; 774262569Simp dmas = <&dma 0 AT91_DMA_CFG_PER_ID(21)>, 775262569Simp <&dma 0 AT91_DMA_CFG_PER_ID(22)>; 776262569Simp dma-names = "tx", "rx"; 777262569Simp pinctrl-names = "default"; 778262569Simp pinctrl-0 = <&pinctrl_ssc0_tx &pinctrl_ssc0_rx>; 779270864Simp clocks = <&ssc0_clk>; 780270864Simp clock-names = "pclk"; 781262569Simp status = "disabled"; 782262569Simp }; 783262569Simp 784262569Simp usart0: serial@f801c000 { 785262569Simp compatible = "atmel,at91sam9260-usart"; 786262569Simp reg = <0xf801c000 0x4000>; 787262569Simp interrupts = <5 IRQ_TYPE_LEVEL_HIGH 5>; 788262569Simp pinctrl-names = "default"; 789262569Simp pinctrl-0 = <&pinctrl_usart0>; 790270864Simp clocks = <&usart0_clk>; 791270864Simp clock-names = "usart"; 792262569Simp status = "disabled"; 793262569Simp }; 794262569Simp 795262569Simp usart1: serial@f8020000 { 796262569Simp compatible = "atmel,at91sam9260-usart"; 797262569Simp reg = <0xf8020000 0x4000>; 798262569Simp interrupts = <6 IRQ_TYPE_LEVEL_HIGH 5>; 799262569Simp pinctrl-names = "default"; 800262569Simp pinctrl-0 = <&pinctrl_usart1>; 801270864Simp clocks = <&usart1_clk>; 802270864Simp clock-names = "usart"; 803262569Simp status = "disabled"; 804262569Simp }; 805262569Simp 806262569Simp usart2: serial@f8024000 { 807262569Simp compatible = "atmel,at91sam9260-usart"; 808262569Simp reg = <0xf8024000 0x4000>; 809262569Simp interrupts = <7 IRQ_TYPE_LEVEL_HIGH 5>; 810262569Simp pinctrl-names = "default"; 811262569Simp pinctrl-0 = <&pinctrl_usart2>; 812270864Simp clocks = <&usart2_clk>; 813270864Simp clock-names = "usart"; 814262569Simp status = "disabled"; 815262569Simp }; 816262569Simp 817262569Simp usart3: serial@f8028000 { 818262569Simp compatible = "atmel,at91sam9260-usart"; 819262569Simp reg = <0xf8028000 0x4000>; 820262569Simp interrupts = <8 IRQ_TYPE_LEVEL_HIGH 5>; 821262569Simp pinctrl-names = "default"; 822262569Simp pinctrl-0 = <&pinctrl_usart3>; 823270864Simp clocks = <&usart3_clk>; 824270864Simp clock-names = "usart"; 825262569Simp status = "disabled"; 826262569Simp }; 827262569Simp 828262569Simp i2c0: i2c@f8010000 { 829262569Simp compatible = "atmel,at91sam9x5-i2c"; 830262569Simp reg = <0xf8010000 0x100>; 831262569Simp interrupts = <9 IRQ_TYPE_LEVEL_HIGH 6>; 832262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(13)>, 833262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(14)>; 834262569Simp dma-names = "tx", "rx"; 835262569Simp #address-cells = <1>; 836262569Simp #size-cells = <0>; 837262569Simp pinctrl-names = "default"; 838262569Simp pinctrl-0 = <&pinctrl_i2c0>; 839270864Simp clocks = <&twi0_clk>; 840262569Simp status = "disabled"; 841262569Simp }; 842262569Simp 843262569Simp i2c1: i2c@f8014000 { 844262569Simp compatible = "atmel,at91sam9x5-i2c"; 845262569Simp reg = <0xf8014000 0x100>; 846262569Simp interrupts = <10 IRQ_TYPE_LEVEL_HIGH 6>; 847262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(15)>, 848262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(16)>; 849262569Simp dma-names = "tx", "rx"; 850262569Simp #address-cells = <1>; 851262569Simp #size-cells = <0>; 852262569Simp pinctrl-names = "default"; 853262569Simp pinctrl-0 = <&pinctrl_i2c1>; 854270864Simp clocks = <&twi1_clk>; 855262569Simp status = "disabled"; 856262569Simp }; 857262569Simp 858262569Simp spi0: spi@f0000000 { 859262569Simp #address-cells = <1>; 860262569Simp #size-cells = <0>; 861262569Simp compatible = "atmel,at91rm9200-spi"; 862262569Simp reg = <0xf0000000 0x100>; 863262569Simp interrupts = <13 IRQ_TYPE_LEVEL_HIGH 3>; 864262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(1)>, 865262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(2)>; 866262569Simp dma-names = "tx", "rx"; 867262569Simp pinctrl-names = "default"; 868262569Simp pinctrl-0 = <&pinctrl_spi0>; 869270864Simp clocks = <&spi0_clk>; 870270864Simp clock-names = "spi_clk"; 871262569Simp status = "disabled"; 872262569Simp }; 873262569Simp 874262569Simp spi1: spi@f0004000 { 875262569Simp #address-cells = <1>; 876262569Simp #size-cells = <0>; 877262569Simp compatible = "atmel,at91rm9200-spi"; 878262569Simp reg = <0xf0004000 0x100>; 879262569Simp interrupts = <14 IRQ_TYPE_LEVEL_HIGH 3>; 880262569Simp dmas = <&dma 1 AT91_DMA_CFG_PER_ID(3)>, 881262569Simp <&dma 1 AT91_DMA_CFG_PER_ID(4)>; 882262569Simp dma-names = "tx", "rx"; 883262569Simp pinctrl-names = "default"; 884262569Simp pinctrl-0 = <&pinctrl_spi1>; 885270864Simp clocks = <&spi1_clk>; 886270864Simp clock-names = "spi_clk"; 887262569Simp status = "disabled"; 888262569Simp }; 889262569Simp 890262569Simp watchdog@fffffe40 { 891262569Simp compatible = "atmel,at91sam9260-wdt"; 892262569Simp reg = <0xfffffe40 0x10>; 893262569Simp interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 894262569Simp atmel,watchdog-type = "hardware"; 895262569Simp atmel,reset-type = "all"; 896262569Simp atmel,dbg-halt; 897262569Simp atmel,idle-halt; 898262569Simp status = "disabled"; 899262569Simp }; 900262569Simp 901284090Sian rtc@fffffeb0 { 902284090Sian compatible = "atmel,at91rm9200-rtc"; 903284090Sian reg = <0xfffffeb0 0x40>; 904284090Sian interrupts = <1 IRQ_TYPE_LEVEL_HIGH 7>; 905284090Sian status = "disabled"; 906284090Sian }; 907284090Sian 908262569Simp pwm0: pwm@f8034000 { 909262569Simp compatible = "atmel,at91sam9rl-pwm"; 910262569Simp reg = <0xf8034000 0x300>; 911262569Simp interrupts = <18 IRQ_TYPE_LEVEL_HIGH 4>; 912262569Simp #pwm-cells = <3>; 913270864Simp clocks = <&pwm_clk>; 914262569Simp status = "disabled"; 915262569Simp }; 916262569Simp }; 917262569Simp 918262569Simp nand0: nand@40000000 { 919262569Simp compatible = "atmel,at91rm9200-nand"; 920262569Simp #address-cells = <1>; 921262569Simp #size-cells = <1>; 922262569Simp reg = < 0x40000000 0x10000000 923262569Simp 0xffffe000 0x00000600 924262569Simp 0xffffe600 0x00000200 925262569Simp 0x00108000 0x00018000 926262569Simp >; 927262569Simp atmel,pmecc-lookup-table-offset = <0x0 0x8000>; 928262569Simp atmel,nand-addr-offset = <21>; 929262569Simp atmel,nand-cmd-offset = <22>; 930270864Simp atmel,nand-has-dma; 931262569Simp pinctrl-names = "default"; 932262569Simp pinctrl-0 = <&pinctrl_nand>; 933262569Simp gpios = <&pioD 5 GPIO_ACTIVE_HIGH 934262569Simp &pioD 4 GPIO_ACTIVE_HIGH 935262569Simp 0 936262569Simp >; 937262569Simp status = "disabled"; 938262569Simp }; 939262569Simp 940262569Simp usb0: ohci@00500000 { 941262569Simp compatible = "atmel,at91rm9200-ohci", "usb-ohci"; 942262569Simp reg = <0x00500000 0x00100000>; 943262569Simp interrupts = <22 IRQ_TYPE_LEVEL_HIGH 2>; 944270864Simp clocks = <&usb>, <&uhphs_clk>, <&uhphs_clk>, 945270864Simp <&uhpck>; 946270864Simp clock-names = "usb_clk", "ohci_clk", "hclk", "uhpck"; 947262569Simp status = "disabled"; 948262569Simp }; 949262569Simp }; 950262569Simp 951262569Simp i2c@0 { 952262569Simp compatible = "i2c-gpio"; 953262569Simp gpios = <&pioA 30 GPIO_ACTIVE_HIGH /* sda */ 954262569Simp &pioA 31 GPIO_ACTIVE_HIGH /* scl */ 955262569Simp >; 956262569Simp i2c-gpio,sda-open-drain; 957262569Simp i2c-gpio,scl-open-drain; 958262569Simp i2c-gpio,delay-us = <2>; /* ~100 kHz */ 959262569Simp #address-cells = <1>; 960262569Simp #size-cells = <0>; 961262569Simp status = "disabled"; 962262569Simp }; 963262569Simp}; 964