1*724ba675SRob Herring// SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause)
2*724ba675SRob Herring/*
3*724ba675SRob Herring * Copyright (C) Linaro Ltd 2019 - All Rights Reserved
4*724ba675SRob Herring * Author: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
5*724ba675SRob Herring * Copyright (C) 2020 Marek Vasut <marex@denx.de>
6*724ba675SRob Herring */
7*724ba675SRob Herring
8*724ba675SRob Herring/* Avenger96 uses DHCOR SoM configured for 1V8 IO operation */
9*724ba675SRob Herring#include "stm32mp15xx-dhcor-io1v8.dtsi"
10*724ba675SRob Herring
11*724ba675SRob Herring/ {
12*724ba675SRob Herring	aliases {
13*724ba675SRob Herring		ethernet0 = &ethernet0;
14*724ba675SRob Herring		mmc0 = &sdmmc1;
15*724ba675SRob Herring		serial0 = &uart4;
16*724ba675SRob Herring		serial1 = &uart7;
17*724ba675SRob Herring		serial2 = &usart2;
18*724ba675SRob Herring		spi0 = &qspi;
19*724ba675SRob Herring	};
20*724ba675SRob Herring
21*724ba675SRob Herring	/* XTal Q1 */
22*724ba675SRob Herring	cec_clock: clk-cec-fixed {
23*724ba675SRob Herring		#clock-cells = <0>;
24*724ba675SRob Herring		compatible = "fixed-clock";
25*724ba675SRob Herring		clock-frequency = <24000000>;
26*724ba675SRob Herring	};
27*724ba675SRob Herring
28*724ba675SRob Herring	chosen {
29*724ba675SRob Herring		stdout-path = "serial0:115200n8";
30*724ba675SRob Herring	};
31*724ba675SRob Herring
32*724ba675SRob Herring	hdmi-out {
33*724ba675SRob Herring		compatible = "hdmi-connector";
34*724ba675SRob Herring		type = "a";
35*724ba675SRob Herring
36*724ba675SRob Herring		port {
37*724ba675SRob Herring			hdmi_con: endpoint {
38*724ba675SRob Herring				remote-endpoint = <&adv7513_out>;
39*724ba675SRob Herring			};
40*724ba675SRob Herring		};
41*724ba675SRob Herring	};
42*724ba675SRob Herring
43*724ba675SRob Herring	led {
44*724ba675SRob Herring		compatible = "gpio-leds";
45*724ba675SRob Herring		led1 {
46*724ba675SRob Herring			label = "green:user0";
47*724ba675SRob Herring			gpios = <&gpioz 7 GPIO_ACTIVE_HIGH>;
48*724ba675SRob Herring			linux,default-trigger = "heartbeat";
49*724ba675SRob Herring			default-state = "off";
50*724ba675SRob Herring		};
51*724ba675SRob Herring
52*724ba675SRob Herring		led2 {
53*724ba675SRob Herring			label = "green:user1";
54*724ba675SRob Herring			gpios = <&gpiof 3 GPIO_ACTIVE_HIGH>;
55*724ba675SRob Herring			linux,default-trigger = "mmc0";
56*724ba675SRob Herring			default-state = "off";
57*724ba675SRob Herring		};
58*724ba675SRob Herring
59*724ba675SRob Herring		led3 {
60*724ba675SRob Herring			label = "green:user2";
61*724ba675SRob Herring			gpios = <&gpiog 0 GPIO_ACTIVE_HIGH>;
62*724ba675SRob Herring			linux,default-trigger = "mmc1";
63*724ba675SRob Herring			default-state = "off";
64*724ba675SRob Herring		};
65*724ba675SRob Herring
66*724ba675SRob Herring		led4 {
67*724ba675SRob Herring			label = "green:user3";
68*724ba675SRob Herring			gpios = <&gpiog 1 GPIO_ACTIVE_HIGH>;
69*724ba675SRob Herring			default-state = "off";
70*724ba675SRob Herring			panic-indicator;
71*724ba675SRob Herring		};
72*724ba675SRob Herring	};
73*724ba675SRob Herring
74*724ba675SRob Herring	sd_switch: regulator-sd_switch {
75*724ba675SRob Herring		compatible = "regulator-gpio";
76*724ba675SRob Herring		regulator-name = "sd_switch";
77*724ba675SRob Herring		regulator-min-microvolt = <1800000>;
78*724ba675SRob Herring		regulator-max-microvolt = <2900000>;
79*724ba675SRob Herring		regulator-type = "voltage";
80*724ba675SRob Herring		regulator-always-on;
81*724ba675SRob Herring
82*724ba675SRob Herring		gpios = <&gpioi 5 GPIO_ACTIVE_HIGH>;
83*724ba675SRob Herring		gpios-states = <0>;
84*724ba675SRob Herring		states = <1800000 0x1>,
85*724ba675SRob Herring			 <2900000 0x0>;
86*724ba675SRob Herring	};
87*724ba675SRob Herring
88*724ba675SRob Herring	sound {
89*724ba675SRob Herring		compatible = "audio-graph-card";
90*724ba675SRob Herring		label = "STM32-AV96-HDMI";
91*724ba675SRob Herring		dais = <&sai2a_port>;
92*724ba675SRob Herring		status = "okay";
93*724ba675SRob Herring	};
94*724ba675SRob Herring
95*724ba675SRob Herring	wlan_pwr: regulator-wlan {
96*724ba675SRob Herring		compatible = "regulator-fixed";
97*724ba675SRob Herring
98*724ba675SRob Herring		regulator-name = "wl-reg";
99*724ba675SRob Herring		regulator-min-microvolt = <3300000>;
100*724ba675SRob Herring		regulator-max-microvolt = <3300000>;
101*724ba675SRob Herring
102*724ba675SRob Herring		gpio = <&gpioz 3 GPIO_ACTIVE_HIGH>;
103*724ba675SRob Herring		enable-active-high;
104*724ba675SRob Herring	};
105*724ba675SRob Herring};
106*724ba675SRob Herring
107*724ba675SRob Herring&adc {
108*724ba675SRob Herring	pinctrl-names = "default";
109*724ba675SRob Herring	pinctrl-0 = <&adc12_ain_pins_b>;
110*724ba675SRob Herring	vdd-supply = <&vdd>;
111*724ba675SRob Herring	vdda-supply = <&vdda>;
112*724ba675SRob Herring	vref-supply = <&vdda>;
113*724ba675SRob Herring	status = "okay";
114*724ba675SRob Herring};
115*724ba675SRob Herring
116*724ba675SRob Herring&adc1 {
117*724ba675SRob Herring	channel@0 {
118*724ba675SRob Herring		reg = <0>;
119*724ba675SRob Herring		st,min-sample-time-ns = <5000>;
120*724ba675SRob Herring	};
121*724ba675SRob Herring
122*724ba675SRob Herring	channel@1 {
123*724ba675SRob Herring		reg = <1>;
124*724ba675SRob Herring		st,min-sample-time-ns = <5000>;
125*724ba675SRob Herring	};
126*724ba675SRob Herring
127*724ba675SRob Herring	channel@6 {
128*724ba675SRob Herring		reg = <6>;
129*724ba675SRob Herring		st,min-sample-time-ns = <5000>;
130*724ba675SRob Herring	};
131*724ba675SRob Herring};
132*724ba675SRob Herring
133*724ba675SRob Herring&adc2 {
134*724ba675SRob Herring	channel@0 {
135*724ba675SRob Herring		reg = <0>;
136*724ba675SRob Herring		st,min-sample-time-ns = <5000>;
137*724ba675SRob Herring	};
138*724ba675SRob Herring
139*724ba675SRob Herring	channel@1 {
140*724ba675SRob Herring		reg = <1>;
141*724ba675SRob Herring		st,min-sample-time-ns = <5000>;
142*724ba675SRob Herring	};
143*724ba675SRob Herring
144*724ba675SRob Herring	channel@2 {
145*724ba675SRob Herring		reg = <2>;
146*724ba675SRob Herring		st,min-sample-time-ns = <5000>;
147*724ba675SRob Herring	};
148*724ba675SRob Herring};
149*724ba675SRob Herring
150*724ba675SRob Herring&dcmi {
151*724ba675SRob Herring	pinctrl-names = "default", "sleep";
152*724ba675SRob Herring	pinctrl-0 = <&dcmi_pins_c>;
153*724ba675SRob Herring	pinctrl-1 = <&dcmi_sleep_pins_c>;
154*724ba675SRob Herring	status = "disabled";
155*724ba675SRob Herring
156*724ba675SRob Herring	port {
157*724ba675SRob Herring		dcmi_0: endpoint {
158*724ba675SRob Herring			remote-endpoint = <&stmipi_2>;
159*724ba675SRob Herring			bus-type = <5>;
160*724ba675SRob Herring			bus-width = <8>;
161*724ba675SRob Herring			pclk-sample = <0>;
162*724ba675SRob Herring		};
163*724ba675SRob Herring	};
164*724ba675SRob Herring};
165*724ba675SRob Herring
166*724ba675SRob Herring&ethernet0 {
167*724ba675SRob Herring	status = "okay";
168*724ba675SRob Herring	pinctrl-0 = <&ethernet0_rgmii_pins_c>;
169*724ba675SRob Herring	pinctrl-1 = <&ethernet0_rgmii_sleep_pins_c>;
170*724ba675SRob Herring	pinctrl-names = "default", "sleep";
171*724ba675SRob Herring	phy-mode = "rgmii";
172*724ba675SRob Herring	max-speed = <1000>;
173*724ba675SRob Herring	phy-handle = <&phy0>;
174*724ba675SRob Herring
175*724ba675SRob Herring	mdio {
176*724ba675SRob Herring		#address-cells = <1>;
177*724ba675SRob Herring		#size-cells = <0>;
178*724ba675SRob Herring		compatible = "snps,dwmac-mdio";
179*724ba675SRob Herring		reset-gpios = <&gpioz 2 GPIO_ACTIVE_LOW>;
180*724ba675SRob Herring		reset-delay-us = <1000>;
181*724ba675SRob Herring		reset-post-delay-us = <1000>;
182*724ba675SRob Herring
183*724ba675SRob Herring		phy0: ethernet-phy@7 {
184*724ba675SRob Herring			reg = <7>;
185*724ba675SRob Herring
186*724ba675SRob Herring			rxc-skew-ps = <1500>;
187*724ba675SRob Herring			rxdv-skew-ps = <540>;
188*724ba675SRob Herring			rxd0-skew-ps = <420>;
189*724ba675SRob Herring			rxd1-skew-ps = <420>;
190*724ba675SRob Herring			rxd2-skew-ps = <420>;
191*724ba675SRob Herring			rxd3-skew-ps = <420>;
192*724ba675SRob Herring
193*724ba675SRob Herring			txc-skew-ps = <1440>;
194*724ba675SRob Herring			txen-skew-ps = <540>;
195*724ba675SRob Herring			txd0-skew-ps = <420>;
196*724ba675SRob Herring			txd1-skew-ps = <420>;
197*724ba675SRob Herring			txd2-skew-ps = <420>;
198*724ba675SRob Herring			txd3-skew-ps = <420>;
199*724ba675SRob Herring		};
200*724ba675SRob Herring	};
201*724ba675SRob Herring};
202*724ba675SRob Herring
203*724ba675SRob Herring&gpioa {
204*724ba675SRob Herring	gpio-line-names = "", "", "", "",
205*724ba675SRob Herring			  "", "", "", "",
206*724ba675SRob Herring			  "", "", "", "AV96-K",
207*724ba675SRob Herring			  "AV96-I", "", "AV96-A", "";
208*724ba675SRob Herring};
209*724ba675SRob Herring
210*724ba675SRob Herring&gpiob {
211*724ba675SRob Herring	gpio-line-names = "", "", "", "",
212*724ba675SRob Herring			  "", "AV96-J", "", "",
213*724ba675SRob Herring			  "", "", "", "AV96-B",
214*724ba675SRob Herring			  "", "AV96-L", "", "";
215*724ba675SRob Herring};
216*724ba675SRob Herring
217*724ba675SRob Herring&gpioc {
218*724ba675SRob Herring	gpio-line-names = "", "", "", "AV96-C",
219*724ba675SRob Herring			  "", "", "", "",
220*724ba675SRob Herring			  "", "", "", "",
221*724ba675SRob Herring			  "", "", "", "";
222*724ba675SRob Herring};
223*724ba675SRob Herring
224*724ba675SRob Herring&gpiod {
225*724ba675SRob Herring	gpio-line-names = "", "", "", "",
226*724ba675SRob Herring			  "", "", "", "",
227*724ba675SRob Herring			  "AV96-D", "", "", "",
228*724ba675SRob Herring			  "", "", "AV96-E", "AV96-F";
229*724ba675SRob Herring};
230*724ba675SRob Herring
231*724ba675SRob Herring&gpiof {
232*724ba675SRob Herring	gpio-line-names = "", "", "", "",
233*724ba675SRob Herring			  "", "", "", "",
234*724ba675SRob Herring			  "", "", "", "",
235*724ba675SRob Herring			  "AV96-G", "AV96-H", "", "";
236*724ba675SRob Herring};
237*724ba675SRob Herring
238*724ba675SRob Herring&i2c1 {	/* X6 I2C1 */
239*724ba675SRob Herring	pinctrl-names = "default";
240*724ba675SRob Herring	pinctrl-0 = <&i2c1_pins_b>;
241*724ba675SRob Herring	i2c-scl-rising-time-ns = <185>;
242*724ba675SRob Herring	i2c-scl-falling-time-ns = <20>;
243*724ba675SRob Herring	status = "okay";
244*724ba675SRob Herring	/delete-property/dmas;
245*724ba675SRob Herring	/delete-property/dma-names;
246*724ba675SRob Herring};
247*724ba675SRob Herring
248*724ba675SRob Herring&i2c2 {	/* X6 I2C2 */
249*724ba675SRob Herring	pinctrl-names = "default";
250*724ba675SRob Herring	pinctrl-0 = <&i2c2_pins_c>;
251*724ba675SRob Herring	i2c-scl-rising-time-ns = <185>;
252*724ba675SRob Herring	i2c-scl-falling-time-ns = <20>;
253*724ba675SRob Herring	status = "okay";
254*724ba675SRob Herring	/delete-property/dmas;
255*724ba675SRob Herring	/delete-property/dma-names;
256*724ba675SRob Herring};
257*724ba675SRob Herring
258*724ba675SRob Herring&i2c4 {
259*724ba675SRob Herring	stmipi: stmipi@14 {
260*724ba675SRob Herring		compatible = "st,st-mipid02";
261*724ba675SRob Herring		pinctrl-names = "default", "sleep";
262*724ba675SRob Herring		pinctrl-0 = <&mco1_pins_a>;
263*724ba675SRob Herring		pinctrl-1 = <&mco1_sleep_pins_a>;
264*724ba675SRob Herring		reg = <0x14>;
265*724ba675SRob Herring		clocks = <&rcc CK_MCO1>;
266*724ba675SRob Herring		clock-names = "xclk";
267*724ba675SRob Herring		assigned-clocks = <&rcc CK_MCO1>;
268*724ba675SRob Herring		assigned-clock-parents = <&rcc CK_HSE>;
269*724ba675SRob Herring		assigned-clock-rates = <24000000>;
270*724ba675SRob Herring		VDDE-supply = <&v1v8>;
271*724ba675SRob Herring		VDDIN-supply = <&v1v8>;
272*724ba675SRob Herring		reset-gpios = <&gpioz 0 GPIO_ACTIVE_LOW>;
273*724ba675SRob Herring		status = "disabled";
274*724ba675SRob Herring
275*724ba675SRob Herring		ports {
276*724ba675SRob Herring			#address-cells = <1>;
277*724ba675SRob Herring			#size-cells = <0>;
278*724ba675SRob Herring
279*724ba675SRob Herring			port@0 {
280*724ba675SRob Herring				reg = <0>;
281*724ba675SRob Herring				stmipi_0: endpoint {
282*724ba675SRob Herring				};
283*724ba675SRob Herring			};
284*724ba675SRob Herring
285*724ba675SRob Herring			port@2 {
286*724ba675SRob Herring				reg = <2>;
287*724ba675SRob Herring				stmipi_2: endpoint {
288*724ba675SRob Herring					bus-width = <8>;
289*724ba675SRob Herring					hsync-active = <0>;
290*724ba675SRob Herring					vsync-active = <0>;
291*724ba675SRob Herring					pclk-sample = <0>;
292*724ba675SRob Herring					remote-endpoint = <&dcmi_0>;
293*724ba675SRob Herring				};
294*724ba675SRob Herring			};
295*724ba675SRob Herring		};
296*724ba675SRob Herring	};
297*724ba675SRob Herring
298*724ba675SRob Herring	hdmi-transmitter@3d {
299*724ba675SRob Herring		compatible = "adi,adv7513";
300*724ba675SRob Herring		reg = <0x3d>, <0x4d>, <0x2d>, <0x5d>;
301*724ba675SRob Herring		reg-names = "main", "edid", "cec", "packet";
302*724ba675SRob Herring		clocks = <&cec_clock>;
303*724ba675SRob Herring		clock-names = "cec";
304*724ba675SRob Herring
305*724ba675SRob Herring		avdd-supply = <&v3v3>;
306*724ba675SRob Herring		dvdd-supply = <&v3v3>;
307*724ba675SRob Herring		pvdd-supply = <&v3v3>;
308*724ba675SRob Herring		dvdd-3v-supply = <&v3v3>;
309*724ba675SRob Herring		bgvdd-supply = <&v3v3>;
310*724ba675SRob Herring
311*724ba675SRob Herring		interrupts = <9 IRQ_TYPE_EDGE_FALLING>;
312*724ba675SRob Herring		interrupt-parent = <&gpiog>;
313*724ba675SRob Herring
314*724ba675SRob Herring		status = "okay";
315*724ba675SRob Herring
316*724ba675SRob Herring		adi,input-depth = <8>;
317*724ba675SRob Herring		adi,input-colorspace = "rgb";
318*724ba675SRob Herring		adi,input-clock = "1x";
319*724ba675SRob Herring
320*724ba675SRob Herring		ports {
321*724ba675SRob Herring			#address-cells = <1>;
322*724ba675SRob Herring			#size-cells = <0>;
323*724ba675SRob Herring
324*724ba675SRob Herring			port@0 {
325*724ba675SRob Herring				reg = <0>;
326*724ba675SRob Herring				adv7513_in: endpoint {
327*724ba675SRob Herring					remote-endpoint = <&ltdc_ep0_out>;
328*724ba675SRob Herring				};
329*724ba675SRob Herring			};
330*724ba675SRob Herring
331*724ba675SRob Herring			port@1 {
332*724ba675SRob Herring				reg = <1>;
333*724ba675SRob Herring				adv7513_out: endpoint {
334*724ba675SRob Herring					remote-endpoint = <&hdmi_con>;
335*724ba675SRob Herring				};
336*724ba675SRob Herring			};
337*724ba675SRob Herring
338*724ba675SRob Herring			port@2 {
339*724ba675SRob Herring				reg = <2>;
340*724ba675SRob Herring				adv7513_i2s0: endpoint {
341*724ba675SRob Herring					remote-endpoint = <&sai2a_endpoint>;
342*724ba675SRob Herring				};
343*724ba675SRob Herring			};
344*724ba675SRob Herring		};
345*724ba675SRob Herring	};
346*724ba675SRob Herring
347*724ba675SRob Herring	dh_mac_eeprom: eeprom@53 {
348*724ba675SRob Herring		compatible = "atmel,24c02";
349*724ba675SRob Herring		reg = <0x53>;
350*724ba675SRob Herring		pagesize = <16>;
351*724ba675SRob Herring	};
352*724ba675SRob Herring};
353*724ba675SRob Herring
354*724ba675SRob Herring&ltdc {
355*724ba675SRob Herring	pinctrl-names = "default", "sleep";
356*724ba675SRob Herring	pinctrl-0 = <&ltdc_pins_d>;
357*724ba675SRob Herring	pinctrl-1 = <&ltdc_sleep_pins_d>;
358*724ba675SRob Herring	status = "okay";
359*724ba675SRob Herring
360*724ba675SRob Herring	port {
361*724ba675SRob Herring		ltdc_ep0_out: endpoint {
362*724ba675SRob Herring			remote-endpoint = <&adv7513_in>;
363*724ba675SRob Herring		};
364*724ba675SRob Herring	};
365*724ba675SRob Herring};
366*724ba675SRob Herring
367*724ba675SRob Herring&sai2 {
368*724ba675SRob Herring	clocks = <&rcc SAI2>, <&rcc PLL3_Q>, <&rcc PLL3_R>;
369*724ba675SRob Herring	pinctrl-names = "default", "sleep";
370*724ba675SRob Herring	pinctrl-0 = <&sai2a_pins_c>;
371*724ba675SRob Herring	pinctrl-1 = <&sai2a_sleep_pins_c>;
372*724ba675SRob Herring	clock-names = "pclk", "x8k", "x11k";
373*724ba675SRob Herring	status = "okay";
374*724ba675SRob Herring
375*724ba675SRob Herring	sai2a: audio-controller@4400b004 {
376*724ba675SRob Herring		#clock-cells = <0>;
377*724ba675SRob Herring		dma-names = "tx";
378*724ba675SRob Herring		clocks = <&rcc SAI2_K>;
379*724ba675SRob Herring		clock-names = "sai_ck";
380*724ba675SRob Herring		status = "okay";
381*724ba675SRob Herring
382*724ba675SRob Herring		sai2a_port: port {
383*724ba675SRob Herring			sai2a_endpoint: endpoint {
384*724ba675SRob Herring				remote-endpoint = <&adv7513_i2s0>;
385*724ba675SRob Herring				dai-format = "i2s";
386*724ba675SRob Herring				mclk-fs = <256>;
387*724ba675SRob Herring			};
388*724ba675SRob Herring		};
389*724ba675SRob Herring	};
390*724ba675SRob Herring};
391*724ba675SRob Herring
392*724ba675SRob Herring&sdmmc1 {
393*724ba675SRob Herring	pinctrl-names = "default", "opendrain", "sleep";
394*724ba675SRob Herring	pinctrl-0 = <&sdmmc1_b4_pins_a &sdmmc1_dir_pins_b>;
395*724ba675SRob Herring	pinctrl-1 = <&sdmmc1_b4_od_pins_a &sdmmc1_dir_pins_b>;
396*724ba675SRob Herring	pinctrl-2 = <&sdmmc1_b4_sleep_pins_a &sdmmc1_dir_sleep_pins_b>;
397*724ba675SRob Herring	cd-gpios = <&gpioi 8 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>;
398*724ba675SRob Herring	disable-wp;
399*724ba675SRob Herring	st,sig-dir;
400*724ba675SRob Herring	st,neg-edge;
401*724ba675SRob Herring	st,use-ckin;
402*724ba675SRob Herring	bus-width = <4>;
403*724ba675SRob Herring	vmmc-supply = <&vdd_sd>;
404*724ba675SRob Herring	vqmmc-supply = <&sd_switch>;
405*724ba675SRob Herring	status = "okay";
406*724ba675SRob Herring};
407*724ba675SRob Herring
408*724ba675SRob Herring&sdmmc2 {
409*724ba675SRob Herring	pinctrl-names = "default", "opendrain", "sleep";
410*724ba675SRob Herring	pinctrl-0 = <&sdmmc2_b4_pins_a &sdmmc2_d47_pins_c>;
411*724ba675SRob Herring	pinctrl-1 = <&sdmmc2_b4_od_pins_a &sdmmc2_d47_pins_c>;
412*724ba675SRob Herring	pinctrl-2 = <&sdmmc2_b4_sleep_pins_a &sdmmc2_d47_sleep_pins_c>;
413*724ba675SRob Herring	bus-width = <8>;
414*724ba675SRob Herring	mmc-ddr-1_8v;
415*724ba675SRob Herring	no-sd;
416*724ba675SRob Herring	no-sdio;
417*724ba675SRob Herring	non-removable;
418*724ba675SRob Herring	st,neg-edge;
419*724ba675SRob Herring	vmmc-supply = <&v3v3>;
420*724ba675SRob Herring	vqmmc-supply = <&vdd_io>;
421*724ba675SRob Herring	status = "okay";
422*724ba675SRob Herring};
423*724ba675SRob Herring
424*724ba675SRob Herring&sdmmc3 {
425*724ba675SRob Herring	pinctrl-names = "default", "opendrain", "sleep";
426*724ba675SRob Herring	pinctrl-0 = <&sdmmc3_b4_pins_b>;
427*724ba675SRob Herring	pinctrl-1 = <&sdmmc3_b4_od_pins_b>;
428*724ba675SRob Herring	pinctrl-2 = <&sdmmc3_b4_sleep_pins_b>;
429*724ba675SRob Herring	broken-cd;
430*724ba675SRob Herring	non-removable;
431*724ba675SRob Herring	st,neg-edge;
432*724ba675SRob Herring	bus-width = <4>;
433*724ba675SRob Herring	vmmc-supply = <&wlan_pwr>;
434*724ba675SRob Herring	status = "okay";
435*724ba675SRob Herring
436*724ba675SRob Herring	#address-cells = <1>;
437*724ba675SRob Herring	#size-cells = <0>;
438*724ba675SRob Herring	brcmf: bcrmf@1 {
439*724ba675SRob Herring		reg = <1>;
440*724ba675SRob Herring		compatible = "brcm,bcm4329-fmac";
441*724ba675SRob Herring	};
442*724ba675SRob Herring};
443*724ba675SRob Herring
444*724ba675SRob Herring&spi2 {
445*724ba675SRob Herring	pinctrl-names = "default";
446*724ba675SRob Herring	pinctrl-0 = <&spi2_pins_a>;
447*724ba675SRob Herring	cs-gpios = <&gpioi 0 0>;
448*724ba675SRob Herring	status = "disabled";
449*724ba675SRob Herring	/delete-property/dmas;
450*724ba675SRob Herring	/delete-property/dma-names;
451*724ba675SRob Herring};
452*724ba675SRob Herring
453*724ba675SRob Herring&uart4 {
454*724ba675SRob Herring	/* On Low speed expansion header */
455*724ba675SRob Herring	label = "LS-UART1";
456*724ba675SRob Herring	pinctrl-names = "default";
457*724ba675SRob Herring	pinctrl-0 = <&uart4_pins_b>;
458*724ba675SRob Herring	/delete-property/dmas;
459*724ba675SRob Herring	/delete-property/dma-names;
460*724ba675SRob Herring	status = "okay";
461*724ba675SRob Herring};
462*724ba675SRob Herring
463*724ba675SRob Herring&uart7 {
464*724ba675SRob Herring	/* On Low speed expansion header */
465*724ba675SRob Herring	label = "LS-UART0";
466*724ba675SRob Herring	pinctrl-names = "default";
467*724ba675SRob Herring	pinctrl-0 = <&uart7_pins_a>;
468*724ba675SRob Herring	uart-has-rtscts;
469*724ba675SRob Herring	/delete-property/dmas;
470*724ba675SRob Herring	/delete-property/dma-names;
471*724ba675SRob Herring	status = "okay";
472*724ba675SRob Herring};
473*724ba675SRob Herring
474*724ba675SRob Herring/* Bluetooth */
475*724ba675SRob Herring&usart2 {
476*724ba675SRob Herring	pinctrl-names = "default", "sleep";
477*724ba675SRob Herring	pinctrl-0 = <&usart2_pins_a>;
478*724ba675SRob Herring	pinctrl-1 = <&usart2_sleep_pins_a>;
479*724ba675SRob Herring	uart-has-rtscts;
480*724ba675SRob Herring	/delete-property/dmas;
481*724ba675SRob Herring	/delete-property/dma-names;
482*724ba675SRob Herring	status = "okay";
483*724ba675SRob Herring
484*724ba675SRob Herring	bluetooth {
485*724ba675SRob Herring		compatible = "brcm,bcm43438-bt";
486*724ba675SRob Herring		max-speed = <3000000>;
487*724ba675SRob Herring		shutdown-gpios = <&gpioz 6 GPIO_ACTIVE_HIGH>;
488*724ba675SRob Herring	};
489*724ba675SRob Herring};
490*724ba675SRob Herring
491*724ba675SRob Herring&usbh_ehci {
492*724ba675SRob Herring	phys = <&usbphyc_port0>;
493*724ba675SRob Herring	phy-names = "usb";
494*724ba675SRob Herring	status = "okay";
495*724ba675SRob Herring};
496*724ba675SRob Herring
497*724ba675SRob Herring&usbotg_hs {
498*724ba675SRob Herring	pinctrl-0 = <&usbotg_hs_pins_a>;
499*724ba675SRob Herring	pinctrl-names = "default";
500*724ba675SRob Herring	phy-names = "usb2-phy";
501*724ba675SRob Herring	phys = <&usbphyc_port1 0>;
502*724ba675SRob Herring	status = "okay";
503*724ba675SRob Herring	vbus-supply = <&vbus_otg>;
504*724ba675SRob Herring};
505*724ba675SRob Herring
506*724ba675SRob Herring&usbphyc {
507*724ba675SRob Herring	status = "okay";
508*724ba675SRob Herring};
509*724ba675SRob Herring
510*724ba675SRob Herring&usbphyc_port0 {
511*724ba675SRob Herring	phy-supply = <&vdd_usb>;
512*724ba675SRob Herring};
513*724ba675SRob Herring
514*724ba675SRob Herring&usbphyc_port1 {
515*724ba675SRob Herring	phy-supply = <&vdd_usb>;
516*724ba675SRob Herring};
517