Merge tag 'block-5.14-2021-08-07' of git://git.kernel.dk/linux-block
[linux-2.6-microblaze.git] / arch / arm64 / boot / dts / freescale / fsl-ls1028a-rdb.dts
1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2 /*
3  * Device Tree file for NXP LS1028A RDB Board.
4  *
5  * Copyright 2018 NXP
6  *
7  * Harninder Rai <harninder.rai@nxp.com>
8  *
9  */
10
11 /dts-v1/;
12 #include "fsl-ls1028a.dtsi"
13
14 / {
15         model = "LS1028A RDB Board";
16         compatible = "fsl,ls1028a-rdb", "fsl,ls1028a";
17
18         aliases {
19                 crypto = &crypto;
20                 serial0 = &duart0;
21                 serial1 = &duart1;
22                 mmc0 = &esdhc;
23                 mmc1 = &esdhc1;
24                 rtc1 = &ftm_alarm0;
25         };
26
27         chosen {
28                 stdout-path = "serial0:115200n8";
29         };
30
31         memory@80000000 {
32                 device_type = "memory";
33                 reg = <0x0 0x80000000 0x1 0x0000000>;
34         };
35
36         sys_mclk: clock-mclk {
37                 compatible = "fixed-clock";
38                 #clock-cells = <0>;
39                 clock-frequency = <25000000>;
40         };
41
42         reg_1p8v: regulator-1p8v {
43                 compatible = "regulator-fixed";
44                 regulator-name = "1P8V";
45                 regulator-min-microvolt = <1800000>;
46                 regulator-max-microvolt = <1800000>;
47                 regulator-always-on;
48         };
49
50         sb_3v3: regulator-sb3v3 {
51                 compatible = "regulator-fixed";
52                 regulator-name = "3v3_vbus";
53                 regulator-min-microvolt = <3300000>;
54                 regulator-max-microvolt = <3300000>;
55                 regulator-boot-on;
56                 regulator-always-on;
57         };
58
59         sound {
60                 compatible = "simple-audio-card";
61                 simple-audio-card,format = "i2s";
62                 simple-audio-card,widgets =
63                         "Microphone", "Microphone Jack",
64                         "Headphone", "Headphone Jack",
65                         "Speaker", "Speaker Ext",
66                         "Line", "Line In Jack";
67                 simple-audio-card,routing =
68                         "MIC_IN", "Microphone Jack",
69                         "Microphone Jack", "Mic Bias",
70                         "LINE_IN", "Line In Jack",
71                         "Headphone Jack", "HP_OUT",
72                         "Speaker Ext", "LINE_OUT";
73
74                 simple-audio-card,cpu {
75                         sound-dai = <&sai4>;
76                         frame-master;
77                         bitclock-master;
78                 };
79
80                 simple-audio-card,codec {
81                         sound-dai = <&sgtl5000>;
82                         frame-master;
83                         bitclock-master;
84                         system-clock-frequency = <25000000>;
85                 };
86         };
87 };
88
89 &can0 {
90         status = "okay";
91
92         can-transceiver {
93                 max-bitrate = <5000000>;
94         };
95 };
96
97 &can1 {
98         status = "okay";
99
100         can-transceiver {
101                 max-bitrate = <5000000>;
102         };
103 };
104
105 &esdhc {
106         sd-uhs-sdr104;
107         sd-uhs-sdr50;
108         sd-uhs-sdr25;
109         sd-uhs-sdr12;
110         status = "okay";
111 };
112
113 &esdhc1 {
114         mmc-hs200-1_8v;
115         mmc-hs400-1_8v;
116         bus-width = <8>;
117         status = "okay";
118 };
119
120 &fspi {
121         status = "okay";
122
123         mt35xu02g0: flash@0 {
124                 compatible = "jedec,spi-nor";
125                 #address-cells = <1>;
126                 #size-cells = <1>;
127                 spi-max-frequency = <50000000>;
128                 /* The following setting enables 1-1-8 (CMD-ADDR-DATA) mode */
129                 spi-rx-bus-width = <8>; /* 8 SPI Rx lines */
130                 spi-tx-bus-width = <1>; /* 1 SPI Tx line */
131                 reg = <0>;
132         };
133 };
134
135 &i2c0 {
136         status = "okay";
137
138         i2c-mux@77 {
139                 compatible = "nxp,pca9847";
140                 reg = <0x77>;
141                 #address-cells = <1>;
142                 #size-cells = <0>;
143
144                 i2c@1 {
145                         #address-cells = <1>;
146                         #size-cells = <0>;
147                         reg = <0x1>;
148
149                         sgtl5000: audio-codec@a {
150                                 #sound-dai-cells = <0>;
151                                 compatible = "fsl,sgtl5000";
152                                 reg = <0xa>;
153                                 VDDA-supply = <&reg_1p8v>;
154                                 VDDIO-supply = <&reg_1p8v>;
155                                 clocks = <&sys_mclk>;
156                                 sclk-strength = <3>;
157                         };
158                 };
159
160                 i2c@2 {
161                         #address-cells = <1>;
162                         #size-cells = <0>;
163                         reg = <0x02>;
164
165                         current-monitor@40 {
166                                 compatible = "ti,ina220";
167                                 reg = <0x40>;
168                                 shunt-resistor = <500>;
169                         };
170                 };
171
172                 i2c@3 {
173                         #address-cells = <1>;
174                         #size-cells = <0>;
175                         reg = <0x3>;
176
177                         temperature-sensor@4c {
178                                 compatible = "nxp,sa56004";
179                                 reg = <0x4c>;
180                                 vcc-supply = <&sb_3v3>;
181                         };
182
183                         rtc@51 {
184                                 compatible = "nxp,pcf2129";
185                                 reg = <0x51>;
186                         };
187                 };
188         };
189 };
190
191 &duart0 {
192         status = "okay";
193 };
194
195 &duart1 {
196         status = "okay";
197 };
198
199 &enetc_mdio_pf3 {
200         /* VSC8514 QSGMII quad PHY */
201         qsgmii_phy0: ethernet-phy@10 {
202                 reg = <0x10>;
203         };
204
205         qsgmii_phy1: ethernet-phy@11 {
206                 reg = <0x11>;
207         };
208
209         qsgmii_phy2: ethernet-phy@12 {
210                 reg = <0x12>;
211         };
212
213         qsgmii_phy3: ethernet-phy@13 {
214                 reg = <0x13>;
215         };
216 };
217
218 &enetc_port0 {
219         phy-handle = <&sgmii_phy0>;
220         phy-connection-type = "sgmii";
221         managed = "in-band-status";
222         status = "okay";
223
224         mdio {
225                 #address-cells = <1>;
226                 #size-cells = <0>;
227                 sgmii_phy0: ethernet-phy@2 {
228                         reg = <0x2>;
229                 };
230         };
231 };
232
233 &enetc_port2 {
234         status = "okay";
235 };
236
237 &mscc_felix {
238         status = "okay";
239 };
240
241 &mscc_felix_port0 {
242         label = "swp0";
243         managed = "in-band-status";
244         phy-handle = <&qsgmii_phy0>;
245         phy-mode = "qsgmii";
246         status = "okay";
247 };
248
249 &mscc_felix_port1 {
250         label = "swp1";
251         managed = "in-band-status";
252         phy-handle = <&qsgmii_phy1>;
253         phy-mode = "qsgmii";
254         status = "okay";
255 };
256
257 &mscc_felix_port2 {
258         label = "swp2";
259         managed = "in-band-status";
260         phy-handle = <&qsgmii_phy2>;
261         phy-mode = "qsgmii";
262         status = "okay";
263 };
264
265 &mscc_felix_port3 {
266         label = "swp3";
267         managed = "in-band-status";
268         phy-handle = <&qsgmii_phy3>;
269         phy-mode = "qsgmii";
270         status = "okay";
271 };
272
273 &mscc_felix_port4 {
274         ethernet = <&enetc_port2>;
275         status = "okay";
276 };
277
278 &optee {
279         status = "okay";
280 };
281
282 &sai4 {
283         status = "okay";
284 };
285
286 &sata {
287         status = "okay";
288 };
289
290 &usb1 {
291         dr_mode = "otg";
292 };