blob: 186a1705f8d3daa584fd24aafee2aabb629995b6 [file] [log] [blame]
Hong Xucce783c2012-04-17 14:26:29 +08001/*
2 * at91sam9n12ek.dts - Device Tree file for AT91SAM9N12-EK board
3 *
4 * Copyright (C) 2012 Atmel,
5 * 2012 Hong Xu <hong.xu@atmel.com>
6 *
7 * Licensed under GPLv2 or later.
8 */
9/dts-v1/;
Jean-Christophe PLAGNIOL-VILLARD6db64d22013-05-15 01:21:50 +080010#include "at91sam9n12.dtsi"
Hong Xucce783c2012-04-17 14:26:29 +080011
12/ {
13 model = "Atmel AT91SAM9N12-EK";
14 compatible = "atmel,at91sam9n12ek", "atmel,at91sam9n12", "atmel,at91sam9";
15
16 chosen {
Alexandre Belloni7cb58522015-06-03 14:24:11 +020017 bootargs = "root=/dev/mtdblock1 rw rootfstype=jffs2";
18 stdout-path = "serial0:115200n8";
Hong Xucce783c2012-04-17 14:26:29 +080019 };
20
21 memory {
Nicolas Ferrea57603c2013-06-28 10:39:15 +020022 reg = <0x20000000 0x8000000>;
Hong Xucce783c2012-04-17 14:26:29 +080023 };
24
25 clocks {
26 #address-cells = <1>;
27 #size-cells = <1>;
28 ranges;
29
30 main_clock: clock@0 {
31 compatible = "atmel,osc", "fixed-clock";
32 clock-frequency = <16000000>;
33 };
Alexandre Belloni6503ab52014-06-17 15:30:18 +020034
35 slow_xtal {
36 clock-frequency = <32768>;
37 };
38
39 main_xtal {
40 clock-frequency = <16000000>;
41 };
Hong Xucce783c2012-04-17 14:26:29 +080042 };
43
44 ahb {
45 apb {
46 dbgu: serial@fffff200 {
47 status = "okay";
48 };
Ludovic Desrochesfbc18712012-09-12 08:42:17 +020049
Bo Shen47609062013-10-14 13:38:32 +080050 ssc0: ssc@f0010000 {
51 status = "okay";
52 };
53
Ludovic Desrochesfbc18712012-09-12 08:42:17 +020054 i2c0: i2c@f8010000 {
55 status = "okay";
voice82914f82013-07-11 11:30:45 +080056
Bo Shene6f79912013-10-14 13:38:31 +080057 wm8904: codec@1a {
Bo Shen4bd37792014-12-15 11:31:13 +080058 compatible = "wlf,wm8904";
Bo Shene6f79912013-10-14 13:38:31 +080059 reg = <0x1a>;
Bo Shen38324352014-06-09 11:31:47 +080060 clocks = <&pck0>;
61 clock-names = "mclk";
Bo Shene6f79912013-10-14 13:38:31 +080062 };
63
voice82914f82013-07-11 11:30:45 +080064 qt1070: keyboard@1b {
65 compatible = "qt1070";
66 reg = <0x1b>;
67 interrupt-parent = <&pioA>;
68 interrupts = <2 IRQ_TYPE_EDGE_FALLING>;
69 pinctrl-names = "default";
70 pinctrl-0 = <&pinctrl_qt1070_irq>;
71 };
Ludovic Desrochesfbc18712012-09-12 08:42:17 +020072 };
73
74 i2c1: i2c@f8014000 {
75 status = "okay";
76 };
Ludovic Desroches4134a452012-11-19 12:24:02 +010077
78 mmc0: mmc@f0008000 {
Jean-Christophe PLAGNIOL-VILLARD199e2ed2012-11-20 00:38:18 +080079 pinctrl-0 = <
80 &pinctrl_board_mmc0
81 &pinctrl_mmc0_slot0_clk_cmd_dat0
82 &pinctrl_mmc0_slot0_dat1_3>;
Ludovic Desroches4134a452012-11-19 12:24:02 +010083 status = "okay";
84 slot@0 {
85 reg = <0>;
86 bus-width = <4>;
Jean-Christophe PLAGNIOL-VILLARD92f86292013-04-24 08:34:25 +080087 cd-gpios = <&pioA 7 GPIO_ACTIVE_HIGH>;
Ludovic Desroches4134a452012-11-19 12:24:02 +010088 };
89 };
Jean-Christophe PLAGNIOL-VILLARD199e2ed2012-11-20 00:38:18 +080090
91 pinctrl@fffff400 {
92 mmc0 {
93 pinctrl_board_mmc0: mmc0-board {
94 atmel,pins =
Jean-Christophe PLAGNIOL-VILLARDc9d0f312013-04-24 08:34:25 +080095 <AT91_PIOA 7 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>; /* PA7 gpio CD pin pull up and deglitch */
Jean-Christophe PLAGNIOL-VILLARD199e2ed2012-11-20 00:38:18 +080096 };
97 };
voice82914f82013-07-11 11:30:45 +080098
99 qt1070 {
100 pinctrl_qt1070_irq: qt1070_irq {
101 atmel,pins =
102 <AT91_PIOA 2 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
103 };
104 };
Bo Shen551a4092013-10-14 13:38:33 +0800105
106 sound {
107 pinctrl_pck0_as_audio_mck: pck0_as_audio_mck {
108 atmel,pins =
109 <AT91_PIOB 10 AT91_PERIPH_B AT91_PINCTRL_NONE>;
110 };
111 };
Bo Shencf05ea72015-02-10 09:55:35 +0800112
113 usb1 {
114 pinctrl_usb1_vbus_sense: usb1_vbus_sense {
115 atmel,pins =
116 <AT91_PIOB 16 AT91_PERIPH_GPIO AT91_PINCTRL_DEGLITCH>; /* PB16 gpio usb vbus sense, no pull up and deglitch */
117 };
118 };
Jean-Christophe PLAGNIOL-VILLARD199e2ed2012-11-20 00:38:18 +0800119 };
Richard Genoudb6811e92013-04-03 14:03:05 +0800120
121 spi0: spi@f0000000 {
122 status = "okay";
123 cs-gpios = <&pioA 14 0>, <0>, <0>, <0>;
124 m25p80@0 {
125 compatible = "atmel,at25df321a";
126 spi-max-frequency = <50000000>;
127 reg = <0>;
128 };
129 };
Wenyou Yangc77bcef2013-05-31 11:11:33 +0800130
Bo Shena437fc52015-03-25 18:41:31 +0800131 hlcdc: hlcdc@f8038000 {
132 status = "okay";
133
134 hlcdc-display-controller {
135 pinctrl-names = "default";
136 pinctrl-0 = <&pinctrl_lcd_base &pinctrl_lcd_rgb888>;
137
138 port@0 {
139 hlcdc_panel_output: endpoint@0 {
140 reg = <0>;
141 remote-endpoint = <&panel_input>;
142 };
143 };
144 };
145 };
146
Bo Shencf05ea72015-02-10 09:55:35 +0800147 usb1: gadget@f803c000 {
148 pinctrl-names = "default";
149 pinctrl-0 = <&pinctrl_usb1_vbus_sense>;
150 atmel,vbus-gpio = <&pioB 16 GPIO_ACTIVE_HIGH>;
151 status = "okay";
152 };
153
Wenyou Yangc77bcef2013-05-31 11:11:33 +0800154 watchdog@fffffe40 {
155 status = "okay";
156 };
Nicolas Ferre87003222015-03-19 17:41:41 +0100157
158 rtc@fffffeb0 {
159 status = "okay";
160 };
Hong Xucce783c2012-04-17 14:26:29 +0800161 };
162
163 nand0: nand@40000000 {
164 nand-bus-width = <8>;
Josh Wuc18c6b22013-01-23 20:47:10 +0800165 nand-ecc-mode = "hw";
166 atmel,has-pmecc;
167 atmel,pmecc-cap = <2>;
168 atmel,pmecc-sector-size = <512>;
Hong Xucce783c2012-04-17 14:26:29 +0800169 nand-on-flash-bbt;
170 status = "okay";
171 };
Bo Shend7e67ee2014-01-14 14:34:44 +0800172
173 usb0: ohci@00500000 {
Bo Shen2fbda372014-08-27 17:52:49 +0800174 num-ports = <1>;
175 atmel,vbus-gpio = <&pioB 7 GPIO_ACTIVE_LOW>;
Bo Shend7e67ee2014-01-14 14:34:44 +0800176 status = "okay";
177 };
Hong Xucce783c2012-04-17 14:26:29 +0800178 };
179
Bo Shena437fc52015-03-25 18:41:31 +0800180 backlight: backlight {
181 compatible = "pwm-backlight";
182 pwms = <&hlcdc_pwm 0 50000 0>;
183 brightness-levels = <0 4 8 16 32 64 128 255>;
184 default-brightness-level = <6>;
185 power-supply = <&bl_reg>;
186 status = "okay";
187 };
188
189 bl_reg: backlight_regulator {
190 compatible = "regulator-fixed";
191 regulator-name = "backlight-power-supply";
192 regulator-min-microvolt = <5000000>;
193 regulator-max-microvolt = <5000000>;
194 status = "okay";
195 };
196
Hong Xucce783c2012-04-17 14:26:29 +0800197 leds {
198 compatible = "gpio-leds";
199
200 d8 {
201 label = "d8";
Jean-Christophe PLAGNIOL-VILLARD92f86292013-04-24 08:34:25 +0800202 gpios = <&pioB 4 GPIO_ACTIVE_LOW>;
Hong Xucce783c2012-04-17 14:26:29 +0800203 linux,default-trigger = "mmc0";
204 };
205
206 d9 {
Josh Wu7b6521f2015-03-30 18:40:22 +0800207 label = "d9";
Jean-Christophe PLAGNIOL-VILLARD92f86292013-04-24 08:34:25 +0800208 gpios = <&pioB 5 GPIO_ACTIVE_LOW>;
Hong Xucce783c2012-04-17 14:26:29 +0800209 linux,default-trigger = "nand-disk";
210 };
211
212 d10 {
Josh Wu7b6521f2015-03-30 18:40:22 +0800213 label = "d10";
Jean-Christophe PLAGNIOL-VILLARD92f86292013-04-24 08:34:25 +0800214 gpios = <&pioB 6 GPIO_ACTIVE_HIGH>;
Hong Xucce783c2012-04-17 14:26:29 +0800215 linux,default-trigger = "heartbeat";
216 };
217 };
218
219 gpio_keys {
220 compatible = "gpio-keys";
Hong Xucce783c2012-04-17 14:26:29 +0800221
222 enter {
223 label = "Enter";
voicef7042042013-07-11 11:30:46 +0800224 gpios = <&pioB 3 GPIO_ACTIVE_LOW>;
Hong Xucce783c2012-04-17 14:26:29 +0800225 linux,code = <28>;
226 gpio-key,wakeup;
227 };
228 };
Bo Shen551a4092013-10-14 13:38:33 +0800229
Bo Shena437fc52015-03-25 18:41:31 +0800230 panel: panel {
231 compatible = "qd,qd43003c0-40", "simple-panel";
232 backlight = <&backlight>;
233 power-supply = <&panel_reg>;
234 #address-cells = <1>;
235 #size-cells = <0>;
236 status = "okay";
237
238 port@0 {
239 reg = <0>;
240 #address-cells = <1>;
241 #size-cells = <0>;
242
243 panel_input: endpoint@0 {
244 reg = <0>;
245 remote-endpoint = <&hlcdc_panel_output>;
246 };
247 };
248 };
249
250 panel_reg: panel_regulator {
251 compatible = "regulator-fixed";
252 regulator-name = "panel-power-supply";
253 regulator-min-microvolt = <3300000>;
254 regulator-max-microvolt = <3300000>;
255 status = "okay";
256 };
257
Bo Shen551a4092013-10-14 13:38:33 +0800258 sound {
259 compatible = "atmel,asoc-wm8904";
260 pinctrl-names = "default";
261 pinctrl-0 = <&pinctrl_pck0_as_audio_mck>;
262
263 atmel,model = "wm8904 @ AT91SAM9N12";
264 atmel,audio-routing =
265 "Headphone Jack", "HPOUTL",
266 "Headphone Jack", "HPOUTR",
267 "IN2L", "Line In Jack",
268 "IN2R", "Line In Jack",
269 "Mic", "MICBIAS",
270 "IN1L", "Mic";
271
272 atmel,ssc-controller = <&ssc0>;
273 atmel,audio-codec = <&wm8904>;
274 };
Hong Xucce783c2012-04-17 14:26:29 +0800275};