1 /******************************************************************************
3 * Copyright(c) 2012 Realtek Corporation.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 * The full GNU General Public License is included in this distribution in the
15 * file called LICENSE.
17 * Contact Information:
18 * wlanfae <wlanfae@realtek.com>
19 * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
20 * Hsinchu 300, Taiwan.
22 * Larry Finger <Larry.Finger@lwfinger.net>
24 *****************************************************************************/
26 /***************************************************************
29 * This file is for RTL8723B Co-exist mechanism
32 * 2012/11/15 Cosa first check in.
34 ***************************************************************/
36 /***************************************************************
38 ***************************************************************/
39 #include "halbt_precomp.h"
40 /***************************************************************
41 * Global variables, these are static variables
42 ***************************************************************/
43 static struct coex_dm_8723b_1ant glcoex_dm_8723b_1ant
;
44 static struct coex_dm_8723b_1ant
*coex_dm
= &glcoex_dm_8723b_1ant
;
45 static struct coex_sta_8723b_1ant glcoex_sta_8723b_1ant
;
46 static struct coex_sta_8723b_1ant
*coex_sta
= &glcoex_sta_8723b_1ant
;
48 static const char *const GLBtInfoSrc8723b1Ant
[] = {
51 "BT Info[bt auto report]",
54 static u32 glcoex_ver_date_8723b_1ant
= 20130918;
55 static u32 glcoex_ver_8723b_1ant
= 0x47;
57 /***************************************************************
58 * local function proto type if needed
59 ***************************************************************/
60 /***************************************************************
61 * local function start with halbtc8723b1ant_
62 ***************************************************************/
63 static u8
halbtc8723b1ant_bt_rssi_state(u8 level_num
, u8 rssi_thresh
,
67 u8 bt_rssi_state
= coex_sta
->pre_bt_rssi_state
;
69 bt_rssi
= coex_sta
->bt_rssi
;
72 if ((coex_sta
->pre_bt_rssi_state
== BTC_RSSI_STATE_LOW
) ||
73 (coex_sta
->pre_bt_rssi_state
== BTC_RSSI_STATE_STAY_LOW
)) {
74 if (bt_rssi
>= rssi_thresh
+
75 BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT
) {
76 bt_rssi_state
= BTC_RSSI_STATE_HIGH
;
77 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
78 "[BTCoex], BT Rssi state switch to High\n");
80 bt_rssi_state
= BTC_RSSI_STATE_STAY_LOW
;
81 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
82 "[BTCoex], BT Rssi state stay at Low\n");
85 if (bt_rssi
< rssi_thresh
) {
86 bt_rssi_state
= BTC_RSSI_STATE_LOW
;
87 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
88 "[BTCoex], BT Rssi state switch to Low\n");
90 bt_rssi_state
= BTC_RSSI_STATE_STAY_HIGH
;
91 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
92 "[BTCoex], BT Rssi state stay at High\n");
95 } else if (level_num
== 3) {
96 if (rssi_thresh
> rssi_thresh1
) {
97 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
98 "[BTCoex], BT Rssi thresh error!!\n");
99 return coex_sta
->pre_bt_rssi_state
;
102 if ((coex_sta
->pre_bt_rssi_state
== BTC_RSSI_STATE_LOW
) ||
103 (coex_sta
->pre_bt_rssi_state
== BTC_RSSI_STATE_STAY_LOW
)) {
104 if (bt_rssi
>= rssi_thresh
+
105 BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT
) {
106 bt_rssi_state
= BTC_RSSI_STATE_MEDIUM
;
107 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
108 "[BTCoex], BT Rssi state switch to Medium\n");
110 bt_rssi_state
= BTC_RSSI_STATE_STAY_LOW
;
111 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
112 "[BTCoex], BT Rssi state stay at Low\n");
114 } else if ((coex_sta
->pre_bt_rssi_state
==
115 BTC_RSSI_STATE_MEDIUM
) ||
116 (coex_sta
->pre_bt_rssi_state
==
117 BTC_RSSI_STATE_STAY_MEDIUM
)) {
118 if (bt_rssi
>= rssi_thresh1
+
119 BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT
) {
120 bt_rssi_state
= BTC_RSSI_STATE_HIGH
;
121 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
122 "[BTCoex], BT Rssi state switch to High\n");
123 } else if (bt_rssi
< rssi_thresh
) {
124 bt_rssi_state
= BTC_RSSI_STATE_LOW
;
125 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
126 "[BTCoex], BT Rssi state switch to Low\n");
128 bt_rssi_state
= BTC_RSSI_STATE_STAY_MEDIUM
;
129 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
130 "[BTCoex], BT Rssi state stay at Medium\n");
133 if (bt_rssi
< rssi_thresh1
) {
134 bt_rssi_state
= BTC_RSSI_STATE_MEDIUM
;
135 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
136 "[BTCoex], BT Rssi state switch to Medium\n");
138 bt_rssi_state
= BTC_RSSI_STATE_STAY_HIGH
;
139 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_RSSI_STATE
,
140 "[BTCoex], BT Rssi state stay at High\n");
145 coex_sta
->pre_bt_rssi_state
= bt_rssi_state
;
147 return bt_rssi_state
;
150 static u8
halbtc8723b1ant_wifi_rssi_state(struct btc_coexist
*btcoexist
,
151 u8 index
, u8 level_num
,
152 u8 rssi_thresh
, u8 rssi_thresh1
)
155 u8 wifi_rssi_state
= coex_sta
->pre_wifi_rssi_state
[index
];
157 btcoexist
->btc_get(btcoexist
,
158 BTC_GET_S4_WIFI_RSSI
, &wifi_rssi
);
160 if (level_num
== 2) {
161 if ((coex_sta
->pre_wifi_rssi_state
[index
] ==
162 BTC_RSSI_STATE_LOW
) ||
163 (coex_sta
->pre_wifi_rssi_state
[index
] ==
164 BTC_RSSI_STATE_STAY_LOW
)) {
165 if (wifi_rssi
>= rssi_thresh
+
166 BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT
) {
167 wifi_rssi_state
= BTC_RSSI_STATE_HIGH
;
168 BTC_PRINT(BTC_MSG_ALGORITHM
,
169 ALGO_WIFI_RSSI_STATE
,
170 "[BTCoex], wifi RSSI state switch to High\n");
172 wifi_rssi_state
= BTC_RSSI_STATE_STAY_LOW
;
173 BTC_PRINT(BTC_MSG_ALGORITHM
,
174 ALGO_WIFI_RSSI_STATE
,
175 "[BTCoex], wifi RSSI state stay at Low\n");
178 if (wifi_rssi
< rssi_thresh
) {
179 wifi_rssi_state
= BTC_RSSI_STATE_LOW
;
180 BTC_PRINT(BTC_MSG_ALGORITHM
,
181 ALGO_WIFI_RSSI_STATE
,
182 "[BTCoex], wifi RSSI state switch to Low\n");
184 wifi_rssi_state
= BTC_RSSI_STATE_STAY_HIGH
;
185 BTC_PRINT(BTC_MSG_ALGORITHM
,
186 ALGO_WIFI_RSSI_STATE
,
187 "[BTCoex], wifi RSSI state stay at High\n");
190 } else if (level_num
== 3) {
191 if (rssi_thresh
> rssi_thresh1
) {
192 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_WIFI_RSSI_STATE
,
193 "[BTCoex], wifi RSSI thresh error!!\n");
194 return coex_sta
->pre_wifi_rssi_state
[index
];
197 if ((coex_sta
->pre_wifi_rssi_state
[index
] ==
198 BTC_RSSI_STATE_LOW
) ||
199 (coex_sta
->pre_wifi_rssi_state
[index
] ==
200 BTC_RSSI_STATE_STAY_LOW
)) {
201 if (wifi_rssi
>= rssi_thresh
+
202 BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT
) {
203 wifi_rssi_state
= BTC_RSSI_STATE_MEDIUM
;
204 BTC_PRINT(BTC_MSG_ALGORITHM
,
205 ALGO_WIFI_RSSI_STATE
,
206 "[BTCoex], wifi RSSI state switch to Medium\n");
208 wifi_rssi_state
= BTC_RSSI_STATE_STAY_LOW
;
209 BTC_PRINT(BTC_MSG_ALGORITHM
,
210 ALGO_WIFI_RSSI_STATE
,
211 "[BTCoex], wifi RSSI state stay at Low\n");
213 } else if ((coex_sta
->pre_wifi_rssi_state
[index
] ==
214 BTC_RSSI_STATE_MEDIUM
) ||
215 (coex_sta
->pre_wifi_rssi_state
[index
] ==
216 BTC_RSSI_STATE_STAY_MEDIUM
)) {
217 if (wifi_rssi
>= rssi_thresh1
+
218 BTC_RSSI_COEX_THRESH_TOL_8723B_1ANT
) {
219 wifi_rssi_state
= BTC_RSSI_STATE_HIGH
;
220 BTC_PRINT(BTC_MSG_ALGORITHM
,
221 ALGO_WIFI_RSSI_STATE
,
222 "[BTCoex], wifi RSSI state switch to High\n");
223 } else if (wifi_rssi
< rssi_thresh
) {
224 wifi_rssi_state
= BTC_RSSI_STATE_LOW
;
225 BTC_PRINT(BTC_MSG_ALGORITHM
,
226 ALGO_WIFI_RSSI_STATE
,
227 "[BTCoex], wifi RSSI state switch to Low\n");
229 wifi_rssi_state
= BTC_RSSI_STATE_STAY_MEDIUM
;
230 BTC_PRINT(BTC_MSG_ALGORITHM
,
231 ALGO_WIFI_RSSI_STATE
,
232 "[BTCoex], wifi RSSI state stay at Medium\n");
235 if (wifi_rssi
< rssi_thresh1
) {
236 wifi_rssi_state
= BTC_RSSI_STATE_MEDIUM
;
237 BTC_PRINT(BTC_MSG_ALGORITHM
,
238 ALGO_WIFI_RSSI_STATE
,
239 "[BTCoex], wifi RSSI state switch to Medium\n");
241 wifi_rssi_state
= BTC_RSSI_STATE_STAY_HIGH
;
242 BTC_PRINT(BTC_MSG_ALGORITHM
,
243 ALGO_WIFI_RSSI_STATE
,
244 "[BTCoex], wifi RSSI state stay at High\n");
249 coex_sta
->pre_wifi_rssi_state
[index
] = wifi_rssi_state
;
251 return wifi_rssi_state
;
254 static void halbtc8723b1ant_updatera_mask(struct btc_coexist
*btcoexist
,
255 bool force_exec
, u32 dis_rate_mask
)
257 coex_dm
->curra_mask
= dis_rate_mask
;
259 if (force_exec
|| (coex_dm
->prera_mask
!= coex_dm
->curra_mask
))
260 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_UPDATE_ra_mask
,
261 &coex_dm
->curra_mask
);
263 coex_dm
->prera_mask
= coex_dm
->curra_mask
;
266 static void btc8723b1ant_auto_rate_fb_retry(struct btc_coexist
*btcoexist
,
267 bool force_exec
, u8 type
)
269 bool wifi_under_bmode
= false;
271 coex_dm
->cur_arfr_type
= type
;
273 if (force_exec
|| (coex_dm
->pre_arfr_type
!= coex_dm
->cur_arfr_type
)) {
274 switch (coex_dm
->cur_arfr_type
) {
275 case 0: /* normal mode */
276 btcoexist
->btc_write_4byte(btcoexist
, 0x430,
277 coex_dm
->backup_arfr_cnt1
);
278 btcoexist
->btc_write_4byte(btcoexist
, 0x434,
279 coex_dm
->backup_arfr_cnt2
);
282 btcoexist
->btc_get(btcoexist
,
283 BTC_GET_BL_WIFI_UNDER_B_MODE
,
285 if (wifi_under_bmode
) {
286 btcoexist
->btc_write_4byte(btcoexist
,
288 btcoexist
->btc_write_4byte(btcoexist
,
291 btcoexist
->btc_write_4byte(btcoexist
,
293 btcoexist
->btc_write_4byte(btcoexist
,
302 coex_dm
->pre_arfr_type
= coex_dm
->cur_arfr_type
;
305 static void halbtc8723b1ant_retry_limit(struct btc_coexist
*btcoexist
,
306 bool force_exec
, u8 type
)
308 coex_dm
->cur_retry_limit_type
= type
;
310 if (force_exec
|| (coex_dm
->pre_retry_limit_type
!=
311 coex_dm
->cur_retry_limit_type
)) {
312 switch (coex_dm
->cur_retry_limit_type
) {
313 case 0: /* normal mode */
314 btcoexist
->btc_write_2byte(btcoexist
, 0x42a,
315 coex_dm
->backup_retry_limit
);
317 case 1: /* retry limit = 8 */
318 btcoexist
->btc_write_2byte(btcoexist
, 0x42a, 0x0808);
325 coex_dm
->pre_retry_limit_type
= coex_dm
->cur_retry_limit_type
;
328 static void halbtc8723b1ant_ampdu_maxtime(struct btc_coexist
*btcoexist
,
329 bool force_exec
, u8 type
)
331 coex_dm
->cur_ampdu_time_type
= type
;
333 if (force_exec
|| (coex_dm
->pre_ampdu_time_type
!=
334 coex_dm
->cur_ampdu_time_type
)) {
335 switch (coex_dm
->cur_ampdu_time_type
) {
336 case 0: /* normal mode */
337 btcoexist
->btc_write_1byte(btcoexist
, 0x456,
338 coex_dm
->backup_ampdu_max_time
);
340 case 1: /* AMPDU timw = 0x38 * 32us */
341 btcoexist
->btc_write_1byte(btcoexist
,
349 coex_dm
->pre_ampdu_time_type
= coex_dm
->cur_ampdu_time_type
;
352 static void halbtc8723b1ant_limited_tx(struct btc_coexist
*btcoexist
,
353 bool force_exec
, u8 ra_masktype
,
354 u8 arfr_type
, u8 retry_limit_type
,
357 switch (ra_masktype
) {
358 case 0: /* normal mode */
359 halbtc8723b1ant_updatera_mask(btcoexist
, force_exec
, 0x0);
361 case 1: /* disable cck 1/2 */
362 halbtc8723b1ant_updatera_mask(btcoexist
, force_exec
,
365 /* disable cck 1/2/5.5, ofdm 6/9/12/18/24, mcs 0/1/2/3/4*/
367 halbtc8723b1ant_updatera_mask(btcoexist
, force_exec
,
374 btc8723b1ant_auto_rate_fb_retry(btcoexist
, force_exec
, arfr_type
);
375 halbtc8723b1ant_retry_limit(btcoexist
, force_exec
, retry_limit_type
);
376 halbtc8723b1ant_ampdu_maxtime(btcoexist
, force_exec
, ampdu_time_type
);
379 static void halbtc8723b1ant_limited_rx(struct btc_coexist
*btcoexist
,
380 bool force_exec
, bool rej_ap_agg_pkt
,
381 bool bt_ctrl_agg_buf_size
,
384 bool reject_rx_agg
= rej_ap_agg_pkt
;
385 bool bt_ctrl_rx_agg_size
= bt_ctrl_agg_buf_size
;
386 u8 rxaggsize
= agg_buf_size
;
388 /**********************************************
389 * Rx Aggregation related setting
390 **********************************************/
391 btcoexist
->btc_set(btcoexist
, BTC_SET_BL_TO_REJ_AP_AGG_PKT
,
393 /* decide BT control aggregation buf size or not */
394 btcoexist
->btc_set(btcoexist
, BTC_SET_BL_BT_CTRL_AGG_SIZE
,
395 &bt_ctrl_rx_agg_size
);
396 /* aggregation buf size, only work
397 * when BT control Rx aggregation size.
399 btcoexist
->btc_set(btcoexist
, BTC_SET_U1_AGG_BUF_SIZE
, &rxaggsize
);
400 /* real update aggregation setting */
401 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_AGGREGATE_CTRL
, NULL
);
404 static void halbtc8723b1ant_monitor_bt_ctr(struct btc_coexist
*btcoexist
)
406 u32 reg_hp_txrx
, reg_lp_txrx
, u32tmp
;
407 u32 reg_hp_tx
= 0, reg_hp_rx
= 0;
408 u32 reg_lp_tx
= 0, reg_lp_rx
= 0;
413 u32tmp
= btcoexist
->btc_read_4byte(btcoexist
, reg_hp_txrx
);
414 reg_hp_tx
= u32tmp
& MASKLWORD
;
415 reg_hp_rx
= (u32tmp
& MASKHWORD
) >> 16;
417 u32tmp
= btcoexist
->btc_read_4byte(btcoexist
, reg_lp_txrx
);
418 reg_lp_tx
= u32tmp
& MASKLWORD
;
419 reg_lp_rx
= (u32tmp
& MASKHWORD
) >> 16;
421 coex_sta
->high_priority_tx
= reg_hp_tx
;
422 coex_sta
->high_priority_rx
= reg_hp_rx
;
423 coex_sta
->low_priority_tx
= reg_lp_tx
;
424 coex_sta
->low_priority_rx
= reg_lp_rx
;
427 btcoexist
->btc_write_1byte(btcoexist
, 0x76e, 0xc);
430 static void halbtc8723b1ant_query_bt_info(struct btc_coexist
*btcoexist
)
432 u8 h2c_parameter
[1] = {0};
434 coex_sta
->c2h_bt_info_req_sent
= true;
436 h2c_parameter
[0] |= BIT0
; /* trigger*/
438 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_EXEC
,
439 "[BTCoex], Query Bt Info, FW write 0x61 = 0x%x\n",
442 btcoexist
->btc_fill_h2c(btcoexist
, 0x61, 1, h2c_parameter
);
445 static bool btc8723b1ant_is_wifi_status_changed(struct btc_coexist
*btcoexist
)
447 static bool pre_wifi_busy
;
448 static bool pre_under_4way
, pre_bt_hs_on
;
449 bool wifi_busy
= false, under_4way
= false, bt_hs_on
= false;
450 bool wifi_connected
= false;
452 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
454 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_BUSY
, &wifi_busy
);
455 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
456 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_4_WAY_PROGRESS
,
459 if (wifi_connected
) {
460 if (wifi_busy
!= pre_wifi_busy
) {
461 pre_wifi_busy
= wifi_busy
;
464 if (under_4way
!= pre_under_4way
) {
465 pre_under_4way
= under_4way
;
468 if (bt_hs_on
!= pre_bt_hs_on
) {
469 pre_bt_hs_on
= bt_hs_on
;
477 static void halbtc8723b1ant_update_bt_link_info(struct btc_coexist
*btcoexist
)
479 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
480 bool bt_hs_on
= false;
482 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
484 bt_link_info
->bt_link_exist
= coex_sta
->bt_link_exist
;
485 bt_link_info
->sco_exist
= coex_sta
->sco_exist
;
486 bt_link_info
->a2dp_exist
= coex_sta
->a2dp_exist
;
487 bt_link_info
->pan_exist
= coex_sta
->pan_exist
;
488 bt_link_info
->hid_exist
= coex_sta
->hid_exist
;
490 /* work around for HS mode. */
492 bt_link_info
->pan_exist
= true;
493 bt_link_info
->bt_link_exist
= true;
496 /* check if Sco only */
497 if (bt_link_info
->sco_exist
&& !bt_link_info
->a2dp_exist
&&
498 !bt_link_info
->pan_exist
&& !bt_link_info
->hid_exist
)
499 bt_link_info
->sco_only
= true;
501 bt_link_info
->sco_only
= false;
503 /* check if A2dp only */
504 if (!bt_link_info
->sco_exist
&& bt_link_info
->a2dp_exist
&&
505 !bt_link_info
->pan_exist
&& !bt_link_info
->hid_exist
)
506 bt_link_info
->a2dp_only
= true;
508 bt_link_info
->a2dp_only
= false;
510 /* check if Pan only */
511 if (!bt_link_info
->sco_exist
&& !bt_link_info
->a2dp_exist
&&
512 bt_link_info
->pan_exist
&& !bt_link_info
->hid_exist
)
513 bt_link_info
->pan_only
= true;
515 bt_link_info
->pan_only
= false;
517 /* check if Hid only */
518 if (!bt_link_info
->sco_exist
&& !bt_link_info
->a2dp_exist
&&
519 !bt_link_info
->pan_exist
&& bt_link_info
->hid_exist
)
520 bt_link_info
->hid_only
= true;
522 bt_link_info
->hid_only
= false;
525 static u8
halbtc8723b1ant_action_algorithm(struct btc_coexist
*btcoexist
)
527 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
528 bool bt_hs_on
= false;
529 u8 algorithm
= BT_8723B_1ANT_COEX_ALGO_UNDEFINED
;
530 u8 numdiffprofile
= 0;
532 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
534 if (!bt_link_info
->bt_link_exist
) {
535 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
536 "[BTCoex], No BT link exists!!!\n");
540 if (bt_link_info
->sco_exist
)
542 if (bt_link_info
->hid_exist
)
544 if (bt_link_info
->pan_exist
)
546 if (bt_link_info
->a2dp_exist
)
549 if (numdiffprofile
== 1) {
550 if (bt_link_info
->sco_exist
) {
551 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
552 "[BTCoex], BT Profile = SCO only\n");
553 algorithm
= BT_8723B_1ANT_COEX_ALGO_SCO
;
555 if (bt_link_info
->hid_exist
) {
556 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
557 "[BTCoex], BT Profile = HID only\n");
558 algorithm
= BT_8723B_1ANT_COEX_ALGO_HID
;
559 } else if (bt_link_info
->a2dp_exist
) {
560 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
561 "[BTCoex], BT Profile = A2DP only\n");
562 algorithm
= BT_8723B_1ANT_COEX_ALGO_A2DP
;
563 } else if (bt_link_info
->pan_exist
) {
565 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
566 "[BTCoex], BT Profile = PAN(HS) only\n");
568 BT_8723B_1ANT_COEX_ALGO_PANHS
;
570 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
571 "[BTCoex], BT Profile = PAN(EDR) only\n");
573 BT_8723B_1ANT_COEX_ALGO_PANEDR
;
577 } else if (numdiffprofile
== 2) {
578 if (bt_link_info
->sco_exist
) {
579 if (bt_link_info
->hid_exist
) {
580 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
581 "[BTCoex], BT Profile = SCO + HID\n");
582 algorithm
= BT_8723B_1ANT_COEX_ALGO_HID
;
583 } else if (bt_link_info
->a2dp_exist
) {
584 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
585 "[BTCoex], BT Profile = SCO + A2DP ==> SCO\n");
586 algorithm
= BT_8723B_1ANT_COEX_ALGO_SCO
;
587 } else if (bt_link_info
->pan_exist
) {
589 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
590 "[BTCoex], BT Profile = SCO + PAN(HS)\n");
591 algorithm
= BT_8723B_1ANT_COEX_ALGO_SCO
;
593 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
594 "[BTCoex], BT Profile = SCO + PAN(EDR)\n");
596 BT_8723B_1ANT_COEX_ALGO_PANEDR_HID
;
600 if (bt_link_info
->hid_exist
&&
601 bt_link_info
->a2dp_exist
) {
602 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
603 "[BTCoex], BT Profile = HID + A2DP\n");
604 algorithm
= BT_8723B_1ANT_COEX_ALGO_HID_A2DP
;
605 } else if (bt_link_info
->hid_exist
&&
606 bt_link_info
->pan_exist
) {
608 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
609 "[BTCoex], BT Profile = HID + PAN(HS)\n");
611 BT_8723B_1ANT_COEX_ALGO_HID_A2DP
;
613 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
614 "[BTCoex], BT Profile = HID + PAN(EDR)\n");
616 BT_8723B_1ANT_COEX_ALGO_PANEDR_HID
;
618 } else if (bt_link_info
->pan_exist
&&
619 bt_link_info
->a2dp_exist
) {
621 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
622 "[BTCoex], BT Profile = A2DP + PAN(HS)\n");
624 BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS
;
626 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
627 "[BTCoex], BT Profile = A2DP + PAN(EDR)\n");
629 BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP
;
633 } else if (numdiffprofile
== 3) {
634 if (bt_link_info
->sco_exist
) {
635 if (bt_link_info
->hid_exist
&&
636 bt_link_info
->a2dp_exist
) {
637 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
638 "[BTCoex], BT Profile = SCO + HID + A2DP ==> HID\n");
639 algorithm
= BT_8723B_1ANT_COEX_ALGO_HID
;
640 } else if (bt_link_info
->hid_exist
&&
641 bt_link_info
->pan_exist
) {
643 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
644 "[BTCoex], BT Profile = SCO + HID + PAN(HS)\n");
646 BT_8723B_1ANT_COEX_ALGO_HID_A2DP
;
648 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
649 "[BTCoex], BT Profile = SCO + HID + PAN(EDR)\n");
651 BT_8723B_1ANT_COEX_ALGO_PANEDR_HID
;
653 } else if (bt_link_info
->pan_exist
&&
654 bt_link_info
->a2dp_exist
) {
656 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
657 "[BTCoex], BT Profile = SCO + A2DP + PAN(HS)\n");
658 algorithm
= BT_8723B_1ANT_COEX_ALGO_SCO
;
660 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
661 "[BTCoex], BT Profile = SCO + A2DP + PAN(EDR) ==> HID\n");
663 BT_8723B_1ANT_COEX_ALGO_PANEDR_HID
;
667 if (bt_link_info
->hid_exist
&&
668 bt_link_info
->pan_exist
&&
669 bt_link_info
->a2dp_exist
) {
671 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
672 "[BTCoex], BT Profile = HID + A2DP + PAN(HS)\n");
674 BT_8723B_1ANT_COEX_ALGO_HID_A2DP
;
676 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
677 "[BTCoex], BT Profile = HID + A2DP + PAN(EDR)\n");
679 BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR
;
683 } else if (numdiffprofile
>= 3) {
684 if (bt_link_info
->sco_exist
) {
685 if (bt_link_info
->hid_exist
&&
686 bt_link_info
->pan_exist
&&
687 bt_link_info
->a2dp_exist
) {
689 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
690 "[BTCoex], Error!!! BT Profile = SCO + HID + A2DP + PAN(HS)\n");
692 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
693 "[BTCoex], BT Profile = SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n");
695 BT_8723B_1ANT_COEX_ALGO_PANEDR_HID
;
704 static void btc8723b1ant_set_sw_pen_tx_rate_adapt(struct btc_coexist
*btcoexist
,
707 u8 h2c_parameter
[6] = {0};
709 h2c_parameter
[0] = 0x6; /* opCode, 0x6= Retry_Penalty */
711 if (low_penalty_ra
) {
712 h2c_parameter
[1] |= BIT0
;
713 /*normal rate except MCS7/6/5, OFDM54/48/36 */
714 h2c_parameter
[2] = 0x00;
715 h2c_parameter
[3] = 0xf7; /*MCS7 or OFDM54 */
716 h2c_parameter
[4] = 0xf8; /*MCS6 or OFDM48 */
717 h2c_parameter
[5] = 0xf9; /*MCS5 or OFDM36 */
720 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_EXEC
,
721 "[BTCoex], set WiFi Low-Penalty Retry: %s",
722 (low_penalty_ra
? "ON!!" : "OFF!!"));
724 btcoexist
->btc_fill_h2c(btcoexist
, 0x69, 6, h2c_parameter
);
727 static void halbtc8723b1ant_low_penalty_ra(struct btc_coexist
*btcoexist
,
728 bool force_exec
, bool low_penalty_ra
)
730 coex_dm
->cur_low_penalty_ra
= low_penalty_ra
;
733 if (coex_dm
->pre_low_penalty_ra
== coex_dm
->cur_low_penalty_ra
)
736 btc8723b1ant_set_sw_pen_tx_rate_adapt(btcoexist
,
737 coex_dm
->cur_low_penalty_ra
);
739 coex_dm
->pre_low_penalty_ra
= coex_dm
->cur_low_penalty_ra
;
742 static void halbtc8723b1ant_set_coex_table(struct btc_coexist
*btcoexist
,
743 u32 val0x6c0
, u32 val0x6c4
,
744 u32 val0x6c8
, u8 val0x6cc
)
746 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_SW_EXEC
,
747 "[BTCoex], set coex table, set 0x6c0 = 0x%x\n", val0x6c0
);
748 btcoexist
->btc_write_4byte(btcoexist
, 0x6c0, val0x6c0
);
750 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_SW_EXEC
,
751 "[BTCoex], set coex table, set 0x6c4 = 0x%x\n", val0x6c4
);
752 btcoexist
->btc_write_4byte(btcoexist
, 0x6c4, val0x6c4
);
754 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_SW_EXEC
,
755 "[BTCoex], set coex table, set 0x6c8 = 0x%x\n", val0x6c8
);
756 btcoexist
->btc_write_4byte(btcoexist
, 0x6c8, val0x6c8
);
758 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_SW_EXEC
,
759 "[BTCoex], set coex table, set 0x6cc = 0x%x\n", val0x6cc
);
760 btcoexist
->btc_write_1byte(btcoexist
, 0x6cc, val0x6cc
);
763 static void halbtc8723b1ant_coex_table(struct btc_coexist
*btcoexist
,
764 bool force_exec
, u32 val0x6c0
,
765 u32 val0x6c4
, u32 val0x6c8
,
768 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_SW
,
769 "[BTCoex], %s write Coex Table 0x6c0 = 0x%x, 0x6c4 = 0x%x, 0x6cc = 0x%x\n",
770 (force_exec
? "force to" : ""),
771 val0x6c0
, val0x6c4
, val0x6cc
);
772 coex_dm
->cur_val0x6c0
= val0x6c0
;
773 coex_dm
->cur_val0x6c4
= val0x6c4
;
774 coex_dm
->cur_val0x6c8
= val0x6c8
;
775 coex_dm
->cur_val0x6cc
= val0x6cc
;
778 if ((coex_dm
->pre_val0x6c0
== coex_dm
->cur_val0x6c0
) &&
779 (coex_dm
->pre_val0x6c4
== coex_dm
->cur_val0x6c4
) &&
780 (coex_dm
->pre_val0x6c8
== coex_dm
->cur_val0x6c8
) &&
781 (coex_dm
->pre_val0x6cc
== coex_dm
->cur_val0x6cc
))
784 halbtc8723b1ant_set_coex_table(btcoexist
, val0x6c0
, val0x6c4
,
787 coex_dm
->pre_val0x6c0
= coex_dm
->cur_val0x6c0
;
788 coex_dm
->pre_val0x6c4
= coex_dm
->cur_val0x6c4
;
789 coex_dm
->pre_val0x6c8
= coex_dm
->cur_val0x6c8
;
790 coex_dm
->pre_val0x6cc
= coex_dm
->cur_val0x6cc
;
793 static void halbtc8723b1ant_coex_table_with_type(struct btc_coexist
*btcoexist
,
794 bool force_exec
, u8 type
)
798 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x55555555,
799 0x55555555, 0xffffff, 0x3);
802 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x55555555,
803 0x5a5a5a5a, 0xffffff, 0x3);
806 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x5a5a5a5a,
807 0x5a5a5a5a, 0xffffff, 0x3);
810 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x55555555,
811 0xaaaaaaaa, 0xffffff, 0x3);
814 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x55555555,
815 0x5aaa5aaa, 0xffffff, 0x3);
818 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x5a5a5a5a,
819 0xaaaa5a5a, 0xffffff, 0x3);
822 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0x55555555,
823 0xaaaa5a5a, 0xffffff, 0x3);
826 halbtc8723b1ant_coex_table(btcoexist
, force_exec
, 0xaaaaaaaa,
827 0xaaaaaaaa, 0xffffff, 0x3);
834 static void halbtc8723b1ant_SetFwIgnoreWlanAct(struct btc_coexist
*btcoexist
,
837 u8 h2c_parameter
[1] = {0};
840 h2c_parameter
[0] |= BIT0
; /* function enable */
842 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_EXEC
,
843 "[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63 = 0x%x\n",
846 btcoexist
->btc_fill_h2c(btcoexist
, 0x63, 1, h2c_parameter
);
849 static void halbtc8723b1ant_ignore_wlan_act(struct btc_coexist
*btcoexist
,
850 bool force_exec
, bool enable
)
852 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW
,
853 "[BTCoex], %s turn Ignore WlanAct %s\n",
854 (force_exec
? "force to" : ""), (enable
? "ON" : "OFF"));
855 coex_dm
->cur_ignore_wlan_act
= enable
;
858 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
859 "[BTCoex], bPreIgnoreWlanAct = %d, bCurIgnoreWlanAct = %d!!\n",
860 coex_dm
->pre_ignore_wlan_act
,
861 coex_dm
->cur_ignore_wlan_act
);
863 if (coex_dm
->pre_ignore_wlan_act
==
864 coex_dm
->cur_ignore_wlan_act
)
867 halbtc8723b1ant_SetFwIgnoreWlanAct(btcoexist
, enable
);
869 coex_dm
->pre_ignore_wlan_act
= coex_dm
->cur_ignore_wlan_act
;
872 static void halbtc8723b1ant_set_fw_ps_tdma(struct btc_coexist
*btcoexist
,
873 u8 byte1
, u8 byte2
, u8 byte3
,
876 u8 h2c_parameter
[5] = {0};
877 u8 real_byte1
= byte1
, real_byte5
= byte5
;
878 bool ap_enable
= false;
880 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_AP_MODE_ENABLE
,
884 if ((byte1
& BIT4
) && !(byte1
& BIT5
)) {
885 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
886 "[BTCoex], FW for 1Ant AP mode\n");
895 h2c_parameter
[0] = real_byte1
;
896 h2c_parameter
[1] = byte2
;
897 h2c_parameter
[2] = byte3
;
898 h2c_parameter
[3] = byte4
;
899 h2c_parameter
[4] = real_byte5
;
901 coex_dm
->ps_tdma_para
[0] = real_byte1
;
902 coex_dm
->ps_tdma_para
[1] = byte2
;
903 coex_dm
->ps_tdma_para
[2] = byte3
;
904 coex_dm
->ps_tdma_para
[3] = byte4
;
905 coex_dm
->ps_tdma_para
[4] = real_byte5
;
907 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_EXEC
,
908 "[BTCoex], PS-TDMA H2C cmd =0x%x%08x\n",
910 h2c_parameter
[1] << 24 |
911 h2c_parameter
[2] << 16 |
912 h2c_parameter
[3] << 8 |
915 btcoexist
->btc_fill_h2c(btcoexist
, 0x60, 5, h2c_parameter
);
918 static void halbtc8723b1ant_set_lps_rpwm(struct btc_coexist
*btcoexist
,
919 u8 lps_val
, u8 rpwm_val
)
924 btcoexist
->btc_set(btcoexist
, BTC_SET_U1_LPS_VAL
, &lps
);
925 btcoexist
->btc_set(btcoexist
, BTC_SET_U1_RPWM_VAL
, &rpwm
);
928 static void halbtc8723b1ant_LpsRpwm(struct btc_coexist
*btcoexist
,
930 u8 lps_val
, u8 rpwm_val
)
932 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW
,
933 "[BTCoex], %s set lps/rpwm = 0x%x/0x%x\n",
934 (force_exec
? "force to" : ""), lps_val
, rpwm_val
);
935 coex_dm
->cur_lps
= lps_val
;
936 coex_dm
->cur_rpwm
= rpwm_val
;
939 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
940 "[BTCoex], LPS-RxBeaconMode = 0x%x , LPS-RPWM = 0x%x!!\n",
941 coex_dm
->cur_lps
, coex_dm
->cur_rpwm
);
943 if ((coex_dm
->pre_lps
== coex_dm
->cur_lps
) &&
944 (coex_dm
->pre_rpwm
== coex_dm
->cur_rpwm
)) {
945 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
946 "[BTCoex], LPS-RPWM_Last = 0x%x , LPS-RPWM_Now = 0x%x!!\n",
947 coex_dm
->pre_rpwm
, coex_dm
->cur_rpwm
);
952 halbtc8723b1ant_set_lps_rpwm(btcoexist
, lps_val
, rpwm_val
);
954 coex_dm
->pre_lps
= coex_dm
->cur_lps
;
955 coex_dm
->pre_rpwm
= coex_dm
->cur_rpwm
;
958 static void halbtc8723b1ant_sw_mechanism(struct btc_coexist
*btcoexist
,
961 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_BT_MONITOR
,
962 "[BTCoex], SM[LpRA] = %d\n", low_penalty_ra
);
964 halbtc8723b1ant_low_penalty_ra(btcoexist
, NORMAL_EXEC
, low_penalty_ra
);
967 static void halbtc8723b1ant_SetAntPath(struct btc_coexist
*btcoexist
,
968 u8 ant_pos_type
, bool init_hw_cfg
,
971 struct btc_board_info
*board_info
= &btcoexist
->board_info
;
972 u32 fw_ver
= 0, u32tmp
= 0;
973 bool pg_ext_switch
= false;
974 bool use_ext_switch
= false;
975 u8 h2c_parameter
[2] = {0};
977 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_EXT_SWITCH
, &pg_ext_switch
);
978 /* [31:16] = fw ver, [15:0] = fw sub ver */
979 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_FW_VER
, &fw_ver
);
981 if ((fw_ver
< 0xc0000) || pg_ext_switch
)
982 use_ext_switch
= true;
985 /*BT select s0/s1 is controlled by WiFi */
986 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x67, 0x20, 0x1);
988 /*Force GNT_BT to Normal */
989 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x765, 0x18, 0x0);
990 } else if (wifi_off
) {
991 /*Force GNT_BT to High */
992 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x765, 0x18, 0x3);
993 /*BT select s0/s1 is controlled by BT */
994 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x67, 0x20, 0x0);
996 /* 0x4c[24:23] = 00, Set Antenna control by BT_RFE_CTRL
997 * BT Vendor 0xac = 0xf002
999 u32tmp
= btcoexist
->btc_read_4byte(btcoexist
, 0x4c);
1002 btcoexist
->btc_write_4byte(btcoexist
, 0x4c, u32tmp
);
1005 if (use_ext_switch
) {
1007 /* 0x4c[23] = 0, 0x4c[24] = 1
1008 * Antenna control by WL/BT
1010 u32tmp
= btcoexist
->btc_read_4byte(btcoexist
, 0x4c);
1013 btcoexist
->btc_write_4byte(btcoexist
, 0x4c, u32tmp
);
1015 if (board_info
->btdm_ant_pos
==
1016 BTC_ANTENNA_AT_MAIN_PORT
) {
1017 /* Main Ant to BT for IPS case 0x4c[23] = 1 */
1018 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1022 /*tell firmware "no antenna inverse"*/
1023 h2c_parameter
[0] = 0;
1024 h2c_parameter
[1] = 1; /*ext switch type*/
1025 btcoexist
->btc_fill_h2c(btcoexist
, 0x65, 2,
1028 /*Aux Ant to BT for IPS case 0x4c[23] = 1 */
1029 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1033 /*tell firmware "antenna inverse"*/
1034 h2c_parameter
[0] = 1;
1035 h2c_parameter
[1] = 1; /*ext switch type*/
1036 btcoexist
->btc_fill_h2c(btcoexist
, 0x65, 2,
1041 /* fixed internal switch first*/
1042 /* fixed internal switch S1->WiFi, S0->BT*/
1043 if (board_info
->btdm_ant_pos
== BTC_ANTENNA_AT_MAIN_PORT
)
1044 btcoexist
->btc_write_2byte(btcoexist
, 0x948, 0x0);
1045 else/* fixed internal switch S0->WiFi, S1->BT*/
1046 btcoexist
->btc_write_2byte(btcoexist
, 0x948, 0x280);
1048 /* ext switch setting */
1049 switch (ant_pos_type
) {
1050 case BTC_ANT_PATH_WIFI
:
1051 if (board_info
->btdm_ant_pos
==
1052 BTC_ANTENNA_AT_MAIN_PORT
)
1053 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1057 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1061 case BTC_ANT_PATH_BT
:
1062 if (board_info
->btdm_ant_pos
==
1063 BTC_ANTENNA_AT_MAIN_PORT
)
1064 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1068 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1073 case BTC_ANT_PATH_PTA
:
1074 if (board_info
->btdm_ant_pos
==
1075 BTC_ANTENNA_AT_MAIN_PORT
)
1076 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1080 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1088 /* 0x4c[23] = 1, 0x4c[24] = 0 Antenna control by 0x64*/
1089 u32tmp
= btcoexist
->btc_read_4byte(btcoexist
, 0x4c);
1092 btcoexist
->btc_write_4byte(btcoexist
, 0x4c, u32tmp
);
1094 if (board_info
->btdm_ant_pos
==
1095 BTC_ANTENNA_AT_MAIN_PORT
) {
1096 /*Main Ant to WiFi for IPS case 0x4c[23] = 1*/
1097 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1101 /*tell firmware "no antenna inverse"*/
1102 h2c_parameter
[0] = 0;
1103 h2c_parameter
[1] = 0; /*internal switch type*/
1104 btcoexist
->btc_fill_h2c(btcoexist
, 0x65, 2,
1107 /*Aux Ant to BT for IPS case 0x4c[23] = 1*/
1108 btcoexist
->btc_write_1byte_bitmask(btcoexist
,
1112 /*tell firmware "antenna inverse"*/
1113 h2c_parameter
[0] = 1;
1114 h2c_parameter
[1] = 0; /*internal switch type*/
1115 btcoexist
->btc_fill_h2c(btcoexist
, 0x65, 2,
1120 /* fixed external switch first*/
1121 /*Main->WiFi, Aux->BT*/
1122 if (board_info
->btdm_ant_pos
==
1123 BTC_ANTENNA_AT_MAIN_PORT
)
1124 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x92c,
1126 else/*Main->BT, Aux->WiFi */
1127 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x92c,
1130 /* internal switch setting*/
1131 switch (ant_pos_type
) {
1132 case BTC_ANT_PATH_WIFI
:
1133 if (board_info
->btdm_ant_pos
==
1134 BTC_ANTENNA_AT_MAIN_PORT
)
1135 btcoexist
->btc_write_2byte(btcoexist
, 0x948,
1138 btcoexist
->btc_write_2byte(btcoexist
, 0x948,
1141 case BTC_ANT_PATH_BT
:
1142 if (board_info
->btdm_ant_pos
==
1143 BTC_ANTENNA_AT_MAIN_PORT
)
1144 btcoexist
->btc_write_2byte(btcoexist
, 0x948,
1147 btcoexist
->btc_write_2byte(btcoexist
, 0x948,
1151 case BTC_ANT_PATH_PTA
:
1152 if (board_info
->btdm_ant_pos
==
1153 BTC_ANTENNA_AT_MAIN_PORT
)
1154 btcoexist
->btc_write_2byte(btcoexist
, 0x948,
1157 btcoexist
->btc_write_2byte(btcoexist
, 0x948,
1164 static void halbtc8723b1ant_ps_tdma(struct btc_coexist
*btcoexist
,
1165 bool force_exec
, bool turn_on
, u8 type
)
1167 bool wifi_busy
= false;
1168 u8 rssi_adjust_val
= 0;
1170 coex_dm
->cur_ps_tdma_on
= turn_on
;
1171 coex_dm
->cur_ps_tdma
= type
;
1173 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_BUSY
, &wifi_busy
);
1176 if (coex_dm
->cur_ps_tdma_on
)
1177 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
1178 "[BTCoex], ******** TDMA(on, %d) *********\n",
1179 coex_dm
->cur_ps_tdma
);
1181 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
1182 "[BTCoex], ******** TDMA(off, %d) ********\n",
1183 coex_dm
->cur_ps_tdma
);
1185 if ((coex_dm
->pre_ps_tdma_on
== coex_dm
->cur_ps_tdma_on
) &&
1186 (coex_dm
->pre_ps_tdma
== coex_dm
->cur_ps_tdma
))
1192 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x1a,
1196 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x3a,
1199 rssi_adjust_val
= 11;
1202 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x2b,
1204 rssi_adjust_val
= 14;
1207 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x1d,
1211 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x93, 0x15,
1213 rssi_adjust_val
= 17;
1216 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x61, 0x15,
1220 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x61, 0x20,
1224 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x13, 0xc,
1228 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x93, 0x25,
1232 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x21,
1234 rssi_adjust_val
= 18;
1237 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x13, 0xa,
1241 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x15,
1243 rssi_adjust_val
= 20;
1246 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x0a,
1250 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x15,
1254 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x21,
1258 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x13, 0xa,
1262 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x93, 0x15,
1264 rssi_adjust_val
= 18;
1267 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x93, 0x25,
1269 rssi_adjust_val
= 14;
1272 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x61, 0x35,
1276 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x61, 0x25,
1280 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x61, 0x25,
1284 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xe3, 0x25,
1286 rssi_adjust_val
= 22;
1289 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xe3, 0x15,
1291 rssi_adjust_val
= 22;
1294 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xe3, 0xa,
1296 rssi_adjust_val
= 22;
1299 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xe3, 0xa,
1301 rssi_adjust_val
= 22;
1304 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xe3, 0x25,
1306 rssi_adjust_val
= 22;
1309 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x69, 0x25,
1313 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xab, 0x1a,
1317 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x51, 0x14,
1321 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xd3, 0x1a,
1325 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x61, 0xa,
1329 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xa3, 0x25,
1333 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x53, 0x1a,
1337 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x63, 0x1a,
1341 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0xd3, 0x12,
1344 /* SoftAP only with no sta associated,BT disable ,
1345 * TDMA mode for power saving
1346 * here softap mode screen off will cost 70-80mA for phone
1349 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x23, 0x18,
1355 case 8: /*PTA Control */
1356 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x8, 0x0,
1358 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_PTA
,
1362 default: /*Software control, Antenna at BT side */
1363 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x0, 0x0,
1365 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_BT
,
1368 case 9: /*Software control, Antenna at WiFi side */
1369 halbtc8723b1ant_set_fw_ps_tdma(btcoexist
, 0x0, 0x0,
1371 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_WIFI
,
1376 rssi_adjust_val
= 0;
1377 btcoexist
->btc_set(btcoexist
,
1378 BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE
,
1381 /* update pre state */
1382 coex_dm
->pre_ps_tdma_on
= coex_dm
->cur_ps_tdma_on
;
1383 coex_dm
->pre_ps_tdma
= coex_dm
->cur_ps_tdma
;
1386 static bool halbtc8723b1ant_is_common_action(struct btc_coexist
*btcoexist
)
1388 bool commom
= false, wifi_connected
= false;
1389 bool wifi_busy
= false;
1391 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
1393 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_BUSY
, &wifi_busy
);
1395 if (!wifi_connected
&&
1396 BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE
== coex_dm
->bt_status
) {
1397 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1398 "[BTCoex], Wifi non connected-idle + BT non connected-idle!!\n");
1399 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1401 } else if (wifi_connected
&&
1402 (BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE
==
1403 coex_dm
->bt_status
)) {
1404 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1405 "[BTCoex], Wifi connected + BT non connected-idle!!\n");
1406 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1408 } else if (!wifi_connected
&&
1409 (BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
==
1410 coex_dm
->bt_status
)) {
1411 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1412 "[BTCoex], Wifi non connected-idle + BT connected-idle!!\n");
1413 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1415 } else if (wifi_connected
&&
1416 (BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
==
1417 coex_dm
->bt_status
)) {
1418 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1419 "[BTCoex], Wifi connected + BT connected-idle!!\n");
1420 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1422 } else if (!wifi_connected
&&
1423 (BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
!=
1424 coex_dm
->bt_status
)) {
1425 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1426 ("[BTCoex], Wifi non connected-idle + BT Busy!!\n"));
1427 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1431 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1432 "[BTCoex], Wifi Connected-Busy + BT Busy!!\n");
1434 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
1435 "[BTCoex], Wifi Connected-Idle + BT Busy!!\n");
1443 static void btc8723b1ant_tdma_dur_adj_for_acl(struct btc_coexist
*btcoexist
,
1446 static s32 up
, dn
, m
, n
, wait_count
;
1447 /* 0: no change, +1: increase WiFi duration,
1448 * -1: decrease WiFi duration
1451 u8 retry_count
= 0, bt_info_ext
;
1452 bool wifi_busy
= false;
1454 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW
,
1455 "[BTCoex], TdmaDurationAdjustForAcl()\n");
1457 if (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY
== wifi_status
)
1462 if ((BT_8723B_1ANT_WIFI_STATUS_NON_CONNECTED_ASSO_AUTH_SCAN
==
1464 (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN
== wifi_status
) ||
1465 (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SPECIAL_PKT
== wifi_status
)) {
1466 if (coex_dm
->cur_ps_tdma
!= 1 && coex_dm
->cur_ps_tdma
!= 2 &&
1467 coex_dm
->cur_ps_tdma
!= 3 && coex_dm
->cur_ps_tdma
!= 9) {
1468 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1470 coex_dm
->tdma_adj_type
= 9;
1482 if (!coex_dm
->auto_tdma_adjust
) {
1483 coex_dm
->auto_tdma_adjust
= true;
1484 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
1485 "[BTCoex], first run TdmaDurationAdjust()!!\n");
1487 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 2);
1488 coex_dm
->tdma_adj_type
= 2;
1497 /*accquire the BT TRx retry count from BT_Info byte2 */
1498 retry_count
= coex_sta
->bt_retry_cnt
;
1499 bt_info_ext
= coex_sta
->bt_info_ext
;
1502 /* no retry in the last 2-second duration */
1503 if (retry_count
== 0) {
1516 BTC_PRINT(BTC_MSG_ALGORITHM
,
1517 ALGO_TRACE_FW_DETAIL
,
1518 "[BTCoex], Increase wifi duration!!\n");
1520 } else if (retry_count
<= 3) {
1528 if (wait_count
<= 2)
1541 BTC_PRINT(BTC_MSG_ALGORITHM
,
1542 ALGO_TRACE_FW_DETAIL
,
1543 "[BTCoex], Decrease wifi duration for retryCounter<3!!\n");
1546 if (wait_count
== 1)
1559 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
1560 "[BTCoex], Decrease wifi duration for retryCounter>3!!\n");
1564 if ((BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(bt_info_ext
)) &&
1565 ((coex_dm
->cur_ps_tdma
== 1) ||
1566 (coex_dm
->cur_ps_tdma
== 2))) {
1567 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1569 coex_dm
->tdma_adj_type
= 9;
1570 } else if (coex_dm
->cur_ps_tdma
== 1) {
1571 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1573 coex_dm
->tdma_adj_type
= 2;
1574 } else if (coex_dm
->cur_ps_tdma
== 2) {
1575 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1577 coex_dm
->tdma_adj_type
= 9;
1578 } else if (coex_dm
->cur_ps_tdma
== 9) {
1579 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1581 coex_dm
->tdma_adj_type
= 11;
1583 } else if (result
== 1) {
1584 if ((BT_INFO_8723B_1ANT_A2DP_BASIC_RATE(bt_info_ext
)) &&
1585 ((coex_dm
->cur_ps_tdma
== 1) ||
1586 (coex_dm
->cur_ps_tdma
== 2))) {
1587 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1589 coex_dm
->tdma_adj_type
= 9;
1590 } else if (coex_dm
->cur_ps_tdma
== 11) {
1591 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1593 coex_dm
->tdma_adj_type
= 9;
1594 } else if (coex_dm
->cur_ps_tdma
== 9) {
1595 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1597 coex_dm
->tdma_adj_type
= 2;
1598 } else if (coex_dm
->cur_ps_tdma
== 2) {
1599 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1601 coex_dm
->tdma_adj_type
= 1;
1603 } else { /*no change */
1604 /*if busy / idle change */
1605 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_DETAIL
,
1606 "[BTCoex],********* TDMA(on, %d) ********\n",
1607 coex_dm
->cur_ps_tdma
);
1610 if (coex_dm
->cur_ps_tdma
!= 1 && coex_dm
->cur_ps_tdma
!= 2 &&
1611 coex_dm
->cur_ps_tdma
!= 9 && coex_dm
->cur_ps_tdma
!= 11) {
1612 /* recover to previous adjust type */
1613 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true,
1614 coex_dm
->tdma_adj_type
);
1619 static void btc8723b1ant_pstdmachkpwrsave(struct btc_coexist
*btcoexist
,
1624 btcoexist
->btc_get(btcoexist
, BTC_GET_U1_LPS_MODE
, &lps_mode
);
1626 if (lps_mode
) { /* already under LPS state */
1628 /* keep state under LPS, do nothing. */
1630 /* will leave LPS state, turn off psTdma first */
1631 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1634 } else { /* NO PS state */
1636 /* will enter LPS state, turn off psTdma first */
1637 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1640 /* keep state under NO PS state, do nothing. */
1645 static void halbtc8723b1ant_power_save_state(struct btc_coexist
*btcoexist
,
1646 u8 ps_type
, u8 lps_val
,
1649 bool low_pwr_disable
= false;
1652 case BTC_PS_WIFI_NATIVE
:
1653 /* recover to original 32k low power setting */
1654 low_pwr_disable
= false;
1655 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_DISABLE_LOW_POWER
,
1657 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_NORMAL_LPS
, NULL
);
1660 btc8723b1ant_pstdmachkpwrsave(btcoexist
, true);
1661 halbtc8723b1ant_LpsRpwm(btcoexist
, NORMAL_EXEC
, lps_val
,
1663 /* when coex force to enter LPS, do not enter 32k low power. */
1664 low_pwr_disable
= true;
1665 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_DISABLE_LOW_POWER
,
1667 /* power save must executed before psTdma. */
1668 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_ENTER_LPS
, NULL
);
1670 case BTC_PS_LPS_OFF
:
1671 btc8723b1ant_pstdmachkpwrsave(btcoexist
, false);
1672 btcoexist
->btc_set(btcoexist
, BTC_SET_ACT_LEAVE_LPS
, NULL
);
1679 /***************************************************
1681 * Software Coex Mechanism start
1683 ***************************************************/
1684 /* SCO only or SCO+PAN(HS) */
1685 static void halbtc8723b1ant_action_sco(struct btc_coexist
*btcoexist
)
1687 halbtc8723b1ant_sw_mechanism(btcoexist
, true);
1690 static void halbtc8723b1ant_action_hid(struct btc_coexist
*btcoexist
)
1692 halbtc8723b1ant_sw_mechanism(btcoexist
, true);
1695 /*A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */
1696 static void halbtc8723b1ant_action_a2dp(struct btc_coexist
*btcoexist
)
1698 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1701 static void halbtc8723b1ant_action_a2dp_pan_hs(struct btc_coexist
*btcoexist
)
1703 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1706 static void halbtc8723b1ant_action_pan_edr(struct btc_coexist
*btcoexist
)
1708 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1712 static void halbtc8723b1ant_action_pan_hs(struct btc_coexist
*btcoexist
)
1714 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1718 static void halbtc8723b1ant_action_pan_edr_a2dp(struct btc_coexist
*btcoexist
)
1720 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
1723 static void halbtc8723b1ant_action_pan_edr_hid(struct btc_coexist
*btcoexist
)
1725 halbtc8723b1ant_sw_mechanism(btcoexist
, true);
1728 /* HID+A2DP+PAN(EDR) */
1729 static void btc8723b1ant_action_hid_a2dp_pan_edr(struct btc_coexist
*btcoexist
)
1731 halbtc8723b1ant_sw_mechanism(btcoexist
, true);
1734 static void halbtc8723b1ant_action_hid_a2dp(struct btc_coexist
*btcoexist
)
1736 halbtc8723b1ant_sw_mechanism(btcoexist
, true);
1739 /*****************************************************
1741 * Non-Software Coex Mechanism start
1743 *****************************************************/
1744 static void halbtc8723b1ant_action_wifi_multiport(struct btc_coexist
*btcoexist
)
1746 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
1749 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 8);
1750 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 2);
1753 static void halbtc8723b1ant_action_hs(struct btc_coexist
*btcoexist
)
1755 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 5);
1756 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 2);
1759 static void halbtc8723b1ant_action_bt_inquiry(struct btc_coexist
*btcoexist
)
1761 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
1762 bool wifi_connected
= false, ap_enable
= false;
1764 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_AP_MODE_ENABLE
,
1766 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
1769 if (!wifi_connected
) {
1770 halbtc8723b1ant_power_save_state(btcoexist
,
1771 BTC_PS_WIFI_NATIVE
, 0x0, 0x0);
1772 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 8);
1773 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 2);
1774 } else if (bt_link_info
->sco_exist
|| bt_link_info
->hid_only
) {
1775 /* SCO/HID-only busy */
1776 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
1778 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 32);
1779 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 1);
1782 halbtc8723b1ant_power_save_state(btcoexist
,
1786 halbtc8723b1ant_power_save_state(btcoexist
,
1790 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 30);
1791 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 1);
1795 static void btc8723b1ant_act_bt_sco_hid_only_busy(struct btc_coexist
*btcoexist
,
1798 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
1799 bool wifi_connected
= false;
1801 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
1804 /* tdma and coex table */
1806 if (bt_link_info
->sco_exist
) {
1807 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 5);
1808 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 2);
1810 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 6);
1811 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 5);
1815 static void halbtc8723b1ant_action_wifi_connected_bt_acl_busy(
1816 struct btc_coexist
*btcoexist
,
1821 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
1823 bt_rssi_state
= halbtc8723b1ant_bt_rssi_state(2, 28, 0);
1825 if (bt_link_info
->hid_only
) { /*HID */
1826 btc8723b1ant_act_bt_sco_hid_only_busy(btcoexist
, wifi_status
);
1827 coex_dm
->auto_tdma_adjust
= false;
1829 } else if (bt_link_info
->a2dp_only
) { /*A2DP */
1830 if (BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE
== wifi_status
) {
1831 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1833 halbtc8723b1ant_coex_table_with_type(btcoexist
,
1835 coex_dm
->auto_tdma_adjust
= false;
1836 } else if ((bt_rssi_state
== BTC_RSSI_STATE_HIGH
) ||
1837 (bt_rssi_state
== BTC_RSSI_STATE_STAY_HIGH
)) {
1838 btc8723b1ant_tdma_dur_adj_for_acl(btcoexist
,
1840 halbtc8723b1ant_coex_table_with_type(btcoexist
,
1842 } else { /*for low BT RSSI */
1843 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1845 halbtc8723b1ant_coex_table_with_type(btcoexist
,
1847 coex_dm
->auto_tdma_adjust
= false;
1849 } else if (bt_link_info
->hid_exist
&&
1850 bt_link_info
->a2dp_exist
) { /*HID+A2DP */
1851 if ((bt_rssi_state
== BTC_RSSI_STATE_HIGH
) ||
1852 (bt_rssi_state
== BTC_RSSI_STATE_STAY_HIGH
)) {
1853 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1855 coex_dm
->auto_tdma_adjust
= false;
1856 } else { /*for low BT RSSI*/
1857 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1859 coex_dm
->auto_tdma_adjust
= false;
1862 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 6);
1863 /*PAN(OPP,FTP), HID+PAN(OPP,FTP) */
1864 } else if (bt_link_info
->pan_only
||
1865 (bt_link_info
->hid_exist
&& bt_link_info
->pan_exist
)) {
1866 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 3);
1867 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 6);
1868 coex_dm
->auto_tdma_adjust
= false;
1869 /*A2DP+PAN(OPP,FTP), HID+A2DP+PAN(OPP,FTP)*/
1870 } else if ((bt_link_info
->a2dp_exist
&& bt_link_info
->pan_exist
) ||
1871 (bt_link_info
->hid_exist
&& bt_link_info
->a2dp_exist
&&
1872 bt_link_info
->pan_exist
)) {
1873 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 13);
1874 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 1);
1875 coex_dm
->auto_tdma_adjust
= false;
1877 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 11);
1878 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 1);
1879 coex_dm
->auto_tdma_adjust
= false;
1883 static void btc8723b1ant_action_wifi_not_conn(struct btc_coexist
*btcoexist
)
1885 /* power save state */
1886 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
1889 /* tdma and coex table */
1890 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 8);
1891 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 0);
1894 static void btc8723b1ant_action_wifi_not_conn_scan(struct btc_coexist
*btcoex
)
1896 struct btc_bt_link_info
*bt_link_info
= &btcoex
->bt_link_info
;
1898 halbtc8723b1ant_power_save_state(btcoex
, BTC_PS_WIFI_NATIVE
,
1901 /* tdma and coex table */
1902 if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
) {
1903 if (bt_link_info
->a2dp_exist
&& bt_link_info
->pan_exist
) {
1904 halbtc8723b1ant_ps_tdma(btcoex
, NORMAL_EXEC
,
1906 halbtc8723b1ant_coex_table_with_type(btcoex
,
1908 } else if (bt_link_info
->pan_only
) {
1909 halbtc8723b1ant_ps_tdma(btcoex
, NORMAL_EXEC
,
1911 halbtc8723b1ant_coex_table_with_type(btcoex
,
1914 halbtc8723b1ant_ps_tdma(btcoex
, NORMAL_EXEC
,
1916 halbtc8723b1ant_coex_table_with_type(btcoex
,
1919 } else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY
== coex_dm
->bt_status
) ||
1920 (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY
==
1921 coex_dm
->bt_status
)){
1922 btc8723b1ant_act_bt_sco_hid_only_busy(btcoex
,
1923 BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN
);
1925 halbtc8723b1ant_ps_tdma(btcoex
, NORMAL_EXEC
, false, 8);
1926 halbtc8723b1ant_coex_table_with_type(btcoex
, NORMAL_EXEC
, 2);
1930 static void btc8723b1ant_act_wifi_not_conn_asso_auth(struct btc_coexist
*btcoex
)
1932 struct btc_bt_link_info
*bt_link_info
= &btcoex
->bt_link_info
;
1934 halbtc8723b1ant_power_save_state(btcoex
, BTC_PS_WIFI_NATIVE
,
1937 if ((BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
== coex_dm
->bt_status
) ||
1938 (bt_link_info
->sco_exist
) || (bt_link_info
->hid_only
) ||
1939 (bt_link_info
->a2dp_only
) || (bt_link_info
->pan_only
)) {
1940 halbtc8723b1ant_ps_tdma(btcoex
, NORMAL_EXEC
, false, 8);
1941 halbtc8723b1ant_coex_table_with_type(btcoex
, NORMAL_EXEC
, 7);
1943 halbtc8723b1ant_ps_tdma(btcoex
, NORMAL_EXEC
, true, 20);
1944 halbtc8723b1ant_coex_table_with_type(btcoex
, NORMAL_EXEC
, 1);
1948 static void btc8723b1ant_action_wifi_conn_scan(struct btc_coexist
*btcoexist
)
1950 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
1952 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
1955 /* tdma and coex table */
1956 if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
) {
1957 if (bt_link_info
->a2dp_exist
&& bt_link_info
->pan_exist
) {
1958 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1960 halbtc8723b1ant_coex_table_with_type(btcoexist
,
1962 } else if (bt_link_info
->pan_only
) {
1963 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1965 halbtc8723b1ant_coex_table_with_type(btcoexist
,
1968 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
1970 halbtc8723b1ant_coex_table_with_type(btcoexist
,
1973 } else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY
== coex_dm
->bt_status
) ||
1974 (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY
==
1975 coex_dm
->bt_status
)) {
1976 btc8723b1ant_act_bt_sco_hid_only_busy(btcoexist
,
1977 BT_8723B_1ANT_WIFI_STATUS_CONNECTED_SCAN
);
1979 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 8);
1980 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 2);
1984 static void halbtc8723b1ant_action_wifi_connected_special_packet(
1985 struct btc_coexist
*btcoexist
)
1987 bool hs_connecting
= false;
1988 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
1990 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_CONNECTING
, &hs_connecting
);
1992 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
1995 /* tdma and coex table */
1996 if ((BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
== coex_dm
->bt_status
) ||
1997 (bt_link_info
->sco_exist
) || (bt_link_info
->hid_only
) ||
1998 (bt_link_info
->a2dp_only
) || (bt_link_info
->pan_only
)) {
1999 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 8);
2000 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 7);
2002 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, true, 20);
2003 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 1);
2007 static void halbtc8723b1ant_action_wifi_connected(struct btc_coexist
*btcoexist
)
2009 bool wifi_busy
= false;
2010 bool scan
= false, link
= false, roam
= false;
2011 bool under_4way
= false, ap_enable
= false;
2013 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2014 "[BTCoex], CoexForWifiConnect()===>\n");
2016 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_4_WAY_PROGRESS
,
2019 halbtc8723b1ant_action_wifi_connected_special_packet(btcoexist
);
2020 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2021 "[BTCoex], CoexForWifiConnect(), return for wifi is under 4way<===\n");
2025 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_SCAN
, &scan
);
2026 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_LINK
, &link
);
2027 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_ROAM
, &roam
);
2029 if (scan
|| link
|| roam
) {
2031 btc8723b1ant_action_wifi_conn_scan(btcoexist
);
2033 halbtc8723b1ant_action_wifi_connected_special_packet(
2035 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2036 "[BTCoex], CoexForWifiConnect(), return for wifi is under scan<===\n");
2040 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_AP_MODE_ENABLE
,
2042 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_BUSY
, &wifi_busy
);
2043 /* power save state */
2045 BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
&&
2046 !btcoexist
->bt_link_info
.hid_only
) {
2047 if (!wifi_busy
&& btcoexist
->bt_link_info
.a2dp_only
)
2048 halbtc8723b1ant_power_save_state(btcoexist
,
2052 halbtc8723b1ant_power_save_state(btcoexist
,
2056 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
2059 /* tdma and coex table */
2061 if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
) {
2062 halbtc8723b1ant_action_wifi_connected_bt_acl_busy(btcoexist
,
2063 BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE
);
2064 } else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY
==
2065 coex_dm
->bt_status
) ||
2066 (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY
==
2067 coex_dm
->bt_status
)) {
2068 btc8723b1ant_act_bt_sco_hid_only_busy(btcoexist
,
2069 BT_8723B_1ANT_WIFI_STATUS_CONNECTED_IDLE
);
2071 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
2073 halbtc8723b1ant_coex_table_with_type(btcoexist
,
2077 if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
) {
2078 halbtc8723b1ant_action_wifi_connected_bt_acl_busy(btcoexist
,
2079 BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY
);
2080 } else if ((BT_8723B_1ANT_BT_STATUS_SCO_BUSY
==
2081 coex_dm
->bt_status
) ||
2082 (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY
==
2083 coex_dm
->bt_status
)) {
2084 btc8723b1ant_act_bt_sco_hid_only_busy(btcoexist
,
2085 BT_8723B_1ANT_WIFI_STATUS_CONNECTED_BUSY
);
2087 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
,
2089 halbtc8723b1ant_coex_table_with_type(btcoexist
,
2095 static void btc8723b1ant_run_sw_coex_mech(struct btc_coexist
*btcoexist
)
2099 algorithm
= halbtc8723b1ant_action_algorithm(btcoexist
);
2100 coex_dm
->cur_algorithm
= algorithm
;
2102 if (!halbtc8723b1ant_is_common_action(btcoexist
)) {
2103 switch (coex_dm
->cur_algorithm
) {
2104 case BT_8723B_1ANT_COEX_ALGO_SCO
:
2105 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2106 "[BTCoex], Action algorithm = SCO.\n");
2107 halbtc8723b1ant_action_sco(btcoexist
);
2109 case BT_8723B_1ANT_COEX_ALGO_HID
:
2110 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2111 "[BTCoex], Action algorithm = HID.\n");
2112 halbtc8723b1ant_action_hid(btcoexist
);
2114 case BT_8723B_1ANT_COEX_ALGO_A2DP
:
2115 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2116 "[BTCoex], Action algorithm = A2DP.\n");
2117 halbtc8723b1ant_action_a2dp(btcoexist
);
2119 case BT_8723B_1ANT_COEX_ALGO_A2DP_PANHS
:
2120 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2121 "[BTCoex], Action algorithm = A2DP+PAN(HS).\n");
2122 halbtc8723b1ant_action_a2dp_pan_hs(btcoexist
);
2124 case BT_8723B_1ANT_COEX_ALGO_PANEDR
:
2125 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2126 "[BTCoex], Action algorithm = PAN(EDR).\n");
2127 halbtc8723b1ant_action_pan_edr(btcoexist
);
2129 case BT_8723B_1ANT_COEX_ALGO_PANHS
:
2130 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2131 "[BTCoex], Action algorithm = HS mode.\n");
2132 halbtc8723b1ant_action_pan_hs(btcoexist
);
2134 case BT_8723B_1ANT_COEX_ALGO_PANEDR_A2DP
:
2135 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2136 "[BTCoex], Action algorithm = PAN+A2DP.\n");
2137 halbtc8723b1ant_action_pan_edr_a2dp(btcoexist
);
2139 case BT_8723B_1ANT_COEX_ALGO_PANEDR_HID
:
2140 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2141 "[BTCoex], Action algorithm = PAN(EDR)+HID.\n");
2142 halbtc8723b1ant_action_pan_edr_hid(btcoexist
);
2144 case BT_8723B_1ANT_COEX_ALGO_HID_A2DP_PANEDR
:
2145 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2146 "[BTCoex], Action algorithm = HID+A2DP+PAN.\n");
2147 btc8723b1ant_action_hid_a2dp_pan_edr(btcoexist
);
2149 case BT_8723B_1ANT_COEX_ALGO_HID_A2DP
:
2150 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2151 "[BTCoex], Action algorithm = HID+A2DP.\n");
2152 halbtc8723b1ant_action_hid_a2dp(btcoexist
);
2155 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2156 "[BTCoex], Action algorithm = coexist All Off!!\n");
2159 coex_dm
->pre_algorithm
= coex_dm
->cur_algorithm
;
2163 static void halbtc8723b1ant_run_coexist_mechanism(struct btc_coexist
*btcoexist
)
2165 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
2166 bool wifi_connected
= false, bt_hs_on
= false;
2167 bool increase_scan_dev_num
= false;
2168 bool bt_ctrl_agg_buf_size
= false;
2169 u8 agg_buf_size
= 5;
2170 u8 wifi_rssi_state
= BTC_RSSI_STATE_HIGH
;
2171 u32 wifi_link_status
= 0;
2172 u32 num_of_wifi_link
= 0;
2174 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2175 "[BTCoex], RunCoexistMechanism()===>\n");
2177 if (btcoexist
->manual_control
) {
2178 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2179 "[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n");
2183 if (btcoexist
->stop_coex_dm
) {
2184 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2185 "[BTCoex], RunCoexistMechanism(), return for Stop Coex DM <===\n");
2189 if (coex_sta
->under_ips
) {
2190 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2191 "[BTCoex], wifi is under IPS !!!\n");
2195 if ((BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
) ||
2196 (BT_8723B_1ANT_BT_STATUS_SCO_BUSY
== coex_dm
->bt_status
) ||
2197 (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY
== coex_dm
->bt_status
)) {
2198 increase_scan_dev_num
= true;
2201 btcoexist
->btc_set(btcoexist
, BTC_SET_BL_INC_SCAN_DEV_NUM
,
2202 &increase_scan_dev_num
);
2204 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
2207 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_LINK_STATUS
,
2209 num_of_wifi_link
= wifi_link_status
>> 16;
2210 if (num_of_wifi_link
>= 2) {
2211 halbtc8723b1ant_limited_tx(btcoexist
, NORMAL_EXEC
, 0, 0, 0, 0);
2212 halbtc8723b1ant_limited_rx(btcoexist
, NORMAL_EXEC
, false,
2213 bt_ctrl_agg_buf_size
,
2215 halbtc8723b1ant_action_wifi_multiport(btcoexist
);
2219 if (!bt_link_info
->sco_exist
&& !bt_link_info
->hid_exist
) {
2220 halbtc8723b1ant_limited_tx(btcoexist
, NORMAL_EXEC
, 0, 0, 0, 0);
2222 if (wifi_connected
) {
2224 halbtc8723b1ant_wifi_rssi_state(btcoexist
,
2226 if ((wifi_rssi_state
== BTC_RSSI_STATE_HIGH
) ||
2227 (wifi_rssi_state
== BTC_RSSI_STATE_STAY_HIGH
)) {
2228 halbtc8723b1ant_limited_tx(btcoexist
,
2232 halbtc8723b1ant_limited_tx(btcoexist
,
2237 halbtc8723b1ant_limited_tx(btcoexist
, NORMAL_EXEC
,
2242 if (bt_link_info
->sco_exist
) {
2243 bt_ctrl_agg_buf_size
= true;
2245 } else if (bt_link_info
->hid_exist
) {
2246 bt_ctrl_agg_buf_size
= true;
2248 } else if (bt_link_info
->a2dp_exist
|| bt_link_info
->pan_exist
) {
2249 bt_ctrl_agg_buf_size
= true;
2252 halbtc8723b1ant_limited_rx(btcoexist
, NORMAL_EXEC
, false,
2253 bt_ctrl_agg_buf_size
, agg_buf_size
);
2255 btc8723b1ant_run_sw_coex_mech(btcoexist
);
2257 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
2259 if (coex_sta
->c2h_bt_inquiry_page
) {
2260 halbtc8723b1ant_action_bt_inquiry(btcoexist
);
2262 } else if (bt_hs_on
) {
2263 halbtc8723b1ant_action_hs(btcoexist
);
2267 if (!wifi_connected
) {
2268 bool scan
= false, link
= false, roam
= false;
2270 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2271 "[BTCoex], wifi is non connected-idle !!!\n");
2273 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_SCAN
, &scan
);
2274 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_LINK
, &link
);
2275 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_ROAM
, &roam
);
2277 if (scan
|| link
|| roam
) {
2279 btc8723b1ant_action_wifi_not_conn_scan(
2282 btc8723b1ant_act_wifi_not_conn_asso_auth(
2285 btc8723b1ant_action_wifi_not_conn(btcoexist
);
2287 } else { /* wifi LPS/Busy */
2288 halbtc8723b1ant_action_wifi_connected(btcoexist
);
2292 static void halbtc8723b1ant_init_coex_dm(struct btc_coexist
*btcoexist
)
2295 halbtc8723b1ant_sw_mechanism(btcoexist
, false);
2297 halbtc8723b1ant_ps_tdma(btcoexist
, FORCE_EXEC
, false, 8);
2298 halbtc8723b1ant_coex_table_with_type(btcoexist
, FORCE_EXEC
, 0);
2301 static void halbtc8723b1ant_init_hw_config(struct btc_coexist
*btcoexist
,
2306 u32 cnt_bt_cal_chk
= 0;
2308 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
2309 "[BTCoex], 1Ant Init HW Config!!\n");
2311 if (backup
) {/* backup rf 0x1e value */
2312 coex_dm
->backup_arfr_cnt1
=
2313 btcoexist
->btc_read_4byte(btcoexist
, 0x430);
2314 coex_dm
->backup_arfr_cnt2
=
2315 btcoexist
->btc_read_4byte(btcoexist
, 0x434);
2316 coex_dm
->backup_retry_limit
=
2317 btcoexist
->btc_read_2byte(btcoexist
, 0x42a);
2318 coex_dm
->backup_ampdu_max_time
=
2319 btcoexist
->btc_read_1byte(btcoexist
, 0x456);
2322 /* WiFi goto standby while GNT_BT 0-->1 */
2323 btcoexist
->btc_set_rf_reg(btcoexist
, BTC_RF_A
, 0x1, 0xfffff, 0x780);
2324 /* BT goto standby while GNT_BT 1-->0 */
2325 btcoexist
->btc_set_rf_reg(btcoexist
, BTC_RF_A
, 0x2, 0xfffff, 0x500);
2327 btcoexist
->btc_write_1byte(btcoexist
, 0x974, 0xff);
2328 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x944, 0x3, 0x3);
2329 btcoexist
->btc_write_1byte(btcoexist
, 0x930, 0x77);
2331 /* BT calibration check */
2332 while (cnt_bt_cal_chk
<= 20) {
2333 u32tmp
= btcoexist
->btc_read_4byte(btcoexist
, 0x49d);
2335 if (u32tmp
& BIT0
) {
2336 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
2337 "[BTCoex], ########### BT calibration(cnt=%d) ###########\n",
2341 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
2342 "[BTCoex], ********** BT NOT calibration (cnt=%d)**********\n",
2348 /* 0x790[5:0] = 0x5 */
2349 u8tmp
= btcoexist
->btc_read_1byte(btcoexist
, 0x790);
2352 btcoexist
->btc_write_1byte(btcoexist
, 0x790, u8tmp
);
2354 /* Enable counter statistics */
2355 /*0x76e[3] =1, WLAN_Act control by PTA */
2356 btcoexist
->btc_write_1byte(btcoexist
, 0x76e, 0xc);
2357 btcoexist
->btc_write_1byte(btcoexist
, 0x778, 0x1);
2358 btcoexist
->btc_write_1byte_bitmask(btcoexist
, 0x40, 0x20, 0x1);
2361 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_PTA
, true, false);
2363 halbtc8723b1ant_coex_table_with_type(btcoexist
, FORCE_EXEC
, 0);
2366 static void halbtc8723b1ant_wifi_off_hw_cfg(struct btc_coexist
*btcoexist
)
2368 /* set wlan_act to low */
2369 btcoexist
->btc_write_1byte(btcoexist
, 0x76e, 0x4);
2372 /**************************************************************
2373 * work around function start with wa_halbtc8723b1ant_
2374 **************************************************************/
2375 /**************************************************************
2376 * extern function start with EXhalbtc8723b1ant_
2377 **************************************************************/
2379 void ex_halbtc8723b1ant_init_hwconfig(struct btc_coexist
*btcoexist
)
2381 halbtc8723b1ant_init_hw_config(btcoexist
, true);
2384 void ex_halbtc8723b1ant_init_coex_dm(struct btc_coexist
*btcoexist
)
2386 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
2387 "[BTCoex], Coex Mechanism Init!!\n");
2389 btcoexist
->stop_coex_dm
= false;
2391 halbtc8723b1ant_init_coex_dm(btcoexist
);
2393 halbtc8723b1ant_query_bt_info(btcoexist
);
2396 void ex_halbtc8723b1ant_display_coex_info(struct btc_coexist
*btcoexist
)
2398 struct btc_board_info
*board_info
= &btcoexist
->board_info
;
2399 struct btc_stack_info
*stack_info
= &btcoexist
->stack_info
;
2400 struct btc_bt_link_info
*bt_link_info
= &btcoexist
->bt_link_info
;
2401 struct rtl_priv
*rtlpriv
= btcoexist
->adapter
;
2402 u8 u8tmp
[4], i
, bt_info_ext
, pstdmacase
= 0;
2405 bool roam
= false, scan
= false;
2406 bool link
= false, wifi_under_5g
= false;
2407 bool bt_hs_on
= false, wifi_busy
= false;
2408 s32 wifi_rssi
= 0, bt_hs_rssi
= 0;
2409 u32 wifi_bw
, wifi_traffic_dir
, fa_ofdm
, fa_cck
, wifi_link_status
;
2410 u8 wifi_dot11_chnl
, wifi_hs_chnl
;
2411 u32 fw_ver
= 0, bt_patch_ver
= 0;
2413 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2414 "\r\n ============[BT Coexist info]============");
2416 if (btcoexist
->manual_control
) {
2417 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2418 "\r\n ============[Under Manual Control]==========");
2419 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2420 "\r\n ==========================================");
2422 if (btcoexist
->stop_coex_dm
) {
2423 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2424 "\r\n ============[Coex is STOPPED]============");
2425 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2426 "\r\n ==========================================");
2429 if (!board_info
->bt_exist
) {
2430 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n BT not exists !!!");
2434 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/ %d/ %d",
2435 "Ant PG Num/ Ant Mech/ Ant Pos:",
2436 board_info
->pg_ant_num
, board_info
->btdm_ant_num
,
2437 board_info
->btdm_ant_pos
);
2439 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %s / %d",
2440 "BT stack/ hci ext ver",
2441 ((stack_info
->profile_notified
) ? "Yes" : "No"),
2442 stack_info
->hci_version
);
2444 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_BT_PATCH_VER
, &bt_patch_ver
);
2445 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_FW_VER
, &fw_ver
);
2446 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2447 "\r\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)",
2448 "CoexVer/ FwVer/ PatchVer",
2449 glcoex_ver_date_8723b_1ant
, glcoex_ver_8723b_1ant
,
2450 fw_ver
, bt_patch_ver
, bt_patch_ver
);
2452 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
2453 btcoexist
->btc_get(btcoexist
, BTC_GET_U1_WIFI_DOT11_CHNL
,
2455 btcoexist
->btc_get(btcoexist
, BTC_GET_U1_WIFI_HS_CHNL
, &wifi_hs_chnl
);
2456 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d / %d(%d)",
2457 "Dot11 channel / HsChnl(HsMode)",
2458 wifi_dot11_chnl
, wifi_hs_chnl
, bt_hs_on
);
2460 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %3ph ",
2461 "H2C Wifi inform bt chnl Info",
2462 coex_dm
->wifi_chnl_info
);
2464 btcoexist
->btc_get(btcoexist
, BTC_GET_S4_WIFI_RSSI
, &wifi_rssi
);
2465 btcoexist
->btc_get(btcoexist
, BTC_GET_S4_HS_RSSI
, &bt_hs_rssi
);
2466 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/ %d",
2467 "Wifi rssi/ HS rssi", wifi_rssi
, bt_hs_rssi
);
2469 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_SCAN
, &scan
);
2470 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_LINK
, &link
);
2471 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_ROAM
, &roam
);
2472 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/ %d/ %d ",
2473 "Wifi link/ roam/ scan", link
, roam
, scan
);
2475 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_UNDER_5G
,
2477 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_BW
, &wifi_bw
);
2478 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_BUSY
, &wifi_busy
);
2479 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION
,
2482 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %s / %s/ %s ",
2483 "Wifi status", (wifi_under_5g
? "5G" : "2.4G"),
2484 ((BTC_WIFI_BW_LEGACY
== wifi_bw
) ? "Legacy" :
2485 (((BTC_WIFI_BW_HT40
== wifi_bw
) ? "HT40" : "HT20"))),
2486 ((!wifi_busy
) ? "idle" :
2487 ((BTC_WIFI_TRAFFIC_TX
== wifi_traffic_dir
) ?
2488 "uplink" : "downlink")));
2490 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_LINK_STATUS
,
2492 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/ %d/ %d/ %d/ %d",
2493 "sta/vwifi/hs/p2pGo/p2pGc",
2494 ((wifi_link_status
& WIFI_STA_CONNECTED
) ? 1 : 0),
2495 ((wifi_link_status
& WIFI_AP_CONNECTED
) ? 1 : 0),
2496 ((wifi_link_status
& WIFI_HS_CONNECTED
) ? 1 : 0),
2497 ((wifi_link_status
& WIFI_P2P_GO_CONNECTED
) ? 1 : 0),
2498 ((wifi_link_status
& WIFI_P2P_GC_CONNECTED
) ? 1 : 0));
2500 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = [%s/ %d/ %d] ",
2501 "BT [status/ rssi/ retryCnt]",
2502 ((btcoexist
->bt_info
.bt_disabled
) ? ("disabled") :
2503 ((coex_sta
->c2h_bt_inquiry_page
) ? ("inquiry/page scan") :
2504 ((BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE
==
2505 coex_dm
->bt_status
) ?
2506 "non-connected idle" :
2507 ((BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
==
2508 coex_dm
->bt_status
) ?
2509 "connected-idle" : "busy")))),
2510 coex_sta
->bt_rssi
, coex_sta
->bt_retry_cnt
);
2512 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2513 "\r\n %-35s = %d / %d / %d / %d",
2514 "SCO/HID/PAN/A2DP", bt_link_info
->sco_exist
,
2515 bt_link_info
->hid_exist
, bt_link_info
->pan_exist
,
2516 bt_link_info
->a2dp_exist
);
2517 btcoexist
->btc_disp_dbg_msg(btcoexist
, BTC_DBG_DISP_BT_LINK_INFO
);
2519 bt_info_ext
= coex_sta
->bt_info_ext
;
2520 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %s",
2521 "BT Info A2DP rate",
2522 (bt_info_ext
& BIT0
) ? "Basic rate" : "EDR rate");
2524 for (i
= 0; i
< BT_INFO_SRC_8723B_1ANT_MAX
; i
++) {
2525 if (coex_sta
->bt_info_c2h_cnt
[i
]) {
2526 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2527 "\r\n %-35s = %7ph(%d)",
2528 GLBtInfoSrc8723b1Ant
[i
],
2529 coex_sta
->bt_info_c2h
[i
],
2530 coex_sta
->bt_info_c2h_cnt
[i
]);
2533 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2534 "\r\n %-35s = %s/%s, (0x%x/0x%x)",
2535 "PS state, IPS/LPS, (lps/rpwm)",
2536 ((coex_sta
->under_ips
? "IPS ON" : "IPS OFF")),
2537 ((coex_sta
->under_lps
? "LPS ON" : "LPS OFF")),
2538 btcoexist
->bt_info
.lps_val
,
2539 btcoexist
->bt_info
.rpwm_val
);
2540 btcoexist
->btc_disp_dbg_msg(btcoexist
, BTC_DBG_DISP_FW_PWR_MODE_CMD
);
2542 if (!btcoexist
->manual_control
) {
2544 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s",
2545 "============[Sw mechanism]============");
2547 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/",
2548 "SM[LowPenaltyRA]", coex_dm
->cur_low_penalty_ra
);
2550 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %s/ %s/ %d ",
2551 "DelBA/ BtCtrlAgg/ AggSize",
2552 (btcoexist
->bt_info
.reject_agg_pkt
? "Yes" : "No"),
2553 (btcoexist
->bt_info
.bt_ctrl_buf_size
? "Yes" : "No"),
2554 btcoexist
->bt_info
.agg_buf_size
);
2556 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x ",
2557 "Rate Mask", btcoexist
->bt_info
.ra_mask
);
2560 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s",
2561 "============[Fw mechanism]============");
2563 pstdmacase
= coex_dm
->cur_ps_tdma
;
2564 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2565 "\r\n %-35s = %5ph case-%d (auto:%d)",
2566 "PS TDMA", coex_dm
->ps_tdma_para
,
2567 pstdmacase
, coex_dm
->auto_tdma_adjust
);
2569 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d ",
2570 "IgnWlanAct", coex_dm
->cur_ignore_wlan_act
);
2572 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x ",
2573 "Latest error condition(should be 0)",
2574 coex_dm
->error_condition
);
2578 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s",
2579 "============[Hw setting]============");
2581 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
2582 "backup ARFR1/ARFR2/RL/AMaxTime", coex_dm
->backup_arfr_cnt1
,
2583 coex_dm
->backup_arfr_cnt2
, coex_dm
->backup_retry_limit
,
2584 coex_dm
->backup_ampdu_max_time
);
2586 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x430);
2587 u32tmp
[1] = btcoexist
->btc_read_4byte(btcoexist
, 0x434);
2588 u16tmp
[0] = btcoexist
->btc_read_2byte(btcoexist
, 0x42a);
2589 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0x456);
2590 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/0x%x/0x%x/0x%x",
2591 "0x430/0x434/0x42a/0x456",
2592 u32tmp
[0], u32tmp
[1], u16tmp
[0], u8tmp
[0]);
2594 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0x778);
2595 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x6cc);
2596 u32tmp
[1] = btcoexist
->btc_read_4byte(btcoexist
, 0x880);
2597 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
2598 "0x778/0x6cc/0x880[29:25]", u8tmp
[0], u32tmp
[0],
2599 (u32tmp
[1] & 0x3e000000) >> 25);
2601 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x948);
2602 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0x67);
2603 u8tmp
[1] = btcoexist
->btc_read_1byte(btcoexist
, 0x765);
2604 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
2605 "0x948/ 0x67[5] / 0x765",
2606 u32tmp
[0], ((u8tmp
[0] & 0x20) >> 5), u8tmp
[1]);
2608 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x92c);
2609 u32tmp
[1] = btcoexist
->btc_read_4byte(btcoexist
, 0x930);
2610 u32tmp
[2] = btcoexist
->btc_read_4byte(btcoexist
, 0x944);
2611 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
2612 "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]",
2613 u32tmp
[0] & 0x3, u32tmp
[1] & 0xff, u32tmp
[2] & 0x3);
2615 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0x39);
2616 u8tmp
[1] = btcoexist
->btc_read_1byte(btcoexist
, 0x40);
2617 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x4c);
2618 u8tmp
[2] = btcoexist
->btc_read_1byte(btcoexist
, 0x64);
2619 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
,
2620 "\r\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x",
2621 "0x38[11]/0x40/0x4c[24:23]/0x64[0]",
2622 ((u8tmp
[0] & 0x8)>>3), u8tmp
[1],
2623 ((u32tmp
[0] & 0x01800000) >> 23), u8tmp
[2] & 0x1);
2625 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x550);
2626 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0x522);
2627 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x",
2628 "0x550(bcn ctrl)/0x522", u32tmp
[0], u8tmp
[0]);
2630 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0xc50);
2631 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0x49c);
2632 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x",
2633 "0xc50(dig)/0x49c(null-drop)", u32tmp
[0] & 0xff, u8tmp
[0]);
2635 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0xda0);
2636 u32tmp
[1] = btcoexist
->btc_read_4byte(btcoexist
, 0xda4);
2637 u32tmp
[2] = btcoexist
->btc_read_4byte(btcoexist
, 0xda8);
2638 u32tmp
[3] = btcoexist
->btc_read_4byte(btcoexist
, 0xcf0);
2640 u8tmp
[0] = btcoexist
->btc_read_1byte(btcoexist
, 0xa5b);
2641 u8tmp
[1] = btcoexist
->btc_read_1byte(btcoexist
, 0xa5c);
2643 fa_ofdm
= ((u32tmp
[0] & 0xffff0000) >> 16) +
2644 ((u32tmp
[1] & 0xffff0000) >> 16) +
2645 (u32tmp
[1] & 0xffff) +
2646 (u32tmp
[2] & 0xffff) +
2647 ((u32tmp
[3] & 0xffff0000) >> 16) +
2648 (u32tmp
[3] & 0xffff);
2649 fa_cck
= (u8tmp
[0] << 8) + u8tmp
[1];
2651 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
2652 "OFDM-CCA/OFDM-FA/CCK-FA",
2653 u32tmp
[0] & 0xffff, fa_ofdm
, fa_cck
);
2655 u32tmp
[0] = btcoexist
->btc_read_4byte(btcoexist
, 0x6c0);
2656 u32tmp
[1] = btcoexist
->btc_read_4byte(btcoexist
, 0x6c4);
2657 u32tmp
[2] = btcoexist
->btc_read_4byte(btcoexist
, 0x6c8);
2658 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = 0x%x/ 0x%x/ 0x%x",
2659 "0x6c0/0x6c4/0x6c8(coexTable)",
2660 u32tmp
[0], u32tmp
[1], u32tmp
[2]);
2662 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/ %d",
2663 "0x770(high-pri rx/tx)", coex_sta
->high_priority_rx
,
2664 coex_sta
->high_priority_tx
);
2665 RT_TRACE(rtlpriv
, COMP_INIT
, DBG_DMESG
, "\r\n %-35s = %d/ %d",
2666 "0x774(low-pri rx/tx)", coex_sta
->low_priority_rx
,
2667 coex_sta
->low_priority_tx
);
2668 #if (BT_AUTO_REPORT_ONLY_8723B_1ANT == 1)
2669 halbtc8723b1ant_monitor_bt_ctr(btcoexist
);
2671 btcoexist
->btc_disp_dbg_msg(btcoexist
, BTC_DBG_DISP_COEX_STATISTICS
);
2674 void ex_halbtc8723b1ant_ips_notify(struct btc_coexist
*btcoexist
, u8 type
)
2676 if (btcoexist
->manual_control
|| btcoexist
->stop_coex_dm
)
2679 if (BTC_IPS_ENTER
== type
) {
2680 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2681 "[BTCoex], IPS ENTER notify\n");
2682 coex_sta
->under_ips
= true;
2684 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_BT
,
2686 /* set PTA control */
2687 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 0);
2688 halbtc8723b1ant_coex_table_with_type(btcoexist
,
2690 halbtc8723b1ant_wifi_off_hw_cfg(btcoexist
);
2691 } else if (BTC_IPS_LEAVE
== type
) {
2692 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2693 "[BTCoex], IPS LEAVE notify\n");
2694 coex_sta
->under_ips
= false;
2696 halbtc8723b1ant_init_hw_config(btcoexist
, false);
2697 halbtc8723b1ant_init_coex_dm(btcoexist
);
2698 halbtc8723b1ant_query_bt_info(btcoexist
);
2702 void ex_halbtc8723b1ant_lps_notify(struct btc_coexist
*btcoexist
, u8 type
)
2704 if (btcoexist
->manual_control
|| btcoexist
->stop_coex_dm
)
2707 if (BTC_LPS_ENABLE
== type
) {
2708 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2709 "[BTCoex], LPS ENABLE notify\n");
2710 coex_sta
->under_lps
= true;
2711 } else if (BTC_LPS_DISABLE
== type
) {
2712 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2713 "[BTCoex], LPS DISABLE notify\n");
2714 coex_sta
->under_lps
= false;
2718 void ex_halbtc8723b1ant_scan_notify(struct btc_coexist
*btcoexist
, u8 type
)
2720 bool wifi_connected
= false, bt_hs_on
= false;
2721 u32 wifi_link_status
= 0;
2722 u32 num_of_wifi_link
= 0;
2723 bool bt_ctrl_agg_buf_size
= false;
2724 u8 agg_buf_size
= 5;
2726 if (btcoexist
->manual_control
|| btcoexist
->stop_coex_dm
||
2727 btcoexist
->bt_info
.bt_disabled
)
2730 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
2731 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
2734 halbtc8723b1ant_query_bt_info(btcoexist
);
2736 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_LINK_STATUS
,
2738 num_of_wifi_link
= wifi_link_status
>> 16;
2739 if (num_of_wifi_link
>= 2) {
2740 halbtc8723b1ant_limited_tx(btcoexist
, NORMAL_EXEC
, 0, 0, 0, 0);
2741 halbtc8723b1ant_limited_rx(btcoexist
, NORMAL_EXEC
, false,
2742 bt_ctrl_agg_buf_size
, agg_buf_size
);
2743 halbtc8723b1ant_action_wifi_multiport(btcoexist
);
2747 if (coex_sta
->c2h_bt_inquiry_page
) {
2748 halbtc8723b1ant_action_bt_inquiry(btcoexist
);
2750 } else if (bt_hs_on
) {
2751 halbtc8723b1ant_action_hs(btcoexist
);
2755 if (BTC_SCAN_START
== type
) {
2756 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2757 "[BTCoex], SCAN START notify\n");
2758 if (!wifi_connected
) /* non-connected scan */
2759 btc8723b1ant_action_wifi_not_conn_scan(btcoexist
);
2760 else /* wifi is connected */
2761 btc8723b1ant_action_wifi_conn_scan(btcoexist
);
2762 } else if (BTC_SCAN_FINISH
== type
) {
2763 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2764 "[BTCoex], SCAN FINISH notify\n");
2765 if (!wifi_connected
) /* non-connected scan */
2766 btc8723b1ant_action_wifi_not_conn(btcoexist
);
2768 halbtc8723b1ant_action_wifi_connected(btcoexist
);
2772 void ex_halbtc8723b1ant_connect_notify(struct btc_coexist
*btcoexist
, u8 type
)
2774 bool wifi_connected
= false, bt_hs_on
= false;
2775 u32 wifi_link_status
= 0;
2776 u32 num_of_wifi_link
= 0;
2777 bool bt_ctrl_agg_buf_size
= false;
2778 u8 agg_buf_size
= 5;
2780 if (btcoexist
->manual_control
|| btcoexist
->stop_coex_dm
||
2781 btcoexist
->bt_info
.bt_disabled
)
2784 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_LINK_STATUS
,
2786 num_of_wifi_link
= wifi_link_status
>>16;
2787 if (num_of_wifi_link
>= 2) {
2788 halbtc8723b1ant_limited_tx(btcoexist
, NORMAL_EXEC
, 0, 0, 0, 0);
2789 halbtc8723b1ant_limited_rx(btcoexist
, NORMAL_EXEC
, false,
2790 bt_ctrl_agg_buf_size
, agg_buf_size
);
2791 halbtc8723b1ant_action_wifi_multiport(btcoexist
);
2795 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
2796 if (coex_sta
->c2h_bt_inquiry_page
) {
2797 halbtc8723b1ant_action_bt_inquiry(btcoexist
);
2799 } else if (bt_hs_on
) {
2800 halbtc8723b1ant_action_hs(btcoexist
);
2804 if (BTC_ASSOCIATE_START
== type
) {
2805 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2806 "[BTCoex], CONNECT START notify\n");
2807 btc8723b1ant_act_wifi_not_conn_asso_auth(btcoexist
);
2808 } else if (BTC_ASSOCIATE_FINISH
== type
) {
2809 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2810 "[BTCoex], CONNECT FINISH notify\n");
2812 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
2814 if (!wifi_connected
) /* non-connected scan */
2815 btc8723b1ant_action_wifi_not_conn(btcoexist
);
2817 halbtc8723b1ant_action_wifi_connected(btcoexist
);
2821 void ex_halbtc8723b1ant_media_status_notify(struct btc_coexist
*btcoexist
,
2824 u8 h2c_parameter
[3] = {0};
2828 if (btcoexist
->manual_control
|| btcoexist
->stop_coex_dm
||
2829 btcoexist
->bt_info
.bt_disabled
)
2832 if (BTC_MEDIA_CONNECT
== type
)
2833 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2834 "[BTCoex], MEDIA connect notify\n");
2836 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2837 "[BTCoex], MEDIA disconnect notify\n");
2839 /* only 2.4G we need to inform bt the chnl mask */
2840 btcoexist
->btc_get(btcoexist
, BTC_GET_U1_WIFI_CENTRAL_CHNL
,
2843 if ((BTC_MEDIA_CONNECT
== type
) &&
2844 (wifiCentralChnl
<= 14)) {
2845 h2c_parameter
[0] = 0x0;
2846 h2c_parameter
[1] = wifiCentralChnl
;
2847 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_BW
, &wifi_bw
);
2848 if (BTC_WIFI_BW_HT40
== wifi_bw
)
2849 h2c_parameter
[2] = 0x30;
2851 h2c_parameter
[2] = 0x20;
2854 coex_dm
->wifi_chnl_info
[0] = h2c_parameter
[0];
2855 coex_dm
->wifi_chnl_info
[1] = h2c_parameter
[1];
2856 coex_dm
->wifi_chnl_info
[2] = h2c_parameter
[2];
2858 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE_FW_EXEC
,
2859 "[BTCoex], FW write 0x66 = 0x%x\n",
2860 h2c_parameter
[0] << 16 | h2c_parameter
[1] << 8 |
2863 btcoexist
->btc_fill_h2c(btcoexist
, 0x66, 3, h2c_parameter
);
2866 void ex_halbtc8723b1ant_special_packet_notify(struct btc_coexist
*btcoexist
,
2869 bool bt_hs_on
= false;
2870 u32 wifi_link_status
= 0;
2871 u32 num_of_wifi_link
= 0;
2872 bool bt_ctrl_agg_buf_size
= false;
2873 u8 agg_buf_size
= 5;
2875 if (btcoexist
->manual_control
|| btcoexist
->stop_coex_dm
||
2876 btcoexist
->bt_info
.bt_disabled
)
2879 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_LINK_STATUS
,
2881 num_of_wifi_link
= wifi_link_status
>> 16;
2882 if (num_of_wifi_link
>= 2) {
2883 halbtc8723b1ant_limited_tx(btcoexist
, NORMAL_EXEC
, 0, 0, 0, 0);
2884 halbtc8723b1ant_limited_rx(btcoexist
, NORMAL_EXEC
, false,
2885 bt_ctrl_agg_buf_size
, agg_buf_size
);
2886 halbtc8723b1ant_action_wifi_multiport(btcoexist
);
2890 coex_sta
->special_pkt_period_cnt
= 0;
2892 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_HS_OPERATION
, &bt_hs_on
);
2893 if (coex_sta
->c2h_bt_inquiry_page
) {
2894 halbtc8723b1ant_action_bt_inquiry(btcoexist
);
2896 } else if (bt_hs_on
) {
2897 halbtc8723b1ant_action_hs(btcoexist
);
2901 if (BTC_PACKET_DHCP
== type
||
2902 BTC_PACKET_EAPOL
== type
) {
2903 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2904 "[BTCoex], special Packet(%d) notify\n", type
);
2905 halbtc8723b1ant_action_wifi_connected_special_packet(btcoexist
);
2909 void ex_halbtc8723b1ant_bt_info_notify(struct btc_coexist
*btcoexist
,
2910 u8
*tmp_buf
, u8 length
)
2913 u8 i
, rsp_source
= 0;
2914 bool wifi_connected
= false;
2915 bool bt_busy
= false;
2917 coex_sta
->c2h_bt_info_req_sent
= false;
2919 rsp_source
= tmp_buf
[0] & 0xf;
2920 if (rsp_source
>= BT_INFO_SRC_8723B_1ANT_MAX
)
2921 rsp_source
= BT_INFO_SRC_8723B_1ANT_WIFI_FW
;
2922 coex_sta
->bt_info_c2h_cnt
[rsp_source
]++;
2924 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2925 "[BTCoex], Bt info[%d], length=%d, hex data = [",
2926 rsp_source
, length
);
2927 for (i
= 0; i
< length
; i
++) {
2928 coex_sta
->bt_info_c2h
[rsp_source
][i
] = tmp_buf
[i
];
2930 bt_info
= tmp_buf
[i
];
2931 if (i
== length
- 1)
2932 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2933 "0x%02x]\n", tmp_buf
[i
]);
2935 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
2936 "0x%02x, ", tmp_buf
[i
]);
2939 if (BT_INFO_SRC_8723B_1ANT_WIFI_FW
!= rsp_source
) {
2940 coex_sta
->bt_retry_cnt
= /* [3:0] */
2941 coex_sta
->bt_info_c2h
[rsp_source
][2] & 0xf;
2944 coex_sta
->bt_info_c2h
[rsp_source
][3] * 2 + 10;
2946 coex_sta
->bt_info_ext
=
2947 coex_sta
->bt_info_c2h
[rsp_source
][4];
2949 /* Here we need to resend some wifi info to BT
2950 * because bt is reset and loss of the info.
2952 if (coex_sta
->bt_info_ext
& BIT1
) {
2953 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2954 "[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n");
2955 btcoexist
->btc_get(btcoexist
, BTC_GET_BL_WIFI_CONNECTED
,
2958 ex_halbtc8723b1ant_media_status_notify(btcoexist
,
2961 ex_halbtc8723b1ant_media_status_notify(btcoexist
,
2962 BTC_MEDIA_DISCONNECT
);
2965 if (coex_sta
->bt_info_ext
& BIT3
) {
2966 if (!btcoexist
->manual_control
&&
2967 !btcoexist
->stop_coex_dm
) {
2968 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
2969 "[BTCoex], BT ext info bit3 check, set BT NOT ignore Wlan active!!\n");
2970 halbtc8723b1ant_ignore_wlan_act(btcoexist
,
2975 /* BT already NOT ignore Wlan active, do nothing here.*/
2977 #if (BT_AUTO_REPORT_ONLY_8723B_1ANT == 0)
2978 if (coex_sta
->bt_info_ext
& BIT4
) {
2979 /* BT auto report already enabled, do nothing */
2981 halbtc8723b1ant_bt_auto_report(btcoexist
, FORCE_EXEC
,
2987 /* check BIT2 first ==> check if bt is under inquiry or page scan */
2988 if (bt_info
& BT_INFO_8723B_1ANT_B_INQ_PAGE
)
2989 coex_sta
->c2h_bt_inquiry_page
= true;
2991 coex_sta
->c2h_bt_inquiry_page
= false;
2993 /* set link exist status */
2994 if (!(bt_info
& BT_INFO_8723B_1ANT_B_CONNECTION
)) {
2995 coex_sta
->bt_link_exist
= false;
2996 coex_sta
->pan_exist
= false;
2997 coex_sta
->a2dp_exist
= false;
2998 coex_sta
->hid_exist
= false;
2999 coex_sta
->sco_exist
= false;
3000 } else { /* connection exists */
3001 coex_sta
->bt_link_exist
= true;
3002 if (bt_info
& BT_INFO_8723B_1ANT_B_FTP
)
3003 coex_sta
->pan_exist
= true;
3005 coex_sta
->pan_exist
= false;
3006 if (bt_info
& BT_INFO_8723B_1ANT_B_A2DP
)
3007 coex_sta
->a2dp_exist
= true;
3009 coex_sta
->a2dp_exist
= false;
3010 if (bt_info
& BT_INFO_8723B_1ANT_B_HID
)
3011 coex_sta
->hid_exist
= true;
3013 coex_sta
->hid_exist
= false;
3014 if (bt_info
& BT_INFO_8723B_1ANT_B_SCO_ESCO
)
3015 coex_sta
->sco_exist
= true;
3017 coex_sta
->sco_exist
= false;
3020 halbtc8723b1ant_update_bt_link_info(btcoexist
);
3022 if (!(bt_info
&BT_INFO_8723B_1ANT_B_CONNECTION
)) {
3023 coex_dm
->bt_status
= BT_8723B_1ANT_BT_STATUS_NON_CONNECTED_IDLE
;
3024 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3025 "[BTCoex], BtInfoNotify(), BT Non-Connected idle!\n");
3026 /* connection exists but no busy */
3027 } else if (bt_info
== BT_INFO_8723B_1ANT_B_CONNECTION
) {
3028 coex_dm
->bt_status
= BT_8723B_1ANT_BT_STATUS_CONNECTED_IDLE
;
3029 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3030 "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n");
3031 } else if ((bt_info
& BT_INFO_8723B_1ANT_B_SCO_ESCO
) ||
3032 (bt_info
& BT_INFO_8723B_1ANT_B_SCO_BUSY
)) {
3033 coex_dm
->bt_status
= BT_8723B_1ANT_BT_STATUS_SCO_BUSY
;
3034 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3035 "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n");
3036 } else if (bt_info
& BT_INFO_8723B_1ANT_B_ACL_BUSY
) {
3037 if (BT_8723B_1ANT_BT_STATUS_ACL_BUSY
!= coex_dm
->bt_status
)
3038 coex_dm
->auto_tdma_adjust
= false;
3040 coex_dm
->bt_status
= BT_8723B_1ANT_BT_STATUS_ACL_BUSY
;
3041 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3042 "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n");
3044 coex_dm
->bt_status
=
3045 BT_8723B_1ANT_BT_STATUS_MAX
;
3046 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3047 "[BTCoex], BtInfoNotify(), BT Non-Defined state!!\n");
3050 if ((BT_8723B_1ANT_BT_STATUS_ACL_BUSY
== coex_dm
->bt_status
) ||
3051 (BT_8723B_1ANT_BT_STATUS_SCO_BUSY
== coex_dm
->bt_status
) ||
3052 (BT_8723B_1ANT_BT_STATUS_ACL_SCO_BUSY
== coex_dm
->bt_status
))
3056 btcoexist
->btc_set(btcoexist
, BTC_SET_BL_BT_TRAFFIC_BUSY
, &bt_busy
);
3058 halbtc8723b1ant_run_coexist_mechanism(btcoexist
);
3061 void ex_halbtc8723b1ant_halt_notify(struct btc_coexist
*btcoexist
)
3063 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
, "[BTCoex], Halt notify\n");
3065 btcoexist
->stop_coex_dm
= true;
3067 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_BT
, false, true);
3069 halbtc8723b1ant_wifi_off_hw_cfg(btcoexist
);
3070 halbtc8723b1ant_ignore_wlan_act(btcoexist
, FORCE_EXEC
, true);
3072 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
3074 halbtc8723b1ant_ps_tdma(btcoexist
, FORCE_EXEC
, false, 0);
3076 ex_halbtc8723b1ant_media_status_notify(btcoexist
, BTC_MEDIA_DISCONNECT
);
3079 void ex_halbtc8723b1ant_pnp_notify(struct btc_coexist
*btcoexist
, u8 pnp_state
)
3081 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
, "[BTCoex], Pnp notify\n");
3083 if (BTC_WIFI_PNP_SLEEP
== pnp_state
) {
3084 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
3085 "[BTCoex], Pnp notify to SLEEP\n");
3086 btcoexist
->stop_coex_dm
= true;
3087 halbtc8723b1ant_SetAntPath(btcoexist
, BTC_ANT_PATH_BT
, false,
3089 halbtc8723b1ant_power_save_state(btcoexist
, BTC_PS_WIFI_NATIVE
,
3091 halbtc8723b1ant_ps_tdma(btcoexist
, NORMAL_EXEC
, false, 0);
3092 halbtc8723b1ant_coex_table_with_type(btcoexist
, NORMAL_EXEC
, 2);
3093 halbtc8723b1ant_wifi_off_hw_cfg(btcoexist
);
3094 } else if (BTC_WIFI_PNP_WAKE_UP
== pnp_state
) {
3095 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_NOTIFY
,
3096 "[BTCoex], Pnp notify to WAKE UP\n");
3097 btcoexist
->stop_coex_dm
= false;
3098 halbtc8723b1ant_init_hw_config(btcoexist
, false);
3099 halbtc8723b1ant_init_coex_dm(btcoexist
);
3100 halbtc8723b1ant_query_bt_info(btcoexist
);
3104 void ex_halbtc8723b1ant_coex_dm_reset(struct btc_coexist
*btcoexist
)
3106 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3107 "[BTCoex], *****************Coex DM Reset****************\n");
3109 halbtc8723b1ant_init_hw_config(btcoexist
, false);
3110 btcoexist
->btc_set_rf_reg(btcoexist
, BTC_RF_A
, 0x1, 0xfffff, 0x0);
3111 btcoexist
->btc_set_rf_reg(btcoexist
, BTC_RF_A
, 0x2, 0xfffff, 0x0);
3112 halbtc8723b1ant_init_coex_dm(btcoexist
);
3115 void ex_halbtc8723b1ant_periodical(struct btc_coexist
*btcoexist
)
3117 struct btc_board_info
*board_info
= &btcoexist
->board_info
;
3118 struct btc_stack_info
*stack_info
= &btcoexist
->stack_info
;
3119 static u8 dis_ver_info_cnt
;
3120 u32 fw_ver
= 0, bt_patch_ver
= 0;
3122 BTC_PRINT(BTC_MSG_ALGORITHM
, ALGO_TRACE
,
3123 "[BTCoex], ==========================Periodical===========================\n");
3125 if (dis_ver_info_cnt
<= 5) {
3126 dis_ver_info_cnt
+= 1;
3127 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
3128 "[BTCoex], ****************************************************************\n");
3129 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
3130 "[BTCoex], Ant PG Num/ Ant Mech/ Ant Pos = %d/ %d/ %d\n",
3131 board_info
->pg_ant_num
, board_info
->btdm_ant_num
,
3132 board_info
->btdm_ant_pos
);
3133 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
3134 "[BTCoex], BT stack/ hci ext ver = %s / %d\n",
3135 ((stack_info
->profile_notified
) ? "Yes" : "No"),
3136 stack_info
->hci_version
);
3137 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_BT_PATCH_VER
,
3139 btcoexist
->btc_get(btcoexist
, BTC_GET_U4_WIFI_FW_VER
, &fw_ver
);
3140 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
3141 "[BTCoex], CoexVer/ FwVer/ PatchVer = %d_%x/ 0x%x/ 0x%x(%d)\n",
3142 glcoex_ver_date_8723b_1ant
,
3143 glcoex_ver_8723b_1ant
, fw_ver
,
3144 bt_patch_ver
, bt_patch_ver
);
3145 BTC_PRINT(BTC_MSG_INTERFACE
, INTF_INIT
,
3146 "[BTCoex], ****************************************************************\n");
3149 #if (BT_AUTO_REPORT_ONLY_8723B_1ANT == 0)
3150 halbtc8723b1ant_query_bt_info(btcoexist
);
3151 halbtc8723b1ant_monitor_bt_ctr(btcoexist
);
3152 halbtc8723b1ant_monitor_bt_enable_disable(btcoexist
);
3154 if (btc8723b1ant_is_wifi_status_changed(btcoexist
) ||
3155 coex_dm
->auto_tdma_adjust
) {
3156 halbtc8723b1ant_run_coexist_mechanism(btcoexist
);
3159 coex_sta
->special_pkt_period_cnt
++;