1*724ba675SRob Herring/* 2*724ba675SRob Herring * Copyright 2015 Vishnu Patekar 3*724ba675SRob Herring * Vishnu Patekar <vishnupatekar0510@gmail.com> 4*724ba675SRob Herring * 5*724ba675SRob Herring * This file is dual-licensed: you can use it either under the terms 6*724ba675SRob Herring * of the GPL or the X11 license, at your option. Note that this dual 7*724ba675SRob Herring * licensing only applies to this file, and not this project as a 8*724ba675SRob Herring * whole. 9*724ba675SRob Herring * 10*724ba675SRob Herring * a) This file is free software; you can redistribute it and/or 11*724ba675SRob Herring * modify it under the terms of the GNU General Public License as 12*724ba675SRob Herring * published by the Free Software Foundation; either version 2 of the 13*724ba675SRob Herring * License, or (at your option) any later version. 14*724ba675SRob Herring * 15*724ba675SRob Herring * This file is distributed in the hope that it will be useful, 16*724ba675SRob Herring * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*724ba675SRob Herring * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*724ba675SRob Herring * GNU General Public License for more details. 19*724ba675SRob Herring * 20*724ba675SRob Herring * Or, alternatively, 21*724ba675SRob Herring * 22*724ba675SRob Herring * b) Permission is hereby granted, free of charge, to any person 23*724ba675SRob Herring * obtaining a copy of this software and associated documentation 24*724ba675SRob Herring * files (the "Software"), to deal in the Software without 25*724ba675SRob Herring * restriction, including without limitation the rights to use, 26*724ba675SRob Herring * copy, modify, merge, publish, distribute, sublicense, and/or 27*724ba675SRob Herring * sell copies of the Software, and to permit persons to whom the 28*724ba675SRob Herring * Software is furnished to do so, subject to the following 29*724ba675SRob Herring * conditions: 30*724ba675SRob Herring * 31*724ba675SRob Herring * The above copyright notice and this permission notice shall be 32*724ba675SRob Herring * included in all copies or substantial portions of the Software. 33*724ba675SRob Herring * 34*724ba675SRob Herring * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 35*724ba675SRob Herring * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 36*724ba675SRob Herring * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 37*724ba675SRob Herring * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 38*724ba675SRob Herring * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 39*724ba675SRob Herring * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 40*724ba675SRob Herring * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 41*724ba675SRob Herring * OTHER DEALINGS IN THE SOFTWARE. 42*724ba675SRob Herring */ 43*724ba675SRob Herring 44*724ba675SRob Herring/dts-v1/; 45*724ba675SRob Herring#include "sun8i-a83t.dtsi" 46*724ba675SRob Herring 47*724ba675SRob Herring#include <dt-bindings/gpio/gpio.h> 48*724ba675SRob Herring 49*724ba675SRob Herring/ { 50*724ba675SRob Herring model = "Allwinner A83T H8Homlet Proto Dev Board v2.0"; 51*724ba675SRob Herring compatible = "allwinner,h8homlet-v2", "allwinner,sun8i-a83t"; 52*724ba675SRob Herring 53*724ba675SRob Herring aliases { 54*724ba675SRob Herring serial0 = &uart0; 55*724ba675SRob Herring }; 56*724ba675SRob Herring 57*724ba675SRob Herring chosen { 58*724ba675SRob Herring stdout-path = "serial0:115200n8"; 59*724ba675SRob Herring }; 60*724ba675SRob Herring 61*724ba675SRob Herring reg_usb0_vbus: reg-usb0-vbus { 62*724ba675SRob Herring compatible = "regulator-fixed"; 63*724ba675SRob Herring regulator-name = "usb0-vbus"; 64*724ba675SRob Herring regulator-min-microvolt = <5000000>; 65*724ba675SRob Herring regulator-max-microvolt = <5000000>; 66*724ba675SRob Herring regulator-boot-on; 67*724ba675SRob Herring enable-active-high; 68*724ba675SRob Herring gpio = <&r_pio 0 5 GPIO_ACTIVE_HIGH>; /* PL5 */ 69*724ba675SRob Herring }; 70*724ba675SRob Herring 71*724ba675SRob Herring reg_usb1_vbus: reg-usb1-vbus { 72*724ba675SRob Herring compatible = "regulator-fixed"; 73*724ba675SRob Herring regulator-name = "usb1-vbus"; 74*724ba675SRob Herring regulator-min-microvolt = <5000000>; 75*724ba675SRob Herring regulator-max-microvolt = <5000000>; 76*724ba675SRob Herring regulator-boot-on; 77*724ba675SRob Herring enable-active-high; 78*724ba675SRob Herring gpio = <&r_pio 0 6 GPIO_ACTIVE_HIGH>; /* PL6 */ 79*724ba675SRob Herring }; 80*724ba675SRob Herring}; 81*724ba675SRob Herring 82*724ba675SRob Herring&cpu0 { 83*724ba675SRob Herring cpu-supply = <®_dcdc2>; 84*724ba675SRob Herring}; 85*724ba675SRob Herring 86*724ba675SRob Herring&cpu100 { 87*724ba675SRob Herring cpu-supply = <®_dcdc3>; 88*724ba675SRob Herring}; 89*724ba675SRob Herring 90*724ba675SRob Herring&ehci0 { 91*724ba675SRob Herring status = "okay"; 92*724ba675SRob Herring}; 93*724ba675SRob Herring 94*724ba675SRob Herring&mmc0 { 95*724ba675SRob Herring pinctrl-names = "default"; 96*724ba675SRob Herring pinctrl-0 = <&mmc0_pins>; 97*724ba675SRob Herring vmmc-supply = <®_dcdc1>; 98*724ba675SRob Herring cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>; /* PF6 */ 99*724ba675SRob Herring bus-width = <4>; 100*724ba675SRob Herring status = "okay"; 101*724ba675SRob Herring}; 102*724ba675SRob Herring 103*724ba675SRob Herring&mmc2 { 104*724ba675SRob Herring pinctrl-names = "default"; 105*724ba675SRob Herring pinctrl-0 = <&mmc2_8bit_emmc_pins>; 106*724ba675SRob Herring vmmc-supply = <®_dcdc1>; 107*724ba675SRob Herring vqmmc-supply = <®_dcdc1>; 108*724ba675SRob Herring bus-width = <8>; 109*724ba675SRob Herring non-removable; 110*724ba675SRob Herring cap-mmc-hw-reset; 111*724ba675SRob Herring status = "okay"; 112*724ba675SRob Herring}; 113*724ba675SRob Herring 114*724ba675SRob Herring&ohci0 { 115*724ba675SRob Herring status = "okay"; 116*724ba675SRob Herring}; 117*724ba675SRob Herring 118*724ba675SRob Herring&r_rsb { 119*724ba675SRob Herring status = "okay"; 120*724ba675SRob Herring 121*724ba675SRob Herring axp81x: pmic@3a3 { 122*724ba675SRob Herring compatible = "x-powers,axp818", "x-powers,axp813"; 123*724ba675SRob Herring reg = <0x3a3>; 124*724ba675SRob Herring interrupt-parent = <&r_intc>; 125*724ba675SRob Herring interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_LOW>; 126*724ba675SRob Herring eldoin-supply = <®_dcdc1>; 127*724ba675SRob Herring swin-supply = <®_dcdc1>; 128*724ba675SRob Herring }; 129*724ba675SRob Herring 130*724ba675SRob Herring ac100: codec@e89 { 131*724ba675SRob Herring compatible = "x-powers,ac100"; 132*724ba675SRob Herring reg = <0xe89>; 133*724ba675SRob Herring 134*724ba675SRob Herring ac100_codec: codec { 135*724ba675SRob Herring compatible = "x-powers,ac100-codec"; 136*724ba675SRob Herring interrupt-parent = <&r_pio>; 137*724ba675SRob Herring interrupts = <0 11 IRQ_TYPE_LEVEL_LOW>; /* PL11 */ 138*724ba675SRob Herring #clock-cells = <0>; 139*724ba675SRob Herring clock-output-names = "4M_adda"; 140*724ba675SRob Herring }; 141*724ba675SRob Herring 142*724ba675SRob Herring ac100_rtc: rtc { 143*724ba675SRob Herring compatible = "x-powers,ac100-rtc"; 144*724ba675SRob Herring interrupt-parent = <&r_intc>; 145*724ba675SRob Herring interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_LOW>; 146*724ba675SRob Herring clocks = <&ac100_codec>; 147*724ba675SRob Herring #clock-cells = <1>; 148*724ba675SRob Herring clock-output-names = "cko1_rtc", 149*724ba675SRob Herring "cko2_rtc", 150*724ba675SRob Herring "cko3_rtc"; 151*724ba675SRob Herring }; 152*724ba675SRob Herring }; 153*724ba675SRob Herring}; 154*724ba675SRob Herring 155*724ba675SRob Herring#include "axp81x.dtsi" 156*724ba675SRob Herring 157*724ba675SRob Herring&ac_power_supply { 158*724ba675SRob Herring status = "okay"; 159*724ba675SRob Herring}; 160*724ba675SRob Herring 161*724ba675SRob Herring®_aldo1 { 162*724ba675SRob Herring regulator-always-on; 163*724ba675SRob Herring regulator-min-microvolt = <1800000>; 164*724ba675SRob Herring regulator-max-microvolt = <1800000>; 165*724ba675SRob Herring regulator-name = "vcc-1v8"; 166*724ba675SRob Herring}; 167*724ba675SRob Herring 168*724ba675SRob Herring®_aldo2 { 169*724ba675SRob Herring regulator-always-on; 170*724ba675SRob Herring regulator-min-microvolt = <1800000>; 171*724ba675SRob Herring regulator-max-microvolt = <1800000>; 172*724ba675SRob Herring regulator-name = "dram-pll"; 173*724ba675SRob Herring}; 174*724ba675SRob Herring 175*724ba675SRob Herring®_aldo3 { 176*724ba675SRob Herring regulator-always-on; 177*724ba675SRob Herring regulator-min-microvolt = <3000000>; 178*724ba675SRob Herring regulator-max-microvolt = <3000000>; 179*724ba675SRob Herring regulator-name = "avcc"; 180*724ba675SRob Herring}; 181*724ba675SRob Herring 182*724ba675SRob Herring®_dcdc1 { 183*724ba675SRob Herring regulator-always-on; 184*724ba675SRob Herring regulator-min-microvolt = <3300000>; 185*724ba675SRob Herring regulator-max-microvolt = <3300000>; 186*724ba675SRob Herring regulator-name = "vcc-3v3"; 187*724ba675SRob Herring}; 188*724ba675SRob Herring 189*724ba675SRob Herring®_dcdc2 { 190*724ba675SRob Herring regulator-always-on; 191*724ba675SRob Herring regulator-min-microvolt = <700000>; 192*724ba675SRob Herring regulator-max-microvolt = <1100000>; 193*724ba675SRob Herring regulator-name = "vdd-cpua"; 194*724ba675SRob Herring}; 195*724ba675SRob Herring 196*724ba675SRob Herring®_dcdc3 { 197*724ba675SRob Herring regulator-always-on; 198*724ba675SRob Herring regulator-min-microvolt = <700000>; 199*724ba675SRob Herring regulator-max-microvolt = <1100000>; 200*724ba675SRob Herring regulator-name = "vdd-cpub"; 201*724ba675SRob Herring}; 202*724ba675SRob Herring 203*724ba675SRob Herring®_dcdc4 { 204*724ba675SRob Herring regulator-min-microvolt = <700000>; 205*724ba675SRob Herring regulator-max-microvolt = <1100000>; 206*724ba675SRob Herring regulator-name = "vdd-gpu"; 207*724ba675SRob Herring}; 208*724ba675SRob Herring 209*724ba675SRob Herring®_dcdc5 { 210*724ba675SRob Herring regulator-always-on; 211*724ba675SRob Herring regulator-min-microvolt = <1500000>; 212*724ba675SRob Herring regulator-max-microvolt = <1500000>; 213*724ba675SRob Herring regulator-name = "vcc-dram"; 214*724ba675SRob Herring}; 215*724ba675SRob Herring 216*724ba675SRob Herring®_dcdc6 { 217*724ba675SRob Herring regulator-always-on; 218*724ba675SRob Herring regulator-min-microvolt = <900000>; 219*724ba675SRob Herring regulator-max-microvolt = <900000>; 220*724ba675SRob Herring regulator-name = "vdd-sys"; 221*724ba675SRob Herring}; 222*724ba675SRob Herring 223*724ba675SRob Herring®_dldo2 { 224*724ba675SRob Herring regulator-min-microvolt = <3300000>; 225*724ba675SRob Herring regulator-max-microvolt = <3300000>; 226*724ba675SRob Herring regulator-name = "vcc-mipi"; 227*724ba675SRob Herring}; 228*724ba675SRob Herring 229*724ba675SRob Herring®_dldo4 { 230*724ba675SRob Herring /* 231*724ba675SRob Herring * The PHY requires 20ms after all voltages are applied until core 232*724ba675SRob Herring * logic is ready and 30ms after the reset pin is de-asserted. 233*724ba675SRob Herring * Set a 100ms delay to account for PMIC ramp time and board traces. 234*724ba675SRob Herring */ 235*724ba675SRob Herring regulator-enable-ramp-delay = <100000>; 236*724ba675SRob Herring regulator-min-microvolt = <3300000>; 237*724ba675SRob Herring regulator-max-microvolt = <3300000>; 238*724ba675SRob Herring regulator-name = "vcc-ephy"; 239*724ba675SRob Herring}; 240*724ba675SRob Herring 241*724ba675SRob Herring®_fldo1 { 242*724ba675SRob Herring regulator-min-microvolt = <1080000>; 243*724ba675SRob Herring regulator-max-microvolt = <1320000>; 244*724ba675SRob Herring regulator-name = "vdd12-hsic"; 245*724ba675SRob Herring}; 246*724ba675SRob Herring 247*724ba675SRob Herring®_fldo2 { 248*724ba675SRob Herring /* 249*724ba675SRob Herring * Despite the embedded CPUs core not being used in any way, 250*724ba675SRob Herring * this must remain on or the system will hang. 251*724ba675SRob Herring */ 252*724ba675SRob Herring regulator-always-on; 253*724ba675SRob Herring regulator-min-microvolt = <700000>; 254*724ba675SRob Herring regulator-max-microvolt = <1100000>; 255*724ba675SRob Herring regulator-name = "vdd-cpus"; 256*724ba675SRob Herring}; 257*724ba675SRob Herring 258*724ba675SRob Herring®_rtc_ldo { 259*724ba675SRob Herring regulator-name = "vcc-rtc"; 260*724ba675SRob Herring}; 261*724ba675SRob Herring 262*724ba675SRob Herring®_sw { 263*724ba675SRob Herring regulator-name = "vcc-wifi"; 264*724ba675SRob Herring}; 265*724ba675SRob Herring 266*724ba675SRob Herring&uart0 { 267*724ba675SRob Herring pinctrl-names = "default"; 268*724ba675SRob Herring pinctrl-0 = <&uart0_pb_pins>; 269*724ba675SRob Herring status = "okay"; 270*724ba675SRob Herring}; 271*724ba675SRob Herring 272*724ba675SRob Herring&usbphy { 273*724ba675SRob Herring usb0_vbus-supply = <®_usb0_vbus>; 274*724ba675SRob Herring usb1_vbus-supply = <®_usb1_vbus>; 275*724ba675SRob Herring status = "okay"; 276*724ba675SRob Herring}; 277*724ba675SRob Herring 278*724ba675SRob Herring&usb_otg { 279*724ba675SRob Herring dr_mode = "host"; 280*724ba675SRob Herring status = "okay"; 281*724ba675SRob Herring}; 282