1*2c4b2dd2SWenyou Yang/dts-v1/;
2*2c4b2dd2SWenyou Yang#include "sama5d2.dtsi"
3*2c4b2dd2SWenyou Yang#include "sama5d2-pinfunc.h"
4*2c4b2dd2SWenyou Yang
5*2c4b2dd2SWenyou Yang/ {
6*2c4b2dd2SWenyou Yang	model = "Atmel SAMA5D2 Xplained";
7*2c4b2dd2SWenyou Yang	compatible = "atmel,sama5d2-xplained", "atmel,sama5d2", "atmel,sama5";
8*2c4b2dd2SWenyou Yang
9*2c4b2dd2SWenyou Yang	chosen {
10*2c4b2dd2SWenyou Yang		stdout-path = &uart1;
11*2c4b2dd2SWenyou Yang	};
12*2c4b2dd2SWenyou Yang
13*2c4b2dd2SWenyou Yang	ahb {
14*2c4b2dd2SWenyou Yang		usb1: ohci@00400000 {
15*2c4b2dd2SWenyou Yang			num-ports = <3>;
16*2c4b2dd2SWenyou Yang			atmel,vbus-gpio = <&pioA 42 0>;
17*2c4b2dd2SWenyou Yang			pinctrl-names = "default";
18*2c4b2dd2SWenyou Yang			pinctrl-0 = <&pinctrl_usb_default>;
19*2c4b2dd2SWenyou Yang			status = "okay";
20*2c4b2dd2SWenyou Yang		};
21*2c4b2dd2SWenyou Yang
22*2c4b2dd2SWenyou Yang		usb2: ehci@00500000 {
23*2c4b2dd2SWenyou Yang			status = "okay";
24*2c4b2dd2SWenyou Yang		};
25*2c4b2dd2SWenyou Yang
26*2c4b2dd2SWenyou Yang		sdmmc0: sdio-host@a0000000 {
27*2c4b2dd2SWenyou Yang			bus-width = <8>;
28*2c4b2dd2SWenyou Yang			pinctrl-names = "default";
29*2c4b2dd2SWenyou Yang			pinctrl-0 = <&pinctrl_sdmmc0_cmd_dat_default &pinctrl_sdmmc0_ck_cd_default>;
30*2c4b2dd2SWenyou Yang			status = "okay";
31*2c4b2dd2SWenyou Yang		};
32*2c4b2dd2SWenyou Yang
33*2c4b2dd2SWenyou Yang		sdmmc1: sdio-host@b0000000 {
34*2c4b2dd2SWenyou Yang			bus-width = <4>;
35*2c4b2dd2SWenyou Yang			pinctrl-names = "default";
36*2c4b2dd2SWenyou Yang			pinctrl-0 = <&pinctrl_sdmmc1_cmd_dat_default &pinctrl_sdmmc1_ck_cd_default>;
37*2c4b2dd2SWenyou Yang			status = "okay"; /* conflict with qspi0 */
38*2c4b2dd2SWenyou Yang		};
39*2c4b2dd2SWenyou Yang
40*2c4b2dd2SWenyou Yang		apb {
41*2c4b2dd2SWenyou Yang			qspi0: spi@f0020000 {
42*2c4b2dd2SWenyou Yang				status = "okay";
43*2c4b2dd2SWenyou Yang
44*2c4b2dd2SWenyou Yang				flash@0 {
45*2c4b2dd2SWenyou Yang					compatible = "atmel,sama5d2-qspi-flash";
46*2c4b2dd2SWenyou Yang					reg = <0>;
47*2c4b2dd2SWenyou Yang					#address-cells = <1>;
48*2c4b2dd2SWenyou Yang					#size-cells = <1>;
49*2c4b2dd2SWenyou Yang					pinctrl-names = "default";
50*2c4b2dd2SWenyou Yang					pinctrl-0 = <&pinctrl_qspi0_default>;
51*2c4b2dd2SWenyou Yang					spi-max-frequency = <83000000>;
52*2c4b2dd2SWenyou Yang
53*2c4b2dd2SWenyou Yang					partition@00000000 {
54*2c4b2dd2SWenyou Yang						label = "boot";
55*2c4b2dd2SWenyou Yang						reg = <0x00000000 0x00c00000>;
56*2c4b2dd2SWenyou Yang					};
57*2c4b2dd2SWenyou Yang
58*2c4b2dd2SWenyou Yang					partition@00c00000 {
59*2c4b2dd2SWenyou Yang						label = "rootfs";
60*2c4b2dd2SWenyou Yang						reg = <0x00c00000 0x00000000>;
61*2c4b2dd2SWenyou Yang					};
62*2c4b2dd2SWenyou Yang				};
63*2c4b2dd2SWenyou Yang			};
64*2c4b2dd2SWenyou Yang
65*2c4b2dd2SWenyou Yang			spi0: spi@f8000000 {
66*2c4b2dd2SWenyou Yang				cs-gpios = <&pioA 17 0>, <0>, <0>, <0>;
67*2c4b2dd2SWenyou Yang				pinctrl-names = "default";
68*2c4b2dd2SWenyou Yang				pinctrl-0 = <&pinctrl_spi0_default>;
69*2c4b2dd2SWenyou Yang				status = "okay";
70*2c4b2dd2SWenyou Yang
71*2c4b2dd2SWenyou Yang				spi_flash@0 {
72*2c4b2dd2SWenyou Yang					compatible = "spi-flash";
73*2c4b2dd2SWenyou Yang					reg = <0>;
74*2c4b2dd2SWenyou Yang					spi-max-frequency = <50000000>;
75*2c4b2dd2SWenyou Yang				};
76*2c4b2dd2SWenyou Yang			};
77*2c4b2dd2SWenyou Yang
78*2c4b2dd2SWenyou Yang			macb0: ethernet@f8008000 {
79*2c4b2dd2SWenyou Yang				pinctrl-names = "default";
80*2c4b2dd2SWenyou Yang				pinctrl-0 = <&pinctrl_macb0_rmii &pinctrl_macb0_phy_irq>;
81*2c4b2dd2SWenyou Yang				phy-mode = "rmii";
82*2c4b2dd2SWenyou Yang				status = "okay";
83*2c4b2dd2SWenyou Yang
84*2c4b2dd2SWenyou Yang				ethernet-phy@1 {
85*2c4b2dd2SWenyou Yang					reg = <0x1>;
86*2c4b2dd2SWenyou Yang				};
87*2c4b2dd2SWenyou Yang			};
88*2c4b2dd2SWenyou Yang
89*2c4b2dd2SWenyou Yang			uart1: serial@f8020000 {
90*2c4b2dd2SWenyou Yang				pinctrl-names = "default";
91*2c4b2dd2SWenyou Yang				pinctrl-0 = <&pinctrl_uart1_default>;
92*2c4b2dd2SWenyou Yang				status = "okay";
93*2c4b2dd2SWenyou Yang			};
94*2c4b2dd2SWenyou Yang
95*2c4b2dd2SWenyou Yang			i2c1: i2c@fc028000 {
96*2c4b2dd2SWenyou Yang				pinctrl-names = "default";
97*2c4b2dd2SWenyou Yang				pinctrl-0 = <&pinctrl_i2c1_default>;
98*2c4b2dd2SWenyou Yang				status = "okay";
99*2c4b2dd2SWenyou Yang			};
100*2c4b2dd2SWenyou Yang
101*2c4b2dd2SWenyou Yang			pioA: gpio@fc038000 {
102*2c4b2dd2SWenyou Yang				pinctrl {
103*2c4b2dd2SWenyou Yang					pinctrl_i2c1_default: i2c1_default {
104*2c4b2dd2SWenyou Yang						pinmux = <PIN_PD4__TWD1>,
105*2c4b2dd2SWenyou Yang							 <PIN_PD5__TWCK1>;
106*2c4b2dd2SWenyou Yang						bias-disable;
107*2c4b2dd2SWenyou Yang					};
108*2c4b2dd2SWenyou Yang
109*2c4b2dd2SWenyou Yang					pinctrl_macb0_phy_irq: macb0_phy_irq {
110*2c4b2dd2SWenyou Yang						pinmux = <PIN_PC9__GPIO>;
111*2c4b2dd2SWenyou Yang						bias-disable;
112*2c4b2dd2SWenyou Yang					};
113*2c4b2dd2SWenyou Yang
114*2c4b2dd2SWenyou Yang					pinctrl_macb0_rmii: macb0_rmii {
115*2c4b2dd2SWenyou Yang						pinmux = <PIN_PB14__GTXCK>,
116*2c4b2dd2SWenyou Yang							 <PIN_PB15__GTXEN>,
117*2c4b2dd2SWenyou Yang							 <PIN_PB16__GRXDV>,
118*2c4b2dd2SWenyou Yang							 <PIN_PB17__GRXER>,
119*2c4b2dd2SWenyou Yang							 <PIN_PB18__GRX0>,
120*2c4b2dd2SWenyou Yang							 <PIN_PB19__GRX1>,
121*2c4b2dd2SWenyou Yang							 <PIN_PB20__GTX0>,
122*2c4b2dd2SWenyou Yang							 <PIN_PB21__GTX1>,
123*2c4b2dd2SWenyou Yang							 <PIN_PB22__GMDC>,
124*2c4b2dd2SWenyou Yang							 <PIN_PB23__GMDIO>;
125*2c4b2dd2SWenyou Yang						bias-disable;
126*2c4b2dd2SWenyou Yang					};
127*2c4b2dd2SWenyou Yang
128*2c4b2dd2SWenyou Yang					pinctrl_qspi0_default: qspi0_default {
129*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA22__QSPI0_SCK>,
130*2c4b2dd2SWenyou Yang							 <PIN_PA23__QSPI0_CS>,
131*2c4b2dd2SWenyou Yang							 <PIN_PA24__QSPI0_IO0>,
132*2c4b2dd2SWenyou Yang							 <PIN_PA25__QSPI0_IO1>,
133*2c4b2dd2SWenyou Yang							 <PIN_PA26__QSPI0_IO2>,
134*2c4b2dd2SWenyou Yang							 <PIN_PA27__QSPI0_IO3>;
135*2c4b2dd2SWenyou Yang						bias-disable;
136*2c4b2dd2SWenyou Yang					};
137*2c4b2dd2SWenyou Yang
138*2c4b2dd2SWenyou Yang					pinctrl_sdmmc0_cmd_dat_default: sdmmc0_cmd_dat_default {
139*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA1__SDMMC0_CMD>,
140*2c4b2dd2SWenyou Yang							 <PIN_PA2__SDMMC0_DAT0>,
141*2c4b2dd2SWenyou Yang							 <PIN_PA3__SDMMC0_DAT1>,
142*2c4b2dd2SWenyou Yang							 <PIN_PA4__SDMMC0_DAT2>,
143*2c4b2dd2SWenyou Yang							 <PIN_PA5__SDMMC0_DAT3>,
144*2c4b2dd2SWenyou Yang							 <PIN_PA6__SDMMC0_DAT4>,
145*2c4b2dd2SWenyou Yang							 <PIN_PA7__SDMMC0_DAT5>,
146*2c4b2dd2SWenyou Yang							 <PIN_PA8__SDMMC0_DAT6>,
147*2c4b2dd2SWenyou Yang							 <PIN_PA9__SDMMC0_DAT7>;
148*2c4b2dd2SWenyou Yang						bias-pull-up;
149*2c4b2dd2SWenyou Yang					};
150*2c4b2dd2SWenyou Yang
151*2c4b2dd2SWenyou Yang					pinctrl_sdmmc0_ck_cd_default: sdmmc0_ck_cd_default {
152*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA0__SDMMC0_CK>,
153*2c4b2dd2SWenyou Yang							 <PIN_PA10__SDMMC0_RSTN>,
154*2c4b2dd2SWenyou Yang							 <PIN_PA11__SDMMC0_VDDSEL>,
155*2c4b2dd2SWenyou Yang							 <PIN_PA13__SDMMC0_CD>;
156*2c4b2dd2SWenyou Yang						bias-disable;
157*2c4b2dd2SWenyou Yang					};
158*2c4b2dd2SWenyou Yang
159*2c4b2dd2SWenyou Yang					pinctrl_sdmmc1_cmd_dat_default: sdmmc1_cmd_dat_default {
160*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA28__SDMMC1_CMD>,
161*2c4b2dd2SWenyou Yang							 <PIN_PA18__SDMMC1_DAT0>,
162*2c4b2dd2SWenyou Yang							 <PIN_PA19__SDMMC1_DAT1>,
163*2c4b2dd2SWenyou Yang							 <PIN_PA20__SDMMC1_DAT2>,
164*2c4b2dd2SWenyou Yang							 <PIN_PA21__SDMMC1_DAT3>;
165*2c4b2dd2SWenyou Yang						bias-pull-up;
166*2c4b2dd2SWenyou Yang					};
167*2c4b2dd2SWenyou Yang
168*2c4b2dd2SWenyou Yang					pinctrl_sdmmc1_ck_cd_default: sdmmc1_ck_cd_default {
169*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA22__SDMMC1_CK>,
170*2c4b2dd2SWenyou Yang							 <PIN_PA30__SDMMC1_CD>;
171*2c4b2dd2SWenyou Yang						bias-disable;
172*2c4b2dd2SWenyou Yang					};
173*2c4b2dd2SWenyou Yang
174*2c4b2dd2SWenyou Yang					pinctrl_spi0_default: spi0_default {
175*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA14__SPI0_SPCK>,
176*2c4b2dd2SWenyou Yang							 <PIN_PA15__SPI0_MOSI>,
177*2c4b2dd2SWenyou Yang							 <PIN_PA16__SPI0_MISO>;
178*2c4b2dd2SWenyou Yang						bias-disable;
179*2c4b2dd2SWenyou Yang					};
180*2c4b2dd2SWenyou Yang
181*2c4b2dd2SWenyou Yang					pinctrl_uart1_default: uart1_default {
182*2c4b2dd2SWenyou Yang						pinmux = <PIN_PD2__URXD1>,
183*2c4b2dd2SWenyou Yang							 <PIN_PD3__UTXD1>;
184*2c4b2dd2SWenyou Yang						bias-disable;
185*2c4b2dd2SWenyou Yang					};
186*2c4b2dd2SWenyou Yang
187*2c4b2dd2SWenyou Yang					pinctrl_usb_default: usb_default {
188*2c4b2dd2SWenyou Yang						pinmux = <PIN_PB10__GPIO>;
189*2c4b2dd2SWenyou Yang						bias-disable;
190*2c4b2dd2SWenyou Yang					};
191*2c4b2dd2SWenyou Yang
192*2c4b2dd2SWenyou Yang					pinctrl_usba_vbus: usba_vbus {
193*2c4b2dd2SWenyou Yang						pinmux = <PIN_PA31__GPIO>;
194*2c4b2dd2SWenyou Yang						bias-disable;
195*2c4b2dd2SWenyou Yang					};
196*2c4b2dd2SWenyou Yang				};
197*2c4b2dd2SWenyou Yang			};
198*2c4b2dd2SWenyou Yang		};
199*2c4b2dd2SWenyou Yang	};
200*2c4b2dd2SWenyou Yang};
201