WIP FPC-III support
[linux/fpc-iii.git] / arch / arm / boot / dts / imx6q-prti6q.dts
blobb4605edfd2ab807ec67153163860b23cc7d5d411
1 // SPDX-License-Identifier: GPL-2.0-or-later OR MIT
2 /*
3  * Copyright (c) 2014 Protonic Holland
4  */
6 /dts-v1/;
7 #include "imx6q.dtsi"
8 #include "imx6qdl-prti6q.dtsi"
9 #include <dt-bindings/leds/common.h>
10 #include <dt-bindings/sound/fsl-imx-audmux.h>
12 / {
13         model = "Protonic PRTI6Q board";
14         compatible = "prt,prti6q", "fsl,imx6q";
16         memory@10000000 {
17                 device_type = "memory";
18                 reg = <0x10000000 0xf0000000>;
19         };
21         backlight_lcd: backlight-lcd {
22                 compatible = "pwm-backlight";
23                 pinctrl-names = "default";
24                 pinctrl-0 = <&pinctrl_backlight>;
25                 pwms = <&pwm1 0 5000000>;
26                 brightness-levels = <0 16 64 255>;
27                 num-interpolated-steps = <16>;
28                 default-brightness-level = <1>;
29                 power-supply = <&reg_3v3>;
30                 enable-gpios = <&gpio4 28 GPIO_ACTIVE_HIGH>;
31         };
33         can_osc: can-osc {
34                 compatible = "fixed-clock";
35                 #clock-cells = <0>;
36                 clock-frequency = <25000000>;
37         };
39         leds {
40                 compatible = "gpio-leds";
41                 pinctrl-names = "default";
42                 pinctrl-0 = <&pinctrl_leds>;
44                 led-debug0 {
45                         function = LED_FUNCTION_STATUS;
46                         gpios = <&gpio1 8 GPIO_ACTIVE_HIGH>;
47                         linux,default-trigger = "heartbeat";
48                 };
50                 led-debug1 {
51                         function = LED_FUNCTION_SD;
52                         gpios = <&gpio1 9 GPIO_ACTIVE_HIGH>;
53                         linux,default-trigger = "disk-activity";
54                 };
55         };
57         panel {
58                 compatible = "kyo,tcg121xglp";
59                 backlight = <&backlight_lcd>;
61                 port {
62                         panel_in: endpoint {
63                                 remote-endpoint = <&lvds0_out>;
64                         };
65                 };
66         };
68         reg_1v8: regulator-1v8 {
69                 compatible = "regulator-fixed";
70                 regulator-name = "1v8";
71                 regulator-min-microvolt = <1800000>;
72                 regulator-max-microvolt = <1800000>;
73         };
75         reg_wifi: regulator-wifi {
76                 compatible = "regulator-fixed";
77                 pinctrl-names = "default";
78                 pinctrl-0 = <&pinctrl_wifi_npd>;
79                 enable-active-high;
80                 gpio = <&gpio1 26 GPIO_ACTIVE_HIGH>;
81                 regulator-max-microvolt = <1800000>;
82                 regulator-min-microvolt = <1800000>;
83                 regulator-name = "regulator-WL12xx";
84                 startup-delay-us = <70000>;
85         };
87         sound {
88                 compatible = "simple-audio-card";
89                 simple-audio-card,name = "prti6q-sgtl5000";
90                 simple-audio-card,format = "i2s";
91                 simple-audio-card,widgets =
92                         "Microphone", "Microphone Jack",
93                         "Line", "Line In Jack",
94                         "Headphone", "Headphone Jack",
95                         "Speaker", "External Speaker";
96                 simple-audio-card,routing =
97                         "MIC_IN", "Microphone Jack",
98                         "LINE_IN", "Line In Jack",
99                         "Headphone Jack", "HP_OUT",
100                         "External Speaker", "LINE_OUT";
102                 simple-audio-card,cpu {
103                         sound-dai = <&ssi1>;
104                         system-clock-frequency = <0>;
105                 };
107                 simple-audio-card,codec {
108                         sound-dai = <&sgtl5000>;
109                         bitclock-master;
110                         frame-master;
111                 };
112         };
114         sound-spdif {
115                 compatible = "fsl,imx-audio-spdif";
116                 model = "imx-spdif";
117                 spdif-controller = <&spdif>;
118                 spdif-in;
119                 spdif-out;
120         };
123 &audmux {
124         pinctrl-names = "default";
125         pinctrl-0 = <&pinctrl_audmux>;
126         status = "okay";
128         mux-ssi1 {
129                 fsl,audmux-port = <0>;
130                 fsl,port-config = <
131                         IMX_AUDMUX_V2_PTCR_SYN          0
132                         IMX_AUDMUX_V2_PTCR_TFSEL(2)     0
133                         IMX_AUDMUX_V2_PTCR_TCSEL(2)     0
134                         IMX_AUDMUX_V2_PTCR_TFSDIR       0
135                         IMX_AUDMUX_V2_PTCR_TCLKDIR IMX_AUDMUX_V2_PDCR_RXDSEL(2)
136                 >;
137         };
139         mux-pins3 {
140                 fsl,audmux-port = <2>;
141                 fsl,port-config = <
142                         IMX_AUDMUX_V2_PTCR_SYN IMX_AUDMUX_V2_PDCR_RXDSEL(0)
143                         0                      IMX_AUDMUX_V2_PDCR_TXRXEN
144                 >;
145         };
148 &can1 {
149         pinctrl-names = "default";
150         pinctrl-0 = <&pinctrl_can1>;
151         status = "okay";
154 &can2 {
155         pinctrl-names = "default";
156         pinctrl-0 = <&pinctrl_can2>;
157         status = "okay";
160 &ecspi1 {
161         cs-gpios = <&gpio3 19 GPIO_ACTIVE_LOW>;
162         pinctrl-names = "default";
163         pinctrl-0 = <&pinctrl_ecspi1>;
164         status = "okay";
166         flash@0 {
167                 compatible = "jedec,spi-nor";
168                 reg = <0>;
169                 spi-max-frequency = <20000000>;
170         };
173 &ecspi2 {
174         cs-gpios = <&gpio2 26 GPIO_ACTIVE_LOW>, <&gpio4 25 GPIO_ACTIVE_LOW>;
175         pinctrl-names = "default";
176         pinctrl-0 = <&pinctrl_ecspi2 &pinctrl_ecspi2_cs>;
177         status = "okay";
179         can@0 {
180                 compatible = "microchip,mcp2515";
181                 reg = <0>;
182                 pinctrl-names = "default";
183                 pinctrl-0 = <&pinctrl_can3>;
184                 clocks = <&can_osc>;
185                 interrupts-extended = <&gpio3 20 IRQ_TYPE_LEVEL_LOW>;
186                 spi-max-frequency = <5000000>;
187         };
189         adc@1 {
190                 compatible = "ti,adc128s052";
191                 reg = <1>;
192                 spi-max-frequency = <2000000>;
193                 vref-supply = <&reg_3v3>;
194         };
197 &ecspi3 {
198         cs-gpios = <&gpio4 24 GPIO_ACTIVE_LOW>;
199         pinctrl-names = "default";
200         pinctrl-0 = <&pinctrl_ecspi3>;
201         status = "okay";
204 &fec {
205         pinctrl-names = "default";
206         pinctrl-0 = <&pinctrl_enet>;
207         phy-mode = "rgmii-id";
208         phy-handle = <&rgmii_phy>;
209         status = "okay";
211         mdio {
212                 #address-cells = <1>;
213                 #size-cells = <0>;
215                 /* Microchip KSZ9031RNX PHY */
216                 rgmii_phy: ethernet-phy@0 {
217                         reg = <0>;
218                         interrupts-extended = <&gpio1 28 IRQ_TYPE_LEVEL_LOW>;
219                         reset-gpios = <&gpio1 25 GPIO_ACTIVE_LOW>;
220                         reset-assert-us = <10000>;
221                         reset-deassert-us = <300>;
222                 };
223         };
226 &hdmi {
227         pinctrl-names = "default";
228         pinctrl-0 = <&pinctrl_hdmi>;
229         ddc-i2c-bus = <&i2c2>;
230         status = "okay";
233 &i2c1 {
234         sgtl5000: audio-codec@a {
235                 compatible = "fsl,sgtl5000";
236                 reg = <0xa>;
237                 #sound-dai-cells = <0>;
238                 clocks = <&clks 201>;
239                 VDDA-supply = <&reg_3v3>;
240                 VDDIO-supply = <&reg_3v3>;
241                 VDDD-supply = <&reg_1v8>;
242         };
245 /* DDC */
246 &i2c2 {
247         clock-frequency = <100000>;
248         pinctrl-names = "default";
249         pinctrl-0 = <&pinctrl_i2c2>;
250         status = "okay";
253 &i2c3 {
254         adc@49 {
255                 compatible = "ti,ads1015";
256                 reg = <0x49>;
257                 #address-cells = <1>;
258                 #size-cells = <0>;
260                 /* can2_l */
261                 channel@4 {
262                         reg = <4>;
263                         ti,gain = <3>;
264                         ti,datarate = <3>;
265                 };
267                 /* can2_h */
268                 channel@5 {
269                         reg = <5>;
270                         ti,gain = <3>;
271                         ti,datarate = <3>;
272                 };
274                 /* can1_l */
275                 channel@6 {
276                         reg = <6>;
277                         ti,gain = <3>;
278                         ti,datarate = <3>;
279                 };
281                 /* can1_h */
282                 channel@7 {
283                         reg = <7>;
284                         ti,gain = <3>;
285                         ti,datarate = <3>;
286                 };
287         };
290 &pcie {
291         status = "okay";
294 &pwm1 {
295         #pwm-cells = <2>;
296         pinctrl-names = "default";
297         pinctrl-0 = <&pinctrl_pwm1>;
298         status = "okay";
301 &ldb {
302         status = "okay";
304         lvds-channel@0 {
305                 status = "okay";
307                 port@4 {
308                         reg = <4>;
310                         lvds0_out: endpoint {
311                                 remote-endpoint = <&panel_in>;
312                         };
313                 };
314         };
317 &sata {
318         status = "okay";
321 &snvs_poweroff {
322         status = "okay";
325 &spdif {
326         pinctrl-names = "default";
327         pinctrl-0 = <&pinctrl_spdif>;
328         status = "okay";
331 &ssi1 {
332         #sound-dai-cells = <0>;
333         fsl,mode = "ac97-slave";
334         status = "okay";
337 &uart2 {
338         pinctrl-names = "default";
339         pinctrl-0 = <&pinctrl_uart2>;
340         status = "okay";
343 &uart5 {
344         pinctrl-names = "default";
345         pinctrl-0 = <&pinctrl_uart5>;
346         status = "okay";
349 &usbotg {
350         pinctrl-0 = <&pinctrl_usbotg &pinctrl_usbotg_id>;
353 &usdhc2 {
354         pinctrl-names = "default";
355         pinctrl-0 = <&pinctrl_usdhc2>;
356         non-removable;
357         vmmc-supply = <&reg_wifi>;
358         cap-power-off-card;
359         keep-power-in-suspend;
360         status = "okay";
362         wifi {
363                 compatible = "ti,wl1271";
364                 pinctrl-names = "default";
365                 pinctrl-0 = <&pinctrl_wifi>;
366                 interrupts-extended = <&gpio1 30 IRQ_TYPE_LEVEL_HIGH>;
367                 ref-clock-frequency = "38400000";
368                 tcxo-clock-frequency = "19200000";
369         };
372 &iomuxc {
373         pinctrl_audmux: audmuxgrp {
374                 fsl,pins = <
375                         MX6QDL_PAD_CSI0_MCLK__CCM_CLKO1         0x030b0
376                         MX6QDL_PAD_CSI0_DAT7__AUD3_RXD          0x130b0
377                         MX6QDL_PAD_CSI0_DAT4__AUD3_TXC          0x130b0
378                         MX6QDL_PAD_CSI0_DAT5__AUD3_TXD          0x110b0
379                         MX6QDL_PAD_CSI0_DAT6__AUD3_TXFS         0x130b0
380                 >;
381         };
383         pinctrl_backlight: backlightgrp {
384                 fsl,pins = <
385                         MX6QDL_PAD_DISP0_DAT7__GPIO4_IO28       0x1b0b0
386                 >;
387         };
389         pinctrl_can2: can2grp {
390                 fsl,pins = <
391                         MX6QDL_PAD_KEY_COL4__FLEXCAN2_TX        0x1b008
392                         MX6QDL_PAD_KEY_ROW4__FLEXCAN2_RX        0x1b008
393                 >;
394         };
396         pinctrl_can3: can3grp {
397                 fsl,pins = <
398                         MX6QDL_PAD_EIM_D20__GPIO3_IO20          0x1b0b1
399                 >;
400         };
402         pinctrl_ecspi1: ecspi1grp {
403                 fsl,pins = <
404                         MX6QDL_PAD_EIM_D17__ECSPI1_MISO         0x100b1
405                         MX6QDL_PAD_EIM_D18__ECSPI1_MOSI         0x100b1
406                         MX6QDL_PAD_EIM_D16__ECSPI1_SCLK         0x100b1
407                         /* CS */
408                         MX6QDL_PAD_EIM_D19__GPIO3_IO19          0x000b1
409                 >;
410         };
412         pinctrl_ecspi2: ecspi2grp {
413                 fsl,pins = <
414                         MX6QDL_PAD_EIM_OE__ECSPI2_MISO          0x100b1
415                         MX6QDL_PAD_EIM_CS0__ECSPI2_SCLK         0x100b1
416                         MX6QDL_PAD_EIM_CS1__ECSPI2_MOSI         0x100b1
417                         MX6QDL_PAD_EIM_RW__GPIO2_IO26           0x000b1
418                 >;
419         };
421         pinctrl_ecspi2_cs: ecspi2csgrp {
422                 fsl,pins = <
423                         /* ADC128S022 CS */
424                         MX6QDL_PAD_DISP0_DAT4__GPIO4_IO25       0x1b0b1
425                 >;
426         };
428         pinctrl_ecspi3: ecspi3grp {
429                 fsl,pins = <
430                         MX6QDL_PAD_DISP0_DAT0__ECSPI3_SCLK      0x100b1
431                         MX6QDL_PAD_DISP0_DAT1__ECSPI3_MOSI      0x100b1
432                         MX6QDL_PAD_DISP0_DAT2__ECSPI3_MISO      0x100b1
433                         MX6QDL_PAD_DISP0_DAT3__GPIO4_IO24       0x000b1
434                 >;
435         };
437         pinctrl_enet: enetgrp {
438                 fsl,pins = <
439                         MX6QDL_PAD_RGMII_RXC__RGMII_RXC         0x1b030
440                         MX6QDL_PAD_RGMII_RD0__RGMII_RD0         0x1b030
441                         MX6QDL_PAD_RGMII_RD1__RGMII_RD1         0x1b030
442                         MX6QDL_PAD_RGMII_RD2__RGMII_RD2         0x1b030
443                         MX6QDL_PAD_RGMII_RD3__RGMII_RD3         0x1b030
444                         MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL   0x1b030
445                         MX6QDL_PAD_RGMII_TXC__RGMII_TXC         0x10030
446                         MX6QDL_PAD_RGMII_TD0__RGMII_TD0         0x10030
447                         MX6QDL_PAD_RGMII_TD1__RGMII_TD1         0x10030
448                         MX6QDL_PAD_RGMII_TD2__RGMII_TD2         0x10030
449                         MX6QDL_PAD_RGMII_TD3__RGMII_TD3         0x10030
450                         MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL   0x10030
451                         MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK    0x10030
452                         MX6QDL_PAD_ENET_MDIO__ENET_MDIO         0x10030
453                         MX6QDL_PAD_ENET_MDC__ENET_MDC           0x10030
455                         /* Phy reset */
456                         MX6QDL_PAD_ENET_CRS_DV__GPIO1_IO25      0x1b0b0
457                         MX6QDL_PAD_ENET_TX_EN__GPIO1_IO28       0x1b0b1
458                 >;
459         };
461         pinctrl_hdmi: hdmigrp {
462                 fsl,pins = <
463                         /* NOTE: DDC is done via I2C2, so DON'T
464                          * configure DDC pins for HDMI!
465                          */
466                         MX6QDL_PAD_EIM_A25__HDMI_TX_CEC_LINE    0x1f8b0
467                 >;
468         };
470         /* DDC */
471         pinctrl_i2c2: i2c2grp {
472                 fsl,pins = <
473                         MX6QDL_PAD_KEY_COL3__I2C2_SCL   0x4001b8b1
474                         MX6QDL_PAD_KEY_ROW3__I2C2_SDA   0x4001b8b1
475                 >;
476         };
478         pinctrl_leds: ledsgrp {
479                 fsl,pins = <
480                         MX6QDL_PAD_GPIO_8__GPIO1_IO08           0x1b0b0
481                         MX6QDL_PAD_GPIO_9__GPIO1_IO09           0x1b0b0
482                 >;
483         };
485         pinctrl_pwm1: pwm1grp {
486                 fsl,pins = <
487                         MX6QDL_PAD_DISP0_DAT8__PWM1_OUT         0x1b0b0
488                 >;
489         };
491         pinctrl_spdif: spdifgrp {
492                 fsl,pins = <
493                         MX6QDL_PAD_GPIO_16__SPDIF_IN            0x1b0b0
494                         MX6QDL_PAD_GPIO_19__SPDIF_OUT           0x1b0b0
495                 >;
496         };
498         pinctrl_uart2: uart2grp {
499                 fsl,pins = <
500                         MX6QDL_PAD_EIM_D26__UART2_RX_DATA       0x1b0b1
501                         MX6QDL_PAD_EIM_D27__UART2_TX_DATA       0x1b0b1
502                         MX6QDL_PAD_EIM_D28__UART2_DTE_CTS_B     0x1b0b1
503                         MX6QDL_PAD_EIM_D29__UART2_DTE_RTS_B     0x1b0b1
504                 >;
505         };
507         pinctrl_uart5: uart5grp {
508                 fsl,pins = <
509                         MX6QDL_PAD_KEY_COL1__UART5_TX_DATA      0x1b0b1
510                         MX6QDL_PAD_KEY_ROW1__UART5_RX_DATA      0x1b0b1
511                 >;
512         };
514         pinctrl_usbotg_id: usbotgidgrp {
515                 fsl,pins = <
516                         MX6QDL_PAD_ENET_RX_ER__USB_OTG_ID       0x1f058
517                 >;
518         };
520         pinctrl_usdhc2: usdhc2grp {
521                 fsl,pins = <
522                         MX6QDL_PAD_SD2_CMD__SD2_CMD             0x170b9
523                         MX6QDL_PAD_SD2_CLK__SD2_CLK             0x100b9
524                         MX6QDL_PAD_SD2_DAT0__SD2_DATA0          0x170b9
525                         MX6QDL_PAD_SD2_DAT1__SD2_DATA1          0x170b9
526                         MX6QDL_PAD_SD2_DAT2__SD2_DATA2          0x170b9
527                         MX6QDL_PAD_SD2_DAT3__SD2_DATA3          0x170b9
528                 >;
529         };
531         pinctrl_wifi: wifigrp {
532                 fsl,pins = <
533                         /* WL12xx IRQ */
534                         MX6QDL_PAD_ENET_TXD0__GPIO1_IO30        0x10880
535                 >;
536         };
538         pinctrl_wifi_npd: wifinpd {
539                 fsl,pins = <
540                         MX6QDL_PAD_ENET_RXD1__GPIO1_IO26        0x1b8b0
541                 >;
542         };