162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2012 Texas Instruments Incorporated - https://www.ti.com/ 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci/dts-v1/; 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci#include "am33xx.dtsi" 862306a36Sopenharmony_ci#include "am335x-bone-common.dtsi" 962306a36Sopenharmony_ci#include "am335x-bonegreen-common.dtsi" 1062306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/irq.h> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci/ { 1362306a36Sopenharmony_ci model = "TI AM335x BeagleBone Green Wireless"; 1462306a36Sopenharmony_ci compatible = "ti,am335x-bone-green-wireless", "ti,am335x-bone-green", "ti,am335x-bone-black", "ti,am335x-bone", "ti,am33xx"; 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci wlan_en_reg: fixedregulator@2 { 1762306a36Sopenharmony_ci compatible = "regulator-fixed"; 1862306a36Sopenharmony_ci regulator-name = "wlan-en-regulator"; 1962306a36Sopenharmony_ci regulator-min-microvolt = <1800000>; 2062306a36Sopenharmony_ci regulator-max-microvolt = <1800000>; 2162306a36Sopenharmony_ci startup-delay-us = <70000>; 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci /* WL_EN */ 2462306a36Sopenharmony_ci gpio = <&gpio0 26 0>; 2562306a36Sopenharmony_ci enable-active-high; 2662306a36Sopenharmony_ci }; 2762306a36Sopenharmony_ci}; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci&am33xx_pinmux { 3062306a36Sopenharmony_ci bt_pins: bt-pins { 3162306a36Sopenharmony_ci pinctrl-single,pins = < 3262306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_BEN1, PIN_OUTPUT_PULLUP, MUX_MODE7) /* gpmc_ad12.gpio1_28 BT_EN */ 3362306a36Sopenharmony_ci >; 3462306a36Sopenharmony_ci }; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci mmc3_pins: mmc3-pins { 3762306a36Sopenharmony_ci pinctrl-single,pins = < 3862306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_AD12, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad12.mmc2_dat0 */ 3962306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_AD13, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad13.mmc2_dat1 */ 4062306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_AD14, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad14.mmc2_dat2 */ 4162306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_AD15, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_ad15.mmc2_dat3 */ 4262306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_CSN3, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_csn3.mmc2_cmd */ 4362306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_CLK, PIN_INPUT_PULLUP, MUX_MODE3) /* gpmc_clk.mmc2_clk */ 4462306a36Sopenharmony_ci >; 4562306a36Sopenharmony_ci }; 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_ci uart3_pins: uart3-pins { 4862306a36Sopenharmony_ci pinctrl-single,pins = < 4962306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_MII1_RXD3, PIN_INPUT_PULLUP, MUX_MODE1) /* gmii1_rxd3.uart3_rxd */ 5062306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_MII1_RXD2, PIN_OUTPUT_PULLDOWN, MUX_MODE1) /* gmii1_rxd2.uart3_txd */ 5162306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_MDIO, PIN_INPUT, MUX_MODE3) /* mdio_data.uart3_ctsn */ 5262306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_MDC, PIN_OUTPUT_PULLDOWN, MUX_MODE3) /* mdio_clk.uart3_rtsn */ 5362306a36Sopenharmony_ci >; 5462306a36Sopenharmony_ci }; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci wl18xx_pins: wl18xx-pins { 5762306a36Sopenharmony_ci pinctrl-single,pins = < 5862306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_AD10, PIN_OUTPUT_PULLDOWN, MUX_MODE7) /* gpmc_ad10.gpio0_26 WL_EN */ 5962306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_AD11, PIN_INPUT_PULLDOWN, MUX_MODE7) /* gpmc_ad11.gpio0_27 WL_IRQ */ 6062306a36Sopenharmony_ci AM33XX_PADCONF(AM335X_PIN_GPMC_CSN0, PIN_OUTPUT_PULLUP, MUX_MODE7) /* gpmc_csn0.gpio1_29 LS_BUF_EN */ 6162306a36Sopenharmony_ci >; 6262306a36Sopenharmony_ci }; 6362306a36Sopenharmony_ci}; 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci&mac_sw { 6662306a36Sopenharmony_ci status = "disabled"; 6762306a36Sopenharmony_ci}; 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_ci&mmc3 { 7062306a36Sopenharmony_ci dmas = <&edma_xbar 12 0 1 7162306a36Sopenharmony_ci &edma_xbar 13 0 2>; 7262306a36Sopenharmony_ci dma-names = "tx", "rx"; 7362306a36Sopenharmony_ci status = "okay"; 7462306a36Sopenharmony_ci vmmc-supply = <&wlan_en_reg>; 7562306a36Sopenharmony_ci bus-width = <4>; 7662306a36Sopenharmony_ci non-removable; 7762306a36Sopenharmony_ci cap-power-off-card; 7862306a36Sopenharmony_ci keep-power-in-suspend; 7962306a36Sopenharmony_ci pinctrl-names = "default"; 8062306a36Sopenharmony_ci pinctrl-0 = <&mmc3_pins &wl18xx_pins>; 8162306a36Sopenharmony_ci 8262306a36Sopenharmony_ci #address-cells = <1>; 8362306a36Sopenharmony_ci #size-cells = <0>; 8462306a36Sopenharmony_ci wlcore: wlcore@2 { 8562306a36Sopenharmony_ci compatible = "ti,wl1835"; 8662306a36Sopenharmony_ci reg = <2>; 8762306a36Sopenharmony_ci interrupt-parent = <&gpio0>; 8862306a36Sopenharmony_ci interrupts = <27 IRQ_TYPE_EDGE_RISING>; 8962306a36Sopenharmony_ci }; 9062306a36Sopenharmony_ci}; 9162306a36Sopenharmony_ci 9262306a36Sopenharmony_ci&uart3 { 9362306a36Sopenharmony_ci pinctrl-names = "default"; 9462306a36Sopenharmony_ci pinctrl-0 = <&uart3_pins &bt_pins>; 9562306a36Sopenharmony_ci status = "okay"; 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci bluetooth { 9862306a36Sopenharmony_ci compatible = "ti,wl1835-st"; 9962306a36Sopenharmony_ci enable-gpios = <&gpio1 28 GPIO_ACTIVE_HIGH>; 10062306a36Sopenharmony_ci }; 10162306a36Sopenharmony_ci}; 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_ci&gpio1 { 10462306a36Sopenharmony_ci ls-buf-en-hog { 10562306a36Sopenharmony_ci gpio-hog; 10662306a36Sopenharmony_ci gpios = <29 GPIO_ACTIVE_HIGH>; 10762306a36Sopenharmony_ci output-high; 10862306a36Sopenharmony_ci line-name = "LS_BUF_EN"; 10962306a36Sopenharmony_ci }; 11062306a36Sopenharmony_ci}; 11162306a36Sopenharmony_ci 11262306a36Sopenharmony_ci/* BT_AUD_OUT from wl1835 has to be pulled low when WL_EN is activated.*/ 11362306a36Sopenharmony_ci/* in case it isn't, wilink8 ends up in one of the test modes that */ 11462306a36Sopenharmony_ci/* intruces various issues (elp wkaeup timeouts etc.) */ 11562306a36Sopenharmony_ci/* On the BBGW this pin is routed through the level shifter (U21) that */ 11662306a36Sopenharmony_ci/* introduces a pullup on the line and wilink8 ends up in a bad state. */ 11762306a36Sopenharmony_ci/* use a gpio hog to force this pin low. An alternative may be adding */ 11862306a36Sopenharmony_ci/* an external pulldown on U21 pin 4. */ 11962306a36Sopenharmony_ci 12062306a36Sopenharmony_ci&gpio3 { 12162306a36Sopenharmony_ci bt-aud-in-hog { 12262306a36Sopenharmony_ci gpio-hog; 12362306a36Sopenharmony_ci gpios = <16 GPIO_ACTIVE_HIGH>; 12462306a36Sopenharmony_ci output-low; 12562306a36Sopenharmony_ci line-name = "MCASP0_AHCLKR"; 12662306a36Sopenharmony_ci }; 12762306a36Sopenharmony_ci}; 128