GNU Linux-libre 6.1.90-gnu
[releases.git] / arch / arm / boot / dts / stm32mp15xx-dhcom-pdk2.dtsi
1 // 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                                 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                                 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 };