blob: 1de0a172aa5f18cab18503ee6c6503d78be3f235 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001// SPDX-License-Identifier: (GPL-2.0 OR MIT)
2/*
3 * Device Tree file for Marvell Armada 385 development board
4 * (RD-88F6820-GP)
5 *
6 * Copyright (C) 2014 Marvell
7 *
8 * Gregory CLEMENT <gregory.clement@free-electrons.com>
9 */
10
11/dts-v1/;
12#include "armada-388.dtsi"
13#include <dt-bindings/gpio/gpio.h>
14
15/ {
16 model = "Marvell Armada 388 DB-88F6820-GP";
17 compatible = "marvell,a388-gp", "marvell,armada388", "marvell,armada380";
18
19 chosen {
20 stdout-path = "serial0:115200n8";
21 };
22
23 memory {
24 device_type = "memory";
25 reg = <0x00000000 0x80000000>; /* 2 GB */
26 };
27
28 soc {
29 ranges = <MBUS_ID(0xf0, 0x01) 0 0xf1000000 0x100000
30 MBUS_ID(0x01, 0x1d) 0 0xfff00000 0x100000
31 MBUS_ID(0x09, 0x19) 0 0xf1100000 0x10000
32 MBUS_ID(0x09, 0x15) 0 0xf1110000 0x10000
33 MBUS_ID(0x0c, 0x04) 0 0xf1200000 0x100000>;
34
35 internal-regs {
36 i2c@11000 {
37 pinctrl-names = "default";
38 pinctrl-0 = <&i2c0_pins>;
39 status = "okay";
40 clock-frequency = <100000>;
41
42 expander0: pca9555@20 {
43 compatible = "nxp,pca9555";
44 pinctrl-names = "default";
45 pinctrl-0 = <&pca0_pins>;
46 interrupt-parent = <&gpio0>;
47 interrupts = <18 IRQ_TYPE_LEVEL_LOW>;
48 gpio-controller;
49 #gpio-cells = <2>;
50 interrupt-controller;
51 #interrupt-cells = <2>;
52 reg = <0x20>;
53 };
54
55 expander1: pca9555@21 {
56 compatible = "nxp,pca9555";
57 pinctrl-names = "default";
58 interrupt-parent = <&gpio0>;
59 interrupts = <18 IRQ_TYPE_LEVEL_LOW>;
60 gpio-controller;
61 #gpio-cells = <2>;
62 interrupt-controller;
63 #interrupt-cells = <2>;
64 reg = <0x21>;
65 };
66
67 eeprom@57 {
68 compatible = "atmel,24c64";
69 reg = <0x57>;
70 };
71 };
72
73 serial@12000 {
74 /*
75 * Exported on the micro USB connector CON16
76 * through an FTDI
77 */
78
79 pinctrl-names = "default";
80 pinctrl-0 = <&uart0_pins>;
81 status = "okay";
82 };
83
84 /* GE1 CON15 */
85 ethernet@30000 {
86 pinctrl-names = "default";
87 pinctrl-0 = <&ge1_rgmii_pins>;
88 status = "okay";
89 phy = <&phy1>;
90 phy-mode = "rgmii-id";
91 buffer-manager = <&bm>;
92 bm,pool-long = <2>;
93 bm,pool-short = <3>;
94 };
95
96 /* CON4 */
97 usb@58000 {
98 vcc-supply = <&reg_usb2_0_vbus>;
99 status = "okay";
100 };
101
102 /* GE0 CON1 */
103 ethernet@70000 {
104 pinctrl-names = "default";
105 /*
106 * The Reference Clock 0 is used to provide a
107 * clock to the PHY
108 */
109 pinctrl-0 = <&ge0_rgmii_pins>, <&ref_clk0_pins>;
110 status = "okay";
111 phy = <&phy0>;
112 phy-mode = "rgmii-id";
113 buffer-manager = <&bm>;
114 bm,pool-long = <0>;
115 bm,pool-short = <1>;
116 };
117
118
119 mdio@72004 {
120 pinctrl-names = "default";
121 pinctrl-0 = <&mdio_pins>;
122
123 phy0: ethernet-phy@1 {
124 reg = <1>;
125 };
126
127 phy1: ethernet-phy@0 {
128 reg = <0>;
129 };
130 };
131
132 sata@a8000 {
133 pinctrl-names = "default";
134 pinctrl-0 = <&sata0_pins>, <&sata1_pins>;
135 status = "okay";
136 #address-cells = <1>;
137 #size-cells = <0>;
138
139 sata0: sata-port@0 {
140 reg = <0>;
141 target-supply = <&reg_5v_sata0>;
142 };
143
144 sata1: sata-port@1 {
145 reg = <1>;
146 target-supply = <&reg_5v_sata1>;
147 };
148 };
149
150 bm@c8000 {
151 status = "okay";
152 };
153
154 sata@e0000 {
155 pinctrl-names = "default";
156 pinctrl-0 = <&sata2_pins>, <&sata3_pins>;
157 status = "okay";
158 #address-cells = <1>;
159 #size-cells = <0>;
160
161 sata2: sata-port@0 {
162 reg = <0>;
163 target-supply = <&reg_5v_sata2>;
164 };
165
166 sata3: sata-port@1 {
167 reg = <1>;
168 target-supply = <&reg_5v_sata3>;
169 };
170 };
171
172 sdhci@d8000 {
173 pinctrl-names = "default";
174 pinctrl-0 = <&sdhci_pins>;
175 no-1-8-v;
176 /*
177 * A388-GP board v1.5 and higher replace
178 * hitherto card detection method based on GPIO
179 * with the one using DAT3 pin. As they are
180 * incompatible, software-based polling is
181 * enabled with 'broken-cd' property. For boards
182 * older than v1.5 it can be replaced with:
183 * 'cd-gpios = <&expander0 5 GPIO_ACTIVE_LOW>;',
184 * whereas for the newer ones following can be
185 * used instead:
186 * 'dat3-cd;'
187 * 'cd-inverted;'
188 */
189 broken-cd;
190 wp-inverted;
191 bus-width = <8>;
192 status = "okay";
193 };
194
195 /* CON5 */
196 usb3@f0000 {
197 usb-phy = <&usb2_1_phy>;
198 status = "okay";
199 };
200
201 /* CON7 */
202 usb3@f8000 {
203 usb-phy = <&usb3_phy>;
204 status = "okay";
205 };
206 };
207
208 bm-bppi {
209 status = "okay";
210 };
211
212 pcie {
213 status = "okay";
214 /*
215 * One PCIe units is accessible through
216 * standard PCIe slot on the board.
217 */
218 pcie@1,0 {
219 /* Port 0, Lane 0 */
220 status = "okay";
221 };
222
223 /*
224 * The two other PCIe units are accessible
225 * through mini PCIe slot on the board.
226 */
227 pcie@2,0 {
228 /* Port 1, Lane 0 */
229 status = "okay";
230 };
231 pcie@3,0 {
232 /* Port 2, Lane 0 */
233 status = "okay";
234 };
235 };
236
237 gpio-fan {
238 compatible = "gpio-fan";
239 gpios = <&expander1 3 GPIO_ACTIVE_HIGH>;
Tom Rini93743d22024-04-01 09:08:13 -0400240 gpio-fan,speed-map = < 0 0>,
241 <3000 1>;
Tom Rini53633a82024-02-29 12:33:36 -0500242 };
243 };
244
245 usb2_1_phy: usb2_1_phy {
246 compatible = "usb-nop-xceiv";
247 vcc-supply = <&reg_usb2_1_vbus>;
248 #phy-cells = <0>;
249 };
250
251 usb3_phy: usb3_phy {
252 compatible = "usb-nop-xceiv";
253 vcc-supply = <&reg_usb3_vbus>;
254 #phy-cells = <0>;
255 };
256
257 reg_usb3_vbus: usb3-vbus {
258 compatible = "regulator-fixed";
259 regulator-name = "usb3-vbus";
260 regulator-min-microvolt = <5000000>;
261 regulator-max-microvolt = <5000000>;
262 enable-active-high;
263 gpio = <&expander1 15 GPIO_ACTIVE_HIGH>;
264 };
265
266 reg_usb2_0_vbus: v5-vbus0 {
267 compatible = "regulator-fixed";
268 regulator-name = "v5.0-vbus0";
269 regulator-min-microvolt = <5000000>;
270 regulator-max-microvolt = <5000000>;
271 enable-active-high;
272 regulator-always-on;
273 gpio = <&expander1 14 GPIO_ACTIVE_HIGH>;
274 };
275
276 reg_usb2_1_vbus: v5-vbus1 {
277 compatible = "regulator-fixed";
278 regulator-name = "v5.0-vbus1";
279 regulator-min-microvolt = <5000000>;
280 regulator-max-microvolt = <5000000>;
281 enable-active-high;
282 gpio = <&expander0 4 GPIO_ACTIVE_HIGH>;
283 };
284
285 reg_sata0: pwr-sata0 {
286 compatible = "regulator-fixed";
287 regulator-name = "pwr_en_sata0";
288 regulator-min-microvolt = <12000000>;
289 regulator-max-microvolt = <12000000>;
290 enable-active-high;
291 regulator-boot-on;
292 gpio = <&expander0 2 GPIO_ACTIVE_HIGH>;
293 };
294
295 reg_5v_sata0: v5-sata0 {
296 compatible = "regulator-fixed";
297 regulator-name = "v5.0-sata0";
298 regulator-min-microvolt = <5000000>;
299 regulator-max-microvolt = <5000000>;
300 vin-supply = <&reg_sata0>;
301 };
302
303 reg_12v_sata0: v12-sata0 {
304 compatible = "regulator-fixed";
305 regulator-name = "v12.0-sata0";
306 regulator-min-microvolt = <12000000>;
307 regulator-max-microvolt = <12000000>;
308 vin-supply = <&reg_sata0>;
309 };
310
311 reg_sata1: pwr-sata1 {
312 regulator-name = "pwr_en_sata1";
313 compatible = "regulator-fixed";
314 regulator-min-microvolt = <12000000>;
315 regulator-max-microvolt = <12000000>;
316 enable-active-high;
317 regulator-boot-on;
318 gpio = <&expander0 3 GPIO_ACTIVE_HIGH>;
319 };
320
321 reg_5v_sata1: v5-sata1 {
322 compatible = "regulator-fixed";
323 regulator-name = "v5.0-sata1";
324 regulator-min-microvolt = <5000000>;
325 regulator-max-microvolt = <5000000>;
326 vin-supply = <&reg_sata1>;
327 };
328
329 reg_12v_sata1: v12-sata1 {
330 compatible = "regulator-fixed";
331 regulator-name = "v12.0-sata1";
332 regulator-min-microvolt = <12000000>;
333 regulator-max-microvolt = <12000000>;
334 vin-supply = <&reg_sata1>;
335 };
336
337 reg_sata2: pwr-sata2 {
338 compatible = "regulator-fixed";
339 regulator-name = "pwr_en_sata2";
340 enable-active-high;
341 regulator-boot-on;
342 gpio = <&expander0 11 GPIO_ACTIVE_HIGH>;
343 };
344
345 reg_5v_sata2: v5-sata2 {
346 compatible = "regulator-fixed";
347 regulator-name = "v5.0-sata2";
348 regulator-min-microvolt = <5000000>;
349 regulator-max-microvolt = <5000000>;
350 vin-supply = <&reg_sata2>;
351 };
352
353 reg_12v_sata2: v12-sata2 {
354 compatible = "regulator-fixed";
355 regulator-name = "v12.0-sata2";
356 regulator-min-microvolt = <12000000>;
357 regulator-max-microvolt = <12000000>;
358 vin-supply = <&reg_sata2>;
359 };
360
361 reg_sata3: pwr-sata3 {
362 compatible = "regulator-fixed";
363 regulator-name = "pwr_en_sata3";
364 enable-active-high;
365 regulator-boot-on;
366 gpio = <&expander0 12 GPIO_ACTIVE_HIGH>;
367 };
368
369 reg_5v_sata3: v5-sata3 {
370 compatible = "regulator-fixed";
371 regulator-name = "v5.0-sata3";
372 regulator-min-microvolt = <5000000>;
373 regulator-max-microvolt = <5000000>;
374 vin-supply = <&reg_sata3>;
375 };
376
377 reg_12v_sata3: v12-sata3 {
378 compatible = "regulator-fixed";
379 regulator-name = "v12.0-sata3";
380 regulator-min-microvolt = <12000000>;
381 regulator-max-microvolt = <12000000>;
382 vin-supply = <&reg_sata3>;
383 };
384};
385
386&pinctrl {
387 pca0_pins: pca0_pins {
388 marvell,pins = "mpp18";
389 marvell,function = "gpio";
390 };
391};
392
393&spi0 {
394 pinctrl-names = "default";
395 pinctrl-0 = <&spi0_pins>;
396 status = "okay";
397
398 flash@0 {
399 #address-cells = <1>;
400 #size-cells = <1>;
401 compatible = "st,m25p128", "jedec,spi-nor";
402 reg = <0>; /* Chip select 0 */
403 spi-max-frequency = <50000000>;
404 m25p,fast-read;
405 };
406};