1bf397214SJagan Teki/* 2bf397214SJagan Teki * Copyright (C) 2017 Jagan Teki <jteki@openedev.com> 3bf397214SJagan Teki * 4bf397214SJagan Teki * This file is dual-licensed: you can use it either under the terms 5bf397214SJagan Teki * of the GPL or the X11 license, at your option. Note that this dual 6bf397214SJagan Teki * licensing only applies to this file, and not this project as a 7bf397214SJagan Teki * whole. 8bf397214SJagan Teki * 9bf397214SJagan Teki * a) This library is free software; you can redistribute it and/or 10bf397214SJagan Teki * modify it under the terms of the GNU General Public License as 11bf397214SJagan Teki * published by the Free Software Foundation; either version 2 of the 12bf397214SJagan Teki * License, or (at your option) any later version. 13bf397214SJagan Teki * 14bf397214SJagan Teki * This library is distributed in the hope that it will be useful, 15bf397214SJagan Teki * but WITHOUT ANY WARRANTY; without even the implied warranty of 16bf397214SJagan Teki * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 17bf397214SJagan Teki * GNU General Public License for more details. 18bf397214SJagan Teki * 19bf397214SJagan Teki * Or, alternatively, 20bf397214SJagan Teki * 21bf397214SJagan Teki * b) Permission is hereby granted, free of charge, to any person 22bf397214SJagan Teki * obtaining a copy of this software and associated documentation 23bf397214SJagan Teki * files (the "Software"), to deal in the Software without 24bf397214SJagan Teki * restriction, including without limitation the rights to use, 25bf397214SJagan Teki * copy, modify, merge, publish, distribute, sublicense, and/or 26bf397214SJagan Teki * sell copies of the Software, and to permit persons to whom the 27bf397214SJagan Teki * Software is furnished to do so, subject to the following 28bf397214SJagan Teki * conditions: 29bf397214SJagan Teki * 30bf397214SJagan Teki * The above copyright notice and this permission notice shall be 31bf397214SJagan Teki * included in all copies or substantial portions of the Software. 32bf397214SJagan Teki * 33bf397214SJagan Teki * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 34bf397214SJagan Teki * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 35bf397214SJagan Teki * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 36bf397214SJagan Teki * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 37bf397214SJagan Teki * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 38bf397214SJagan Teki * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 39bf397214SJagan Teki * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 40bf397214SJagan Teki * OTHER DEALINGS IN THE SOFTWARE. 41bf397214SJagan Teki */ 42bf397214SJagan Teki 43bf397214SJagan Teki/dts-v1/; 44bf397214SJagan Teki 45bf397214SJagan Teki#include "sun50i-a64.dtsi" 46bf397214SJagan Teki 47bf397214SJagan Teki#include <dt-bindings/gpio/gpio.h> 48bf397214SJagan Teki 49bf397214SJagan Teki/ { 50bf397214SJagan Teki model = "FriendlyARM NanoPi A64"; 51bf397214SJagan Teki compatible = "friendlyarm,nanopi-a64", "allwinner,sun50i-a64"; 52bf397214SJagan Teki 53bf397214SJagan Teki aliases { 54708db568SAndre Przywara ethernet0 = &emac; 55bf397214SJagan Teki serial0 = &uart0; 56bf397214SJagan Teki }; 57bf397214SJagan Teki 58bf397214SJagan Teki chosen { 59bf397214SJagan Teki stdout-path = "serial0:115200n8"; 60bf397214SJagan Teki }; 61ca6aee21SAndre Przywara 62ca6aee21SAndre Przywara wifi_pwrseq: wifi_pwrseq { 63ca6aee21SAndre Przywara compatible = "mmc-pwrseq-simple"; 64ca6aee21SAndre Przywara clocks = <&rtc 1>; 65ca6aee21SAndre Przywara clock-names = "ext_clock"; 66ca6aee21SAndre Przywara reset-gpios = <&r_pio 0 2 GPIO_ACTIVE_LOW>; /* PL2 */ 67ca6aee21SAndre Przywara }; 68bf397214SJagan Teki}; 69bf397214SJagan Teki 70bf397214SJagan Teki&ehci0 { 71bf397214SJagan Teki status = "okay"; 72bf397214SJagan Teki}; 73bf397214SJagan Teki 74bf397214SJagan Teki&ehci1 { 75bf397214SJagan Teki status = "okay"; 76bf397214SJagan Teki}; 77bf397214SJagan Teki 78708db568SAndre Przywara&emac { 79708db568SAndre Przywara pinctrl-names = "default"; 80708db568SAndre Przywara pinctrl-0 = <&rgmii_pins>; 81708db568SAndre Przywara phy-mode = "rgmii"; 82708db568SAndre Przywara phy-handle = <&ext_rgmii_phy>; 83708db568SAndre Przywara phy-supply = <®_dcdc1>; 84708db568SAndre Przywara status = "okay"; 85708db568SAndre Przywara}; 86708db568SAndre Przywara 87bf397214SJagan Teki/* i2c1 connected with gpio headers like pine64, bananapi */ 88bf397214SJagan Teki&i2c1 { 89bf397214SJagan Teki pinctrl-names = "default"; 90bf397214SJagan Teki pinctrl-0 = <&i2c1_pins>; 91bf397214SJagan Teki status = "disabled"; 92bf397214SJagan Teki}; 93bf397214SJagan Teki 94bf397214SJagan Teki&i2c1_pins { 95bf397214SJagan Teki bias-pull-up; 96bf397214SJagan Teki}; 97bf397214SJagan Teki 98708db568SAndre Przywara&mdio { 99708db568SAndre Przywara ext_rgmii_phy: ethernet-phy@1 { 100708db568SAndre Przywara compatible = "ethernet-phy-ieee802.3-c22"; 101708db568SAndre Przywara reg = <7>; 102708db568SAndre Przywara }; 103708db568SAndre Przywara}; 104708db568SAndre Przywara 105bf397214SJagan Teki&mmc0 { 106bf397214SJagan Teki pinctrl-names = "default"; 107bf397214SJagan Teki pinctrl-0 = <&mmc0_pins>; 108bf397214SJagan Teki vmmc-supply = <®_dcdc1>; 109b75cb68dSTuomas Tynkkynen cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; 110bf397214SJagan Teki disable-wp; 111bf397214SJagan Teki bus-width = <4>; 112bf397214SJagan Teki status = "okay"; 113bf397214SJagan Teki}; 114bf397214SJagan Teki 115ca6aee21SAndre Przywara&mmc1 { 116ca6aee21SAndre Przywara pinctrl-names = "default"; 117ca6aee21SAndre Przywara pinctrl-0 = <&mmc1_pins>; 118ca6aee21SAndre Przywara vmmc-supply = <®_dcdc1>; 119ca6aee21SAndre Przywara vqmmc-supply = <®_dldo4>; 120ca6aee21SAndre Przywara mmc-pwrseq = <&wifi_pwrseq>; 121ca6aee21SAndre Przywara bus-width = <4>; 122ca6aee21SAndre Przywara non-removable; 123ca6aee21SAndre Przywara status = "okay"; 124ca6aee21SAndre Przywara 125ca6aee21SAndre Przywara rtl8189etv: wifi@1 { 126ca6aee21SAndre Przywara reg = <1>; 127ca6aee21SAndre Przywara interrupt-parent = <&r_pio>; 128ca6aee21SAndre Przywara interrupts = <0 3 IRQ_TYPE_LEVEL_LOW>; /* PL3 */ 129ca6aee21SAndre Przywara interrupt-names = "host-wake"; 130ca6aee21SAndre Przywara }; 131ca6aee21SAndre Przywara}; 132ca6aee21SAndre Przywara 133bf397214SJagan Teki&ohci0 { 134bf397214SJagan Teki status = "okay"; 135bf397214SJagan Teki}; 136bf397214SJagan Teki 137bf397214SJagan Teki&ohci1 { 138bf397214SJagan Teki status = "okay"; 139bf397214SJagan Teki}; 140bf397214SJagan Teki 141bf397214SJagan Teki&r_rsb { 142bf397214SJagan Teki status = "okay"; 143bf397214SJagan Teki 144bf397214SJagan Teki axp803: pmic@3a3 { 145bf397214SJagan Teki compatible = "x-powers,axp803"; 146bf397214SJagan Teki reg = <0x3a3>; 147bf397214SJagan Teki interrupt-parent = <&r_intc>; 148bf397214SJagan Teki interrupts = <0 IRQ_TYPE_LEVEL_LOW>; 149bf397214SJagan Teki }; 150bf397214SJagan Teki}; 151bf397214SJagan Teki 152bf397214SJagan Teki#include "axp803.dtsi" 153bf397214SJagan Teki 154bf397214SJagan Teki®_aldo2 { 155bf397214SJagan Teki regulator-always-on; 156bf397214SJagan Teki regulator-min-microvolt = <1800000>; 157bf397214SJagan Teki regulator-max-microvolt = <3300000>; 158bf397214SJagan Teki regulator-name = "vcc-pl"; 159bf397214SJagan Teki}; 160bf397214SJagan Teki 161bf397214SJagan Teki®_aldo3 { 162bf397214SJagan Teki regulator-always-on; 163bf397214SJagan Teki regulator-min-microvolt = <3000000>; 164bf397214SJagan Teki regulator-max-microvolt = <3000000>; 165bf397214SJagan Teki regulator-name = "vcc-pll-avcc"; 166bf397214SJagan Teki}; 167bf397214SJagan Teki 168bf397214SJagan Teki®_dcdc1 { 169bf397214SJagan Teki regulator-always-on; 170480f58cdSAndre Przywara regulator-min-microvolt = <3300000>; 171480f58cdSAndre Przywara regulator-max-microvolt = <3300000>; 172480f58cdSAndre Przywara regulator-name = "vcc-3v3"; 173bf397214SJagan Teki}; 174bf397214SJagan Teki 175bf397214SJagan Teki®_dcdc2 { 176bf397214SJagan Teki regulator-always-on; 177bf397214SJagan Teki regulator-min-microvolt = <1040000>; 178bf397214SJagan Teki regulator-max-microvolt = <1300000>; 179bf397214SJagan Teki regulator-name = "vdd-cpux"; 180bf397214SJagan Teki}; 181bf397214SJagan Teki 182bf397214SJagan Teki/* DCDC3 is polyphased with DCDC2 */ 183bf397214SJagan Teki 184bf397214SJagan Teki®_dcdc5 { 185bf397214SJagan Teki regulator-always-on; 186bf397214SJagan Teki regulator-min-microvolt = <1500000>; 187bf397214SJagan Teki regulator-max-microvolt = <1500000>; 188bf397214SJagan Teki regulator-name = "vcc-dram"; 189bf397214SJagan Teki}; 190bf397214SJagan Teki 191bf397214SJagan Teki®_dcdc6 { 192bf397214SJagan Teki regulator-always-on; 193bf397214SJagan Teki regulator-min-microvolt = <1100000>; 194bf397214SJagan Teki regulator-max-microvolt = <1100000>; 195bf397214SJagan Teki regulator-name = "vdd-sys"; 196bf397214SJagan Teki}; 197bf397214SJagan Teki 198bf397214SJagan Teki®_dldo1 { 199bf397214SJagan Teki regulator-always-on; 200bf397214SJagan Teki regulator-min-microvolt = <3300000>; 201bf397214SJagan Teki regulator-max-microvolt = <3300000>; 202bf397214SJagan Teki regulator-name = "vcc-hdmi-dsi"; 203bf397214SJagan Teki}; 204bf397214SJagan Teki 205bf397214SJagan Teki®_dldo4 { 206bf397214SJagan Teki regulator-always-on; 207bf397214SJagan Teki regulator-min-microvolt = <3000000>; 208bf397214SJagan Teki regulator-max-microvolt = <3000000>; 209bf397214SJagan Teki regulator-name = "vcc-pg-wifi-io"; 210bf397214SJagan Teki}; 211bf397214SJagan Teki 212bf397214SJagan Teki®_eldo1 { 213bf397214SJagan Teki regulator-min-microvolt = <1800000>; 214bf397214SJagan Teki regulator-max-microvolt = <1800000>; 215bf397214SJagan Teki regulator-name = "cpvdd"; 216bf397214SJagan Teki}; 217bf397214SJagan Teki 218bf397214SJagan Teki®_fldo1 { 219bf397214SJagan Teki regulator-min-microvolt = <1200000>; 220bf397214SJagan Teki regulator-max-microvolt = <1200000>; 221bf397214SJagan Teki regulator-name = "vcc-1v2-hsic"; 222bf397214SJagan Teki}; 223bf397214SJagan Teki 224bf397214SJagan Teki/* 225bf397214SJagan Teki * The A64 chip cannot work without this regulator off, although 226bf397214SJagan Teki * it seems to be only driving the AR100 core. 227bf397214SJagan Teki * Maybe we don't still know well about CPUs domain. 228bf397214SJagan Teki */ 229bf397214SJagan Teki®_fldo2 { 230bf397214SJagan Teki regulator-always-on; 231bf397214SJagan Teki regulator-min-microvolt = <1100000>; 232bf397214SJagan Teki regulator-max-microvolt = <1100000>; 233bf397214SJagan Teki regulator-name = "vdd-cpus"; 234bf397214SJagan Teki}; 235bf397214SJagan Teki 236bf397214SJagan Teki®_rtc_ldo { 237bf397214SJagan Teki regulator-name = "vcc-rtc"; 238bf397214SJagan Teki}; 239bf397214SJagan Teki 2405cbef9f9SIcenowy Zheng&simplefb_hdmi { 2415cbef9f9SIcenowy Zheng vcc-hdmi-supply = <®_dldo1>; 2425cbef9f9SIcenowy Zheng}; 2435cbef9f9SIcenowy Zheng 244bf397214SJagan Teki&uart0 { 245bf397214SJagan Teki pinctrl-names = "default"; 246bf397214SJagan Teki pinctrl-0 = <&uart0_pins_a>; 247bf397214SJagan Teki status = "okay"; 248bf397214SJagan Teki}; 249bf397214SJagan Teki 250bf397214SJagan Teki&usbphy { 251bf397214SJagan Teki status = "okay"; 252bf397214SJagan Teki}; 253