1cc733bc9SAndreas Färber/*
2cc733bc9SAndreas Färber * Copyright (c) 2016 Andreas Färber
3cc733bc9SAndreas Färber *
4cc733bc9SAndreas Färber * This file is dual-licensed: you can use it either under the terms
5cc733bc9SAndreas Färber * of the GPL or the X11 license, at your option. Note that this dual
6cc733bc9SAndreas Färber * licensing only applies to this file, and not this project as a
7cc733bc9SAndreas Färber * whole.
8cc733bc9SAndreas Färber *
9cc733bc9SAndreas Färber *  a) This library is free software; you can redistribute it and/or
10cc733bc9SAndreas Färber *     modify it under the terms of the GNU General Public License as
11cc733bc9SAndreas Färber *     published by the Free Software Foundation; either version 2 of the
12cc733bc9SAndreas Färber *     License, or (at your option) any later version.
13cc733bc9SAndreas Färber *
14cc733bc9SAndreas Färber *     This library is distributed in the hope that it will be useful,
15cc733bc9SAndreas Färber *     but WITHOUT ANY WARRANTY; without even the implied warranty of
16cc733bc9SAndreas Färber *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17cc733bc9SAndreas Färber *     GNU General Public License for more details.
18cc733bc9SAndreas Färber *
19cc733bc9SAndreas Färber * Or, alternatively,
20cc733bc9SAndreas Färber *
21cc733bc9SAndreas Färber *  b) Permission is hereby granted, free of charge, to any person
22cc733bc9SAndreas Färber *     obtaining a copy of this software and associated documentation
23cc733bc9SAndreas Färber *     files (the "Software"), to deal in the Software without
24cc733bc9SAndreas Färber *     restriction, including without limitation the rights to use,
25cc733bc9SAndreas Färber *     copy, modify, merge, publish, distribute, sublicense, and/or
26cc733bc9SAndreas Färber *     sell copies of the Software, and to permit persons to whom the
27cc733bc9SAndreas Färber *     Software is furnished to do so, subject to the following
28cc733bc9SAndreas Färber *     conditions:
29cc733bc9SAndreas Färber *
30cc733bc9SAndreas Färber *     The above copyright notice and this permission notice shall be
31cc733bc9SAndreas Färber *     included in all copies or substantial portions of the Software.
32cc733bc9SAndreas Färber *
33cc733bc9SAndreas Färber *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
34cc733bc9SAndreas Färber *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
35cc733bc9SAndreas Färber *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
36cc733bc9SAndreas Färber *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
37cc733bc9SAndreas Färber *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
38cc733bc9SAndreas Färber *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
39cc733bc9SAndreas Färber *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
40cc733bc9SAndreas Färber *     OTHER DEALINGS IN THE SOFTWARE.
41cc733bc9SAndreas Färber */
42cc733bc9SAndreas Färber
43cc733bc9SAndreas Färber#include "meson-gxbb.dtsi"
44cc733bc9SAndreas Färber
45cc733bc9SAndreas Färber/ {
46cc733bc9SAndreas Färber	compatible = "tronsmart,vega-s95", "amlogic,meson-gxbb";
47cc733bc9SAndreas Färber
48962f271eSKevin Hilman	aliases {
49962f271eSKevin Hilman		serial0 = &uart_AO;
50962f271eSKevin Hilman	};
51962f271eSKevin Hilman
52cc733bc9SAndreas Färber	chosen {
53cc733bc9SAndreas Färber		stdout-path = "serial0:115200n8";
54cc733bc9SAndreas Färber	};
55c763eb82SMartin Blumenstingl
562fbbc4bfSAndreas Färber	leds {
572fbbc4bfSAndreas Färber		compatible = "gpio-leds";
582fbbc4bfSAndreas Färber
592fbbc4bfSAndreas Färber		blue {
602fbbc4bfSAndreas Färber			label = "vega-s95:blue:on";
612fbbc4bfSAndreas Färber			gpios = <&gpio_ao GPIOAO_13 GPIO_ACTIVE_HIGH>;
622fbbc4bfSAndreas Färber			default-state = "on";
632fbbc4bfSAndreas Färber			panic-indicator;
642fbbc4bfSAndreas Färber		};
652fbbc4bfSAndreas Färber	};
662fbbc4bfSAndreas Färber
67c763eb82SMartin Blumenstingl	usb_vbus: regulator-usb0-vbus {
68c763eb82SMartin Blumenstingl		compatible = "regulator-fixed";
69c763eb82SMartin Blumenstingl
70c763eb82SMartin Blumenstingl		regulator-name = "USB0_VBUS";
71c763eb82SMartin Blumenstingl
72c763eb82SMartin Blumenstingl		regulator-min-microvolt = <5000000>;
73c763eb82SMartin Blumenstingl		regulator-max-microvolt = <5000000>;
74c763eb82SMartin Blumenstingl
75c763eb82SMartin Blumenstingl		gpio = <&gpio GPIODV_24 GPIO_ACTIVE_HIGH>;
76c763eb82SMartin Blumenstingl		enable-active-high;
77c763eb82SMartin Blumenstingl	};
78c763eb82SMartin Blumenstingl
79ab5b24fdSMartin Blumenstingl	vcc_3v3: regulator-vcc_3v3 {
80ab5b24fdSMartin Blumenstingl		compatible = "regulator-fixed";
81ab5b24fdSMartin Blumenstingl		regulator-name = "VCC_3V3";
82ab5b24fdSMartin Blumenstingl		regulator-min-microvolt = <3300000>;
83ab5b24fdSMartin Blumenstingl		regulator-max-microvolt = <3300000>;
84ab5b24fdSMartin Blumenstingl	};
85ab5b24fdSMartin Blumenstingl
86ab5b24fdSMartin Blumenstingl	vcc_1v8: regulator-vcc_1v8 {
87ab5b24fdSMartin Blumenstingl		compatible = "regulator-fixed";
88ab5b24fdSMartin Blumenstingl		regulator-name = "VCC_1V8";
89ab5b24fdSMartin Blumenstingl		regulator-min-microvolt = <1800000>;
90ab5b24fdSMartin Blumenstingl		regulator-max-microvolt = <1800000>;
91ab5b24fdSMartin Blumenstingl	};
92ab5b24fdSMartin Blumenstingl
93ab5b24fdSMartin Blumenstingl	emmc_pwrseq: emmc-pwrseq {
94ab5b24fdSMartin Blumenstingl		compatible = "mmc-pwrseq-emmc";
95ab5b24fdSMartin Blumenstingl		reset-gpios = <&gpio BOOT_9 GPIO_ACTIVE_LOW>;
96ab5b24fdSMartin Blumenstingl	};
97ab5b24fdSMartin Blumenstingl
98ab5b24fdSMartin Blumenstingl	wifi32k: wifi32k {
99ab5b24fdSMartin Blumenstingl		compatible = "pwm-clock";
100ab5b24fdSMartin Blumenstingl		#clock-cells = <0>;
101ab5b24fdSMartin Blumenstingl		clock-frequency = <32768>;
102ab5b24fdSMartin Blumenstingl		pwms = <&pwm_ef 0 30518 0>; /* PWM_E at 32.768KHz */
103ab5b24fdSMartin Blumenstingl	};
104ab5b24fdSMartin Blumenstingl
105ab5b24fdSMartin Blumenstingl	sdio_pwrseq: sdio-pwrseq {
106ab5b24fdSMartin Blumenstingl		compatible = "mmc-pwrseq-simple";
107ab5b24fdSMartin Blumenstingl		reset-gpios = <&gpio GPIOX_6 GPIO_ACTIVE_LOW>,
108ab5b24fdSMartin Blumenstingl				<&gpio GPIOX_20 GPIO_ACTIVE_LOW>;
109ab5b24fdSMartin Blumenstingl		clocks = <&wifi32k>;
110ab5b24fdSMartin Blumenstingl		clock-names = "ext_clock";
111ab5b24fdSMartin Blumenstingl	};
112cc733bc9SAndreas Färber};
113cc733bc9SAndreas Färber
114f59063aeSMartin Blumenstingl&ethmac {
115f59063aeSMartin Blumenstingl	status = "okay";
1163be2d9cfSNeil Armstrong	pinctrl-0 = <&eth_rgmii_pins>;
117f59063aeSMartin Blumenstingl	pinctrl-names = "default";
1181220b297SMartin Blumenstingl
1191220b297SMartin Blumenstingl	phy-handle = <&eth_phy0>;
1201220b297SMartin Blumenstingl	phy-mode = "rgmii";
1211220b297SMartin Blumenstingl
122093d23dbSMartin Blumenstingl	amlogic,tx-delay-ns = <2>;
123093d23dbSMartin Blumenstingl
1241220b297SMartin Blumenstingl	snps,reset-gpio = <&gpio GPIOZ_14 0>;
1251220b297SMartin Blumenstingl	snps,reset-delays-us = <0 10000 1000000>;
1261220b297SMartin Blumenstingl	snps,reset-active-low;
1271220b297SMartin Blumenstingl
1281220b297SMartin Blumenstingl	mdio {
1291220b297SMartin Blumenstingl		compatible = "snps,dwmac-mdio";
1301220b297SMartin Blumenstingl		#address-cells = <1>;
1311220b297SMartin Blumenstingl		#size-cells = <0>;
1321220b297SMartin Blumenstingl
1331220b297SMartin Blumenstingl		eth_phy0: ethernet-phy@0 {
1341220b297SMartin Blumenstingl			/* Realtek RTL8211F (0x001cc916) */
1351220b297SMartin Blumenstingl			reg = <0>;
1361220b297SMartin Blumenstingl		};
1371220b297SMartin Blumenstingl	};
138f59063aeSMartin Blumenstingl};
139c763eb82SMartin Blumenstingl
140d6f93b02SAndreas Färber&ir {
141c763eb82SMartin Blumenstingl	status = "okay";
142d6f93b02SAndreas Färber	pinctrl-0 = <&remote_input_ao_pins>;
143d6f93b02SAndreas Färber	pinctrl-names = "default";
144c763eb82SMartin Blumenstingl};
145c763eb82SMartin Blumenstingl
146d6f93b02SAndreas Färber&pwm_ef {
147c763eb82SMartin Blumenstingl	status = "okay";
148d6f93b02SAndreas Färber	pinctrl-0 = <&pwm_e_pins>;
149d6f93b02SAndreas Färber	pinctrl-names = "default";
150d6f93b02SAndreas Färber	clocks = <&clkc CLKID_FCLK_DIV4>;
151d6f93b02SAndreas Färber	clock-names = "clkin0";
152c763eb82SMartin Blumenstingl};
153ab5b24fdSMartin Blumenstingl
154ab5b24fdSMartin Blumenstingl/* Wireless SDIO Module */
155ab5b24fdSMartin Blumenstingl&sd_emmc_a {
156ab5b24fdSMartin Blumenstingl	status = "okay";
157ab5b24fdSMartin Blumenstingl	pinctrl-0 = <&sdio_pins &sdio_irq_pins>;
15867e7607fSJerome Brunet	pinctrl-1 = <&sdio_clk_gate_pins>;
15967e7607fSJerome Brunet	pinctrl-names = "default", "clk-gate";
160ab5b24fdSMartin Blumenstingl	#address-cells = <1>;
161ab5b24fdSMartin Blumenstingl	#size-cells = <0>;
162ab5b24fdSMartin Blumenstingl
163ab5b24fdSMartin Blumenstingl	bus-width = <4>;
164ab5b24fdSMartin Blumenstingl	cap-sd-highspeed;
165ab5b24fdSMartin Blumenstingl	max-frequency = <100000000>;
166ab5b24fdSMartin Blumenstingl
167ab5b24fdSMartin Blumenstingl	non-removable;
168ab5b24fdSMartin Blumenstingl	disable-wp;
169ab5b24fdSMartin Blumenstingl
170ab5b24fdSMartin Blumenstingl	mmc-pwrseq = <&sdio_pwrseq>;
171ab5b24fdSMartin Blumenstingl
172ab5b24fdSMartin Blumenstingl	vmmc-supply = <&vcc_3v3>;
173ab5b24fdSMartin Blumenstingl	vqmmc-supply = <&vcc_1v8>;
174ab5b24fdSMartin Blumenstingl
17519e16750SAndreas Färber	brcmf: wifi@1 {
176ab5b24fdSMartin Blumenstingl		reg = <1>;
177ab5b24fdSMartin Blumenstingl		compatible = "brcm,bcm4329-fmac";
178ab5b24fdSMartin Blumenstingl	};
179ab5b24fdSMartin Blumenstingl};
180ab5b24fdSMartin Blumenstingl
181ab5b24fdSMartin Blumenstingl/* SD card */
182ab5b24fdSMartin Blumenstingl&sd_emmc_b {
183ab5b24fdSMartin Blumenstingl	status = "okay";
184ab5b24fdSMartin Blumenstingl	pinctrl-0 = <&sdcard_pins>;
18567e7607fSJerome Brunet	pinctrl-1 = <&sdcard_clk_gate_pins>;
18667e7607fSJerome Brunet	pinctrl-names = "default", "clk-gate";
187ab5b24fdSMartin Blumenstingl
188ab5b24fdSMartin Blumenstingl	bus-width = <4>;
189ab5b24fdSMartin Blumenstingl	cap-sd-highspeed;
190ab5b24fdSMartin Blumenstingl	max-frequency = <100000000>;
191ab5b24fdSMartin Blumenstingl	disable-wp;
192ab5b24fdSMartin Blumenstingl
193ab5b24fdSMartin Blumenstingl	cd-gpios = <&gpio CARD_6 GPIO_ACTIVE_HIGH>;
194ab5b24fdSMartin Blumenstingl	cd-inverted;
195ab5b24fdSMartin Blumenstingl
196ab5b24fdSMartin Blumenstingl	vmmc-supply = <&vcc_3v3>;
197ab5b24fdSMartin Blumenstingl};
198ab5b24fdSMartin Blumenstingl
199ab5b24fdSMartin Blumenstingl/* eMMC */
200ab5b24fdSMartin Blumenstingl&sd_emmc_c {
201ab5b24fdSMartin Blumenstingl	status = "okay";
202ab36be66SNeil Armstrong	pinctrl-0 = <&emmc_pins>, <&emmc_ds_pins>;
20367e7607fSJerome Brunet	pinctrl-1 = <&emmc_clk_gate_pins>;
20467e7607fSJerome Brunet	pinctrl-names = "default", "clk-gate";
205ab5b24fdSMartin Blumenstingl
206ab5b24fdSMartin Blumenstingl	bus-width = <8>;
207ab5b24fdSMartin Blumenstingl	cap-mmc-highspeed;
208ab5b24fdSMartin Blumenstingl	max-frequency = <200000000>;
209ab5b24fdSMartin Blumenstingl	non-removable;
210ab5b24fdSMartin Blumenstingl	disable-wp;
211ab5b24fdSMartin Blumenstingl	mmc-ddr-1_8v;
212ab5b24fdSMartin Blumenstingl	mmc-hs200-1_8v;
213ab5b24fdSMartin Blumenstingl
214ab5b24fdSMartin Blumenstingl	mmc-pwrseq = <&emmc_pwrseq>;
215ab5b24fdSMartin Blumenstingl	vmmc-supply = <&vcc_3v3>;
216ab5b24fdSMartin Blumenstingl	vmmcq-sumpply = <&vcc_1v8>;
217ab5b24fdSMartin Blumenstingl};
218ab5b24fdSMartin Blumenstingl
219d6f93b02SAndreas Färber&uart_AO {
220ab5b24fdSMartin Blumenstingl	status = "okay";
221d6f93b02SAndreas Färber	pinctrl-0 = <&uart_ao_a_pins>;
222ab5b24fdSMartin Blumenstingl	pinctrl-names = "default";
223d6f93b02SAndreas Färber};
224d6f93b02SAndreas Färber
225d6f93b02SAndreas Färber&usb0_phy {
226d6f93b02SAndreas Färber	status = "okay";
227d6f93b02SAndreas Färber	phy-supply = <&usb_vbus>;
228d6f93b02SAndreas Färber};
229d6f93b02SAndreas Färber
230d6f93b02SAndreas Färber&usb1_phy {
231d6f93b02SAndreas Färber	status = "okay";
232d6f93b02SAndreas Färber};
233d6f93b02SAndreas Färber
234d6f93b02SAndreas Färber&usb0 {
235d6f93b02SAndreas Färber	status = "okay";
236d6f93b02SAndreas Färber};
237d6f93b02SAndreas Färber
238d6f93b02SAndreas Färber&usb1 {
239d6f93b02SAndreas Färber	status = "okay";
240ab5b24fdSMartin Blumenstingl};
241