xref: /freebsd-src/sys/contrib/device-tree/src/arm/allwinner/sun8i-r40-bananapi-m2-ultra.dts (revision 7d0873ebb83b19ba1e8a89e679470d885efe12e3)
1f126890aSEmmanuel Vadot/*
2f126890aSEmmanuel Vadot * Copyright (C) 2017 Chen-Yu Tsai <wens@csie.org>
3f126890aSEmmanuel Vadot * Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
4f126890aSEmmanuel Vadot *
5f126890aSEmmanuel Vadot * This file is dual-licensed: you can use it either under the terms
6f126890aSEmmanuel Vadot * of the GPL or the X11 license, at your option. Note that this dual
7f126890aSEmmanuel Vadot * licensing only applies to this file, and not this project as a
8f126890aSEmmanuel Vadot * whole.
9f126890aSEmmanuel Vadot *
10f126890aSEmmanuel Vadot *  a) This file is free software; you can redistribute it and/or
11f126890aSEmmanuel Vadot *     modify it under the terms of the GNU General Public License as
12f126890aSEmmanuel Vadot *     published by the Free Software Foundation; either version 2 of the
13f126890aSEmmanuel Vadot *     License, or (at your option) any later version.
14f126890aSEmmanuel Vadot *
15f126890aSEmmanuel Vadot *     This file is distributed in the hope that it will be useful,
16f126890aSEmmanuel Vadot *     but WITHOUT ANY WARRANTY; without even the implied warranty of
17f126890aSEmmanuel Vadot *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18f126890aSEmmanuel Vadot *     GNU General Public License for more details.
19f126890aSEmmanuel Vadot *
20f126890aSEmmanuel Vadot * Or, alternatively,
21f126890aSEmmanuel Vadot *
22f126890aSEmmanuel Vadot *  b) Permission is hereby granted, free of charge, to any person
23f126890aSEmmanuel Vadot *     obtaining a copy of this software and associated documentation
24f126890aSEmmanuel Vadot *     files (the "Software"), to deal in the Software without
25f126890aSEmmanuel Vadot *     restriction, including without limitation the rights to use,
26f126890aSEmmanuel Vadot *     copy, modify, merge, publish, distribute, sublicense, and/or
27f126890aSEmmanuel Vadot *     sell copies of the Software, and to permit persons to whom the
28f126890aSEmmanuel Vadot *     Software is furnished to do so, subject to the following
29f126890aSEmmanuel Vadot *     conditions:
30f126890aSEmmanuel Vadot *
31f126890aSEmmanuel Vadot *     The above copyright notice and this permission notice shall be
32f126890aSEmmanuel Vadot *     included in all copies or substantial portions of the Software.
33f126890aSEmmanuel Vadot *
34f126890aSEmmanuel Vadot *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
35f126890aSEmmanuel Vadot *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
36f126890aSEmmanuel Vadot *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
37f126890aSEmmanuel Vadot *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
38f126890aSEmmanuel Vadot *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
39f126890aSEmmanuel Vadot *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
40f126890aSEmmanuel Vadot *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
41f126890aSEmmanuel Vadot *     OTHER DEALINGS IN THE SOFTWARE.
42f126890aSEmmanuel Vadot */
43f126890aSEmmanuel Vadot
44f126890aSEmmanuel Vadot/dts-v1/;
45f126890aSEmmanuel Vadot#include "sun8i-r40.dtsi"
46f126890aSEmmanuel Vadot#include "sun8i-r40-cpu-opp.dtsi"
47f126890aSEmmanuel Vadot
48f126890aSEmmanuel Vadot#include <dt-bindings/gpio/gpio.h>
49f126890aSEmmanuel Vadot
50f126890aSEmmanuel Vadot/ {
51f126890aSEmmanuel Vadot	model = "Banana Pi BPI-M2-Ultra";
52f126890aSEmmanuel Vadot	compatible = "sinovoip,bpi-m2-ultra", "allwinner,sun8i-r40";
53f126890aSEmmanuel Vadot
54f126890aSEmmanuel Vadot	aliases {
55f126890aSEmmanuel Vadot		ethernet0 = &gmac;
56f126890aSEmmanuel Vadot		serial0 = &uart0;
57f126890aSEmmanuel Vadot	};
58f126890aSEmmanuel Vadot
59f126890aSEmmanuel Vadot	chosen {
60f126890aSEmmanuel Vadot		stdout-path = "serial0:115200n8";
61f126890aSEmmanuel Vadot	};
62f126890aSEmmanuel Vadot
63f126890aSEmmanuel Vadot	connector {
64f126890aSEmmanuel Vadot		compatible = "hdmi-connector";
65f126890aSEmmanuel Vadot		type = "a";
66f126890aSEmmanuel Vadot
67f126890aSEmmanuel Vadot		port {
68f126890aSEmmanuel Vadot			hdmi_con_in: endpoint {
69f126890aSEmmanuel Vadot				remote-endpoint = <&hdmi_out_con>;
70f126890aSEmmanuel Vadot			};
71f126890aSEmmanuel Vadot		};
72f126890aSEmmanuel Vadot	};
73f126890aSEmmanuel Vadot
74f126890aSEmmanuel Vadot	leds {
75f126890aSEmmanuel Vadot		compatible = "gpio-leds";
76f126890aSEmmanuel Vadot
77f126890aSEmmanuel Vadot		pwr-led {
78f126890aSEmmanuel Vadot			label = "bananapi:red:pwr";
79f126890aSEmmanuel Vadot			gpios = <&pio 7 20 GPIO_ACTIVE_HIGH>;
80f126890aSEmmanuel Vadot			default-state = "on";
81f126890aSEmmanuel Vadot		};
82f126890aSEmmanuel Vadot
83f126890aSEmmanuel Vadot		user-led-green {
84f126890aSEmmanuel Vadot			label = "bananapi:green:user";
85f126890aSEmmanuel Vadot			gpios = <&pio 7 21 GPIO_ACTIVE_HIGH>;
86f126890aSEmmanuel Vadot		};
87f126890aSEmmanuel Vadot
88f126890aSEmmanuel Vadot		user-led-blue {
89f126890aSEmmanuel Vadot			label = "bananapi:blue:user";
90f126890aSEmmanuel Vadot			gpios = <&pio 7 22 GPIO_ACTIVE_HIGH>;
91f126890aSEmmanuel Vadot		};
92f126890aSEmmanuel Vadot	};
93f126890aSEmmanuel Vadot
94f126890aSEmmanuel Vadot	reg_vcc5v0: vcc5v0 {
95f126890aSEmmanuel Vadot		compatible = "regulator-fixed";
96f126890aSEmmanuel Vadot		regulator-name = "vcc5v0";
97f126890aSEmmanuel Vadot		regulator-min-microvolt = <5000000>;
98f126890aSEmmanuel Vadot		regulator-max-microvolt = <5000000>;
99f126890aSEmmanuel Vadot		gpio = <&pio 7 23 GPIO_ACTIVE_HIGH>; /* PH23 */
100f126890aSEmmanuel Vadot		enable-active-high;
101f126890aSEmmanuel Vadot	};
102f126890aSEmmanuel Vadot
103*7d0873ebSEmmanuel Vadot	wifi_pwrseq: pwrseq {
104f126890aSEmmanuel Vadot		compatible = "mmc-pwrseq-simple";
105f126890aSEmmanuel Vadot		reset-gpios = <&pio 6 10 GPIO_ACTIVE_LOW>; /* PG10 WIFI_EN */
106f126890aSEmmanuel Vadot		clocks = <&ccu CLK_OUTA>;
107f126890aSEmmanuel Vadot		clock-names = "ext_clock";
108f126890aSEmmanuel Vadot	};
109f126890aSEmmanuel Vadot};
110f126890aSEmmanuel Vadot
111f126890aSEmmanuel Vadot&ahci {
112f126890aSEmmanuel Vadot	ahci-supply = <&reg_dldo4>;
113f126890aSEmmanuel Vadot	phy-supply = <&reg_eldo3>;
114f126890aSEmmanuel Vadot	status = "okay";
115f126890aSEmmanuel Vadot};
116f126890aSEmmanuel Vadot
117f126890aSEmmanuel Vadot&cpu0 {
118f126890aSEmmanuel Vadot	cpu-supply = <&reg_dcdc2>;
119f126890aSEmmanuel Vadot};
120f126890aSEmmanuel Vadot
121f126890aSEmmanuel Vadot&de {
122f126890aSEmmanuel Vadot	status = "okay";
123f126890aSEmmanuel Vadot};
124f126890aSEmmanuel Vadot
125f126890aSEmmanuel Vadot&ehci1 {
126f126890aSEmmanuel Vadot	status = "okay";
127f126890aSEmmanuel Vadot};
128f126890aSEmmanuel Vadot
129f126890aSEmmanuel Vadot&ehci2 {
130f126890aSEmmanuel Vadot	status = "okay";
131f126890aSEmmanuel Vadot};
132f126890aSEmmanuel Vadot
133f126890aSEmmanuel Vadot&gmac {
134f126890aSEmmanuel Vadot	pinctrl-names = "default";
135f126890aSEmmanuel Vadot	pinctrl-0 = <&gmac_rgmii_pins>;
136f126890aSEmmanuel Vadot	phy-handle = <&phy1>;
137f126890aSEmmanuel Vadot	phy-mode = "rgmii-id";
138f126890aSEmmanuel Vadot	phy-supply = <&reg_dc1sw>;
139f126890aSEmmanuel Vadot	status = "okay";
140f126890aSEmmanuel Vadot};
141f126890aSEmmanuel Vadot
142f126890aSEmmanuel Vadot&gmac_mdio {
143f126890aSEmmanuel Vadot	phy1: ethernet-phy@1 {
144f126890aSEmmanuel Vadot		compatible = "ethernet-phy-ieee802.3-c22";
145f126890aSEmmanuel Vadot		reg = <1>;
146f126890aSEmmanuel Vadot	};
147f126890aSEmmanuel Vadot};
148f126890aSEmmanuel Vadot
149f126890aSEmmanuel Vadot&hdmi {
150f126890aSEmmanuel Vadot	status = "okay";
151f126890aSEmmanuel Vadot};
152f126890aSEmmanuel Vadot
153f126890aSEmmanuel Vadot&hdmi_out {
154f126890aSEmmanuel Vadot	hdmi_out_con: endpoint {
155f126890aSEmmanuel Vadot		remote-endpoint = <&hdmi_con_in>;
156f126890aSEmmanuel Vadot	};
157f126890aSEmmanuel Vadot};
158f126890aSEmmanuel Vadot
159f126890aSEmmanuel Vadot&i2c0 {
160f126890aSEmmanuel Vadot	status = "okay";
161f126890aSEmmanuel Vadot
162f126890aSEmmanuel Vadot	axp22x: pmic@34 {
163f126890aSEmmanuel Vadot		compatible = "x-powers,axp221";
164f126890aSEmmanuel Vadot		reg = <0x34>;
165f126890aSEmmanuel Vadot		interrupt-parent = <&nmi_intc>;
166f126890aSEmmanuel Vadot		interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
167f126890aSEmmanuel Vadot	};
168f126890aSEmmanuel Vadot};
169f126890aSEmmanuel Vadot
170f126890aSEmmanuel Vadot#include "axp22x.dtsi"
171f126890aSEmmanuel Vadot
172f126890aSEmmanuel Vadot&ir0 {
173f126890aSEmmanuel Vadot	status = "okay";
174f126890aSEmmanuel Vadot};
175f126890aSEmmanuel Vadot
176f126890aSEmmanuel Vadot&mmc0 {
177f126890aSEmmanuel Vadot	vmmc-supply = <&reg_dcdc1>;
178f126890aSEmmanuel Vadot	bus-width = <4>;
179f126890aSEmmanuel Vadot	cd-gpios = <&pio 7 13 GPIO_ACTIVE_LOW>; /* PH13 */
180f126890aSEmmanuel Vadot	status = "okay";
181f126890aSEmmanuel Vadot};
182f126890aSEmmanuel Vadot
183f126890aSEmmanuel Vadot&mmc1 {
184f126890aSEmmanuel Vadot	pinctrl-names = "default";
185f126890aSEmmanuel Vadot	pinctrl-0 = <&mmc1_pg_pins>;
186f126890aSEmmanuel Vadot	vmmc-supply = <&reg_dldo2>;
187f126890aSEmmanuel Vadot	vqmmc-supply = <&reg_dldo1>;
188f126890aSEmmanuel Vadot	mmc-pwrseq = <&wifi_pwrseq>;
189f126890aSEmmanuel Vadot	bus-width = <4>;
190f126890aSEmmanuel Vadot	non-removable;
191f126890aSEmmanuel Vadot	status = "okay";
192f126890aSEmmanuel Vadot};
193f126890aSEmmanuel Vadot
194f126890aSEmmanuel Vadot&mmc2 {
195f126890aSEmmanuel Vadot	vmmc-supply = <&reg_dcdc1>;
196f126890aSEmmanuel Vadot	vqmmc-supply = <&reg_dcdc1>;
197f126890aSEmmanuel Vadot	bus-width = <8>;
198f126890aSEmmanuel Vadot	non-removable;
199f126890aSEmmanuel Vadot	status = "okay";
200f126890aSEmmanuel Vadot};
201f126890aSEmmanuel Vadot
202f126890aSEmmanuel Vadot&ohci1 {
203f126890aSEmmanuel Vadot	status = "okay";
204f126890aSEmmanuel Vadot};
205f126890aSEmmanuel Vadot
206f126890aSEmmanuel Vadot&ohci2 {
207f126890aSEmmanuel Vadot	status = "okay";
208f126890aSEmmanuel Vadot};
209f126890aSEmmanuel Vadot
210f126890aSEmmanuel Vadot&pio {
211f126890aSEmmanuel Vadot	pinctrl-names = "default";
212f126890aSEmmanuel Vadot	pinctrl-0 = <&clk_out_a_pin>;
213f126890aSEmmanuel Vadot	vcc-pa-supply = <&reg_aldo2>;
214f126890aSEmmanuel Vadot	vcc-pc-supply = <&reg_dcdc1>;
215f126890aSEmmanuel Vadot	vcc-pd-supply = <&reg_dcdc1>;
216f126890aSEmmanuel Vadot	vcc-pe-supply = <&reg_eldo1>;
217f126890aSEmmanuel Vadot	vcc-pf-supply = <&reg_dcdc1>;
218f126890aSEmmanuel Vadot	vcc-pg-supply = <&reg_dldo1>;
219f126890aSEmmanuel Vadot};
220f126890aSEmmanuel Vadot
221f126890aSEmmanuel Vadot&reg_aldo2 {
222f126890aSEmmanuel Vadot	regulator-min-microvolt = <2500000>;
223f126890aSEmmanuel Vadot	regulator-max-microvolt = <2500000>;
224f126890aSEmmanuel Vadot	regulator-name = "vcc-pa";
225f126890aSEmmanuel Vadot};
226f126890aSEmmanuel Vadot
227f126890aSEmmanuel Vadot&reg_aldo3 {
228f126890aSEmmanuel Vadot	regulator-always-on;
229f126890aSEmmanuel Vadot	regulator-min-microvolt = <2700000>;
230f126890aSEmmanuel Vadot	regulator-max-microvolt = <3300000>;
231f126890aSEmmanuel Vadot	regulator-name = "avcc";
232f126890aSEmmanuel Vadot};
233f126890aSEmmanuel Vadot
234f126890aSEmmanuel Vadot&reg_dc1sw {
235f126890aSEmmanuel Vadot	regulator-min-microvolt = <3300000>;
236f126890aSEmmanuel Vadot	regulator-max-microvolt = <3300000>;
237f126890aSEmmanuel Vadot	regulator-name = "vcc-gmac-phy";
238f126890aSEmmanuel Vadot};
239f126890aSEmmanuel Vadot
240f126890aSEmmanuel Vadot&reg_dcdc1 {
241f126890aSEmmanuel Vadot	regulator-always-on;
242f126890aSEmmanuel Vadot	regulator-min-microvolt = <3300000>;
243f126890aSEmmanuel Vadot	regulator-max-microvolt = <3300000>;
244f126890aSEmmanuel Vadot	regulator-name = "vcc-3v3";
245f126890aSEmmanuel Vadot};
246f126890aSEmmanuel Vadot
247f126890aSEmmanuel Vadot&reg_dcdc2 {
248f126890aSEmmanuel Vadot	regulator-always-on;
249f126890aSEmmanuel Vadot	regulator-min-microvolt = <1000000>;
250f126890aSEmmanuel Vadot	regulator-max-microvolt = <1300000>;
251f126890aSEmmanuel Vadot	regulator-name = "vdd-cpu";
252f126890aSEmmanuel Vadot};
253f126890aSEmmanuel Vadot
254f126890aSEmmanuel Vadot&reg_dcdc3 {
255f126890aSEmmanuel Vadot	regulator-always-on;
256f126890aSEmmanuel Vadot	regulator-min-microvolt = <1000000>;
257f126890aSEmmanuel Vadot	regulator-max-microvolt = <1300000>;
258f126890aSEmmanuel Vadot	regulator-name = "vdd-sys";
259f126890aSEmmanuel Vadot};
260f126890aSEmmanuel Vadot
261f126890aSEmmanuel Vadot&reg_dcdc5 {
262f126890aSEmmanuel Vadot	regulator-always-on;
263f126890aSEmmanuel Vadot	regulator-min-microvolt = <1500000>;
264f126890aSEmmanuel Vadot	regulator-max-microvolt = <1500000>;
265f126890aSEmmanuel Vadot	regulator-name = "vcc-dram";
266f126890aSEmmanuel Vadot};
267f126890aSEmmanuel Vadot
268f126890aSEmmanuel Vadot&reg_dldo1 {
269f126890aSEmmanuel Vadot	regulator-min-microvolt = <1800000>;
270f126890aSEmmanuel Vadot	regulator-max-microvolt = <3300000>;
271f126890aSEmmanuel Vadot	regulator-name = "vcc-wifi-io";
272f126890aSEmmanuel Vadot};
273f126890aSEmmanuel Vadot
274f126890aSEmmanuel Vadot/*
275f126890aSEmmanuel Vadot * Our WiFi chip needs both DLDO2 and DLDO3 to be powered at the same
276f126890aSEmmanuel Vadot * time, with the two being in sync, to be able to meet maximum power
277f126890aSEmmanuel Vadot * consumption during transmits. Since this is not really supported
278f126890aSEmmanuel Vadot * right now, just use the two as always on, and we will fix it later.
279f126890aSEmmanuel Vadot */
280f126890aSEmmanuel Vadot
281f126890aSEmmanuel Vadot&reg_dldo2 {
282f126890aSEmmanuel Vadot	regulator-always-on;
283f126890aSEmmanuel Vadot	regulator-min-microvolt = <3300000>;
284f126890aSEmmanuel Vadot	regulator-max-microvolt = <3300000>;
285f126890aSEmmanuel Vadot	regulator-name = "vcc-wifi";
286f126890aSEmmanuel Vadot};
287f126890aSEmmanuel Vadot
288f126890aSEmmanuel Vadot&reg_dldo3 {
289f126890aSEmmanuel Vadot	regulator-always-on;
290f126890aSEmmanuel Vadot	regulator-min-microvolt = <3300000>;
291f126890aSEmmanuel Vadot	regulator-max-microvolt = <3300000>;
292f126890aSEmmanuel Vadot	regulator-name = "vcc-wifi-2";
293f126890aSEmmanuel Vadot};
294f126890aSEmmanuel Vadot
295f126890aSEmmanuel Vadot&reg_dldo4 {
296f126890aSEmmanuel Vadot	regulator-min-microvolt = <2500000>;
297f126890aSEmmanuel Vadot	regulator-max-microvolt = <2500000>;
298f126890aSEmmanuel Vadot	regulator-name = "vdd2v5-sata";
299f126890aSEmmanuel Vadot};
300f126890aSEmmanuel Vadot
301f126890aSEmmanuel Vadot&reg_eldo3 {
302f126890aSEmmanuel Vadot	regulator-min-microvolt = <1200000>;
303f126890aSEmmanuel Vadot	regulator-max-microvolt = <1200000>;
304f126890aSEmmanuel Vadot	regulator-name = "vdd1v2-sata";
305f126890aSEmmanuel Vadot};
306f126890aSEmmanuel Vadot
307f126890aSEmmanuel Vadot&tcon_tv0 {
308f126890aSEmmanuel Vadot	status = "okay";
309f126890aSEmmanuel Vadot};
310f126890aSEmmanuel Vadot
311f126890aSEmmanuel Vadot&uart0 {
312f126890aSEmmanuel Vadot	pinctrl-names = "default";
313f126890aSEmmanuel Vadot	pinctrl-0 = <&uart0_pb_pins>;
314f126890aSEmmanuel Vadot	status = "okay";
315f126890aSEmmanuel Vadot};
316f126890aSEmmanuel Vadot
317f126890aSEmmanuel Vadot&uart3 {
318f126890aSEmmanuel Vadot	pinctrl-names = "default";
319f126890aSEmmanuel Vadot	pinctrl-0 = <&uart3_pg_pins>, <&uart3_rts_cts_pg_pins>;
320f126890aSEmmanuel Vadot	uart-has-rtscts;
321f126890aSEmmanuel Vadot	status = "okay";
322f126890aSEmmanuel Vadot
323f126890aSEmmanuel Vadot	bluetooth {
324f126890aSEmmanuel Vadot		compatible = "brcm,bcm43438-bt";
325f126890aSEmmanuel Vadot		clocks = <&ccu CLK_OUTA>;
326f126890aSEmmanuel Vadot		clock-names = "lpo";
327f126890aSEmmanuel Vadot		vbat-supply = <&reg_dldo2>;
328f126890aSEmmanuel Vadot		vddio-supply = <&reg_dldo1>;
329f126890aSEmmanuel Vadot		device-wakeup-gpios = <&pio 6 11 GPIO_ACTIVE_HIGH>; /* PG11 */
330f126890aSEmmanuel Vadot		/* TODO host wake line connected to PMIC GPIO pins */
331f126890aSEmmanuel Vadot		shutdown-gpios = <&pio 7 12 GPIO_ACTIVE_HIGH>; /* PH12 */
332f126890aSEmmanuel Vadot		max-speed = <1500000>;
333f126890aSEmmanuel Vadot	};
334f126890aSEmmanuel Vadot};
335f126890aSEmmanuel Vadot
336f126890aSEmmanuel Vadot&usbphy {
337f126890aSEmmanuel Vadot	usb1_vbus-supply = <&reg_vcc5v0>;
338f126890aSEmmanuel Vadot	usb2_vbus-supply = <&reg_vcc5v0>;
339f126890aSEmmanuel Vadot	status = "okay";
340f126890aSEmmanuel Vadot};
341