153ab4af3SHans de Goede/* 253ab4af3SHans de Goede * Copyright 2013 Wills Wang 353ab4af3SHans de Goede * 453ab4af3SHans de Goede * Wills Wang <wills.wang.open@gmail.com> 553ab4af3SHans de Goede * 653ab4af3SHans de Goede * This file is dual-licensed: you can use it either under the terms 753ab4af3SHans de Goede * of the GPL or the X11 license, at your option. Note that this dual 853ab4af3SHans de Goede * licensing only applies to this file, and not this project as a 953ab4af3SHans de Goede * whole. 1053ab4af3SHans de Goede * 1153ab4af3SHans de Goede * a) This file is free software; you can redistribute it and/or 1253ab4af3SHans de Goede * modify it under the terms of the GNU General Public License as 1353ab4af3SHans de Goede * published by the Free Software Foundation; either version 2 of the 1453ab4af3SHans de Goede * License, or (at your option) any later version. 1553ab4af3SHans de Goede * 1653ab4af3SHans de Goede * This file is distributed in the hope that it will be useful, 1753ab4af3SHans de Goede * but WITHOUT ANY WARRANTY; without even the implied warranty of 1853ab4af3SHans de Goede * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 1953ab4af3SHans de Goede * GNU General Public License for more details. 2053ab4af3SHans de Goede * 2153ab4af3SHans de Goede * Or, alternatively, 2253ab4af3SHans de Goede * 2353ab4af3SHans de Goede * b) Permission is hereby granted, free of charge, to any person 2453ab4af3SHans de Goede * obtaining a copy of this software and associated documentation 2553ab4af3SHans de Goede * files (the "Software"), to deal in the Software without 2653ab4af3SHans de Goede * restriction, including without limitation the rights to use, 2753ab4af3SHans de Goede * copy, modify, merge, publish, distribute, sublicense, and/or 2853ab4af3SHans de Goede * sell copies of the Software, and to permit persons to whom the 2953ab4af3SHans de Goede * Software is furnished to do so, subject to the following 3053ab4af3SHans de Goede * conditions: 3153ab4af3SHans de Goede * 3253ab4af3SHans de Goede * The above copyright notice and this permission notice shall be 3353ab4af3SHans de Goede * included in all copies or substantial portions of the Software. 3453ab4af3SHans de Goede * 3553ab4af3SHans de Goede * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 3653ab4af3SHans de Goede * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 3753ab4af3SHans de Goede * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 3853ab4af3SHans de Goede * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 3953ab4af3SHans de Goede * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 4053ab4af3SHans de Goede * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 4153ab4af3SHans de Goede * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 4253ab4af3SHans de Goede * OTHER DEALINGS IN THE SOFTWARE. 4353ab4af3SHans de Goede */ 4453ab4af3SHans de Goede 4553ab4af3SHans de Goede/dts-v1/; 4653ab4af3SHans de Goede#include "sun7i-a20.dtsi" 4753ab4af3SHans de Goede#include "sunxi-common-regulators.dtsi" 4853ab4af3SHans de Goede 4953ab4af3SHans de Goede#include <dt-bindings/gpio/gpio.h> 5053ab4af3SHans de Goede#include <dt-bindings/interrupt-controller/irq.h> 5153ab4af3SHans de Goede#include <dt-bindings/pinctrl/sun4i-a10.h> 5253ab4af3SHans de Goede 5353ab4af3SHans de Goede/ { 5453ab4af3SHans de Goede model = "Merrii A20 Hummingbird"; 5553ab4af3SHans de Goede compatible = "merrii,a20-hummingbird", "allwinner,sun7i-a20"; 5653ab4af3SHans de Goede 5753ab4af3SHans de Goede aliases { 5853ab4af3SHans de Goede serial0 = &uart0; 5953ab4af3SHans de Goede serial1 = &uart2; 6053ab4af3SHans de Goede serial2 = &uart3; 6153ab4af3SHans de Goede serial3 = &uart4; 6253ab4af3SHans de Goede serial4 = &uart5; 6353ab4af3SHans de Goede }; 6453ab4af3SHans de Goede 6553ab4af3SHans de Goede chosen { 6653ab4af3SHans de Goede stdout-path = "serial0:115200n8"; 6753ab4af3SHans de Goede }; 6853ab4af3SHans de Goede 6953ab4af3SHans de Goede reg_mmc3_vdd: mmc3_vdd { 7053ab4af3SHans de Goede compatible = "regulator-fixed"; 7153ab4af3SHans de Goede pinctrl-names = "default"; 7253ab4af3SHans de Goede pinctrl-0 = <&mmc3_vdd_pin_a20_hummingbird>; 7353ab4af3SHans de Goede regulator-name = "mmc3_vdd"; 7453ab4af3SHans de Goede regulator-min-microvolt = <3000000>; 7553ab4af3SHans de Goede regulator-max-microvolt = <3000000>; 7653ab4af3SHans de Goede enable-active-high; 7753ab4af3SHans de Goede gpio = <&pio 7 9 GPIO_ACTIVE_HIGH>; /* PH9 */ 7853ab4af3SHans de Goede }; 7953ab4af3SHans de Goede 8053ab4af3SHans de Goede reg_gmac_vdd: gmac_vdd { 8153ab4af3SHans de Goede compatible = "regulator-fixed"; 8253ab4af3SHans de Goede pinctrl-names = "default"; 8353ab4af3SHans de Goede pinctrl-0 = <&gmac_vdd_pin_a20_hummingbird>; 8453ab4af3SHans de Goede regulator-name = "gmac_vdd"; 8553ab4af3SHans de Goede regulator-min-microvolt = <3000000>; 8653ab4af3SHans de Goede regulator-max-microvolt = <3000000>; 8753ab4af3SHans de Goede enable-active-high; 8853ab4af3SHans de Goede gpio = <&pio 7 16 GPIO_ACTIVE_HIGH>; /* PH16 */ 8953ab4af3SHans de Goede }; 9053ab4af3SHans de Goede}; 9153ab4af3SHans de Goede 9253ab4af3SHans de Goede&ahci { 9353ab4af3SHans de Goede target-supply = <®_ahci_5v>; 9453ab4af3SHans de Goede status = "okay"; 9553ab4af3SHans de Goede}; 9653ab4af3SHans de Goede 9753ab4af3SHans de Goede&ehci0 { 9853ab4af3SHans de Goede status = "okay"; 9953ab4af3SHans de Goede}; 10053ab4af3SHans de Goede 10153ab4af3SHans de Goede&ehci1 { 10253ab4af3SHans de Goede status = "okay"; 10353ab4af3SHans de Goede}; 10453ab4af3SHans de Goede 10553ab4af3SHans de Goede&gmac { 10653ab4af3SHans de Goede pinctrl-names = "default"; 10753ab4af3SHans de Goede pinctrl-0 = <&gmac_pins_rgmii_a>; 10853ab4af3SHans de Goede phy = <&phy1>; 10953ab4af3SHans de Goede phy-mode = "rgmii"; 11053ab4af3SHans de Goede phy-supply = <®_gmac_vdd>; 11153ab4af3SHans de Goede /* phy reset config */ 11253ab4af3SHans de Goede snps,reset-gpio = <&pio 0 17 GPIO_ACTIVE_HIGH>; /* PA17 */ 11353ab4af3SHans de Goede snps,reset-active-low; 11453ab4af3SHans de Goede /* wait 1s after reset, otherwise fail to read phy id */ 11553ab4af3SHans de Goede snps,reset-delays-us = <0 10000 1000000>; 11653ab4af3SHans de Goede status = "okay"; 11753ab4af3SHans de Goede 11853ab4af3SHans de Goede phy1: ethernet-phy@1 { 11953ab4af3SHans de Goede reg = <1>; 12053ab4af3SHans de Goede }; 12153ab4af3SHans de Goede}; 12253ab4af3SHans de Goede 12353ab4af3SHans de Goede&i2c0 { 12453ab4af3SHans de Goede pinctrl-names = "default"; 12553ab4af3SHans de Goede pinctrl-0 = <&i2c0_pins_a>; 12653ab4af3SHans de Goede status = "okay"; 12753ab4af3SHans de Goede 12853ab4af3SHans de Goede axp209: pmic@34 { 12953ab4af3SHans de Goede compatible = "x-powers,axp209"; 13053ab4af3SHans de Goede reg = <0x34>; 13153ab4af3SHans de Goede interrupt-parent = <&nmi_intc>; 13253ab4af3SHans de Goede interrupts = <0 IRQ_TYPE_LEVEL_LOW>; 13353ab4af3SHans de Goede interrupt-controller; 13453ab4af3SHans de Goede #interrupt-cells = <1>; 13553ab4af3SHans de Goede }; 13653ab4af3SHans de Goede}; 13753ab4af3SHans de Goede 13853ab4af3SHans de Goede&i2c1 { 13953ab4af3SHans de Goede pinctrl-names = "default"; 14053ab4af3SHans de Goede pinctrl-0 = <&i2c1_pins_a>; 14153ab4af3SHans de Goede status = "okay"; 14253ab4af3SHans de Goede}; 14353ab4af3SHans de Goede 14453ab4af3SHans de Goede&i2c2 { 14553ab4af3SHans de Goede pinctrl-names = "default"; 14653ab4af3SHans de Goede pinctrl-0 = <&i2c2_pins_a>; 14753ab4af3SHans de Goede status = "okay"; 14853ab4af3SHans de Goede}; 14953ab4af3SHans de Goede 15053ab4af3SHans de Goede&i2c3 { 15153ab4af3SHans de Goede pinctrl-names = "default"; 15253ab4af3SHans de Goede pinctrl-0 = <&i2c3_pins_a>; 15353ab4af3SHans de Goede status = "okay"; 15453ab4af3SHans de Goede}; 15553ab4af3SHans de Goede 15653ab4af3SHans de Goede&ir0 { 15753ab4af3SHans de Goede pinctrl-names = "default"; 158*8b1ba941SHans de Goede pinctrl-0 = <&ir0_rx_pins_a>; 15953ab4af3SHans de Goede status = "okay"; 16053ab4af3SHans de Goede}; 16153ab4af3SHans de Goede 16253ab4af3SHans de Goede&mmc0 { 16353ab4af3SHans de Goede pinctrl-names = "default"; 16453ab4af3SHans de Goede pinctrl-0 = <&mmc0_pins_a>, <&mmc0_cd_pin_reference_design>; 16553ab4af3SHans de Goede vmmc-supply = <®_vcc3v0>; 16653ab4af3SHans de Goede bus-width = <4>; 16753ab4af3SHans de Goede cd-gpios = <&pio 7 1 GPIO_ACTIVE_HIGH>; /* PH1 */ 16853ab4af3SHans de Goede cd-inverted; 16953ab4af3SHans de Goede status = "okay"; 17053ab4af3SHans de Goede}; 17153ab4af3SHans de Goede 17253ab4af3SHans de Goede&mmc3 { 17353ab4af3SHans de Goede pinctrl-names = "default"; 17453ab4af3SHans de Goede pinctrl-0 = <&mmc3_pins_a>; 17553ab4af3SHans de Goede vmmc-supply = <®_mmc3_vdd>; 17653ab4af3SHans de Goede bus-width = <4>; 17753ab4af3SHans de Goede non-removable; 17853ab4af3SHans de Goede status = "okay"; 17953ab4af3SHans de Goede}; 18053ab4af3SHans de Goede 18153ab4af3SHans de Goede&ohci0 { 18253ab4af3SHans de Goede status = "okay"; 18353ab4af3SHans de Goede}; 18453ab4af3SHans de Goede 18553ab4af3SHans de Goede&ohci1 { 18653ab4af3SHans de Goede status = "okay"; 18753ab4af3SHans de Goede}; 18853ab4af3SHans de Goede 18953ab4af3SHans de Goede&pio { 19053ab4af3SHans de Goede ahci_pwr_pin_a20_hummingbird: ahci_pwr_pin@0 { 19153ab4af3SHans de Goede allwinner,pins = "PH15"; 19253ab4af3SHans de Goede allwinner,function = "gpio_out"; 19353ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 19453ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; 19553ab4af3SHans de Goede }; 19653ab4af3SHans de Goede 19753ab4af3SHans de Goede usb1_vbus_pin_a20_hummingbird: usb1_vbus_pin@0 { 19853ab4af3SHans de Goede allwinner,pins = "PH2"; 19953ab4af3SHans de Goede allwinner,function = "gpio_out"; 20053ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 20153ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; 20253ab4af3SHans de Goede }; 20353ab4af3SHans de Goede 20453ab4af3SHans de Goede mmc3_vdd_pin_a20_hummingbird: mmc3_vdd_pin@0 { 20553ab4af3SHans de Goede allwinner,pins = "PH9"; 20653ab4af3SHans de Goede allwinner,function = "gpio_out"; 20753ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 20853ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; 20953ab4af3SHans de Goede }; 21053ab4af3SHans de Goede 21153ab4af3SHans de Goede gmac_vdd_pin_a20_hummingbird: gmac_vdd_pin@0 { 21253ab4af3SHans de Goede allwinner,pins = "PH16"; 21353ab4af3SHans de Goede allwinner,function = "gpio_out"; 21453ab4af3SHans de Goede allwinner,drive = <SUN4I_PINCTRL_10_MA>; 21553ab4af3SHans de Goede allwinner,pull = <SUN4I_PINCTRL_NO_PULL>; 21653ab4af3SHans de Goede }; 21753ab4af3SHans de Goede}; 21853ab4af3SHans de Goede 21953ab4af3SHans de Goede&pwm { 22053ab4af3SHans de Goede pinctrl-names = "default"; 22153ab4af3SHans de Goede pinctrl-0 = <&pwm0_pins_a>; 22253ab4af3SHans de Goede status = "okay"; 22353ab4af3SHans de Goede}; 22453ab4af3SHans de Goede 22553ab4af3SHans de Goede®_ahci_5v { 22653ab4af3SHans de Goede pinctrl-0 = <&ahci_pwr_pin_a20_hummingbird>; 22753ab4af3SHans de Goede gpio = <&pio 7 15 GPIO_ACTIVE_HIGH>; /* PH15 */ 22853ab4af3SHans de Goede status = "okay"; 22953ab4af3SHans de Goede}; 23053ab4af3SHans de Goede 23153ab4af3SHans de Goede®_usb1_vbus { 23253ab4af3SHans de Goede pinctrl-0 = <&usb1_vbus_pin_a20_hummingbird>; 23353ab4af3SHans de Goede gpio = <&pio 7 2 GPIO_ACTIVE_HIGH>; /* PH2 */ 23453ab4af3SHans de Goede status = "okay"; 23553ab4af3SHans de Goede}; 23653ab4af3SHans de Goede 23753ab4af3SHans de Goede®_usb2_vbus { 23853ab4af3SHans de Goede status = "okay"; 23953ab4af3SHans de Goede}; 24053ab4af3SHans de Goede 24153ab4af3SHans de Goede&spi2 { 24253ab4af3SHans de Goede pinctrl-names = "default"; 243*8b1ba941SHans de Goede pinctrl-0 = <&spi2_pins_b>, 244*8b1ba941SHans de Goede <&spi2_cs0_pins_b>; 24553ab4af3SHans de Goede status = "okay"; 24653ab4af3SHans de Goede}; 24753ab4af3SHans de Goede 24853ab4af3SHans de Goede&uart0 { 24953ab4af3SHans de Goede pinctrl-names = "default"; 25053ab4af3SHans de Goede pinctrl-0 = <&uart0_pins_a>; 25153ab4af3SHans de Goede status = "okay"; 25253ab4af3SHans de Goede}; 25353ab4af3SHans de Goede 25453ab4af3SHans de Goede&uart2 { 25553ab4af3SHans de Goede pinctrl-names = "default"; 25653ab4af3SHans de Goede pinctrl-0 = <&uart2_pins_a>; 25753ab4af3SHans de Goede status = "okay"; 25853ab4af3SHans de Goede}; 25953ab4af3SHans de Goede 26053ab4af3SHans de Goede&uart3 { 26153ab4af3SHans de Goede pinctrl-names = "default"; 26253ab4af3SHans de Goede pinctrl-0 = <&uart3_pins_a>; 26353ab4af3SHans de Goede status = "okay"; 26453ab4af3SHans de Goede}; 26553ab4af3SHans de Goede 26653ab4af3SHans de Goede&uart4 { 26753ab4af3SHans de Goede pinctrl-names = "default"; 26853ab4af3SHans de Goede pinctrl-0 = <&uart4_pins_a>; 26953ab4af3SHans de Goede status = "okay"; 27053ab4af3SHans de Goede}; 27153ab4af3SHans de Goede 27253ab4af3SHans de Goede&uart5 { 27353ab4af3SHans de Goede pinctrl-names = "default"; 27453ab4af3SHans de Goede pinctrl-0 = <&uart5_pins_a>; 27553ab4af3SHans de Goede status = "okay"; 27653ab4af3SHans de Goede}; 27753ab4af3SHans de Goede 27853ab4af3SHans de Goede&usbphy { 27953ab4af3SHans de Goede usb1_vbus-supply = <®_usb1_vbus>; 28053ab4af3SHans de Goede usb2_vbus-supply = <®_usb2_vbus>; 28153ab4af3SHans de Goede status = "okay"; 28253ab4af3SHans de Goede}; 283