xref: /openbmc/u-boot/arch/arm/dts/sun6i-a31-m9.dts (revision 860fbdd41f010348757926ca8f9c65dd00616d1e)
153ab4af3SHans de Goede/*
253ab4af3SHans de Goede * Copyright 2014 Hans de Goede <hdegoede@redhat.com>
353ab4af3SHans de Goede *
453ab4af3SHans de Goede * This file is dual-licensed: you can use it either under the terms
553ab4af3SHans de Goede * of the GPL or the X11 license, at your option. Note that this dual
653ab4af3SHans de Goede * licensing only applies to this file, and not this project as a
753ab4af3SHans de Goede * whole.
853ab4af3SHans de Goede *
953ab4af3SHans de Goede *  a) This file is free software; you can redistribute it and/or
1053ab4af3SHans de Goede *     modify it under the terms of the GNU General Public License as
1153ab4af3SHans de Goede *     published by the Free Software Foundation; either version 2 of the
1253ab4af3SHans de Goede *     License, or (at your option) any later version.
1353ab4af3SHans de Goede *
1453ab4af3SHans de Goede *     This file is distributed in the hope that it will be useful,
1553ab4af3SHans de Goede *     but WITHOUT ANY WARRANTY; without even the implied warranty of
1653ab4af3SHans de Goede *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1753ab4af3SHans de Goede *     GNU General Public License for more details.
1853ab4af3SHans de Goede *
1953ab4af3SHans de Goede * Or, alternatively,
2053ab4af3SHans de Goede *
2153ab4af3SHans de Goede *  b) Permission is hereby granted, free of charge, to any person
2253ab4af3SHans de Goede *     obtaining a copy of this software and associated documentation
2353ab4af3SHans de Goede *     files (the "Software"), to deal in the Software without
2453ab4af3SHans de Goede *     restriction, including without limitation the rights to use,
2553ab4af3SHans de Goede *     copy, modify, merge, publish, distribute, sublicense, and/or
2653ab4af3SHans de Goede *     sell copies of the Software, and to permit persons to whom the
2753ab4af3SHans de Goede *     Software is furnished to do so, subject to the following
2853ab4af3SHans de Goede *     conditions:
2953ab4af3SHans de Goede *
3053ab4af3SHans de Goede *     The above copyright notice and this permission notice shall be
3153ab4af3SHans de Goede *     included in all copies or substantial portions of the Software.
3253ab4af3SHans de Goede *
3353ab4af3SHans de Goede *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
3453ab4af3SHans de Goede *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
3553ab4af3SHans de Goede *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
3653ab4af3SHans de Goede *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
3753ab4af3SHans de Goede *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
3853ab4af3SHans de Goede *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
3953ab4af3SHans de Goede *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
4053ab4af3SHans de Goede *     OTHER DEALINGS IN THE SOFTWARE.
4153ab4af3SHans de Goede */
4253ab4af3SHans de Goede
4353ab4af3SHans de Goede/dts-v1/;
4453ab4af3SHans de Goede#include "sun6i-a31.dtsi"
4553ab4af3SHans de Goede#include "sunxi-common-regulators.dtsi"
4653ab4af3SHans de Goede
4753ab4af3SHans de Goede#include <dt-bindings/gpio/gpio.h>
4853ab4af3SHans de Goede#include <dt-bindings/pinctrl/sun4i-a10.h>
4953ab4af3SHans de Goede
5053ab4af3SHans de Goede/ {
51da52a4a3SHans de Goede	model = "Mele M9 top set box";
5253ab4af3SHans de Goede	compatible = "mele,m9", "allwinner,sun6i-a31";
5353ab4af3SHans de Goede
5453ab4af3SHans de Goede	aliases {
5553ab4af3SHans de Goede		serial0 = &uart0;
5653ab4af3SHans de Goede	};
5753ab4af3SHans de Goede
5853ab4af3SHans de Goede	chosen {
5953ab4af3SHans de Goede		stdout-path = "serial0:115200n8";
6053ab4af3SHans de Goede	};
6153ab4af3SHans de Goede
6253ab4af3SHans de Goede	leds {
6353ab4af3SHans de Goede		compatible = "gpio-leds";
6453ab4af3SHans de Goede		pinctrl-names = "default";
6553ab4af3SHans de Goede		pinctrl-0 = <&led_pins_m9>;
6653ab4af3SHans de Goede
6753ab4af3SHans de Goede		blue {
68*860fbdd4SHans de Goede			label = "m9:blue:pwr";
6953ab4af3SHans de Goede			gpios = <&pio 7 13 GPIO_ACTIVE_HIGH>;
70*860fbdd4SHans de Goede			default-state = "on";
7153ab4af3SHans de Goede		};
7253ab4af3SHans de Goede	};
7353ab4af3SHans de Goede};
7453ab4af3SHans de Goede
75*860fbdd4SHans de Goede&cpu0 {
76*860fbdd4SHans de Goede	cpu-supply = <&reg_dcdc3>;
77*860fbdd4SHans de Goede};
78*860fbdd4SHans de Goede
7953ab4af3SHans de Goede&ehci0 {
8053ab4af3SHans de Goede	status = "okay";
8153ab4af3SHans de Goede};
8253ab4af3SHans de Goede
8353ab4af3SHans de Goede&ehci1 {
8453ab4af3SHans de Goede	status = "okay";
8553ab4af3SHans de Goede};
8653ab4af3SHans de Goede
8753ab4af3SHans de Goede&gmac {
8853ab4af3SHans de Goede	pinctrl-names = "default";
8953ab4af3SHans de Goede	pinctrl-0 = <&gmac_pins_mii_a>;
9053ab4af3SHans de Goede	phy = <&phy1>;
9153ab4af3SHans de Goede	phy-mode = "mii";
92*860fbdd4SHans de Goede	phy-supply = <&reg_dldo1>;
9353ab4af3SHans de Goede	status = "okay";
9453ab4af3SHans de Goede
9553ab4af3SHans de Goede	phy1: ethernet-phy@1 {
9653ab4af3SHans de Goede		reg = <1>;
9753ab4af3SHans de Goede	};
9853ab4af3SHans de Goede};
9953ab4af3SHans de Goede
10053ab4af3SHans de Goede&ir {
10153ab4af3SHans de Goede	pinctrl-names = "default";
10253ab4af3SHans de Goede	pinctrl-0 = <&ir_pins_a>;
10353ab4af3SHans de Goede	status = "okay";
10453ab4af3SHans de Goede};
10553ab4af3SHans de Goede
10653ab4af3SHans de Goede&mmc0 {
10753ab4af3SHans de Goede	pinctrl-names = "default";
10853ab4af3SHans de Goede	pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_m9>;
109*860fbdd4SHans de Goede	vmmc-supply = <&reg_dcdc1>;
11053ab4af3SHans de Goede	bus-width = <4>;
11153ab4af3SHans de Goede	cd-gpios = <&pio 7 22 GPIO_ACTIVE_HIGH>; /* PH22 */
11253ab4af3SHans de Goede	cd-inverted;
11353ab4af3SHans de Goede	status = "okay";
11453ab4af3SHans de Goede};
11553ab4af3SHans de Goede
116*860fbdd4SHans de Goede&p2wi {
117*860fbdd4SHans de Goede	status = "okay";
118*860fbdd4SHans de Goede
119*860fbdd4SHans de Goede	axp22x: pmic@68 {
120*860fbdd4SHans de Goede		compatible = "x-powers,axp221";
121*860fbdd4SHans de Goede		reg = <0x68>;
122*860fbdd4SHans de Goede		interrupt-parent = <&nmi_intc>;
123*860fbdd4SHans de Goede		interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
124*860fbdd4SHans de Goede	};
125*860fbdd4SHans de Goede};
126*860fbdd4SHans de Goede
127*860fbdd4SHans de Goede#include "axp22x.dtsi"
128*860fbdd4SHans de Goede
12953ab4af3SHans de Goede&pio {
13053ab4af3SHans de Goede	led_pins_m9: led_pins@0 {
13153ab4af3SHans de Goede		allwinner,pins = "PH13";
13253ab4af3SHans de Goede		allwinner,function = "gpio_out";
13353ab4af3SHans de Goede		allwinner,drive = <SUN4I_PINCTRL_10_MA>;
13453ab4af3SHans de Goede		allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
13553ab4af3SHans de Goede	};
13653ab4af3SHans de Goede
13753ab4af3SHans de Goede	mmc0_cd_pin_m9: mmc0_cd_pin@0 {
13853ab4af3SHans de Goede		allwinner,pins = "PH22";
13953ab4af3SHans de Goede		allwinner,function = "gpio_in";
14053ab4af3SHans de Goede		allwinner,drive = <SUN4I_PINCTRL_10_MA>;
14153ab4af3SHans de Goede		allwinner,pull = <SUN4I_PINCTRL_PULL_UP>;
14253ab4af3SHans de Goede	};
14353ab4af3SHans de Goede
14453ab4af3SHans de Goede	usb1_vbus_pin_m9: usb1_vbus_pin@0 {
14553ab4af3SHans de Goede		allwinner,pins = "PC27";
14653ab4af3SHans de Goede		allwinner,function = "gpio_out";
14753ab4af3SHans de Goede		allwinner,drive = <SUN4I_PINCTRL_10_MA>;
14853ab4af3SHans de Goede		allwinner,pull = <SUN4I_PINCTRL_NO_PULL>;
14953ab4af3SHans de Goede	};
15053ab4af3SHans de Goede};
15153ab4af3SHans de Goede
152*860fbdd4SHans de Goede&reg_aldo1 {
153*860fbdd4SHans de Goede	regulator-min-microvolt = <3300000>;
154*860fbdd4SHans de Goede	regulator-max-microvolt = <3300000>;
155*860fbdd4SHans de Goede	regulator-name = "vcc-wifi";
156*860fbdd4SHans de Goede};
157*860fbdd4SHans de Goede
158*860fbdd4SHans de Goede&reg_aldo3 {
159*860fbdd4SHans de Goede	regulator-always-on;
160*860fbdd4SHans de Goede	regulator-min-microvolt = <2700000>;
161*860fbdd4SHans de Goede	regulator-max-microvolt = <3300000>;
162*860fbdd4SHans de Goede	regulator-name = "avcc";
163*860fbdd4SHans de Goede};
164*860fbdd4SHans de Goede
165*860fbdd4SHans de Goede&reg_dc5ldo {
166*860fbdd4SHans de Goede	regulator-always-on;
167*860fbdd4SHans de Goede	regulator-min-microvolt = <700000>;
168*860fbdd4SHans de Goede	regulator-max-microvolt = <1320000>;
169*860fbdd4SHans de Goede	regulator-name = "vdd-cpus"; /* This is an educated guess */
170*860fbdd4SHans de Goede};
171*860fbdd4SHans de Goede
172*860fbdd4SHans de Goede&reg_dcdc1 {
173*860fbdd4SHans de Goede	regulator-always-on;
174*860fbdd4SHans de Goede	regulator-min-microvolt = <3300000>;
175*860fbdd4SHans de Goede	regulator-max-microvolt = <3300000>;
176*860fbdd4SHans de Goede	regulator-name = "vcc-3v3";
177*860fbdd4SHans de Goede};
178*860fbdd4SHans de Goede
179*860fbdd4SHans de Goede&reg_dcdc2 {
180*860fbdd4SHans de Goede	regulator-min-microvolt = <700000>;
181*860fbdd4SHans de Goede	regulator-max-microvolt = <1320000>;
182*860fbdd4SHans de Goede	regulator-name = "vdd-gpu";
183*860fbdd4SHans de Goede};
184*860fbdd4SHans de Goede
185*860fbdd4SHans de Goede&reg_dcdc3 {
186*860fbdd4SHans de Goede	regulator-always-on;
187*860fbdd4SHans de Goede	regulator-min-microvolt = <700000>;
188*860fbdd4SHans de Goede	regulator-max-microvolt = <1320000>;
189*860fbdd4SHans de Goede	regulator-name = "vdd-cpu";
190*860fbdd4SHans de Goede};
191*860fbdd4SHans de Goede
192*860fbdd4SHans de Goede&reg_dcdc4 {
193*860fbdd4SHans de Goede	regulator-always-on;
194*860fbdd4SHans de Goede	regulator-min-microvolt = <700000>;
195*860fbdd4SHans de Goede	regulator-max-microvolt = <1320000>;
196*860fbdd4SHans de Goede	regulator-name = "vdd-sys-dll";
197*860fbdd4SHans de Goede};
198*860fbdd4SHans de Goede
199*860fbdd4SHans de Goede&reg_dcdc5 {
200*860fbdd4SHans de Goede	regulator-always-on;
201*860fbdd4SHans de Goede	regulator-min-microvolt = <1500000>;
202*860fbdd4SHans de Goede	regulator-max-microvolt = <1500000>;
203*860fbdd4SHans de Goede	regulator-name = "vcc-dram";
204*860fbdd4SHans de Goede};
205*860fbdd4SHans de Goede
206*860fbdd4SHans de Goede&reg_dldo1 {
207*860fbdd4SHans de Goede	regulator-min-microvolt = <3300000>;
208*860fbdd4SHans de Goede	regulator-max-microvolt = <3300000>;
209*860fbdd4SHans de Goede	regulator-name = "vcc-ethernet-phy";
210*860fbdd4SHans de Goede};
211*860fbdd4SHans de Goede
212*860fbdd4SHans de Goede/*
213*860fbdd4SHans de Goede * Both reg_usb1_vbus and reg_dldo4 need to be on for the hub attached
214*860fbdd4SHans de Goede * to usb1 to work, and we can list only one usb1_vbus-supply, so dldo4 is
215*860fbdd4SHans de Goede * marked as regulator-always-on.
216*860fbdd4SHans de Goede */
217*860fbdd4SHans de Goede&reg_dldo4 {
218*860fbdd4SHans de Goede	regulator-always-on;
219*860fbdd4SHans de Goede	regulator-min-microvolt = <3300000>;
220*860fbdd4SHans de Goede	regulator-max-microvolt = <3300000>;
221*860fbdd4SHans de Goede	regulator-name = "vcc-usb-hub";
222*860fbdd4SHans de Goede};
223*860fbdd4SHans de Goede
22453ab4af3SHans de Goede&reg_usb1_vbus {
22553ab4af3SHans de Goede	pinctrl-names = "default";
22653ab4af3SHans de Goede	pinctrl-0 = <&usb1_vbus_pin_m9>;
22753ab4af3SHans de Goede	gpio = <&pio 2 27 GPIO_ACTIVE_HIGH>;
22853ab4af3SHans de Goede	status = "okay";
22953ab4af3SHans de Goede};
23053ab4af3SHans de Goede
23153ab4af3SHans de Goede&uart0 {
23253ab4af3SHans de Goede	pinctrl-names = "default";
23353ab4af3SHans de Goede	pinctrl-0 = <&uart0_pins_a>;
23453ab4af3SHans de Goede	status = "okay";
23553ab4af3SHans de Goede};
23653ab4af3SHans de Goede
23753ab4af3SHans de Goede&usbphy {
23853ab4af3SHans de Goede	usb1_vbus-supply = <&reg_usb1_vbus>;
239*860fbdd4SHans de Goede	usb2_vbus-supply = <&reg_aldo1>;
24053ab4af3SHans de Goede	status = "okay";
24153ab4af3SHans de Goede};
242