1cc733bc9SAndreas Färber/* 2cc733bc9SAndreas Färber * Copyright (c) 2016 Andreas Färber 3cc733bc9SAndreas Färber * 4cc733bc9SAndreas Färber * This file is dual-licensed: you can use it either under the terms 5cc733bc9SAndreas Färber * of the GPL or the X11 license, at your option. Note that this dual 6cc733bc9SAndreas Färber * licensing only applies to this file, and not this project as a 7cc733bc9SAndreas Färber * whole. 8cc733bc9SAndreas Färber * 9cc733bc9SAndreas Färber * a) This library is free software; you can redistribute it and/or 10cc733bc9SAndreas Färber * modify it under the terms of the GNU General Public License as 11cc733bc9SAndreas Färber * published by the Free Software Foundation; either version 2 of the 12cc733bc9SAndreas Färber * License, or (at your option) any later version. 13cc733bc9SAndreas Färber * 14cc733bc9SAndreas Färber * This library is distributed in the hope that it will be useful, 15cc733bc9SAndreas Färber * but WITHOUT ANY WARRANTY; without even the implied warranty of 16cc733bc9SAndreas Färber * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 17cc733bc9SAndreas Färber * GNU General Public License for more details. 18cc733bc9SAndreas Färber * 19cc733bc9SAndreas Färber * Or, alternatively, 20cc733bc9SAndreas Färber * 21cc733bc9SAndreas Färber * b) Permission is hereby granted, free of charge, to any person 22cc733bc9SAndreas Färber * obtaining a copy of this software and associated documentation 23cc733bc9SAndreas Färber * files (the "Software"), to deal in the Software without 24cc733bc9SAndreas Färber * restriction, including without limitation the rights to use, 25cc733bc9SAndreas Färber * copy, modify, merge, publish, distribute, sublicense, and/or 26cc733bc9SAndreas Färber * sell copies of the Software, and to permit persons to whom the 27cc733bc9SAndreas Färber * Software is furnished to do so, subject to the following 28cc733bc9SAndreas Färber * conditions: 29cc733bc9SAndreas Färber * 30cc733bc9SAndreas Färber * The above copyright notice and this permission notice shall be 31cc733bc9SAndreas Färber * included in all copies or substantial portions of the Software. 32cc733bc9SAndreas Färber * 33cc733bc9SAndreas Färber * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 34cc733bc9SAndreas Färber * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 35cc733bc9SAndreas Färber * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 36cc733bc9SAndreas Färber * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 37cc733bc9SAndreas Färber * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 38cc733bc9SAndreas Färber * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 39cc733bc9SAndreas Färber * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 40cc733bc9SAndreas Färber * OTHER DEALINGS IN THE SOFTWARE. 41cc733bc9SAndreas Färber */ 42cc733bc9SAndreas Färber 43cc733bc9SAndreas Färber#include "meson-gxbb.dtsi" 44cc733bc9SAndreas Färber 45cc733bc9SAndreas Färber/ { 46cc733bc9SAndreas Färber compatible = "tronsmart,vega-s95", "amlogic,meson-gxbb"; 47cc733bc9SAndreas Färber 48962f271eSKevin Hilman aliases { 49962f271eSKevin Hilman serial0 = &uart_AO; 50059a58fcSJorge Ramirez-Ortiz ethernet0 = ðmac; 51962f271eSKevin Hilman }; 52962f271eSKevin Hilman 53cc733bc9SAndreas Färber chosen { 54cc733bc9SAndreas Färber stdout-path = "serial0:115200n8"; 55cc733bc9SAndreas Färber }; 56c763eb82SMartin Blumenstingl 572fbbc4bfSAndreas Färber leds { 582fbbc4bfSAndreas Färber compatible = "gpio-leds"; 592fbbc4bfSAndreas Färber 602fbbc4bfSAndreas Färber blue { 612fbbc4bfSAndreas Färber label = "vega-s95:blue:on"; 622fbbc4bfSAndreas Färber gpios = <&gpio_ao GPIOAO_13 GPIO_ACTIVE_HIGH>; 632fbbc4bfSAndreas Färber default-state = "on"; 642fbbc4bfSAndreas Färber panic-indicator; 652fbbc4bfSAndreas Färber }; 662fbbc4bfSAndreas Färber }; 672fbbc4bfSAndreas Färber 68c763eb82SMartin Blumenstingl usb_vbus: regulator-usb0-vbus { 69c763eb82SMartin Blumenstingl compatible = "regulator-fixed"; 70c763eb82SMartin Blumenstingl 71c763eb82SMartin Blumenstingl regulator-name = "USB0_VBUS"; 72c763eb82SMartin Blumenstingl 73c763eb82SMartin Blumenstingl regulator-min-microvolt = <5000000>; 74c763eb82SMartin Blumenstingl regulator-max-microvolt = <5000000>; 75c763eb82SMartin Blumenstingl 76c763eb82SMartin Blumenstingl gpio = <&gpio GPIODV_24 GPIO_ACTIVE_HIGH>; 77c763eb82SMartin Blumenstingl enable-active-high; 78c763eb82SMartin Blumenstingl }; 79c763eb82SMartin Blumenstingl 80ab5b24fdSMartin Blumenstingl vcc_3v3: regulator-vcc_3v3 { 81ab5b24fdSMartin Blumenstingl compatible = "regulator-fixed"; 82ab5b24fdSMartin Blumenstingl regulator-name = "VCC_3V3"; 83ab5b24fdSMartin Blumenstingl regulator-min-microvolt = <3300000>; 84ab5b24fdSMartin Blumenstingl regulator-max-microvolt = <3300000>; 85ab5b24fdSMartin Blumenstingl }; 86ab5b24fdSMartin Blumenstingl 87ab5b24fdSMartin Blumenstingl vcc_1v8: regulator-vcc_1v8 { 88ab5b24fdSMartin Blumenstingl compatible = "regulator-fixed"; 89ab5b24fdSMartin Blumenstingl regulator-name = "VCC_1V8"; 90ab5b24fdSMartin Blumenstingl regulator-min-microvolt = <1800000>; 91ab5b24fdSMartin Blumenstingl regulator-max-microvolt = <1800000>; 92ab5b24fdSMartin Blumenstingl }; 93ab5b24fdSMartin Blumenstingl 94ab5b24fdSMartin Blumenstingl emmc_pwrseq: emmc-pwrseq { 95ab5b24fdSMartin Blumenstingl compatible = "mmc-pwrseq-emmc"; 96ab5b24fdSMartin Blumenstingl reset-gpios = <&gpio BOOT_9 GPIO_ACTIVE_LOW>; 97ab5b24fdSMartin Blumenstingl }; 98ab5b24fdSMartin Blumenstingl 99ab5b24fdSMartin Blumenstingl wifi32k: wifi32k { 100ab5b24fdSMartin Blumenstingl compatible = "pwm-clock"; 101ab5b24fdSMartin Blumenstingl #clock-cells = <0>; 102ab5b24fdSMartin Blumenstingl clock-frequency = <32768>; 103ab5b24fdSMartin Blumenstingl pwms = <&pwm_ef 0 30518 0>; /* PWM_E at 32.768KHz */ 104ab5b24fdSMartin Blumenstingl }; 105ab5b24fdSMartin Blumenstingl 106ab5b24fdSMartin Blumenstingl sdio_pwrseq: sdio-pwrseq { 107ab5b24fdSMartin Blumenstingl compatible = "mmc-pwrseq-simple"; 108ab5b24fdSMartin Blumenstingl reset-gpios = <&gpio GPIOX_6 GPIO_ACTIVE_LOW>, 109ab5b24fdSMartin Blumenstingl <&gpio GPIOX_20 GPIO_ACTIVE_LOW>; 110ab5b24fdSMartin Blumenstingl clocks = <&wifi32k>; 111ab5b24fdSMartin Blumenstingl clock-names = "ext_clock"; 112ab5b24fdSMartin Blumenstingl }; 113cc733bc9SAndreas Färber}; 114cc733bc9SAndreas Färber 115f59063aeSMartin Blumenstinglðmac { 116f59063aeSMartin Blumenstingl status = "okay"; 1173be2d9cfSNeil Armstrong pinctrl-0 = <ð_rgmii_pins>; 118f59063aeSMartin Blumenstingl pinctrl-names = "default"; 1191220b297SMartin Blumenstingl 1201220b297SMartin Blumenstingl phy-handle = <ð_phy0>; 1211220b297SMartin Blumenstingl phy-mode = "rgmii"; 1221220b297SMartin Blumenstingl 123093d23dbSMartin Blumenstingl amlogic,tx-delay-ns = <2>; 124093d23dbSMartin Blumenstingl 1251220b297SMartin Blumenstingl snps,reset-gpio = <&gpio GPIOZ_14 0>; 1261220b297SMartin Blumenstingl snps,reset-delays-us = <0 10000 1000000>; 1271220b297SMartin Blumenstingl snps,reset-active-low; 1281220b297SMartin Blumenstingl 1291220b297SMartin Blumenstingl mdio { 1301220b297SMartin Blumenstingl compatible = "snps,dwmac-mdio"; 1311220b297SMartin Blumenstingl #address-cells = <1>; 1321220b297SMartin Blumenstingl #size-cells = <0>; 1331220b297SMartin Blumenstingl 1341220b297SMartin Blumenstingl eth_phy0: ethernet-phy@0 { 1351220b297SMartin Blumenstingl /* Realtek RTL8211F (0x001cc916) */ 1361220b297SMartin Blumenstingl reg = <0>; 1371220b297SMartin Blumenstingl }; 1381220b297SMartin Blumenstingl }; 139f59063aeSMartin Blumenstingl}; 140c763eb82SMartin Blumenstingl 141d6f93b02SAndreas Färber&ir { 142c763eb82SMartin Blumenstingl status = "okay"; 143d6f93b02SAndreas Färber pinctrl-0 = <&remote_input_ao_pins>; 144d6f93b02SAndreas Färber pinctrl-names = "default"; 145c763eb82SMartin Blumenstingl}; 146c763eb82SMartin Blumenstingl 147d6f93b02SAndreas Färber&pwm_ef { 148c763eb82SMartin Blumenstingl status = "okay"; 149d6f93b02SAndreas Färber pinctrl-0 = <&pwm_e_pins>; 150d6f93b02SAndreas Färber pinctrl-names = "default"; 151d6f93b02SAndreas Färber clocks = <&clkc CLKID_FCLK_DIV4>; 152d6f93b02SAndreas Färber clock-names = "clkin0"; 153c763eb82SMartin Blumenstingl}; 154ab5b24fdSMartin Blumenstingl 155ab5b24fdSMartin Blumenstingl/* Wireless SDIO Module */ 156ab5b24fdSMartin Blumenstingl&sd_emmc_a { 157ab5b24fdSMartin Blumenstingl status = "okay"; 158ab5b24fdSMartin Blumenstingl pinctrl-0 = <&sdio_pins &sdio_irq_pins>; 15967e7607fSJerome Brunet pinctrl-1 = <&sdio_clk_gate_pins>; 16067e7607fSJerome Brunet pinctrl-names = "default", "clk-gate"; 161ab5b24fdSMartin Blumenstingl #address-cells = <1>; 162ab5b24fdSMartin Blumenstingl #size-cells = <0>; 163ab5b24fdSMartin Blumenstingl 164ab5b24fdSMartin Blumenstingl bus-width = <4>; 165ab5b24fdSMartin Blumenstingl cap-sd-highspeed; 166ab5b24fdSMartin Blumenstingl max-frequency = <100000000>; 167ab5b24fdSMartin Blumenstingl 168ab5b24fdSMartin Blumenstingl non-removable; 169ab5b24fdSMartin Blumenstingl disable-wp; 170ab5b24fdSMartin Blumenstingl 171ab5b24fdSMartin Blumenstingl mmc-pwrseq = <&sdio_pwrseq>; 172ab5b24fdSMartin Blumenstingl 173ab5b24fdSMartin Blumenstingl vmmc-supply = <&vcc_3v3>; 174ab5b24fdSMartin Blumenstingl vqmmc-supply = <&vcc_1v8>; 175ab5b24fdSMartin Blumenstingl 17619e16750SAndreas Färber brcmf: wifi@1 { 177ab5b24fdSMartin Blumenstingl reg = <1>; 178ab5b24fdSMartin Blumenstingl compatible = "brcm,bcm4329-fmac"; 179ab5b24fdSMartin Blumenstingl }; 180ab5b24fdSMartin Blumenstingl}; 181ab5b24fdSMartin Blumenstingl 182ab5b24fdSMartin Blumenstingl/* SD card */ 183ab5b24fdSMartin Blumenstingl&sd_emmc_b { 184ab5b24fdSMartin Blumenstingl status = "okay"; 185ab5b24fdSMartin Blumenstingl pinctrl-0 = <&sdcard_pins>; 18667e7607fSJerome Brunet pinctrl-1 = <&sdcard_clk_gate_pins>; 18767e7607fSJerome Brunet pinctrl-names = "default", "clk-gate"; 188ab5b24fdSMartin Blumenstingl 189ab5b24fdSMartin Blumenstingl bus-width = <4>; 190ab5b24fdSMartin Blumenstingl cap-sd-highspeed; 191ab5b24fdSMartin Blumenstingl max-frequency = <100000000>; 192ab5b24fdSMartin Blumenstingl disable-wp; 193ab5b24fdSMartin Blumenstingl 194ab5b24fdSMartin Blumenstingl cd-gpios = <&gpio CARD_6 GPIO_ACTIVE_HIGH>; 195ab5b24fdSMartin Blumenstingl cd-inverted; 196ab5b24fdSMartin Blumenstingl 197ab5b24fdSMartin Blumenstingl vmmc-supply = <&vcc_3v3>; 198ab5b24fdSMartin Blumenstingl}; 199ab5b24fdSMartin Blumenstingl 200ab5b24fdSMartin Blumenstingl/* eMMC */ 201ab5b24fdSMartin Blumenstingl&sd_emmc_c { 202ab5b24fdSMartin Blumenstingl status = "okay"; 203ab36be66SNeil Armstrong pinctrl-0 = <&emmc_pins>, <&emmc_ds_pins>; 20467e7607fSJerome Brunet pinctrl-1 = <&emmc_clk_gate_pins>; 20567e7607fSJerome Brunet pinctrl-names = "default", "clk-gate"; 206ab5b24fdSMartin Blumenstingl 207ab5b24fdSMartin Blumenstingl bus-width = <8>; 208ab5b24fdSMartin Blumenstingl cap-mmc-highspeed; 209ab5b24fdSMartin Blumenstingl max-frequency = <200000000>; 210ab5b24fdSMartin Blumenstingl non-removable; 211ab5b24fdSMartin Blumenstingl disable-wp; 212ab5b24fdSMartin Blumenstingl mmc-ddr-1_8v; 213ab5b24fdSMartin Blumenstingl mmc-hs200-1_8v; 214ab5b24fdSMartin Blumenstingl 215ab5b24fdSMartin Blumenstingl mmc-pwrseq = <&emmc_pwrseq>; 216ab5b24fdSMartin Blumenstingl vmmc-supply = <&vcc_3v3>; 217ab5b24fdSMartin Blumenstingl vmmcq-sumpply = <&vcc_1v8>; 218ab5b24fdSMartin Blumenstingl}; 219ab5b24fdSMartin Blumenstingl 220d6f93b02SAndreas Färber&uart_AO { 221ab5b24fdSMartin Blumenstingl status = "okay"; 222d6f93b02SAndreas Färber pinctrl-0 = <&uart_ao_a_pins>; 223ab5b24fdSMartin Blumenstingl pinctrl-names = "default"; 224d6f93b02SAndreas Färber}; 225d6f93b02SAndreas Färber 226d6f93b02SAndreas Färber&usb0_phy { 227d6f93b02SAndreas Färber status = "okay"; 228d6f93b02SAndreas Färber phy-supply = <&usb_vbus>; 229d6f93b02SAndreas Färber}; 230d6f93b02SAndreas Färber 231d6f93b02SAndreas Färber&usb1_phy { 232d6f93b02SAndreas Färber status = "okay"; 233d6f93b02SAndreas Färber}; 234d6f93b02SAndreas Färber 235d6f93b02SAndreas Färber&usb0 { 236d6f93b02SAndreas Färber status = "okay"; 237d6f93b02SAndreas Färber}; 238d6f93b02SAndreas Färber 239d6f93b02SAndreas Färber&usb1 { 240d6f93b02SAndreas Färber status = "okay"; 241ab5b24fdSMartin Blumenstingl}; 242