1// SPDX-License-Identifier: GPL-2.0
2/*
3 * at91-kizbox3.dts - Device Tree Include file for Overkiz Kizbox 3
4 * family SoC boards
5 *
6 * Copyright (C) 2018 Overkiz SAS
7 *
8 * Authors: Dorian Rocipon <d.rocipon@overkiz.com>
9 *          Kevin Carli <k.carli@overkiz.com>
10 *          Mickael Gardet <m.gardet@overkiz.com>
11 */
12/dts-v1/;
13#include "sama5d2.dtsi"
14#include "sama5d2-pinfunc.h"
15#include <dt-bindings/gpio/gpio.h>
16#include <dt-bindings/mfd/atmel-flexcom.h>
17#include <dt-bindings/pinctrl/at91.h>
18#include <dt-bindings/pwm/pwm.h>
19
20/ {
21	model = "Overkiz Kizbox3";
22	compatible = "overkiz,kizbox3", "atmel,sama5d2", "atmel,sama5";
23
24	aliases {
25		serial0 = &uart0;
26		serial1 = &uart1;
27		serial2 = &uart2;
28		serial3 = &uart3;
29		serial4 = &uart4;
30		serial5 = &uart5;
31		serial6 = &uart8;
32	};
33
34	chosen {
35		bootargs = "ubi.mtd=ubi";
36		stdout-path = "serial1:115200n8";
37	};
38
39	clocks {
40		slow_xtal {
41			clock-frequency = <32768>;
42		};
43
44		main_xtal {
45			clock-frequency = <12000000>;
46		};
47	};
48
49	vdd_adc_vddana: supply_3v3_ana {
50		compatible = "regulator-fixed";
51		regulator-name = "adc-vddana";
52		regulator-min-microvolt = <3300000>;
53		regulator-max-microvolt = <3300000>;
54		regulator-always-on;
55	};
56
57	vdd_adc_vref: supply_3v3_ref {
58		compatible = "regulator-fixed";
59		regulator-name = "adc-vref";
60		regulator-min-microvolt = <3300000>;
61		regulator-max-microvolt = <3300000>;
62		regulator-always-on;
63	};
64
65	pwm_leds {
66		compatible = "pwm-leds";
67		pinctrl-names = "default";
68		pinctrl-0 = <&pinctrl_pwm0_pwm_h0
69			     &pinctrl_pwm0_pwm_h1
70			     &pinctrl_pwm0_pwm_h2
71			     &pinctrl_pwm0_pwm_h3>;
72		status = "disabled";
73
74		red {
75			label = "pwm:red:user";
76			pwms = <&pwm0 0 10000000 0>;
77			max-brightness = <255>;
78			linux,default-trigger = "default-on";
79			status = "disabled";
80		};
81
82		green {
83			label = "pwm:green:user";
84			pwms = <&pwm0 1 10000000 0>;
85			max-brightness = <255>;
86			linux,default-trigger = "default-on";
87			status = "disabled";
88		};
89
90		blue {
91			label = "pwm:blue:user";
92			pwms = <&pwm0 2 10000000 0>;
93			max-brightness = <255>;
94			status = "disabled";
95		};
96
97		white {
98			label = "pwm:white:user";
99			pwms = <&pwm0 3 10000000 0>;
100			max-brightness = <255>;
101			status = "disabled";
102		};
103	};
104};
105
106&ebi {
107	status = "okay";
108};
109
110&nand_controller {
111	status = "okay";
112
113	nand@3 {
114		pinctrl-0 = <&pinctrl_ebi_nand_addr>;
115		pinctrl-names = "default";
116		reg = <0x3 0x0 0x800000>;
117
118		atmel,rb = <0>;
119		nand-bus-width = <8>;
120		nand-ecc-mode = "hw";
121		nand-ecc-strength = <4>;
122		nand-ecc-step-size = <512>;
123		nand-on-flash-bbt;
124		label = "atmel_nand";
125
126		partitions {
127			compatible = "fixed-partitions";
128			#address-cells = <1>;
129			#size-cells = <1>;
130
131			bootstrap@0 {
132				label = "bootstrap";
133				reg = <0x0 0x20000>;
134			};
135
136			u-boot@20000 {
137				label = "u-boot";
138				reg = <0x20000 0x140000>;
139			};
140
141			u-boot-factory@160000 {
142				label = "u-boot-factory";
143				reg = <0x160000 0x140000>;
144			};
145
146			ubi@2A0000 {
147				label = "ubi";
148				reg = <0x2A0000 0x7D60000>;
149			};
150		};
151
152	};
153};
154
155&rtc {
156	status = "okay";
157};
158
159&pioA {
160	pinctrl_ebi_nand_addr: ebi-addr-1 {
161		pinmux = <PIN_PA0__D0>,
162			<PIN_PA1__D1>,
163			<PIN_PA2__D2>,
164			<PIN_PA3__D3>,
165			<PIN_PA4__D4>,
166			<PIN_PA5__D5>,
167			<PIN_PA6__D6>,
168			<PIN_PA7__D7>,
169			<PIN_PA8__NWE_NANDWE>,
170			<PIN_PA9__NCS3>,
171			<PIN_PA10__A21_NANDALE>,
172			<PIN_PA11__A22_NANDCLE>,
173			<PIN_PA21__NANDRDY>;
174		bias-disable;
175	};
176
177	pinctrl_usart {
178		pinctrl_usart_0: usart0-0 {
179			pinmux = < PIN_PB26__URXD0>, <PIN_PB27__UTXD0>;
180			bias-disable;
181		};
182		pinctrl_usart_1: usart1-0 {
183			pinmux = < PIN_PD2__URXD1>, <PIN_PD3__UTXD1>;
184			bias-disable;
185		};
186		pinctrl_usart_2: usart2-0 {
187			pinmux = < PIN_PD4__URXD2>, <PIN_PD5__UTXD2>;
188			bias-disable;
189		};
190		pinctrl_usart_3: usart3-0 {
191			pinmux = < PIN_PC12__URXD3>, <PIN_PC13__UTXD3>;
192			bias-disable;
193		};
194		pinctrl_usart_4: usart4-0 {
195			pinmux = < PIN_PB3__URXD4>, <PIN_PB4__UTXD4>;
196			bias-disable;
197		};
198		pinctrl_flx0_default: flx0_usart_default {
199			pinmux = <PIN_PB28__FLEXCOM0_IO0>, //TX
200			<PIN_PB29__FLEXCOM0_IO1>; //RX
201			bias-disable;
202		};
203		pinctrl_flx3_default: flx3_usart_default {
204			pinmux = <PIN_PB22__FLEXCOM3_IO1>, //RX
205			<PIN_PB23__FLEXCOM3_IO0>; //TX
206			bias-disable;
207		};
208	};
209
210	pinctrl_flx4_default: flx4_i2c6_default {
211		pinmux = <PIN_PD12__FLEXCOM4_IO0>, //DATA
212		<PIN_PD13__FLEXCOM4_IO1>; //CLK
213		bias-disable;
214		drive-open-drain = <1>;
215	};
216
217	pinctrl_pwm0 {
218		pinctrl_pwm0_pwm_h0: pwm0_pwm_h0 {
219			pinmux = <PIN_PA30__PWMH0>;
220			bias-disable;
221		};
222		pinctrl_pwm0_pwm_h1: pwm0_pwmh1 {
223			pinmux = <PIN_PB0__PWMH1>;
224			bias-disable;
225		};
226		pinctrl_pwm0_pwm_h2: pwm0_pwm_h2 {
227			pinmux = <PIN_PB5__PWMH2>;
228			bias-disable;
229		};
230		pinctrl_pwm0_pwm_h3: pwm0_pwm_h3 {
231			pinmux = <PIN_PB7__PWMH3>;
232			bias-disable;
233		};
234	};
235
236	pinctrl_adc {
237		pinctrl_adc2: adc2 {
238			pinmux = <PIN_PD21__GPIO>;
239			bias-disable;
240		};
241		pinctrl_adc3: adc3 {
242			pinmux = <PIN_PD22__GPIO>;
243			bias-disable;
244		};
245		pinctrl_adc4: adc4 {
246			pinmux = <PIN_PD23__GPIO>;
247			bias-disable;
248		};
249		pinctrl_adc5: adc5 {
250			pinmux = <PIN_PD24__GPIO>;
251			bias-disable;
252		};
253	};
254};
255
256&uart0 {
257	pinctrl-names = "default";
258	pinctrl-0 = <&pinctrl_usart_0>;
259	atmel,use-dma-rx;
260	atmel,use-dma-tx;
261	status = "disabled";
262};
263
264/* debug uart */
265&uart1 {
266	pinctrl-names = "default";
267	pinctrl-0 = <&pinctrl_usart_1>;
268	atmel,use-dma-rx;
269	atmel,use-dma-tx;
270	status = "disabled";
271};
272
273&uart2 {
274	pinctrl-names = "default";
275	pinctrl-0 = <&pinctrl_usart_2>;
276	atmel,use-dma-rx;
277	atmel,use-dma-tx;
278	status = "disabled";
279};
280
281&uart3 {
282	pinctrl-names = "default";
283	pinctrl-0 = <&pinctrl_usart_3>;
284	atmel,use-dma-rx;
285	atmel,use-dma-tx;
286	status = "disabled";
287};
288
289&uart4 {
290	pinctrl-names = "default";
291	pinctrl-0 = <&pinctrl_usart_4>;
292	atmel,use-dma-rx;
293	atmel,use-dma-tx;
294	status = "disabled";
295};
296
297&flx0 {
298	atmel,flexcom-mode = <ATMEL_FLEXCOM_MODE_USART>;
299	status = "disabled";
300
301	uart5: serial@200  {
302		pinctrl-names = "default";
303		pinctrl-0 = <&pinctrl_flx0_default>;
304		atmel,use-dma-rx;
305		atmel,use-dma-tx;
306		status = "disabled";
307	};
308};
309
310&flx3 {
311	atmel,flexcom-mode = <ATMEL_FLEXCOM_MODE_USART>;
312	status = "disabled";
313
314	uart8: serial@200 {
315		pinctrl-names = "default";
316		pinctrl-0 = <&pinctrl_flx3_default>;
317		atmel,use-dma-rx;
318		atmel,use-dma-tx;
319		status = "disabled";
320	};
321};
322
323&flx4 {
324	atmel,flexcom-mode = <ATMEL_FLEXCOM_MODE_TWI>;
325	status = "disabled";
326
327	i2c6: i2c@600 {
328		pinctrl-names = "default";
329		pinctrl-0 = <&pinctrl_flx4_default>;
330		status = "disabled";
331	};
332};
333
334&pwm0 {
335	status = "okay";
336};
337
338&shutdown_controller {
339	atmel,shdwc-debouncer = <976>;
340	atmel,wakeup-rtc-timer;
341
342	input@0 {
343		reg = <0>;
344		atmel,wakeup-type = "low";
345	};
346};
347
348&watchdog {
349	status = "okay";
350};
351
352&adc {
353	pinctrl-names = "default";
354	pinctrl-0 = <&pinctrl_adc2
355		     &pinctrl_adc3
356		     &pinctrl_adc4
357		     &pinctrl_adc5>;
358
359	vddana-supply = <&vdd_adc_vddana>;
360	vref-supply = <&vdd_adc_vref>;
361	status = "disabled";
362};
363
364&securam {
365	export;
366
367	/* export overkiz u-boot mode/version and factory */
368	uboot@1400 {
369		reg = <0x1400 0x20>;
370		export;
371	};
372};
373