1 /******************************************************************************
3 * Copyright(c) 2016 - 2017 Realtek Corporation.
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of version 2 of the GNU General Public License as
7 * published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14 *****************************************************************************/
15 #ifndef __HALBTC_OUT_SRC_H__
16 #define __HALBTC_OUT_SRC_H__
114 BTC_MULTIPORT_MCC_DUAL_CHANNEL,
115 BTC_MULTIPORT_MCC_DUAL_BAND,
119 #define BTC_COEX_OFFLOAD 0
120 #define BTC_TMP_BUF_SHORT 20
122 extern u1Byte gl_btc_trace_buf[];
123 #define BTC_SPRINTF rsprintf
124 #define BTC_TRACE(_MSG_)\
126 if (GLBtcDbgType[COMP_COEX] & BIT(DBG_LOUD)) {\
127 RTW_INFO("%s", _MSG_);\
130 #define BT_PrintData(adapter, _MSG_, len, data) RTW_DBG_DUMP((_MSG_), data, len)
133 #define NORMAL_EXEC FALSE
134 #define FORCE_EXEC TRUE
136 #define NM_EXCU FALSE
139 #define BTC_RF_OFF 0x0
140 #define BTC_RF_ON 0x1
147 #define BTC_SMSP SINGLEMAC_SINGLEPHY
148 #define BTC_DMDP DUALMAC_DUALPHY
149 #define BTC_DMSP DUALMAC_SINGLEPHY
150 #define BTC_MP_UNKNOWN 0xff
152 #define BT_COEX_ANT_TYPE_PG 0
153 #define BT_COEX_ANT_TYPE_ANTDIV 1
154 #define BT_COEX_ANT_TYPE_DETECTED 2
156 #define BTC_MIMO_PS_STATIC 0 /* 1ss */
157 #define BTC_MIMO_PS_DYNAMIC 1 /* 2ss */
159 #define BTC_RATE_DISABLE 0
160 #define BTC_RATE_ENABLE 1
162 /* single Antenna definition */
163 #define BTC_ANT_PATH_WIFI 0
164 #define BTC_ANT_PATH_BT 1
165 #define BTC_ANT_PATH_PTA 2
166 #define BTC_ANT_PATH_WIFI5G 3
167 #define BTC_ANT_PATH_AUTO 4
168 /* dual Antenna definition */
169 #define BTC_ANT_WIFI_AT_MAIN 0
170 #define BTC_ANT_WIFI_AT_AUX 1
171 #define BTC_ANT_WIFI_AT_DIVERSITY 2
172 /* coupler Antenna definition */
173 #define BTC_ANT_WIFI_AT_CPL_MAIN 0
174 #define BTC_ANT_WIFI_AT_CPL_AUX 1
176 typedef enum _BTC_POWERSAVE_TYPE {
177 BTC_PS_WIFI_NATIVE = 0, /* wifi original power save behavior */
181 } BTC_POWERSAVE_TYPE, *PBTC_POWERSAVE_TYPE;
183 typedef enum _BTC_BT_REG_TYPE {
185 BTC_BT_REG_MODEM = 1,
186 BTC_BT_REG_BLUEWIZE = 2,
187 BTC_BT_REG_VENDOR = 3,
190 } BTC_BT_REG_TYPE, *PBTC_BT_REG_TYPE;
192 typedef enum _BTC_CHIP_INTERFACE {
193 BTC_INTF_UNKNOWN = 0,
198 } BTC_CHIP_INTERFACE, *PBTC_CHIP_INTERFACE;
200 typedef enum _BTC_CHIP_TYPE {
202 BTC_CHIP_CSR_BC4 = 1,
203 BTC_CHIP_CSR_BC8 = 2,
204 BTC_CHIP_RTL8723A = 3,
205 BTC_CHIP_RTL8821 = 4,
206 BTC_CHIP_RTL8723B = 5,
208 } BTC_CHIP_TYPE, *PBTC_CHIP_TYPE;
210 /* following is for wifi link status */
211 #define WIFI_STA_CONNECTED BIT0
212 #define WIFI_AP_CONNECTED BIT1
213 #define WIFI_HS_CONNECTED BIT2
214 #define WIFI_P2P_GO_CONNECTED BIT3
215 #define WIFI_P2P_GC_CONNECTED BIT4
217 /* following is for command line utility */
218 #define CL_SPRINTF rsprintf
219 #define CL_PRINTF DCMD_Printf
220 #define CL_STRNCAT(dst, dst_size, src, src_size) rstrncat(dst, src, src_size)
222 struct btc_board_info {
223 /* The following is some board information */
225 u8 pg_ant_num; /* pg ant number */
226 u8 btdm_ant_num; /* ant number for btdm */
227 u8 btdm_ant_num_by_ant_det; /* ant number for btdm after antenna detection */
228 u8 btdm_ant_pos; /* Bryant Add to indicate Antenna Position for (pg_ant_num = 2) && (btdm_ant_num =1) (DPDT+1Ant case) */
229 u8 single_ant_path; /* current used for 8723b only, 1=>s0, 0=>s1 */
230 boolean tfbga_package; /* for Antenna detect threshold */
231 boolean btdm_ant_det_finish;
232 boolean btdm_ant_det_already_init_phydm;
236 boolean btdm_ant_det_complete_fail;
238 boolean ant_det_result_five_complete;
244 typedef enum _BTC_DBG_OPCODE {
245 BTC_DBG_SET_COEX_NORMAL = 0x0,
246 BTC_DBG_SET_COEX_WIFI_ONLY = 0x1,
247 BTC_DBG_SET_COEX_BT_ONLY = 0x2,
248 BTC_DBG_SET_COEX_DEC_BT_PWR = 0x3,
249 BTC_DBG_SET_COEX_BT_AFH_MAP = 0x4,
250 BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT = 0x5,
251 BTC_DBG_SET_COEX_MANUAL_CTRL = 0x6,
253 } BTC_DBG_OPCODE, *PBTC_DBG_OPCODE;
255 typedef enum _BTC_RSSI_STATE {
256 BTC_RSSI_STATE_HIGH = 0x0,
257 BTC_RSSI_STATE_MEDIUM = 0x1,
258 BTC_RSSI_STATE_LOW = 0x2,
259 BTC_RSSI_STATE_STAY_HIGH = 0x3,
260 BTC_RSSI_STATE_STAY_MEDIUM = 0x4,
261 BTC_RSSI_STATE_STAY_LOW = 0x5,
263 } BTC_RSSI_STATE, *PBTC_RSSI_STATE;
264 #define BTC_RSSI_HIGH(_rssi_) ((_rssi_ == BTC_RSSI_STATE_HIGH || _rssi_ == BTC_RSSI_STATE_STAY_HIGH) ? TRUE:FALSE)
265 #define BTC_RSSI_MEDIUM(_rssi_) ((_rssi_ == BTC_RSSI_STATE_MEDIUM || _rssi_ == BTC_RSSI_STATE_STAY_MEDIUM) ? TRUE:FALSE)
266 #define BTC_RSSI_LOW(_rssi_) ((_rssi_ == BTC_RSSI_STATE_LOW || _rssi_ == BTC_RSSI_STATE_STAY_LOW) ? TRUE:FALSE)
268 typedef enum _BTC_WIFI_ROLE {
269 BTC_ROLE_STATION = 0x0,
272 BTC_ROLE_HS_MODE = 0x3,
274 } BTC_WIFI_ROLE, *PBTC_WIFI_ROLE;
276 typedef enum _BTC_WIRELESS_FREQ {
281 } BTC_WIRELESS_FREQ, *PBTC_WIRELESS_FREQ;
283 typedef enum _BTC_WIFI_BW_MODE {
284 BTC_WIFI_BW_LEGACY = 0x0,
285 BTC_WIFI_BW_HT20 = 0x1,
286 BTC_WIFI_BW_HT40 = 0x2,
287 BTC_WIFI_BW_HT80 = 0x3,
288 BTC_WIFI_BW_HT160 = 0x4,
290 } BTC_WIFI_BW_MODE, *PBTC_WIFI_BW_MODE;
292 typedef enum _BTC_WIFI_TRAFFIC_DIR {
293 BTC_WIFI_TRAFFIC_TX = 0x0,
294 BTC_WIFI_TRAFFIC_RX = 0x1,
296 } BTC_WIFI_TRAFFIC_DIR, *PBTC_WIFI_TRAFFIC_DIR;
298 typedef enum _BTC_WIFI_PNP {
299 BTC_WIFI_PNP_WAKE_UP = 0x0,
300 BTC_WIFI_PNP_SLEEP = 0x1,
301 BTC_WIFI_PNP_SLEEP_KEEP_ANT = 0x2,
302 BTC_WIFI_PNP_WOWLAN = 0x3,
304 } BTC_WIFI_PNP, *PBTC_WIFI_PNP;
306 typedef enum _BTC_IOT_PEER {
307 BTC_IOT_PEER_UNKNOWN = 0,
308 BTC_IOT_PEER_REALTEK = 1,
309 BTC_IOT_PEER_REALTEK_92SE = 2,
310 BTC_IOT_PEER_BROADCOM = 3,
311 BTC_IOT_PEER_RALINK = 4,
312 BTC_IOT_PEER_ATHEROS = 5,
313 BTC_IOT_PEER_CISCO = 6,
314 BTC_IOT_PEER_MERU = 7,
315 BTC_IOT_PEER_MARVELL = 8,
316 BTC_IOT_PEER_REALTEK_SOFTAP = 9, /* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 */
317 BTC_IOT_PEER_SELF_SOFTAP = 10, /* Self is SoftAP */
318 BTC_IOT_PEER_AIRGO = 11,
319 BTC_IOT_PEER_INTEL = 12,
320 BTC_IOT_PEER_RTK_APCLIENT = 13,
321 BTC_IOT_PEER_REALTEK_81XX = 14,
322 BTC_IOT_PEER_REALTEK_WOW = 15,
323 BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 16,
324 BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,
326 } BTC_IOT_PEER, *PBTC_IOT_PEER;
328 /* for 8723b-d cut large current issue */
329 typedef enum _BTC_WIFI_COEX_STATE {
332 BTC_WIFI_STAT_NORMAL_OFF,
333 BTC_WIFI_STAT_MP_OFF,
334 BTC_WIFI_STAT_NORMAL,
335 BTC_WIFI_STAT_ANT_DIV,
337 } BTC_WIFI_COEX_STATE, *PBTC_WIFI_COEX_STATE;
339 typedef enum _BTC_ANT_TYPE {
346 } BTC_ANT_TYPE, *PBTC_ANT_TYPE;
348 typedef enum _BTC_VENDOR {
352 } BTC_VENDOR, *PBTC_VENDOR;
355 /* defined for BFP_BTC_GET */
356 typedef enum _BTC_GET_TYPE {
358 BTC_GET_BL_HS_OPERATION,
359 BTC_GET_BL_HS_CONNECTING,
360 BTC_GET_BL_WIFI_FW_READY,
361 BTC_GET_BL_WIFI_CONNECTED,
362 BTC_GET_BL_WIFI_DUAL_BAND_CONNECTED,
363 BTC_GET_BL_WIFI_LINK_INFO,
364 BTC_GET_BL_WIFI_BUSY,
365 BTC_GET_BL_WIFI_SCAN,
366 BTC_GET_BL_WIFI_LINK,
367 BTC_GET_BL_WIFI_ROAM,
368 BTC_GET_BL_WIFI_4_WAY_PROGRESS,
369 BTC_GET_BL_WIFI_UNDER_5G,
370 BTC_GET_BL_WIFI_AP_MODE_ENABLE,
371 BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
372 BTC_GET_BL_WIFI_UNDER_B_MODE,
373 BTC_GET_BL_EXT_SWITCH,
374 BTC_GET_BL_WIFI_IS_IN_MP_MODE,
375 BTC_GET_BL_IS_ASUS_8723B,
376 BTC_GET_BL_RF4CE_CONNECTED,
377 BTC_GET_BL_WIFI_LW_PWR_STATE,
380 BTC_GET_S4_WIFI_RSSI,
385 BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
386 BTC_GET_U4_WIFI_FW_VER,
387 BTC_GET_U4_WIFI_LINK_STATUS,
388 BTC_GET_U4_BT_PATCH_VER,
390 BTC_GET_U4_SUPPORTED_VERSION,
391 BTC_GET_U4_SUPPORTED_FEATURE,
392 BTC_GET_U4_BT_DEVICE_INFO,
393 BTC_GET_U4_BT_FORBIDDEN_SLOT_VAL,
394 BTC_GET_U4_WIFI_IQK_TOTAL,
395 BTC_GET_U4_WIFI_IQK_OK,
396 BTC_GET_U4_WIFI_IQK_FAIL,
399 BTC_GET_U1_WIFI_DOT11_CHNL,
400 BTC_GET_U1_WIFI_CENTRAL_CHNL,
401 BTC_GET_U1_WIFI_HS_CHNL,
402 BTC_GET_U1_WIFI_P2P_CHNL,
403 BTC_GET_U1_MAC_PHY_MODE,
409 BTC_GET_U2_BEACON_PERIOD,
411 /*===== for 1Ant ======*/
415 } BTC_GET_TYPE, *PBTC_GET_TYPE;
417 /* defined for BFP_BTC_SET */
418 typedef enum _BTC_SET_TYPE {
420 BTC_SET_BL_BT_DISABLE,
421 BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE,
422 BTC_SET_BL_BT_TRAFFIC_BUSY,
423 BTC_SET_BL_BT_LIMITED_DIG,
424 BTC_SET_BL_FORCE_TO_ROAM,
425 BTC_SET_BL_TO_REJ_AP_AGG_PKT,
426 BTC_SET_BL_BT_CTRL_AGG_SIZE,
427 BTC_SET_BL_INC_SCAN_DEV_NUM,
428 BTC_SET_BL_BT_TX_RX_MASK,
429 BTC_SET_BL_MIRACAST_PLUS_BT,
430 BTC_SET_BL_BT_LNA_CONSTRAIN_LEVEL,
433 BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
434 BTC_SET_U1_AGG_BUF_SIZE,
436 /* type trigger some action */
437 BTC_SET_ACT_GET_BT_RSSI,
438 BTC_SET_ACT_AGGREGATE_CTRL,
439 BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
441 // for mimo ps mode setting
442 BTC_SET_MIMO_PS_MODE,
443 /*===== for 1Ant ======*/
447 BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
450 /* type trigger some action */
451 BTC_SET_ACT_LEAVE_LPS,
452 BTC_SET_ACT_ENTER_LPS,
453 BTC_SET_ACT_NORMAL_LPS,
454 BTC_SET_ACT_PRE_NORMAL_LPS,
455 BTC_SET_ACT_POST_NORMAL_LPS,
456 BTC_SET_ACT_DISABLE_LOW_POWER,
457 BTC_SET_ACT_UPDATE_RAMASK,
458 BTC_SET_ACT_SEND_MIMO_PS,
459 /* BT Coex related */
460 BTC_SET_ACT_CTRL_BT_INFO,
461 BTC_SET_ACT_CTRL_BT_COEX,
462 BTC_SET_ACT_CTRL_8723B_ANT,
463 /*=================*/
465 } BTC_SET_TYPE, *PBTC_SET_TYPE;
467 typedef enum _BTC_DBG_DISP_TYPE {
468 BTC_DBG_DISP_COEX_STATISTICS = 0x0,
469 BTC_DBG_DISP_BT_LINK_INFO = 0x1,
470 BTC_DBG_DISP_WIFI_STATUS = 0x2,
472 } BTC_DBG_DISP_TYPE, *PBTC_DBG_DISP_TYPE;
474 typedef enum _BTC_NOTIFY_TYPE_IPS {
478 } BTC_NOTIFY_TYPE_IPS, *PBTC_NOTIFY_TYPE_IPS;
479 typedef enum _BTC_NOTIFY_TYPE_LPS {
480 BTC_LPS_DISABLE = 0x0,
481 BTC_LPS_ENABLE = 0x1,
483 } BTC_NOTIFY_TYPE_LPS, *PBTC_NOTIFY_TYPE_LPS;
484 typedef enum _BTC_NOTIFY_TYPE_SCAN {
485 BTC_SCAN_FINISH = 0x0,
486 BTC_SCAN_START = 0x1,
487 BTC_SCAN_START_2G = 0x2,
488 BTC_SCAN_START_5G = 0x3,
490 } BTC_NOTIFY_TYPE_SCAN, *PBTC_NOTIFY_TYPE_SCAN;
491 typedef enum _BTC_NOTIFY_TYPE_SWITCHBAND {
492 BTC_NOT_SWITCH = 0x0,
493 BTC_SWITCH_TO_24G = 0x1,
494 BTC_SWITCH_TO_5G = 0x2,
495 BTC_SWITCH_TO_24G_NOFORSCAN = 0x3,
497 } BTC_NOTIFY_TYPE_SWITCHBAND, *PBTC_NOTIFY_TYPE_SWITCHBAND;
498 typedef enum _BTC_NOTIFY_TYPE_ASSOCIATE {
499 BTC_ASSOCIATE_FINISH = 0x0,
500 BTC_ASSOCIATE_START = 0x1,
501 BTC_ASSOCIATE_5G_FINISH = 0x2,
502 BTC_ASSOCIATE_5G_START = 0x3,
504 } BTC_NOTIFY_TYPE_ASSOCIATE, *PBTC_NOTIFY_TYPE_ASSOCIATE;
505 typedef enum _BTC_NOTIFY_TYPE_MEDIA_STATUS {
506 BTC_MEDIA_DISCONNECT = 0x0,
507 BTC_MEDIA_CONNECT = 0x1,
508 BTC_MEDIA_CONNECT_5G = 0x02,
510 } BTC_NOTIFY_TYPE_MEDIA_STATUS, *PBTC_NOTIFY_TYPE_MEDIA_STATUS;
511 typedef enum _BTC_NOTIFY_TYPE_SPECIFIC_PACKET {
512 BTC_PACKET_UNKNOWN = 0x0,
513 BTC_PACKET_DHCP = 0x1,
514 BTC_PACKET_ARP = 0x2,
515 BTC_PACKET_EAPOL = 0x3,
517 } BTC_NOTIFY_TYPE_SPECIFIC_PACKET, *PBTC_NOTIFY_TYPE_SPECIFIC_PACKET;
518 typedef enum _BTC_NOTIFY_TYPE_STACK_OPERATION {
519 BTC_STACK_OP_NONE = 0x0,
520 BTC_STACK_OP_INQ_PAGE_PAIR_START = 0x1,
521 BTC_STACK_OP_INQ_PAGE_PAIR_FINISH = 0x2,
523 } BTC_NOTIFY_TYPE_STACK_OPERATION, *PBTC_NOTIFY_TYPE_STACK_OPERATION;
526 typedef enum _BTC_ANTENNA_POS {
527 BTC_ANTENNA_AT_MAIN_PORT = 0x1,
528 BTC_ANTENNA_AT_AUX_PORT = 0x2,
529 } BTC_ANTENNA_POS, *PBTC_ANTENNA_POS;
532 typedef enum _BTC_BT_OFFON {
535 } BTC_BTOFFON, *PBTC_BT_OFFON;
537 #define BTC_5G_BAND 0x80
539 /*==================================================
540 For following block is for coex offload
541 ==================================================*/
542 typedef struct _COL_H2C {
547 } COL_H2C, *PCOL_H2C;
549 #define COL_C2H_ACK_HDR_LEN 3
550 typedef struct _COL_C2H_ACK {
556 } COL_C2H_ACK, *PCOL_C2H_ACK;
558 #define COL_C2H_IND_HDR_LEN 3
559 typedef struct _COL_C2H_IND {
564 } COL_C2H_IND, *PCOL_C2H_IND;
566 /*============================================
567 NOTE: for debug message, the following define should match
568 the strings in coexH2cResultString.
569 ============================================*/
570 typedef enum _COL_H2C_STATUS {
572 COL_STATUS_C2H_OK = 0x00, /* Wifi received H2C request and check content ok. */
573 COL_STATUS_C2H_UNKNOWN = 0x01, /* Not handled routine */
574 COL_STATUS_C2H_UNKNOWN_OPCODE = 0x02, /* Invalid OP code, It means that wifi firmware received an undefiend OP code. */
575 COL_STATUS_C2H_OPCODE_VER_MISMATCH = 0x03, /* Wifi firmware and wifi driver mismatch, need to update wifi driver or wifi or. */
576 COL_STATUS_C2H_PARAMETER_ERROR = 0x04, /* Error paraneter.(ex: parameters = NULL but it should have values) */
577 COL_STATUS_C2H_PARAMETER_OUT_OF_RANGE = 0x05, /* Wifi firmware needs to check the parameters from H2C request and return the status.(ex: ch = 500, it's wrong) */
578 /* other COL status start from here */
579 COL_STATUS_C2H_REQ_NUM_MISMATCH , /* c2h req_num mismatch, means this c2h is not we expected. */
580 COL_STATUS_H2C_HALMAC_FAIL , /* HALMAC return fail. */
581 COL_STATUS_H2C_TIMTOUT , /* not received the c2h response from fw */
582 COL_STATUS_INVALID_C2H_LEN , /* invalid coex offload c2h ack length, must >= 3 */
583 COL_STATUS_COEX_DATA_OVERFLOW , /* coex returned length over the c2h ack length. */
585 } COL_H2C_STATUS, *PCOL_H2C_STATUS;
587 #define COL_MAX_H2C_REQ_NUM 16
589 #define COL_H2C_BUF_LEN 20
590 typedef enum _COL_OPCODE {
591 COL_OP_WIFI_STATUS_NOTIFY = 0x0,
592 COL_OP_WIFI_PROGRESS_NOTIFY = 0x1,
593 COL_OP_WIFI_INFO_NOTIFY = 0x2,
594 COL_OP_WIFI_POWER_STATE_NOTIFY = 0x3,
595 COL_OP_SET_CONTROL = 0x4,
596 COL_OP_GET_CONTROL = 0x5,
597 COL_OP_WIFI_OPCODE_MAX
598 } COL_OPCODE, *PCOL_OPCODE;
600 typedef enum _COL_IND_TYPE {
601 COL_IND_BT_INFO = 0x0,
602 COL_IND_PSTDMA = 0x1,
603 COL_IND_LIMITED_TX_RX = 0x2,
604 COL_IND_COEX_TABLE = 0x3,
607 } COL_IND_TYPE, *PCOL_IND_TYPE;
609 typedef struct _COL_SINGLE_H2C_RECORD {
610 u1Byte h2c_buf[COL_H2C_BUF_LEN]; /* the latest sent h2c buffer */
612 u1Byte c2h_ack_buf[COL_H2C_BUF_LEN]; /* the latest received c2h buffer */
614 u4Byte count; /* the total number of the sent h2c command */
615 u4Byte status[COL_STATUS_MAX]; /* the c2h status for the sent h2c command */
616 } COL_SINGLE_H2C_RECORD, *PCOL_SINGLE_H2C_RECORD;
618 typedef struct _COL_SINGLE_C2H_IND_RECORD {
619 u1Byte ind_buf[COL_H2C_BUF_LEN]; /* the latest received c2h indication buffer */
621 u4Byte count; /* the total number of the rcvd c2h indication */
622 u4Byte status[COL_STATUS_MAX]; /* the c2h indication verified status */
623 } COL_SINGLE_C2H_IND_RECORD, *PCOL_SINGLE_C2H_IND_RECORD;
625 typedef struct _BTC_OFFLOAD {
626 /* H2C command related */
629 COL_SINGLE_H2C_RECORD h2c_record[COL_OP_WIFI_OPCODE_MAX];
631 /* C2H Ack related */
633 u4Byte status[COL_STATUS_MAX];
634 struct completion c2h_event[COL_MAX_H2C_REQ_NUM]; /* for req_num = 1~COL_MAX_H2C_REQ_NUM */
635 u1Byte c2h_ack_buf[COL_MAX_H2C_REQ_NUM][COL_H2C_BUF_LEN];
636 u1Byte c2h_ack_len[COL_MAX_H2C_REQ_NUM];
638 /* C2H Indication related */
640 COL_SINGLE_C2H_IND_RECORD c2h_ind_record[COL_IND_MAX];
641 u4Byte c2h_ind_status[COL_STATUS_MAX];
642 u1Byte c2h_ind_buf[COL_H2C_BUF_LEN];
644 } BTC_OFFLOAD, *PBTC_OFFLOAD;
645 extern BTC_OFFLOAD gl_coex_offload;
646 /*==================================================*/
648 /* BTC_LINK_MODE same as WIFI_LINK_MODE */
649 typedef enum _BTC_LINK_MODE{
655 BTC_LINK_2G_MCC_GO_STA,
656 BTC_LINK_5G_MCC_GO_STA,
657 BTC_LINK_25G_MCC_GO_STA,
658 BTC_LINK_2G_MCC_GC_STA,
659 BTC_LINK_5G_MCC_GC_STA,
660 BTC_LINK_25G_MCC_GC_STA,
661 BTC_LINK_2G_SCC_GO_STA,
662 BTC_LINK_5G_SCC_GO_STA,
663 BTC_LINK_2G_SCC_GC_STA,
664 BTC_LINK_5G_SCC_GC_STA,
666 }BTC_LINK_MODE, *PBTC_LINK_MODE;
669 struct btc_wifi_link_info {
670 BTC_LINK_MODE link_mode; /* LinkMode */
671 u1Byte sta_center_channel; /* StaCenterChannel */
672 u1Byte p2p_center_channel; /* P2PCenterChannel */
673 BOOLEAN bany_client_join_go;
678 typedef enum _BTC_MULTI_PORT_TDMA_MODE {
679 BTC_MULTI_PORT_TDMA_MODE_NONE=0,
680 BTC_MULTI_PORT_TDMA_MODE_2G_SCC_GO,
681 BTC_MULTI_PORT_TDMA_MODE_2G_P2P_GO,
682 BTC_MULTI_PORT_TDMA_MODE_2G_HOTSPOT_GO
683 } BTC_MULTI_PORT_TDMA_MODE, *PBTC_MULTI_PORT_TDMA_MODE;
685 typedef struct btc_multi_port_tdma_info {
686 BTC_MULTI_PORT_TDMA_MODE btc_multi_port_tdma_mode;
687 u1Byte start_time_from_bcn;
689 } BTC_MULTI_PORT_TDMA_INFO, *PBTC_MULTI_PORT_TDMA_INFO;
693 IN PVOID pBtcContext,
698 IN PVOID pBtcContext,
703 IN PVOID pBtcContext,
708 IN PVOID pBtcContext,
713 (*BFP_BTC_W1_BIT_MASK)(
714 IN PVOID pBtcContext,
721 IN PVOID pBtcContext,
727 IN PVOID pBtcContext,
732 (*BFP_BTC_LOCAL_REG_W1)(
733 IN PVOID pBtcContext,
738 (*BFP_BTC_SET_BB_REG)(
739 IN PVOID pBtcContext,
745 (*BFP_BTC_GET_BB_REG)(
746 IN PVOID pBtcContext,
751 (*BFP_BTC_SET_RF_REG)(
752 IN PVOID pBtcContext,
753 IN enum rf_path eRFPath,
759 (*BFP_BTC_GET_RF_REG)(
760 IN PVOID pBtcContext,
761 IN enum rf_path eRFPath,
767 IN PVOID pBtcContext,
770 IN pu1Byte pCmdBuffer
787 (*BFP_BTC_SET_BT_REG)(
788 IN PVOID pBtcContext,
794 (*BFP_BTC_SET_BT_ANT_DETECTION)(
795 IN PVOID pBtcContext,
801 (*BFP_BTC_SET_BT_TRX_MASK)(
802 IN PVOID pBtcContext,
803 IN u1Byte bt_trx_mask
807 (*BFP_BTC_GET_BT_REG)(
808 IN PVOID pBtcContext,
813 (*BFP_BTC_DISP_DBG_MSG)(
818 typedef COL_H2C_STATUS
819 (*BFP_BTC_COEX_H2C_PROCESS)(
822 IN u1Byte opcode_ver,
824 IN u1Byte h2c_par_len
828 (*BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE)(
833 (*BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION)(
838 (*BFP_BTC_GET_PHYDM_VERSION)(
843 (*BFP_BTC_SET_ATOMIC) (
844 IN PVOID pBtcContext,
851 (*BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD)(
853 IN u1Byte RA_offset_direction,
854 IN u1Byte RA_threshold_offset
858 (*BTC_PHYDM_CMNINFOQUERY)(
864 (*BTC_PHYDM_MODIFY_ANTDIV_HWSW)(
870 (*BFP_BTC_GET_ANT_DET_VAL_FROM_BT)(
876 (*BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT)(
881 (*BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT)(
882 IN PVOID pBtcContext,
887 (*BFP_BTC_GET_BT_AFH_MAP_FROM_BT)(
888 IN PVOID pBtcContext,
895 boolean bt_enable_disable_change;
896 u8 rssi_adjust_for_agc_table_on;
897 u8 rssi_adjust_for_1ant_coex_type;
898 boolean pre_bt_ctrl_agg_buf_size;
899 boolean bt_ctrl_agg_buf_size;
900 boolean pre_reject_agg_pkt;
901 boolean reject_agg_pkt;
902 boolean increase_scan_dev_num;
903 boolean bt_tx_rx_mask;
911 u32 get_bt_fw_ver_cnt;
913 boolean miracast_plus_bt;
915 boolean bt_disable_low_pwr;
919 boolean force_to_roam; /* for 1Ant solution */
925 struct btc_stack_info {
926 boolean profile_notified;
927 u16 hci_version; /* stack hci version */
929 boolean bt_link_exist;
936 boolean unknown_acl_exist;
940 struct btc_bt_link_info {
941 boolean bt_link_exist;
942 boolean bt_hi_pri_link_exist;
955 #ifdef CONFIG_RF4CE_COEXIST
956 struct btc_rf4ce_info {
961 struct btc_statistics {
964 u32 cnt_pre_load_firmware;
965 u32 cnt_init_hw_config;
966 u32 cnt_init_coex_dm;
970 u32 cnt_connect_notify;
971 u32 cnt_media_status_notify;
972 u32 cnt_specific_packet_notify;
973 u32 cnt_bt_info_notify;
974 u32 cnt_rf_status_notify;
976 u32 cnt_coex_dm_switch;
977 u32 cnt_stack_operation_notify;
979 u32 cnt_rate_id_notify;
985 BOOLEAN bBinded; /*make sure only one adapter can bind the data context*/
986 PVOID Adapter; /*default adapter*/
987 struct btc_board_info board_info;
988 struct btc_bt_info bt_info; /*some bt info referenced by non-bt module*/
989 struct btc_stack_info stack_info;
990 struct btc_bt_link_info bt_link_info;
991 struct btc_wifi_link_info wifi_link_info;
993 #ifdef CONFIG_RF4CE_COEXIST
994 struct btc_rf4ce_info rf4ce_info;
996 BTC_CHIP_INTERFACE chip_interface;
1000 BOOLEAN stop_coex_dm;
1001 BOOLEAN manual_control;
1002 BOOLEAN bdontenterLPS;
1004 struct btc_statistics statistics;
1005 u1Byte pwrModeVal[10];
1007 BOOLEAN auto_report;
1009 /* function pointers */
1011 BFP_BTC_R1 btc_read_1byte;
1012 BFP_BTC_W1 btc_write_1byte;
1013 BFP_BTC_W1_BIT_MASK btc_write_1byte_bitmask;
1014 BFP_BTC_R2 btc_read_2byte;
1015 BFP_BTC_W2 btc_write_2byte;
1016 BFP_BTC_R4 btc_read_4byte;
1017 BFP_BTC_W4 btc_write_4byte;
1018 BFP_BTC_LOCAL_REG_W1 btc_write_local_reg_1byte;
1019 /* read/write bb related */
1020 BFP_BTC_SET_BB_REG btc_set_bb_reg;
1021 BFP_BTC_GET_BB_REG btc_get_bb_reg;
1023 /* read/write rf related */
1024 BFP_BTC_SET_RF_REG btc_set_rf_reg;
1025 BFP_BTC_GET_RF_REG btc_get_rf_reg;
1027 /* fill h2c related */
1028 BFP_BTC_FILL_H2C btc_fill_h2c;
1030 BFP_BTC_DISP_DBG_MSG btc_disp_dbg_msg;
1031 /* normal get/set related */
1032 BFP_BTC_GET btc_get;
1033 BFP_BTC_SET btc_set;
1035 BFP_BTC_GET_BT_REG btc_get_bt_reg;
1036 BFP_BTC_SET_BT_REG btc_set_bt_reg;
1038 BFP_BTC_SET_BT_ANT_DETECTION btc_set_bt_ant_detection;
1040 BFP_BTC_COEX_H2C_PROCESS btc_coex_h2c_process;
1041 BFP_BTC_SET_BT_TRX_MASK btc_set_bt_trx_mask;
1042 BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE btc_get_bt_coex_supported_feature;
1043 BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION btc_get_bt_coex_supported_version;
1044 BFP_BTC_GET_PHYDM_VERSION btc_get_bt_phydm_version;
1045 BFP_BTC_SET_ATOMIC btc_set_atomic;
1046 BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD btc_phydm_modify_RA_PCR_threshold;
1047 BTC_PHYDM_CMNINFOQUERY btc_phydm_query_PHY_counter;
1048 BTC_PHYDM_MODIFY_ANTDIV_HWSW btc_phydm_modify_antdiv_hwsw;
1049 BFP_BTC_GET_ANT_DET_VAL_FROM_BT btc_get_ant_det_val_from_bt;
1050 BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT btc_get_ble_scan_type_from_bt;
1051 BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT btc_get_ble_scan_para_from_bt;
1052 BFP_BTC_GET_BT_AFH_MAP_FROM_BT btc_get_bt_afh_map_from_bt;
1055 #ifdef CONFIG_RTL8822B
1056 struct coex_dm_8822b_1ant coex_dm_8822b_1ant;
1057 struct coex_dm_8822b_2ant coex_dm_8822b_2ant;
1059 #ifdef CONFIG_RTL8821C
1060 struct coex_dm_8821c_1ant coex_dm_8821c_1ant;
1061 struct coex_dm_8821c_2ant coex_dm_8821c_2ant;
1066 #ifdef CONFIG_RTL8822B
1067 struct coex_sta_8822b_1ant coex_sta_8822b_1ant;
1068 struct coex_sta_8822b_2ant coex_sta_8822b_2ant;
1070 #ifdef CONFIG_RTL8821C
1071 struct coex_sta_8821c_1ant coex_sta_8821c_1ant;
1072 struct coex_sta_8821c_2ant coex_sta_8821c_2ant;
1077 #ifdef CONFIG_RTL8822B
1078 struct rfe_type_8822b_1ant rfe_type_8822b_1ant;
1079 struct rfe_type_8822b_2ant rfe_type_8822b_2ant;
1081 #ifdef CONFIG_RTL8821C
1082 struct rfe_type_8821c_1ant rfe_type_8821c_1ant;
1083 struct rfe_type_8821c_2ant rfe_type_8821c_2ant;
1088 #ifdef CONFIG_RTL8822B
1089 struct wifi_link_info_8822b_1ant wifi_link_info_8822b_1ant;
1090 struct wifi_link_info_8822b_2ant wifi_link_info_8822b_2ant;
1092 #ifdef CONFIG_RTL8821C
1093 struct wifi_link_info_8821c_1ant wifi_link_info_8821c_1ant;
1094 struct wifi_link_info_8821c_2ant wifi_link_info_8821c_2ant;
1099 typedef struct btc_coexist *PBTC_COEXIST;
1101 extern struct btc_coexist GLBtCoexist;
1104 EXhalbtcoutsrc_InitlizeVariables(
1108 EXhalbtcoutsrc_PowerOnSetting(
1109 IN PBTC_COEXIST pBtCoexist
1112 EXhalbtcoutsrc_PreLoadFirmware(
1113 IN PBTC_COEXIST pBtCoexist
1116 EXhalbtcoutsrc_InitHwConfig(
1117 IN PBTC_COEXIST pBtCoexist,
1118 IN BOOLEAN bWifiOnly
1121 EXhalbtcoutsrc_InitCoexDm(
1122 IN PBTC_COEXIST pBtCoexist
1125 EXhalbtcoutsrc_IpsNotify(
1126 IN PBTC_COEXIST pBtCoexist,
1130 EXhalbtcoutsrc_LpsNotify(
1131 IN PBTC_COEXIST pBtCoexist,
1135 EXhalbtcoutsrc_ScanNotify(
1136 IN PBTC_COEXIST pBtCoexist,
1140 EXhalbtcoutsrc_SetAntennaPathNotify(
1141 IN PBTC_COEXIST pBtCoexist,
1145 EXhalbtcoutsrc_ConnectNotify(
1146 IN PBTC_COEXIST pBtCoexist,
1150 EXhalbtcoutsrc_MediaStatusNotify(
1151 IN PBTC_COEXIST pBtCoexist,
1152 IN RT_MEDIA_STATUS mediaStatus
1155 EXhalbtcoutsrc_SpecificPacketNotify(
1156 IN PBTC_COEXIST pBtCoexist,
1160 EXhalbtcoutsrc_BtInfoNotify(
1161 IN PBTC_COEXIST pBtCoexist,
1166 EXhalbtcoutsrc_RfStatusNotify(
1167 IN PBTC_COEXIST pBtCoexist,
1171 EXhalbtcoutsrc_WlFwDbgInfoNotify(
1172 IN PBTC_COEXIST pBtCoexist,
1177 EXhalbtcoutsrc_rx_rate_change_notify(
1178 IN PBTC_COEXIST pBtCoexist,
1179 IN BOOLEAN is_data_frame,
1180 IN u1Byte btc_rate_id
1183 EXhalbtcoutsrc_StackOperationNotify(
1184 IN PBTC_COEXIST pBtCoexist,
1188 EXhalbtcoutsrc_HaltNotify(
1189 IN PBTC_COEXIST pBtCoexist
1192 EXhalbtcoutsrc_PnpNotify(
1193 IN PBTC_COEXIST pBtCoexist,
1197 EXhalbtcoutsrc_CoexDmSwitch(
1198 IN PBTC_COEXIST pBtCoexist
1201 EXhalbtcoutsrc_Periodical(
1202 IN PBTC_COEXIST pBtCoexist
1205 EXhalbtcoutsrc_DbgControl(
1206 IN PBTC_COEXIST pBtCoexist,
1212 EXhalbtcoutsrc_AntennaDetection(
1213 IN PBTC_COEXIST pBtCoexist,
1220 EXhalbtcoutsrc_StackUpdateProfileInfo(
1224 EXhalbtcoutsrc_SetHciVersion(
1225 IN u2Byte hciVersion
1228 EXhalbtcoutsrc_SetBtPatchVersion(
1229 IN u2Byte btHciVersion,
1230 IN u2Byte btPatchVersion
1233 EXhalbtcoutsrc_UpdateMinBtRssi(
1238 EXhalbtcoutsrc_SetBtExist(
1243 EXhalbtcoutsrc_SetChipType(
1247 EXhalbtcoutsrc_SetAntNum(
1252 EXhalbtcoutsrc_SetSingleAntPath(
1253 IN u1Byte singleAntPath
1256 EXhalbtcoutsrc_DisplayBtCoexInfo(
1257 IN PBTC_COEXIST pBtCoexist
1260 EXhalbtcoutsrc_DisplayAntDetection(
1261 IN PBTC_COEXIST pBtCoexist
1264 #define MASKBYTE0 0xff
1265 #define MASKBYTE1 0xff00
1266 #define MASKBYTE2 0xff0000
1267 #define MASKBYTE3 0xff000000
1268 #define MASKHWORD 0xffff0000
1269 #define MASKLWORD 0x0000ffff
1270 #define MASKDWORD 0xffffffff
1271 #define MASK12BITS 0xfff
1272 #define MASKH4BITS 0xf0000000
1273 #define MASKOFDM_D 0xffc00000
1274 #define MASKCCK 0x3f3f3f3f