xref: /OK3568_Linux_fs/kernel/arch/arm/boot/dts/am335x-bonegreen-wireless.dts (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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