blob: 8daef65d5bb3542a0d223d80a198dc26db2af336 [file] [log] [blame]
Soeren Mochb184dc02019-03-01 13:10:54 +01001// SPDX-License-Identifier: GPL-2.0+ OR MIT
2//
Marcel Ziswilerd0399a42022-07-21 15:27:26 +02003// Copyright 2014 Soeren Moch <smoch@web.de>
Soeren Mochb184dc02019-03-01 13:10:54 +01004
5/dts-v1/;
6
7#include "imx6q.dtsi"
8#include <dt-bindings/gpio/gpio.h>
9#include <dt-bindings/input/input.h>
10
11/ {
12 model = "TBS2910 Matrix ARM mini PC";
13 compatible = "tbs,imx6q-tbs2910", "fsl,imx6q";
14
15 chosen {
16 stdout-path = &uart1;
17 };
18
19 aliases {
20 mmc0 = &usdhc2;
21 mmc1 = &usdhc3;
22 mmc2 = &usdhc4;
Marcel Ziswilerd0399a42022-07-21 15:27:26 +020023 /delete-property/ mmc3;
Soeren Mochb184dc02019-03-01 13:10:54 +010024 };
25
26 memory@10000000 {
Soeren Mochdc6c8fb2019-10-11 00:59:48 +020027 device_type = "memory";
Soeren Mochb184dc02019-03-01 13:10:54 +010028 reg = <0x10000000 0x80000000>;
29 };
30
31 fan {
32 compatible = "gpio-fan";
33 pinctrl-names = "default";
34 pinctrl-0 = <&pinctrl_gpio_fan>;
35 gpios = <&gpio3 28 GPIO_ACTIVE_HIGH>;
36 gpio-fan,speed-map = <0 0
37 3000 1>;
38 };
39
40 ir_recv {
41 compatible = "gpio-ir-receiver";
42 gpios = <&gpio3 18 GPIO_ACTIVE_LOW>;
43 pinctrl-names = "default";
44 pinctrl-0 = <&pinctrl_ir>;
45 };
46
47 leds {
48 compatible = "gpio-leds";
49 pinctrl-names = "default";
50 pinctrl-0 = <&pinctrl_gpio_leds>;
51
52 blue {
53 label = "blue_status_led";
54 gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>;
55 default-state = "keep";
56 };
57 };
58
59 reg_2p5v: regulator-2p5v {
60 compatible = "regulator-fixed";
61 regulator-name = "2P5V";
62 regulator-min-microvolt = <2500000>;
63 regulator-max-microvolt = <2500000>;
64 };
65
66 reg_3p3v: regulator-3p3v {
67 compatible = "regulator-fixed";
68 regulator-name = "3P3V";
69 regulator-min-microvolt = <3300000>;
70 regulator-max-microvolt = <3300000>;
71 };
72
73 reg_5p0v: regulator-5p0v {
74 compatible = "regulator-fixed";
75 regulator-name = "5P0V";
76 regulator-min-microvolt = <5000000>;
77 regulator-max-microvolt = <5000000>;
78 };
79
80 sound-sgtl5000 {
81 audio-codec = <&sgtl5000>;
82 audio-routing =
83 "MIC_IN", "Mic Jack",
84 "Mic Jack", "Mic Bias",
85 "Headphone Jack", "HP_OUT";
86 compatible = "fsl,imx-audio-sgtl5000";
87 model = "On-board Codec";
88 mux-ext-port = <3>;
89 mux-int-port = <1>;
90 ssi-controller = <&ssi1>;
91 };
92
93 sound-spdif {
94 compatible = "fsl,imx-audio-spdif";
95 model = "On-board SPDIF";
96 spdif-controller = <&spdif>;
97 spdif-out;
98 };
99};
100
101&audmux {
102 status = "okay";
103};
104
105&fec {
106 pinctrl-names = "default";
107 pinctrl-0 = <&pinctrl_enet>;
Soeren Mochdc6c8fb2019-10-11 00:59:48 +0200108 phy-mode = "rgmii-id";
Fabio Estevam4b78b5b2020-06-25 08:14:57 -0300109 phy-handle = <&phy>;
Soeren Mochb184dc02019-03-01 13:10:54 +0100110 status = "okay";
Fabio Estevam4b78b5b2020-06-25 08:14:57 -0300111
112 mdio {
113 #address-cells = <1>;
114 #size-cells = <0>;
115
116 phy: ethernet-phy@4 {
117 reg = <4>;
118 qca,clk-out-frequency = <125000000>;
Marcel Ziswilerd0399a42022-07-21 15:27:26 +0200119 reset-gpios = <&gpio1 25 GPIO_ACTIVE_LOW>;
120 reset-assert-us = <10000>;
Fabio Estevam4b78b5b2020-06-25 08:14:57 -0300121 };
122 };
Soeren Mochb184dc02019-03-01 13:10:54 +0100123};
124
125&hdmi {
126 pinctrl-names = "default";
127 pinctrl-0 = <&pinctrl_hdmi>;
128 ddc-i2c-bus = <&i2c2>;
129 status = "okay";
130};
131
132&i2c1 {
133 clock-frequency = <100000>;
134 pinctrl-names = "default";
135 pinctrl-0 = <&pinctrl_i2c1>;
136 status = "okay";
137
138 sgtl5000: sgtl5000@a {
139 clocks = <&clks IMX6QDL_CLK_CKO>;
140 compatible = "fsl,sgtl5000";
141 pinctrl-names = "default";
142 pinctrl-0 = <&pinctrl_sgtl5000>;
143 reg = <0x0a>;
144 VDDA-supply = <&reg_2p5v>;
145 VDDIO-supply = <&reg_3p3v>;
146 };
147};
148
149&i2c2 {
150 clock-frequency = <100000>;
151 pinctrl-names = "default";
152 pinctrl-0 = <&pinctrl_i2c2>;
153 status = "okay";
154};
155
156&i2c3 {
157 clock-frequency = <100000>;
158 pinctrl-names = "default";
159 pinctrl-0 = <&pinctrl_i2c3>;
160 status = "okay";
161
Marcel Ziswilerd0399a42022-07-21 15:27:26 +0200162 rtc: rtc@68 {
Soeren Mochb184dc02019-03-01 13:10:54 +0100163 compatible = "dallas,ds1307";
164 reg = <0x68>;
165 };
166};
167
168&pcie {
169 pinctrl-names = "default";
170 pinctrl-0 = <&pinctrl_pcie>;
171 reset-gpio = <&gpio7 12 GPIO_ACTIVE_LOW>;
172 status = "okay";
173};
174
175&sata {
176 fsl,transmit-level-mV = <1104>;
177 fsl,transmit-boost-mdB = <3330>;
178 fsl,transmit-atten-16ths = <16>;
179 fsl,receive-eq-mdB = <3000>;
180 status = "okay";
181};
182
183&snvs_poweroff {
184 status = "okay";
185};
186
187&spdif {
188 pinctrl-names = "default";
189 pinctrl-0 = <&pinctrl_spdif>;
190 status = "okay";
191};
192
193&ssi1 {
194 status = "okay";
195};
196
197&uart1 {
198 pinctrl-names = "default";
199 pinctrl-0 = <&pinctrl_uart1>;
200 status = "okay";
201};
202
203&uart2 {
204 pinctrl-names = "default";
205 pinctrl-0 = <&pinctrl_uart2>;
206 status = "okay";
207};
208
209&usbh1 {
210 vbus-supply = <&reg_5p0v>;
211 status = "okay";
212};
213
214&usbotg {
215 vbus-supply = <&reg_5p0v>;
216 pinctrl-names = "default";
217 pinctrl-0 = <&pinctrl_usbotg>;
218 disable-over-current;
219 status = "okay";
220};
221
222&usdhc2 {
223 pinctrl-names = "default";
224 pinctrl-0 = <&pinctrl_usdhc2>;
225 bus-width = <4>;
226 cd-gpios = <&gpio2 2 GPIO_ACTIVE_LOW>;
227 vmmc-supply = <&reg_3p3v>;
228 vqmmc-supply = <&reg_3p3v>;
229 voltage-ranges = <3300 3300>;
230 no-1-8-v;
231 status = "okay";
232};
233
234&usdhc3 {
235 pinctrl-names = "default";
236 pinctrl-0 = <&pinctrl_usdhc3>;
237 bus-width = <4>;
238 cd-gpios = <&gpio2 0 GPIO_ACTIVE_LOW>;
239 wp-gpios = <&gpio2 1 GPIO_ACTIVE_HIGH>;
240 vmmc-supply = <&reg_3p3v>;
241 vqmmc-supply = <&reg_3p3v>;
242 voltage-ranges = <3300 3300>;
243 no-1-8-v;
244 status = "okay";
245};
246
247&usdhc4 {
248 pinctrl-names = "default";
249 pinctrl-0 = <&pinctrl_usdhc4>;
250 bus-width = <8>;
251 vmmc-supply = <&reg_3p3v>;
252 vqmmc-supply = <&reg_3p3v>;
253 voltage-ranges = <3300 3300>;
254 non-removable;
255 no-1-8-v;
256 status = "okay";
257};
258
259&iomuxc {
260 pinctrl_enet: enetgrp {
261 fsl,pins = <
262 MX6QDL_PAD_ENET_MDIO__ENET_MDIO 0x1b0b0
263 MX6QDL_PAD_ENET_MDC__ENET_MDC 0x1b0b0
264 MX6QDL_PAD_RGMII_TXC__RGMII_TXC 0x1b030
265 MX6QDL_PAD_RGMII_TD0__RGMII_TD0 0x1b030
266 MX6QDL_PAD_RGMII_TD1__RGMII_TD1 0x1b030
267 MX6QDL_PAD_RGMII_TD2__RGMII_TD2 0x1b030
268 MX6QDL_PAD_RGMII_TD3__RGMII_TD3 0x1b030
269 MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL 0x1b030
270 MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK 0x1b0b0
271 MX6QDL_PAD_RGMII_RXC__RGMII_RXC 0x1b030
272 MX6QDL_PAD_RGMII_RD0__RGMII_RD0 0x1b030
273 MX6QDL_PAD_RGMII_RD1__RGMII_RD1 0x1b030
274 MX6QDL_PAD_RGMII_RD2__RGMII_RD2 0x1b030
275 MX6QDL_PAD_RGMII_RD3__RGMII_RD3 0x1b030
276 MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL 0x1b030
277 MX6QDL_PAD_GPIO_16__ENET_REF_CLK 0x4001b0a8
278 MX6QDL_PAD_ENET_CRS_DV__GPIO1_IO25 0x1b059
279 >;
280 };
281
282 pinctrl_gpio_fan: gpiofangrp {
283 fsl,pins = <
284 MX6QDL_PAD_EIM_D28__GPIO3_IO28 0x130b1
285 >;
286 };
287
288 pinctrl_gpio_leds: gpioledsgrp {
289 fsl,pins = <
290 MX6QDL_PAD_GPIO_2__GPIO1_IO02 0x130b1
291 >;
292 };
293
294 pinctrl_hdmi: hdmigrp {
295 fsl,pins = <
296 MX6QDL_PAD_KEY_ROW2__HDMI_TX_CEC_LINE 0x1f8b0
297 >;
298 };
299
300 pinctrl_i2c1: i2c1grp {
301 fsl,pins = <
302 MX6QDL_PAD_CSI0_DAT9__I2C1_SCL 0x4001b8b1
303 MX6QDL_PAD_CSI0_DAT8__I2C1_SDA 0x4001b8b1
304 >;
305 };
306
307 pinctrl_i2c2: i2c2grp {
308 fsl,pins = <
309 MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1
310 MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1
311 >;
312 };
313
314 pinctrl_i2c3: i2c3grp {
315 fsl,pins = <
316 MX6QDL_PAD_GPIO_3__I2C3_SCL 0x4001b8b1
317 MX6QDL_PAD_GPIO_6__I2C3_SDA 0x4001b8b1
318 >;
319 };
320
321 pinctrl_ir: irgrp {
322 fsl,pins = <
323 MX6QDL_PAD_EIM_D18__GPIO3_IO18 0x17059
324 >;
325 };
326
327 pinctrl_pcie: pciegrp {
328 fsl,pins = <
329 MX6QDL_PAD_GPIO_17__GPIO7_IO12 0x17059
330 >;
331 };
332
333 pinctrl_sgtl5000: sgtl5000grp {
334 fsl,pins = <
335 MX6QDL_PAD_CSI0_DAT7__AUD3_RXD 0x130b0
336 MX6QDL_PAD_CSI0_DAT4__AUD3_TXC 0x130b0
337 MX6QDL_PAD_CSI0_DAT5__AUD3_TXD 0x110b0
338 MX6QDL_PAD_CSI0_DAT6__AUD3_TXFS 0x130b0
339 MX6QDL_PAD_GPIO_0__CCM_CLKO1 0x130b0
340 >;
341 };
342
343 pinctrl_spdif: spdifgrp {
344 fsl,pins = <MX6QDL_PAD_GPIO_19__SPDIF_OUT 0x13091
345 >;
346 };
347
348 pinctrl_uart1: uart1grp {
349 fsl,pins = <
350 MX6QDL_PAD_CSI0_DAT10__UART1_TX_DATA 0x1b0b1
351 MX6QDL_PAD_CSI0_DAT11__UART1_RX_DATA 0x1b0b1
352 >;
353 };
354
355 pinctrl_uart2: uart2grp {
356 fsl,pins = <
357 MX6QDL_PAD_EIM_D26__UART2_TX_DATA 0x1b0b1
358 MX6QDL_PAD_EIM_D27__UART2_RX_DATA 0x1b0b1
359 >;
360 };
361
362 pinctrl_usbotg: usbotggrp {
363 fsl,pins = <
364 MX6QDL_PAD_ENET_RX_ER__USB_OTG_ID 0x17059
365 >;
366 };
367
368 pinctrl_usdhc2: usdhc2grp {
369 fsl,pins = <
370 MX6QDL_PAD_SD2_CMD__SD2_CMD 0x17059
371 MX6QDL_PAD_SD2_CLK__SD2_CLK 0x10059
372 MX6QDL_PAD_SD2_DAT0__SD2_DATA0 0x17059
373 MX6QDL_PAD_SD2_DAT1__SD2_DATA1 0x17059
374 MX6QDL_PAD_SD2_DAT2__SD2_DATA2 0x17059
375 MX6QDL_PAD_SD2_DAT3__SD2_DATA3 0x17059
376 MX6QDL_PAD_NANDF_D2__GPIO2_IO02 0x17059
377 >;
378 };
379
380 pinctrl_usdhc3: usdhc3grp {
381 fsl,pins = <
382 MX6QDL_PAD_SD3_CMD__SD3_CMD 0x17059
383 MX6QDL_PAD_SD3_CLK__SD3_CLK 0x10059
384 MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17059
385 MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17059
386 MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17059
387 MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17059
388 MX6QDL_PAD_NANDF_D0__GPIO2_IO00 0x17059
389 MX6QDL_PAD_NANDF_D1__GPIO2_IO01 0x17059
390 >;
391 };
392
393 pinctrl_usdhc4: usdhc4grp {
394 fsl,pins = <
395 MX6QDL_PAD_SD4_CMD__SD4_CMD 0x17059
396 MX6QDL_PAD_SD4_CLK__SD4_CLK 0x10059
397 MX6QDL_PAD_SD4_DAT0__SD4_DATA0 0x17059
398 MX6QDL_PAD_SD4_DAT1__SD4_DATA1 0x17059
399 MX6QDL_PAD_SD4_DAT2__SD4_DATA2 0x17059
400 MX6QDL_PAD_SD4_DAT3__SD4_DATA3 0x17059
401 MX6QDL_PAD_SD4_DAT4__SD4_DATA4 0x17059
402 MX6QDL_PAD_SD4_DAT5__SD4_DATA5 0x17059
403 MX6QDL_PAD_SD4_DAT6__SD4_DATA6 0x17059
404 MX6QDL_PAD_SD4_DAT7__SD4_DATA7 0x17059
405 >;
406 };
407};