2019-04-03 22:52:18 +02:00
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2015-03-04 10:51:48 +08:00
/*
* at91-sama5d4_xplained.dts - Device Tree file for SAMA5D4 Xplained board
*
* Copyright (C) 2015 Atmel,
* 2015 Josh Wu <josh.wu@atmel.com>
*/
/dts-v1/;
#include "sama5d4.dtsi"
/ {
model = "Atmel SAMA5D4 Xplained";
compatible = "atmel,sama5d4-xplained", "atmel,sama5d4", "atmel,sama5";
chosen {
2015-06-03 14:24:17 +02:00
stdout-path = "serial0:115200n8";
2015-03-04 10:51:48 +08:00
};
2020-08-31 19:11:28 +02:00
memory@20000000 {
2015-03-04 10:51:48 +08:00
reg = <0x20000000 0x20000000>;
};
clocks {
slow_xtal {
clock-frequency = <32768>;
};
main_xtal {
clock-frequency = <12000000>;
};
};
ahb {
apb {
2016-11-30 18:36:30 +01:00
uart0: serial@f8004000 {
atmel,use-dma-rx;
atmel,use-dma-tx;
status = "okay";
};
2015-03-04 10:51:48 +08:00
spi0: spi@f8010000 {
cs-gpios = <&pioC 3 0>, <0>, <0>, <0>;
status = "okay";
m25p80@0 {
compatible = "atmel,at25df321a";
spi-max-frequency = <50000000>;
reg = <0>;
};
};
2015-02-26 16:05:14 +01:00
i2c0: i2c@f8014000 {
2019-09-11 10:24:40 +02:00
i2c-digital-filter;
2015-02-26 16:05:14 +01:00
status = "okay";
};
2015-03-04 10:51:48 +08:00
macb0: ethernet@f8020000 {
phy-mode = "rmii";
status = "okay";
2016-01-15 09:30:18 +01:00
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_macb0_rmii &pinctrl_macb0_phy_irq>;
2015-03-04 10:51:48 +08:00
phy0: ethernet-phy@1 {
interrupt-parent = <&pioE>;
2016-01-27 11:03:02 +01:00
interrupts = <1 IRQ_TYPE_LEVEL_LOW>;
2015-03-04 10:51:48 +08:00
reg = <1>;
};
};
mmc1: mmc@fc000000 {
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_mmc1_clk_cmd_dat0 &pinctrl_mmc1_dat1_3 &pinctrl_mmc1_cd>;
2015-04-27 15:27:52 +02:00
vmmc-supply = <&vcc_mmc1_reg>;
vqmmc-supply = <&vcc_3v3_reg>;
2015-03-04 10:51:48 +08:00
status = "okay";
slot@0 {
reg = <0>;
bus-width = <4>;
cd-gpios = <&pioE 3 0>;
};
};
usart3: serial@fc00c000 {
2017-01-19 01:46:58 +01:00
atmel,use-dma-rx;
atmel,use-dma-tx;
2015-03-04 10:51:48 +08:00
status = "okay";
};
usart4: serial@fc010000 {
status = "okay";
};
2015-05-18 12:18:03 +02:00
spi1: spi@fc018000 {
cs-gpios = <&pioB 21 0>;
status = "okay";
};
2016-05-05 17:57:24 +02:00
tcb2: timer@fc024000 {
timer0: timer@0 {
compatible = "atmel,tcb-timer";
reg = <0>;
};
timer1: timer@1 {
compatible = "atmel,tcb-timer";
reg = <1>;
};
};
2015-03-04 10:51:48 +08:00
adc0: adc@fc034000 {
2015-06-22 09:45:48 +02:00
pinctrl-names = "default";
pinctrl-0 = <
/* external trigger conflicts with USBA_VBUS */
&pinctrl_adc0_ad0
&pinctrl_adc0_ad1
&pinctrl_adc0_ad2
&pinctrl_adc0_ad3
&pinctrl_adc0_ad4
>;
2015-03-04 10:51:48 +08:00
atmel,adc-vref = <3300>;
status = "okay";
};
watchdog@fc068640 {
status = "okay";
};
pinctrl@fc06a000 {
board {
pinctrl_mmc1_cd: mmc1_cd {
atmel,pins =
<AT91_PIOE 3 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
};
pinctrl_usba_vbus: usba_vbus {
atmel,pins =
<AT91_PIOE 31 AT91_PERIPH_GPIO AT91_PINCTRL_DEGLITCH>;
};
2020-11-18 14:00:18 +02:00
pinctrl_usb_default: usb_default {
atmel,pins =
<AT91_PIOE 11 AT91_PERIPH_GPIO AT91_PINCTRL_NONE
AT91_PIOE 14 AT91_PERIPH_GPIO AT91_PINCTRL_NONE>;
};
2015-03-04 10:51:48 +08:00
pinctrl_key_gpio: key_gpio_0 {
atmel,pins =
<AT91_PIOE 8 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
2016-01-15 09:30:18 +01:00
};
pinctrl_macb0_phy_irq: macb0_phy_irq_0 {
atmel,pins =
<AT91_PIOE 1 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
2015-03-04 10:51:48 +08:00
};
};
};
};
2017-10-13 12:54:51 -05:00
usb0: gadget@400000 {
2015-03-04 10:51:48 +08:00
atmel,vbus-gpio = <&pioE 31 GPIO_ACTIVE_HIGH>;
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_usba_vbus>;
status = "okay";
};
2017-10-13 12:54:51 -05:00
usb1: ohci@500000 {
2015-03-04 10:51:48 +08:00
num-ports = <3>;
atmel,vbus-gpio = <0
&pioE 11 GPIO_ACTIVE_HIGH
&pioE 14 GPIO_ACTIVE_HIGH
>;
2020-11-18 14:00:18 +02:00
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_usb_default>;
2015-03-04 10:51:48 +08:00
status = "okay";
};
2017-10-13 12:54:51 -05:00
usb2: ehci@600000 {
2015-03-04 10:51:48 +08:00
status = "okay";
};
2017-05-30 11:20:53 +02:00
ebi: ebi@10000000 {
pinctrl-0 = <&pinctrl_ebi_cs3 &pinctrl_ebi_nrd_nandoe
&pinctrl_ebi_nwe_nandwe &pinctrl_ebi_nandrdy
&pinctrl_ebi_data_0_7 &pinctrl_ebi_nand_addr>;
pinctrl-names = "default";
2015-03-04 10:51:48 +08:00
status = "okay";
2017-05-30 11:20:53 +02:00
nand_controller: nand-controller {
status = "okay";
2015-03-04 10:51:48 +08:00
2017-05-30 11:20:53 +02:00
nand@3 {
reg = <0x3 0x0 0x2>;
atmel,rb = <0>;
nand-bus-width = <8>;
nand-ecc-mode = "hw";
nand-on-flash-bbt;
label = "atmel_nand";
partitions {
compatible = "fixed-partitions";
#address-cells = <1>;
#size-cells = <1>;
at91bootstrap@0 {
label = "at91bootstrap";
reg = <0x0 0x40000>;
};
bootloader@40000 {
label = "bootloader";
2018-10-02 16:20:38 +03:00
reg = <0x40000 0xc0000>;
2017-05-30 11:20:53 +02:00
};
2018-10-02 16:20:38 +03:00
bootloaderenvred@100000 {
label = "bootloader env redundant";
reg = <0x100000 0x40000>;
};
bootloaderenv@140000 {
2017-05-30 11:20:53 +02:00
label = "bootloader env";
2018-10-02 16:20:38 +03:00
reg = <0x140000 0x40000>;
2017-05-30 11:20:53 +02:00
};
dtb@180000 {
label = "device tree";
reg = <0x180000 0x80000>;
};
kernel@200000 {
label = "kernel";
reg = <0x200000 0x600000>;
};
rootfs@800000 {
label = "rootfs";
2018-10-02 16:00:35 +03:00
reg = <0x800000 0x1f800000>;
2017-05-30 11:20:53 +02:00
};
};
};
2015-03-04 10:51:48 +08:00
};
};
};
gpio_keys {
compatible = "gpio-keys";
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_key_gpio>;
pb_user1 {
label = "pb_user1";
gpios = <&pioE 8 GPIO_ACTIVE_HIGH>;
linux,code = <0x100>;
2015-10-21 11:10:07 +01:00
wakeup-source;
2015-03-04 10:51:48 +08:00
};
};
leds {
compatible = "gpio-leds";
status = "okay";
d8 {
label = "d8";
gpios = <&pioD 30 GPIO_ACTIVE_HIGH>;
2015-04-23 10:08:04 +02:00
default-state = "on";
2015-03-04 10:51:48 +08:00
};
d10 {
label = "d10";
gpios = <&pioE 15 GPIO_ACTIVE_LOW>;
linux,default-trigger = "heartbeat";
};
};
2015-04-27 15:27:52 +02:00
2016-07-13 00:10:13 +02:00
vcc_3v3_reg: fixedregulator_3v3 {
2015-04-27 15:27:52 +02:00
compatible = "regulator-fixed";
regulator-name = "VCC 3V3";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
regulator-boot-on;
regulator-always-on;
};
2016-07-13 00:10:13 +02:00
vcc_mmc1_reg: fixedregulator_mmc1 {
2015-04-27 15:27:52 +02:00
compatible = "regulator-fixed";
gpio = <&pioE 4 GPIO_ACTIVE_LOW>;
regulator-name = "VDD MCI1";
regulator-min-microvolt = <3300000>;
regulator-max-microvolt = <3300000>;
vin-supply = <&vcc_3v3_reg>;
2016-03-11 11:35:10 +01:00
regulator-always-on;
2015-04-27 15:27:52 +02:00
};
2015-03-04 10:51:48 +08:00
};