1*724ba675SRob Herring// SPDX-License-Identifier: GPL-2.0-only 2*724ba675SRob Herring/* 3*724ba675SRob Herring * Copyright (C) 2012 Texas Instruments Incorporated - https://www.ti.com/ 4*724ba675SRob Herring */ 5*724ba675SRob Herring/dts-v1/; 6*724ba675SRob Herring 7*724ba675SRob Herring#include "am33xx.dtsi" 8*724ba675SRob Herring#include "am335x-bone-common.dtsi" 9*724ba675SRob Herring#include "am335x-bonegreen-common.dtsi" 10*724ba675SRob Herring#include <dt-bindings/interrupt-controller/irq.h> 11*724ba675SRob Herring 12*724ba675SRob Herring/ { 13*724ba675SRob Herring model = "TI AM335x BeagleBone Green Wireless"; 14*724ba675SRob Herring compatible = "ti,am335x-bone-green-wireless", "ti,am335x-bone-green", "ti,am335x-bone-black", "ti,am335x-bone", "ti,am33xx"; 15*724ba675SRob Herring 16*724ba675SRob Herring wlan_en_reg: fixedregulator@2 { 17*724ba675SRob Herring compatible = "regulator-fixed"; 18*724ba675SRob Herring regulator-name = "wlan-en-regulator"; 19*724ba675SRob Herring regulator-min-microvolt = <1800000>; 20*724ba675SRob Herring regulator-max-microvolt = <1800000>; 21*724ba675SRob Herring startup-delay-us = <70000>; 22*724ba675SRob Herring 23*724ba675SRob Herring /* WL_EN */ 24*724ba675SRob Herring gpio = <&gpio0 26 0>; 25*724ba675SRob Herring enable-active-high; 26*724ba675SRob Herring }; 27*724ba675SRob Herring}; 28*724ba675SRob Herring 29*724ba675SRob Herring&am33xx_pinmux { 30*724ba675SRob Herring bt_pins: bt-pins { 31*724ba675SRob Herring pinctrl-single,pins = < 32*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_BEN1, PIN_OUTPUT_PULLUP, MUX_MODE7) /* gpmc_ad12.gpio1_28 BT_EN */ 33*724ba675SRob Herring >; 34*724ba675SRob Herring }; 35*724ba675SRob Herring 36*724ba675SRob Herring mmc3_pins: mmc3-pins { 37*724ba675SRob Herring pinctrl-single,pins = < 38*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_AD12, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad12.mmc2_dat0 */ 39*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_AD13, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad13.mmc2_dat1 */ 40*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_AD14, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad14.mmc2_dat2 */ 41*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_AD15, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad15.mmc2_dat3 */ 42*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_CSN3, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_csn3.mmc2_cmd */ 43*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_CLK, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_clk.mmc2_clk */ 44*724ba675SRob Herring >; 45*724ba675SRob Herring }; 46*724ba675SRob Herring 47*724ba675SRob Herring uart3_pins: uart3-pins { 48*724ba675SRob Herring pinctrl-single,pins = < 49*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_MII1_RXD3, PIN_INPUT_PULLUP, MUX_MODE1) /* gmii1_rxd3.uart3_rxd */ 50*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_MII1_RXD2, PIN_OUTPUT_PULLDOWN, MUX_MODE1) /* gmii1_rxd2.uart3_txd */ 51*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_MDIO, PIN_INPUT, MUX_MODE3) /* mdio_data.uart3_ctsn */ 52*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_MDC, PIN_OUTPUT_PULLDOWN, MUX_MODE3) /* mdio_clk.uart3_rtsn */ 53*724ba675SRob Herring >; 54*724ba675SRob Herring }; 55*724ba675SRob Herring 56*724ba675SRob Herring wl18xx_pins: wl18xx-pins { 57*724ba675SRob Herring pinctrl-single,pins = < 58*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_AD10, PIN_OUTPUT_PULLDOWN, MUX_MODE7) /* gpmc_ad10.gpio0_26 WL_EN */ 59*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_AD11, PIN_INPUT_PULLDOWN, MUX_MODE7) /* gpmc_ad11.gpio0_27 WL_IRQ */ 60*724ba675SRob Herring AM33XX_PADCONF(AM335X_PIN_GPMC_CSN0, PIN_OUTPUT_PULLUP, MUX_MODE7) /* gpmc_csn0.gpio1_29 LS_BUF_EN */ 61*724ba675SRob Herring >; 62*724ba675SRob Herring }; 63*724ba675SRob Herring}; 64*724ba675SRob Herring 65*724ba675SRob Herring&mac_sw { 66*724ba675SRob Herring status = "disabled"; 67*724ba675SRob Herring}; 68*724ba675SRob Herring 69*724ba675SRob Herring&mmc3 { 70*724ba675SRob Herring dmas = <&edma_xbar 12 0 1 71*724ba675SRob Herring &edma_xbar 13 0 2>; 72*724ba675SRob Herring dma-names = "tx", "rx"; 73*724ba675SRob Herring status = "okay"; 74*724ba675SRob Herring vmmc-supply = <&wlan_en_reg>; 75*724ba675SRob Herring bus-width = <4>; 76*724ba675SRob Herring non-removable; 77*724ba675SRob Herring cap-power-off-card; 78*724ba675SRob Herring keep-power-in-suspend; 79*724ba675SRob Herring pinctrl-names = "default"; 80*724ba675SRob Herring pinctrl-0 = <&mmc3_pins &wl18xx_pins>; 81*724ba675SRob Herring 82*724ba675SRob Herring #address-cells = <1>; 83*724ba675SRob Herring #size-cells = <0>; 84*724ba675SRob Herring wlcore: wlcore@2 { 85*724ba675SRob Herring compatible = "ti,wl1835"; 86*724ba675SRob Herring reg = <2>; 87*724ba675SRob Herring interrupt-parent = <&gpio0>; 88*724ba675SRob Herring interrupts = <27 IRQ_TYPE_EDGE_RISING>; 89*724ba675SRob Herring }; 90*724ba675SRob Herring}; 91*724ba675SRob Herring 92*724ba675SRob Herring&uart3 { 93*724ba675SRob Herring pinctrl-names = "default"; 94*724ba675SRob Herring pinctrl-0 = <&uart3_pins &bt_pins>; 95*724ba675SRob Herring status = "okay"; 96*724ba675SRob Herring 97*724ba675SRob Herring bluetooth { 98*724ba675SRob Herring compatible = "ti,wl1835-st"; 99*724ba675SRob Herring enable-gpios = <&gpio1 28 GPIO_ACTIVE_HIGH>; 100*724ba675SRob Herring }; 101*724ba675SRob Herring}; 102*724ba675SRob Herring 103*724ba675SRob Herring&gpio1 { 104*724ba675SRob Herring ls-buf-en-hog { 105*724ba675SRob Herring gpio-hog; 106*724ba675SRob Herring gpios = <29 GPIO_ACTIVE_HIGH>; 107*724ba675SRob Herring output-high; 108*724ba675SRob Herring line-name = "LS_BUF_EN"; 109*724ba675SRob Herring }; 110*724ba675SRob Herring}; 111*724ba675SRob Herring 112*724ba675SRob Herring/* BT_AUD_OUT from wl1835 has to be pulled low when WL_EN is activated.*/ 113*724ba675SRob Herring/* in case it isn't, wilink8 ends up in one of the test modes that */ 114*724ba675SRob Herring/* intruces various issues (elp wkaeup timeouts etc.) */ 115*724ba675SRob Herring/* On the BBGW this pin is routed through the level shifter (U21) that */ 116*724ba675SRob Herring/* introduces a pullup on the line and wilink8 ends up in a bad state. */ 117*724ba675SRob Herring/* use a gpio hog to force this pin low. An alternative may be adding */ 118*724ba675SRob Herring/* an external pulldown on U21 pin 4. */ 119*724ba675SRob Herring 120*724ba675SRob Herring&gpio3 { 121*724ba675SRob Herring bt-aud-in-hog { 122*724ba675SRob Herring gpio-hog; 123*724ba675SRob Herring gpios = <16 GPIO_ACTIVE_HIGH>; 124*724ba675SRob Herring output-low; 125*724ba675SRob Herring line-name = "MCASP0_AHCLKR"; 126*724ba675SRob Herring }; 127*724ba675SRob Herring}; 128