treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / arch / arm / boot / dts / at91-kizbox3_common.dtsi
blob299e74d23184580e5264465ab82db8bdc087a6c9
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>
20 / {
21         model = "Overkiz Kizbox3";
22         compatible = "overkiz,kizbox3", "atmel,sama5d2", "atmel,sama5";
24         aliases {
25                 serial0 = &uart0;
26                 serial1 = &uart1;
27                 serial2 = &uart2;
28                 serial3 = &uart3;
29                 serial4 = &uart4;
30                 serial5 = &uart5;
31                 serial6 = &uart6;
32         };
34         chosen {
35                 bootargs = "ubi.mtd=ubi";
36                 stdout-path = "serial1:115200n8";
37         };
39         clocks {
40                 slow_xtal {
41                         clock-frequency = <32768>;
42                 };
44                 main_xtal {
45                         clock-frequency = <12000000>;
46                 };
47         };
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         };
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         };
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";
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                 };
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                 };
90                 blue {
91                         label = "pwm:blue:user";
92                         pwms = <&pwm0 2 10000000 0>;
93                         max-brightness = <255>;
94                         status = "disabled";
95                 };
97                 white {
98                         label = "pwm:white:user";
99                         pwms = <&pwm0 3 10000000 0>;
100                         max-brightness = <255>;
101                         status = "disabled";
102                 };
103         };
106 &ebi {
107         status = "okay";
110 &nand_controller {
111         status = "okay";
113         nand@3 {
114                 pinctrl-0 = <&pinctrl_ebi_nand_addr>;
115                 pinctrl-names = "default";
116                 reg = <0x3 0x0 0x800000>;
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";
126                 partitions {
127                         compatible = "fixed-partitions";
128                         #address-cells = <1>;
129                         #size-cells = <1>;
131                         bootstrap@0 {
132                                 label = "bootstrap";
133                                 reg = <0x0 0x20000>;
134                         };
136                         u-boot@20000 {
137                                 label = "u-boot";
138                                 reg = <0x20000 0x140000>;
139                         };
141                         u-boot-factory@160000 {
142                                 label = "u-boot-factory";
143                                 reg = <0x160000 0x140000>;
144                         };
146                         ubi@2A0000 {
147                                 label = "ubi";
148                                 reg = <0x2A0000 0x7D60000>;
149                         };
150                 };
152         };
155 &rtc {
156         status = "okay";
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         };
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         };
210         pinctrl_flx4_default: flx4_i2c2_default {
211                 pinmux = <PIN_PD12__FLEXCOM4_IO0>, //DATA
212                 <PIN_PD13__FLEXCOM4_IO1>; //CLK
213                 bias-disable;
214                 drive-open-drain = <1>;
215         };
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         };
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         };
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";
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";
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";
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";
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";
297 &flx0 {
298         atmel,flexcom-mode = <ATMEL_FLEXCOM_MODE_USART>;
299         status = "disabled";
301         uart5: serial@200  {
302                 compatible = "atmel,at91sam9260-usart";
303                 reg = <0x200 0x400>;
304                 interrupts = <19 IRQ_TYPE_LEVEL_HIGH 7>;
305                 dmas = <&dma0
306                         (AT91_XDMAC_DT_MEM_IF(0) | AT91_XDMAC_DT_PER_IF(1)
307                         | AT91_XDMAC_DT_PERID(11))>,
308                        <&dma0
309                         (AT91_XDMAC_DT_MEM_IF(0) | AT91_XDMAC_DT_PER_IF(1)
310                         | AT91_XDMAC_DT_PERID(12))>;
311                 dma-names = "tx", "rx";
312                 clocks = <&pmc PMC_TYPE_PERIPHERAL 19>;
313                 clock-names = "usart";
314                 pinctrl-names = "default";
315                 pinctrl-0 = <&pinctrl_flx0_default>;
316                 atmel,fifo-size = <32>;
317                 atmel,use-dma-rx;
318                 atmel,use-dma-tx;
319                 status = "disabled";
320         };
323 &flx3 {
324         atmel,flexcom-mode = <ATMEL_FLEXCOM_MODE_USART>;
325         status = "disabled";
327         uart6: serial@200 {
328                 compatible = "atmel,at91sam9260-usart";
329                 reg = <0x200 0x400>;
330                 interrupts = <22 IRQ_TYPE_LEVEL_HIGH 7>;
331                 dmas = <&dma0
332                         (AT91_XDMAC_DT_MEM_IF(0) | AT91_XDMAC_DT_PER_IF(1)
333                         | AT91_XDMAC_DT_PERID(17))>,
334                        <&dma0
335                         (AT91_XDMAC_DT_MEM_IF(0) | AT91_XDMAC_DT_PER_IF(1)
336                         | AT91_XDMAC_DT_PERID(18))>;
337                 dma-names = "tx", "rx";
338                 clocks = <&pmc PMC_TYPE_PERIPHERAL 22>;
339                 clock-names = "usart";
340                 pinctrl-names = "default";
341                 pinctrl-0 = <&pinctrl_flx3_default>;
342                 atmel,fifo-size = <32>;
343                 atmel,use-dma-rx;
344                 atmel,use-dma-tx;
345                 status = "disabled";
346         };
349 &flx4 {
350         atmel,flexcom-mode = <ATMEL_FLEXCOM_MODE_TWI>;
351         status = "disabled";
353         i2c2: i2c@600 {
354                 compatible = "atmel,sama5d2-i2c";
355                 reg = <0x600 0x200>;
356                 interrupts = <23 IRQ_TYPE_LEVEL_HIGH 7>;
357                 dmas = <&dma0
358                         (AT91_XDMAC_DT_MEM_IF(0) | AT91_XDMAC_DT_PER_IF(1)
359                         | AT91_XDMAC_DT_PERID(19))>,
360                        <&dma0
361                         (AT91_XDMAC_DT_MEM_IF(0) | AT91_XDMAC_DT_PER_IF(1)
362                         | AT91_XDMAC_DT_PERID(20))>;
363                 dma-names = "tx", "rx";
364                 #address-cells = <1>;
365                 #size-cells = <0>;
366                 clocks = <&pmc PMC_TYPE_PERIPHERAL 23>;
367                 pinctrl-names = "default";
368                 pinctrl-0 = <&pinctrl_flx4_default>;
369                 atmel,fifo-size = <16>;
370                 status = "disabled";
371         };
374 &pwm0 {
375         status = "okay";
378 &shutdown_controller {
379         atmel,shdwc-debouncer = <976>;
380         atmel,wakeup-rtc-timer;
382         input@0 {
383                 reg = <0>;
384                 atmel,wakeup-type = "low";
385         };
388 &watchdog {
389         status = "okay";
392 &adc {
393         pinctrl-names = "default";
394         pinctrl-0 = <&pinctrl_adc2
395                      &pinctrl_adc3
396                      &pinctrl_adc4
397                      &pinctrl_adc5>;
399         vddana-supply = <&vdd_adc_vddana>;
400         vref-supply = <&vdd_adc_vref>;
401         status = "disabled";
404 &securam {
405         export;
407         /* export overkiz u-boot mode/version and factory */
408         uboot@1400 {
409                 reg = <0x1400 0x20>;
410                 export;
411         };