Linux Audio

Check our new training course

Yocto / OpenEmbedded training

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