blob: 0b123a84018b2978291ccff845332d55022c7c75 [file] [log] [blame]
Marek Vasutd7f72b62022-04-08 02:15:01 +02001// SPDX-License-Identifier: GPL-2.0+ OR MIT
2/*
3 * Copyright 2021-2022 Marek Vasut <marex@denx.de>
4 */
5
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +02006/dts-v1/;
7
8#include "imx8mm-verdin.dtsi"
Marek Vasutd7f72b62022-04-08 02:15:01 +02009
10/ {
11 model = "MENLO MX8MM EMBEDDED DEVICE";
12 compatible = "menlo,mx8menlo",
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +020013 "toradex,verdin-imx8mm-nonwifi",
Marek Vasutd7f72b62022-04-08 02:15:01 +020014 "toradex,verdin-imx8mm",
15 "fsl,imx8mm";
16
17 /delete-node/ gpio-keys;
18
19 leds {
20 compatible = "gpio-leds";
21 pinctrl-names = "default";
22 pinctrl-0 = <&pinctrl_led>;
23
Marcel Ziswilerdbd5ca22022-11-07 22:22:41 +010024 led-1 {
Marek Vasutd7f72b62022-04-08 02:15:01 +020025 label = "TestLed601";
26 gpios = <&gpio4 18 GPIO_ACTIVE_HIGH>;
27 linux,default-trigger = "mmc0";
28 };
29
Marcel Ziswilerdbd5ca22022-11-07 22:22:41 +010030 led-2 {
Marek Vasutd7f72b62022-04-08 02:15:01 +020031 label = "TestLed602";
32 gpios = <&gpio4 10 GPIO_ACTIVE_HIGH>;
33 linux,default-trigger = "heartbeat";
34 };
35 };
36
37 beeper {
38 compatible = "gpio-beeper";
39 pinctrl-names = "default";
40 pinctrl-0 = <&pinctrl_beeper>;
41 gpios = <&gpio5 3 GPIO_ACTIVE_HIGH>;
42 };
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +020043
44 /* Fixed clock dedicated to SPI CAN on carrier board */
45 clk_xtal20: clk-xtal20 {
46 compatible = "fixed-clock";
47 #clock-cells = <0>;
48 clock-frequency = <20000000>;
49 };
Marek Vasutd7f72b62022-04-08 02:15:01 +020050};
51
52&ecspi1 {
53 #address-cells = <1>;
54 #size-cells = <0>;
55 pinctrl-names = "default";
56 pinctrl-0 = <&pinctrl_ecspi1>;
57 cs-gpios = <&gpio5 9 GPIO_ACTIVE_LOW>;
58 status = "okay";
59
60 /* CAN controller on the baseboard */
61 canfd: can@0 {
62 compatible = "microchip,mcp2518fd";
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +020063 clocks = <&clk_xtal20>;
Marek Vasutd7f72b62022-04-08 02:15:01 +020064 interrupt-parent = <&gpio1>;
65 interrupts = <8 IRQ_TYPE_EDGE_FALLING>;
66 reg = <0>;
67 spi-max-frequency = <2000000>;
Marek Vasutd7f72b62022-04-08 02:15:01 +020068 };
69
70};
71
72&ecspi2 {
73 pinctrl-0 = <&pinctrl_ecspi2 &pinctrl_gpio1>;
74 cs-gpios = <&gpio5 13 GPIO_ACTIVE_LOW>, <&gpio3 4 GPIO_ACTIVE_LOW>;
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +020075 status = "okay";
76
77 spidev@0 {
78 compatible = "menlo,m53cpld";
79 reg = <0>;
80 spi-max-frequency = <25000000>;
81 };
82
83 spidev@1 {
84 compatible = "menlo,m53cpld";
85 reg = <1>;
86 spi-max-frequency = <25000000>;
87 };
88
Marek Vasutd7f72b62022-04-08 02:15:01 +020089};
90
91&ethphy0 {
92 max-speed = <100>;
93};
94
95&fec1 {
96 status = "okay";
97};
98
99&flexspi {
100 status = "okay";
101
102 flash@0 {
103 reg = <0>;
104 #address-cells = <1>;
105 #size-cells = <1>;
106 compatible = "jedec,spi-nor";
107 spi-max-frequency = <66000000>;
108 spi-rx-bus-width = <4>;
109 spi-tx-bus-width = <4>;
110 };
111};
112
113&gpio1 {
114 gpio-line-names =
115 "", "", "", "",
116 "", "", "", "",
117 "", "", "", "",
118 "", "", "", "",
119 "", "", "", "",
120 "", "", "", "",
121 "", "", "", "",
122 "", "", "", "";
123};
124
125&gpio2 {
126 gpio-line-names =
127 "", "", "", "",
128 "", "", "", "",
129 "", "", "", "",
130 "", "", "", "",
131 "", "", "", "",
132 "", "", "", "",
133 "", "", "", "",
134 "", "", "", "";
135};
136
137&gpio3 {
138 gpio-line-names =
139 "", "", "", "",
140 "", "", "", "",
141 "", "", "", "",
142 "", "", "", "",
143 "", "", "", "",
144 "", "", "DISP_reset", "KBD_intI",
145 "", "", "", "",
146 "", "", "", "";
147};
148
149&gpio4 {
150 /*
151 * CPLD_D[n] is ARM_CPLD[n] in schematic
152 * CPLD_int is SA_INTERRUPT in schematic
153 * CPLD_reset is RESET_SOFT in schematic
154 */
155 gpio-line-names =
Marcel Ziswilerdbd5ca22022-11-07 22:22:41 +0100156 "CPLD_D[6]", "CPLD_int", "CPLD_reset", "",
157 "", "CPLD_D[7]", "", "",
158 "", "", "", "CPLD_D[5]",
159 "CPLD_D[4]", "CPLD_D[3]", "CPLD_D[2]", "CPLD_D[1]",
160 "CPLD_D[0]", "", "", "",
Marek Vasutd7f72b62022-04-08 02:15:01 +0200161 "", "", "", "",
162 "", "", "", "KBD_intK",
163 "", "", "", "";
164};
165
166&gpio5 {
167 gpio-line-names =
168 "", "", "", "",
169 "", "", "", "",
170 "", "", "", "",
171 "", "", "", "",
172 "", "", "", "",
173 "", "", "", "",
174 "", "", "", "",
175 "", "", "", "";
176};
177
178&gpio_expander_21 {
179 status = "okay";
180};
181
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +0200182&hwmon {
183 status = "okay";
Marek Vasutd7f72b62022-04-08 02:15:01 +0200184};
185
186&i2c3 {
Marek Vasutd7f72b62022-04-08 02:15:01 +0200187 status = "okay";
188};
189
190&i2c4 {
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +0200191 /* None of this is present on the SoM. */
Marek Vasutd7f72b62022-04-08 02:15:01 +0200192 /delete-node/ bridge@2c;
Marek Vasutd7f72b62022-04-08 02:15:01 +0200193 /delete-node/ hdmi@48;
194 /delete-node/ touch@4a;
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +0200195 /delete-node/ sensor@4f;
Marek Vasutd7f72b62022-04-08 02:15:01 +0200196 /delete-node/ eeprom@50;
197 /delete-node/ eeprom@57;
198};
199
200&iomuxc {
201 pinctrl-0 = <&pinctrl_gpio7>, <&pinctrl_gpio_hog1>,
202 <&pinctrl_gpio_hog2>, <&pinctrl_gpio_hog3>;
203
204 pinctrl_beeper: beepergrp {
205 fsl,pins = <
206 MX8MM_IOMUXC_SPDIF_TX_GPIO5_IO3 0x1c4
207 >;
208 };
209
210 pinctrl_ecspi1: ecspi1grp {
211 fsl,pins = <
212 MX8MM_IOMUXC_ECSPI1_SCLK_ECSPI1_SCLK 0x4
213 MX8MM_IOMUXC_ECSPI1_MOSI_ECSPI1_MOSI 0x4
214 MX8MM_IOMUXC_ECSPI1_MISO_ECSPI1_MISO 0x1c4
215 MX8MM_IOMUXC_ECSPI1_SS0_GPIO5_IO9 0x1c4
216 >;
217 };
218
219 pinctrl_led: ledgrp {
220 fsl,pins = <
221 MX8MM_IOMUXC_SAI1_TXD6_GPIO4_IO18 0x1c4
222 MX8MM_IOMUXC_SAI1_TXFS_GPIO4_IO10 0x1c4
223 >;
224 };
225
226 pinctrl_uart4_rts: uart4rtsgrp {
227 fsl,pins = <
228 /* SODIMM 222 */
229 MX8MM_IOMUXC_GPIO1_IO09_GPIO1_IO9 0x184
230 >;
231 };
232};
233
234&pinctrl_gpio1 {
235 fsl,pins = <
236 /* SODIMM 206 */
237 MX8MM_IOMUXC_NAND_CE3_B_GPIO3_IO4 0x1c4
238 >;
239};
240
241&pinctrl_gpio_hog1 {
242 fsl,pins = <
243 /* SODIMM 88 */
244 MX8MM_IOMUXC_SAI1_MCLK_GPIO4_IO20 0x1c4
245 /* CPLD_int */
246 MX8MM_IOMUXC_SAI1_RXC_GPIO4_IO1 0x1c4
247 /* CPLD_reset */
248 MX8MM_IOMUXC_SAI1_RXD0_GPIO4_IO2 0x1c4
249 /* SODIMM 94 */
250 MX8MM_IOMUXC_SAI1_RXD1_GPIO4_IO3 0x1c4
251 /* SODIMM 96 */
252 MX8MM_IOMUXC_SAI1_RXD2_GPIO4_IO4 0x1c4
253 /* CPLD_D[7] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200254 MX8MM_IOMUXC_SAI1_RXD3_GPIO4_IO5 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200255 /* CPLD_D[6] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200256 MX8MM_IOMUXC_SAI1_RXFS_GPIO4_IO0 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200257 /* CPLD_D[5] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200258 MX8MM_IOMUXC_SAI1_TXC_GPIO4_IO11 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200259 /* CPLD_D[4] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200260 MX8MM_IOMUXC_SAI1_TXD0_GPIO4_IO12 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200261 /* CPLD_D[3] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200262 MX8MM_IOMUXC_SAI1_TXD1_GPIO4_IO13 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200263 /* CPLD_D[2] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200264 MX8MM_IOMUXC_SAI1_TXD2_GPIO4_IO14 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200265 /* CPLD_D[1] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200266 MX8MM_IOMUXC_SAI1_TXD3_GPIO4_IO15 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200267 /* CPLD_D[0] */
Marcel Ziswilercd9a3e32023-07-11 11:09:14 +0200268 MX8MM_IOMUXC_SAI1_TXD4_GPIO4_IO16 0x184
Marek Vasutd7f72b62022-04-08 02:15:01 +0200269 /* KBD_intK */
270 MX8MM_IOMUXC_SAI2_MCLK_GPIO4_IO27 0x1c4
271 /* DISP_reset */
272 MX8MM_IOMUXC_SAI5_RXD1_GPIO3_IO22 0x1c4
273 /* KBD_intI */
274 MX8MM_IOMUXC_SAI5_RXD2_GPIO3_IO23 0x1c4
275 /* SODIMM 46 */
276 MX8MM_IOMUXC_SAI5_RXD3_GPIO3_IO24 0x1c4
277 >;
278};
279
280&pinctrl_uart1 {
281 fsl,pins = <
282 /* SODIMM 149 */
283 MX8MM_IOMUXC_SAI2_RXFS_UART1_DCE_TX 0x1c4
284 /* SODIMM 147 */
285 MX8MM_IOMUXC_SAI2_RXC_UART1_DCE_RX 0x1c4
286 /* SODIMM 210 */
287 MX8MM_IOMUXC_UART3_RXD_UART1_DTE_RTS_B 0x1c4
288 /* SODIMM 212 */
289 MX8MM_IOMUXC_UART3_TXD_UART1_DTE_CTS_B 0x1c4
290 >;
291};
292
293&reg_usb_otg1_vbus {
294 /delete-property/ enable-active-high;
295 gpio = <&gpio1 12 GPIO_ACTIVE_LOW>;
296};
297
298&reg_usb_otg2_vbus {
299 /delete-property/ enable-active-high;
300 gpio = <&gpio1 14 GPIO_ACTIVE_LOW>;
301};
302
303&sai2 {
304 status = "disabled";
305};
306
307&uart1 {
308 uart-has-rtscts;
309 status = "okay";
310};
311
312&uart2 {
Marek Vasutd7f72b62022-04-08 02:15:01 +0200313 status = "okay";
314};
315
316&uart4 {
317 pinctrl-0 = <&pinctrl_uart4 &pinctrl_uart4_rts>;
318 linux,rs485-enabled-at-boot-time;
319 rts-gpios = <&gpio1 9 GPIO_ACTIVE_HIGH>;
320 status = "okay";
321};
322
323&usbotg1 {
Marcel Ziswiler24a7a3c2022-07-21 15:27:40 +0200324 dr_mode = "peripheral";
Marek Vasutd7f72b62022-04-08 02:15:01 +0200325 status = "okay";
326};
327
328&usbotg2 {
329 dr_mode = "host";
330 status = "okay";
331};
332
333&usdhc2 {
334 status = "okay";
335};