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