blob: 46b87a27d8b378fa52ee8ede3a23dd9a4c7424d7 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001// SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause
2/*
3 * Copyright (C) 2019-2020 Marek Vasut <marex@denx.de>
4 */
5
6#include <dt-bindings/input/input.h>
7#include <dt-bindings/pwm/pwm.h>
8
9/ {
10 aliases {
11 serial0 = &uart4;
12 serial1 = &usart3;
13 serial2 = &uart8;
14 };
15
16 chosen {
17 stdout-path = "serial0:115200n8";
18 };
19
20 clk_ext_audio_codec: clock-codec {
21 compatible = "fixed-clock";
22 #clock-cells = <0>;
23 clock-frequency = <24000000>;
24 };
25
26 display_bl: display-bl {
27 compatible = "pwm-backlight";
28 pwms = <&pwm2 3 500000 PWM_POLARITY_INVERTED>;
29 brightness-levels = <0 16 22 30 40 55 75 102 138 188 255>;
30 default-brightness-level = <8>;
31 enable-gpios = <&gpioi 0 GPIO_ACTIVE_HIGH>;
32 power-supply = <&reg_panel_bl>;
33 status = "okay";
34 };
35
36 gpio-keys-polled {
37 compatible = "gpio-keys-polled";
38 poll-interval = <20>;
39
40 /*
41 * The EXTi IRQ line 3 is shared with ethernet,
42 * so mark this as polled GPIO key.
43 */
44 button-0 {
45 label = "TA1-GPIO-A";
46 linux,code = <KEY_A>;
47 gpios = <&gpiof 3 GPIO_ACTIVE_LOW>;
48 };
49
50 /*
51 * The EXTi IRQ line 6 is shared with touchscreen,
52 * so mark this as polled GPIO key.
53 */
54 button-1 {
55 label = "TA2-GPIO-B";
56 linux,code = <KEY_B>;
57 gpios = <&gpiod 6 GPIO_ACTIVE_LOW>;
58 };
59
60 /*
61 * The EXTi IRQ line 0 is shared with PMIC,
62 * so mark this as polled GPIO key.
63 */
64 button-2 {
65 label = "TA3-GPIO-C";
66 linux,code = <KEY_C>;
67 gpios = <&gpiog 0 GPIO_ACTIVE_LOW>;
68 };
69 };
70
71 gpio-keys {
72 compatible = "gpio-keys";
73
74 button-3 {
75 label = "TA4-GPIO-D";
76 linux,code = <KEY_D>;
77 gpios = <&gpiod 12 GPIO_ACTIVE_LOW>;
78 wakeup-source;
79 };
80 };
81
82 led {
83 compatible = "gpio-leds";
84
85 led-0 {
86 label = "green:led5";
87 gpios = <&gpioc 6 GPIO_ACTIVE_HIGH>;
88 default-state = "off";
89 status = "disabled";
90 };
91
92 led-1 {
93 label = "green:led6";
94 gpios = <&gpiod 11 GPIO_ACTIVE_HIGH>;
95 default-state = "off";
96 };
97
98 led-2 {
99 label = "green:led7";
100 gpios = <&gpioi 2 GPIO_ACTIVE_HIGH>;
101 default-state = "off";
102 };
103
104 led-3 {
105 label = "green:led8";
106 gpios = <&gpioi 3 GPIO_ACTIVE_HIGH>;
107 default-state = "off";
108 };
109 };
110
111 panel {
112 compatible = "edt,etm0700g0edh6";
113 backlight = <&display_bl>;
114 power-supply = <&reg_panel_bl>;
115
116 port {
117 lcd_panel_in: endpoint {
118 remote-endpoint = <&lcd_display_out>;
119 };
120 };
121 };
122
123 reg_panel_bl: regulator-panel-bl {
124 compatible = "regulator-fixed";
125 regulator-name = "panel_backlight";
126 regulator-min-microvolt = <3300000>;
127 regulator-max-microvolt = <3300000>;
128 vin-supply = <&reg_panel_supply>;
129 };
130
131 reg_panel_supply: regulator-panel-supply {
132 compatible = "regulator-fixed";
133 regulator-name = "panel_supply";
134 regulator-min-microvolt = <24000000>;
135 regulator-max-microvolt = <24000000>;
136 };
137
138 sound {
139 compatible = "audio-graph-card";
140 widgets = "Headphone", "Headphone Jack",
141 "Line", "Line In Jack",
142 "Microphone", "Microphone Jack";
143 routing = "Headphone Jack", "HP_OUT",
144 "LINE_IN", "Line In Jack",
145 "MIC_IN", "Microphone Jack",
146 "Microphone Jack", "Mic Bias";
147 dais = <&sai2a_port &sai2b_port>;
148 status = "okay";
149 };
150};
151
152&cec {
153 pinctrl-names = "default";
154 pinctrl-0 = <&cec_pins_a>;
155 status = "okay";
156};
157
158&i2c2 { /* Header X22 */
159 pinctrl-names = "default";
160 pinctrl-0 = <&i2c2_pins_a>;
161 i2c-scl-rising-time-ns = <185>;
162 i2c-scl-falling-time-ns = <20>;
163 status = "okay";
164 /* spare dmas for other usage */
165 /delete-property/dmas;
166 /delete-property/dma-names;
167 status = "okay";
168};
169
170&i2c5 { /* Header X21 */
171 pinctrl-names = "default";
172 pinctrl-0 = <&i2c5_pins_a>;
173 i2c-scl-rising-time-ns = <185>;
174 i2c-scl-falling-time-ns = <20>;
175 status = "okay";
176 /* spare dmas for other usage */
177 /delete-property/dmas;
178 /delete-property/dma-names;
179
180 sgtl5000: codec@a {
181 compatible = "fsl,sgtl5000";
182 reg = <0x0a>;
183 #sound-dai-cells = <0>;
184 clocks = <&clk_ext_audio_codec>;
185 VDDA-supply = <&v3v3>;
186 VDDIO-supply = <&vdd>;
187
188 sgtl5000_port: port {
189 #address-cells = <1>;
190 #size-cells = <0>;
191
192 sgtl5000_tx_endpoint: endpoint@0 {
193 reg = <0>;
194 remote-endpoint = <&sai2a_endpoint>;
195 frame-master = <&sgtl5000_tx_endpoint>;
196 bitclock-master = <&sgtl5000_tx_endpoint>;
197 };
198
199 sgtl5000_rx_endpoint: endpoint@1 {
200 reg = <1>;
201 remote-endpoint = <&sai2b_endpoint>;
202 frame-master = <&sgtl5000_rx_endpoint>;
203 bitclock-master = <&sgtl5000_rx_endpoint>;
204 };
205 };
206
207 };
208
209 touchscreen@38 {
210 compatible = "edt,edt-ft5406";
211 reg = <0x38>;
212 interrupt-parent = <&gpioc>;
213 interrupts = <6 IRQ_TYPE_EDGE_FALLING>; /* GPIO E */
214 };
215};
216
217&ltdc {
218 pinctrl-names = "default", "sleep";
219 pinctrl-0 = <&ltdc_pins_b>;
220 pinctrl-1 = <&ltdc_sleep_pins_b>;
221 status = "okay";
222
223 port {
224 lcd_display_out: endpoint {
225 remote-endpoint = <&lcd_panel_in>;
226 };
227 };
228};
229
230&sai2 {
231 clocks = <&rcc SAI2>, <&rcc PLL3_Q>, <&rcc PLL3_R>;
232 clock-names = "pclk", "x8k", "x11k";
233 pinctrl-names = "default", "sleep";
234 pinctrl-0 = <&sai2a_pins_b &sai2b_pins_b>;
235 pinctrl-1 = <&sai2a_sleep_pins_b &sai2b_sleep_pins_b>;
236 status = "okay";
237
238 sai2a: audio-controller@4400b004 {
239 #clock-cells = <0>;
240 dma-names = "tx";
241 clocks = <&rcc SAI2_K>;
242 clock-names = "sai_ck";
243 status = "okay";
244
245 sai2a_port: port {
246 sai2a_endpoint: endpoint {
247 remote-endpoint = <&sgtl5000_tx_endpoint>;
248 dai-format = "i2s";
249 mclk-fs = <512>;
250 dai-tdm-slot-num = <2>;
251 dai-tdm-slot-width = <16>;
252 };
253 };
254 };
255
256 sai2b: audio-controller@4400b024 {
257 dma-names = "rx";
258 st,sync = <&sai2a 2>;
259 clocks = <&rcc SAI2_K>, <&sai2a>;
260 clock-names = "sai_ck", "MCLK";
261 status = "okay";
262
263 sai2b_port: port {
264 sai2b_endpoint: endpoint {
265 remote-endpoint = <&sgtl5000_rx_endpoint>;
266 dai-format = "i2s";
267 mclk-fs = <512>;
268 dai-tdm-slot-num = <2>;
269 dai-tdm-slot-width = <16>;
270 };
271 };
272 };
273};
274
275&timers2 {
276 /* spare dmas for other usage (un-delete to enable pwm capture) */
277 /delete-property/dmas;
278 /delete-property/dma-names;
279 status = "okay";
280 pwm2: pwm {
281 pinctrl-0 = <&pwm2_pins_a>;
282 pinctrl-names = "default";
283 status = "okay";
284 };
285 timer@1 {
286 status = "okay";
287 };
288};
289
290&usart3 {
291 pinctrl-names = "default";
292 pinctrl-0 = <&usart3_pins_a>;
293 /delete-property/dmas;
294 /delete-property/dma-names;
295 status = "okay";
296};
297
298&uart8 {
299 pinctrl-names = "default";
300 pinctrl-0 = <&uart8_pins_a &uart8_rtscts_pins_a>;
301 uart-has-rtscts;
302 /delete-property/dmas;
303 /delete-property/dma-names;
304 status = "okay";
305};
306
307&usbh_ehci {
308 phys = <&usbphyc_port0>;
309 status = "okay";
310};
311
312&usbotg_hs {
313 dr_mode = "otg";
314 pinctrl-0 = <&usbotg_hs_pins_a>;
315 pinctrl-names = "default";
316 phy-names = "usb2-phy";
317 phys = <&usbphyc_port1 0>;
318 vbus-supply = <&vbus_otg>;
319 status = "okay";
320};
321
322&usbphyc {
323 status = "okay";
324};
325
326&usbphyc_port0 {
327 phy-supply = <&vdd_usb>;
328};
329
330&usbphyc_port1 {
331 phy-supply = <&vdd_usb>;
332};