Loading...
1/*
2 * sama5d3xmb_cmp.dts - Device Tree file for SAMA5D3x CMP mother board
3 *
4 * Copyright (C) 2016 Atmel,
5 *
6 * This file is dual-licensed: you can use it either under the terms
7 * of the GPL or the X11 license, at your option. Note that this dual
8 * licensing only applies to this file, and not this project as a
9 * whole.
10 *
11 * a) This file is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License as
13 * published by the Free Software Foundation; either version 2 of the
14 * License, or (at your option) any later version.
15 *
16 * This file is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * Or, alternatively,
22 *
23 * b) Permission is hereby granted, free of charge, to any person
24 * obtaining a copy of this software and associated documentation
25 * files (the "Software"), to deal in the Software without
26 * restriction, including without limitation the rights to use,
27 * copy, modify, merge, publish, distribute, sublicense, and/or
28 * sell copies of the Software, and to permit persons to whom the
29 * Software is furnished to do so, subject to the following
30 * conditions:
31 *
32 * The above copyright notice and this permission notice shall be
33 * included in all copies or substantial portions of the Software.
34 *
35 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
36 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
37 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
38 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
39 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
40 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
41 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
42 * OTHER DEALINGS IN THE SOFTWARE.
43 */
44#include "sama5d3xcm_cmp.dtsi"
45
46/ {
47 compatible = "atmel,sama5d3xmb-cmp", "atmel,sama5d3xcm-cmp", "atmel,sama5d3", "atmel,sama5";
48
49 ahb {
50 apb {
51 mmc0: mmc@f0000000 {
52 pinctrl-names = "default";
53 pinctrl-0 = <&pinctrl_mmc0_clk_cmd_dat0 &pinctrl_mmc0_dat1_3 &pinctrl_mmc0_cd>;
54 status = "okay";
55 slot@0 {
56 reg = <0>;
57 bus-width = <4>;
58 cd-gpios = <&pioD 17 GPIO_ACTIVE_HIGH>;
59 };
60 };
61
62 spi0: spi@f0004000 {
63 dmas = <0>, <0>; /* Do not use DMA for spi0 */
64
65 m25p80@0 {
66 compatible = "atmel,at25df321a";
67 spi-max-frequency = <50000000>;
68 reg = <0>;
69 };
70 };
71
72 ssc0: ssc@f0008000 {
73 atmel,clk-from-rk-pin;
74 };
75
76 /*
77 * i2c0 conflicts with ISI:
78 * disable it to allow the use of ISI
79 * can not enable audio when i2c0 disabled
80 */
81 i2c0: i2c@f0014000 {
82 wm8904: wm8904@1a {
83 compatible = "wlf,wm8904";
84 reg = <0x1a>;
85 clocks = <&pck0>;
86 clock-names = "mclk";
87 };
88 };
89
90 i2c1: i2c@f0018000 {
91 ov2640: camera@30 {
92 compatible = "ovti,ov2640";
93 reg = <0x30>;
94 pinctrl-names = "default";
95 pinctrl-0 = <&pinctrl_pck1_as_isi_mck &pinctrl_sensor_power &pinctrl_sensor_reset>;
96 resetb-gpios = <&pioE 24 GPIO_ACTIVE_LOW>;
97 pwdn-gpios = <&pioE 29 GPIO_ACTIVE_HIGH>;
98 /* use pck1 for the master clock of ov2640 */
99 clocks = <&pck1>;
100 clock-names = "xvclk";
101 assigned-clocks = <&pck1>;
102 assigned-clock-rates = <25000000>;
103
104 port {
105 ov2640_0: endpoint {
106 remote-endpoint = <&isi_0>;
107 bus-width = <8>;
108 };
109 };
110 };
111 };
112
113 usart1: serial@f0020000 {
114 dmas = <0>, <0>; /* Do not use DMA for usart1 */
115 pinctrl-names = "default";
116 pinctrl-0 = <&pinctrl_usart1 &pinctrl_usart1_rts_cts>;
117 status = "okay";
118 };
119
120 isi: isi@f0034000 {
121 port {
122 isi_0: endpoint {
123 remote-endpoint = <&ov2640_0>;
124 bus-width = <8>;
125 vsync-active = <1>;
126 hsync-active = <1>;
127 };
128 };
129 };
130
131 mmc1: mmc@f8000000 {
132 pinctrl-names = "default";
133 pinctrl-0 = <&pinctrl_mmc1_clk_cmd_dat0 &pinctrl_mmc1_dat1_3 &pinctrl_mmc1_cd>;
134 status = "okay";
135 slot@0 {
136 reg = <0>;
137 bus-width = <4>;
138 cd-gpios = <&pioD 18 GPIO_ACTIVE_HIGH>;
139 };
140 };
141
142 adc0: adc@f8018000 {
143 pinctrl-names = "default", "sleep";
144 pinctrl-0 = <
145 &pinctrl_adc0_adtrg
146 &pinctrl_adc0_ad0
147 &pinctrl_adc0_ad1
148 &pinctrl_adc0_ad2
149 &pinctrl_adc0_ad3
150 &pinctrl_adc0_ad4
151 >;
152 pinctrl-1 = <
153 &pinctrl_adc0_adtrg_sleep
154 &pinctrl_adc0_ad0_sleep
155 &pinctrl_adc0_ad1_sleep
156 &pinctrl_adc0_ad2_sleep
157 &pinctrl_adc0_ad3_sleep
158 &pinctrl_adc0_ad4_sleep
159 >;
160 status = "okay";
161 };
162
163 macb1: ethernet@f802c000 {
164 phy-mode = "rmii";
165
166 #address-cells = <1>;
167 #size-cells = <0>;
168 phy0: ethernet-phy@1 {
169 /*interrupt-parent = <&pioE>;*/
170 /*interrupts = <30 IRQ_TYPE_EDGE_FALLING>;*/
171 reg = <1>;
172 };
173 };
174
175 pinctrl@fffff200 {
176 adc0 {
177 pinctrl_adc0_adtrg_sleep: adc0_adtrg_1 {
178 atmel,pins =
179 <AT91_PIOD 19 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
180 };
181 pinctrl_adc0_ad0_sleep: adc0_ad0_1 {
182 atmel,pins =
183 <AT91_PIOD 20 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
184 };
185 pinctrl_adc0_ad1_sleep: adc0_ad1_1 {
186 atmel,pins =
187 <AT91_PIOD 21 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
188 };
189 pinctrl_adc0_ad2_sleep: adc0_ad2_1 {
190 atmel,pins =
191 <AT91_PIOD 22 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
192 };
193 pinctrl_adc0_ad3_sleep: adc0_ad3_1 {
194 atmel,pins =
195 <AT91_PIOD 23 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
196 };
197 pinctrl_adc0_ad4_sleep: adc0_ad4_1 {
198 atmel,pins =
199 <AT91_PIOD 24 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
200 };
201 };
202
203 board {
204 pinctrl_gpio_keys: gpio_keys {
205 atmel,pins =
206 <AT91_PIOE 27 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP>;
207 };
208
209 pinctrl_mmc0_cd: mmc0_cd {
210 atmel,pins =
211 <AT91_PIOD 17 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
212 };
213
214 pinctrl_mmc1_cd: mmc1_cd {
215 atmel,pins =
216 <AT91_PIOD 18 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
217 };
218
219 pinctrl_pck0_as_audio_mck: pck0_as_audio_mck {
220 atmel,pins =
221 <AT91_PIOD 30 AT91_PERIPH_B AT91_PINCTRL_NONE>;
222 };
223
224 pinctrl_pck1_as_isi_mck: pck1_as_isi_mck-0 {
225 atmel,pins =
226 <AT91_PIOD 31 AT91_PERIPH_B AT91_PINCTRL_NONE>;
227 };
228
229 pinctrl_sensor_reset: sensor_reset-0 {
230 atmel,pins =
231 <AT91_PIOE 24 AT91_PERIPH_GPIO AT91_PINCTRL_NONE>;
232 };
233
234 pinctrl_sensor_power: sensor_power-0 {
235 atmel,pins =
236 <AT91_PIOE 29 AT91_PERIPH_GPIO AT91_PINCTRL_NONE>;
237 };
238
239 pinctrl_usba_vbus: usba_vbus {
240 atmel,pins =
241 <AT91_PIOD 29 AT91_PERIPH_GPIO AT91_PINCTRL_DEGLITCH>;
242 };
243 };
244 };
245
246 dbgu: serial@ffffee00 {
247 dmas = <0>, <0>; /* Do not use DMA for dbgu */
248 status = "okay";
249 };
250
251 watchdog@fffffe40 {
252 status = "okay";
253 };
254 };
255
256 usb0: gadget@500000 {
257 atmel,vbus-gpio = <&pioD 29 GPIO_ACTIVE_HIGH>;
258 pinctrl-names = "default";
259 pinctrl-0 = <&pinctrl_usba_vbus>;
260 status = "okay";
261 };
262 };
263
264 sound {
265 compatible = "atmel,asoc-wm8904";
266 pinctrl-names = "default";
267 pinctrl-0 = <&pinctrl_pck0_as_audio_mck>;
268
269 atmel,model = "wm8904 @ SAMA5D3EK";
270 atmel,audio-routing =
271 "Headphone Jack", "HPOUTL",
272 "Headphone Jack", "HPOUTR",
273 "IN2L", "Line In Jack",
274 "IN2R", "Line In Jack",
275 "Mic", "MICBIAS",
276 "IN1L", "Mic";
277
278 atmel,ssc-controller = <&ssc0>;
279 atmel,audio-codec = <&wm8904>;
280
281 status = "disabled";
282 };
283
284 /* Conflict with LCD pins */
285 gpio_keys {
286 compatible = "gpio-keys";
287 status = "okay";
288
289 #address-cells = <1>;
290 #size-cells = <0>;
291 pinctrl-names = "default";
292 pinctrl-0 = <&pinctrl_gpio_keys>;
293
294 pb_user1 {
295 label = "pb_user1";
296 gpios = <&pioE 27 GPIO_ACTIVE_HIGH>;
297 linux,code = <0x100>;
298 wakeup-source;
299 };
300 };
301};
1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
3 * sama5d3xmb_cmp.dts - Device Tree file for SAMA5D3x CMP mother board
4 *
5 * Copyright (C) 2016 Atmel,
6 */
7#include "sama5d3xcm_cmp.dtsi"
8
9/ {
10 compatible = "atmel,sama5d3xmb-cmp", "atmel,sama5d3xcm-cmp", "atmel,sama5d3", "atmel,sama5";
11
12 ahb {
13 apb {
14 mmc0: mmc@f0000000 {
15 pinctrl-names = "default";
16 pinctrl-0 = <&pinctrl_mmc0_clk_cmd_dat0 &pinctrl_mmc0_dat1_3 &pinctrl_mmc0_cd>;
17 status = "okay";
18 slot@0 {
19 reg = <0>;
20 bus-width = <4>;
21 cd-gpios = <&pioD 17 GPIO_ACTIVE_HIGH>;
22 };
23 };
24
25 spi0: spi@f0004000 {
26 dmas = <0>, <0>; /* Do not use DMA for spi0 */
27
28 m25p80@0 {
29 compatible = "atmel,at25df321a";
30 spi-max-frequency = <50000000>;
31 reg = <0>;
32 };
33 };
34
35 ssc0: ssc@f0008000 {
36 atmel,clk-from-rk-pin;
37 };
38
39 /*
40 * i2c0 conflicts with ISI:
41 * disable it to allow the use of ISI
42 * can not enable audio when i2c0 disabled
43 */
44 i2c0: i2c@f0014000 {
45 wm8904: wm8904@1a {
46 compatible = "wlf,wm8904";
47 reg = <0x1a>;
48 clocks = <&pck0>;
49 clock-names = "mclk";
50 };
51 };
52
53 i2c1: i2c@f0018000 {
54 ov2640: camera@30 {
55 compatible = "ovti,ov2640";
56 reg = <0x30>;
57 pinctrl-names = "default";
58 pinctrl-0 = <&pinctrl_pck1_as_isi_mck &pinctrl_sensor_power &pinctrl_sensor_reset>;
59 resetb-gpios = <&pioE 24 GPIO_ACTIVE_LOW>;
60 pwdn-gpios = <&pioE 29 GPIO_ACTIVE_HIGH>;
61 /* use pck1 for the master clock of ov2640 */
62 clocks = <&pck1>;
63 clock-names = "xvclk";
64 assigned-clocks = <&pck1>;
65 assigned-clock-rates = <25000000>;
66
67 port {
68 ov2640_0: endpoint {
69 remote-endpoint = <&isi_0>;
70 bus-width = <8>;
71 };
72 };
73 };
74 };
75
76 usart1: serial@f0020000 {
77 dmas = <0>, <0>; /* Do not use DMA for usart1 */
78 pinctrl-names = "default";
79 pinctrl-0 = <&pinctrl_usart1 &pinctrl_usart1_rts_cts>;
80 status = "okay";
81 };
82
83 isi: isi@f0034000 {
84 port {
85 isi_0: endpoint {
86 remote-endpoint = <&ov2640_0>;
87 bus-width = <8>;
88 vsync-active = <1>;
89 hsync-active = <1>;
90 };
91 };
92 };
93
94 mmc1: mmc@f8000000 {
95 pinctrl-names = "default";
96 pinctrl-0 = <&pinctrl_mmc1_clk_cmd_dat0 &pinctrl_mmc1_dat1_3 &pinctrl_mmc1_cd>;
97 status = "okay";
98 slot@0 {
99 reg = <0>;
100 bus-width = <4>;
101 cd-gpios = <&pioD 18 GPIO_ACTIVE_HIGH>;
102 };
103 };
104
105 adc0: adc@f8018000 {
106 pinctrl-names = "default", "sleep";
107 pinctrl-0 = <
108 &pinctrl_adc0_adtrg
109 &pinctrl_adc0_ad0
110 &pinctrl_adc0_ad1
111 &pinctrl_adc0_ad2
112 &pinctrl_adc0_ad3
113 &pinctrl_adc0_ad4
114 >;
115 pinctrl-1 = <
116 &pinctrl_adc0_adtrg_sleep
117 &pinctrl_adc0_ad0_sleep
118 &pinctrl_adc0_ad1_sleep
119 &pinctrl_adc0_ad2_sleep
120 &pinctrl_adc0_ad3_sleep
121 &pinctrl_adc0_ad4_sleep
122 >;
123 status = "okay";
124 };
125
126 macb1: ethernet@f802c000 {
127 phy-mode = "rmii";
128
129 #address-cells = <1>;
130 #size-cells = <0>;
131 phy0: ethernet-phy@1 {
132 /*interrupt-parent = <&pioE>;*/
133 /*interrupts = <30 IRQ_TYPE_EDGE_FALLING>;*/
134 reg = <1>;
135 };
136 };
137
138 pinctrl@fffff200 {
139 adc0 {
140 pinctrl_adc0_adtrg_sleep: adc0_adtrg_1 {
141 atmel,pins =
142 <AT91_PIOD 19 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
143 };
144 pinctrl_adc0_ad0_sleep: adc0_ad0_1 {
145 atmel,pins =
146 <AT91_PIOD 20 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
147 };
148 pinctrl_adc0_ad1_sleep: adc0_ad1_1 {
149 atmel,pins =
150 <AT91_PIOD 21 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
151 };
152 pinctrl_adc0_ad2_sleep: adc0_ad2_1 {
153 atmel,pins =
154 <AT91_PIOD 22 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
155 };
156 pinctrl_adc0_ad3_sleep: adc0_ad3_1 {
157 atmel,pins =
158 <AT91_PIOD 23 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
159 };
160 pinctrl_adc0_ad4_sleep: adc0_ad4_1 {
161 atmel,pins =
162 <AT91_PIOD 24 AT91_PERIPH_GPIO (AT91_PINCTRL_OUTPUT | AT91_PINCTRL_OUTPUT_VAL(0))>;
163 };
164 };
165
166 board {
167 pinctrl_gpio_keys: gpio_keys {
168 atmel,pins =
169 <AT91_PIOE 27 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP>;
170 };
171
172 pinctrl_mmc0_cd: mmc0_cd {
173 atmel,pins =
174 <AT91_PIOD 17 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
175 };
176
177 pinctrl_mmc1_cd: mmc1_cd {
178 atmel,pins =
179 <AT91_PIOD 18 AT91_PERIPH_GPIO AT91_PINCTRL_PULL_UP_DEGLITCH>;
180 };
181
182 pinctrl_pck0_as_audio_mck: pck0_as_audio_mck {
183 atmel,pins =
184 <AT91_PIOD 30 AT91_PERIPH_B AT91_PINCTRL_NONE>;
185 };
186
187 pinctrl_pck1_as_isi_mck: pck1_as_isi_mck-0 {
188 atmel,pins =
189 <AT91_PIOD 31 AT91_PERIPH_B AT91_PINCTRL_NONE>;
190 };
191
192 pinctrl_sensor_reset: sensor_reset-0 {
193 atmel,pins =
194 <AT91_PIOE 24 AT91_PERIPH_GPIO AT91_PINCTRL_NONE>;
195 };
196
197 pinctrl_sensor_power: sensor_power-0 {
198 atmel,pins =
199 <AT91_PIOE 29 AT91_PERIPH_GPIO AT91_PINCTRL_NONE>;
200 };
201
202 pinctrl_usba_vbus: usba_vbus {
203 atmel,pins =
204 <AT91_PIOD 29 AT91_PERIPH_GPIO AT91_PINCTRL_DEGLITCH>;
205 };
206 };
207 };
208
209 dbgu: serial@ffffee00 {
210 dmas = <0>, <0>; /* Do not use DMA for dbgu */
211 status = "okay";
212 };
213
214 watchdog@fffffe40 {
215 status = "okay";
216 };
217 };
218
219 usb0: gadget@500000 {
220 atmel,vbus-gpio = <&pioD 29 GPIO_ACTIVE_HIGH>;
221 pinctrl-names = "default";
222 pinctrl-0 = <&pinctrl_usba_vbus>;
223 status = "okay";
224 };
225 };
226
227 sound {
228 compatible = "atmel,asoc-wm8904";
229 pinctrl-names = "default";
230 pinctrl-0 = <&pinctrl_pck0_as_audio_mck>;
231
232 atmel,model = "wm8904 @ SAMA5D3EK";
233 atmel,audio-routing =
234 "Headphone Jack", "HPOUTL",
235 "Headphone Jack", "HPOUTR",
236 "IN2L", "Line In Jack",
237 "IN2R", "Line In Jack",
238 "Mic", "MICBIAS",
239 "IN1L", "Mic";
240
241 atmel,ssc-controller = <&ssc0>;
242 atmel,audio-codec = <&wm8904>;
243
244 status = "disabled";
245 };
246
247 /* Conflict with LCD pins */
248 gpio_keys {
249 compatible = "gpio-keys";
250 status = "okay";
251
252 #address-cells = <1>;
253 #size-cells = <0>;
254 pinctrl-names = "default";
255 pinctrl-0 = <&pinctrl_gpio_keys>;
256
257 pb_user1 {
258 label = "pb_user1";
259 gpios = <&pioE 27 GPIO_ACTIVE_HIGH>;
260 linux,code = <0x100>;
261 wakeup-source;
262 };
263 };
264};