1 // SPDX-License-Identifier: GPL-2.0
2 /******************************************************************************
3  *
4  * Copyright(c) 2013 Realtek Corporation. All rights reserved.
5  *
6  ******************************************************************************/
7 #include <drv_types.h>
8 #include <rtw_debug.h>
9 #include <rtw_btcoex.h>
10 #include <hal_btcoex.h>
11 
12 
rtw_btcoex_Initialize(struct adapter * padapter)13 void rtw_btcoex_Initialize(struct adapter *padapter)
14 {
15 	hal_btcoex_Initialize(padapter);
16 }
17 
rtw_btcoex_PowerOnSetting(struct adapter * padapter)18 void rtw_btcoex_PowerOnSetting(struct adapter *padapter)
19 {
20 	hal_btcoex_PowerOnSetting(padapter);
21 }
22 
rtw_btcoex_HAL_Initialize(struct adapter * padapter,u8 bWifiOnly)23 void rtw_btcoex_HAL_Initialize(struct adapter *padapter, u8 bWifiOnly)
24 {
25 	hal_btcoex_InitHwConfig(padapter, bWifiOnly);
26 }
27 
rtw_btcoex_IpsNotify(struct adapter * padapter,u8 type)28 void rtw_btcoex_IpsNotify(struct adapter *padapter, u8 type)
29 {
30 	hal_btcoex_IpsNotify(padapter, type);
31 }
32 
rtw_btcoex_LpsNotify(struct adapter * padapter,u8 type)33 void rtw_btcoex_LpsNotify(struct adapter *padapter, u8 type)
34 {
35 	hal_btcoex_LpsNotify(padapter, type);
36 }
37 
rtw_btcoex_ScanNotify(struct adapter * padapter,u8 type)38 void rtw_btcoex_ScanNotify(struct adapter *padapter, u8 type)
39 {
40 	hal_btcoex_ScanNotify(padapter, type);
41 }
42 
rtw_btcoex_ConnectNotify(struct adapter * padapter,u8 action)43 void rtw_btcoex_ConnectNotify(struct adapter *padapter, u8 action)
44 {
45 	hal_btcoex_ConnectNotify(padapter, action);
46 }
47 
rtw_btcoex_MediaStatusNotify(struct adapter * padapter,u8 mediaStatus)48 void rtw_btcoex_MediaStatusNotify(struct adapter *padapter, u8 mediaStatus)
49 {
50 	if ((mediaStatus == RT_MEDIA_CONNECT)
51 		&& (check_fwstate(&padapter->mlmepriv, WIFI_AP_STATE) == true)) {
52 		rtw_hal_set_hwreg(padapter, HW_VAR_DL_RSVD_PAGE, NULL);
53 	}
54 
55 	hal_btcoex_MediaStatusNotify(padapter, mediaStatus);
56 }
57 
rtw_btcoex_SpecialPacketNotify(struct adapter * padapter,u8 pktType)58 void rtw_btcoex_SpecialPacketNotify(struct adapter *padapter, u8 pktType)
59 {
60 	hal_btcoex_SpecialPacketNotify(padapter, pktType);
61 }
62 
rtw_btcoex_IQKNotify(struct adapter * padapter,u8 state)63 void rtw_btcoex_IQKNotify(struct adapter *padapter, u8 state)
64 {
65 	hal_btcoex_IQKNotify(padapter, state);
66 }
67 
rtw_btcoex_BtInfoNotify(struct adapter * padapter,u8 length,u8 * tmpBuf)68 void rtw_btcoex_BtInfoNotify(struct adapter *padapter, u8 length, u8 *tmpBuf)
69 {
70 	hal_btcoex_BtInfoNotify(padapter, length, tmpBuf);
71 }
72 
rtw_btcoex_SuspendNotify(struct adapter * padapter,u8 state)73 void rtw_btcoex_SuspendNotify(struct adapter *padapter, u8 state)
74 {
75 	hal_btcoex_SuspendNotify(padapter, state);
76 }
77 
rtw_btcoex_HaltNotify(struct adapter * padapter)78 void rtw_btcoex_HaltNotify(struct adapter *padapter)
79 {
80 	if (!padapter->bup) {
81 		DBG_871X(FUNC_ADPT_FMT ": bup =%d Skip!\n",
82 			FUNC_ADPT_ARG(padapter), padapter->bup);
83 
84 		return;
85 	}
86 
87 	if (padapter->bSurpriseRemoved) {
88 		DBG_871X(FUNC_ADPT_FMT ": bSurpriseRemoved =%d Skip!\n",
89 			FUNC_ADPT_ARG(padapter), padapter->bSurpriseRemoved);
90 
91 		return;
92 	}
93 
94 	hal_btcoex_HaltNotify(padapter);
95 }
96 
rtw_btcoex_IsBtDisabled(struct adapter * padapter)97 u8 rtw_btcoex_IsBtDisabled(struct adapter *padapter)
98 {
99 	return hal_btcoex_IsBtDisabled(padapter);
100 }
101 
rtw_btcoex_Handler(struct adapter * padapter)102 void rtw_btcoex_Handler(struct adapter *padapter)
103 {
104 	hal_btcoex_Hanlder(padapter);
105 }
106 
rtw_btcoex_IsBTCoexCtrlAMPDUSize(struct adapter * padapter)107 s32 rtw_btcoex_IsBTCoexCtrlAMPDUSize(struct adapter *padapter)
108 {
109 	s32 coexctrl;
110 
111 	coexctrl = hal_btcoex_IsBTCoexCtrlAMPDUSize(padapter);
112 
113 	return coexctrl;
114 }
115 
rtw_btcoex_SetManualControl(struct adapter * padapter,u8 manual)116 void rtw_btcoex_SetManualControl(struct adapter *padapter, u8 manual)
117 {
118 	hal_btcoex_SetManualControl(padapter, manual);
119 }
120 
rtw_btcoex_IsBtControlLps(struct adapter * padapter)121 u8 rtw_btcoex_IsBtControlLps(struct adapter *padapter)
122 {
123 	return hal_btcoex_IsBtControlLps(padapter);
124 }
125 
rtw_btcoex_IsLpsOn(struct adapter * padapter)126 u8 rtw_btcoex_IsLpsOn(struct adapter *padapter)
127 {
128 	return hal_btcoex_IsLpsOn(padapter);
129 }
130 
rtw_btcoex_RpwmVal(struct adapter * padapter)131 u8 rtw_btcoex_RpwmVal(struct adapter *padapter)
132 {
133 	return hal_btcoex_RpwmVal(padapter);
134 }
135 
rtw_btcoex_LpsVal(struct adapter * padapter)136 u8 rtw_btcoex_LpsVal(struct adapter *padapter)
137 {
138 	return hal_btcoex_LpsVal(padapter);
139 }
140 
rtw_btcoex_SetBTCoexist(struct adapter * padapter,u8 bBtExist)141 void rtw_btcoex_SetBTCoexist(struct adapter *padapter, u8 bBtExist)
142 {
143 	hal_btcoex_SetBTCoexist(padapter, bBtExist);
144 }
145 
rtw_btcoex_SetChipType(struct adapter * padapter,u8 chipType)146 void rtw_btcoex_SetChipType(struct adapter *padapter, u8 chipType)
147 {
148 	hal_btcoex_SetChipType(padapter, chipType);
149 }
150 
rtw_btcoex_SetPGAntNum(struct adapter * padapter,u8 antNum)151 void rtw_btcoex_SetPGAntNum(struct adapter *padapter, u8 antNum)
152 {
153 	hal_btcoex_SetPgAntNum(padapter, antNum);
154 }
155 
rtw_btcoex_SetSingleAntPath(struct adapter * padapter,u8 singleAntPath)156 void rtw_btcoex_SetSingleAntPath(struct adapter *padapter, u8 singleAntPath)
157 {
158 	hal_btcoex_SetSingleAntPath(padapter, singleAntPath);
159 }
160 
rtw_btcoex_GetRaMask(struct adapter * padapter)161 u32 rtw_btcoex_GetRaMask(struct adapter *padapter)
162 {
163 	return hal_btcoex_GetRaMask(padapter);
164 }
165 
rtw_btcoex_RecordPwrMode(struct adapter * padapter,u8 * pCmdBuf,u8 cmdLen)166 void rtw_btcoex_RecordPwrMode(struct adapter *padapter, u8 *pCmdBuf, u8 cmdLen)
167 {
168 	hal_btcoex_RecordPwrMode(padapter, pCmdBuf, cmdLen);
169 }
170 
rtw_btcoex_DisplayBtCoexInfo(struct adapter * padapter,u8 * pbuf,u32 bufsize)171 void rtw_btcoex_DisplayBtCoexInfo(struct adapter *padapter, u8 *pbuf, u32 bufsize)
172 {
173 	hal_btcoex_DisplayBtCoexInfo(padapter, pbuf, bufsize);
174 }
175 
rtw_btcoex_SetDBG(struct adapter * padapter,u32 * pDbgModule)176 void rtw_btcoex_SetDBG(struct adapter *padapter, u32 *pDbgModule)
177 {
178 	hal_btcoex_SetDBG(padapter, pDbgModule);
179 }
180 
rtw_btcoex_GetDBG(struct adapter * padapter,u8 * pStrBuf,u32 bufSize)181 u32 rtw_btcoex_GetDBG(struct adapter *padapter, u8 *pStrBuf, u32 bufSize)
182 {
183 	return hal_btcoex_GetDBG(padapter, pStrBuf, bufSize);
184 }
185 
186 /*  ================================================== */
187 /*  Below Functions are called by BT-Coex */
188 /*  ================================================== */
rtw_btcoex_RejectApAggregatedPacket(struct adapter * padapter,u8 enable)189 void rtw_btcoex_RejectApAggregatedPacket(struct adapter *padapter, u8 enable)
190 {
191 	struct mlme_ext_info *pmlmeinfo;
192 	struct sta_info *psta;
193 
194 	pmlmeinfo = &padapter->mlmeextpriv.mlmext_info;
195 	psta = rtw_get_stainfo(&padapter->stapriv, get_bssid(&padapter->mlmepriv));
196 
197 	if (enable) {
198 		pmlmeinfo->accept_addba_req = false;
199 		if (psta)
200 			send_delba(padapter, 0, psta->hwaddr);
201 	} else {
202 		pmlmeinfo->accept_addba_req = true;
203 	}
204 }
205 
rtw_btcoex_LPS_Enter(struct adapter * padapter)206 void rtw_btcoex_LPS_Enter(struct adapter *padapter)
207 {
208 	struct pwrctrl_priv *pwrpriv;
209 	u8 lpsVal;
210 
211 
212 	pwrpriv = adapter_to_pwrctl(padapter);
213 
214 	pwrpriv->bpower_saving = true;
215 	lpsVal = rtw_btcoex_LpsVal(padapter);
216 	rtw_set_ps_mode(padapter, PS_MODE_MIN, 0, lpsVal, "BTCOEX");
217 }
218 
rtw_btcoex_LPS_Leave(struct adapter * padapter)219 void rtw_btcoex_LPS_Leave(struct adapter *padapter)
220 {
221 	struct pwrctrl_priv *pwrpriv;
222 
223 
224 	pwrpriv = adapter_to_pwrctl(padapter);
225 
226 	if (pwrpriv->pwr_mode != PS_MODE_ACTIVE) {
227 		rtw_set_ps_mode(padapter, PS_MODE_ACTIVE, 0, 0, "BTCOEX");
228 		LPS_RF_ON_check(padapter, 100);
229 		pwrpriv->bpower_saving = false;
230 	}
231 }
232