treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / arch / arm / boot / dts / imx6q-gw5400-a.dts
blobb6e2b580051d97d830b750dec247e791df03ab33
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Copyright 2013 Gateworks Corporation
4  */
6 /dts-v1/;
7 #include <dt-bindings/gpio/gpio.h>
8 #include "imx6q.dtsi"
10 / {
11         model = "Gateworks Ventana GW5400-A";
12         compatible = "gw,imx6q-gw5400-a", "gw,ventana", "fsl,imx6q";
14         /* these are used by bootloader for disabling nodes */
15         aliases {
16                 i2c0 = &i2c1;
17                 i2c1 = &i2c2;
18                 i2c2 = &i2c3;
19                 led0 = &led0;
20                 led1 = &led1;
21                 led2 = &led2;
22                 ssi0 = &ssi1;
23                 spi0 = &ecspi1;
24                 usb0 = &usbh1;
25                 usb1 = &usbotg;
26         };
28         chosen {
29                 bootargs = "console=ttymxc1,115200";
30         };
32         leds {
33                 compatible = "gpio-leds";
34                 pinctrl-names = "default";
35                 pinctrl-0 = <&pinctrl_gpio_leds>;
37                 led0: user1 {
38                         label = "user1";
39                         gpios = <&gpio4 6 GPIO_ACTIVE_HIGH>; /* 102 -> MX6_PANLEDG */
40                         default-state = "on";
41                         linux,default-trigger = "heartbeat";
42                 };
44                 led1: user2 {
45                         label = "user2";
46                         gpios = <&gpio4 10 GPIO_ACTIVE_HIGH>; /* 106 -> MX6_PANLEDR */
47                         default-state = "off";
48                 };
50                 led2: user3 {
51                         label = "user3";
52                         gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* 111 -> MX6_LOCLED# */
53                         default-state = "off";
54                 };
55         };
57         memory@10000000 {
58                 device_type = "memory";
59                 reg = <0x10000000 0x40000000>;
60         };
62         pps {
63                 compatible = "pps-gpio";
64                 pinctrl-names = "default";
65                 pinctrl-0 = <&pinctrl_gpio_leds>;
66                 gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>;
67                 status = "okay";
68         };
70         regulators {
71                 compatible = "simple-bus";
72                 #address-cells = <1>;
73                 #size-cells = <0>;
75                 reg_1p0v: regulator@0 {
76                         compatible = "regulator-fixed";
77                         reg = <0>;
78                         regulator-name = "1P0V";
79                         regulator-min-microvolt = <1000000>;
80                         regulator-max-microvolt = <1000000>;
81                         regulator-always-on;
82                 };
84                 reg_3p3v: regulator@1 {
85                         compatible = "regulator-fixed";
86                         reg = <1>;
87                         regulator-name = "3P3V";
88                         regulator-min-microvolt = <3300000>;
89                         regulator-max-microvolt = <3300000>;
90                         regulator-always-on;
91                 };
93                 reg_usb_h1_vbus: regulator@2 {
94                         compatible = "regulator-fixed";
95                         reg = <2>;
96                         regulator-name = "usb_h1_vbus";
97                         regulator-min-microvolt = <5000000>;
98                         regulator-max-microvolt = <5000000>;
99                         regulator-always-on;
100                 };
102                 reg_usb_otg_vbus: regulator@3 {
103                         compatible = "regulator-fixed";
104                         reg = <3>;
105                         regulator-name = "usb_otg_vbus";
106                         regulator-min-microvolt = <5000000>;
107                         regulator-max-microvolt = <5000000>;
108                         gpio = <&gpio3 22 GPIO_ACTIVE_HIGH>;
109                         enable-active-high;
110                 };
111         };
113         sound {
114                 compatible = "fsl,imx6q-ventana-sgtl5000",
115                              "fsl,imx-audio-sgtl5000";
116                 model = "sgtl5000-audio";
117                 ssi-controller = <&ssi1>;
118                 audio-codec = <&codec>;
119                 audio-routing =
120                         "MIC_IN", "Mic Jack",
121                         "Mic Jack", "Mic Bias",
122                         "Headphone Jack", "HP_OUT";
123                 mux-int-port = <1>;
124                 mux-ext-port = <4>;
125         };
128 &audmux {
129         pinctrl-names = "default";
130         pinctrl-0 = <&pinctrl_audmux>;
131         status = "okay";
134 &ecspi1 {
135         cs-gpios = <&gpio3 19 GPIO_ACTIVE_HIGH>;
136         pinctrl-names = "default";
137         pinctrl-0 = <&pinctrl_ecspi1>;
138         status = "okay";
140         flash: m25p80@0 {
141                 compatible = "sst,w25q256", "jedec,spi-nor";
142                 spi-max-frequency = <30000000>;
143                 reg = <0>;
144         };
147 &fec {
148         pinctrl-names = "default";
149         pinctrl-0 = <&pinctrl_enet>;
150         phy-mode = "rgmii-id";
151         phy-reset-gpios = <&gpio1 30 GPIO_ACTIVE_LOW>;
152         status = "okay";
155 &hdmi {
156         ddc-i2c-bus = <&i2c3>;
157         status = "okay";
160 &i2c1 {
161         clock-frequency = <100000>;
162         pinctrl-names = "default";
163         pinctrl-0 = <&pinctrl_i2c1>;
164         status = "okay";
166         eeprom1: eeprom@50 {
167                 compatible = "atmel,24c02";
168                 reg = <0x50>;
169                 pagesize = <16>;
170         };
172         eeprom2: eeprom@51 {
173                 compatible = "atmel,24c02";
174                 reg = <0x51>;
175                 pagesize = <16>;
176         };
178         eeprom3: eeprom@52 {
179                 compatible = "atmel,24c02";
180                 reg = <0x52>;
181                 pagesize = <16>;
182         };
184         eeprom4: eeprom@53 {
185                 compatible = "atmel,24c02";
186                 reg = <0x53>;
187                 pagesize = <16>;
188         };
190         gpio: pca9555@23 {
191                 compatible = "nxp,pca9555";
192                 reg = <0x23>;
193                 gpio-controller;
194                 #gpio-cells = <2>;
195         };
197         rtc: ds1672@68 {
198                 compatible = "dallas,ds1672";
199                 reg = <0x68>;
200         };
203 &i2c2 {
204         clock-frequency = <100000>;
205         pinctrl-names = "default";
206         pinctrl-0 = <&pinctrl_i2c2>;
207         status = "okay";
209         pmic: pfuze100@8 {
210                 compatible = "fsl,pfuze100";
211                 reg = <0x08>;
213                 regulators {
214                         sw1a_reg: sw1ab {
215                                 regulator-min-microvolt = <300000>;
216                                 regulator-max-microvolt = <1875000>;
217                                 regulator-boot-on;
218                                 regulator-always-on;
219                                 regulator-ramp-delay = <6250>;
220                         };
222                         sw1c_reg: sw1c {
223                                 regulator-min-microvolt = <300000>;
224                                 regulator-max-microvolt = <1875000>;
225                                 regulator-boot-on;
226                                 regulator-always-on;
227                                 regulator-ramp-delay = <6250>;
228                         };
230                         sw2_reg: sw2 {
231                                 regulator-min-microvolt = <800000>;
232                                 regulator-max-microvolt = <3950000>;
233                                 regulator-boot-on;
234                                 regulator-always-on;
235                         };
237                         sw3a_reg: sw3a {
238                                 regulator-min-microvolt = <400000>;
239                                 regulator-max-microvolt = <1975000>;
240                                 regulator-boot-on;
241                                 regulator-always-on;
242                         };
244                         sw3b_reg: sw3b {
245                                 regulator-min-microvolt = <400000>;
246                                 regulator-max-microvolt = <1975000>;
247                                 regulator-boot-on;
248                                 regulator-always-on;
249                         };
251                         sw4_reg: sw4 {
252                                 regulator-min-microvolt = <800000>;
253                                 regulator-max-microvolt = <3300000>;
254                         };
256                         swbst_reg: swbst {
257                                 regulator-min-microvolt = <5000000>;
258                                 regulator-max-microvolt = <5150000>;
259                         };
261                         snvs_reg: vsnvs {
262                                 regulator-min-microvolt = <1000000>;
263                                 regulator-max-microvolt = <3000000>;
264                                 regulator-boot-on;
265                                 regulator-always-on;
266                         };
268                         vref_reg: vrefddr {
269                                 regulator-boot-on;
270                                 regulator-always-on;
271                         };
273                         vgen1_reg: vgen1 {
274                                 regulator-min-microvolt = <800000>;
275                                 regulator-max-microvolt = <1550000>;
276                         };
278                         vgen2_reg: vgen2 {
279                                 regulator-min-microvolt = <800000>;
280                                 regulator-max-microvolt = <1550000>;
281                         };
283                         vgen3_reg: vgen3 {
284                                 regulator-min-microvolt = <1800000>;
285                                 regulator-max-microvolt = <3300000>;
286                         };
288                         vgen4_reg: vgen4 {
289                                 regulator-min-microvolt = <1800000>;
290                                 regulator-max-microvolt = <3300000>;
291                                 regulator-always-on;
292                         };
294                         vgen5_reg: vgen5 {
295                                 regulator-min-microvolt = <1800000>;
296                                 regulator-max-microvolt = <3300000>;
297                                 regulator-always-on;
298                         };
300                         vgen6_reg: vgen6 {
301                                 regulator-min-microvolt = <1800000>;
302                                 regulator-max-microvolt = <3300000>;
303                                 regulator-always-on;
304                         };
305                 };
306         };
309 &i2c3 {
310         clock-frequency = <100000>;
311         pinctrl-names = "default";
312         pinctrl-0 = <&pinctrl_i2c3>;
313         status = "okay";
315         accelerometer: mma8450@1c {
316                 compatible = "fsl,mma8450";
317                 reg = <0x1c>;
318         };
320         codec: sgtl5000@a {
321                 compatible = "fsl,sgtl5000";
322                 reg = <0x0a>;
323                 clocks = <&clks IMX6QDL_CLK_CKO>;
324                 VDDA-supply = <&sw4_reg>;
325                 VDDIO-supply = <&reg_3p3v>;
326         };
328         touchscreen: egalax_ts@4 {
329                 compatible = "eeti,egalax_ts";
330                 reg = <0x04>;
331                 interrupt-parent = <&gpio7>;
332                 interrupts = <12 2>;
333                 wakeup-gpios = <&gpio7 12 GPIO_ACTIVE_LOW>;
334         };
337 &ldb {
338         status = "okay";
341 &pcie {
342         reset-gpio = <&gpio1 29 GPIO_ACTIVE_LOW>;
343         status = "okay";
346 &ssi1 {
347         status = "okay";
350 &uart1 {
351         pinctrl-names = "default";
352         pinctrl-0 = <&pinctrl_uart1>;
353         status = "okay";
356 &uart2 {
357         pinctrl-names = "default";
358         pinctrl-0 = <&pinctrl_uart2>;
359         status = "okay";
362 &uart5 {
363         pinctrl-names = "default";
364         pinctrl-0 = <&pinctrl_uart5>;
365         status = "okay";
368 &usbotg {
369         vbus-supply = <&reg_usb_otg_vbus>;
370         pinctrl-names = "default";
371         pinctrl-0 = <&pinctrl_usbotg>;
372         disable-over-current;
373         status = "okay";
376 &usbh1 {
377         vbus-supply = <&reg_usb_h1_vbus>;
378         status = "okay";
381 &usdhc3 {
382         pinctrl-names = "default";
383         pinctrl-0 = <&pinctrl_usdhc3>;
384         cd-gpios = <&gpio7 0 GPIO_ACTIVE_LOW>;
385         vmmc-supply = <&reg_3p3v>;
386         status = "okay";
389 &iomuxc {
390         pinctrl_audmux: audmuxgrp {
391                 fsl,pins = <
392                         MX6QDL_PAD_SD2_DAT0__AUD4_RXD           0x130b0
393                         MX6QDL_PAD_SD2_DAT3__AUD4_TXC           0x130b0
394                         MX6QDL_PAD_SD2_DAT2__AUD4_TXD           0x110b0
395                         MX6QDL_PAD_SD2_DAT1__AUD4_TXFS          0x130b0
396                         MX6QDL_PAD_GPIO_0__CCM_CLKO1            0x130b0 /* AUD4_MCK */
397                 >;
398         };
400         pinctrl_ecspi1: ecspi1grp {
401                 fsl,pins = <
402                         MX6QDL_PAD_EIM_D17__ECSPI1_MISO         0x100b1
403                         MX6QDL_PAD_EIM_D18__ECSPI1_MOSI         0x100b1
404                         MX6QDL_PAD_EIM_D16__ECSPI1_SCLK         0x100b1
405                         MX6QDL_PAD_EIM_D19__GPIO3_IO19          0x1b0b0 /* SPINOR_CS0# */
406                 >;
407         };
409         pinctrl_enet: enetgrp {
410                 fsl,pins = <
411                         MX6QDL_PAD_RGMII_RXC__RGMII_RXC         0x1b030
412                         MX6QDL_PAD_RGMII_RD0__RGMII_RD0         0x1b030
413                         MX6QDL_PAD_RGMII_RD1__RGMII_RD1         0x1b030
414                         MX6QDL_PAD_RGMII_RD2__RGMII_RD2         0x1b030
415                         MX6QDL_PAD_RGMII_RD3__RGMII_RD3         0x1b030
416                         MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL   0x1b030
417                         MX6QDL_PAD_RGMII_TXC__RGMII_TXC         0x1b030
418                         MX6QDL_PAD_RGMII_TD0__RGMII_TD0         0x1b030
419                         MX6QDL_PAD_RGMII_TD1__RGMII_TD1         0x1b030
420                         MX6QDL_PAD_RGMII_TD2__RGMII_TD2         0x1b030
421                         MX6QDL_PAD_RGMII_TD3__RGMII_TD3         0x1b030
422                         MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL   0x1b030
423                         MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK    0x1b0b0
424                         MX6QDL_PAD_ENET_MDIO__ENET_MDIO         0x1b0b0
425                         MX6QDL_PAD_ENET_MDC__ENET_MDC           0x1b0b0
426                         MX6QDL_PAD_GPIO_16__ENET_REF_CLK        0x4001b0a8
427                 >;
428         };
430         pinctrl_gpio_leds: gpioledsgrp {
431                 fsl,pins = <
432                         MX6QDL_PAD_KEY_COL0__GPIO4_IO06         0x1b0b0 /* user1 led */
433                         MX6QDL_PAD_KEY_COL2__GPIO4_IO10         0x1b0b0 /* user2 led */
434                         MX6QDL_PAD_KEY_ROW4__GPIO4_IO15         0x1b0b0 /* user3 led */
435                 >;
436         };
438         pinctrl_i2c1: i2c1grp {
439                 fsl,pins = <
440                         MX6QDL_PAD_EIM_D21__I2C1_SCL            0x4001b8b1
441                         MX6QDL_PAD_EIM_D28__I2C1_SDA            0x4001b8b1
442                 >;
443         };
445         pinctrl_i2c2: i2c2grp {
446                 fsl,pins = <
447                         MX6QDL_PAD_KEY_COL3__I2C2_SCL           0x4001b8b1
448                         MX6QDL_PAD_KEY_ROW3__I2C2_SDA           0x4001b8b1
449                 >;
450         };
452         pinctrl_i2c3: i2c3grp {
453                 fsl,pins = <
454                         MX6QDL_PAD_GPIO_3__I2C3_SCL             0x4001b8b1
455                         MX6QDL_PAD_GPIO_6__I2C3_SDA             0x4001b8b1
456                 >;
457         };
459         pinctrl_pcie: pciegrp {
460                 fsl,pins = <
461                         MX6QDL_PAD_ENET_TX_EN__GPIO1_IO28       0x1b0b0 /* PCIE IRQ */
462                         MX6QDL_PAD_ENET_TXD1__GPIO1_IO29        0x1b0b0 /* PCIE RST */
463                 >;
464         };
466         pinctrl_pps: ppsgrp {
467                 fsl,pins = <
468                         MX6QDL_PAD_GPIO_5__GPIO1_IO05           0x1b0b0 /* GPS_PPS */
469                 >;
470         };
472         pinctrl_uart1: uart1grp {
473                 fsl,pins = <
474                         MX6QDL_PAD_SD3_DAT7__UART1_TX_DATA      0x1b0b1
475                         MX6QDL_PAD_SD3_DAT6__UART1_RX_DATA      0x1b0b1
476                 >;
477         };
479         pinctrl_uart2: uart2grp {
480                 fsl,pins = <
481                         MX6QDL_PAD_SD4_DAT7__UART2_TX_DATA      0x1b0b1
482                         MX6QDL_PAD_SD4_DAT4__UART2_RX_DATA      0x1b0b1
483                 >;
484         };
486         pinctrl_uart5: uart5grp {
487                 fsl,pins = <
488                         MX6QDL_PAD_KEY_COL1__UART5_TX_DATA      0x1b0b1
489                         MX6QDL_PAD_KEY_ROW1__UART5_RX_DATA      0x1b0b1
490                 >;
491         };
493         pinctrl_usbotg: usbotggrp {
494                 fsl,pins = <
495                         MX6QDL_PAD_GPIO_1__USB_OTG_ID           0x17059
496                         MX6QDL_PAD_EIM_D22__GPIO3_IO22          0x1b0b0 /* OTG_PWR_EN */
497                 >;
498         };
500         pinctrl_usdhc3: usdhc3grp {
501                 fsl,pins = <
502                         MX6QDL_PAD_SD3_CMD__SD3_CMD             0x17059
503                         MX6QDL_PAD_SD3_CLK__SD3_CLK             0x10059
504                         MX6QDL_PAD_SD3_DAT0__SD3_DATA0          0x17059
505                         MX6QDL_PAD_SD3_DAT1__SD3_DATA1          0x17059
506                         MX6QDL_PAD_SD3_DAT2__SD3_DATA2          0x17059
507                         MX6QDL_PAD_SD3_DAT3__SD3_DATA3          0x17059
508                 >;
509         };