blob: d8bfd7b74916262dcfeebe7e11cef06d1ca35149 [file] [log] [blame]
Priit Laes17a35942015-01-26 20:00:06 +02001/*
2 * Copyright 2015 Priit Laes
3 *
4 * Priit Laes <plaes@plaes.org>
5 *
6 * This file is dual-licensed: you can use it either under the terms
7 * of the GPL or the X11 license, at your option. Note that this dual
8 * licensing only applies to this file, and not this project as a
9 * whole.
10 *
11 * a) This file is free software; you can redistribute it and/or
12 * modify it under the terms of the GNU General Public License as
13 * published by the Free Software Foundation; either version 2 of the
14 * License, or (at your option) any later version.
15 *
16 * This file is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
Priit Laes17a35942015-01-26 20:00:06 +020021 * Or, alternatively,
22 *
23 * b) Permission is hereby granted, free of charge, to any person
24 * obtaining a copy of this software and associated documentation
25 * files (the "Software"), to deal in the Software without
26 * restriction, including without limitation the rights to use,
27 * copy, modify, merge, publish, distribute, sublicense, and/or
28 * sell copies of the Software, and to permit persons to whom the
29 * Software is furnished to do so, subject to the following
30 * conditions:
31 *
32 * The above copyright notice and this permission notice shall be
33 * included in all copies or substantial portions of the Software.
34 *
35 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
36 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
37 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
38 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
39 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
40 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
41 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
42 * OTHER DEALINGS IN THE SOFTWARE.
43 */
44
45/dts-v1/;
46#include "sun4i-a10.dtsi"
47#include "sunxi-common-regulators.dtsi"
48#include <dt-bindings/gpio/gpio.h>
49#include <dt-bindings/input/input.h>
Priit Laes0372bb62015-09-23 10:38:31 +030050#include <dt-bindings/interrupt-controller/irq.h>
Priit Laes17a35942015-01-26 20:00:06 +020051
52/ {
53 model = "Gemei G9 Tablet";
54 compatible = "gemei,g9", "allwinner,sun4i-a10";
Maxime Ripard59ebbe82015-03-15 20:47:31 +010055
56 aliases {
57 serial0 = &uart0;
58 };
59
60 chosen {
61 stdout-path = "serial0:115200n8";
62 };
Priit Laes17a35942015-01-26 20:00:06 +020063};
64
65/*
66 * TODO:
67 * 2x cameras via CSI
Priit Laes17a35942015-01-26 20:00:06 +020068 * AXP battery management
69 * NAND
70 * OTG
71 * Touchscreen - gt801_2plus1 @ i2c adapter 2 @ 0x48
72 */
Priit Laesfef52182015-11-06 19:54:46 +020073&codec {
Priit Laes2c102c32015-12-11 23:23:00 +020074 /* PH15 controls power to external amplifier (ft2012q) */
75 pinctrl-names = "default";
76 pinctrl-0 = <&codec_pa_pin>;
77 allwinner,pa-gpios = <&pio 7 15 GPIO_ACTIVE_HIGH>;
Priit Laesfef52182015-11-06 19:54:46 +020078 status = "okay";
79};
Priit Laes17a35942015-01-26 20:00:06 +020080
Priit Laesbc1e2712015-11-06 19:54:44 +020081&cpu0 {
82 cpu-supply = <&reg_dcdc2>;
83};
84
Priit Laes17a35942015-01-26 20:00:06 +020085&ehci0 {
86 status = "okay";
87};
88
89&ehci1 {
90 status = "okay";
91};
92
93&i2c0 {
94 pinctrl-names = "default";
95 pinctrl-0 = <&i2c0_pins_a>;
96 status = "okay";
97
98 axp209: pmic@34 {
Priit Laes17a35942015-01-26 20:00:06 +020099 reg = <0x34>;
100 interrupts = <0>;
Priit Laes17a35942015-01-26 20:00:06 +0200101 };
102};
103
Priit Laesbc1e2712015-11-06 19:54:44 +0200104#include "axp209.dtsi"
105
Priit Laes17a35942015-01-26 20:00:06 +0200106&i2c1 {
107 pinctrl-names = "default";
108 pinctrl-0 = <&i2c1_pins_a>;
109 status = "okay";
110
111 /* Accelerometer */
112 bma250@18 {
113 compatible = "bosch,bma250";
114 reg = <0x18>;
Priit Laes0372bb62015-09-23 10:38:31 +0300115 interrupt-parent = <&pio>;
116 interrupts = <7 0 IRQ_TYPE_EDGE_RISING>; /* PH00 / EINT0 */
Priit Laes17a35942015-01-26 20:00:06 +0200117 };
118};
119
120&lradc {
Priit Laes108f7802015-11-06 19:54:45 +0200121 vref-supply = <&reg_ldo2>;
Priit Laes17a35942015-01-26 20:00:06 +0200122
123 status = "okay";
124
125 button@158 {
126 label = "Volume Down";
127 linux,code = <KEY_VOLUMEDOWN>;
128 channel = <0>;
129 voltage = <158730>;
130 };
131
132 button@349 {
133 label = "Volume Up";
134 linux,code = <KEY_VOLUMEUP>;
135 channel = <0>;
136 voltage = <349206>;
137 };
138
139 button@1142 {
140 label = "Esc";
141 linux,code = <KEY_ESC>;
142 channel = <0>;
143 voltage = <1142856>;
144 };
145};
146
147&mmc0 {
148 pinctrl-names = "default";
Chen-Yu Tsaicf439662017-04-19 13:09:17 +0800149 pinctrl-0 = <&mmc0_pins_a>;
Priit Laes17a35942015-01-26 20:00:06 +0200150 vmmc-supply = <&reg_vcc3v3>;
151 bus-width = <4>;
152 cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH01 */
153 cd-inverted;
154 status = "okay";
155};
156
Priit Laes2c102c32015-12-11 23:23:00 +0200157&pio {
158 codec_pa_pin: codec_pa_pin@0 {
Maxime Ripard1edcd362016-09-23 14:28:10 +0300159 pins = "PH15";
160 function = "gpio_out";
Priit Laes2c102c32015-12-11 23:23:00 +0200161 };
162};
163
Priit Laesbc1e2712015-11-06 19:54:44 +0200164&reg_dcdc2 {
165 regulator-always-on;
166 regulator-min-microvolt = <1000000>;
167 regulator-max-microvolt = <1400000>;
168 regulator-name = "vdd-cpu";
169};
170
171&reg_dcdc3 {
172 regulator-always-on;
173 regulator-min-microvolt = <1250000>;
174 regulator-max-microvolt = <1250000>;
175 regulator-name = "vdd-int-dll";
176};
177
178&reg_ldo1 {
179 regulator-name = "vdd-rtc";
180};
181
182&reg_ldo2 {
183 regulator-always-on;
184 regulator-min-microvolt = <3000000>;
185 regulator-max-microvolt = <3000000>;
186 regulator-name = "avcc";
187};
188
Priit Laes17a35942015-01-26 20:00:06 +0200189&reg_usb1_vbus {
190 status = "okay";
191};
192
193&reg_usb2_vbus {
194 status = "okay";
195};
196
197
198&uart0 {
199 pinctrl-names = "default";
200 pinctrl-0 = <&uart0_pins_a>;
201 status = "okay";
202};
203
204&usbphy {
205 usb1_vbus-supply = <&reg_usb1_vbus>;
206 usb2_vbus-supply = <&reg_usb2_vbus>;
207 status = "okay";
208};