]> git.karo-electronics.de Git - karo-tx-linux.git/blob - arch/arm/boot/dts/imx6q-tx6q-11x0-mb7.dts
6b42c442168ba573b12084339abbd6fd7b158df2
[karo-tx-linux.git] / arch / arm / boot / dts / imx6q-tx6q-11x0-mb7.dts
1 /*
2  * Copyright 2016-2017 Lothar Waßmann <LW@KARO-electronics.de>
3  *
4  * This file is dual-licensed: you can use it either under the terms
5  * of the GPL or the X11 license, at your option. Note that this dual
6  * licensing only applies to this file, and not this project as a
7  * whole.
8  *
9  *  a) This file is free software; you can redistribute it and/or
10  *     modify it under the terms of the GNU General Public License
11  *     version 2 as published by the Free Software Foundation.
12  *
13  *     This file is distributed in the hope that it will be useful,
14  *     but WITHOUT ANY WARRANTY; without even the implied warranty of
15  *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  *     GNU General Public License for more details.
17  *
18  * Or, alternatively,
19  *
20  *  b) Permission is hereby granted, free of charge, to any person
21  *     obtaining a copy of this software and associated documentation
22  *     files (the "Software"), to deal in the Software without
23  *     restriction, including without limitation the rights to use,
24  *     copy, modify, merge, publish, distribute, sublicense, and/or
25  *     sell copies of the Software, and to permit persons to whom the
26  *     Software is furnished to do so, subject to the following
27  *     conditions:
28  *
29  *     The above copyright notice and this permission notice shall be
30  *     included in all copies or substantial portions of the Software.
31  *
32  *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
33  *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
34  *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
35  *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
36  *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
37  *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
38  *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
39  *     OTHER DEALINGS IN THE SOFTWARE.
40  */
41
42 /dts-v1/;
43 #include "imx6q.dtsi"
44 #include "imx6qdl-tx6.dtsi"
45
46 / {
47         model = "Ka-Ro electronics TX6Q-1110/-1130 Module on MB7 baseboard";
48         compatible = "karo,imx6q-tx6q", "fsl,imx6q";
49
50         aliases {
51                 display = &lvds0;
52                 ipu1 = &ipu2;
53                 lvds0 = &lvds0;
54                 lvds1 = &lvds1;
55         };
56
57         backlight0: backlight0 {
58                 compatible = "pwm-backlight";
59                 pwms = <&pwm2 0 500000 PWM_POLARITY_INVERTED>;
60                 power-supply = <&reg_lcd0_pwr>;
61                 /*
62                  * a poor man's way to create a 1:1 relationship between
63                  * the PWM value and the actual duty cycle
64                  */
65                 brightness-levels = < 0  1  2  3  4  5  6  7  8  9
66                                      10 11 12 13 14 15 16 17 18 19
67                                      20 21 22 23 24 25 26 27 28 29
68                                      30 31 32 33 34 35 36 37 38 39
69                                      40 41 42 43 44 45 46 47 48 49
70                                      50 51 52 53 54 55 56 57 58 59
71                                      60 61 62 63 64 65 66 67 68 69
72                                      70 71 72 73 74 75 76 77 78 79
73                                      80 81 82 83 84 85 86 87 88 89
74                                      90 91 92 93 94 95 96 97 98 99
75                                     100>;
76                 default-brightness-level = <50>;
77         };
78
79         backlight1: backlight1 {
80                 compatible = "pwm-backlight";
81                 pwms = <&pwm1 0 500000 PWM_POLARITY_INVERTED>;
82                 power-supply = <&reg_lcd1_pwr>;
83                 /*
84                  * a poor man's way to create a 1:1 relationship between
85                  * the PWM value and the actual duty cycle
86                  */
87                 brightness-levels = < 0  1  2  3  4  5  6  7  8  9
88                                      10 11 12 13 14 15 16 17 18 19
89                                      20 21 22 23 24 25 26 27 28 29
90                                      30 31 32 33 34 35 36 37 38 39
91                                      40 41 42 43 44 45 46 47 48 49
92                                      50 51 52 53 54 55 56 57 58 59
93                                      60 61 62 63 64 65 66 67 68 69
94                                      70 71 72 73 74 75 76 77 78 79
95                                      80 81 82 83 84 85 86 87 88 89
96                                      90 91 92 93 94 95 96 97 98 99
97                                     100>;
98                 default-brightness-level = <50>;
99         };
100 };
101
102 &can1 {
103         status = "disabled";
104 };
105
106 &can2 {
107         xceiver-supply = <&reg_3v3>;
108 };
109
110 &ipu2 {
111         status = "disabled";
112 };
113
114 &kpp {
115         status = "disabled"; /* pads partially clash with backlight1 PWM */
116 };
117
118 &ldb {
119         status = "okay";
120
121         lvds0: lvds-channel@0 {
122                 fsl,data-mapping = "spwg";
123                 fsl,data-width = <18>;
124                 status = "okay";
125
126                 display-timings {
127                         native-mode = <&lvds0_timing1>;
128
129                         lvds0_timing0: hsd100pxn1 {
130                                 clock-frequency = <65000000>;
131                                 hactive = <1024>;
132                                 vactive = <768>;
133                                 hback-porch = <220>;
134                                 hfront-porch = <40>;
135                                 vback-porch = <21>;
136                                 vfront-porch = <7>;
137                                 hsync-len = <60>;
138                                 vsync-len = <10>;
139                                 hsync-active = <0>;
140                                 vsync-active = <0>;
141                                 de-active = <1>;
142                                 pixelclk-active = <1>;
143                         };
144
145                         lvds0_timing1: VGA {
146                                 clock-frequency = <25200000>;
147                                 hactive = <640>;
148                                 vactive = <480>;
149                                 hback-porch = <48>;
150                                 hfront-porch = <16>;
151                                 vback-porch = <31>;
152                                 vfront-porch = <12>;
153                                 hsync-len = <96>;
154                                 vsync-len = <2>;
155                                 hsync-active = <0>;
156                                 vsync-active = <0>;
157                                 de-active = <1>;
158                                 pixelclk-active = <0>;
159                         };
160
161                         lvds0_timing2: nl12880bc20 {
162                                 clock-frequency = <71000000>;
163                                 hactive = <1280>;
164                                 vactive = <800>;
165                                 hback-porch = <50>;
166                                 hfront-porch = <50>;
167                                 vback-porch = <5>;
168                                 vfront-porch = <5>;
169                                 hsync-len = <60>;
170                                 vsync-len = <13>;
171                                 hsync-active = <0>;
172                                 vsync-active = <0>;
173                                 de-active = <1>;
174                                 pixelclk-active = <1>;
175                         };
176                 };
177         };
178
179         lvds1: lvds-channel@1 {
180                 fsl,data-mapping = "spwg";
181                 fsl,data-width = <18>;
182                 status = "okay";
183
184                 display-timings {
185                         native-mode = <&lvds1_timing2>;
186
187                         lvds1_timing0: hsd100pxn1 {
188                                 clock-frequency = <65000000>;
189                                 hactive = <1024>;
190                                 vactive = <768>;
191                                 hback-porch = <220>;
192                                 hfront-porch = <40>;
193                                 vback-porch = <21>;
194                                 vfront-porch = <7>;
195                                 hsync-len = <60>;
196                                 vsync-len = <10>;
197                                 hsync-active = <0>;
198                                 vsync-active = <0>;
199                                 de-active = <1>;
200                                 pixelclk-active = <1>;
201                         };
202
203                         lvds1_timing1: VGA {
204                                 clock-frequency = <25200000>;
205                                 hactive = <640>;
206                                 vactive = <480>;
207                                 hback-porch = <48>;
208                                 hfront-porch = <16>;
209                                 vback-porch = <31>;
210                                 vfront-porch = <12>;
211                                 hsync-len = <96>;
212                                 vsync-len = <2>;
213                                 hsync-active = <0>;
214                                 vsync-active = <0>;
215                                 de-active = <1>;
216                                 pixelclk-active = <0>;
217                         };
218
219                         lvds1_timing2: nl12880bc20 {
220                                 clock-frequency = <71000000>;
221                                 hactive = <1280>;
222                                 vactive = <800>;
223                                 hback-porch = <50>;
224                                 hfront-porch = <50>;
225                                 vback-porch = <5>;
226                                 vfront-porch = <5>;
227                                 hsync-len = <60>;
228                                 vsync-len = <13>;
229                                 hsync-active = <0>;
230                                 vsync-active = <0>;
231                                 de-active = <1>;
232                                 pixelclk-active = <1>;
233                         };
234                 };
235         };
236 };
237
238 &pwm1 {
239         status = "okay";
240 };
241
242 &sata {
243         status = "okay";
244 };