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