1 // SPDX-License-Identifier: GPL-2.0 2 /* Copyright(c) 2012 Realtek Corporation.*/ 3 4 /*************************************************************** 5 * Description: 6 * 7 * This file is for RTL8723B Co-exist mechanism 8 * 9 * History 10 * 2012/11/15 Cosa first check in. 11 * 12 **************************************************************/ 13 /************************************************************** 14 * include files 15 **************************************************************/ 16 #include "halbt_precomp.h" 17 /************************************************************** 18 * Global variables, these are static variables 19 **************************************************************/ 20 static struct coex_dm_8723b_2ant glcoex_dm_8723b_2ant; 21 static struct coex_dm_8723b_2ant *coex_dm = &glcoex_dm_8723b_2ant; 22 static struct coex_sta_8723b_2ant glcoex_sta_8723b_2ant; 23 static struct coex_sta_8723b_2ant *coex_sta = &glcoex_sta_8723b_2ant; 24 25 static const char *const glbt_info_src_8723b_2ant[] = { 26 "BT Info[wifi fw]", 27 "BT Info[bt rsp]", 28 "BT Info[bt auto report]", 29 }; 30 31 static u32 glcoex_ver_date_8723b_2ant = 20131113; 32 static u32 glcoex_ver_8723b_2ant = 0x3f; 33 34 /************************************************************** 35 * local function proto type if needed 36 **************************************************************/ 37 /************************************************************** 38 * local function start with btc8723b2ant_ 39 **************************************************************/ 40 static u8 btc8723b2ant_bt_rssi_state(struct btc_coexist *btcoexist, 41 u8 level_num, u8 rssi_thresh, 42 u8 rssi_thresh1) 43 { 44 struct rtl_priv *rtlpriv = btcoexist->adapter; 45 s32 bt_rssi = 0; 46 u8 bt_rssi_state = coex_sta->pre_bt_rssi_state; 47 48 bt_rssi = coex_sta->bt_rssi; 49 50 if (level_num == 2) { 51 if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) || 52 (coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) { 53 if (bt_rssi >= rssi_thresh + 54 BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT) { 55 bt_rssi_state = BTC_RSSI_STATE_HIGH; 56 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 57 "[BTCoex], BT Rssi state switch to High\n"); 58 } else { 59 bt_rssi_state = BTC_RSSI_STATE_STAY_LOW; 60 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 61 "[BTCoex], BT Rssi state stay at Low\n"); 62 } 63 } else { 64 if (bt_rssi < rssi_thresh) { 65 bt_rssi_state = BTC_RSSI_STATE_LOW; 66 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 67 "[BTCoex], BT Rssi state switch to Low\n"); 68 } else { 69 bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH; 70 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 71 "[BTCoex], BT Rssi state stay at High\n"); 72 } 73 } 74 } else if (level_num == 3) { 75 if (rssi_thresh > rssi_thresh1) { 76 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 77 "[BTCoex], BT Rssi thresh error!!\n"); 78 return coex_sta->pre_bt_rssi_state; 79 } 80 81 if ((coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_LOW) || 82 (coex_sta->pre_bt_rssi_state == BTC_RSSI_STATE_STAY_LOW)) { 83 if (bt_rssi >= rssi_thresh + 84 BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT) { 85 bt_rssi_state = BTC_RSSI_STATE_MEDIUM; 86 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 87 "[BTCoex], BT Rssi state switch to Medium\n"); 88 } else { 89 bt_rssi_state = BTC_RSSI_STATE_STAY_LOW; 90 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 91 "[BTCoex], BT Rssi state stay at Low\n"); 92 } 93 } else if ((coex_sta->pre_bt_rssi_state == 94 BTC_RSSI_STATE_MEDIUM) || 95 (coex_sta->pre_bt_rssi_state == 96 BTC_RSSI_STATE_STAY_MEDIUM)) { 97 if (bt_rssi >= rssi_thresh1 + 98 BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT) { 99 bt_rssi_state = BTC_RSSI_STATE_HIGH; 100 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 101 "[BTCoex], BT Rssi state switch to High\n"); 102 } else if (bt_rssi < rssi_thresh) { 103 bt_rssi_state = BTC_RSSI_STATE_LOW; 104 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 105 "[BTCoex], BT Rssi state switch to Low\n"); 106 } else { 107 bt_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM; 108 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 109 "[BTCoex], BT Rssi state stay at Medium\n"); 110 } 111 } else { 112 if (bt_rssi < rssi_thresh1) { 113 bt_rssi_state = BTC_RSSI_STATE_MEDIUM; 114 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 115 "[BTCoex], BT Rssi state switch to Medium\n"); 116 } else { 117 bt_rssi_state = BTC_RSSI_STATE_STAY_HIGH; 118 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 119 "[BTCoex], BT Rssi state stay at High\n"); 120 } 121 } 122 } 123 124 coex_sta->pre_bt_rssi_state = bt_rssi_state; 125 126 return bt_rssi_state; 127 } 128 129 static u8 btc8723b2ant_wifi_rssi_state(struct btc_coexist *btcoexist, 130 u8 index, u8 level_num, 131 u8 rssi_thresh, u8 rssi_thresh1) 132 { 133 struct rtl_priv *rtlpriv = btcoexist->adapter; 134 s32 wifi_rssi = 0; 135 u8 wifi_rssi_state = coex_sta->pre_wifi_rssi_state[index]; 136 137 btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi); 138 139 if (level_num == 2) { 140 if ((coex_sta->pre_wifi_rssi_state[index] == 141 BTC_RSSI_STATE_LOW) || 142 (coex_sta->pre_wifi_rssi_state[index] == 143 BTC_RSSI_STATE_STAY_LOW)) { 144 if (wifi_rssi >= rssi_thresh + 145 BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT) { 146 wifi_rssi_state = BTC_RSSI_STATE_HIGH; 147 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 148 "[BTCoex], wifi RSSI state switch to High\n"); 149 } else { 150 wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW; 151 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 152 "[BTCoex], wifi RSSI state stay at Low\n"); 153 } 154 } else { 155 if (wifi_rssi < rssi_thresh) { 156 wifi_rssi_state = BTC_RSSI_STATE_LOW; 157 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 158 "[BTCoex], wifi RSSI state switch to Low\n"); 159 } else { 160 wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH; 161 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 162 "[BTCoex], wifi RSSI state stay at High\n"); 163 } 164 } 165 } else if (level_num == 3) { 166 if (rssi_thresh > rssi_thresh1) { 167 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 168 "[BTCoex], wifi RSSI thresh error!!\n"); 169 return coex_sta->pre_wifi_rssi_state[index]; 170 } 171 172 if ((coex_sta->pre_wifi_rssi_state[index] == 173 BTC_RSSI_STATE_LOW) || 174 (coex_sta->pre_wifi_rssi_state[index] == 175 BTC_RSSI_STATE_STAY_LOW)) { 176 if (wifi_rssi >= rssi_thresh + 177 BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT) { 178 wifi_rssi_state = BTC_RSSI_STATE_MEDIUM; 179 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 180 "[BTCoex], wifi RSSI state switch to Medium\n"); 181 } else { 182 wifi_rssi_state = BTC_RSSI_STATE_STAY_LOW; 183 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 184 "[BTCoex], wifi RSSI state stay at Low\n"); 185 } 186 } else if ((coex_sta->pre_wifi_rssi_state[index] == 187 BTC_RSSI_STATE_MEDIUM) || 188 (coex_sta->pre_wifi_rssi_state[index] == 189 BTC_RSSI_STATE_STAY_MEDIUM)) { 190 if (wifi_rssi >= rssi_thresh1 + 191 BTC_RSSI_COEX_THRESH_TOL_8723B_2ANT) { 192 wifi_rssi_state = BTC_RSSI_STATE_HIGH; 193 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 194 "[BTCoex], wifi RSSI state switch to High\n"); 195 } else if (wifi_rssi < rssi_thresh) { 196 wifi_rssi_state = BTC_RSSI_STATE_LOW; 197 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 198 "[BTCoex], wifi RSSI state switch to Low\n"); 199 } else { 200 wifi_rssi_state = BTC_RSSI_STATE_STAY_MEDIUM; 201 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 202 "[BTCoex], wifi RSSI state stay at Medium\n"); 203 } 204 } else { 205 if (wifi_rssi < rssi_thresh1) { 206 wifi_rssi_state = BTC_RSSI_STATE_MEDIUM; 207 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 208 "[BTCoex], wifi RSSI state switch to Medium\n"); 209 } else { 210 wifi_rssi_state = BTC_RSSI_STATE_STAY_HIGH; 211 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 212 "[BTCoex], wifi RSSI state stay at High\n"); 213 } 214 } 215 } 216 217 coex_sta->pre_wifi_rssi_state[index] = wifi_rssi_state; 218 219 return wifi_rssi_state; 220 } 221 222 static 223 void btc8723b2ant_limited_rx(struct btc_coexist *btcoexist, bool force_exec, 224 bool rej_ap_agg_pkt, bool bt_ctrl_agg_buf_size, 225 u8 agg_buf_size) 226 { 227 bool reject_rx_agg = rej_ap_agg_pkt; 228 bool bt_ctrl_rx_agg_size = bt_ctrl_agg_buf_size; 229 u8 rx_agg_size = agg_buf_size; 230 231 /* ============================================ */ 232 /* Rx Aggregation related setting */ 233 /* ============================================ */ 234 btcoexist->btc_set(btcoexist, BTC_SET_BL_TO_REJ_AP_AGG_PKT, 235 &reject_rx_agg); 236 /* decide BT control aggregation buf size or not */ 237 btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_CTRL_AGG_SIZE, 238 &bt_ctrl_rx_agg_size); 239 /* aggregate buf size, only work when BT control Rx aggregate size */ 240 btcoexist->btc_set(btcoexist, BTC_SET_U1_AGG_BUF_SIZE, &rx_agg_size); 241 /* real update aggregation setting */ 242 btcoexist->btc_set(btcoexist, BTC_SET_ACT_AGGREGATE_CTRL, NULL); 243 } 244 245 static void btc8723b2ant_monitor_bt_ctr(struct btc_coexist *btcoexist) 246 { 247 struct rtl_priv *rtlpriv = btcoexist->adapter; 248 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 249 u32 reg_hp_txrx, reg_lp_txrx, u32tmp; 250 u32 reg_hp_tx = 0, reg_hp_rx = 0; 251 u32 reg_lp_tx = 0, reg_lp_rx = 0; 252 253 reg_hp_txrx = 0x770; 254 reg_lp_txrx = 0x774; 255 256 u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_hp_txrx); 257 reg_hp_tx = u32tmp & MASKLWORD; 258 reg_hp_rx = (u32tmp & MASKHWORD) >> 16; 259 260 u32tmp = btcoexist->btc_read_4byte(btcoexist, reg_lp_txrx); 261 reg_lp_tx = u32tmp & MASKLWORD; 262 reg_lp_rx = (u32tmp & MASKHWORD) >> 16; 263 264 coex_sta->high_priority_tx = reg_hp_tx; 265 coex_sta->high_priority_rx = reg_hp_rx; 266 coex_sta->low_priority_tx = reg_lp_tx; 267 coex_sta->low_priority_rx = reg_lp_rx; 268 269 if ((coex_sta->low_priority_tx > 1050) && 270 (!coex_sta->c2h_bt_inquiry_page)) 271 coex_sta->pop_event_cnt++; 272 273 if ((coex_sta->low_priority_rx >= 950) && 274 (coex_sta->low_priority_rx >= coex_sta->low_priority_tx) && 275 (!coex_sta->under_ips)) 276 bt_link_info->slave_role = true; 277 else 278 bt_link_info->slave_role = false; 279 280 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 281 "[BTCoex], High Priority Tx/Rx(reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 282 reg_hp_txrx, reg_hp_tx, reg_hp_tx, reg_hp_rx, reg_hp_rx); 283 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 284 "[BTCoex], Low Priority Tx/Rx(reg 0x%x)=0x%x(%d)/0x%x(%d)\n", 285 reg_lp_txrx, reg_lp_tx, reg_lp_tx, reg_lp_rx, reg_lp_rx); 286 287 /* reset counter */ 288 btcoexist->btc_write_1byte(btcoexist, 0x76e, 0xc); 289 } 290 291 static void btc8723b2ant_monitor_wifi_ctr(struct btc_coexist *btcoexist) 292 { 293 if (coex_sta->under_ips) { 294 coex_sta->crc_ok_cck = 0; 295 coex_sta->crc_ok_11g = 0; 296 coex_sta->crc_ok_11n = 0; 297 coex_sta->crc_ok_11n_agg = 0; 298 299 coex_sta->crc_err_cck = 0; 300 coex_sta->crc_err_11g = 0; 301 coex_sta->crc_err_11n = 0; 302 coex_sta->crc_err_11n_agg = 0; 303 } else { 304 coex_sta->crc_ok_cck = 305 btcoexist->btc_read_4byte(btcoexist, 0xf88); 306 coex_sta->crc_ok_11g = 307 btcoexist->btc_read_2byte(btcoexist, 0xf94); 308 coex_sta->crc_ok_11n = 309 btcoexist->btc_read_2byte(btcoexist, 0xf90); 310 coex_sta->crc_ok_11n_agg = 311 btcoexist->btc_read_2byte(btcoexist, 0xfb8); 312 313 coex_sta->crc_err_cck = 314 btcoexist->btc_read_4byte(btcoexist, 0xf84); 315 coex_sta->crc_err_11g = 316 btcoexist->btc_read_2byte(btcoexist, 0xf96); 317 coex_sta->crc_err_11n = 318 btcoexist->btc_read_2byte(btcoexist, 0xf92); 319 coex_sta->crc_err_11n_agg = 320 btcoexist->btc_read_2byte(btcoexist, 0xfba); 321 } 322 323 /* reset counter */ 324 btcoexist->btc_write_1byte_bitmask(btcoexist, 0xf16, 0x1, 0x1); 325 btcoexist->btc_write_1byte_bitmask(btcoexist, 0xf16, 0x1, 0x0); 326 } 327 328 static void btc8723b2ant_query_bt_info(struct btc_coexist *btcoexist) 329 { 330 struct rtl_priv *rtlpriv = btcoexist->adapter; 331 u8 h2c_parameter[1] = {0}; 332 333 coex_sta->c2h_bt_info_req_sent = true; 334 335 h2c_parameter[0] |= BIT0; /* trigger */ 336 337 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 338 "[BTCoex], Query Bt Info, FW write 0x61 = 0x%x\n", 339 h2c_parameter[0]); 340 341 btcoexist->btc_fill_h2c(btcoexist, 0x61, 1, h2c_parameter); 342 } 343 344 static bool btc8723b2ant_is_wifi_status_changed(struct btc_coexist *btcoexist) 345 { 346 static bool pre_wifi_busy; 347 static bool pre_under_4way; 348 static bool pre_bt_hs_on; 349 bool wifi_busy = false, under_4way = false, bt_hs_on = false; 350 bool wifi_connected = false; 351 u8 wifi_rssi_state = BTC_RSSI_STATE_HIGH; 352 u8 tmp; 353 354 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, 355 &wifi_connected); 356 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy); 357 btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on); 358 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_4_WAY_PROGRESS, 359 &under_4way); 360 361 if (wifi_connected) { 362 if (wifi_busy != pre_wifi_busy) { 363 pre_wifi_busy = wifi_busy; 364 return true; 365 } 366 367 if (under_4way != pre_under_4way) { 368 pre_under_4way = under_4way; 369 return true; 370 } 371 372 if (bt_hs_on != pre_bt_hs_on) { 373 pre_bt_hs_on = bt_hs_on; 374 return true; 375 } 376 377 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 378 coex_dm->switch_thres_offset; 379 wifi_rssi_state = 380 btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, tmp, 0); 381 382 if ((wifi_rssi_state == BTC_RSSI_STATE_HIGH) || 383 (wifi_rssi_state == BTC_RSSI_STATE_LOW)) 384 return true; 385 } 386 387 return false; 388 } 389 390 static void btc8723b2ant_update_bt_link_info(struct btc_coexist *btcoexist) 391 { 392 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 393 bool bt_hs_on = false; 394 395 btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on); 396 397 bt_link_info->bt_link_exist = coex_sta->bt_link_exist; 398 bt_link_info->sco_exist = coex_sta->sco_exist; 399 bt_link_info->a2dp_exist = coex_sta->a2dp_exist; 400 bt_link_info->pan_exist = coex_sta->pan_exist; 401 bt_link_info->hid_exist = coex_sta->hid_exist; 402 403 /* work around for HS mode. */ 404 if (bt_hs_on) { 405 bt_link_info->pan_exist = true; 406 bt_link_info->bt_link_exist = true; 407 } 408 409 /* check if Sco only */ 410 if (bt_link_info->sco_exist && !bt_link_info->a2dp_exist && 411 !bt_link_info->pan_exist && !bt_link_info->hid_exist) 412 bt_link_info->sco_only = true; 413 else 414 bt_link_info->sco_only = false; 415 416 /* check if A2dp only */ 417 if (!bt_link_info->sco_exist && bt_link_info->a2dp_exist && 418 !bt_link_info->pan_exist && !bt_link_info->hid_exist) 419 bt_link_info->a2dp_only = true; 420 else 421 bt_link_info->a2dp_only = false; 422 423 /* check if Pan only */ 424 if (!bt_link_info->sco_exist && !bt_link_info->a2dp_exist && 425 bt_link_info->pan_exist && !bt_link_info->hid_exist) 426 bt_link_info->pan_only = true; 427 else 428 bt_link_info->pan_only = false; 429 430 /* check if Hid only */ 431 if (!bt_link_info->sco_exist && !bt_link_info->a2dp_exist && 432 !bt_link_info->pan_exist && bt_link_info->hid_exist) 433 bt_link_info->hid_only = true; 434 else 435 bt_link_info->hid_only = false; 436 } 437 438 static u8 btc8723b2ant_action_algorithm(struct btc_coexist *btcoexist) 439 { 440 struct rtl_priv *rtlpriv = btcoexist->adapter; 441 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 442 bool bt_hs_on = false; 443 u8 algorithm = BT_8723B_2ANT_COEX_ALGO_UNDEFINED; 444 u8 num_of_diff_profile = 0; 445 446 btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on); 447 448 if (!bt_link_info->bt_link_exist) { 449 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 450 "[BTCoex], No BT link exists!!!\n"); 451 return algorithm; 452 } 453 454 if (bt_link_info->sco_exist) 455 num_of_diff_profile++; 456 if (bt_link_info->hid_exist) 457 num_of_diff_profile++; 458 if (bt_link_info->pan_exist) 459 num_of_diff_profile++; 460 if (bt_link_info->a2dp_exist) 461 num_of_diff_profile++; 462 463 if (num_of_diff_profile == 1) { 464 if (bt_link_info->sco_exist) { 465 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 466 "[BTCoex], SCO only\n"); 467 algorithm = BT_8723B_2ANT_COEX_ALGO_SCO; 468 } else { 469 if (bt_link_info->hid_exist) { 470 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 471 "[BTCoex], HID only\n"); 472 algorithm = BT_8723B_2ANT_COEX_ALGO_HID; 473 } else if (bt_link_info->a2dp_exist) { 474 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 475 "[BTCoex], A2DP only\n"); 476 algorithm = BT_8723B_2ANT_COEX_ALGO_A2DP; 477 } else if (bt_link_info->pan_exist) { 478 if (bt_hs_on) { 479 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 480 DBG_LOUD, 481 "[BTCoex], PAN(HS) only\n"); 482 algorithm = 483 BT_8723B_2ANT_COEX_ALGO_PANHS; 484 } else { 485 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 486 DBG_LOUD, 487 "[BTCoex], PAN(EDR) only\n"); 488 algorithm = 489 BT_8723B_2ANT_COEX_ALGO_PANEDR; 490 } 491 } 492 } 493 } else if (num_of_diff_profile == 2) { 494 if (bt_link_info->sco_exist) { 495 if (bt_link_info->hid_exist) { 496 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 497 "[BTCoex], SCO + HID\n"); 498 algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 499 } else if (bt_link_info->a2dp_exist) { 500 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 501 "[BTCoex], SCO + A2DP ==> SCO\n"); 502 algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 503 } else if (bt_link_info->pan_exist) { 504 if (bt_hs_on) { 505 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 506 DBG_LOUD, 507 "[BTCoex], SCO + PAN(HS)\n"); 508 algorithm = BT_8723B_2ANT_COEX_ALGO_SCO; 509 } else { 510 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 511 DBG_LOUD, 512 "[BTCoex], SCO + PAN(EDR)\n"); 513 algorithm = 514 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 515 } 516 } 517 } else { 518 if (bt_link_info->hid_exist && 519 bt_link_info->a2dp_exist) { 520 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 521 "[BTCoex], HID + A2DP\n"); 522 algorithm = BT_8723B_2ANT_COEX_ALGO_HID_A2DP; 523 } else if (bt_link_info->hid_exist && 524 bt_link_info->pan_exist) { 525 if (bt_hs_on) { 526 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 527 DBG_LOUD, 528 "[BTCoex], HID + PAN(HS)\n"); 529 algorithm = BT_8723B_2ANT_COEX_ALGO_HID; 530 } else { 531 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 532 DBG_LOUD, 533 "[BTCoex], HID + PAN(EDR)\n"); 534 algorithm = 535 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 536 } 537 } else if (bt_link_info->pan_exist && 538 bt_link_info->a2dp_exist) { 539 if (bt_hs_on) { 540 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 541 DBG_LOUD, 542 "[BTCoex], A2DP + PAN(HS)\n"); 543 algorithm = 544 BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS; 545 } else { 546 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 547 DBG_LOUD, 548 "[BTCoex],A2DP + PAN(EDR)\n"); 549 algorithm = 550 BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP; 551 } 552 } 553 } 554 } else if (num_of_diff_profile == 3) { 555 if (bt_link_info->sco_exist) { 556 if (bt_link_info->hid_exist && 557 bt_link_info->a2dp_exist) { 558 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 559 "[BTCoex], SCO + HID + A2DP ==> HID\n"); 560 algorithm = BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 561 } else if (bt_link_info->hid_exist && 562 bt_link_info->pan_exist) { 563 if (bt_hs_on) { 564 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 565 DBG_LOUD, 566 "[BTCoex], SCO + HID + PAN(HS)\n"); 567 algorithm = 568 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 569 } else { 570 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 571 DBG_LOUD, 572 "[BTCoex], SCO + HID + PAN(EDR)\n"); 573 algorithm = 574 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 575 } 576 } else if (bt_link_info->pan_exist && 577 bt_link_info->a2dp_exist) { 578 if (bt_hs_on) { 579 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 580 DBG_LOUD, 581 "[BTCoex], SCO + A2DP + PAN(HS)\n"); 582 algorithm = 583 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 584 } else { 585 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 586 DBG_LOUD, 587 "[BTCoex], SCO + A2DP + PAN(EDR) ==> HID\n"); 588 algorithm = 589 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 590 } 591 } 592 } else { 593 if (bt_link_info->hid_exist && 594 bt_link_info->pan_exist && 595 bt_link_info->a2dp_exist) { 596 if (bt_hs_on) { 597 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 598 DBG_LOUD, 599 "[BTCoex], HID + A2DP + PAN(HS)\n"); 600 algorithm = 601 BT_8723B_2ANT_COEX_ALGO_HID_A2DP; 602 } else { 603 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 604 DBG_LOUD, 605 "[BTCoex], HID + A2DP + PAN(EDR)\n"); 606 algorithm = 607 BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR; 608 } 609 } 610 } 611 } else if (num_of_diff_profile >= 3) { 612 if (bt_link_info->sco_exist) { 613 if (bt_link_info->hid_exist && 614 bt_link_info->pan_exist && 615 bt_link_info->a2dp_exist) { 616 if (bt_hs_on) { 617 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 618 DBG_LOUD, 619 "[BTCoex], Error!!! SCO + HID + A2DP + PAN(HS)\n"); 620 } else { 621 rtl_dbg(rtlpriv, COMP_BT_COEXIST, 622 DBG_LOUD, 623 "[BTCoex], SCO + HID + A2DP + PAN(EDR)==>PAN(EDR)+HID\n"); 624 algorithm = 625 BT_8723B_2ANT_COEX_ALGO_PANEDR_HID; 626 } 627 } 628 } 629 } 630 return algorithm; 631 } 632 633 static void btc8723b2ant_set_fw_dac_swing_level(struct btc_coexist *btcoexist, 634 u8 dac_swing_lvl) 635 { 636 struct rtl_priv *rtlpriv = btcoexist->adapter; 637 u8 h2c_parameter[1] = {0}; 638 639 /* There are several type of dacswing 640 * 0x18/ 0x10/ 0xc/ 0x8/ 0x4/ 0x6 641 */ 642 h2c_parameter[0] = dac_swing_lvl; 643 644 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 645 "[BTCoex], Set Dac Swing Level=0x%x\n", dac_swing_lvl); 646 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 647 "[BTCoex], FW write 0x64=0x%x\n", h2c_parameter[0]); 648 649 btcoexist->btc_fill_h2c(btcoexist, 0x64, 1, h2c_parameter); 650 } 651 652 static void btc8723b2ant_set_fw_dec_bt_pwr(struct btc_coexist *btcoexist, 653 u8 dec_bt_pwr_lvl) 654 { 655 struct rtl_priv *rtlpriv = btcoexist->adapter; 656 u8 h2c_parameter[1] = {0}; 657 658 h2c_parameter[0] = dec_bt_pwr_lvl; 659 660 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 661 "[BTCoex], decrease Bt Power Level : %u\n", dec_bt_pwr_lvl); 662 663 btcoexist->btc_fill_h2c(btcoexist, 0x62, 1, h2c_parameter); 664 } 665 666 static void btc8723b2ant_dec_bt_pwr(struct btc_coexist *btcoexist, 667 bool force_exec, u8 dec_bt_pwr_lvl) 668 { 669 struct rtl_priv *rtlpriv = btcoexist->adapter; 670 671 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 672 "[BTCoex], Dec BT power level = %u\n", dec_bt_pwr_lvl); 673 coex_dm->cur_dec_bt_pwr_lvl = dec_bt_pwr_lvl; 674 675 if (!force_exec) { 676 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 677 "[BTCoex], PreDecBtPwrLvl=%d, CurDecBtPwrLvl=%d\n", 678 coex_dm->pre_dec_bt_pwr_lvl, 679 coex_dm->cur_dec_bt_pwr_lvl); 680 681 if (coex_dm->pre_dec_bt_pwr_lvl == coex_dm->cur_dec_bt_pwr_lvl) 682 return; 683 } 684 btc8723b2ant_set_fw_dec_bt_pwr(btcoexist, coex_dm->cur_dec_bt_pwr_lvl); 685 686 coex_dm->pre_dec_bt_pwr_lvl = coex_dm->cur_dec_bt_pwr_lvl; 687 } 688 689 static 690 void halbtc8723b2ant_set_bt_auto_report(struct btc_coexist *btcoexist, 691 bool enable_auto_report) 692 { 693 u8 h2c_parameter[1] = {0}; 694 695 h2c_parameter[0] = 0; 696 697 if (enable_auto_report) 698 h2c_parameter[0] |= BIT(0); 699 700 btcoexist->btc_fill_h2c(btcoexist, 0x68, 1, h2c_parameter); 701 } 702 703 static 704 void btc8723b2ant_bt_auto_report(struct btc_coexist *btcoexist, 705 bool force_exec, bool enable_auto_report) 706 { 707 coex_dm->cur_bt_auto_report = enable_auto_report; 708 709 if (!force_exec) { 710 if (coex_dm->pre_bt_auto_report == coex_dm->cur_bt_auto_report) 711 return; 712 } 713 halbtc8723b2ant_set_bt_auto_report(btcoexist, 714 coex_dm->cur_bt_auto_report); 715 716 coex_dm->pre_bt_auto_report = coex_dm->cur_bt_auto_report; 717 } 718 719 static void btc8723b2ant_fw_dac_swing_lvl(struct btc_coexist *btcoexist, 720 bool force_exec, u8 fw_dac_swing_lvl) 721 { 722 struct rtl_priv *rtlpriv = btcoexist->adapter; 723 724 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 725 "[BTCoex], %s set FW Dac Swing level = %d\n", 726 (force_exec ? "force to" : ""), fw_dac_swing_lvl); 727 coex_dm->cur_fw_dac_swing_lvl = fw_dac_swing_lvl; 728 729 if (!force_exec) { 730 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 731 "[BTCoex], preFwDacSwingLvl=%d, curFwDacSwingLvl=%d\n", 732 coex_dm->pre_fw_dac_swing_lvl, 733 coex_dm->cur_fw_dac_swing_lvl); 734 735 if (coex_dm->pre_fw_dac_swing_lvl == 736 coex_dm->cur_fw_dac_swing_lvl) 737 return; 738 } 739 740 btc8723b2ant_set_fw_dac_swing_level(btcoexist, 741 coex_dm->cur_fw_dac_swing_lvl); 742 coex_dm->pre_fw_dac_swing_lvl = coex_dm->cur_fw_dac_swing_lvl; 743 } 744 745 static void btc8723b_set_penalty_txrate(struct btc_coexist *btcoexist, 746 bool low_penalty_ra) 747 { 748 struct rtl_priv *rtlpriv = btcoexist->adapter; 749 u8 h2c_parameter[6] = {0}; 750 751 h2c_parameter[0] = 0x6; /* op_code, 0x6 = Retry_Penalty */ 752 753 if (low_penalty_ra) { 754 h2c_parameter[1] |= BIT0; 755 /* normal rate except MCS7/6/5, OFDM54/48/36 */ 756 h2c_parameter[2] = 0x00; 757 h2c_parameter[3] = 0xf4; /* MCS7 or OFDM54 */ 758 h2c_parameter[4] = 0xf5; /* MCS6 or OFDM48 */ 759 h2c_parameter[5] = 0xf6; /* MCS5 or OFDM36 */ 760 } 761 762 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 763 "[BTCoex], set WiFi Low-Penalty Retry: %s", 764 (low_penalty_ra ? "ON!!" : "OFF!!")); 765 766 btcoexist->btc_fill_h2c(btcoexist, 0x69, 6, h2c_parameter); 767 } 768 769 static void btc8723b2ant_low_penalty_ra(struct btc_coexist *btcoexist, 770 bool force_exec, bool low_penalty_ra) 771 { 772 struct rtl_priv *rtlpriv = btcoexist->adapter; 773 774 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 775 "[BTCoex], %s turn LowPenaltyRA = %s\n", 776 (force_exec ? "force to" : ""), (low_penalty_ra ? 777 "ON" : "OFF")); 778 coex_dm->cur_low_penalty_ra = low_penalty_ra; 779 780 if (!force_exec) { 781 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 782 "[BTCoex], bPreLowPenaltyRa=%d, bCurLowPenaltyRa=%d\n", 783 coex_dm->pre_low_penalty_ra, 784 coex_dm->cur_low_penalty_ra); 785 786 if (coex_dm->pre_low_penalty_ra == coex_dm->cur_low_penalty_ra) 787 return; 788 } 789 btc8723b_set_penalty_txrate(btcoexist, coex_dm->cur_low_penalty_ra); 790 791 coex_dm->pre_low_penalty_ra = coex_dm->cur_low_penalty_ra; 792 } 793 794 static void btc8723b2ant_set_dac_swing_reg(struct btc_coexist *btcoexist, 795 u32 level) 796 { 797 struct rtl_priv *rtlpriv = btcoexist->adapter; 798 u8 val = (u8) level; 799 800 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 801 "[BTCoex], Write SwDacSwing = 0x%x\n", level); 802 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x883, 0x3e, val); 803 } 804 805 static void btc8723b2ant_set_sw_fulltime_dac_swing(struct btc_coexist *btcoex, 806 bool sw_dac_swing_on, 807 u32 sw_dac_swing_lvl) 808 { 809 if (sw_dac_swing_on) 810 btc8723b2ant_set_dac_swing_reg(btcoex, sw_dac_swing_lvl); 811 else 812 btc8723b2ant_set_dac_swing_reg(btcoex, 0x18); 813 } 814 815 static void btc8723b2ant_dac_swing(struct btc_coexist *btcoexist, 816 bool force_exec, bool dac_swing_on, 817 u32 dac_swing_lvl) 818 { 819 struct rtl_priv *rtlpriv = btcoexist->adapter; 820 821 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 822 "[BTCoex], %s turn DacSwing=%s, dac_swing_lvl=0x%x\n", 823 (force_exec ? "force to" : ""), 824 (dac_swing_on ? "ON" : "OFF"), dac_swing_lvl); 825 coex_dm->cur_dac_swing_on = dac_swing_on; 826 coex_dm->cur_dac_swing_lvl = dac_swing_lvl; 827 828 if (!force_exec) { 829 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 830 "[BTCoex], bPreDacSwingOn=%d, preDacSwingLvl=0x%x, bCurDacSwingOn=%d, curDacSwingLvl=0x%x\n", 831 coex_dm->pre_dac_swing_on, 832 coex_dm->pre_dac_swing_lvl, 833 coex_dm->cur_dac_swing_on, 834 coex_dm->cur_dac_swing_lvl); 835 836 if ((coex_dm->pre_dac_swing_on == coex_dm->cur_dac_swing_on) && 837 (coex_dm->pre_dac_swing_lvl == coex_dm->cur_dac_swing_lvl)) 838 return; 839 } 840 mdelay(30); 841 btc8723b2ant_set_sw_fulltime_dac_swing(btcoexist, dac_swing_on, 842 dac_swing_lvl); 843 844 coex_dm->pre_dac_swing_on = coex_dm->cur_dac_swing_on; 845 coex_dm->pre_dac_swing_lvl = coex_dm->cur_dac_swing_lvl; 846 } 847 848 static void btc8723b2ant_set_coex_table(struct btc_coexist *btcoexist, 849 u32 val0x6c0, u32 val0x6c4, 850 u32 val0x6c8, u8 val0x6cc) 851 { 852 struct rtl_priv *rtlpriv = btcoexist->adapter; 853 854 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 855 "[BTCoex], set coex table, set 0x6c0=0x%x\n", val0x6c0); 856 btcoexist->btc_write_4byte(btcoexist, 0x6c0, val0x6c0); 857 858 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 859 "[BTCoex], set coex table, set 0x6c4=0x%x\n", val0x6c4); 860 btcoexist->btc_write_4byte(btcoexist, 0x6c4, val0x6c4); 861 862 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 863 "[BTCoex], set coex table, set 0x6c8=0x%x\n", val0x6c8); 864 btcoexist->btc_write_4byte(btcoexist, 0x6c8, val0x6c8); 865 866 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 867 "[BTCoex], set coex table, set 0x6cc=0x%x\n", val0x6cc); 868 btcoexist->btc_write_1byte(btcoexist, 0x6cc, val0x6cc); 869 } 870 871 static void btc8723b2ant_coex_table(struct btc_coexist *btcoexist, 872 bool force_exec, u32 val0x6c0, 873 u32 val0x6c4, u32 val0x6c8, 874 u8 val0x6cc) 875 { 876 struct rtl_priv *rtlpriv = btcoexist->adapter; 877 878 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 879 "[BTCoex], %s write Coex Table 0x6c0=0x%x, 0x6c4=0x%x, 0x6c8=0x%x, 0x6cc=0x%x\n", 880 force_exec ? "force to" : "", 881 val0x6c0, val0x6c4, val0x6c8, val0x6cc); 882 coex_dm->cur_val0x6c0 = val0x6c0; 883 coex_dm->cur_val0x6c4 = val0x6c4; 884 coex_dm->cur_val0x6c8 = val0x6c8; 885 coex_dm->cur_val0x6cc = val0x6cc; 886 887 if (!force_exec) { 888 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 889 "[BTCoex], preVal0x6c0=0x%x, preVal0x6c4=0x%x, preVal0x6c8=0x%x, preVal0x6cc=0x%x !!\n", 890 coex_dm->pre_val0x6c0, coex_dm->pre_val0x6c4, 891 coex_dm->pre_val0x6c8, coex_dm->pre_val0x6cc); 892 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 893 "[BTCoex], curVal0x6c0=0x%x, curVal0x6c4=0x%x, curVal0x6c8=0x%x, curVal0x6cc=0x%x !!\n", 894 coex_dm->cur_val0x6c0, coex_dm->cur_val0x6c4, 895 coex_dm->cur_val0x6c8, coex_dm->cur_val0x6cc); 896 897 if ((coex_dm->pre_val0x6c0 == coex_dm->cur_val0x6c0) && 898 (coex_dm->pre_val0x6c4 == coex_dm->cur_val0x6c4) && 899 (coex_dm->pre_val0x6c8 == coex_dm->cur_val0x6c8) && 900 (coex_dm->pre_val0x6cc == coex_dm->cur_val0x6cc)) 901 return; 902 } 903 btc8723b2ant_set_coex_table(btcoexist, val0x6c0, val0x6c4, 904 val0x6c8, val0x6cc); 905 906 coex_dm->pre_val0x6c0 = coex_dm->cur_val0x6c0; 907 coex_dm->pre_val0x6c4 = coex_dm->cur_val0x6c4; 908 coex_dm->pre_val0x6c8 = coex_dm->cur_val0x6c8; 909 coex_dm->pre_val0x6cc = coex_dm->cur_val0x6cc; 910 } 911 912 static void btc8723b2ant_coex_table_with_type(struct btc_coexist *btcoexist, 913 bool force_exec, u8 type) 914 { 915 switch (type) { 916 case 0: 917 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55555555, 918 0x55555555, 0xffffff, 0x3); 919 break; 920 case 1: 921 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55555555, 922 0x5afa5afa, 0xffffff, 0x3); 923 break; 924 case 2: 925 btc8723b2ant_coex_table(btcoexist, force_exec, 0x5ada5ada, 926 0x5ada5ada, 0xffffff, 0x3); 927 break; 928 case 3: 929 btc8723b2ant_coex_table(btcoexist, force_exec, 0xaaaaaaaa, 930 0xaaaaaaaa, 0xffffff, 0x3); 931 break; 932 case 4: 933 btc8723b2ant_coex_table(btcoexist, force_exec, 0xffffffff, 934 0xffffffff, 0xffffff, 0x3); 935 break; 936 case 5: 937 btc8723b2ant_coex_table(btcoexist, force_exec, 0x5fff5fff, 938 0x5fff5fff, 0xffffff, 0x3); 939 break; 940 case 6: 941 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55ff55ff, 942 0x5a5a5a5a, 0xffffff, 0x3); 943 break; 944 case 7: 945 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 946 0x5ada5ada, 0xffffff, 0x3); 947 break; 948 case 8: 949 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 950 0x5ada5ada, 0xffffff, 0x3); 951 break; 952 case 9: 953 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 954 0x5ada5ada, 0xffffff, 0x3); 955 break; 956 case 10: 957 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 958 0x5ada5ada, 0xffffff, 0x3); 959 break; 960 case 11: 961 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 962 0x5ada5ada, 0xffffff, 0x3); 963 break; 964 case 12: 965 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 966 0x5ada5ada, 0xffffff, 0x3); 967 break; 968 case 13: 969 btc8723b2ant_coex_table(btcoexist, force_exec, 0x5fff5fff, 970 0xaaaaaaaa, 0xffffff, 0x3); 971 break; 972 case 14: 973 btc8723b2ant_coex_table(btcoexist, force_exec, 0x5fff5fff, 974 0x5ada5ada, 0xffffff, 0x3); 975 break; 976 case 15: 977 btc8723b2ant_coex_table(btcoexist, force_exec, 0x55dd55dd, 978 0xaaaaaaaa, 0xffffff, 0x3); 979 break; 980 default: 981 break; 982 } 983 } 984 985 static void btc8723b2ant_set_fw_ignore_wlan_act(struct btc_coexist *btcoexist, 986 bool enable) 987 { 988 struct rtl_priv *rtlpriv = btcoexist->adapter; 989 u8 h2c_parameter[1] = {0}; 990 991 if (enable) 992 h2c_parameter[0] |= BIT0; /* function enable */ 993 994 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 995 "[BTCoex], set FW for BT Ignore Wlan_Act, FW write 0x63=0x%x\n", 996 h2c_parameter[0]); 997 998 btcoexist->btc_fill_h2c(btcoexist, 0x63, 1, h2c_parameter); 999 } 1000 1001 static void btc8723b2ant_set_lps_rpwm(struct btc_coexist *btcoexist, 1002 u8 lps_val, u8 rpwm_val) 1003 { 1004 u8 lps = lps_val; 1005 u8 rpwm = rpwm_val; 1006 1007 btcoexist->btc_set(btcoexist, BTC_SET_U1_LPS_VAL, &lps); 1008 btcoexist->btc_set(btcoexist, BTC_SET_U1_RPWM_VAL, &rpwm); 1009 } 1010 1011 static void btc8723b2ant_lps_rpwm(struct btc_coexist *btcoexist, 1012 bool force_exec, u8 lps_val, u8 rpwm_val) 1013 { 1014 coex_dm->cur_lps = lps_val; 1015 coex_dm->cur_rpwm = rpwm_val; 1016 1017 if (!force_exec) { 1018 if ((coex_dm->pre_lps == coex_dm->cur_lps) && 1019 (coex_dm->pre_rpwm == coex_dm->cur_rpwm)) 1020 return; 1021 } 1022 btc8723b2ant_set_lps_rpwm(btcoexist, lps_val, rpwm_val); 1023 1024 coex_dm->pre_lps = coex_dm->cur_lps; 1025 coex_dm->pre_rpwm = coex_dm->cur_rpwm; 1026 } 1027 1028 static void btc8723b2ant_ignore_wlan_act(struct btc_coexist *btcoexist, 1029 bool force_exec, bool enable) 1030 { 1031 struct rtl_priv *rtlpriv = btcoexist->adapter; 1032 1033 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1034 "[BTCoex], %s turn Ignore WlanAct %s\n", 1035 (force_exec ? "force to" : ""), (enable ? "ON" : "OFF")); 1036 coex_dm->cur_ignore_wlan_act = enable; 1037 1038 if (!force_exec) { 1039 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1040 "[BTCoex], bPreIgnoreWlanAct = %d, bCurIgnoreWlanAct = %d!!\n", 1041 coex_dm->pre_ignore_wlan_act, 1042 coex_dm->cur_ignore_wlan_act); 1043 1044 if (coex_dm->pre_ignore_wlan_act == 1045 coex_dm->cur_ignore_wlan_act) 1046 return; 1047 } 1048 btc8723b2ant_set_fw_ignore_wlan_act(btcoexist, enable); 1049 1050 coex_dm->pre_ignore_wlan_act = coex_dm->cur_ignore_wlan_act; 1051 } 1052 1053 static void btc8723b2ant_set_fw_ps_tdma(struct btc_coexist *btcoexist, u8 byte1, 1054 u8 byte2, u8 byte3, u8 byte4, u8 byte5) 1055 { 1056 struct rtl_priv *rtlpriv = btcoexist->adapter; 1057 u8 h2c_parameter[5]; 1058 if ((coex_sta->a2dp_exist) && (coex_sta->hid_exist)) 1059 byte5 = byte5 | 0x1; 1060 1061 h2c_parameter[0] = byte1; 1062 h2c_parameter[1] = byte2; 1063 h2c_parameter[2] = byte3; 1064 h2c_parameter[3] = byte4; 1065 h2c_parameter[4] = byte5; 1066 1067 coex_dm->ps_tdma_para[0] = byte1; 1068 coex_dm->ps_tdma_para[1] = byte2; 1069 coex_dm->ps_tdma_para[2] = byte3; 1070 coex_dm->ps_tdma_para[3] = byte4; 1071 coex_dm->ps_tdma_para[4] = byte5; 1072 1073 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1074 "[BTCoex], FW write 0x60(5bytes)=0x%x%08x\n", 1075 h2c_parameter[0], 1076 h2c_parameter[1] << 24 | h2c_parameter[2] << 16 | 1077 h2c_parameter[3] << 8 | h2c_parameter[4]); 1078 1079 btcoexist->btc_fill_h2c(btcoexist, 0x60, 5, h2c_parameter); 1080 } 1081 1082 static void btc8723b2ant_sw_mechanism(struct btc_coexist *btcoexist, 1083 bool shrink_rx_lpf, bool low_penalty_ra, 1084 bool limited_dig, bool bt_lna_constrain) 1085 { 1086 btc8723b2ant_low_penalty_ra(btcoexist, NORMAL_EXEC, low_penalty_ra); 1087 } 1088 1089 static void btc8723b2ant_set_ant_path(struct btc_coexist *btcoexist, 1090 u8 antpos_type, bool init_hwcfg, 1091 bool wifi_off) 1092 { 1093 struct btc_board_info *board_info = &btcoexist->board_info; 1094 u32 fw_ver = 0, u32tmp = 0; 1095 bool pg_ext_switch = false; 1096 bool use_ext_switch = false; 1097 u8 h2c_parameter[2] = {0}; 1098 1099 btcoexist->btc_get(btcoexist, BTC_GET_BL_EXT_SWITCH, &pg_ext_switch); 1100 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver); 1101 1102 if ((fw_ver < 0xc0000) || pg_ext_switch) 1103 use_ext_switch = true; 1104 1105 if (init_hwcfg) { 1106 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x39, 0x8, 0x1); 1107 btcoexist->btc_write_1byte(btcoexist, 0x974, 0xff); 1108 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x944, 0x3, 0x3); 1109 btcoexist->btc_write_1byte(btcoexist, 0x930, 0x77); 1110 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20, 0x1); 1111 1112 if (fw_ver >= 0x180000) { 1113 /* Use H2C to set GNT_BT to High to avoid A2DP click */ 1114 h2c_parameter[0] = 1; 1115 btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1, 1116 h2c_parameter); 1117 } else { 1118 btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18); 1119 } 1120 1121 btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0); 1122 1123 /* WiFi TRx Mask off */ 1124 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 1125 0x1, 0xfffff, 0x0); 1126 1127 if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) { 1128 /* tell firmware "no antenna inverse" */ 1129 h2c_parameter[0] = 0; 1130 } else { 1131 /* tell firmware "antenna inverse" */ 1132 h2c_parameter[0] = 1; 1133 } 1134 1135 if (use_ext_switch) { 1136 /* ext switch type */ 1137 h2c_parameter[1] = 1; 1138 } else { 1139 /* int switch type */ 1140 h2c_parameter[1] = 0; 1141 } 1142 btcoexist->btc_fill_h2c(btcoexist, 0x65, 2, h2c_parameter); 1143 } else { 1144 if (fw_ver >= 0x180000) { 1145 /* Use H2C to set GNT_BT to "Control by PTA"*/ 1146 h2c_parameter[0] = 0; 1147 btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1, 1148 h2c_parameter); 1149 } else { 1150 btcoexist->btc_write_1byte(btcoexist, 0x765, 0x0); 1151 } 1152 } 1153 1154 /* ext switch setting */ 1155 if (use_ext_switch) { 1156 if (init_hwcfg) { 1157 /* 0x4c[23] = 0, 0x4c[24] = 1 Ant controlled by WL/BT */ 1158 u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c); 1159 u32tmp &= ~BIT23; 1160 u32tmp |= BIT24; 1161 btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp); 1162 } 1163 1164 /* fixed internal switch S1->WiFi, S0->BT */ 1165 if (board_info->btdm_ant_pos == BTC_ANTENNA_AT_MAIN_PORT) 1166 btcoexist->btc_write_2byte(btcoexist, 0x948, 0x0); 1167 else 1168 btcoexist->btc_write_2byte(btcoexist, 0x948, 0x280); 1169 1170 switch (antpos_type) { 1171 case BTC_ANT_WIFI_AT_MAIN: 1172 /* ext switch main at wifi */ 1173 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x92c, 1174 0x3, 0x1); 1175 break; 1176 case BTC_ANT_WIFI_AT_AUX: 1177 /* ext switch aux at wifi */ 1178 btcoexist->btc_write_1byte_bitmask(btcoexist, 1179 0x92c, 0x3, 0x2); 1180 break; 1181 } 1182 } else { 1183 /* internal switch */ 1184 if (init_hwcfg) { 1185 /* 0x4c[23] = 0, 0x4c[24] = 1 Ant controlled by WL/BT */ 1186 u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x4c); 1187 u32tmp |= BIT23; 1188 u32tmp &= ~BIT24; 1189 btcoexist->btc_write_4byte(btcoexist, 0x4c, u32tmp); 1190 } 1191 1192 /* fixed ext switch, S1->Main, S0->Aux */ 1193 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x64, 0x1, 0x0); 1194 switch (antpos_type) { 1195 case BTC_ANT_WIFI_AT_MAIN: 1196 /* fixed internal switch S1->WiFi, S0->BT */ 1197 btcoexist->btc_write_2byte(btcoexist, 0x948, 0x0); 1198 break; 1199 case BTC_ANT_WIFI_AT_AUX: 1200 /* fixed internal switch S0->WiFi, S1->BT */ 1201 btcoexist->btc_write_2byte(btcoexist, 0x948, 0x280); 1202 break; 1203 } 1204 } 1205 } 1206 1207 static void btc8723b2ant_ps_tdma(struct btc_coexist *btcoexist, bool force_exec, 1208 bool turn_on, u8 type) 1209 { 1210 struct rtl_priv *rtlpriv = btcoexist->adapter; 1211 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 1212 u8 wifi_rssi_state, bt_rssi_state; 1213 s8 wifi_duration_adjust = 0x0; 1214 u8 tdma_byte4_modify = 0x0; 1215 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 1216 coex_dm->switch_thres_offset; 1217 1218 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, tmp, 0); 1219 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 1220 coex_dm->switch_thres_offset; 1221 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 1222 1223 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1224 "[BTCoex], %s turn %s PS TDMA, type=%d\n", 1225 (force_exec ? "force to" : ""), 1226 (turn_on ? "ON" : "OFF"), type); 1227 coex_dm->cur_ps_tdma_on = turn_on; 1228 coex_dm->cur_ps_tdma = type; 1229 1230 if (!(BTC_RSSI_HIGH(wifi_rssi_state) && 1231 BTC_RSSI_HIGH(bt_rssi_state)) && turn_on) { 1232 /* for WiFi RSSI low or BT RSSI low */ 1233 type = type + 100; 1234 coex_dm->is_switch_to_1dot5_ant = true; 1235 } else { 1236 coex_dm->is_switch_to_1dot5_ant = false; 1237 } 1238 1239 if (!force_exec) { 1240 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1241 "[BTCoex], bPrePsTdmaOn = %d, bCurPsTdmaOn = %d!!\n", 1242 coex_dm->pre_ps_tdma_on, coex_dm->cur_ps_tdma_on); 1243 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1244 "[BTCoex], prePsTdma = %d, curPsTdma = %d!!\n", 1245 coex_dm->pre_ps_tdma, coex_dm->cur_ps_tdma); 1246 1247 if ((coex_dm->pre_ps_tdma_on == coex_dm->cur_ps_tdma_on) && 1248 (coex_dm->pre_ps_tdma == coex_dm->cur_ps_tdma)) 1249 return; 1250 } 1251 1252 if (coex_sta->scan_ap_num <= 5) { 1253 if (coex_sta->a2dp_bit_pool >= 45) 1254 wifi_duration_adjust = -15; 1255 else if (coex_sta->a2dp_bit_pool >= 35) 1256 wifi_duration_adjust = -10; 1257 else 1258 wifi_duration_adjust = 5; 1259 } else if (coex_sta->scan_ap_num <= 20) { 1260 if (coex_sta->a2dp_bit_pool >= 45) 1261 wifi_duration_adjust = -15; 1262 else if (coex_sta->a2dp_bit_pool >= 35) 1263 wifi_duration_adjust = -10; 1264 else 1265 wifi_duration_adjust = 0; 1266 } else if (coex_sta->scan_ap_num <= 40) { 1267 if (coex_sta->a2dp_bit_pool >= 45) 1268 wifi_duration_adjust = -15; 1269 else if (coex_sta->a2dp_bit_pool >= 35) 1270 wifi_duration_adjust = -10; 1271 else 1272 wifi_duration_adjust = -5; 1273 } else { 1274 if (coex_sta->a2dp_bit_pool >= 45) 1275 wifi_duration_adjust = -15; 1276 else if (coex_sta->a2dp_bit_pool >= 35) 1277 wifi_duration_adjust = -10; 1278 else 1279 wifi_duration_adjust = -10; 1280 } 1281 1282 if ((bt_link_info->slave_role) && (bt_link_info->a2dp_exist)) 1283 /* 0x778 = 0x1 at wifi slot (no blocking BT Low-Pri pkts) */ 1284 tdma_byte4_modify = 0x1; 1285 1286 if (turn_on) { 1287 switch (type) { 1288 case 1: 1289 default: 1290 btc8723b2ant_set_fw_ps_tdma( 1291 btcoexist, 0xe3, 0x3c, 1292 0x03, 0xf1, 0x90 | tdma_byte4_modify); 1293 break; 1294 case 2: 1295 btc8723b2ant_set_fw_ps_tdma( 1296 btcoexist, 0xe3, 0x2d, 1297 0x03, 0xf1, 0x90 | tdma_byte4_modify); 1298 break; 1299 case 3: 1300 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x1c, 1301 0x3, 0xf1, 1302 0x90 | tdma_byte4_modify); 1303 break; 1304 case 4: 1305 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x10, 1306 0x03, 0xf1, 1307 0x90 | tdma_byte4_modify); 1308 break; 1309 case 5: 1310 btc8723b2ant_set_fw_ps_tdma( 1311 btcoexist, 0xe3, 0x3c, 1312 0x3, 0x70, 0x90 | tdma_byte4_modify); 1313 break; 1314 case 6: 1315 btc8723b2ant_set_fw_ps_tdma( 1316 btcoexist, 0xe3, 0x2d, 1317 0x3, 0x70, 0x90 | tdma_byte4_modify); 1318 break; 1319 case 7: 1320 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x1c, 1321 0x3, 0x70, 1322 0x90 | tdma_byte4_modify); 1323 break; 1324 case 8: 1325 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xa3, 0x10, 1326 0x3, 0x70, 1327 0x90 | tdma_byte4_modify); 1328 break; 1329 case 9: 1330 btc8723b2ant_set_fw_ps_tdma( 1331 btcoexist, 0xe3, 0x3c + wifi_duration_adjust, 1332 0x03, 0xf1, 0x90 | tdma_byte4_modify); 1333 break; 1334 case 10: 1335 btc8723b2ant_set_fw_ps_tdma( 1336 btcoexist, 0xe3, 0x2d, 1337 0x03, 0xf1, 0x90 | tdma_byte4_modify); 1338 break; 1339 case 11: 1340 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x1c, 1341 0x3, 0xf1, 1342 0x90 | tdma_byte4_modify); 1343 break; 1344 case 12: 1345 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x10, 1346 0x3, 0xf1, 1347 0x90 | tdma_byte4_modify); 1348 break; 1349 case 13: 1350 btc8723b2ant_set_fw_ps_tdma( 1351 btcoexist, 0xe3, 0x3c, 1352 0x3, 0x70, 0x90 | tdma_byte4_modify); 1353 break; 1354 case 14: 1355 btc8723b2ant_set_fw_ps_tdma( 1356 btcoexist, 0xe3, 0x2d, 1357 0x3, 0x70, 0x90 | tdma_byte4_modify); 1358 break; 1359 case 15: 1360 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x1c, 1361 0x3, 0x70, 1362 0x90 | tdma_byte4_modify); 1363 break; 1364 case 16: 1365 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x10, 1366 0x3, 0x70, 1367 0x90 | tdma_byte4_modify); 1368 break; 1369 case 17: 1370 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xa3, 0x2f, 1371 0x2f, 0x60, 0x90); 1372 break; 1373 case 18: 1374 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x5, 0x5, 1375 0xe1, 0x90); 1376 break; 1377 case 19: 1378 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x25, 1379 0x25, 0xe1, 0x90); 1380 break; 1381 case 20: 1382 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x25, 1383 0x25, 0x60, 0x90); 1384 break; 1385 case 21: 1386 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x15, 1387 0x03, 0x70, 0x90); 1388 break; 1389 1390 case 23: 1391 case 123: 1392 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x35, 1393 0x03, 0x71, 0x10); 1394 break; 1395 case 71: 1396 btc8723b2ant_set_fw_ps_tdma( 1397 btcoexist, 0xe3, 0x3c + wifi_duration_adjust, 1398 0x03, 0xf1, 0x90); 1399 break; 1400 case 101: 1401 case 105: 1402 case 113: 1403 case 171: 1404 btc8723b2ant_set_fw_ps_tdma( 1405 btcoexist, 0xd3, 0x3a + wifi_duration_adjust, 1406 0x03, 0x70, 0x50 | tdma_byte4_modify); 1407 break; 1408 case 102: 1409 case 106: 1410 case 110: 1411 case 114: 1412 btc8723b2ant_set_fw_ps_tdma( 1413 btcoexist, 0xd3, 0x2d + wifi_duration_adjust, 1414 0x03, 0x70, 0x50 | tdma_byte4_modify); 1415 break; 1416 case 103: 1417 case 107: 1418 case 111: 1419 case 115: 1420 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xd3, 0x1c, 1421 0x03, 0x70, 1422 0x50 | tdma_byte4_modify); 1423 break; 1424 case 104: 1425 case 108: 1426 case 112: 1427 case 116: 1428 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xd3, 0x10, 1429 0x03, 0x70, 1430 0x50 | tdma_byte4_modify); 1431 break; 1432 case 109: 1433 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x3c, 1434 0x03, 0xf1, 1435 0x90 | tdma_byte4_modify); 1436 break; 1437 case 121: 1438 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x15, 1439 0x03, 0x70, 1440 0x90 | tdma_byte4_modify); 1441 break; 1442 case 22: 1443 case 122: 1444 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0xe3, 0x35, 1445 0x03, 0x71, 0x11); 1446 break; 1447 } 1448 } else { 1449 /* disable PS tdma */ 1450 switch (type) { 1451 case 0: 1452 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0x0, 0x0, 0x0, 1453 0x40, 0x0); 1454 break; 1455 case 1: 1456 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0x0, 0x0, 0x0, 1457 0x48, 0x0); 1458 break; 1459 default: 1460 btc8723b2ant_set_fw_ps_tdma(btcoexist, 0x0, 0x0, 0x0, 1461 0x40, 0x0); 1462 break; 1463 } 1464 } 1465 1466 /* update pre state */ 1467 coex_dm->pre_ps_tdma_on = coex_dm->cur_ps_tdma_on; 1468 coex_dm->pre_ps_tdma = coex_dm->cur_ps_tdma; 1469 } 1470 1471 static void btc8723b2ant_ps_tdma_check_for_power_save_state( 1472 struct btc_coexist *btcoexist, bool new_ps_state) 1473 { 1474 u8 lps_mode = 0x0; 1475 1476 btcoexist->btc_get(btcoexist, BTC_GET_U1_LPS_MODE, &lps_mode); 1477 1478 if (lps_mode) { 1479 /* already under LPS state */ 1480 if (new_ps_state) { 1481 /* keep state under LPS, do nothing. */ 1482 } else { 1483 /* will leave LPS state, turn off psTdma first */ 1484 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1485 } 1486 } else { 1487 /* NO PS state */ 1488 if (new_ps_state) { 1489 /* will enter LPS state, turn off psTdma first */ 1490 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1491 } else { 1492 /* keep state under NO PS state, do nothing. */ 1493 } 1494 } 1495 } 1496 1497 static void btc8723b2ant_power_save_state(struct btc_coexist *btcoexist, 1498 u8 ps_type, u8 lps_val, u8 rpwm_val) 1499 { 1500 bool low_pwr_disable = false; 1501 1502 switch (ps_type) { 1503 case BTC_PS_WIFI_NATIVE: 1504 /* recover to original 32k low power setting */ 1505 low_pwr_disable = false; 1506 btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER, 1507 &low_pwr_disable); 1508 btcoexist->btc_set(btcoexist, BTC_SET_ACT_NORMAL_LPS, NULL); 1509 coex_sta->force_lps_on = false; 1510 break; 1511 case BTC_PS_LPS_ON: 1512 btc8723b2ant_ps_tdma_check_for_power_save_state(btcoexist, 1513 true); 1514 btc8723b2ant_lps_rpwm(btcoexist, NORMAL_EXEC, lps_val, 1515 rpwm_val); 1516 /* when coex force to enter LPS, do not enter 32k low power */ 1517 low_pwr_disable = true; 1518 btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER, 1519 &low_pwr_disable); 1520 /* power save must executed before psTdma */ 1521 btcoexist->btc_set(btcoexist, BTC_SET_ACT_ENTER_LPS, NULL); 1522 coex_sta->force_lps_on = true; 1523 break; 1524 case BTC_PS_LPS_OFF: 1525 btc8723b2ant_ps_tdma_check_for_power_save_state(btcoexist, 1526 false); 1527 btcoexist->btc_set(btcoexist, BTC_SET_ACT_LEAVE_LPS, NULL); 1528 coex_sta->force_lps_on = false; 1529 break; 1530 default: 1531 break; 1532 } 1533 } 1534 1535 static void btc8723b2ant_coex_alloff(struct btc_coexist *btcoexist) 1536 { 1537 /* fw all off */ 1538 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0); 1539 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1540 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 1541 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 1542 1543 /* sw all off */ 1544 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, false); 1545 1546 /* hw all off */ 1547 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 1548 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 1549 } 1550 1551 static void btc8723b2ant_init_coex_dm(struct btc_coexist *btcoexist) 1552 { 1553 /* force to reset coex mechanism*/ 1554 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 1555 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0); 1556 1557 btc8723b2ant_ps_tdma(btcoexist, FORCE_EXEC, false, 1); 1558 btc8723b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6); 1559 btc8723b2ant_dec_bt_pwr(btcoexist, FORCE_EXEC, 0); 1560 1561 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, false); 1562 1563 coex_sta->pop_event_cnt = 0; 1564 } 1565 1566 static void btc8723b2ant_action_bt_inquiry(struct btc_coexist *btcoexist) 1567 { 1568 struct rtl_priv *rtlpriv = btcoexist->adapter; 1569 bool wifi_connected = false; 1570 bool low_pwr_disable = true; 1571 bool scan = false, link = false, roam = false; 1572 1573 btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER, 1574 &low_pwr_disable); 1575 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, 1576 &wifi_connected); 1577 1578 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan); 1579 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link); 1580 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam); 1581 1582 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0); 1583 1584 if (coex_sta->bt_abnormal_scan) { 1585 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 23); 1586 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 3); 1587 } else if (scan || link || roam) { 1588 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1589 "[BTCoex], Wifi link process + BT Inq/Page!!\n"); 1590 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 15); 1591 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22); 1592 } else if (wifi_connected) { 1593 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1594 "[BTCoex], Wifi connected + BT Inq/Page!!\n"); 1595 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 15); 1596 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22); 1597 } else { 1598 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 1599 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1600 } 1601 btc8723b2ant_fw_dac_swing_lvl(btcoexist, FORCE_EXEC, 6); 1602 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 1603 1604 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, false); 1605 } 1606 1607 static void btc8723b2ant_action_wifi_link_process(struct btc_coexist 1608 *btcoexist) 1609 { 1610 struct rtl_priv *rtlpriv = btcoexist->adapter; 1611 u32 u32tmp; 1612 u8 u8tmpa, u8tmpb; 1613 1614 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 15); 1615 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 22); 1616 1617 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, false); 1618 1619 u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948); 1620 u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765); 1621 u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e); 1622 1623 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1624 "[BTCoex], 0x948 = 0x%x, 0x765 = 0x%x, 0x76e = 0x%x\n", 1625 u32tmp, u8tmpa, u8tmpb); 1626 } 1627 1628 static bool btc8723b2ant_action_wifi_idle_process(struct btc_coexist *btcoexist) 1629 { 1630 struct rtl_priv *rtlpriv = btcoexist->adapter; 1631 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 1632 u8 ap_num = 0; 1633 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 1634 coex_dm->switch_thres_offset - coex_dm->switch_thres_offset; 1635 1636 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 1637 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 1638 tmp, 0); 1639 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 1640 coex_dm->switch_thres_offset - coex_dm->switch_thres_offset; 1641 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 1642 1643 btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num); 1644 1645 /* office environment */ 1646 if (BTC_RSSI_HIGH(wifi_rssi_state1) && (coex_sta->hid_exist) && 1647 (coex_sta->a2dp_exist)) { 1648 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1649 "[BTCoex], Wifi idle process for BT HID+A2DP exist!!\n"); 1650 1651 btc8723b2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x6); 1652 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 1653 1654 /* sw all off */ 1655 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, 1656 false); 1657 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 1658 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 1659 0x0, 0x0); 1660 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1661 1662 return true; 1663 } 1664 1665 btc8723b2ant_dac_swing(btcoexist, NORMAL_EXEC, true, 0x18); 1666 return false; 1667 } 1668 1669 static bool btc8723b2ant_is_common_action(struct btc_coexist *btcoexist) 1670 { 1671 struct rtl_priv *rtlpriv = btcoexist->adapter; 1672 bool common = false, wifi_connected = false; 1673 bool wifi_busy = false; 1674 bool bt_hs_on = false, low_pwr_disable = false; 1675 1676 btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on); 1677 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, 1678 &wifi_connected); 1679 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy); 1680 1681 if (!wifi_connected) { 1682 low_pwr_disable = false; 1683 btcoexist->btc_set(btcoexist, BTC_SET_ACT_DISABLE_LOW_POWER, 1684 &low_pwr_disable); 1685 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, 1686 false, false, 0x8); 1687 1688 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1689 "[BTCoex], Wifi non-connected idle!!\n"); 1690 1691 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 1692 0x0); 1693 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 1694 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1695 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 1696 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 1697 1698 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, 1699 false); 1700 1701 common = true; 1702 } else { 1703 if (BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE == 1704 coex_dm->bt_status) { 1705 low_pwr_disable = false; 1706 btcoexist->btc_set(btcoexist, 1707 BTC_SET_ACT_DISABLE_LOW_POWER, 1708 &low_pwr_disable); 1709 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, 1710 false, false, 0x8); 1711 1712 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1713 "[BTCoex], Wifi connected + BT non connected-idle!!\n"); 1714 1715 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 1716 0xfffff, 0x0); 1717 btc8723b2ant_coex_table_with_type(btcoexist, 1718 NORMAL_EXEC, 0); 1719 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1720 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 1721 0xb); 1722 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 1723 1724 btc8723b2ant_sw_mechanism(btcoexist, false, false, 1725 false, false); 1726 1727 common = true; 1728 } else if (BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE == 1729 coex_dm->bt_status) { 1730 low_pwr_disable = true; 1731 btcoexist->btc_set(btcoexist, 1732 BTC_SET_ACT_DISABLE_LOW_POWER, 1733 &low_pwr_disable); 1734 1735 if (bt_hs_on) 1736 return false; 1737 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1738 "[BTCoex], Wifi connected + BT connected-idle!!\n"); 1739 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, 1740 false, false, 0x8); 1741 1742 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 1743 0xfffff, 0x0); 1744 btc8723b2ant_coex_table_with_type(btcoexist, 1745 NORMAL_EXEC, 0); 1746 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 1747 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 1748 0xb); 1749 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 1750 1751 btc8723b2ant_sw_mechanism(btcoexist, true, false, 1752 false, false); 1753 1754 common = true; 1755 } else { 1756 low_pwr_disable = true; 1757 btcoexist->btc_set(btcoexist, 1758 BTC_SET_ACT_DISABLE_LOW_POWER, 1759 &low_pwr_disable); 1760 1761 if (wifi_busy) { 1762 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1763 "[BTCoex], Wifi Connected-Busy + BT Busy!!\n"); 1764 common = false; 1765 } else { 1766 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1767 "[BTCoex], Wifi Connected-Idle + BT Busy!!\n"); 1768 1769 common = 1770 btc8723b2ant_action_wifi_idle_process( 1771 btcoexist); 1772 } 1773 } 1774 } 1775 1776 return common; 1777 } 1778 1779 static void btc8723b2ant_tdma_duration_adjust(struct btc_coexist *btcoexist, 1780 bool sco_hid, bool tx_pause, 1781 u8 max_interval) 1782 { 1783 struct rtl_priv *rtlpriv = btcoexist->adapter; 1784 static s32 up, dn, m, n, wait_count; 1785 /*0: no change, +1: increase WiFi duration, -1: decrease WiFi duration*/ 1786 s32 result; 1787 u8 retry_count = 0; 1788 1789 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1790 "[BTCoex], TdmaDurationAdjust()\n"); 1791 1792 if (!coex_dm->auto_tdma_adjust) { 1793 coex_dm->auto_tdma_adjust = true; 1794 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1795 "[BTCoex], first run TdmaDurationAdjust()!!\n"); 1796 if (sco_hid) { 1797 if (tx_pause) { 1798 if (max_interval == 1) { 1799 btc8723b2ant_ps_tdma(btcoexist, 1800 NORMAL_EXEC, 1801 true, 13); 1802 coex_dm->ps_tdma_du_adj_type = 13; 1803 } else if (max_interval == 2) { 1804 btc8723b2ant_ps_tdma(btcoexist, 1805 NORMAL_EXEC, 1806 true, 14); 1807 coex_dm->ps_tdma_du_adj_type = 14; 1808 } else if (max_interval == 3) { 1809 btc8723b2ant_ps_tdma(btcoexist, 1810 NORMAL_EXEC, 1811 true, 15); 1812 coex_dm->ps_tdma_du_adj_type = 15; 1813 } else { 1814 btc8723b2ant_ps_tdma(btcoexist, 1815 NORMAL_EXEC, 1816 true, 15); 1817 coex_dm->ps_tdma_du_adj_type = 15; 1818 } 1819 } else { 1820 if (max_interval == 1) { 1821 btc8723b2ant_ps_tdma(btcoexist, 1822 NORMAL_EXEC, 1823 true, 9); 1824 coex_dm->ps_tdma_du_adj_type = 9; 1825 } else if (max_interval == 2) { 1826 btc8723b2ant_ps_tdma(btcoexist, 1827 NORMAL_EXEC, 1828 true, 10); 1829 coex_dm->ps_tdma_du_adj_type = 10; 1830 } else if (max_interval == 3) { 1831 btc8723b2ant_ps_tdma(btcoexist, 1832 NORMAL_EXEC, 1833 true, 11); 1834 coex_dm->ps_tdma_du_adj_type = 11; 1835 } else { 1836 btc8723b2ant_ps_tdma(btcoexist, 1837 NORMAL_EXEC, 1838 true, 11); 1839 coex_dm->ps_tdma_du_adj_type = 11; 1840 } 1841 } 1842 } else { 1843 if (tx_pause) { 1844 if (max_interval == 1) { 1845 btc8723b2ant_ps_tdma(btcoexist, 1846 NORMAL_EXEC, 1847 true, 5); 1848 coex_dm->ps_tdma_du_adj_type = 5; 1849 } else if (max_interval == 2) { 1850 btc8723b2ant_ps_tdma(btcoexist, 1851 NORMAL_EXEC, 1852 true, 6); 1853 coex_dm->ps_tdma_du_adj_type = 6; 1854 } else if (max_interval == 3) { 1855 btc8723b2ant_ps_tdma(btcoexist, 1856 NORMAL_EXEC, 1857 true, 7); 1858 coex_dm->ps_tdma_du_adj_type = 7; 1859 } else { 1860 btc8723b2ant_ps_tdma(btcoexist, 1861 NORMAL_EXEC, 1862 true, 7); 1863 coex_dm->ps_tdma_du_adj_type = 7; 1864 } 1865 } else { 1866 if (max_interval == 1) { 1867 btc8723b2ant_ps_tdma(btcoexist, 1868 NORMAL_EXEC, 1869 true, 1); 1870 coex_dm->ps_tdma_du_adj_type = 1; 1871 } else if (max_interval == 2) { 1872 btc8723b2ant_ps_tdma(btcoexist, 1873 NORMAL_EXEC, 1874 true, 2); 1875 coex_dm->ps_tdma_du_adj_type = 2; 1876 } else if (max_interval == 3) { 1877 btc8723b2ant_ps_tdma(btcoexist, 1878 NORMAL_EXEC, 1879 true, 3); 1880 coex_dm->ps_tdma_du_adj_type = 3; 1881 } else { 1882 btc8723b2ant_ps_tdma(btcoexist, 1883 NORMAL_EXEC, 1884 true, 3); 1885 coex_dm->ps_tdma_du_adj_type = 3; 1886 } 1887 } 1888 } 1889 1890 up = 0; 1891 dn = 0; 1892 m = 1; 1893 n = 3; 1894 result = 0; 1895 wait_count = 0; 1896 } else { 1897 /*accquire the BT TRx retry count from BT_Info byte2*/ 1898 retry_count = coex_sta->bt_retry_cnt; 1899 1900 if ((coex_sta->low_priority_tx) > 1050 || 1901 (coex_sta->low_priority_rx) > 1250) 1902 retry_count++; 1903 1904 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1905 "[BTCoex], retry_count = %d\n", retry_count); 1906 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1907 "[BTCoex], up=%d, dn=%d, m=%d, n=%d, wait_count=%d\n", 1908 up, dn, m, n, wait_count); 1909 result = 0; 1910 wait_count++; 1911 /* no retry in the last 2-second duration*/ 1912 if (retry_count == 0) { 1913 up++; 1914 dn--; 1915 1916 if (dn <= 0) 1917 dn = 0; 1918 1919 if (up >= n) { 1920 /* if retry count during continuous n*2 1921 * seconds is 0, enlarge WiFi duration 1922 */ 1923 wait_count = 0; 1924 n = 3; 1925 up = 0; 1926 dn = 0; 1927 result = 1; 1928 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1929 "[BTCoex], Increase wifi duration!!\n"); 1930 } /* <=3 retry in the last 2-second duration*/ 1931 } else if (retry_count <= 3) { 1932 up--; 1933 dn++; 1934 1935 if (up <= 0) 1936 up = 0; 1937 1938 if (dn == 2) { 1939 /* if continuous 2 retry count(every 2 1940 * seconds) >0 and < 3, reduce WiFi duration 1941 */ 1942 if (wait_count <= 2) 1943 /* avoid loop between the two levels */ 1944 m++; 1945 else 1946 m = 1; 1947 1948 if (m >= 20) 1949 /* maximum of m = 20 ' will recheck if 1950 * need to adjust wifi duration in 1951 * maximum time interval 120 seconds 1952 */ 1953 m = 20; 1954 1955 n = 3 * m; 1956 up = 0; 1957 dn = 0; 1958 wait_count = 0; 1959 result = -1; 1960 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1961 "[BTCoex], Decrease wifi duration for retry_counter<3!!\n"); 1962 } 1963 } else { 1964 /* retry count > 3, once retry count > 3, to reduce 1965 * WiFi duration 1966 */ 1967 if (wait_count == 1) 1968 /* to avoid loop between the two levels */ 1969 m++; 1970 else 1971 m = 1; 1972 1973 if (m >= 20) 1974 /* maximum of m = 20 ' will recheck if need to 1975 * adjust wifi duration in maximum time interval 1976 * 120 seconds 1977 */ 1978 m = 20; 1979 1980 n = 3 * m; 1981 up = 0; 1982 dn = 0; 1983 wait_count = 0; 1984 result = -1; 1985 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1986 "[BTCoex], Decrease wifi duration for retry_counter>3!!\n"); 1987 } 1988 1989 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 1990 "[BTCoex], max Interval = %d\n", max_interval); 1991 if (max_interval == 1) { 1992 if (tx_pause) { 1993 if (coex_dm->cur_ps_tdma == 71) { 1994 btc8723b2ant_ps_tdma(btcoexist, 1995 NORMAL_EXEC, 1996 true, 5); 1997 coex_dm->ps_tdma_du_adj_type = 5; 1998 } else if (coex_dm->cur_ps_tdma == 1) { 1999 btc8723b2ant_ps_tdma(btcoexist, 2000 NORMAL_EXEC, 2001 true, 5); 2002 coex_dm->ps_tdma_du_adj_type = 5; 2003 } else if (coex_dm->cur_ps_tdma == 2) { 2004 btc8723b2ant_ps_tdma(btcoexist, 2005 NORMAL_EXEC, 2006 true, 6); 2007 coex_dm->ps_tdma_du_adj_type = 6; 2008 } else if (coex_dm->cur_ps_tdma == 3) { 2009 btc8723b2ant_ps_tdma(btcoexist, 2010 NORMAL_EXEC, 2011 true, 7); 2012 coex_dm->ps_tdma_du_adj_type = 7; 2013 } else if (coex_dm->cur_ps_tdma == 4) { 2014 btc8723b2ant_ps_tdma(btcoexist, 2015 NORMAL_EXEC, 2016 true, 8); 2017 coex_dm->ps_tdma_du_adj_type = 8; 2018 } 2019 if (coex_dm->cur_ps_tdma == 9) { 2020 btc8723b2ant_ps_tdma(btcoexist, 2021 NORMAL_EXEC, 2022 true, 13); 2023 coex_dm->ps_tdma_du_adj_type = 13; 2024 } else if (coex_dm->cur_ps_tdma == 10) { 2025 btc8723b2ant_ps_tdma(btcoexist, 2026 NORMAL_EXEC, 2027 true, 14); 2028 coex_dm->ps_tdma_du_adj_type = 14; 2029 } else if (coex_dm->cur_ps_tdma == 11) { 2030 btc8723b2ant_ps_tdma(btcoexist, 2031 NORMAL_EXEC, 2032 true, 15); 2033 coex_dm->ps_tdma_du_adj_type = 15; 2034 } else if (coex_dm->cur_ps_tdma == 12) { 2035 btc8723b2ant_ps_tdma(btcoexist, 2036 NORMAL_EXEC, 2037 true, 16); 2038 coex_dm->ps_tdma_du_adj_type = 16; 2039 } 2040 2041 if (result == -1) { 2042 if (coex_dm->cur_ps_tdma == 5) { 2043 btc8723b2ant_ps_tdma( 2044 btcoexist, NORMAL_EXEC, 2045 true, 6); 2046 coex_dm->ps_tdma_du_adj_type = 2047 6; 2048 } else if (coex_dm->cur_ps_tdma == 6) { 2049 btc8723b2ant_ps_tdma( 2050 btcoexist, NORMAL_EXEC, 2051 true, 7); 2052 coex_dm->ps_tdma_du_adj_type = 2053 7; 2054 } else if (coex_dm->cur_ps_tdma == 7) { 2055 btc8723b2ant_ps_tdma( 2056 btcoexist, NORMAL_EXEC, 2057 true, 8); 2058 coex_dm->ps_tdma_du_adj_type = 2059 8; 2060 } else if (coex_dm->cur_ps_tdma == 13) { 2061 btc8723b2ant_ps_tdma( 2062 btcoexist, NORMAL_EXEC, 2063 true, 14); 2064 coex_dm->ps_tdma_du_adj_type = 2065 14; 2066 } else if (coex_dm->cur_ps_tdma == 14) { 2067 btc8723b2ant_ps_tdma( 2068 btcoexist, NORMAL_EXEC, 2069 true, 15); 2070 coex_dm->ps_tdma_du_adj_type = 2071 15; 2072 } else if (coex_dm->cur_ps_tdma == 15) { 2073 btc8723b2ant_ps_tdma( 2074 btcoexist, NORMAL_EXEC, 2075 true, 16); 2076 coex_dm->ps_tdma_du_adj_type = 2077 16; 2078 } 2079 } else if (result == 1) { 2080 if (coex_dm->cur_ps_tdma == 8) { 2081 btc8723b2ant_ps_tdma( 2082 btcoexist, NORMAL_EXEC, 2083 true, 7); 2084 coex_dm->ps_tdma_du_adj_type = 2085 7; 2086 } else if (coex_dm->cur_ps_tdma == 7) { 2087 btc8723b2ant_ps_tdma( 2088 btcoexist, NORMAL_EXEC, 2089 true, 6); 2090 coex_dm->ps_tdma_du_adj_type = 2091 6; 2092 } else if (coex_dm->cur_ps_tdma == 6) { 2093 btc8723b2ant_ps_tdma( 2094 btcoexist, NORMAL_EXEC, 2095 true, 5); 2096 coex_dm->ps_tdma_du_adj_type = 2097 5; 2098 } else if (coex_dm->cur_ps_tdma == 16) { 2099 btc8723b2ant_ps_tdma( 2100 btcoexist, NORMAL_EXEC, 2101 true, 15); 2102 coex_dm->ps_tdma_du_adj_type = 2103 15; 2104 } else if (coex_dm->cur_ps_tdma == 15) { 2105 btc8723b2ant_ps_tdma( 2106 btcoexist, NORMAL_EXEC, 2107 true, 14); 2108 coex_dm->ps_tdma_du_adj_type = 2109 14; 2110 } else if (coex_dm->cur_ps_tdma == 14) { 2111 btc8723b2ant_ps_tdma( 2112 btcoexist, NORMAL_EXEC, 2113 true, 13); 2114 coex_dm->ps_tdma_du_adj_type = 2115 13; 2116 } 2117 } 2118 } else { 2119 if (coex_dm->cur_ps_tdma == 5) { 2120 btc8723b2ant_ps_tdma(btcoexist, 2121 NORMAL_EXEC, 2122 true, 71); 2123 coex_dm->ps_tdma_du_adj_type = 71; 2124 } else if (coex_dm->cur_ps_tdma == 6) { 2125 btc8723b2ant_ps_tdma(btcoexist, 2126 NORMAL_EXEC, 2127 true, 2); 2128 coex_dm->ps_tdma_du_adj_type = 2; 2129 } else if (coex_dm->cur_ps_tdma == 7) { 2130 btc8723b2ant_ps_tdma(btcoexist, 2131 NORMAL_EXEC, 2132 true, 3); 2133 coex_dm->ps_tdma_du_adj_type = 3; 2134 } else if (coex_dm->cur_ps_tdma == 8) { 2135 btc8723b2ant_ps_tdma(btcoexist, 2136 NORMAL_EXEC, 2137 true, 4); 2138 coex_dm->ps_tdma_du_adj_type = 4; 2139 } 2140 if (coex_dm->cur_ps_tdma == 13) { 2141 btc8723b2ant_ps_tdma(btcoexist, 2142 NORMAL_EXEC, 2143 true, 9); 2144 coex_dm->ps_tdma_du_adj_type = 9; 2145 } else if (coex_dm->cur_ps_tdma == 14) { 2146 btc8723b2ant_ps_tdma(btcoexist, 2147 NORMAL_EXEC, 2148 true, 10); 2149 coex_dm->ps_tdma_du_adj_type = 10; 2150 } else if (coex_dm->cur_ps_tdma == 15) { 2151 btc8723b2ant_ps_tdma(btcoexist, 2152 NORMAL_EXEC, 2153 true, 11); 2154 coex_dm->ps_tdma_du_adj_type = 11; 2155 } else if (coex_dm->cur_ps_tdma == 16) { 2156 btc8723b2ant_ps_tdma(btcoexist, 2157 NORMAL_EXEC, 2158 true, 12); 2159 coex_dm->ps_tdma_du_adj_type = 12; 2160 } 2161 2162 if (result == -1) { 2163 if (coex_dm->cur_ps_tdma == 71) { 2164 btc8723b2ant_ps_tdma( 2165 btcoexist, NORMAL_EXEC, 2166 true, 1); 2167 coex_dm->ps_tdma_du_adj_type = 2168 1; 2169 } else if (coex_dm->cur_ps_tdma == 1) { 2170 btc8723b2ant_ps_tdma( 2171 btcoexist, NORMAL_EXEC, 2172 true, 2); 2173 coex_dm->ps_tdma_du_adj_type = 2174 2; 2175 } else if (coex_dm->cur_ps_tdma == 2) { 2176 btc8723b2ant_ps_tdma( 2177 btcoexist, NORMAL_EXEC, 2178 true, 3); 2179 coex_dm->ps_tdma_du_adj_type = 2180 3; 2181 } else if (coex_dm->cur_ps_tdma == 3) { 2182 btc8723b2ant_ps_tdma( 2183 btcoexist, NORMAL_EXEC, 2184 true, 4); 2185 coex_dm->ps_tdma_du_adj_type = 2186 4; 2187 } else if (coex_dm->cur_ps_tdma == 9) { 2188 btc8723b2ant_ps_tdma( 2189 btcoexist, NORMAL_EXEC, 2190 true, 10); 2191 coex_dm->ps_tdma_du_adj_type = 2192 10; 2193 } else if (coex_dm->cur_ps_tdma == 10) { 2194 btc8723b2ant_ps_tdma( 2195 btcoexist, NORMAL_EXEC, 2196 true, 11); 2197 coex_dm->ps_tdma_du_adj_type = 2198 11; 2199 } else if (coex_dm->cur_ps_tdma == 11) { 2200 btc8723b2ant_ps_tdma( 2201 btcoexist, NORMAL_EXEC, 2202 true, 12); 2203 coex_dm->ps_tdma_du_adj_type = 2204 12; 2205 } 2206 } else if (result == 1) { 2207 if (coex_dm->cur_ps_tdma == 4) { 2208 btc8723b2ant_ps_tdma( 2209 btcoexist, NORMAL_EXEC, 2210 true, 3); 2211 coex_dm->ps_tdma_du_adj_type = 2212 3; 2213 } else if (coex_dm->cur_ps_tdma == 3) { 2214 btc8723b2ant_ps_tdma( 2215 btcoexist, NORMAL_EXEC, 2216 true, 2); 2217 coex_dm->ps_tdma_du_adj_type = 2218 2; 2219 } else if (coex_dm->cur_ps_tdma == 2) { 2220 btc8723b2ant_ps_tdma( 2221 btcoexist, NORMAL_EXEC, 2222 true, 1); 2223 coex_dm->ps_tdma_du_adj_type = 2224 1; 2225 } else if (coex_dm->cur_ps_tdma == 1) { 2226 btc8723b2ant_ps_tdma( 2227 btcoexist, NORMAL_EXEC, 2228 true, 71); 2229 coex_dm->ps_tdma_du_adj_type = 2230 71; 2231 } else if (coex_dm->cur_ps_tdma == 12) { 2232 btc8723b2ant_ps_tdma( 2233 btcoexist, NORMAL_EXEC, 2234 true, 11); 2235 coex_dm->ps_tdma_du_adj_type = 2236 11; 2237 } else if (coex_dm->cur_ps_tdma == 11) { 2238 btc8723b2ant_ps_tdma( 2239 btcoexist, NORMAL_EXEC, 2240 true, 10); 2241 coex_dm->ps_tdma_du_adj_type = 2242 10; 2243 } else if (coex_dm->cur_ps_tdma == 10) { 2244 btc8723b2ant_ps_tdma( 2245 btcoexist, NORMAL_EXEC, 2246 true, 9); 2247 coex_dm->ps_tdma_du_adj_type = 2248 9; 2249 } 2250 } 2251 } 2252 } else if (max_interval == 2) { 2253 if (tx_pause) { 2254 if (coex_dm->cur_ps_tdma == 1) { 2255 btc8723b2ant_ps_tdma(btcoexist, 2256 NORMAL_EXEC, 2257 true, 6); 2258 coex_dm->ps_tdma_du_adj_type = 6; 2259 } else if (coex_dm->cur_ps_tdma == 2) { 2260 btc8723b2ant_ps_tdma(btcoexist, 2261 NORMAL_EXEC, 2262 true, 6); 2263 coex_dm->ps_tdma_du_adj_type = 6; 2264 } else if (coex_dm->cur_ps_tdma == 3) { 2265 btc8723b2ant_ps_tdma(btcoexist, 2266 NORMAL_EXEC, 2267 true, 7); 2268 coex_dm->ps_tdma_du_adj_type = 7; 2269 } else if (coex_dm->cur_ps_tdma == 4) { 2270 btc8723b2ant_ps_tdma(btcoexist, 2271 NORMAL_EXEC, 2272 true, 8); 2273 coex_dm->ps_tdma_du_adj_type = 8; 2274 } 2275 if (coex_dm->cur_ps_tdma == 9) { 2276 btc8723b2ant_ps_tdma(btcoexist, 2277 NORMAL_EXEC, 2278 true, 14); 2279 coex_dm->ps_tdma_du_adj_type = 14; 2280 } else if (coex_dm->cur_ps_tdma == 10) { 2281 btc8723b2ant_ps_tdma(btcoexist, 2282 NORMAL_EXEC, 2283 true, 14); 2284 coex_dm->ps_tdma_du_adj_type = 14; 2285 } else if (coex_dm->cur_ps_tdma == 11) { 2286 btc8723b2ant_ps_tdma(btcoexist, 2287 NORMAL_EXEC, 2288 true, 15); 2289 coex_dm->ps_tdma_du_adj_type = 15; 2290 } else if (coex_dm->cur_ps_tdma == 12) { 2291 btc8723b2ant_ps_tdma(btcoexist, 2292 NORMAL_EXEC, 2293 true, 16); 2294 coex_dm->ps_tdma_du_adj_type = 16; 2295 } 2296 if (result == -1) { 2297 if (coex_dm->cur_ps_tdma == 5) { 2298 btc8723b2ant_ps_tdma( 2299 btcoexist, NORMAL_EXEC, 2300 true, 6); 2301 coex_dm->ps_tdma_du_adj_type = 2302 6; 2303 } else if (coex_dm->cur_ps_tdma == 6) { 2304 btc8723b2ant_ps_tdma( 2305 btcoexist, NORMAL_EXEC, 2306 true, 7); 2307 coex_dm->ps_tdma_du_adj_type = 2308 7; 2309 } else if (coex_dm->cur_ps_tdma == 7) { 2310 btc8723b2ant_ps_tdma( 2311 btcoexist, NORMAL_EXEC, 2312 true, 8); 2313 coex_dm->ps_tdma_du_adj_type = 2314 8; 2315 } else if (coex_dm->cur_ps_tdma == 13) { 2316 btc8723b2ant_ps_tdma( 2317 btcoexist, NORMAL_EXEC, 2318 true, 14); 2319 coex_dm->ps_tdma_du_adj_type = 2320 14; 2321 } else if (coex_dm->cur_ps_tdma == 14) { 2322 btc8723b2ant_ps_tdma( 2323 btcoexist, NORMAL_EXEC, 2324 true, 15); 2325 coex_dm->ps_tdma_du_adj_type = 2326 15; 2327 } else if (coex_dm->cur_ps_tdma == 15) { 2328 btc8723b2ant_ps_tdma( 2329 btcoexist, NORMAL_EXEC, 2330 true, 16); 2331 coex_dm->ps_tdma_du_adj_type = 2332 16; 2333 } 2334 } else if (result == 1) { 2335 if (coex_dm->cur_ps_tdma == 8) { 2336 btc8723b2ant_ps_tdma( 2337 btcoexist, NORMAL_EXEC, 2338 true, 7); 2339 coex_dm->ps_tdma_du_adj_type = 2340 7; 2341 } else if (coex_dm->cur_ps_tdma == 7) { 2342 btc8723b2ant_ps_tdma( 2343 btcoexist, NORMAL_EXEC, 2344 true, 6); 2345 coex_dm->ps_tdma_du_adj_type = 2346 6; 2347 } else if (coex_dm->cur_ps_tdma == 6) { 2348 btc8723b2ant_ps_tdma( 2349 btcoexist, NORMAL_EXEC, 2350 true, 6); 2351 coex_dm->ps_tdma_du_adj_type = 2352 6; 2353 } else if (coex_dm->cur_ps_tdma == 16) { 2354 btc8723b2ant_ps_tdma( 2355 btcoexist, NORMAL_EXEC, 2356 true, 15); 2357 coex_dm->ps_tdma_du_adj_type = 2358 15; 2359 } else if (coex_dm->cur_ps_tdma == 15) { 2360 btc8723b2ant_ps_tdma( 2361 btcoexist, NORMAL_EXEC, 2362 true, 14); 2363 coex_dm->ps_tdma_du_adj_type = 2364 14; 2365 } else if (coex_dm->cur_ps_tdma == 14) { 2366 btc8723b2ant_ps_tdma( 2367 btcoexist, NORMAL_EXEC, 2368 true, 14); 2369 coex_dm->ps_tdma_du_adj_type = 2370 14; 2371 } 2372 } 2373 } else { 2374 if (coex_dm->cur_ps_tdma == 5) { 2375 btc8723b2ant_ps_tdma(btcoexist, 2376 NORMAL_EXEC, 2377 true, 2); 2378 coex_dm->ps_tdma_du_adj_type = 2; 2379 } else if (coex_dm->cur_ps_tdma == 6) { 2380 btc8723b2ant_ps_tdma(btcoexist, 2381 NORMAL_EXEC, 2382 true, 2); 2383 coex_dm->ps_tdma_du_adj_type = 2; 2384 } else if (coex_dm->cur_ps_tdma == 7) { 2385 btc8723b2ant_ps_tdma(btcoexist, 2386 NORMAL_EXEC, 2387 true, 3); 2388 coex_dm->ps_tdma_du_adj_type = 3; 2389 } else if (coex_dm->cur_ps_tdma == 8) { 2390 btc8723b2ant_ps_tdma(btcoexist, 2391 NORMAL_EXEC, 2392 true, 4); 2393 coex_dm->ps_tdma_du_adj_type = 4; 2394 } 2395 if (coex_dm->cur_ps_tdma == 13) { 2396 btc8723b2ant_ps_tdma(btcoexist, 2397 NORMAL_EXEC, 2398 true, 10); 2399 coex_dm->ps_tdma_du_adj_type = 10; 2400 } else if (coex_dm->cur_ps_tdma == 14) { 2401 btc8723b2ant_ps_tdma(btcoexist, 2402 NORMAL_EXEC, 2403 true, 10); 2404 coex_dm->ps_tdma_du_adj_type = 10; 2405 } else if (coex_dm->cur_ps_tdma == 15) { 2406 btc8723b2ant_ps_tdma(btcoexist, 2407 NORMAL_EXEC, 2408 true, 11); 2409 coex_dm->ps_tdma_du_adj_type = 11; 2410 } else if (coex_dm->cur_ps_tdma == 16) { 2411 btc8723b2ant_ps_tdma(btcoexist, 2412 NORMAL_EXEC, 2413 true, 12); 2414 coex_dm->ps_tdma_du_adj_type = 12; 2415 } 2416 if (result == -1) { 2417 if (coex_dm->cur_ps_tdma == 1) { 2418 btc8723b2ant_ps_tdma( 2419 btcoexist, NORMAL_EXEC, 2420 true, 2); 2421 coex_dm->ps_tdma_du_adj_type = 2422 2; 2423 } else if (coex_dm->cur_ps_tdma == 2) { 2424 btc8723b2ant_ps_tdma( 2425 btcoexist, NORMAL_EXEC, 2426 true, 3); 2427 coex_dm->ps_tdma_du_adj_type = 2428 3; 2429 } else if (coex_dm->cur_ps_tdma == 3) { 2430 btc8723b2ant_ps_tdma( 2431 btcoexist, NORMAL_EXEC, 2432 true, 4); 2433 coex_dm->ps_tdma_du_adj_type = 2434 4; 2435 } else if (coex_dm->cur_ps_tdma == 9) { 2436 btc8723b2ant_ps_tdma( 2437 btcoexist, NORMAL_EXEC, 2438 true, 10); 2439 coex_dm->ps_tdma_du_adj_type = 2440 10; 2441 } else if (coex_dm->cur_ps_tdma == 10) { 2442 btc8723b2ant_ps_tdma( 2443 btcoexist, NORMAL_EXEC, 2444 true, 11); 2445 coex_dm->ps_tdma_du_adj_type = 2446 11; 2447 } else if (coex_dm->cur_ps_tdma == 11) { 2448 btc8723b2ant_ps_tdma( 2449 btcoexist, NORMAL_EXEC, 2450 true, 12); 2451 coex_dm->ps_tdma_du_adj_type = 2452 12; 2453 } 2454 } else if (result == 1) { 2455 if (coex_dm->cur_ps_tdma == 4) { 2456 btc8723b2ant_ps_tdma( 2457 btcoexist, NORMAL_EXEC, 2458 true, 3); 2459 coex_dm->ps_tdma_du_adj_type = 2460 3; 2461 } else if (coex_dm->cur_ps_tdma == 3) { 2462 btc8723b2ant_ps_tdma( 2463 btcoexist, NORMAL_EXEC, 2464 true, 2); 2465 coex_dm->ps_tdma_du_adj_type = 2466 2; 2467 } else if (coex_dm->cur_ps_tdma == 2) { 2468 btc8723b2ant_ps_tdma( 2469 btcoexist, NORMAL_EXEC, 2470 true, 2); 2471 coex_dm->ps_tdma_du_adj_type = 2472 2; 2473 } else if (coex_dm->cur_ps_tdma == 12) { 2474 btc8723b2ant_ps_tdma( 2475 btcoexist, NORMAL_EXEC, 2476 true, 11); 2477 coex_dm->ps_tdma_du_adj_type = 2478 11; 2479 } else if (coex_dm->cur_ps_tdma == 11) { 2480 btc8723b2ant_ps_tdma( 2481 btcoexist, NORMAL_EXEC, 2482 true, 10); 2483 coex_dm->ps_tdma_du_adj_type = 2484 10; 2485 } else if (coex_dm->cur_ps_tdma == 10) { 2486 btc8723b2ant_ps_tdma( 2487 btcoexist, NORMAL_EXEC, 2488 true, 10); 2489 coex_dm->ps_tdma_du_adj_type = 2490 10; 2491 } 2492 } 2493 } 2494 } else if (max_interval == 3) { 2495 if (tx_pause) { 2496 if (coex_dm->cur_ps_tdma == 1) { 2497 btc8723b2ant_ps_tdma(btcoexist, 2498 NORMAL_EXEC, 2499 true, 7); 2500 coex_dm->ps_tdma_du_adj_type = 7; 2501 } else if (coex_dm->cur_ps_tdma == 2) { 2502 btc8723b2ant_ps_tdma(btcoexist, 2503 NORMAL_EXEC, 2504 true, 7); 2505 coex_dm->ps_tdma_du_adj_type = 7; 2506 } else if (coex_dm->cur_ps_tdma == 3) { 2507 btc8723b2ant_ps_tdma(btcoexist, 2508 NORMAL_EXEC, 2509 true, 7); 2510 coex_dm->ps_tdma_du_adj_type = 7; 2511 } else if (coex_dm->cur_ps_tdma == 4) { 2512 btc8723b2ant_ps_tdma(btcoexist, 2513 NORMAL_EXEC, 2514 true, 8); 2515 coex_dm->ps_tdma_du_adj_type = 8; 2516 } 2517 if (coex_dm->cur_ps_tdma == 9) { 2518 btc8723b2ant_ps_tdma(btcoexist, 2519 NORMAL_EXEC, 2520 true, 15); 2521 coex_dm->ps_tdma_du_adj_type = 15; 2522 } else if (coex_dm->cur_ps_tdma == 10) { 2523 btc8723b2ant_ps_tdma(btcoexist, 2524 NORMAL_EXEC, 2525 true, 15); 2526 coex_dm->ps_tdma_du_adj_type = 15; 2527 } else if (coex_dm->cur_ps_tdma == 11) { 2528 btc8723b2ant_ps_tdma(btcoexist, 2529 NORMAL_EXEC, 2530 true, 15); 2531 coex_dm->ps_tdma_du_adj_type = 15; 2532 } else if (coex_dm->cur_ps_tdma == 12) { 2533 btc8723b2ant_ps_tdma(btcoexist, 2534 NORMAL_EXEC, 2535 true, 16); 2536 coex_dm->ps_tdma_du_adj_type = 16; 2537 } 2538 if (result == -1) { 2539 if (coex_dm->cur_ps_tdma == 5) { 2540 btc8723b2ant_ps_tdma( 2541 btcoexist, NORMAL_EXEC, 2542 true, 7); 2543 coex_dm->ps_tdma_du_adj_type = 2544 7; 2545 } else if (coex_dm->cur_ps_tdma == 6) { 2546 btc8723b2ant_ps_tdma( 2547 btcoexist, NORMAL_EXEC, 2548 true, 7); 2549 coex_dm->ps_tdma_du_adj_type = 2550 7; 2551 } else if (coex_dm->cur_ps_tdma == 7) { 2552 btc8723b2ant_ps_tdma( 2553 btcoexist, NORMAL_EXEC, 2554 true, 8); 2555 coex_dm->ps_tdma_du_adj_type = 2556 8; 2557 } else if (coex_dm->cur_ps_tdma == 13) { 2558 btc8723b2ant_ps_tdma( 2559 btcoexist, NORMAL_EXEC, 2560 true, 15); 2561 coex_dm->ps_tdma_du_adj_type = 2562 15; 2563 } else if (coex_dm->cur_ps_tdma == 14) { 2564 btc8723b2ant_ps_tdma( 2565 btcoexist, NORMAL_EXEC, 2566 true, 15); 2567 coex_dm->ps_tdma_du_adj_type = 2568 15; 2569 } else if (coex_dm->cur_ps_tdma == 15) { 2570 btc8723b2ant_ps_tdma( 2571 btcoexist, NORMAL_EXEC, 2572 true, 16); 2573 coex_dm->ps_tdma_du_adj_type = 2574 16; 2575 } 2576 } else if (result == 1) { 2577 if (coex_dm->cur_ps_tdma == 8) { 2578 btc8723b2ant_ps_tdma( 2579 btcoexist, NORMAL_EXEC, 2580 true, 7); 2581 coex_dm->ps_tdma_du_adj_type = 2582 7; 2583 } else if (coex_dm->cur_ps_tdma == 7) { 2584 btc8723b2ant_ps_tdma( 2585 btcoexist, NORMAL_EXEC, 2586 true, 7); 2587 coex_dm->ps_tdma_du_adj_type = 2588 7; 2589 } else if (coex_dm->cur_ps_tdma == 6) { 2590 btc8723b2ant_ps_tdma( 2591 btcoexist, NORMAL_EXEC, 2592 true, 7); 2593 coex_dm->ps_tdma_du_adj_type = 2594 7; 2595 } else if (coex_dm->cur_ps_tdma == 16) { 2596 btc8723b2ant_ps_tdma( 2597 btcoexist, NORMAL_EXEC, 2598 true, 15); 2599 coex_dm->ps_tdma_du_adj_type = 2600 15; 2601 } else if (coex_dm->cur_ps_tdma == 15) { 2602 btc8723b2ant_ps_tdma( 2603 btcoexist, NORMAL_EXEC, 2604 true, 15); 2605 coex_dm->ps_tdma_du_adj_type = 2606 15; 2607 } else if (coex_dm->cur_ps_tdma == 14) { 2608 btc8723b2ant_ps_tdma( 2609 btcoexist, NORMAL_EXEC, 2610 true, 15); 2611 coex_dm->ps_tdma_du_adj_type = 2612 15; 2613 } 2614 } 2615 } else { 2616 if (coex_dm->cur_ps_tdma == 5) { 2617 btc8723b2ant_ps_tdma(btcoexist, 2618 NORMAL_EXEC, 2619 true, 3); 2620 coex_dm->ps_tdma_du_adj_type = 3; 2621 } else if (coex_dm->cur_ps_tdma == 6) { 2622 btc8723b2ant_ps_tdma(btcoexist, 2623 NORMAL_EXEC, 2624 true, 3); 2625 coex_dm->ps_tdma_du_adj_type = 3; 2626 } else if (coex_dm->cur_ps_tdma == 7) { 2627 btc8723b2ant_ps_tdma(btcoexist, 2628 NORMAL_EXEC, 2629 true, 3); 2630 coex_dm->ps_tdma_du_adj_type = 3; 2631 } else if (coex_dm->cur_ps_tdma == 8) { 2632 btc8723b2ant_ps_tdma(btcoexist, 2633 NORMAL_EXEC, 2634 true, 4); 2635 coex_dm->ps_tdma_du_adj_type = 4; 2636 } 2637 if (coex_dm->cur_ps_tdma == 13) { 2638 btc8723b2ant_ps_tdma(btcoexist, 2639 NORMAL_EXEC, 2640 true, 11); 2641 coex_dm->ps_tdma_du_adj_type = 11; 2642 } else if (coex_dm->cur_ps_tdma == 14) { 2643 btc8723b2ant_ps_tdma(btcoexist, 2644 NORMAL_EXEC, 2645 true, 11); 2646 coex_dm->ps_tdma_du_adj_type = 11; 2647 } else if (coex_dm->cur_ps_tdma == 15) { 2648 btc8723b2ant_ps_tdma(btcoexist, 2649 NORMAL_EXEC, 2650 true, 11); 2651 coex_dm->ps_tdma_du_adj_type = 11; 2652 } else if (coex_dm->cur_ps_tdma == 16) { 2653 btc8723b2ant_ps_tdma(btcoexist, 2654 NORMAL_EXEC, 2655 true, 12); 2656 coex_dm->ps_tdma_du_adj_type = 12; 2657 } 2658 if (result == -1) { 2659 if (coex_dm->cur_ps_tdma == 1) { 2660 btc8723b2ant_ps_tdma( 2661 btcoexist, NORMAL_EXEC, 2662 true, 3); 2663 coex_dm->ps_tdma_du_adj_type = 2664 3; 2665 } else if (coex_dm->cur_ps_tdma == 2) { 2666 btc8723b2ant_ps_tdma( 2667 btcoexist, NORMAL_EXEC, 2668 true, 3); 2669 coex_dm->ps_tdma_du_adj_type = 2670 3; 2671 } else if (coex_dm->cur_ps_tdma == 3) { 2672 btc8723b2ant_ps_tdma( 2673 btcoexist, NORMAL_EXEC, 2674 true, 4); 2675 coex_dm->ps_tdma_du_adj_type = 2676 4; 2677 } else if (coex_dm->cur_ps_tdma == 9) { 2678 btc8723b2ant_ps_tdma( 2679 btcoexist, NORMAL_EXEC, 2680 true, 11); 2681 coex_dm->ps_tdma_du_adj_type = 2682 11; 2683 } else if (coex_dm->cur_ps_tdma == 10) { 2684 btc8723b2ant_ps_tdma( 2685 btcoexist, NORMAL_EXEC, 2686 true, 11); 2687 coex_dm->ps_tdma_du_adj_type = 2688 11; 2689 } else if (coex_dm->cur_ps_tdma == 11) { 2690 btc8723b2ant_ps_tdma( 2691 btcoexist, NORMAL_EXEC, 2692 true, 12); 2693 coex_dm->ps_tdma_du_adj_type = 2694 12; 2695 } 2696 } else if (result == 1) { 2697 if (coex_dm->cur_ps_tdma == 4) { 2698 btc8723b2ant_ps_tdma( 2699 btcoexist, NORMAL_EXEC, 2700 true, 3); 2701 coex_dm->ps_tdma_du_adj_type = 2702 3; 2703 } else if (coex_dm->cur_ps_tdma == 3) { 2704 btc8723b2ant_ps_tdma( 2705 btcoexist, NORMAL_EXEC, 2706 true, 3); 2707 coex_dm->ps_tdma_du_adj_type = 2708 3; 2709 } else if (coex_dm->cur_ps_tdma == 2) { 2710 btc8723b2ant_ps_tdma( 2711 btcoexist, NORMAL_EXEC, 2712 true, 3); 2713 coex_dm->ps_tdma_du_adj_type = 2714 3; 2715 } else if (coex_dm->cur_ps_tdma == 12) { 2716 btc8723b2ant_ps_tdma( 2717 btcoexist, NORMAL_EXEC, 2718 true, 11); 2719 coex_dm->ps_tdma_du_adj_type = 2720 11; 2721 } else if (coex_dm->cur_ps_tdma == 11) { 2722 btc8723b2ant_ps_tdma( 2723 btcoexist, NORMAL_EXEC, 2724 true, 11); 2725 coex_dm->ps_tdma_du_adj_type = 2726 11; 2727 } else if (coex_dm->cur_ps_tdma == 10) { 2728 btc8723b2ant_ps_tdma( 2729 btcoexist, NORMAL_EXEC, 2730 true, 11); 2731 coex_dm->ps_tdma_du_adj_type = 2732 11; 2733 } 2734 } 2735 } 2736 } 2737 } 2738 2739 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 2740 "[BTCoex], max Interval = %d\n", max_interval); 2741 2742 /* if current PsTdma not match with the recorded one (scan, dhcp, ...), 2743 * then we have to adjust it back to the previous recorded one. 2744 */ 2745 if (coex_dm->cur_ps_tdma != coex_dm->ps_tdma_du_adj_type) { 2746 bool scan = false, link = false, roam = false; 2747 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 2748 "[BTCoex], PsTdma type mismatch!!!, curPsTdma=%d, recordPsTdma=%d\n", 2749 coex_dm->cur_ps_tdma, coex_dm->ps_tdma_du_adj_type); 2750 2751 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan); 2752 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link); 2753 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam); 2754 2755 if (!scan && !link && !roam) 2756 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 2757 coex_dm->ps_tdma_du_adj_type); 2758 else 2759 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 2760 "[BTCoex], roaming/link/scan is under progress, will adjust next time!!!\n"); 2761 } 2762 } 2763 2764 /* SCO only or SCO+PAN(HS) */ 2765 static void btc8723b2ant_action_sco(struct btc_coexist *btcoexist) 2766 { 2767 u8 wifi_rssi_state, bt_rssi_state; 2768 u32 wifi_bw; 2769 2770 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 2771 bt_rssi_state = btc8723b2ant_bt_rssi_state( 2772 btcoexist, 2, BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 2773 coex_dm->switch_thres_offset, 2774 0); 2775 2776 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 2777 2778 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 2779 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 4); 2780 2781 if (BTC_RSSI_HIGH(bt_rssi_state)) 2782 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 2783 else 2784 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 2785 2786 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 2787 2788 if (BTC_WIFI_BW_LEGACY == wifi_bw) 2789 /* for SCO quality at 11b/g mode */ 2790 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 2); 2791 else 2792 /* for SCO quality & wifi performance balance at 11n mode */ 2793 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 8); 2794 2795 /* for voice quality */ 2796 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 0); 2797 2798 /* sw mechanism */ 2799 if (BTC_WIFI_BW_HT40 == wifi_bw) { 2800 btc8723b2ant_sw_mechanism(btcoexist, true, true, 2801 false, false); 2802 } else { 2803 btc8723b2ant_sw_mechanism(btcoexist, false, true, 2804 false, false); 2805 } 2806 } 2807 2808 static void btc8723b2ant_action_hid(struct btc_coexist *btcoexist) 2809 { 2810 u8 wifi_rssi_state, bt_rssi_state; 2811 u32 wifi_bw; 2812 u8 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 2813 coex_dm->switch_thres_offset; 2814 2815 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 2816 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 2817 2818 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 2819 2820 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 2821 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 2822 2823 if (BTC_RSSI_HIGH(bt_rssi_state)) 2824 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 2825 else 2826 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 2827 2828 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 2829 2830 if (wifi_bw == BTC_WIFI_BW_LEGACY) 2831 /* for HID at 11b/g mode */ 2832 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 2833 else 2834 /* for HID quality & wifi performance balance at 11n mode */ 2835 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 9); 2836 2837 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0); 2838 2839 if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) || 2840 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) 2841 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 9); 2842 else 2843 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 13); 2844 2845 /* sw mechanism */ 2846 if (wifi_bw == BTC_WIFI_BW_HT40) 2847 btc8723b2ant_sw_mechanism(btcoexist, true, true, false, false); 2848 else 2849 btc8723b2ant_sw_mechanism(btcoexist, false, true, false, false); 2850 } 2851 2852 /* A2DP only / PAN(EDR) only/ A2DP+PAN(HS) */ 2853 static void btc8723b2ant_action_a2dp(struct btc_coexist *btcoexist) 2854 { 2855 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 2856 u32 wifi_bw; 2857 u8 ap_num = 0; 2858 u8 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 2859 coex_dm->switch_thres_offset; 2860 2861 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 2862 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 40, 0); 2863 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 2864 2865 btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num); 2866 2867 /* define the office environment */ 2868 /* driver don't know AP num in Linux, so we will never enter this if */ 2869 if (ap_num >= 10 && BTC_RSSI_HIGH(wifi_rssi_state1)) { 2870 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 2871 0x0); 2872 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 2873 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, false); 2874 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 2875 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 2876 2877 /* sw mechanism */ 2878 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 2879 if (BTC_WIFI_BW_HT40 == wifi_bw) { 2880 btc8723b2ant_sw_mechanism(btcoexist, true, false, 2881 false, false); 2882 } else { 2883 btc8723b2ant_sw_mechanism(btcoexist, false, false, 2884 false, false); 2885 } 2886 return; 2887 } 2888 2889 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 2890 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 2891 2892 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 2893 2894 if (BTC_RSSI_HIGH(bt_rssi_state)) 2895 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 2896 else 2897 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 2898 2899 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) { 2900 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 2901 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 2902 0x0, 0x0); 2903 } else { 2904 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13); 2905 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 2906 0x4); 2907 } 2908 2909 if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) || 2910 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) 2911 btc8723b2ant_tdma_duration_adjust(btcoexist, false, 2912 false, 1); 2913 else 2914 btc8723b2ant_tdma_duration_adjust(btcoexist, false, true, 1); 2915 2916 /* sw mechanism */ 2917 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 2918 if (BTC_WIFI_BW_HT40 == wifi_bw) { 2919 btc8723b2ant_sw_mechanism(btcoexist, true, false, 2920 false, false); 2921 } else { 2922 btc8723b2ant_sw_mechanism(btcoexist, false, false, 2923 false, false); 2924 } 2925 } 2926 2927 static void btc8723b2ant_action_a2dp_pan_hs(struct btc_coexist *btcoexist) 2928 { 2929 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 2930 u32 wifi_bw; 2931 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 2932 coex_dm->switch_thres_offset; 2933 2934 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 2935 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 2936 tmp, 0); 2937 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 2938 coex_dm->switch_thres_offset; 2939 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 2940 2941 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 2942 2943 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 2944 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 2945 2946 if (BTC_RSSI_HIGH(bt_rssi_state)) 2947 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 2948 else 2949 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 2950 2951 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) { 2952 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 2953 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 2954 0x0, 0x0); 2955 } else { 2956 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13); 2957 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 2958 0x4); 2959 } 2960 2961 btc8723b2ant_tdma_duration_adjust(btcoexist, false, true, 2); 2962 2963 /* sw mechanism */ 2964 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 2965 if (BTC_WIFI_BW_HT40 == wifi_bw) { 2966 btc8723b2ant_sw_mechanism(btcoexist, true, false, 2967 false, false); 2968 } else { 2969 btc8723b2ant_sw_mechanism(btcoexist, false, false, 2970 false, false); 2971 } 2972 } 2973 2974 static void btc8723b2ant_action_pan_edr(struct btc_coexist *btcoexist) 2975 { 2976 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 2977 u32 wifi_bw; 2978 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 2979 coex_dm->switch_thres_offset; 2980 2981 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 2982 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 2983 tmp, 0); 2984 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 2985 coex_dm->switch_thres_offset; 2986 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 2987 2988 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 2989 2990 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 2991 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 2992 2993 if (BTC_RSSI_HIGH(bt_rssi_state)) 2994 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 2995 else 2996 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 2997 2998 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) { 2999 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 10); 3000 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 3001 0x0, 0x0); 3002 } else { 3003 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 13); 3004 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 3005 0x4); 3006 } 3007 3008 if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) || 3009 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) 3010 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 1); 3011 else 3012 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 5); 3013 3014 /* sw mechanism */ 3015 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3016 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3017 btc8723b2ant_sw_mechanism(btcoexist, true, false, 3018 false, false); 3019 } else { 3020 btc8723b2ant_sw_mechanism(btcoexist, false, false, 3021 false, false); 3022 } 3023 } 3024 3025 /* PAN(HS) only */ 3026 static void btc8723b2ant_action_pan_hs(struct btc_coexist *btcoexist) 3027 { 3028 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 3029 u32 wifi_bw; 3030 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 3031 coex_dm->switch_thres_offset; 3032 3033 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 3034 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 3035 tmp, 0); 3036 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 3037 coex_dm->switch_thres_offset; 3038 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 3039 3040 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 3041 3042 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 3043 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 3044 3045 if (BTC_RSSI_HIGH(bt_rssi_state)) 3046 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3047 else 3048 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3049 3050 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 3051 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 3052 3053 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3054 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3055 btc8723b2ant_sw_mechanism(btcoexist, true, false, 3056 false, false); 3057 } else { 3058 btc8723b2ant_sw_mechanism(btcoexist, false, false, 3059 false, false); 3060 } 3061 } 3062 3063 /* PAN(EDR) + A2DP */ 3064 static void btc8723b2ant_action_pan_edr_a2dp(struct btc_coexist *btcoexist) 3065 { 3066 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 3067 u32 wifi_bw; 3068 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 3069 coex_dm->switch_thres_offset; 3070 3071 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 3072 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 3073 tmp, 0); 3074 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 3075 coex_dm->switch_thres_offset; 3076 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 3077 3078 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 3079 3080 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 3081 3082 if (BTC_RSSI_HIGH(bt_rssi_state)) 3083 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3084 else 3085 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3086 3087 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) 3088 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 3089 0x0, 0x0); 3090 else 3091 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 3092 0x4); 3093 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3094 3095 if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) || 3096 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) { 3097 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 12); 3098 if (BTC_WIFI_BW_HT40 == wifi_bw) 3099 btc8723b2ant_tdma_duration_adjust(btcoexist, false, 3100 true, 3); 3101 else 3102 btc8723b2ant_tdma_duration_adjust(btcoexist, false, 3103 false, 3); 3104 } else { 3105 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 3106 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, true, 3); 3107 } 3108 3109 /* sw mechanism */ 3110 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3111 btc8723b2ant_sw_mechanism(btcoexist, true, false, 3112 false, false); 3113 } else { 3114 btc8723b2ant_sw_mechanism(btcoexist, false, false, 3115 false, false); 3116 } 3117 } 3118 3119 static void btc8723b2ant_action_pan_edr_hid(struct btc_coexist *btcoexist) 3120 { 3121 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 3122 u32 wifi_bw; 3123 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 3124 coex_dm->switch_thres_offset; 3125 3126 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 3127 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 3128 tmp, 0); 3129 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 3130 coex_dm->switch_thres_offset; 3131 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 3132 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3133 3134 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 3135 3136 if (BTC_RSSI_HIGH(bt_rssi_state)) 3137 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3138 else 3139 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3140 3141 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) { 3142 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 3143 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 3144 0x0, 0x0); 3145 } else { 3146 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14); 3147 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 3148 0x4); 3149 } 3150 3151 if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) || 3152 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) { 3153 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3154 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 3155 3); 3156 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 3157 0xfffff, 0x780); 3158 } else { 3159 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 3160 6); 3161 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 3162 0xfffff, 0x0); 3163 } 3164 btc8723b2ant_tdma_duration_adjust(btcoexist, true, false, 2); 3165 } else { 3166 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 3167 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 3168 0x0); 3169 btc8723b2ant_tdma_duration_adjust(btcoexist, true, true, 2); 3170 } 3171 3172 /* sw mechanism */ 3173 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3174 btc8723b2ant_sw_mechanism(btcoexist, true, true, 3175 false, false); 3176 } else { 3177 btc8723b2ant_sw_mechanism(btcoexist, false, true, 3178 false, false); 3179 } 3180 } 3181 3182 /* HID + A2DP + PAN(EDR) */ 3183 static void btc8723b2ant_action_hid_a2dp_pan_edr(struct btc_coexist *btcoexist) 3184 { 3185 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 3186 u32 wifi_bw; 3187 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 3188 coex_dm->switch_thres_offset; 3189 3190 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 3191 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 3192 tmp, 0); 3193 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 3194 coex_dm->switch_thres_offset; 3195 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 2, tmp, 0); 3196 3197 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 3198 3199 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, false, 0x8); 3200 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 3201 3202 if (BTC_RSSI_HIGH(bt_rssi_state)) 3203 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3204 else 3205 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3206 3207 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) { 3208 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 3209 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 3210 0x0, 0x0); 3211 } else { 3212 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14); 3213 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 3214 0x4); 3215 } 3216 3217 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3218 3219 3220 if ((bt_rssi_state == BTC_RSSI_STATE_HIGH) || 3221 (bt_rssi_state == BTC_RSSI_STATE_STAY_HIGH)) { 3222 if (BTC_WIFI_BW_HT40 == wifi_bw) 3223 btc8723b2ant_tdma_duration_adjust(btcoexist, true, 3224 true, 2); 3225 else 3226 btc8723b2ant_tdma_duration_adjust(btcoexist, true, 3227 false, 3); 3228 } else { 3229 btc8723b2ant_tdma_duration_adjust(btcoexist, true, true, 3); 3230 } 3231 3232 /* sw mechanism */ 3233 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3234 btc8723b2ant_sw_mechanism(btcoexist, true, true, 3235 false, false); 3236 } else { 3237 btc8723b2ant_sw_mechanism(btcoexist, false, true, 3238 false, false); 3239 } 3240 } 3241 3242 static void btc8723b2ant_action_hid_a2dp(struct btc_coexist *btcoexist) 3243 { 3244 u8 wifi_rssi_state, wifi_rssi_state1, bt_rssi_state; 3245 u32 wifi_bw; 3246 u8 ap_num = 0; 3247 u8 tmp = BT_8723B_2ANT_WIFI_RSSI_COEXSWITCH_THRES - 3248 coex_dm->switch_thres_offset; 3249 3250 wifi_rssi_state = btc8723b2ant_wifi_rssi_state(btcoexist, 0, 2, 15, 0); 3251 wifi_rssi_state1 = btc8723b2ant_wifi_rssi_state(btcoexist, 1, 2, 3252 tmp, 0); 3253 tmp = BT_8723B_2ANT_BT_RSSI_COEXSWITCH_THRES - 3254 coex_dm->switch_thres_offset; 3255 bt_rssi_state = btc8723b2ant_bt_rssi_state(btcoexist, 3, tmp, 37); 3256 3257 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x0); 3258 3259 btc8723b2ant_limited_rx(btcoexist, NORMAL_EXEC, false, true, 0x5); 3260 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 3261 3262 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3263 3264 if (wifi_bw == BTC_WIFI_BW_LEGACY) { 3265 if (BTC_RSSI_HIGH(bt_rssi_state)) 3266 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3267 else if (BTC_RSSI_MEDIUM(bt_rssi_state)) 3268 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3269 else 3270 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3271 } else { 3272 /* only 802.11N mode we have to dec bt power to 4 degree */ 3273 if (BTC_RSSI_HIGH(bt_rssi_state)) { 3274 /* need to check ap Number of Not */ 3275 if (ap_num < 10) 3276 btc8723b2ant_dec_bt_pwr(btcoexist, 3277 NORMAL_EXEC, 4); 3278 else 3279 btc8723b2ant_dec_bt_pwr(btcoexist, 3280 NORMAL_EXEC, 2); 3281 } else if (BTC_RSSI_MEDIUM(bt_rssi_state)) { 3282 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 2); 3283 } else { 3284 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3285 } 3286 } 3287 3288 if (BTC_RSSI_HIGH(wifi_rssi_state1) && BTC_RSSI_HIGH(bt_rssi_state)) { 3289 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 7); 3290 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 3291 0x0, 0x0); 3292 } else { 3293 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 14); 3294 btc8723b2ant_power_save_state(btcoexist, BTC_PS_LPS_ON, 0x50, 3295 0x4); 3296 } 3297 3298 if (BTC_RSSI_HIGH(bt_rssi_state)) { 3299 if (ap_num < 10) 3300 btc8723b2ant_tdma_duration_adjust(btcoexist, true, 3301 false, 1); 3302 else 3303 btc8723b2ant_tdma_duration_adjust(btcoexist, true, 3304 false, 3); 3305 } else { 3306 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 18); 3307 btcoexist->btc_write_1byte(btcoexist, 0x456, 0x38); 3308 btcoexist->btc_write_2byte(btcoexist, 0x42a, 0x0808); 3309 btcoexist->btc_write_4byte(btcoexist, 0x430, 0x0); 3310 btcoexist->btc_write_4byte(btcoexist, 0x434, 0x01010000); 3311 3312 if (ap_num < 10) 3313 btc8723b2ant_tdma_duration_adjust(btcoexist, true, 3314 true, 1); 3315 else 3316 btc8723b2ant_tdma_duration_adjust(btcoexist, true, 3317 true, 3); 3318 } 3319 3320 /* sw mechanism */ 3321 if (BTC_WIFI_BW_HT40 == wifi_bw) { 3322 btc8723b2ant_sw_mechanism(btcoexist, true, true, 3323 false, false); 3324 } else { 3325 btc8723b2ant_sw_mechanism(btcoexist, false, true, 3326 false, false); 3327 } 3328 } 3329 3330 static void btc8723b2ant_action_wifi_multi_port(struct btc_coexist *btcoexist) 3331 { 3332 btc8723b2ant_fw_dac_swing_lvl(btcoexist, NORMAL_EXEC, 6); 3333 btc8723b2ant_dec_bt_pwr(btcoexist, NORMAL_EXEC, 0); 3334 3335 /* sw all off */ 3336 btc8723b2ant_sw_mechanism(btcoexist, false, false, false, false); 3337 3338 /* hw all off */ 3339 btc8723b2ant_coex_table_with_type(btcoexist, NORMAL_EXEC, 0); 3340 3341 btc8723b2ant_power_save_state(btcoexist, BTC_PS_WIFI_NATIVE, 0x0, 0x0); 3342 btc8723b2ant_ps_tdma(btcoexist, NORMAL_EXEC, false, 1); 3343 } 3344 3345 static void btc8723b2ant_run_coexist_mechanism(struct btc_coexist *btcoexist) 3346 { 3347 struct rtl_priv *rtlpriv = btcoexist->adapter; 3348 u8 algorithm = 0; 3349 u32 num_of_wifi_link = 0; 3350 u32 wifi_link_status = 0; 3351 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 3352 bool miracast_plus_bt = false; 3353 bool scan = false, link = false, roam = false; 3354 3355 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3356 "[BTCoex], RunCoexistMechanism()===>\n"); 3357 3358 if (btcoexist->manual_control) { 3359 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3360 "[BTCoex], RunCoexistMechanism(), return for Manual CTRL <===\n"); 3361 return; 3362 } 3363 3364 if (coex_sta->under_ips) { 3365 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3366 "[BTCoex], wifi is under IPS !!!\n"); 3367 return; 3368 } 3369 3370 algorithm = btc8723b2ant_action_algorithm(btcoexist); 3371 if (coex_sta->c2h_bt_inquiry_page && 3372 (BT_8723B_2ANT_COEX_ALGO_PANHS != algorithm)) { 3373 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3374 "[BTCoex], BT is under inquiry/page scan !!\n"); 3375 btc8723b2ant_action_bt_inquiry(btcoexist); 3376 return; 3377 } 3378 3379 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan); 3380 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link); 3381 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam); 3382 3383 if (scan || link || roam) { 3384 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3385 "[BTCoex], WiFi is under Link Process !!\n"); 3386 btc8723b2ant_action_wifi_link_process(btcoexist); 3387 return; 3388 } 3389 3390 /* for P2P */ 3391 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_LINK_STATUS, 3392 &wifi_link_status); 3393 num_of_wifi_link = wifi_link_status >> 16; 3394 3395 if ((num_of_wifi_link >= 2) || 3396 (wifi_link_status & WIFI_P2P_GO_CONNECTED)) { 3397 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3398 "############# [BTCoex], Multi-Port num_of_wifi_link = %d, wifi_link_status = 0x%x\n", 3399 num_of_wifi_link, wifi_link_status); 3400 3401 if (bt_link_info->bt_link_exist) 3402 miracast_plus_bt = true; 3403 else 3404 miracast_plus_bt = false; 3405 3406 btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT, 3407 &miracast_plus_bt); 3408 btc8723b2ant_action_wifi_multi_port(btcoexist); 3409 3410 return; 3411 } 3412 3413 miracast_plus_bt = false; 3414 btcoexist->btc_set(btcoexist, BTC_SET_BL_MIRACAST_PLUS_BT, 3415 &miracast_plus_bt); 3416 3417 coex_dm->cur_algorithm = algorithm; 3418 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3419 "[BTCoex], Algorithm = %d\n", 3420 coex_dm->cur_algorithm); 3421 3422 if (btc8723b2ant_is_common_action(btcoexist)) { 3423 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3424 "[BTCoex], Action 2-Ant common\n"); 3425 coex_dm->auto_tdma_adjust = false; 3426 } else { 3427 if (coex_dm->cur_algorithm != coex_dm->pre_algorithm) { 3428 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3429 "[BTCoex], preAlgorithm=%d, curAlgorithm=%d\n", 3430 coex_dm->pre_algorithm, 3431 coex_dm->cur_algorithm); 3432 coex_dm->auto_tdma_adjust = false; 3433 } 3434 switch (coex_dm->cur_algorithm) { 3435 case BT_8723B_2ANT_COEX_ALGO_SCO: 3436 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3437 "[BTCoex], Action 2-Ant, algorithm = SCO\n"); 3438 btc8723b2ant_action_sco(btcoexist); 3439 break; 3440 case BT_8723B_2ANT_COEX_ALGO_HID: 3441 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3442 "[BTCoex], Action 2-Ant, algorithm = HID\n"); 3443 btc8723b2ant_action_hid(btcoexist); 3444 break; 3445 case BT_8723B_2ANT_COEX_ALGO_A2DP: 3446 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3447 "[BTCoex], Action 2-Ant, algorithm = A2DP\n"); 3448 btc8723b2ant_action_a2dp(btcoexist); 3449 break; 3450 case BT_8723B_2ANT_COEX_ALGO_A2DP_PANHS: 3451 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3452 "[BTCoex], Action 2-Ant, algorithm = A2DP+PAN(HS)\n"); 3453 btc8723b2ant_action_a2dp_pan_hs(btcoexist); 3454 break; 3455 case BT_8723B_2ANT_COEX_ALGO_PANEDR: 3456 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3457 "[BTCoex], Action 2-Ant, algorithm = PAN(EDR)\n"); 3458 btc8723b2ant_action_pan_edr(btcoexist); 3459 break; 3460 case BT_8723B_2ANT_COEX_ALGO_PANHS: 3461 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3462 "[BTCoex], Action 2-Ant, algorithm = HS mode\n"); 3463 btc8723b2ant_action_pan_hs(btcoexist); 3464 break; 3465 case BT_8723B_2ANT_COEX_ALGO_PANEDR_A2DP: 3466 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3467 "[BTCoex], Action 2-Ant, algorithm = PAN+A2DP\n"); 3468 btc8723b2ant_action_pan_edr_a2dp(btcoexist); 3469 break; 3470 case BT_8723B_2ANT_COEX_ALGO_PANEDR_HID: 3471 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3472 "[BTCoex], Action 2-Ant, algorithm = PAN(EDR)+HID\n"); 3473 btc8723b2ant_action_pan_edr_hid(btcoexist); 3474 break; 3475 case BT_8723B_2ANT_COEX_ALGO_HID_A2DP_PANEDR: 3476 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3477 "[BTCoex], Action 2-Ant, algorithm = HID+A2DP+PAN\n"); 3478 btc8723b2ant_action_hid_a2dp_pan_edr(btcoexist); 3479 break; 3480 case BT_8723B_2ANT_COEX_ALGO_HID_A2DP: 3481 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3482 "[BTCoex], Action 2-Ant, algorithm = HID+A2DP\n"); 3483 btc8723b2ant_action_hid_a2dp(btcoexist); 3484 break; 3485 default: 3486 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3487 "[BTCoex], Action 2-Ant, algorithm = coexist All Off!!\n"); 3488 btc8723b2ant_coex_alloff(btcoexist); 3489 break; 3490 } 3491 coex_dm->pre_algorithm = coex_dm->cur_algorithm; 3492 } 3493 } 3494 3495 static void btc8723b2ant_wifioff_hwcfg(struct btc_coexist *btcoexist) 3496 { 3497 bool is_in_mp_mode = false; 3498 u8 h2c_parameter[2] = {0}; 3499 u32 fw_ver = 0; 3500 3501 /* set wlan_act to low */ 3502 btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4); 3503 3504 /* WiFi standby while GNT_BT 0 -> 1 */ 3505 btcoexist->btc_set_rf_reg(btcoexist, BTC_RF_A, 0x1, 0xfffff, 0x780); 3506 3507 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver); 3508 if (fw_ver >= 0x180000) { 3509 /* Use H2C to set GNT_BT to HIGH */ 3510 h2c_parameter[0] = 1; 3511 btcoexist->btc_fill_h2c(btcoexist, 0x6E, 1, h2c_parameter); 3512 } else { 3513 btcoexist->btc_write_1byte(btcoexist, 0x765, 0x18); 3514 } 3515 3516 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_IS_IN_MP_MODE, 3517 &is_in_mp_mode); 3518 if (!is_in_mp_mode) 3519 /* BT select s0/s1 is controlled by BT */ 3520 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20, 0x0); 3521 else 3522 /* BT select s0/s1 is controlled by WiFi */ 3523 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x67, 0x20, 0x1); 3524 } 3525 3526 /********************************************************************* 3527 * extern function start with ex_btc8723b2ant_ 3528 *********************************************************************/ 3529 void ex_btc8723b2ant_init_hwconfig(struct btc_coexist *btcoexist) 3530 { 3531 struct rtl_priv *rtlpriv = btcoexist->adapter; 3532 u8 u8tmp = 0; 3533 3534 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3535 "[BTCoex], 2Ant Init HW Config!!\n"); 3536 coex_dm->bt_rf0x1e_backup = 3537 btcoexist->btc_get_rf_reg(btcoexist, BTC_RF_A, 0x1e, 0xfffff); 3538 3539 /* 0x790[5:0] = 0x5 */ 3540 u8tmp = btcoexist->btc_read_1byte(btcoexist, 0x790); 3541 u8tmp &= 0xc0; 3542 u8tmp |= 0x5; 3543 btcoexist->btc_write_1byte(btcoexist, 0x790, u8tmp); 3544 3545 /* Antenna config */ 3546 btc8723b2ant_set_ant_path(btcoexist, BTC_ANT_WIFI_AT_MAIN, 3547 true, false); 3548 coex_sta->dis_ver_info_cnt = 0; 3549 3550 /* PTA parameter */ 3551 btc8723b2ant_coex_table_with_type(btcoexist, FORCE_EXEC, 0); 3552 3553 /* Enable counter statistics */ 3554 /* 0x76e[3] = 1, WLAN_ACT controlled by PTA */ 3555 btcoexist->btc_write_1byte(btcoexist, 0x76e, 0x4); 3556 btcoexist->btc_write_1byte(btcoexist, 0x778, 0x3); 3557 btcoexist->btc_write_1byte_bitmask(btcoexist, 0x40, 0x20, 0x1); 3558 btcoexist->auto_report_2ant = true; 3559 } 3560 3561 void ex_btc8723b2ant_power_on_setting(struct btc_coexist *btcoexist) 3562 { 3563 struct btc_board_info *board_info = &btcoexist->board_info; 3564 u16 u16tmp = 0x0; 3565 u32 value = 0; 3566 3567 btcoexist->btc_write_1byte(btcoexist, 0x67, 0x20); 3568 3569 /* enable BB, REG_SYS_FUNC_EN such that we can write 0x948 correctly */ 3570 u16tmp = btcoexist->btc_read_2byte(btcoexist, 0x2); 3571 btcoexist->btc_write_2byte(btcoexist, 0x2, u16tmp | BIT0 | BIT1); 3572 3573 btcoexist->btc_write_4byte(btcoexist, 0x948, 0x0); 3574 3575 if (btcoexist->chip_interface == BTC_INTF_USB) { 3576 /* fixed at S0 for USB interface */ 3577 board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT; 3578 } else { 3579 /* for PCIE and SDIO interface, we check efuse 0xc3[6] */ 3580 if (board_info->single_ant_path == 0) { 3581 /* set to S1 */ 3582 board_info->btdm_ant_pos = BTC_ANTENNA_AT_MAIN_PORT; 3583 } else if (board_info->single_ant_path == 1) { 3584 /* set to S0 */ 3585 board_info->btdm_ant_pos = BTC_ANTENNA_AT_AUX_PORT; 3586 } 3587 btcoexist->btc_set(btcoexist, BTC_SET_ACT_ANTPOSREGRISTRY_CTRL, 3588 &value); 3589 } 3590 } 3591 3592 void ex_btc8723b2ant_pre_load_firmware(struct btc_coexist *btcoexist) 3593 { 3594 struct btc_board_info *board_info = &btcoexist->board_info; 3595 u8 u8tmp = 0x4; /* Set BIT2 by default since it's 2ant case */ 3596 3597 /** 3598 * S0 or S1 setting and Local register setting(By this fw can get 3599 * ant number, S0/S1, ... info) 3600 * 3601 * Local setting bit define 3602 * BIT0: "0" : no antenna inverse; "1" : antenna inverse 3603 * BIT1: "0" : internal switch; "1" : external switch 3604 * BIT2: "0" : one antenna; "1" : two antennas 3605 * 3606 * NOTE: here default all internal switch and 1-antenna ==> BIT1=0 and 3607 * BIT2 = 0 3608 */ 3609 if (btcoexist->chip_interface == BTC_INTF_USB) { 3610 /* fixed at S0 for USB interface */ 3611 u8tmp |= 0x1; /* antenna inverse */ 3612 btcoexist->btc_write_local_reg_1byte(btcoexist, 0xfe08, u8tmp); 3613 } else { 3614 /* for PCIE and SDIO interface, we check efuse 0xc3[6] */ 3615 if (board_info->single_ant_path == 0) { 3616 } else if (board_info->single_ant_path == 1) { 3617 /* set to S0 */ 3618 u8tmp |= 0x1; /* antenna inverse */ 3619 } 3620 3621 if (btcoexist->chip_interface == BTC_INTF_PCI) 3622 btcoexist->btc_write_local_reg_1byte(btcoexist, 0x384, 3623 u8tmp); 3624 else if (btcoexist->chip_interface == BTC_INTF_SDIO) 3625 btcoexist->btc_write_local_reg_1byte(btcoexist, 0x60, 3626 u8tmp); 3627 } 3628 } 3629 3630 void ex_btc8723b2ant_init_coex_dm(struct btc_coexist *btcoexist) 3631 { 3632 struct rtl_priv *rtlpriv = btcoexist->adapter; 3633 3634 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3635 "[BTCoex], Coex Mechanism Init!!\n"); 3636 btc8723b2ant_init_coex_dm(btcoexist); 3637 } 3638 3639 void ex_btc8723b2ant_display_coex_info(struct btc_coexist *btcoexist, 3640 struct seq_file *m) 3641 { 3642 struct btc_board_info *board_info = &btcoexist->board_info; 3643 struct btc_stack_info *stack_info = &btcoexist->stack_info; 3644 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 3645 u8 u8tmp[4], i, bt_info_ext, ps_tdma_case = 0; 3646 u32 u32tmp[4]; 3647 bool roam = false, scan = false; 3648 bool link = false, wifi_under_5g = false; 3649 bool bt_hs_on = false, wifi_busy = false; 3650 s32 wifi_rssi = 0, bt_hs_rssi = 0; 3651 u32 wifi_bw, wifi_traffic_dir, fa_ofdm, fa_cck; 3652 u8 wifi_dot11_chnl, wifi_hs_chnl; 3653 u32 fw_ver = 0, bt_patch_ver = 0; 3654 u8 ap_num = 0; 3655 3656 seq_puts(m, "\n ============[BT Coexist info]============"); 3657 3658 if (btcoexist->manual_control) { 3659 seq_puts(m, "\n ==========[Under Manual Control]============"); 3660 seq_puts(m, "\n =========================================="); 3661 } 3662 3663 seq_printf(m, "\n %-35s = %d/ %d ", 3664 "Ant PG number/ Ant mechanism:", 3665 board_info->pg_ant_num, board_info->btdm_ant_num); 3666 3667 seq_printf(m, "\n %-35s = %s / %d", 3668 "BT stack/ hci ext ver", 3669 ((stack_info->profile_notified) ? "Yes" : "No"), 3670 stack_info->hci_version); 3671 3672 btcoexist->btc_get(btcoexist, BTC_GET_U4_BT_PATCH_VER, &bt_patch_ver); 3673 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_FW_VER, &fw_ver); 3674 seq_printf(m, "\n %-35s = %d_%x/ 0x%x/ 0x%x(%d)", 3675 "CoexVer/ FwVer/ PatchVer", 3676 glcoex_ver_date_8723b_2ant, glcoex_ver_8723b_2ant, 3677 fw_ver, bt_patch_ver, bt_patch_ver); 3678 3679 btcoexist->btc_get(btcoexist, BTC_GET_BL_HS_OPERATION, &bt_hs_on); 3680 btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_DOT11_CHNL, 3681 &wifi_dot11_chnl); 3682 btcoexist->btc_get(btcoexist, BTC_GET_U1_WIFI_HS_CHNL, &wifi_hs_chnl); 3683 3684 seq_printf(m, "\n %-35s = %d / %d(%d)", 3685 "Dot11 channel / HsChnl(HsMode)", 3686 wifi_dot11_chnl, wifi_hs_chnl, bt_hs_on); 3687 3688 seq_printf(m, "\n %-35s = %3ph ", 3689 "H2C Wifi inform bt chnl Info", coex_dm->wifi_chnl_info); 3690 3691 btcoexist->btc_get(btcoexist, BTC_GET_S4_WIFI_RSSI, &wifi_rssi); 3692 btcoexist->btc_get(btcoexist, BTC_GET_S4_HS_RSSI, &bt_hs_rssi); 3693 btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, &ap_num); 3694 seq_printf(m, "\n %-35s = %d/ %d/ %d", 3695 "Wifi rssi/ HS rssi/ AP#", wifi_rssi, bt_hs_rssi, ap_num); 3696 3697 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_SCAN, &scan); 3698 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_LINK, &link); 3699 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_ROAM, &roam); 3700 seq_printf(m, "\n %-35s = %d/ %d/ %d ", 3701 "Wifi link/ roam/ scan", link, roam, scan); 3702 3703 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_UNDER_5G, &wifi_under_5g); 3704 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_BW, &wifi_bw); 3705 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_BUSY, &wifi_busy); 3706 btcoexist->btc_get(btcoexist, BTC_GET_U4_WIFI_TRAFFIC_DIRECTION, 3707 &wifi_traffic_dir); 3708 seq_printf(m, "\n %-35s = %s / %s/ %s ", 3709 "Wifi status", (wifi_under_5g ? "5G" : "2.4G"), 3710 ((wifi_bw == BTC_WIFI_BW_LEGACY) ? "Legacy" : 3711 (((wifi_bw == BTC_WIFI_BW_HT40) ? "HT40" : "HT20"))), 3712 ((!wifi_busy) ? "idle" : 3713 ((wifi_traffic_dir == BTC_WIFI_TRAFFIC_TX) ? 3714 "uplink" : "downlink"))); 3715 3716 seq_printf(m, "\n %-35s = %d / %d / %d / %d", 3717 "SCO/HID/PAN/A2DP", 3718 bt_link_info->sco_exist, bt_link_info->hid_exist, 3719 bt_link_info->pan_exist, bt_link_info->a2dp_exist); 3720 btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_BT_LINK_INFO, m); 3721 3722 bt_info_ext = coex_sta->bt_info_ext; 3723 seq_printf(m, "\n %-35s = %s", 3724 "BT Info A2DP rate", 3725 (bt_info_ext & BIT0) ? "Basic rate" : "EDR rate"); 3726 3727 for (i = 0; i < BT_INFO_SRC_8723B_2ANT_MAX; i++) { 3728 if (coex_sta->bt_info_c2h_cnt[i]) { 3729 seq_printf(m, "\n %-35s = %7ph(%d)", 3730 glbt_info_src_8723b_2ant[i], 3731 coex_sta->bt_info_c2h[i], 3732 coex_sta->bt_info_c2h_cnt[i]); 3733 } 3734 } 3735 3736 seq_printf(m, "\n %-35s = %s/%s", 3737 "PS state, IPS/LPS", 3738 ((coex_sta->under_ips ? "IPS ON" : "IPS OFF")), 3739 ((coex_sta->under_lps ? "LPS ON" : "LPS OFF"))); 3740 btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_FW_PWR_MODE_CMD, m); 3741 3742 /* Sw mechanism */ 3743 seq_printf(m, 3744 "\n %-35s", "============[Sw mechanism]============"); 3745 seq_printf(m, "\n %-35s = %d/ %d/ %d ", 3746 "SM1[ShRf/ LpRA/ LimDig]", coex_dm->cur_rf_rx_lpf_shrink, 3747 coex_dm->cur_low_penalty_ra, coex_dm->limited_dig); 3748 seq_printf(m, "\n %-35s = %d/ %d/ %d(0x%x) ", 3749 "SM2[AgcT/ AdcB/ SwDacSwing(lvl)]", 3750 coex_dm->cur_agc_table_en, coex_dm->cur_adc_back_off, 3751 coex_dm->cur_dac_swing_on, coex_dm->cur_dac_swing_lvl); 3752 3753 /* Fw mechanism */ 3754 seq_printf(m, "\n %-35s", 3755 "============[Fw mechanism]============"); 3756 3757 ps_tdma_case = coex_dm->cur_ps_tdma; 3758 seq_printf(m, "\n %-35s = %5ph case-%d (auto:%d)", 3759 "PS TDMA", coex_dm->ps_tdma_para, 3760 ps_tdma_case, coex_dm->auto_tdma_adjust); 3761 3762 seq_printf(m, "\n %-35s = %d/ %d ", 3763 "DecBtPwr/ IgnWlanAct", coex_dm->cur_dec_bt_pwr_lvl, 3764 coex_dm->cur_ignore_wlan_act); 3765 3766 /* Hw setting */ 3767 seq_printf(m, "\n %-35s", 3768 "============[Hw setting]============"); 3769 3770 seq_printf(m, "\n %-35s = 0x%x", 3771 "RF-A, 0x1e initVal", coex_dm->bt_rf0x1e_backup); 3772 3773 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x778); 3774 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x880); 3775 seq_printf(m, "\n %-35s = 0x%x/ 0x%x", 3776 "0x778/0x880[29:25]", u8tmp[0], 3777 (u32tmp[0] & 0x3e000000) >> 25); 3778 3779 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x948); 3780 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x67); 3781 u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x765); 3782 seq_printf(m, "\n %-35s = 0x%x/ 0x%x/ 0x%x", 3783 "0x948/ 0x67[5] / 0x765", 3784 u32tmp[0], ((u8tmp[0] & 0x20) >> 5), u8tmp[1]); 3785 3786 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x92c); 3787 u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x930); 3788 u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x944); 3789 seq_printf(m, "\n %-35s = 0x%x/ 0x%x/ 0x%x", 3790 "0x92c[1:0]/ 0x930[7:0]/0x944[1:0]", 3791 u32tmp[0] & 0x3, u32tmp[1] & 0xff, u32tmp[2] & 0x3); 3792 3793 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x39); 3794 u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0x40); 3795 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x4c); 3796 u8tmp[2] = btcoexist->btc_read_1byte(btcoexist, 0x64); 3797 seq_printf(m, "\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", 3798 "0x38[11]/0x40/0x4c[24:23]/0x64[0]", 3799 ((u8tmp[0] & 0x8) >> 3), u8tmp[1], 3800 ((u32tmp[0] & 0x01800000) >> 23), u8tmp[2] & 0x1); 3801 3802 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x550); 3803 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x522); 3804 seq_printf(m, "\n %-35s = 0x%x/ 0x%x", 3805 "0x550(bcn ctrl)/0x522", u32tmp[0], u8tmp[0]); 3806 3807 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xc50); 3808 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x49c); 3809 seq_printf(m, "\n %-35s = 0x%x/ 0x%x", 3810 "0xc50(dig)/0x49c(null-drop)", u32tmp[0] & 0xff, u8tmp[0]); 3811 3812 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0xda0); 3813 u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0xda4); 3814 u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0xda8); 3815 u32tmp[3] = btcoexist->btc_read_4byte(btcoexist, 0xcf0); 3816 3817 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0xa5b); 3818 u8tmp[1] = btcoexist->btc_read_1byte(btcoexist, 0xa5c); 3819 3820 fa_ofdm = ((u32tmp[0]&0xffff0000) >> 16) + 3821 ((u32tmp[1]&0xffff0000) >> 16) + 3822 (u32tmp[1] & 0xffff) + 3823 (u32tmp[2] & 0xffff) + 3824 ((u32tmp[3]&0xffff0000) >> 16) + 3825 (u32tmp[3] & 0xffff); 3826 fa_cck = (u8tmp[0] << 8) + u8tmp[1]; 3827 3828 seq_printf(m, "\n %-35s = 0x%x/ 0x%x/ 0x%x", 3829 "OFDM-CCA/OFDM-FA/CCK-FA", 3830 u32tmp[0] & 0xffff, fa_ofdm, fa_cck); 3831 3832 u32tmp[0] = btcoexist->btc_read_4byte(btcoexist, 0x6c0); 3833 u32tmp[1] = btcoexist->btc_read_4byte(btcoexist, 0x6c4); 3834 u32tmp[2] = btcoexist->btc_read_4byte(btcoexist, 0x6c8); 3835 u8tmp[0] = btcoexist->btc_read_1byte(btcoexist, 0x6cc); 3836 seq_printf(m, "\n %-35s = 0x%x/ 0x%x/ 0x%x/ 0x%x", 3837 "0x6c0/0x6c4/0x6c8/0x6cc(coexTable)", 3838 u32tmp[0], u32tmp[1], u32tmp[2], u8tmp[0]); 3839 3840 seq_printf(m, "\n %-35s = %d/ %d", 3841 "0x770(high-pri rx/tx)", 3842 coex_sta->high_priority_rx, coex_sta->high_priority_tx); 3843 seq_printf(m, "\n %-35s = %d/ %d", 3844 "0x774(low-pri rx/tx)", coex_sta->low_priority_rx, 3845 coex_sta->low_priority_tx); 3846 if (btcoexist->auto_report_2ant) 3847 btc8723b2ant_monitor_bt_ctr(btcoexist); 3848 btcoexist->btc_disp_dbg_msg(btcoexist, BTC_DBG_DISP_COEX_STATISTICS, m); 3849 } 3850 3851 void ex_btc8723b2ant_ips_notify(struct btc_coexist *btcoexist, u8 type) 3852 { 3853 struct rtl_priv *rtlpriv = btcoexist->adapter; 3854 3855 if (BTC_IPS_ENTER == type) { 3856 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3857 "[BTCoex], IPS ENTER notify\n"); 3858 coex_sta->under_ips = true; 3859 btc8723b2ant_wifioff_hwcfg(btcoexist); 3860 btc8723b2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true); 3861 btc8723b2ant_coex_alloff(btcoexist); 3862 } else if (BTC_IPS_LEAVE == type) { 3863 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3864 "[BTCoex], IPS LEAVE notify\n"); 3865 coex_sta->under_ips = false; 3866 ex_btc8723b2ant_init_hwconfig(btcoexist); 3867 btc8723b2ant_init_coex_dm(btcoexist); 3868 btc8723b2ant_query_bt_info(btcoexist); 3869 } 3870 } 3871 3872 void ex_btc8723b2ant_lps_notify(struct btc_coexist *btcoexist, u8 type) 3873 { 3874 struct rtl_priv *rtlpriv = btcoexist->adapter; 3875 3876 if (BTC_LPS_ENABLE == type) { 3877 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3878 "[BTCoex], LPS ENABLE notify\n"); 3879 coex_sta->under_lps = true; 3880 } else if (BTC_LPS_DISABLE == type) { 3881 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3882 "[BTCoex], LPS DISABLE notify\n"); 3883 coex_sta->under_lps = false; 3884 } 3885 } 3886 3887 void ex_btc8723b2ant_scan_notify(struct btc_coexist *btcoexist, u8 type) 3888 { 3889 struct rtl_priv *rtlpriv = btcoexist->adapter; 3890 u32 u32tmp; 3891 u8 u8tmpa, u8tmpb; 3892 3893 u32tmp = btcoexist->btc_read_4byte(btcoexist, 0x948); 3894 u8tmpa = btcoexist->btc_read_1byte(btcoexist, 0x765); 3895 u8tmpb = btcoexist->btc_read_1byte(btcoexist, 0x76e); 3896 3897 if (BTC_SCAN_START == type) 3898 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3899 "[BTCoex], SCAN START notify\n"); 3900 else if (BTC_SCAN_FINISH == type) 3901 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3902 "[BTCoex], SCAN FINISH notify\n"); 3903 btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, 3904 &coex_sta->scan_ap_num); 3905 3906 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3907 "############# [BTCoex], 0x948=0x%x, 0x765=0x%x, 0x76e=0x%x\n", 3908 u32tmp, u8tmpa, u8tmpb); 3909 } 3910 3911 void ex_btc8723b2ant_connect_notify(struct btc_coexist *btcoexist, u8 type) 3912 { 3913 struct rtl_priv *rtlpriv = btcoexist->adapter; 3914 3915 if (BTC_ASSOCIATE_START == type) 3916 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3917 "[BTCoex], CONNECT START notify\n"); 3918 else if (BTC_ASSOCIATE_FINISH == type) 3919 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3920 "[BTCoex], CONNECT FINISH notify\n"); 3921 } 3922 3923 void ex_btc8723b2ant_media_status_notify(struct btc_coexist *btcoexist, 3924 u8 type) 3925 { 3926 struct rtl_priv *rtlpriv = btcoexist->adapter; 3927 u8 h2c_parameter[3] = {0}; 3928 u32 wifi_bw; 3929 u8 wifi_central_chnl; 3930 u8 ap_num = 0; 3931 3932 if (BTC_MEDIA_CONNECT == type) 3933 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3934 "[BTCoex], MEDIA connect notify\n"); 3935 else 3936 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3937 "[BTCoex], MEDIA disconnect notify\n"); 3938 3939 /* only 2.4G we need to inform bt the chnl mask */ 3940 btcoexist->btc_get(btcoexist, 3941 BTC_GET_U1_WIFI_CENTRAL_CHNL, &wifi_central_chnl); 3942 if ((BTC_MEDIA_CONNECT == type) && 3943 (wifi_central_chnl <= 14)) { 3944 h2c_parameter[0] = 0x1; 3945 h2c_parameter[1] = wifi_central_chnl; 3946 btcoexist->btc_get(btcoexist, 3947 BTC_GET_U4_WIFI_BW, &wifi_bw); 3948 if (wifi_bw == BTC_WIFI_BW_HT40) { 3949 h2c_parameter[2] = 0x30; 3950 } else { 3951 btcoexist->btc_get(btcoexist, BTC_GET_U1_AP_NUM, 3952 &ap_num); 3953 if (ap_num < 10) 3954 h2c_parameter[2] = 0x30; 3955 else 3956 h2c_parameter[2] = 0x20; 3957 } 3958 } 3959 3960 coex_dm->wifi_chnl_info[0] = h2c_parameter[0]; 3961 coex_dm->wifi_chnl_info[1] = h2c_parameter[1]; 3962 coex_dm->wifi_chnl_info[2] = h2c_parameter[2]; 3963 3964 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3965 "[BTCoex], FW write 0x66=0x%x\n", 3966 h2c_parameter[0] << 16 | h2c_parameter[1] << 8 | 3967 h2c_parameter[2]); 3968 3969 btcoexist->btc_fill_h2c(btcoexist, 0x66, 3, h2c_parameter); 3970 } 3971 3972 void ex_btc8723b2ant_special_packet_notify(struct btc_coexist *btcoexist, 3973 u8 type) 3974 { 3975 struct rtl_priv *rtlpriv = btcoexist->adapter; 3976 3977 if (type == BTC_PACKET_DHCP) 3978 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3979 "[BTCoex], DHCP Packet notify\n"); 3980 } 3981 3982 void ex_btc8723b2ant_bt_info_notify(struct btc_coexist *btcoexist, 3983 u8 *tmpbuf, u8 length) 3984 { 3985 struct rtl_priv *rtlpriv = btcoexist->adapter; 3986 u8 bt_info = 0; 3987 u8 i, rsp_source = 0; 3988 bool bt_busy = false, limited_dig = false; 3989 bool wifi_connected = false; 3990 3991 coex_sta->c2h_bt_info_req_sent = false; 3992 3993 rsp_source = tmpbuf[0]&0xf; 3994 if (rsp_source >= BT_INFO_SRC_8723B_2ANT_MAX) 3995 rsp_source = BT_INFO_SRC_8723B_2ANT_WIFI_FW; 3996 coex_sta->bt_info_c2h_cnt[rsp_source]++; 3997 3998 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 3999 "[BTCoex], Bt info[%d], length=%d, hex data=[", 4000 rsp_source, length); 4001 for (i = 0; i < length; i++) { 4002 coex_sta->bt_info_c2h[rsp_source][i] = tmpbuf[i]; 4003 if (i == 1) 4004 bt_info = tmpbuf[i]; 4005 if (i == length - 1) 4006 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4007 "0x%02x]\n", tmpbuf[i]); 4008 else 4009 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4010 "0x%02x, ", tmpbuf[i]); 4011 } 4012 4013 if (btcoexist->manual_control) { 4014 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4015 "[BTCoex], BtInfoNotify(), return for Manual CTRL<===\n"); 4016 return; 4017 } 4018 4019 if (BT_INFO_SRC_8723B_2ANT_WIFI_FW != rsp_source) { 4020 coex_sta->bt_retry_cnt = 4021 coex_sta->bt_info_c2h[rsp_source][2] & 0xf; 4022 4023 if (coex_sta->bt_retry_cnt >= 1) 4024 coex_sta->pop_event_cnt++; 4025 4026 coex_sta->bt_rssi = 4027 coex_sta->bt_info_c2h[rsp_source][3] * 2 + 10; 4028 4029 coex_sta->bt_info_ext = coex_sta->bt_info_c2h[rsp_source][4]; 4030 4031 if (coex_sta->bt_info_c2h[rsp_source][2] & 0x20) 4032 coex_sta->c2h_bt_remote_name_req = true; 4033 else 4034 coex_sta->c2h_bt_remote_name_req = false; 4035 4036 if (coex_sta->bt_info_c2h[rsp_source][1] == 0x49) 4037 coex_sta->a2dp_bit_pool = 4038 coex_sta->bt_info_c2h[rsp_source][6]; 4039 else 4040 coex_sta->a2dp_bit_pool = 0; 4041 4042 /* Here we need to resend some wifi info to BT 4043 * because BT is reset and loss of the info. 4044 */ 4045 if ((coex_sta->bt_info_ext & BIT1)) { 4046 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4047 "[BTCoex], BT ext info bit1 check, send wifi BW&Chnl to BT!!\n"); 4048 btcoexist->btc_get(btcoexist, BTC_GET_BL_WIFI_CONNECTED, 4049 &wifi_connected); 4050 if (wifi_connected) 4051 ex_btc8723b2ant_media_status_notify( 4052 btcoexist, 4053 BTC_MEDIA_CONNECT); 4054 else 4055 ex_btc8723b2ant_media_status_notify( 4056 btcoexist, 4057 BTC_MEDIA_DISCONNECT); 4058 } 4059 4060 if ((coex_sta->bt_info_ext & BIT3)) { 4061 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4062 "[BTCoex], BT ext info bit3 check, set BT NOT to ignore Wlan active!!\n"); 4063 btc8723b2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, 4064 false); 4065 } else { 4066 /* BT already NOT ignore Wlan active, do nothing here.*/ 4067 } 4068 if (!btcoexist->auto_report_2ant) { 4069 if (!(coex_sta->bt_info_ext & BIT4)) 4070 btc8723b2ant_bt_auto_report(btcoexist, 4071 FORCE_EXEC, true); 4072 } 4073 } 4074 4075 /* check BIT2 first ==> check if bt is under inquiry or page scan */ 4076 if (bt_info & BT_INFO_8723B_2ANT_B_INQ_PAGE) 4077 coex_sta->c2h_bt_inquiry_page = true; 4078 else 4079 coex_sta->c2h_bt_inquiry_page = false; 4080 4081 if (!(bt_info & BT_INFO_8723B_2ANT_B_CONNECTION)) { 4082 /* set link exist status */ 4083 coex_sta->bt_link_exist = false; 4084 coex_sta->pan_exist = false; 4085 coex_sta->a2dp_exist = false; 4086 coex_sta->hid_exist = false; 4087 coex_sta->sco_exist = false; 4088 } else { 4089 /* connection exists */ 4090 coex_sta->bt_link_exist = true; 4091 if (bt_info & BT_INFO_8723B_2ANT_B_FTP) 4092 coex_sta->pan_exist = true; 4093 else 4094 coex_sta->pan_exist = false; 4095 if (bt_info & BT_INFO_8723B_2ANT_B_A2DP) 4096 coex_sta->a2dp_exist = true; 4097 else 4098 coex_sta->a2dp_exist = false; 4099 if (bt_info & BT_INFO_8723B_2ANT_B_HID) 4100 coex_sta->hid_exist = true; 4101 else 4102 coex_sta->hid_exist = false; 4103 if (bt_info & BT_INFO_8723B_2ANT_B_SCO_ESCO) 4104 coex_sta->sco_exist = true; 4105 else 4106 coex_sta->sco_exist = false; 4107 4108 if ((!coex_sta->hid_exist) && 4109 (!coex_sta->c2h_bt_inquiry_page) && 4110 (!coex_sta->sco_exist)) { 4111 if (coex_sta->high_priority_tx + 4112 coex_sta->high_priority_rx >= 160) { 4113 coex_sta->hid_exist = true; 4114 bt_info = bt_info | 0x28; 4115 } 4116 } 4117 } 4118 4119 btc8723b2ant_update_bt_link_info(btcoexist); 4120 4121 if (!(bt_info & BT_INFO_8723B_2ANT_B_CONNECTION)) { 4122 coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_NON_CONNECTED_IDLE; 4123 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4124 "[BTCoex], BtInfoNotify(), BT Non-Connected idle!!!\n"); 4125 /* connection exists but no busy */ 4126 } else if (bt_info == BT_INFO_8723B_2ANT_B_CONNECTION) { 4127 coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_CONNECTED_IDLE; 4128 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4129 "[BTCoex], BtInfoNotify(), BT Connected-idle!!!\n"); 4130 } else if ((bt_info & BT_INFO_8723B_2ANT_B_SCO_ESCO) || 4131 (bt_info & BT_INFO_8723B_2ANT_B_SCO_BUSY)) { 4132 coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_SCO_BUSY; 4133 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4134 "[BTCoex], BtInfoNotify(), BT SCO busy!!!\n"); 4135 } else if (bt_info&BT_INFO_8723B_2ANT_B_ACL_BUSY) { 4136 coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_ACL_BUSY; 4137 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4138 "[BTCoex], BtInfoNotify(), BT ACL busy!!!\n"); 4139 } else { 4140 coex_dm->bt_status = BT_8723B_2ANT_BT_STATUS_MAX; 4141 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4142 "[BTCoex], BtInfoNotify(), BT Non-Defined state!!!\n"); 4143 } 4144 4145 if ((BT_8723B_2ANT_BT_STATUS_ACL_BUSY == coex_dm->bt_status) || 4146 (BT_8723B_2ANT_BT_STATUS_SCO_BUSY == coex_dm->bt_status) || 4147 (BT_8723B_2ANT_BT_STATUS_ACL_SCO_BUSY == coex_dm->bt_status)) { 4148 bt_busy = true; 4149 limited_dig = true; 4150 } else { 4151 bt_busy = false; 4152 limited_dig = false; 4153 } 4154 4155 btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_TRAFFIC_BUSY, &bt_busy); 4156 4157 coex_dm->limited_dig = limited_dig; 4158 btcoexist->btc_set(btcoexist, BTC_SET_BL_BT_LIMITED_DIG, &limited_dig); 4159 4160 btc8723b2ant_run_coexist_mechanism(btcoexist); 4161 } 4162 4163 void ex_btc8723b2ant_halt_notify(struct btc_coexist *btcoexist) 4164 { 4165 struct rtl_priv *rtlpriv = btcoexist->adapter; 4166 4167 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, "[BTCoex], Halt notify\n"); 4168 4169 btc8723b2ant_wifioff_hwcfg(btcoexist); 4170 btc8723b2ant_ignore_wlan_act(btcoexist, FORCE_EXEC, true); 4171 ex_btc8723b2ant_media_status_notify(btcoexist, BTC_MEDIA_DISCONNECT); 4172 } 4173 4174 void ex_btc8723b2ant_pnp_notify(struct btc_coexist *btcoexist, u8 pnp_state) 4175 { 4176 struct rtl_priv *rtlpriv = btcoexist->adapter; 4177 4178 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, "[BTCoex], Pnp notify\n"); 4179 4180 if (pnp_state == BTC_WIFI_PNP_SLEEP) { 4181 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4182 "[BTCoex], Pnp notify to SLEEP\n"); 4183 4184 /* Driver do not leave IPS/LPS when driver is going to sleep, so 4185 * BTCoexistence think wifi is still under IPS/LPS 4186 * 4187 * BT should clear UnderIPS/UnderLPS state to avoid mismatch 4188 * state after wakeup. 4189 */ 4190 coex_sta->under_ips = false; 4191 coex_sta->under_lps = false; 4192 } else if (pnp_state == BTC_WIFI_PNP_WAKE_UP) { 4193 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4194 "[BTCoex], Pnp notify to WAKE UP\n"); 4195 ex_btc8723b2ant_init_hwconfig(btcoexist); 4196 btc8723b2ant_init_coex_dm(btcoexist); 4197 btc8723b2ant_query_bt_info(btcoexist); 4198 } 4199 } 4200 4201 void ex_btc8723b2ant_periodical(struct btc_coexist *btcoexist) 4202 { 4203 struct rtl_priv *rtlpriv = btcoexist->adapter; 4204 struct btc_bt_link_info *bt_link_info = &btcoexist->bt_link_info; 4205 4206 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4207 "[BTCoex], ==========================Periodical===========================\n"); 4208 4209 if (coex_sta->dis_ver_info_cnt <= 5) { 4210 coex_sta->dis_ver_info_cnt += 1; 4211 if (coex_sta->dis_ver_info_cnt == 3) { 4212 /* Antenna config to set 0x765 = 0x0 (GNT_BT control by 4213 * PTA) after initial 4214 */ 4215 rtl_dbg(rtlpriv, COMP_BT_COEXIST, DBG_LOUD, 4216 "[BTCoex], Set GNT_BT control by PTA\n"); 4217 btc8723b2ant_set_ant_path( 4218 btcoexist, BTC_ANT_WIFI_AT_MAIN, false, false); 4219 } 4220 } 4221 4222 if (!btcoexist->auto_report_2ant) { 4223 btc8723b2ant_query_bt_info(btcoexist); 4224 } else { 4225 btc8723b2ant_monitor_bt_ctr(btcoexist); 4226 btc8723b2ant_monitor_wifi_ctr(btcoexist); 4227 4228 /* for some BT speakers that High-Priority pkts appear before 4229 * playing, this will cause HID exist 4230 */ 4231 if ((coex_sta->high_priority_tx + 4232 coex_sta->high_priority_rx < 50) && 4233 (bt_link_info->hid_exist)) 4234 bt_link_info->hid_exist = false; 4235 4236 if (btc8723b2ant_is_wifi_status_changed(btcoexist) || 4237 coex_dm->auto_tdma_adjust) 4238 btc8723b2ant_run_coexist_mechanism(btcoexist); 4239 } 4240 } 4241