153ab4af3SHans de Goede/* 253ab4af3SHans de Goede * Copyright 2015 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 "sun5i-a13.dtsi" 4553ab4af3SHans de Goede#include "sunxi-common-regulators.dtsi" 4653ab4af3SHans de Goede#include <dt-bindings/gpio/gpio.h> 4753ab4af3SHans de Goede#include <dt-bindings/input/input.h> 48*8b1ba941SHans de Goede#include <dt-bindings/interrupt-controller/irq.h> 4953ab4af3SHans de Goede#include <dt-bindings/pinctrl/sun4i-a10.h> 5053ab4af3SHans de Goede 5153ab4af3SHans de Goede/ { 5253ab4af3SHans de Goede model = "Utoo P66"; 5353ab4af3SHans de Goede compatible = "utoo,p66", "allwinner,sun5i-a13"; 5453ab4af3SHans de Goede 5553ab4af3SHans de Goede aliases { 5653ab4af3SHans de Goede serial0 = &uart1; 5753ab4af3SHans de Goede }; 5853ab4af3SHans de Goede 5953ab4af3SHans de Goede chosen { 6053ab4af3SHans de Goede stdout-path = "serial0:115200n8"; 6153ab4af3SHans de Goede }; 6253ab4af3SHans de Goede 6353ab4af3SHans de Goede i2c_lcd: i2c@0 { 6453ab4af3SHans de Goede /* The lcd panel i2c interface is hooked up via gpios */ 6553ab4af3SHans de Goede compatible = "i2c-gpio"; 6653ab4af3SHans de Goede pinctrl-names = "default"; 6753ab4af3SHans de Goede pinctrl-0 = <&i2c_lcd_pins>; 6853ab4af3SHans de Goede gpios = <&pio 6 12 GPIO_ACTIVE_HIGH>, /* PG12, sda */ 6953ab4af3SHans de Goede <&pio 6 10 GPIO_ACTIVE_HIGH>; /* PG10, scl */ 7053ab4af3SHans de Goede i2c-gpio,delay-us = <5>; 7153ab4af3SHans de Goede }; 7253ab4af3SHans de Goede}; 7353ab4af3SHans de Goede 7453ab4af3SHans de Goede&cpu0 { 7553ab4af3SHans de Goede cpu-supply = <®_dcdc2>; 7653ab4af3SHans de Goede}; 7753ab4af3SHans de Goede 7853ab4af3SHans de Goede&ehci0 { 7953ab4af3SHans de Goede status = "okay"; 8053ab4af3SHans de Goede}; 8153ab4af3SHans de Goede 8253ab4af3SHans de Goede&i2c0 { 8353ab4af3SHans de Goede pinctrl-names = "default"; 8453ab4af3SHans de Goede pinctrl-0 = <&i2c0_pins_a>; 8553ab4af3SHans de Goede status = "okay"; 8653ab4af3SHans de Goede 8753ab4af3SHans de Goede axp209: pmic@34 { 8853ab4af3SHans de Goede reg = <0x34>; 8953ab4af3SHans de Goede interrupts = <0>; 9053ab4af3SHans de Goede }; 9153ab4af3SHans de Goede}; 9253ab4af3SHans de Goede 9353ab4af3SHans de Goede#include "axp209.dtsi" 9453ab4af3SHans de Goede 9553ab4af3SHans de Goede&i2c1 { 9653ab4af3SHans de Goede pinctrl-names = "default"; 9753ab4af3SHans de Goede pinctrl-0 = <&i2c1_pins_a>; 9853ab4af3SHans de Goede status = "okay"; 9953ab4af3SHans de Goede 100*8b1ba941SHans de Goede icn8318: touchscreen@40 { 101*8b1ba941SHans de Goede compatible = "chipone,icn8318"; 102*8b1ba941SHans de Goede reg = <0x40>; 103*8b1ba941SHans de Goede interrupt-parent = <&pio>; 104*8b1ba941SHans de Goede interrupts = <9 IRQ_TYPE_EDGE_FALLING>; /* EINT9 (PG9) */ 105*8b1ba941SHans de Goede pinctrl-names = "default"; 106*8b1ba941SHans de Goede pinctrl-0 = <&ts_wake_pin_p66>; 107*8b1ba941SHans de Goede wake-gpios = <&pio 1 3 GPIO_ACTIVE_HIGH>; /* PB3 */ 108*8b1ba941SHans de Goede touchscreen-size-x = <800>; 109*8b1ba941SHans de Goede touchscreen-size-y = <480>; 110*8b1ba941SHans de Goede touchscreen-inverted-x; 111*8b1ba941SHans de Goede touchscreen-swapped-x-y; 112*8b1ba941SHans de Goede }; 113*8b1ba941SHans de Goede 11453ab4af3SHans de Goede pcf8563: rtc@51 { 11553ab4af3SHans de Goede compatible = "nxp,pcf8563"; 11653ab4af3SHans de Goede reg = <0x51>; 11753ab4af3SHans de Goede }; 11853ab4af3SHans de Goede}; 11953ab4af3SHans de Goede 12053ab4af3SHans de Goede&lradc { 12153ab4af3SHans de Goede vref-supply = <®_ldo2>; 12253ab4af3SHans de Goede status = "okay"; 12353ab4af3SHans de Goede 12453ab4af3SHans de Goede button@200 { 12553ab4af3SHans de Goede label = "Volume Up"; 12653ab4af3SHans de Goede linux,code = <KEY_VOLUMEUP>; 12753ab4af3SHans de Goede channel = <0>; 12853ab4af3SHans de Goede voltage = <200000>; 12953ab4af3SHans de Goede }; 13053ab4af3SHans de Goede 13153ab4af3SHans de Goede button@400 { 13253ab4af3SHans de Goede label = "Volume Down"; 13353ab4af3SHans de Goede linux,code = <KEY_VOLUMEDOWN>; 13453ab4af3SHans de Goede channel = <0>; 13553ab4af3SHans de Goede voltage = <400000>; 13653ab4af3SHans de Goede }; 13753ab4af3SHans de Goede}; 13853ab4af3SHans de Goede 13953ab4af3SHans de Goede&mmc0 { 14053ab4af3SHans de Goede pinctrl-names = "default"; 14153ab4af3SHans de Goede pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_p66>; 14253ab4af3SHans de Goede vmmc-supply = <®_vcc3v3>; 14353ab4af3SHans de Goede bus-width = <4>; 14453ab4af3SHans de Goede cd-gpios = <&pio 6 0 GPIO_ACTIVE_HIGH>; /* PG0 */ 14553ab4af3SHans de Goede cd-inverted; 14653ab4af3SHans de Goede status = "okay"; 14753ab4af3SHans de Goede}; 14853ab4af3SHans de Goede 14953ab4af3SHans de Goede&mmc2 { 15053ab4af3SHans de Goede pinctrl-names = "default"; 15153ab4af3SHans de Goede pinctrl-0 = <&mmc2_pins_a>; 15253ab4af3SHans de Goede vmmc-supply = <®_vcc3v3>; 15353ab4af3SHans de Goede bus-width = <8>; 15453ab4af3SHans de Goede non-removable; 15553ab4af3SHans de Goede status = "okay"; 15653ab4af3SHans de Goede 15753ab4af3SHans de Goede mmccard: mmccard@0 { 15853ab4af3SHans de Goede reg = <0>; 15953ab4af3SHans de Goede compatible = "mmc-card"; 16053ab4af3SHans de Goede broken-hpi; 16153ab4af3SHans de Goede }; 16253ab4af3SHans de Goede}; 16353ab4af3SHans de Goede 16453ab4af3SHans de Goede&pio { 16553ab4af3SHans de Goede mmc0_cd_pin_p66: mmc0_cd_pin@0 { 16653ab4af3SHans de Goede allwinner,pins = "PG0"; 16753ab4af3SHans de Goede allwinner,function = "gpio_in"; 16853ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 16953ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_PULL_UP>; 17053ab4af3SHans de Goede }; 17153ab4af3SHans de Goede 17253ab4af3SHans de Goede i2c_lcd_pins: i2c_lcd_pin@0 { 17353ab4af3SHans de Goede allwinner,pins = "PG10", "PG12"; 17453ab4af3SHans de Goede allwinner,function = "gpio_out"; 17553ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 17653ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_PULL_UP>; 17753ab4af3SHans de Goede }; 17853ab4af3SHans de Goede 179*8b1ba941SHans de Goede ts_wake_pin_p66: ts_wake_pin@0 { 180*8b1ba941SHans de Goede allwinner,pins = "PB3"; 181*8b1ba941SHans de Goede allwinner,function = "gpio_out"; 182*8b1ba941SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 183*8b1ba941SHans de Goede allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; 184*8b1ba941SHans de Goede }; 185*8b1ba941SHans de Goede 18653ab4af3SHans de Goede usb0_vbus_pin_a: usb0_vbus_pin@0 { 18753ab4af3SHans de Goede allwinner,pins = "PB4"; 18853ab4af3SHans de Goede allwinner,function = "gpio_out"; 18953ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 19053ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; 19153ab4af3SHans de Goede }; 19253ab4af3SHans de Goede}; 19353ab4af3SHans de Goede 19453ab4af3SHans de Goede®_dcdc2 { 19553ab4af3SHans de Goede regulator-always-on; 19653ab4af3SHans de Goede regulator-min-microvolt = <1000000>; 19753ab4af3SHans de Goede regulator-max-microvolt = <1500000>; 19853ab4af3SHans de Goede regulator-name = "vdd-cpu"; 19953ab4af3SHans de Goede}; 20053ab4af3SHans de Goede 20153ab4af3SHans de Goede®_dcdc3 { 20253ab4af3SHans de Goede regulator-always-on; 20353ab4af3SHans de Goede regulator-min-microvolt = <1000000>; 20453ab4af3SHans de Goede regulator-max-microvolt = <1400000>; 20553ab4af3SHans de Goede regulator-name = "vdd-int-pll"; 20653ab4af3SHans de Goede}; 20753ab4af3SHans de Goede 20853ab4af3SHans de Goede®_ldo1 { 20953ab4af3SHans de Goede regulator-name = "vdd-rtc"; 21053ab4af3SHans de Goede}; 21153ab4af3SHans de Goede 21253ab4af3SHans de Goede®_ldo2 { 21353ab4af3SHans de Goede regulator-always-on; 21453ab4af3SHans de Goede regulator-min-microvolt = <3000000>; 21553ab4af3SHans de Goede regulator-max-microvolt = <3000000>; 21653ab4af3SHans de Goede regulator-name = "avcc"; 21753ab4af3SHans de Goede}; 21853ab4af3SHans de Goede 21953ab4af3SHans de Goede®_ldo3 { 22053ab4af3SHans de Goede regulator-min-microvolt = <3300000>; 22153ab4af3SHans de Goede regulator-max-microvolt = <3300000>; 22253ab4af3SHans de Goede regulator-name = "vcc-wifi"; 22353ab4af3SHans de Goede}; 22453ab4af3SHans de Goede 22553ab4af3SHans de Goede®_usb0_vbus { 22653ab4af3SHans de Goede gpio = <&pio 1 4 GPIO_ACTIVE_HIGH>; /* PB4 */ 22753ab4af3SHans de Goede status = "okay"; 22853ab4af3SHans de Goede}; 22953ab4af3SHans de Goede 23053ab4af3SHans de Goede&uart1 { 23153ab4af3SHans de Goede pinctrl-names = "default"; 23253ab4af3SHans de Goede pinctrl-0 = <&uart1_pins_b>; 23353ab4af3SHans de Goede status = "okay"; 23453ab4af3SHans de Goede}; 23553ab4af3SHans de Goede 23653ab4af3SHans de Goede&usbphy { 23753ab4af3SHans de Goede usb0_vbus-supply = <®_usb0_vbus>; 23853ab4af3SHans de Goede usb1_vbus-supply = <®_ldo3>; 23953ab4af3SHans de Goede status = "okay"; 24053ab4af3SHans de Goede}; 241