blob: ceeca4966fc5c8a06694f38527691b2564f409db [file] [log] [blame]
Tim Harvey23956252022-04-13 11:31:09 -07001// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
Marcel Ziswilere0caa842022-07-21 15:44:32 +02003 * Copyright 2021 Gateworks Corporation
Tim Harvey23956252022-04-13 11:31:09 -07004 */
5
6/dts-v1/;
7
8#include <dt-bindings/gpio/gpio.h>
9#include <dt-bindings/input/linux-event-codes.h>
10#include <dt-bindings/leds/common.h>
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +010011#include <dt-bindings/phy/phy-imx8-pcie.h>
Tim Harvey23956252022-04-13 11:31:09 -070012
13#include "imx8mp.dtsi"
14
15/ {
16 model = "Gateworks Venice GW74xx i.MX8MP board";
17 compatible = "gateworks,imx8mp-gw74xx", "fsl,imx8mp";
18
19 aliases {
20 ethernet0 = &eqos;
21 ethernet1 = &fec;
22 ethernet2 = &lan1;
23 ethernet3 = &lan2;
24 ethernet4 = &lan3;
25 ethernet5 = &lan4;
26 ethernet6 = &lan5;
27 };
28
29 chosen {
30 stdout-path = &uart2;
31 };
32
33 memory@40000000 {
34 device_type = "memory";
35 reg = <0x0 0x40000000 0 0x80000000>;
36 };
37
38 gpio-keys {
39 compatible = "gpio-keys";
40
41 key-0 {
42 label = "user_pb";
43 gpios = <&gpio 2 GPIO_ACTIVE_LOW>;
44 linux,code = <BTN_0>;
45 };
46
47 key-1 {
48 label = "user_pb1x";
49 linux,code = <BTN_1>;
50 interrupt-parent = <&gsc>;
51 interrupts = <0>;
52 };
53
54 key-2 {
55 label = "key_erased";
56 linux,code = <BTN_2>;
57 interrupt-parent = <&gsc>;
58 interrupts = <1>;
59 };
60
61 key-3 {
62 label = "eeprom_wp";
63 linux,code = <BTN_3>;
64 interrupt-parent = <&gsc>;
65 interrupts = <2>;
66 };
67
68 key-4 {
69 label = "tamper";
70 linux,code = <BTN_4>;
71 interrupt-parent = <&gsc>;
72 interrupts = <5>;
73 };
74
75 key-5 {
76 label = "switch_hold";
77 linux,code = <BTN_5>;
78 interrupt-parent = <&gsc>;
79 interrupts = <7>;
80 };
81 };
82
83 led-controller {
84 compatible = "gpio-leds";
85 pinctrl-names = "default";
86 pinctrl-0 = <&pinctrl_gpio_leds>;
87
88 led-0 {
89 function = LED_FUNCTION_HEARTBEAT;
90 color = <LED_COLOR_ID_GREEN>;
91 gpios = <&gpio2 15 GPIO_ACTIVE_HIGH>;
92 default-state = "on";
93 linux,default-trigger = "heartbeat";
94 };
95
96 led-1 {
97 function = LED_FUNCTION_STATUS;
98 color = <LED_COLOR_ID_RED>;
99 gpios = <&gpio2 16 GPIO_ACTIVE_HIGH>;
100 default-state = "off";
101 };
102 };
103
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100104 pcie0_refclk: pcie0-refclk {
105 compatible = "fixed-clock";
106 #clock-cells = <0>;
107 clock-frequency = <100000000>;
108 };
109
Tim Harvey23956252022-04-13 11:31:09 -0700110 pps {
111 compatible = "pps-gpio";
112 pinctrl-names = "default";
113 pinctrl-0 = <&pinctrl_pps>;
114 gpios = <&gpio1 12 GPIO_ACTIVE_HIGH>;
115 };
116
117 reg_usb2_vbus: regulator-usb2 {
118 pinctrl-names = "default";
119 pinctrl-0 = <&pinctrl_reg_usb2>;
120 compatible = "regulator-fixed";
121 regulator-name = "usb_usb2_vbus";
122 gpio = <&gpio1 6 GPIO_ACTIVE_HIGH>;
123 enable-active-high;
124 regulator-min-microvolt = <5000000>;
125 regulator-max-microvolt = <5000000>;
126 };
127
128 reg_can2_stby: regulator-can2-stby {
129 compatible = "regulator-fixed";
130 pinctrl-names = "default";
131 pinctrl-0 = <&pinctrl_reg_can>;
132 regulator-name = "can2_stby";
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100133 gpio = <&gpio3 19 GPIO_ACTIVE_LOW>;
Tim Harvey23956252022-04-13 11:31:09 -0700134 regulator-min-microvolt = <3300000>;
135 regulator-max-microvolt = <3300000>;
136 };
137
138 reg_wifi_en: regulator-wifi-en {
139 pinctrl-names = "default";
140 pinctrl-0 = <&pinctrl_reg_wifi>;
141 compatible = "regulator-fixed";
142 regulator-name = "wl";
143 gpio = <&gpio3 9 GPIO_ACTIVE_HIGH>;
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100144 startup-delay-us = <70000>;
Tim Harvey23956252022-04-13 11:31:09 -0700145 enable-active-high;
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100146 regulator-min-microvolt = <3300000>;
147 regulator-max-microvolt = <3300000>;
Tim Harvey23956252022-04-13 11:31:09 -0700148 };
149};
150
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100151&A53_0 {
152 cpu-supply = <&reg_arm>;
153};
154
155&A53_1 {
156 cpu-supply = <&reg_arm>;
157};
158
159&A53_2 {
160 cpu-supply = <&reg_arm>;
161};
162
163&A53_3 {
164 cpu-supply = <&reg_arm>;
165};
166
Tim Harvey23956252022-04-13 11:31:09 -0700167/* off-board header */
168&ecspi2 {
169 pinctrl-names = "default";
170 pinctrl-0 = <&pinctrl_spi2>;
171 cs-gpios = <&gpio5 13 GPIO_ACTIVE_LOW>;
172 status = "okay";
173};
174
175&eqos {
176 pinctrl-names = "default";
177 pinctrl-0 = <&pinctrl_eqos>;
178 phy-mode = "rgmii-id";
179 phy-handle = <&ethphy0>;
180 status = "okay";
181
182 mdio {
183 compatible = "snps,dwmac-mdio";
184 #address-cells = <1>;
185 #size-cells = <0>;
186
187 ethphy0: ethernet-phy@0 {
188 compatible = "ethernet-phy-ieee802.3-c22";
189 reg = <0x0>;
190 };
191 };
192};
193
194&fec {
195 pinctrl-names = "default";
196 pinctrl-0 = <&pinctrl_fec>;
197 phy-mode = "rgmii-id";
198 local-mac-address = [00 00 00 00 00 00];
199 status = "okay";
200
201 fixed-link {
202 speed = <1000>;
203 full-duplex;
204 };
205};
206
207&flexcan2 {
208 pinctrl-names = "default";
209 pinctrl-0 = <&pinctrl_flexcan2>;
210 xceiver-supply = <&reg_can2_stby>;
211 status = "okay";
212};
213
214&gpio1 {
215 gpio-line-names =
216 "", "", "", "", "", "", "", "",
217 "", "", "dio0", "", "dio1", "", "", "",
218 "", "", "", "", "", "", "", "",
219 "", "", "", "", "", "", "", "";
220};
221
222&gpio2 {
223 gpio-line-names =
224 "", "", "", "", "", "", "", "",
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100225 "", "", "", "", "", "", "pcie3_wdis#", "",
226 "", "", "pcie2_wdis#", "", "", "", "", "",
Tim Harvey23956252022-04-13 11:31:09 -0700227 "", "", "", "", "", "", "", "";
228};
229
230&gpio3 {
231 gpio-line-names =
232 "m2_gdis#", "", "", "", "", "", "", "m2_rst#",
233 "", "", "", "", "", "", "", "",
234 "m2_off#", "", "", "", "", "", "", "",
235 "", "", "", "", "", "", "", "";
236};
237
238&gpio4 {
239 gpio-line-names =
240 "", "", "", "", "", "", "", "",
241 "", "", "", "", "", "", "", "",
242 "", "", "", "", "m2_wdis#", "", "", "",
243 "", "", "", "", "", "", "", "uart_rs485";
244};
245
246&gpio5 {
247 gpio-line-names =
248 "uart_half", "uart_term", "", "", "", "", "", "",
249 "", "", "", "", "", "", "", "",
250 "", "", "", "", "", "", "", "",
251 "", "", "", "", "", "", "", "";
252};
253
254&i2c1 {
255 clock-frequency = <100000>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800256 pinctrl-names = "default", "gpio";
Tim Harvey23956252022-04-13 11:31:09 -0700257 pinctrl-0 = <&pinctrl_i2c1>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800258 pinctrl-1 = <&pinctrl_i2c1_gpio>;
259 scl-gpios = <&gpio5 14 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
260 sda-gpios = <&gpio5 15 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
Tim Harvey23956252022-04-13 11:31:09 -0700261 status = "okay";
262
263 gsc: gsc@20 {
264 compatible = "gw,gsc";
265 reg = <0x20>;
266 pinctrl-0 = <&pinctrl_gsc>;
267 interrupt-parent = <&gpio4>;
268 interrupts = <20 IRQ_TYPE_EDGE_FALLING>;
269 interrupt-controller;
270 #interrupt-cells = <1>;
271
272 adc {
273 compatible = "gw,gsc-adc";
274 #address-cells = <1>;
275 #size-cells = <0>;
276
277 channel@6 {
278 gw,mode = <0>;
279 reg = <0x06>;
280 label = "temp";
281 };
282
283 channel@8 {
284 gw,mode = <1>;
285 reg = <0x08>;
286 label = "vdd_bat";
287 };
288
289 channel@82 {
290 gw,mode = <2>;
291 reg = <0x82>;
292 label = "vdd_adc1";
293 gw,voltage-divider-ohms = <10000 10000>;
294 };
295
296 channel@84 {
297 gw,mode = <2>;
298 reg = <0x84>;
299 label = "vdd_adc2";
300 gw,voltage-divider-ohms = <10000 10000>;
301 };
302
303 channel@86 {
304 gw,mode = <2>;
305 reg = <0x86>;
306 label = "vdd_vin";
307 gw,voltage-divider-ohms = <22100 1000>;
308 };
309
310 channel@88 {
311 gw,mode = <2>;
312 reg = <0x88>;
313 label = "vdd_3p3";
314 gw,voltage-divider-ohms = <10000 10000>;
315 };
316
317 channel@8c {
318 gw,mode = <2>;
319 reg = <0x8c>;
320 label = "vdd_2p5";
321 gw,voltage-divider-ohms = <10000 10000>;
322 };
323
324 channel@90 {
325 gw,mode = <2>;
326 reg = <0x90>;
327 label = "vdd_soc";
328 };
329
330 channel@92 {
331 gw,mode = <2>;
332 reg = <0x92>;
333 label = "vdd_arm";
334 };
335
336 channel@98 {
337 gw,mode = <2>;
338 reg = <0x98>;
339 label = "vdd_1p8";
340 };
341
342 channel@9a {
343 gw,mode = <2>;
344 reg = <0x9a>;
345 label = "vdd_1p2";
346 };
347
348 channel@9c {
349 gw,mode = <2>;
350 reg = <0x9c>;
351 label = "vdd_dram";
352 };
353
354 channel@a2 {
355 gw,mode = <2>;
356 reg = <0xa2>;
357 label = "vdd_gsc";
358 gw,voltage-divider-ohms = <10000 10000>;
359 };
360 };
361 };
362
363 gpio: gpio@23 {
364 compatible = "nxp,pca9555";
365 reg = <0x23>;
366 gpio-controller;
367 #gpio-cells = <2>;
368 interrupt-parent = <&gsc>;
369 interrupts = <4>;
370 };
371
372 pmic@25 {
373 compatible = "nxp,pca9450c";
374 reg = <0x25>;
375 pinctrl-names = "default";
376 pinctrl-0 = <&pinctrl_pmic>;
377 interrupt-parent = <&gpio3>;
378 interrupts = <7 IRQ_TYPE_LEVEL_LOW>;
379
380 regulators {
381 BUCK1 {
382 regulator-name = "BUCK1";
383 regulator-min-microvolt = <720000>;
384 regulator-max-microvolt = <1000000>;
385 regulator-boot-on;
386 regulator-always-on;
387 regulator-ramp-delay = <3125>;
388 };
389
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100390 reg_arm: BUCK2 {
Tim Harvey23956252022-04-13 11:31:09 -0700391 regulator-name = "BUCK2";
392 regulator-min-microvolt = <720000>;
393 regulator-max-microvolt = <1025000>;
394 regulator-boot-on;
395 regulator-always-on;
396 regulator-ramp-delay = <3125>;
397 nxp,dvs-run-voltage = <950000>;
398 nxp,dvs-standby-voltage = <850000>;
399 };
400
401 BUCK4 {
402 regulator-name = "BUCK4";
403 regulator-min-microvolt = <3000000>;
404 regulator-max-microvolt = <3600000>;
405 regulator-boot-on;
406 regulator-always-on;
407 };
408
409 BUCK5 {
410 regulator-name = "BUCK5";
411 regulator-min-microvolt = <1650000>;
412 regulator-max-microvolt = <1950000>;
413 regulator-boot-on;
414 regulator-always-on;
415 };
416
417 BUCK6 {
418 regulator-name = "BUCK6";
419 regulator-min-microvolt = <1045000>;
420 regulator-max-microvolt = <1155000>;
421 regulator-boot-on;
422 regulator-always-on;
423 };
424
425 LDO1 {
426 regulator-name = "LDO1";
427 regulator-min-microvolt = <1650000>;
428 regulator-max-microvolt = <1950000>;
429 regulator-boot-on;
430 regulator-always-on;
431 };
432
433 LDO3 {
434 regulator-name = "LDO3";
435 regulator-min-microvolt = <1710000>;
436 regulator-max-microvolt = <1890000>;
437 regulator-boot-on;
438 regulator-always-on;
439 };
440
441 LDO5 {
442 regulator-name = "LDO5";
443 regulator-min-microvolt = <1800000>;
444 regulator-max-microvolt = <3300000>;
445 regulator-boot-on;
446 regulator-always-on;
447 };
448 };
449 };
450
451 eeprom@50 {
452 compatible = "atmel,24c02";
453 reg = <0x50>;
454 pagesize = <16>;
455 };
456
457 eeprom@51 {
458 compatible = "atmel,24c02";
459 reg = <0x51>;
460 pagesize = <16>;
461 };
462
463 eeprom@52 {
464 compatible = "atmel,24c02";
465 reg = <0x52>;
466 pagesize = <16>;
467 };
468
469 eeprom@53 {
470 compatible = "atmel,24c02";
471 reg = <0x53>;
472 pagesize = <16>;
473 };
474
475 rtc@68 {
476 compatible = "dallas,ds1672";
477 reg = <0x68>;
478 };
479};
480
481&i2c2 {
482 clock-frequency = <400000>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800483 pinctrl-names = "default", "gpio";
Tim Harvey23956252022-04-13 11:31:09 -0700484 pinctrl-0 = <&pinctrl_i2c2>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800485 pinctrl-1 = <&pinctrl_i2c2_gpio>;
486 scl-gpios = <&gpio5 16 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
487 sda-gpios = <&gpio5 17 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
Tim Harvey23956252022-04-13 11:31:09 -0700488 status = "okay";
489
490 accelerometer@19 {
491 compatible = "st,lis2de12";
492 pinctrl-names = "default";
493 pinctrl-0 = <&pinctrl_accel>;
494 reg = <0x19>;
495 st,drdy-int-pin = <1>;
496 interrupt-parent = <&gpio1>;
497 interrupts = <7 IRQ_TYPE_LEVEL_LOW>;
498 interrupt-names = "INT1";
499 };
500
501 switch: switch@5f {
502 compatible = "microchip,ksz9897";
503 reg = <0x5f>;
504 pinctrl-0 = <&pinctrl_ksz>;
505 interrupt-parent = <&gpio4>;
506 interrupts = <29 IRQ_TYPE_EDGE_FALLING>;
507
508 ports {
509 #address-cells = <1>;
510 #size-cells = <0>;
511
512 lan1: port@0 {
513 reg = <0>;
514 label = "lan1";
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100515 phy-mode = "internal";
Tim Harvey23956252022-04-13 11:31:09 -0700516 local-mac-address = [00 00 00 00 00 00];
Tim Harvey23956252022-04-13 11:31:09 -0700517 };
518
519 lan2: port@1 {
520 reg = <1>;
521 label = "lan2";
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100522 phy-mode = "internal";
Tim Harvey23956252022-04-13 11:31:09 -0700523 local-mac-address = [00 00 00 00 00 00];
Tim Harvey23956252022-04-13 11:31:09 -0700524 };
525
526 lan3: port@2 {
527 reg = <2>;
528 label = "lan3";
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100529 phy-mode = "internal";
Tim Harvey23956252022-04-13 11:31:09 -0700530 local-mac-address = [00 00 00 00 00 00];
Tim Harvey23956252022-04-13 11:31:09 -0700531 };
532
533 lan4: port@3 {
534 reg = <3>;
535 label = "lan4";
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100536 phy-mode = "internal";
Tim Harvey23956252022-04-13 11:31:09 -0700537 local-mac-address = [00 00 00 00 00 00];
Tim Harvey23956252022-04-13 11:31:09 -0700538 };
539
540 lan5: port@4 {
541 reg = <4>;
542 label = "lan5";
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100543 phy-mode = "internal";
Tim Harvey23956252022-04-13 11:31:09 -0700544 local-mac-address = [00 00 00 00 00 00];
Tim Harvey23956252022-04-13 11:31:09 -0700545 };
546
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100547 port@5 {
548 reg = <5>;
Tim Harvey23956252022-04-13 11:31:09 -0700549 label = "cpu";
550 ethernet = <&fec>;
551 phy-mode = "rgmii-id";
552
553 fixed-link {
554 speed = <1000>;
555 full-duplex;
556 };
557 };
558 };
Tim Harvey23956252022-04-13 11:31:09 -0700559 };
560};
561
562/* off-board header */
563&i2c3 {
564 clock-frequency = <400000>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800565 pinctrl-names = "default", "gpio";
Tim Harvey23956252022-04-13 11:31:09 -0700566 pinctrl-0 = <&pinctrl_i2c3>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800567 pinctrl-1 = <&pinctrl_i2c3_gpio>;
568 scl-gpios = <&gpio5 18 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
569 sda-gpios = <&gpio5 19 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
Tim Harvey23956252022-04-13 11:31:09 -0700570 status = "okay";
571};
572
573/* off-board header */
574&i2c4 {
575 clock-frequency = <400000>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800576 pinctrl-names = "default", "gpio";
Tim Harvey23956252022-04-13 11:31:09 -0700577 pinctrl-0 = <&pinctrl_i2c4>;
Tim Harveya4dc8472022-11-11 08:03:06 -0800578 pinctrl-1 = <&pinctrl_i2c4_gpio>;
579 scl-gpios = <&gpio5 20 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
580 sda-gpios = <&gpio5 21 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
Tim Harvey23956252022-04-13 11:31:09 -0700581 status = "okay";
582};
583
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100584&pcie_phy {
585 fsl,refclk-pad-mode = <IMX8_PCIE_REFCLK_PAD_INPUT>;
586 fsl,clkreq-unsupported;
587 clocks = <&pcie0_refclk>;
588 clock-names = "ref";
589 status = "okay";
590};
591
592&pcie {
593 pinctrl-names = "default";
594 pinctrl-0 = <&pinctrl_pcie0>;
595 reset-gpio = <&gpio2 17 GPIO_ACTIVE_LOW>;
596 clocks = <&clk IMX8MP_CLK_HSIO_ROOT>,
597 <&clk IMX8MP_CLK_PCIE_ROOT>,
598 <&clk IMX8MP_CLK_HSIO_AXI>;
599 clock-names = "pcie", "pcie_aux", "pcie_bus";
600 assigned-clocks = <&clk IMX8MP_CLK_PCIE_AUX>;
601 assigned-clock-rates = <10000000>;
602 assigned-clock-parents = <&clk IMX8MP_SYS_PLL2_50M>;
603 status = "okay";
604};
605
Tim Harvey23956252022-04-13 11:31:09 -0700606/* GPS / off-board header */
607&uart1 {
608 pinctrl-names = "default";
609 pinctrl-0 = <&pinctrl_uart1>;
610 status = "okay";
611};
612
613/* RS232 console */
614&uart2 {
615 pinctrl-names = "default";
616 pinctrl-0 = <&pinctrl_uart2>;
617 status = "okay";
618};
619
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100620/* bluetooth HCI */
621&uart3 {
622 pinctrl-names = "default";
623 pinctrl-0 = <&pinctrl_uart3>, <&pinctrl_uart3_gpio>;
624 cts-gpios = <&gpio3 21 GPIO_ACTIVE_LOW>;
625 rts-gpios = <&gpio3 22 GPIO_ACTIVE_LOW>;
626 uart-has-rtscts;
627 status = "okay";
628
629 bluetooth {
630 compatible = "brcm,bcm4330-bt";
631 shutdown-gpios = <&gpio3 8 GPIO_ACTIVE_HIGH>;
632 };
633};
634
Tim Harvey23956252022-04-13 11:31:09 -0700635&uart4 {
636 pinctrl-names = "default";
637 pinctrl-0 = <&pinctrl_uart4>;
638 status = "okay";
639};
640
641/* USB1 - Type C front panel */
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100642&usb3_0 {
Tim Harvey23956252022-04-13 11:31:09 -0700643 pinctrl-names = "default";
644 pinctrl-0 = <&pinctrl_usb1>;
Tim Harvey23956252022-04-13 11:31:09 -0700645 fsl,over-current-active-low;
646 status = "okay";
647};
648
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100649&usb3_phy0 {
Tim Harvey23956252022-04-13 11:31:09 -0700650 status = "okay";
651};
652
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100653&usb_dwc3_0 {
654 /* dual role is implemented but not a full featured OTG */
655 adp-disable;
656 hnp-disable;
657 srp-disable;
658 dr_mode = "otg";
659 usb-role-switch;
660 role-switch-default-mode = "peripheral";
661 status = "okay";
662
663 connector {
664 pinctrl-names = "default";
665 pinctrl-0 = <&pinctrl_usbcon1>;
666 compatible = "gpio-usb-b-connector", "usb-b-connector";
667 type = "micro";
668 label = "Type-C";
669 id-gpios = <&gpio1 10 GPIO_ACTIVE_HIGH>;
670 };
671};
672
Tim Harvey23956252022-04-13 11:31:09 -0700673/* USB2 - USB3.0 Hub */
674&usb3_phy1 {
675 vbus-supply = <&reg_usb2_vbus>;
676 status = "okay";
677};
678
679&usb3_1 {
680 fsl,permanently-attached;
681 fsl,disable-port-power-control;
682 status = "okay";
683};
684
685&usb_dwc3_1 {
686 dr_mode = "host";
687 status = "okay";
688};
689
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100690/* SDIO WiFi */
691&usdhc1 {
692 pinctrl-names = "default", "state_100mhz", "state_200mhz";
693 pinctrl-0 = <&pinctrl_usdhc1>;
694 pinctrl-1 = <&pinctrl_usdhc1_100mhz>;
695 pinctrl-2 = <&pinctrl_usdhc1_200mhz>;
696 bus-width = <4>;
697 non-removable;
698 vmmc-supply = <&reg_wifi_en>;
699 #address-cells = <1>;
700 #size-cells = <0>;
701 status = "okay";
702
703 wifi@0 {
704 compatible = "cypress,cyw4373-fmac";
705 reg = <0>;
706 };
707};
708
Tim Harvey23956252022-04-13 11:31:09 -0700709/* eMMC */
710&usdhc3 {
711 assigned-clocks = <&clk IMX8MP_CLK_USDHC3>;
712 assigned-clock-rates = <400000000>;
713 pinctrl-names = "default", "state_100mhz", "state_200mhz";
714 pinctrl-0 = <&pinctrl_usdhc3>;
715 pinctrl-1 = <&pinctrl_usdhc3_100mhz>;
716 pinctrl-2 = <&pinctrl_usdhc3_200mhz>;
717 bus-width = <8>;
718 non-removable;
719 status = "okay";
720};
721
722&wdog1 {
723 pinctrl-names = "default";
724 pinctrl-0 = <&pinctrl_wdog>;
725 fsl,ext-reset-output;
726 status = "okay";
727};
728
729&iomuxc {
730 pinctrl-names = "default";
731 pinctrl-0 = <&pinctrl_hog>;
732
733 pinctrl_hog: hoggrp {
734 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100735 MX8MP_IOMUXC_GPIO1_IO09__GPIO1_IO09 0x40000040 /* DIO0 */
736 MX8MP_IOMUXC_GPIO1_IO11__GPIO1_IO11 0x40000040 /* DIO1 */
737 MX8MP_IOMUXC_NAND_DQS__GPIO3_IO14 0x40000040 /* M2SKT_OFF# */
738 MX8MP_IOMUXC_SD2_DATA3__GPIO2_IO18 0x40000150 /* PCIE2_WDIS# */
739 MX8MP_IOMUXC_SD2_CMD__GPIO2_IO14 0x40000150 /* PCIE3_WDIS# */
740 MX8MP_IOMUXC_NAND_DATA00__GPIO3_IO06 0x40000040 /* M2SKT_RST# */
741 MX8MP_IOMUXC_SAI1_TXD6__GPIO4_IO18 0x40000150 /* M2SKT_WDIS# */
742 MX8MP_IOMUXC_NAND_ALE__GPIO3_IO00 0x40000150 /* M2SKT_GDIS# */
Tim Harvey23956252022-04-13 11:31:09 -0700743 MX8MP_IOMUXC_SAI3_TXD__GPIO5_IO01 0x40000104 /* UART_TERM */
744 MX8MP_IOMUXC_SAI3_TXFS__GPIO4_IO31 0x40000104 /* UART_RS485 */
745 MX8MP_IOMUXC_SAI3_TXC__GPIO5_IO00 0x40000104 /* UART_HALF */
746 >;
747 };
748
749 pinctrl_accel: accelgrp {
750 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100751 MX8MP_IOMUXC_GPIO1_IO07__GPIO1_IO07 0x150
Tim Harvey23956252022-04-13 11:31:09 -0700752 >;
753 };
754
755 pinctrl_eqos: eqosgrp {
756 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100757 MX8MP_IOMUXC_ENET_MDC__ENET_QOS_MDC 0x2
758 MX8MP_IOMUXC_ENET_MDIO__ENET_QOS_MDIO 0x2
759 MX8MP_IOMUXC_ENET_RD0__ENET_QOS_RGMII_RD0 0x90
760 MX8MP_IOMUXC_ENET_RD1__ENET_QOS_RGMII_RD1 0x90
761 MX8MP_IOMUXC_ENET_RD2__ENET_QOS_RGMII_RD2 0x90
762 MX8MP_IOMUXC_ENET_RD3__ENET_QOS_RGMII_RD3 0x90
763 MX8MP_IOMUXC_ENET_RXC__CCM_ENET_QOS_CLOCK_GENERATE_RX_CLK 0x90
764 MX8MP_IOMUXC_ENET_RX_CTL__ENET_QOS_RGMII_RX_CTL 0x90
765 MX8MP_IOMUXC_ENET_TD0__ENET_QOS_RGMII_TD0 0x16
766 MX8MP_IOMUXC_ENET_TD1__ENET_QOS_RGMII_TD1 0x16
767 MX8MP_IOMUXC_ENET_TD2__ENET_QOS_RGMII_TD2 0x16
768 MX8MP_IOMUXC_ENET_TD3__ENET_QOS_RGMII_TD3 0x16
769 MX8MP_IOMUXC_ENET_TX_CTL__ENET_QOS_RGMII_TX_CTL 0x16
770 MX8MP_IOMUXC_ENET_TXC__CCM_ENET_QOS_CLOCK_GENERATE_TX_CLK 0x16
771 MX8MP_IOMUXC_SAI3_RXD__GPIO4_IO30 0x140 /* RST# */
772 MX8MP_IOMUXC_SAI3_RXFS__GPIO4_IO28 0x150 /* IRQ# */
Tim Harvey23956252022-04-13 11:31:09 -0700773 >;
774 };
775
776 pinctrl_fec: fecgrp {
777 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100778 MX8MP_IOMUXC_SAI1_RXD4__ENET1_RGMII_RD0 0x90
779 MX8MP_IOMUXC_SAI1_RXD5__ENET1_RGMII_RD1 0x90
780 MX8MP_IOMUXC_SAI1_RXD6__ENET1_RGMII_RD2 0x90
781 MX8MP_IOMUXC_SAI1_RXD7__ENET1_RGMII_RD3 0x90
782 MX8MP_IOMUXC_SAI1_TXC__ENET1_RGMII_RXC 0x90
783 MX8MP_IOMUXC_SAI1_TXFS__ENET1_RGMII_RX_CTL 0x90
784 MX8MP_IOMUXC_SAI1_TXD0__ENET1_RGMII_TD0 0x16
785 MX8MP_IOMUXC_SAI1_TXD1__ENET1_RGMII_TD1 0x16
786 MX8MP_IOMUXC_SAI1_TXD2__ENET1_RGMII_TD2 0x16
787 MX8MP_IOMUXC_SAI1_TXD3__ENET1_RGMII_TD3 0x16
788 MX8MP_IOMUXC_SAI1_TXD4__ENET1_RGMII_TX_CTL 0x16
789 MX8MP_IOMUXC_SAI1_TXD5__ENET1_RGMII_TXC 0x16
790 MX8MP_IOMUXC_SAI1_RXFS__ENET1_1588_EVENT0_IN 0x140
791 MX8MP_IOMUXC_SAI1_RXC__ENET1_1588_EVENT0_OUT 0x140
Tim Harvey23956252022-04-13 11:31:09 -0700792 >;
793 };
794
795 pinctrl_flexcan2: flexcan2grp {
796 fsl,pins = <
797 MX8MP_IOMUXC_SAI5_RXD3__CAN2_TX 0x154
798 MX8MP_IOMUXC_SAI5_MCLK__CAN2_RX 0x154
799 >;
800 };
801
802 pinctrl_gsc: gscgrp {
803 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100804 MX8MP_IOMUXC_SAI1_MCLK__GPIO4_IO20 0x150
Tim Harvey23956252022-04-13 11:31:09 -0700805 >;
806 };
807
808 pinctrl_i2c1: i2c1grp {
809 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100810 MX8MP_IOMUXC_I2C1_SCL__I2C1_SCL 0x400001c2
811 MX8MP_IOMUXC_I2C1_SDA__I2C1_SDA 0x400001c2
Tim Harvey23956252022-04-13 11:31:09 -0700812 >;
813 };
814
Tim Harveya4dc8472022-11-11 08:03:06 -0800815 pinctrl_i2c1_gpio: i2c1gpiogrp {
816 fsl,pins = <
817 MX8MP_IOMUXC_I2C1_SCL__GPIO5_IO14 0x400001c2
818 MX8MP_IOMUXC_I2C1_SDA__GPIO5_IO15 0x400001c2
819 >;
820 };
821
Tim Harvey23956252022-04-13 11:31:09 -0700822 pinctrl_i2c2: i2c2grp {
823 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100824 MX8MP_IOMUXC_I2C2_SCL__I2C2_SCL 0x400001c2
825 MX8MP_IOMUXC_I2C2_SDA__I2C2_SDA 0x400001c2
Tim Harvey23956252022-04-13 11:31:09 -0700826 >;
827 };
828
Tim Harveya4dc8472022-11-11 08:03:06 -0800829 pinctrl_i2c2_gpio: i2c2gpiogrp {
830 fsl,pins = <
831 MX8MP_IOMUXC_I2C2_SCL__GPIO5_IO16 0x400001c3
832 MX8MP_IOMUXC_I2C2_SDA__GPIO5_IO17 0x400001c3
833 >;
834 };
835
Tim Harvey23956252022-04-13 11:31:09 -0700836 pinctrl_i2c3: i2c3grp {
837 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100838 MX8MP_IOMUXC_I2C3_SCL__I2C3_SCL 0x400001c2
839 MX8MP_IOMUXC_I2C3_SDA__I2C3_SDA 0x400001c2
Tim Harvey23956252022-04-13 11:31:09 -0700840 >;
841 };
842
Tim Harveya4dc8472022-11-11 08:03:06 -0800843 pinctrl_i2c3_gpio: i2c3gpiogrp {
844 fsl,pins = <
845 MX8MP_IOMUXC_I2C3_SCL__GPIO5_IO18 0x400001c3
846 MX8MP_IOMUXC_I2C3_SDA__GPIO5_IO19 0x400001c3
847 >;
848 };
849
Tim Harvey23956252022-04-13 11:31:09 -0700850 pinctrl_i2c4: i2c4grp {
851 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100852 MX8MP_IOMUXC_I2C4_SCL__I2C4_SCL 0x400001c2
853 MX8MP_IOMUXC_I2C4_SDA__I2C4_SDA 0x400001c2
Tim Harvey23956252022-04-13 11:31:09 -0700854 >;
855 };
856
Tim Harveya4dc8472022-11-11 08:03:06 -0800857 pinctrl_i2c4_gpio: i2c4gpiogrp {
858 fsl,pins = <
859 MX8MP_IOMUXC_I2C4_SCL__GPIO5_IO20 0x400001c3
860 MX8MP_IOMUXC_I2C4_SDA__GPIO5_IO21 0x400001c3
861 >;
862 };
863
Tim Harvey23956252022-04-13 11:31:09 -0700864 pinctrl_ksz: kszgrp {
865 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100866 MX8MP_IOMUXC_SAI3_RXC__GPIO4_IO29 0x150 /* IRQ# */
867 MX8MP_IOMUXC_SAI3_MCLK__GPIO5_IO02 0x140 /* RST# */
Tim Harvey23956252022-04-13 11:31:09 -0700868 >;
869 };
870
871 pinctrl_gpio_leds: ledgrp {
872 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100873 MX8MP_IOMUXC_SD2_DATA0__GPIO2_IO15 0x10
874 MX8MP_IOMUXC_SD2_DATA1__GPIO2_IO16 0x10
875 >;
876 };
877
878 pinctrl_pcie0: pciegrp {
879 fsl,pins = <
880 MX8MP_IOMUXC_SD2_DATA2__GPIO2_IO17 0x110
Tim Harvey23956252022-04-13 11:31:09 -0700881 >;
882 };
883
884 pinctrl_pmic: pmicgrp {
885 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100886 MX8MP_IOMUXC_NAND_DATA01__GPIO3_IO07 0x140
Tim Harvey23956252022-04-13 11:31:09 -0700887 >;
888 };
889
890 pinctrl_pps: ppsgrp {
891 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100892 MX8MP_IOMUXC_GPIO1_IO12__GPIO1_IO12 0x140
Tim Harvey23956252022-04-13 11:31:09 -0700893 >;
894 };
895
896 pinctrl_reg_can: regcangrp {
897 fsl,pins = <
898 MX8MP_IOMUXC_SAI5_RXFS__GPIO3_IO19 0x154
899 >;
900 };
901
902 pinctrl_reg_usb2: regusb2grp {
903 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100904 MX8MP_IOMUXC_GPIO1_IO06__GPIO1_IO06 0x140
Tim Harvey23956252022-04-13 11:31:09 -0700905 >;
906 };
907
908 pinctrl_reg_wifi: regwifigrp {
909 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100910 MX8MP_IOMUXC_NAND_DATA03__GPIO3_IO09 0x110
Tim Harvey23956252022-04-13 11:31:09 -0700911 >;
912 };
913
914 pinctrl_sai2: sai2grp {
915 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100916 MX8MP_IOMUXC_SAI2_TXFS__AUDIOMIX_SAI2_TX_SYNC 0xd6
917 MX8MP_IOMUXC_SAI2_TXD0__AUDIOMIX_SAI2_TX_DATA00 0xd6
918 MX8MP_IOMUXC_SAI2_TXC__AUDIOMIX_SAI2_TX_BCLK 0xd6
919 MX8MP_IOMUXC_SAI2_MCLK__AUDIOMIX_SAI2_MCLK 0xd6
Tim Harvey23956252022-04-13 11:31:09 -0700920 >;
921 };
922
923 pinctrl_spi2: spi2grp {
924 fsl,pins = <
925 MX8MP_IOMUXC_ECSPI2_SCLK__ECSPI2_SCLK 0x82
926 MX8MP_IOMUXC_ECSPI2_MOSI__ECSPI2_MOSI 0x82
927 MX8MP_IOMUXC_ECSPI2_MISO__ECSPI2_MISO 0x82
928 MX8MP_IOMUXC_ECSPI2_SS0__GPIO5_IO13 0x140
929 >;
930 };
931
932 pinctrl_uart1: uart1grp {
933 fsl,pins = <
934 MX8MP_IOMUXC_UART1_RXD__UART1_DCE_RX 0x140
935 MX8MP_IOMUXC_UART1_TXD__UART1_DCE_TX 0x140
936 >;
937 };
938
939 pinctrl_uart2: uart2grp {
940 fsl,pins = <
941 MX8MP_IOMUXC_UART2_RXD__UART2_DCE_RX 0x140
942 MX8MP_IOMUXC_UART2_TXD__UART2_DCE_TX 0x140
943 >;
944 };
945
Marcel Ziswilere0caa842022-07-21 15:44:32 +0200946 pinctrl_uart3: uart3grp {
947 fsl,pins = <
948 MX8MP_IOMUXC_UART3_RXD__UART3_DCE_RX 0x140
949 MX8MP_IOMUXC_UART3_TXD__UART3_DCE_TX 0x140
950 MX8MP_IOMUXC_SAI5_RXD0__GPIO3_IO21 0x140
951 MX8MP_IOMUXC_SAI5_RXD1__GPIO3_IO22 0x140
952 >;
953 };
954
955 pinctrl_uart3_gpio: uart3gpiogrp {
956 fsl,pins = <
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100957 MX8MP_IOMUXC_NAND_DATA02__GPIO3_IO08 0x110
Marcel Ziswilere0caa842022-07-21 15:44:32 +0200958 >;
959 };
960
Tim Harvey23956252022-04-13 11:31:09 -0700961 pinctrl_uart4: uart4grp {
962 fsl,pins = <
963 MX8MP_IOMUXC_UART4_RXD__UART4_DCE_RX 0x140
964 MX8MP_IOMUXC_UART4_TXD__UART4_DCE_TX 0x140
965 >;
966 };
967
968 pinctrl_usb1: usb1grp {
969 fsl,pins = <
970 MX8MP_IOMUXC_GPIO1_IO13__USB1_OTG_OC 0x140
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100971 >;
972 };
973
974 pinctrl_usbcon1: usb1congrp {
975 fsl,pins = <
976 MX8MP_IOMUXC_GPIO1_IO10__GPIO1_IO10 0x140
Tim Harvey23956252022-04-13 11:31:09 -0700977 >;
978 };
979
980 pinctrl_usdhc1: usdhc1grp {
981 fsl,pins = <
982 MX8MP_IOMUXC_SD1_CLK__USDHC1_CLK 0x190
983 MX8MP_IOMUXC_SD1_CMD__USDHC1_CMD 0x1d0
984 MX8MP_IOMUXC_SD1_DATA0__USDHC1_DATA0 0x1d0
985 MX8MP_IOMUXC_SD1_DATA1__USDHC1_DATA1 0x1d0
986 MX8MP_IOMUXC_SD1_DATA2__USDHC1_DATA2 0x1d0
987 MX8MP_IOMUXC_SD1_DATA3__USDHC1_DATA3 0x1d0
988 >;
989 };
990
Marcel Ziswiler0b42fdc2022-11-07 22:22:39 +0100991 pinctrl_usdhc1_100mhz: usdhc1-100mhzgrp {
992 fsl,pins = <
993 MX8MP_IOMUXC_SD1_CLK__USDHC1_CLK 0x194
994 MX8MP_IOMUXC_SD1_CMD__USDHC1_CMD 0x1d4
995 MX8MP_IOMUXC_SD1_DATA0__USDHC1_DATA0 0x1d4
996 MX8MP_IOMUXC_SD1_DATA1__USDHC1_DATA1 0x1d4
997 MX8MP_IOMUXC_SD1_DATA2__USDHC1_DATA2 0x1d4
998 MX8MP_IOMUXC_SD1_DATA3__USDHC1_DATA3 0x1d4
999 >;
1000 };
1001
1002 pinctrl_usdhc1_200mhz: usdhc1-200mhzgrp {
1003 fsl,pins = <
1004 MX8MP_IOMUXC_SD1_CLK__USDHC1_CLK 0x196
1005 MX8MP_IOMUXC_SD1_CMD__USDHC1_CMD 0x1d6
1006 MX8MP_IOMUXC_SD1_DATA0__USDHC1_DATA0 0x1d6
1007 MX8MP_IOMUXC_SD1_DATA1__USDHC1_DATA1 0x1d6
1008 MX8MP_IOMUXC_SD1_DATA2__USDHC1_DATA2 0x1d6
1009 MX8MP_IOMUXC_SD1_DATA3__USDHC1_DATA3 0x1d6
1010 >;
1011 };
1012
Tim Harvey23956252022-04-13 11:31:09 -07001013 pinctrl_usdhc3: usdhc3grp {
1014 fsl,pins = <
1015 MX8MP_IOMUXC_NAND_WE_B__USDHC3_CLK 0x190
1016 MX8MP_IOMUXC_NAND_WP_B__USDHC3_CMD 0x1d0
1017 MX8MP_IOMUXC_NAND_DATA04__USDHC3_DATA0 0x1d0
1018 MX8MP_IOMUXC_NAND_DATA05__USDHC3_DATA1 0x1d0
1019 MX8MP_IOMUXC_NAND_DATA06__USDHC3_DATA2 0x1d0
1020 MX8MP_IOMUXC_NAND_DATA07__USDHC3_DATA3 0x1d0
1021 MX8MP_IOMUXC_NAND_RE_B__USDHC3_DATA4 0x1d0
1022 MX8MP_IOMUXC_NAND_CE2_B__USDHC3_DATA5 0x1d0
1023 MX8MP_IOMUXC_NAND_CE3_B__USDHC3_DATA6 0x1d0
1024 MX8MP_IOMUXC_NAND_CLE__USDHC3_DATA7 0x1d0
1025 MX8MP_IOMUXC_NAND_CE1_B__USDHC3_STROBE 0x190
1026 >;
1027 };
1028
1029 pinctrl_usdhc3_100mhz: usdhc3-100mhzgrp {
1030 fsl,pins = <
1031 MX8MP_IOMUXC_NAND_WE_B__USDHC3_CLK 0x194
1032 MX8MP_IOMUXC_NAND_WP_B__USDHC3_CMD 0x1d4
1033 MX8MP_IOMUXC_NAND_DATA04__USDHC3_DATA0 0x1d4
1034 MX8MP_IOMUXC_NAND_DATA05__USDHC3_DATA1 0x1d4
1035 MX8MP_IOMUXC_NAND_DATA06__USDHC3_DATA2 0x1d4
1036 MX8MP_IOMUXC_NAND_DATA07__USDHC3_DATA3 0x1d4
1037 MX8MP_IOMUXC_NAND_RE_B__USDHC3_DATA4 0x1d4
1038 MX8MP_IOMUXC_NAND_CE2_B__USDHC3_DATA5 0x1d4
1039 MX8MP_IOMUXC_NAND_CE3_B__USDHC3_DATA6 0x1d4
1040 MX8MP_IOMUXC_NAND_CLE__USDHC3_DATA7 0x1d4
1041 MX8MP_IOMUXC_NAND_CE1_B__USDHC3_STROBE 0x194
1042 >;
1043 };
1044
1045 pinctrl_usdhc3_200mhz: usdhc3-200mhzgrp {
1046 fsl,pins = <
1047 MX8MP_IOMUXC_NAND_WE_B__USDHC3_CLK 0x196
1048 MX8MP_IOMUXC_NAND_WP_B__USDHC3_CMD 0x1d6
1049 MX8MP_IOMUXC_NAND_DATA04__USDHC3_DATA0 0x1d6
1050 MX8MP_IOMUXC_NAND_DATA05__USDHC3_DATA1 0x1d6
1051 MX8MP_IOMUXC_NAND_DATA06__USDHC3_DATA2 0x1d6
1052 MX8MP_IOMUXC_NAND_DATA07__USDHC3_DATA3 0x1d6
1053 MX8MP_IOMUXC_NAND_RE_B__USDHC3_DATA4 0x1d6
1054 MX8MP_IOMUXC_NAND_CE2_B__USDHC3_DATA5 0x1d6
1055 MX8MP_IOMUXC_NAND_CE3_B__USDHC3_DATA6 0x1d6
1056 MX8MP_IOMUXC_NAND_CLE__USDHC3_DATA7 0x1d6
1057 MX8MP_IOMUXC_NAND_CE1_B__USDHC3_STROBE 0x196
1058 >;
1059 };
1060
1061 pinctrl_wdog: wdoggrp {
1062 fsl,pins = <
1063 MX8MP_IOMUXC_GPIO1_IO02__WDOG1_WDOG_B 0x166
1064 >;
1065 };
1066};