1*724ba675SRob Herring/*
2*724ba675SRob Herring * Copyright 2015 Chen-Yu Tsai
3*724ba675SRob Herring *
4*724ba675SRob Herring * Chen-Yu Tsai <wens@csie.org>
5*724ba675SRob Herring *
6*724ba675SRob Herring * This file is dual-licensed: you can use it either under the terms
7*724ba675SRob Herring * of the GPL or the X11 license, at your option. Note that this dual
8*724ba675SRob Herring * licensing only applies to this file, and not this project as a
9*724ba675SRob Herring * whole.
10*724ba675SRob Herring *
11*724ba675SRob Herring *  a) This file is free software; you can redistribute it and/or
12*724ba675SRob Herring *     modify it under the terms of the GNU General Public License as
13*724ba675SRob Herring *     published by the Free Software Foundation; either version 2 of the
14*724ba675SRob Herring *     License, or (at your option) any later version.
15*724ba675SRob Herring *
16*724ba675SRob Herring *     This file is distributed in the hope that it will be useful,
17*724ba675SRob Herring *     but WITHOUT ANY WARRANTY; without even the implied warranty of
18*724ba675SRob Herring *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19*724ba675SRob Herring *     GNU General Public License for more details.
20*724ba675SRob Herring *
21*724ba675SRob Herring * Or, alternatively,
22*724ba675SRob Herring *
23*724ba675SRob Herring *  b) Permission is hereby granted, free of charge, to any person
24*724ba675SRob Herring *     obtaining a copy of this software and associated documentation
25*724ba675SRob Herring *     files (the "Software"), to deal in the Software without
26*724ba675SRob Herring *     restriction, including without limitation the rights to use,
27*724ba675SRob Herring *     copy, modify, merge, publish, distribute, sublicense, and/or
28*724ba675SRob Herring *     sell copies of the Software, and to permit persons to whom the
29*724ba675SRob Herring *     Software is furnished to do so, subject to the following
30*724ba675SRob Herring *     conditions:
31*724ba675SRob Herring *
32*724ba675SRob Herring *     The above copyright notice and this permission notice shall be
33*724ba675SRob Herring *     included in all copies or substantial portions of the Software.
34*724ba675SRob Herring *
35*724ba675SRob Herring *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
36*724ba675SRob Herring *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
37*724ba675SRob Herring *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
38*724ba675SRob Herring *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
39*724ba675SRob Herring *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
40*724ba675SRob Herring *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
41*724ba675SRob Herring *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
42*724ba675SRob Herring *     OTHER DEALINGS IN THE SOFTWARE.
43*724ba675SRob Herring */
44*724ba675SRob Herring
45*724ba675SRob Herring/dts-v1/;
46*724ba675SRob Herring#include "sun8i-a33.dtsi"
47*724ba675SRob Herring#include "sunxi-common-regulators.dtsi"
48*724ba675SRob Herring
49*724ba675SRob Herring#include <dt-bindings/gpio/gpio.h>
50*724ba675SRob Herring#include <dt-bindings/input/input.h>
51*724ba675SRob Herring
52*724ba675SRob Herring/ {
53*724ba675SRob Herring	model = "Sinlinx SinA33";
54*724ba675SRob Herring	compatible = "sinlinx,sina33", "allwinner,sun8i-a33";
55*724ba675SRob Herring
56*724ba675SRob Herring	aliases {
57*724ba675SRob Herring		serial0 = &uart0;
58*724ba675SRob Herring	};
59*724ba675SRob Herring
60*724ba675SRob Herring	chosen {
61*724ba675SRob Herring		stdout-path = "serial0:115200n8";
62*724ba675SRob Herring	};
63*724ba675SRob Herring
64*724ba675SRob Herring	panel {
65*724ba675SRob Herring		compatible = "netron-dy,e231732";
66*724ba675SRob Herring		power-supply = <&reg_vcc3v3>;
67*724ba675SRob Herring
68*724ba675SRob Herring		port {
69*724ba675SRob Herring			panel_input: endpoint {
70*724ba675SRob Herring				remote-endpoint = <&tcon0_out_panel>;
71*724ba675SRob Herring			};
72*724ba675SRob Herring		};
73*724ba675SRob Herring	};
74*724ba675SRob Herring};
75*724ba675SRob Herring
76*724ba675SRob Herring&codec {
77*724ba675SRob Herring	status = "okay";
78*724ba675SRob Herring};
79*724ba675SRob Herring
80*724ba675SRob Herring&cpu0 {
81*724ba675SRob Herring	cpu-supply = <&reg_dcdc3>;
82*724ba675SRob Herring};
83*724ba675SRob Herring
84*724ba675SRob Herring&cpu0_opp_table {
85*724ba675SRob Herring	opp-1104000000 {
86*724ba675SRob Herring		opp-hz = /bits/ 64 <1104000000>;
87*724ba675SRob Herring		opp-microvolt = <1320000>;
88*724ba675SRob Herring		clock-latency-ns = <244144>; /* 8 32k periods */
89*724ba675SRob Herring	};
90*724ba675SRob Herring
91*724ba675SRob Herring	opp-1200000000 {
92*724ba675SRob Herring		opp-hz = /bits/ 64 <1200000000>;
93*724ba675SRob Herring		opp-microvolt = <1320000>;
94*724ba675SRob Herring		clock-latency-ns = <244144>; /* 8 32k periods */
95*724ba675SRob Herring	};
96*724ba675SRob Herring};
97*724ba675SRob Herring
98*724ba675SRob Herring&de {
99*724ba675SRob Herring	status = "okay";
100*724ba675SRob Herring};
101*724ba675SRob Herring
102*724ba675SRob Herring&dai {
103*724ba675SRob Herring	status = "okay";
104*724ba675SRob Herring};
105*724ba675SRob Herring
106*724ba675SRob Herring&ehci0 {
107*724ba675SRob Herring	status = "okay";
108*724ba675SRob Herring};
109*724ba675SRob Herring
110*724ba675SRob Herring&lradc {
111*724ba675SRob Herring	vref-supply = <&reg_dcdc1>;
112*724ba675SRob Herring	status = "okay";
113*724ba675SRob Herring
114*724ba675SRob Herring	button-200 {
115*724ba675SRob Herring		label = "Volume Up";
116*724ba675SRob Herring		linux,code = <KEY_VOLUMEUP>;
117*724ba675SRob Herring		channel = <0>;
118*724ba675SRob Herring		voltage = <191011>;
119*724ba675SRob Herring	};
120*724ba675SRob Herring
121*724ba675SRob Herring	button-400 {
122*724ba675SRob Herring		label = "Volume Down";
123*724ba675SRob Herring		linux,code = <KEY_VOLUMEDOWN>;
124*724ba675SRob Herring		channel = <0>;
125*724ba675SRob Herring		voltage = <391304>;
126*724ba675SRob Herring	};
127*724ba675SRob Herring
128*724ba675SRob Herring	button-600 {
129*724ba675SRob Herring		label = "Home";
130*724ba675SRob Herring		linux,code = <KEY_HOME>;
131*724ba675SRob Herring		channel = <0>;
132*724ba675SRob Herring		voltage = <600000>;
133*724ba675SRob Herring	};
134*724ba675SRob Herring};
135*724ba675SRob Herring
136*724ba675SRob Herring&mmc0 {
137*724ba675SRob Herring	vmmc-supply = <&reg_dcdc1>;
138*724ba675SRob Herring	bus-width = <4>;
139*724ba675SRob Herring	cd-gpios = <&pio 1 4 GPIO_ACTIVE_LOW>; /* PB4 */
140*724ba675SRob Herring	status = "okay";
141*724ba675SRob Herring};
142*724ba675SRob Herring
143*724ba675SRob Herring&mmc2 {
144*724ba675SRob Herring	pinctrl-names = "default";
145*724ba675SRob Herring	pinctrl-0 = <&mmc2_8bit_pins>;
146*724ba675SRob Herring	vmmc-supply = <&reg_dcdc1>;
147*724ba675SRob Herring	bus-width = <8>;
148*724ba675SRob Herring	non-removable;
149*724ba675SRob Herring	cap-mmc-hw-reset;
150*724ba675SRob Herring	status = "okay";
151*724ba675SRob Herring};
152*724ba675SRob Herring
153*724ba675SRob Herring&mmc2_8bit_pins {
154*724ba675SRob Herring	/* Increase drive strength for DDR modes */
155*724ba675SRob Herring	drive-strength = <40>;
156*724ba675SRob Herring};
157*724ba675SRob Herring
158*724ba675SRob Herring&ohci0 {
159*724ba675SRob Herring	status = "okay";
160*724ba675SRob Herring};
161*724ba675SRob Herring
162*724ba675SRob Herring&r_rsb {
163*724ba675SRob Herring	status = "okay";
164*724ba675SRob Herring
165*724ba675SRob Herring	axp22x: pmic@3a3 {
166*724ba675SRob Herring		compatible = "x-powers,axp223";
167*724ba675SRob Herring		reg = <0x3a3>;
168*724ba675SRob Herring		interrupt-parent = <&r_intc>;
169*724ba675SRob Herring		interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_LOW>;
170*724ba675SRob Herring		eldoin-supply = <&reg_dcdc1>;
171*724ba675SRob Herring	};
172*724ba675SRob Herring};
173*724ba675SRob Herring
174*724ba675SRob Herring#include "axp223.dtsi"
175*724ba675SRob Herring
176*724ba675SRob Herring&ac_power_supply {
177*724ba675SRob Herring	status = "okay";
178*724ba675SRob Herring};
179*724ba675SRob Herring
180*724ba675SRob Herring&battery_power_supply {
181*724ba675SRob Herring	status = "okay";
182*724ba675SRob Herring};
183*724ba675SRob Herring
184*724ba675SRob Herring&reg_aldo1 {
185*724ba675SRob Herring	regulator-always-on;
186*724ba675SRob Herring	regulator-min-microvolt = <3000000>;
187*724ba675SRob Herring	regulator-max-microvolt = <3000000>;
188*724ba675SRob Herring	regulator-name = "vcc-io";
189*724ba675SRob Herring};
190*724ba675SRob Herring
191*724ba675SRob Herring&reg_aldo2 {
192*724ba675SRob Herring	regulator-always-on;
193*724ba675SRob Herring	regulator-min-microvolt = <2350000>;
194*724ba675SRob Herring	regulator-max-microvolt = <2650000>;
195*724ba675SRob Herring	regulator-name = "vdd-dll";
196*724ba675SRob Herring};
197*724ba675SRob Herring
198*724ba675SRob Herring&reg_aldo3 {
199*724ba675SRob Herring	regulator-always-on;
200*724ba675SRob Herring	regulator-min-microvolt = <2700000>;
201*724ba675SRob Herring	regulator-max-microvolt = <3300000>;
202*724ba675SRob Herring	regulator-name = "vcc-pll-avcc";
203*724ba675SRob Herring};
204*724ba675SRob Herring
205*724ba675SRob Herring&reg_dc5ldo {
206*724ba675SRob Herring	regulator-always-on;
207*724ba675SRob Herring	regulator-min-microvolt = <900000>;
208*724ba675SRob Herring	regulator-max-microvolt = <1400000>;
209*724ba675SRob Herring	regulator-name = "vdd-cpus";
210*724ba675SRob Herring};
211*724ba675SRob Herring
212*724ba675SRob Herring&reg_dcdc1 {
213*724ba675SRob Herring	regulator-always-on;
214*724ba675SRob Herring	regulator-min-microvolt = <3000000>;
215*724ba675SRob Herring	regulator-max-microvolt = <3000000>;
216*724ba675SRob Herring	regulator-name = "vcc-3v0";
217*724ba675SRob Herring};
218*724ba675SRob Herring
219*724ba675SRob Herring&reg_dcdc2 {
220*724ba675SRob Herring	regulator-always-on;
221*724ba675SRob Herring	regulator-min-microvolt = <900000>;
222*724ba675SRob Herring	regulator-max-microvolt = <1400000>;
223*724ba675SRob Herring	regulator-name = "vdd-sys";
224*724ba675SRob Herring};
225*724ba675SRob Herring
226*724ba675SRob Herring&reg_dcdc3 {
227*724ba675SRob Herring	regulator-always-on;
228*724ba675SRob Herring	regulator-min-microvolt = <900000>;
229*724ba675SRob Herring	regulator-max-microvolt = <1400000>;
230*724ba675SRob Herring	regulator-name = "vdd-cpu";
231*724ba675SRob Herring};
232*724ba675SRob Herring
233*724ba675SRob Herring&reg_dcdc5 {
234*724ba675SRob Herring	regulator-always-on;
235*724ba675SRob Herring	regulator-min-microvolt = <1500000>;
236*724ba675SRob Herring	regulator-max-microvolt = <1500000>;
237*724ba675SRob Herring	regulator-name = "vcc-dram";
238*724ba675SRob Herring};
239*724ba675SRob Herring
240*724ba675SRob Herring&reg_rtc_ldo {
241*724ba675SRob Herring	regulator-name = "vcc-rtc";
242*724ba675SRob Herring};
243*724ba675SRob Herring
244*724ba675SRob Herring&sound {
245*724ba675SRob Herring	status = "okay";
246*724ba675SRob Herring};
247*724ba675SRob Herring
248*724ba675SRob Herring&tcon0 {
249*724ba675SRob Herring	pinctrl-names = "default";
250*724ba675SRob Herring	pinctrl-0 = <&lcd_rgb666_pins>;
251*724ba675SRob Herring	status = "okay";
252*724ba675SRob Herring};
253*724ba675SRob Herring
254*724ba675SRob Herring&tcon0_out {
255*724ba675SRob Herring	tcon0_out_panel: endpoint@0 {
256*724ba675SRob Herring		reg = <0>;
257*724ba675SRob Herring		remote-endpoint = <&panel_input>;
258*724ba675SRob Herring	};
259*724ba675SRob Herring};
260*724ba675SRob Herring
261*724ba675SRob Herring&uart0 {
262*724ba675SRob Herring	pinctrl-names = "default";
263*724ba675SRob Herring	pinctrl-0 = <&uart0_pb_pins>;
264*724ba675SRob Herring	status = "okay";
265*724ba675SRob Herring};
266*724ba675SRob Herring
267*724ba675SRob Herring&usb_otg {
268*724ba675SRob Herring	dr_mode = "peripheral";
269*724ba675SRob Herring	status = "okay";
270*724ba675SRob Herring};
271*724ba675SRob Herring
272*724ba675SRob Herring&usbphy {
273*724ba675SRob Herring	status = "okay";
274*724ba675SRob Herring	usb1_vbus-supply = <&reg_vcc5v0>; /* USB1 VBUS is always on */
275*724ba675SRob Herring};
276