halbtcoutsrc.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014
  1. #ifndef __HALBTC_OUT_SRC_H__
  2. #define __HALBTC_OUT_SRC_H__
  3. #define BTC_COEX_OFFLOAD 0
  4. #define BTC_TMP_BUF_SHORT 20
  5. extern u1Byte gl_btc_trace_buf[];
  6. #define BTC_SPRINTF rsprintf
  7. #define BTC_TRACE(_MSG_)\
  8. do {\
  9. if (GLBtcDbgType[COMP_COEX] & BIT(DBG_LOUD)) {\
  10. RTW_INFO("%s", _MSG_);\
  11. } \
  12. } while (0)
  13. #define BT_PrintData(adapter, _MSG_, len, data) RTW_DBG_DUMP((_MSG_), data, len)
  14. #define NORMAL_EXEC FALSE
  15. #define FORCE_EXEC TRUE
  16. #define BTC_RF_OFF 0x0
  17. #define BTC_RF_ON 0x1
  18. #define BTC_RF_A 0x0
  19. #define BTC_RF_B 0x1
  20. #define BTC_RF_C 0x2
  21. #define BTC_RF_D 0x3
  22. #define BTC_SMSP SINGLEMAC_SINGLEPHY
  23. #define BTC_DMDP DUALMAC_DUALPHY
  24. #define BTC_DMSP DUALMAC_SINGLEPHY
  25. #define BTC_MP_UNKNOWN 0xff
  26. #define BT_COEX_ANT_TYPE_PG 0
  27. #define BT_COEX_ANT_TYPE_ANTDIV 1
  28. #define BT_COEX_ANT_TYPE_DETECTED 2
  29. #define BTC_MIMO_PS_STATIC 0 /* 1ss */
  30. #define BTC_MIMO_PS_DYNAMIC 1 /* 2ss */
  31. #define BTC_RATE_DISABLE 0
  32. #define BTC_RATE_ENABLE 1
  33. /* single Antenna definition */
  34. #define BTC_ANT_PATH_WIFI 0
  35. #define BTC_ANT_PATH_BT 1
  36. #define BTC_ANT_PATH_PTA 2
  37. #define BTC_ANT_PATH_WIFI5G 3
  38. #define BTC_ANT_PATH_AUTO 4
  39. /* dual Antenna definition */
  40. #define BTC_ANT_WIFI_AT_MAIN 0
  41. #define BTC_ANT_WIFI_AT_AUX 1
  42. #define BTC_ANT_WIFI_AT_DIVERSITY 2
  43. /* coupler Antenna definition */
  44. #define BTC_ANT_WIFI_AT_CPL_MAIN 0
  45. #define BTC_ANT_WIFI_AT_CPL_AUX 1
  46. typedef enum _BTC_POWERSAVE_TYPE {
  47. BTC_PS_WIFI_NATIVE = 0, /* wifi original power save behavior */
  48. BTC_PS_LPS_ON = 1,
  49. BTC_PS_LPS_OFF = 2,
  50. BTC_PS_MAX
  51. } BTC_POWERSAVE_TYPE, *PBTC_POWERSAVE_TYPE;
  52. typedef enum _BTC_BT_REG_TYPE {
  53. BTC_BT_REG_RF = 0,
  54. BTC_BT_REG_MODEM = 1,
  55. BTC_BT_REG_BLUEWIZE = 2,
  56. BTC_BT_REG_VENDOR = 3,
  57. BTC_BT_REG_LE = 4,
  58. BTC_BT_REG_MAX
  59. } BTC_BT_REG_TYPE, *PBTC_BT_REG_TYPE;
  60. typedef enum _BTC_CHIP_INTERFACE {
  61. BTC_INTF_UNKNOWN = 0,
  62. BTC_INTF_PCI = 1,
  63. BTC_INTF_USB = 2,
  64. BTC_INTF_SDIO = 3,
  65. BTC_INTF_MAX
  66. } BTC_CHIP_INTERFACE, *PBTC_CHIP_INTERFACE;
  67. typedef enum _BTC_CHIP_TYPE {
  68. BTC_CHIP_UNDEF = 0,
  69. BTC_CHIP_CSR_BC4 = 1,
  70. BTC_CHIP_CSR_BC8 = 2,
  71. BTC_CHIP_RTL8723A = 3,
  72. BTC_CHIP_RTL8821 = 4,
  73. BTC_CHIP_RTL8723B = 5,
  74. BTC_CHIP_MAX
  75. } BTC_CHIP_TYPE, *PBTC_CHIP_TYPE;
  76. /* following is for wifi link status */
  77. #define WIFI_STA_CONNECTED BIT0
  78. #define WIFI_AP_CONNECTED BIT1
  79. #define WIFI_HS_CONNECTED BIT2
  80. #define WIFI_P2P_GO_CONNECTED BIT3
  81. #define WIFI_P2P_GC_CONNECTED BIT4
  82. /* following is for command line utility */
  83. #define CL_SPRINTF rsprintf
  84. #define CL_PRINTF DCMD_Printf
  85. struct btc_board_info {
  86. /* The following is some board information */
  87. u8 bt_chip_type;
  88. u8 pg_ant_num; /* pg ant number */
  89. u8 btdm_ant_num; /* ant number for btdm */
  90. u8 btdm_ant_num_by_ant_det; /* ant number for btdm after antenna detection */
  91. u8 btdm_ant_pos; /* Bryant Add to indicate Antenna Position for (pg_ant_num = 2) && (btdm_ant_num =1) (DPDT+1Ant case) */
  92. u8 single_ant_path; /* current used for 8723b only, 1=>s0, 0=>s1 */
  93. boolean tfbga_package; /* for Antenna detect threshold */
  94. boolean btdm_ant_det_finish;
  95. boolean btdm_ant_det_already_init_phydm;
  96. u8 ant_type;
  97. u8 rfe_type;
  98. u8 ant_div_cfg;
  99. boolean btdm_ant_det_complete_fail;
  100. u8 ant_det_result;
  101. boolean ant_det_result_five_complete;
  102. u32 antdetval;
  103. };
  104. typedef enum _BTC_DBG_OPCODE {
  105. BTC_DBG_SET_COEX_NORMAL = 0x0,
  106. BTC_DBG_SET_COEX_WIFI_ONLY = 0x1,
  107. BTC_DBG_SET_COEX_BT_ONLY = 0x2,
  108. BTC_DBG_SET_COEX_DEC_BT_PWR = 0x3,
  109. BTC_DBG_SET_COEX_BT_AFH_MAP = 0x4,
  110. BTC_DBG_SET_COEX_BT_IGNORE_WLAN_ACT = 0x5,
  111. BTC_DBG_SET_COEX_MANUAL_CTRL = 0x6,
  112. BTC_DBG_MAX
  113. } BTC_DBG_OPCODE, *PBTC_DBG_OPCODE;
  114. typedef enum _BTC_RSSI_STATE {
  115. BTC_RSSI_STATE_HIGH = 0x0,
  116. BTC_RSSI_STATE_MEDIUM = 0x1,
  117. BTC_RSSI_STATE_LOW = 0x2,
  118. BTC_RSSI_STATE_STAY_HIGH = 0x3,
  119. BTC_RSSI_STATE_STAY_MEDIUM = 0x4,
  120. BTC_RSSI_STATE_STAY_LOW = 0x5,
  121. BTC_RSSI_MAX
  122. } BTC_RSSI_STATE, *PBTC_RSSI_STATE;
  123. #define BTC_RSSI_HIGH(_rssi_) ((_rssi_ == BTC_RSSI_STATE_HIGH || _rssi_ == BTC_RSSI_STATE_STAY_HIGH) ? TRUE:FALSE)
  124. #define BTC_RSSI_MEDIUM(_rssi_) ((_rssi_ == BTC_RSSI_STATE_MEDIUM || _rssi_ == BTC_RSSI_STATE_STAY_MEDIUM) ? TRUE:FALSE)
  125. #define BTC_RSSI_LOW(_rssi_) ((_rssi_ == BTC_RSSI_STATE_LOW || _rssi_ == BTC_RSSI_STATE_STAY_LOW) ? TRUE:FALSE)
  126. typedef enum _BTC_WIFI_ROLE {
  127. BTC_ROLE_STATION = 0x0,
  128. BTC_ROLE_AP = 0x1,
  129. BTC_ROLE_IBSS = 0x2,
  130. BTC_ROLE_HS_MODE = 0x3,
  131. BTC_ROLE_MAX
  132. } BTC_WIFI_ROLE, *PBTC_WIFI_ROLE;
  133. typedef enum _BTC_WIRELESS_FREQ {
  134. BTC_FREQ_2_4G = 0x0,
  135. BTC_FREQ_5G = 0x1,
  136. BTC_FREQ_MAX
  137. } BTC_WIRELESS_FREQ, *PBTC_WIRELESS_FREQ;
  138. typedef enum _BTC_WIFI_BW_MODE {
  139. BTC_WIFI_BW_LEGACY = 0x0,
  140. BTC_WIFI_BW_HT20 = 0x1,
  141. BTC_WIFI_BW_HT40 = 0x2,
  142. BTC_WIFI_BW_HT80 = 0x3,
  143. BTC_WIFI_BW_HT160 = 0x4,
  144. BTC_WIFI_BW_MAX
  145. } BTC_WIFI_BW_MODE, *PBTC_WIFI_BW_MODE;
  146. typedef enum _BTC_WIFI_TRAFFIC_DIR {
  147. BTC_WIFI_TRAFFIC_TX = 0x0,
  148. BTC_WIFI_TRAFFIC_RX = 0x1,
  149. BTC_WIFI_TRAFFIC_MAX
  150. } BTC_WIFI_TRAFFIC_DIR, *PBTC_WIFI_TRAFFIC_DIR;
  151. typedef enum _BTC_WIFI_PNP {
  152. BTC_WIFI_PNP_WAKE_UP = 0x0,
  153. BTC_WIFI_PNP_SLEEP = 0x1,
  154. BTC_WIFI_PNP_SLEEP_KEEP_ANT = 0x2,
  155. BTC_WIFI_PNP_MAX
  156. } BTC_WIFI_PNP, *PBTC_WIFI_PNP;
  157. typedef enum _BTC_IOT_PEER {
  158. BTC_IOT_PEER_UNKNOWN = 0,
  159. BTC_IOT_PEER_REALTEK = 1,
  160. BTC_IOT_PEER_REALTEK_92SE = 2,
  161. BTC_IOT_PEER_BROADCOM = 3,
  162. BTC_IOT_PEER_RALINK = 4,
  163. BTC_IOT_PEER_ATHEROS = 5,
  164. BTC_IOT_PEER_CISCO = 6,
  165. BTC_IOT_PEER_MERU = 7,
  166. BTC_IOT_PEER_MARVELL = 8,
  167. BTC_IOT_PEER_REALTEK_SOFTAP = 9, /* peer is RealTek SOFT_AP, by Bohn, 2009.12.17 */
  168. BTC_IOT_PEER_SELF_SOFTAP = 10, /* Self is SoftAP */
  169. BTC_IOT_PEER_AIRGO = 11,
  170. BTC_IOT_PEER_INTEL = 12,
  171. BTC_IOT_PEER_RTK_APCLIENT = 13,
  172. BTC_IOT_PEER_REALTEK_81XX = 14,
  173. BTC_IOT_PEER_REALTEK_WOW = 15,
  174. BTC_IOT_PEER_REALTEK_JAGUAR_BCUTAP = 16,
  175. BTC_IOT_PEER_REALTEK_JAGUAR_CCUTAP = 17,
  176. BTC_IOT_PEER_MAX,
  177. } BTC_IOT_PEER, *PBTC_IOT_PEER;
  178. /* for 8723b-d cut large current issue */
  179. typedef enum _BTC_WIFI_COEX_STATE {
  180. BTC_WIFI_STAT_INIT,
  181. BTC_WIFI_STAT_IQK,
  182. BTC_WIFI_STAT_NORMAL_OFF,
  183. BTC_WIFI_STAT_MP_OFF,
  184. BTC_WIFI_STAT_NORMAL,
  185. BTC_WIFI_STAT_ANT_DIV,
  186. BTC_WIFI_STAT_MAX
  187. } BTC_WIFI_COEX_STATE, *PBTC_WIFI_COEX_STATE;
  188. typedef enum _BTC_ANT_TYPE {
  189. BTC_ANT_TYPE_0,
  190. BTC_ANT_TYPE_1,
  191. BTC_ANT_TYPE_2,
  192. BTC_ANT_TYPE_3,
  193. BTC_ANT_TYPE_4,
  194. BTC_ANT_TYPE_MAX
  195. } BTC_ANT_TYPE, *PBTC_ANT_TYPE;
  196. typedef enum _BTC_VENDOR {
  197. BTC_VENDOR_LENOVO,
  198. BTC_VENDOR_ASUS,
  199. BTC_VENDOR_OTHER
  200. } BTC_VENDOR, *PBTC_VENDOR;
  201. /* defined for BFP_BTC_GET */
  202. typedef enum _BTC_GET_TYPE {
  203. /* type BOOLEAN */
  204. BTC_GET_BL_HS_OPERATION,
  205. BTC_GET_BL_HS_CONNECTING,
  206. BTC_GET_BL_WIFI_FW_READY,
  207. BTC_GET_BL_WIFI_CONNECTED,
  208. BTC_GET_BL_WIFI_BUSY,
  209. BTC_GET_BL_WIFI_SCAN,
  210. BTC_GET_BL_WIFI_LINK,
  211. BTC_GET_BL_WIFI_ROAM,
  212. BTC_GET_BL_WIFI_4_WAY_PROGRESS,
  213. BTC_GET_BL_WIFI_UNDER_5G,
  214. BTC_GET_BL_WIFI_AP_MODE_ENABLE,
  215. BTC_GET_BL_WIFI_ENABLE_ENCRYPTION,
  216. BTC_GET_BL_WIFI_UNDER_B_MODE,
  217. BTC_GET_BL_EXT_SWITCH,
  218. BTC_GET_BL_WIFI_IS_IN_MP_MODE,
  219. BTC_GET_BL_IS_ASUS_8723B,
  220. BTC_GET_BL_RF4CE_CONNECTED,
  221. /* type s4Byte */
  222. BTC_GET_S4_WIFI_RSSI,
  223. BTC_GET_S4_HS_RSSI,
  224. /* type u4Byte */
  225. BTC_GET_U4_WIFI_BW,
  226. BTC_GET_U4_WIFI_TRAFFIC_DIRECTION,
  227. BTC_GET_U4_WIFI_FW_VER,
  228. BTC_GET_U4_WIFI_LINK_STATUS,
  229. BTC_GET_U4_BT_PATCH_VER,
  230. BTC_GET_U4_VENDOR,
  231. BTC_GET_U4_SUPPORTED_VERSION,
  232. BTC_GET_U4_SUPPORTED_FEATURE,
  233. BTC_GET_U4_WIFI_IQK_TOTAL,
  234. BTC_GET_U4_WIFI_IQK_OK,
  235. BTC_GET_U4_WIFI_IQK_FAIL,
  236. /* type u1Byte */
  237. BTC_GET_U1_WIFI_DOT11_CHNL,
  238. BTC_GET_U1_WIFI_CENTRAL_CHNL,
  239. BTC_GET_U1_WIFI_HS_CHNL,
  240. BTC_GET_U1_WIFI_P2P_CHNL,
  241. BTC_GET_U1_MAC_PHY_MODE,
  242. BTC_GET_U1_AP_NUM,
  243. BTC_GET_U1_ANT_TYPE,
  244. BTC_GET_U1_IOT_PEER,
  245. /*===== for 1Ant ======*/
  246. BTC_GET_U1_LPS_MODE,
  247. BTC_GET_MAX
  248. } BTC_GET_TYPE, *PBTC_GET_TYPE;
  249. /* defined for BFP_BTC_SET */
  250. typedef enum _BTC_SET_TYPE {
  251. /* type BOOLEAN */
  252. BTC_SET_BL_BT_DISABLE,
  253. BTC_SET_BL_BT_ENABLE_DISABLE_CHANGE,
  254. BTC_SET_BL_BT_TRAFFIC_BUSY,
  255. BTC_SET_BL_BT_LIMITED_DIG,
  256. BTC_SET_BL_FORCE_TO_ROAM,
  257. BTC_SET_BL_TO_REJ_AP_AGG_PKT,
  258. BTC_SET_BL_BT_CTRL_AGG_SIZE,
  259. BTC_SET_BL_INC_SCAN_DEV_NUM,
  260. BTC_SET_BL_BT_TX_RX_MASK,
  261. BTC_SET_BL_MIRACAST_PLUS_BT,
  262. /* type u1Byte */
  263. BTC_SET_U1_RSSI_ADJ_VAL_FOR_AGC_TABLE_ON,
  264. BTC_SET_U1_AGG_BUF_SIZE,
  265. /* type trigger some action */
  266. BTC_SET_ACT_GET_BT_RSSI,
  267. BTC_SET_ACT_AGGREGATE_CTRL,
  268. BTC_SET_ACT_ANTPOSREGRISTRY_CTRL,
  269. /*===== for 1Ant ======*/
  270. /* type BOOLEAN */
  271. /* type u1Byte */
  272. BTC_SET_U1_RSSI_ADJ_VAL_FOR_1ANT_COEX_TYPE,
  273. BTC_SET_U1_LPS_VAL,
  274. BTC_SET_U1_RPWM_VAL,
  275. /* type trigger some action */
  276. BTC_SET_ACT_LEAVE_LPS,
  277. BTC_SET_ACT_ENTER_LPS,
  278. BTC_SET_ACT_NORMAL_LPS,
  279. BTC_SET_ACT_DISABLE_LOW_POWER,
  280. BTC_SET_ACT_UPDATE_RAMASK,
  281. BTC_SET_ACT_SEND_MIMO_PS,
  282. /* BT Coex related */
  283. BTC_SET_ACT_CTRL_BT_INFO,
  284. BTC_SET_ACT_CTRL_BT_COEX,
  285. BTC_SET_ACT_CTRL_8723B_ANT,
  286. /*=================*/
  287. BTC_SET_MAX
  288. } BTC_SET_TYPE, *PBTC_SET_TYPE;
  289. typedef enum _BTC_DBG_DISP_TYPE {
  290. BTC_DBG_DISP_COEX_STATISTICS = 0x0,
  291. BTC_DBG_DISP_BT_LINK_INFO = 0x1,
  292. BTC_DBG_DISP_WIFI_STATUS = 0x2,
  293. BTC_DBG_DISP_MAX
  294. } BTC_DBG_DISP_TYPE, *PBTC_DBG_DISP_TYPE;
  295. typedef enum _BTC_NOTIFY_TYPE_IPS {
  296. BTC_IPS_LEAVE = 0x0,
  297. BTC_IPS_ENTER = 0x1,
  298. BTC_IPS_MAX
  299. } BTC_NOTIFY_TYPE_IPS, *PBTC_NOTIFY_TYPE_IPS;
  300. typedef enum _BTC_NOTIFY_TYPE_LPS {
  301. BTC_LPS_DISABLE = 0x0,
  302. BTC_LPS_ENABLE = 0x1,
  303. BTC_LPS_MAX
  304. } BTC_NOTIFY_TYPE_LPS, *PBTC_NOTIFY_TYPE_LPS;
  305. typedef enum _BTC_NOTIFY_TYPE_SCAN {
  306. BTC_SCAN_FINISH = 0x0,
  307. BTC_SCAN_START = 0x1,
  308. BTC_SCAN_START_2G = 0x2,
  309. BTC_SCAN_MAX
  310. } BTC_NOTIFY_TYPE_SCAN, *PBTC_NOTIFY_TYPE_SCAN;
  311. typedef enum _BTC_NOTIFY_TYPE_SWITCHBAND {
  312. BTC_NOT_SWITCH = 0x0,
  313. BTC_SWITCH_TO_24G = 0x1,
  314. BTC_SWITCH_TO_5G = 0x2,
  315. BTC_SWITCH_TO_24G_NOFORSCAN = 0x3,
  316. BTC_SWITCH_MAX
  317. } BTC_NOTIFY_TYPE_SWITCHBAND, *PBTC_NOTIFY_TYPE_SWITCHBAND;
  318. typedef enum _BTC_NOTIFY_TYPE_ASSOCIATE {
  319. BTC_ASSOCIATE_FINISH = 0x0,
  320. BTC_ASSOCIATE_START = 0x1,
  321. BTC_ASSOCIATE_5G_FINISH = 0x2,
  322. BTC_ASSOCIATE_5G_START = 0x3,
  323. BTC_ASSOCIATE_MAX
  324. } BTC_NOTIFY_TYPE_ASSOCIATE, *PBTC_NOTIFY_TYPE_ASSOCIATE;
  325. typedef enum _BTC_NOTIFY_TYPE_MEDIA_STATUS {
  326. BTC_MEDIA_DISCONNECT = 0x0,
  327. BTC_MEDIA_CONNECT = 0x1,
  328. BTC_MEDIA_MAX
  329. } BTC_NOTIFY_TYPE_MEDIA_STATUS, *PBTC_NOTIFY_TYPE_MEDIA_STATUS;
  330. typedef enum _BTC_NOTIFY_TYPE_SPECIFIC_PACKET {
  331. BTC_PACKET_UNKNOWN = 0x0,
  332. BTC_PACKET_DHCP = 0x1,
  333. BTC_PACKET_ARP = 0x2,
  334. BTC_PACKET_EAPOL = 0x3,
  335. BTC_PACKET_MAX
  336. } BTC_NOTIFY_TYPE_SPECIFIC_PACKET, *PBTC_NOTIFY_TYPE_SPECIFIC_PACKET;
  337. typedef enum _BTC_NOTIFY_TYPE_STACK_OPERATION {
  338. BTC_STACK_OP_NONE = 0x0,
  339. BTC_STACK_OP_INQ_PAGE_PAIR_START = 0x1,
  340. BTC_STACK_OP_INQ_PAGE_PAIR_FINISH = 0x2,
  341. BTC_STACK_OP_MAX
  342. } BTC_NOTIFY_TYPE_STACK_OPERATION, *PBTC_NOTIFY_TYPE_STACK_OPERATION;
  343. /* Bryant Add */
  344. typedef enum _BTC_ANTENNA_POS {
  345. BTC_ANTENNA_AT_MAIN_PORT = 0x1,
  346. BTC_ANTENNA_AT_AUX_PORT = 0x2,
  347. } BTC_ANTENNA_POS, *PBTC_ANTENNA_POS;
  348. /* Bryant Add */
  349. typedef enum _BTC_BT_OFFON {
  350. BTC_BT_OFF = 0x0,
  351. BTC_BT_ON = 0x1,
  352. } BTC_BTOFFON, *PBTC_BT_OFFON;
  353. /*==================================================
  354. For following block is for coex offload
  355. ==================================================*/
  356. typedef struct _COL_H2C {
  357. u1Byte opcode;
  358. u1Byte opcode_ver:4;
  359. u1Byte req_num:4;
  360. u1Byte buf[1];
  361. } COL_H2C, *PCOL_H2C;
  362. #define COL_C2H_ACK_HDR_LEN 3
  363. typedef struct _COL_C2H_ACK {
  364. u1Byte status;
  365. u1Byte opcode_ver:4;
  366. u1Byte req_num:4;
  367. u1Byte ret_len;
  368. u1Byte buf[1];
  369. } COL_C2H_ACK, *PCOL_C2H_ACK;
  370. #define COL_C2H_IND_HDR_LEN 3
  371. typedef struct _COL_C2H_IND {
  372. u1Byte type;
  373. u1Byte version;
  374. u1Byte length;
  375. u1Byte data[1];
  376. } COL_C2H_IND, *PCOL_C2H_IND;
  377. /*============================================
  378. NOTE: for debug message, the following define should match
  379. the strings in coexH2cResultString.
  380. ============================================*/
  381. typedef enum _COL_H2C_STATUS {
  382. /* c2h status */
  383. COL_STATUS_C2H_OK = 0x00, /* Wifi received H2C request and check content ok. */
  384. COL_STATUS_C2H_UNKNOWN = 0x01, /* Not handled routine */
  385. COL_STATUS_C2H_UNKNOWN_OPCODE = 0x02, /* Invalid OP code, It means that wifi firmware received an undefiend OP code. */
  386. COL_STATUS_C2H_OPCODE_VER_MISMATCH = 0x03, /* Wifi firmware and wifi driver mismatch, need to update wifi driver or wifi or. */
  387. COL_STATUS_C2H_PARAMETER_ERROR = 0x04, /* Error paraneter.(ex: parameters = NULL but it should have values) */
  388. 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) */
  389. /* other COL status start from here */
  390. COL_STATUS_C2H_REQ_NUM_MISMATCH , /* c2h req_num mismatch, means this c2h is not we expected. */
  391. COL_STATUS_H2C_HALMAC_FAIL , /* HALMAC return fail. */
  392. COL_STATUS_H2C_TIMTOUT , /* not received the c2h response from fw */
  393. COL_STATUS_INVALID_C2H_LEN , /* invalid coex offload c2h ack length, must >= 3 */
  394. COL_STATUS_COEX_DATA_OVERFLOW , /* coex returned length over the c2h ack length. */
  395. COL_STATUS_MAX
  396. } COL_H2C_STATUS, *PCOL_H2C_STATUS;
  397. #define COL_MAX_H2C_REQ_NUM 16
  398. #define COL_H2C_BUF_LEN 20
  399. typedef enum _COL_OPCODE {
  400. COL_OP_WIFI_STATUS_NOTIFY = 0x0,
  401. COL_OP_WIFI_PROGRESS_NOTIFY = 0x1,
  402. COL_OP_WIFI_INFO_NOTIFY = 0x2,
  403. COL_OP_WIFI_POWER_STATE_NOTIFY = 0x3,
  404. COL_OP_SET_CONTROL = 0x4,
  405. COL_OP_GET_CONTROL = 0x5,
  406. COL_OP_WIFI_OPCODE_MAX
  407. } COL_OPCODE, *PCOL_OPCODE;
  408. typedef enum _COL_IND_TYPE {
  409. COL_IND_BT_INFO = 0x0,
  410. COL_IND_PSTDMA = 0x1,
  411. COL_IND_LIMITED_TX_RX = 0x2,
  412. COL_IND_COEX_TABLE = 0x3,
  413. COL_IND_REQ = 0x4,
  414. COL_IND_MAX
  415. } COL_IND_TYPE, *PCOL_IND_TYPE;
  416. typedef struct _COL_SINGLE_H2C_RECORD {
  417. u1Byte h2c_buf[COL_H2C_BUF_LEN]; /* the latest sent h2c buffer */
  418. u4Byte h2c_len;
  419. u1Byte c2h_ack_buf[COL_H2C_BUF_LEN]; /* the latest received c2h buffer */
  420. u4Byte c2h_ack_len;
  421. u4Byte count; /* the total number of the sent h2c command */
  422. u4Byte status[COL_STATUS_MAX]; /* the c2h status for the sent h2c command */
  423. } COL_SINGLE_H2C_RECORD, *PCOL_SINGLE_H2C_RECORD;
  424. typedef struct _COL_SINGLE_C2H_IND_RECORD {
  425. u1Byte ind_buf[COL_H2C_BUF_LEN]; /* the latest received c2h indication buffer */
  426. u4Byte ind_len;
  427. u4Byte count; /* the total number of the rcvd c2h indication */
  428. u4Byte status[COL_STATUS_MAX]; /* the c2h indication verified status */
  429. } COL_SINGLE_C2H_IND_RECORD, *PCOL_SINGLE_C2H_IND_RECORD;
  430. typedef struct _BTC_OFFLOAD {
  431. /* H2C command related */
  432. u1Byte h2c_req_num;
  433. u4Byte cnt_h2c_sent;
  434. COL_SINGLE_H2C_RECORD h2c_record[COL_OP_WIFI_OPCODE_MAX];
  435. /* C2H Ack related */
  436. u4Byte cnt_c2h_ack;
  437. u4Byte status[COL_STATUS_MAX];
  438. struct completion c2h_event[COL_MAX_H2C_REQ_NUM]; /* for req_num = 1~COL_MAX_H2C_REQ_NUM */
  439. u1Byte c2h_ack_buf[COL_MAX_H2C_REQ_NUM][COL_H2C_BUF_LEN];
  440. u1Byte c2h_ack_len[COL_MAX_H2C_REQ_NUM];
  441. /* C2H Indication related */
  442. u4Byte cnt_c2h_ind;
  443. COL_SINGLE_C2H_IND_RECORD c2h_ind_record[COL_IND_MAX];
  444. u4Byte c2h_ind_status[COL_STATUS_MAX];
  445. u1Byte c2h_ind_buf[COL_H2C_BUF_LEN];
  446. u1Byte c2h_ind_len;
  447. } BTC_OFFLOAD, *PBTC_OFFLOAD;
  448. extern BTC_OFFLOAD gl_coex_offload;
  449. /*==================================================*/
  450. typedef u1Byte
  451. (*BFP_BTC_R1)(
  452. IN PVOID pBtcContext,
  453. IN u4Byte RegAddr
  454. );
  455. typedef u2Byte
  456. (*BFP_BTC_R2)(
  457. IN PVOID pBtcContext,
  458. IN u4Byte RegAddr
  459. );
  460. typedef u4Byte
  461. (*BFP_BTC_R4)(
  462. IN PVOID pBtcContext,
  463. IN u4Byte RegAddr
  464. );
  465. typedef VOID
  466. (*BFP_BTC_W1)(
  467. IN PVOID pBtcContext,
  468. IN u4Byte RegAddr,
  469. IN u1Byte Data
  470. );
  471. typedef VOID
  472. (*BFP_BTC_W1_BIT_MASK)(
  473. IN PVOID pBtcContext,
  474. IN u4Byte regAddr,
  475. IN u1Byte bitMask,
  476. IN u1Byte data1b
  477. );
  478. typedef VOID
  479. (*BFP_BTC_W2)(
  480. IN PVOID pBtcContext,
  481. IN u4Byte RegAddr,
  482. IN u2Byte Data
  483. );
  484. typedef VOID
  485. (*BFP_BTC_W4)(
  486. IN PVOID pBtcContext,
  487. IN u4Byte RegAddr,
  488. IN u4Byte Data
  489. );
  490. typedef VOID
  491. (*BFP_BTC_LOCAL_REG_W1)(
  492. IN PVOID pBtcContext,
  493. IN u4Byte RegAddr,
  494. IN u1Byte Data
  495. );
  496. typedef VOID
  497. (*BFP_BTC_SET_BB_REG)(
  498. IN PVOID pBtcContext,
  499. IN u4Byte RegAddr,
  500. IN u4Byte BitMask,
  501. IN u4Byte Data
  502. );
  503. typedef u4Byte
  504. (*BFP_BTC_GET_BB_REG)(
  505. IN PVOID pBtcContext,
  506. IN u4Byte RegAddr,
  507. IN u4Byte BitMask
  508. );
  509. typedef VOID
  510. (*BFP_BTC_SET_RF_REG)(
  511. IN PVOID pBtcContext,
  512. IN u1Byte eRFPath,
  513. IN u4Byte RegAddr,
  514. IN u4Byte BitMask,
  515. IN u4Byte Data
  516. );
  517. typedef u4Byte
  518. (*BFP_BTC_GET_RF_REG)(
  519. IN PVOID pBtcContext,
  520. IN u1Byte eRFPath,
  521. IN u4Byte RegAddr,
  522. IN u4Byte BitMask
  523. );
  524. typedef VOID
  525. (*BFP_BTC_FILL_H2C)(
  526. IN PVOID pBtcContext,
  527. IN u1Byte elementId,
  528. IN u4Byte cmdLen,
  529. IN pu1Byte pCmdBuffer
  530. );
  531. typedef BOOLEAN
  532. (*BFP_BTC_GET)(
  533. IN PVOID pBtCoexist,
  534. IN u1Byte getType,
  535. OUT PVOID pOutBuf
  536. );
  537. typedef BOOLEAN
  538. (*BFP_BTC_SET)(
  539. IN PVOID pBtCoexist,
  540. IN u1Byte setType,
  541. OUT PVOID pInBuf
  542. );
  543. typedef u2Byte
  544. (*BFP_BTC_SET_BT_REG)(
  545. IN PVOID pBtcContext,
  546. IN u1Byte regType,
  547. IN u4Byte offset,
  548. IN u4Byte value
  549. );
  550. typedef BOOLEAN
  551. (*BFP_BTC_SET_BT_ANT_DETECTION)(
  552. IN PVOID pBtcContext,
  553. IN u1Byte txTime,
  554. IN u1Byte btChnl
  555. );
  556. typedef BOOLEAN
  557. (*BFP_BTC_SET_BT_TRX_MASK)(
  558. IN PVOID pBtcContext,
  559. IN u1Byte bt_trx_mask
  560. );
  561. typedef u4Byte
  562. (*BFP_BTC_GET_BT_REG)(
  563. IN PVOID pBtcContext,
  564. IN u1Byte regType,
  565. IN u4Byte offset
  566. );
  567. typedef VOID
  568. (*BFP_BTC_DISP_DBG_MSG)(
  569. IN PVOID pBtCoexist,
  570. IN u1Byte dispType
  571. );
  572. typedef COL_H2C_STATUS
  573. (*BFP_BTC_COEX_H2C_PROCESS)(
  574. IN PVOID pBtCoexist,
  575. IN u1Byte opcode,
  576. IN u1Byte opcode_ver,
  577. IN pu1Byte ph2c_par,
  578. IN u1Byte h2c_par_len
  579. );
  580. typedef u4Byte
  581. (*BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE)(
  582. IN PVOID pBtcContext
  583. );
  584. typedef u4Byte
  585. (*BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION)(
  586. IN PVOID pBtcContext
  587. );
  588. typedef u4Byte
  589. (*BFP_BTC_GET_PHYDM_VERSION)(
  590. IN PVOID pBtcContext
  591. );
  592. typedef VOID
  593. (*BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD)(
  594. IN PVOID pDM_Odm,
  595. IN u1Byte RA_offset_direction,
  596. IN u1Byte RA_threshold_offset
  597. );
  598. typedef u4Byte
  599. (*BTC_PHYDM_CMNINFOQUERY)(
  600. IN PVOID pDM_Odm,
  601. IN u1Byte info_type
  602. );
  603. typedef u1Byte
  604. (*BFP_BTC_GET_ANT_DET_VAL_FROM_BT)(
  605. IN PVOID pBtcContext
  606. );
  607. typedef u1Byte
  608. (*BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT)(
  609. IN PVOID pBtcContext
  610. );
  611. typedef u4Byte
  612. (*BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT)(
  613. IN PVOID pBtcContext,
  614. IN u1Byte scanType
  615. );
  616. typedef BOOLEAN
  617. (*BFP_BTC_GET_BT_AFH_MAP_FROM_BT)(
  618. IN PVOID pBtcContext,
  619. IN u1Byte mapType,
  620. OUT pu1Byte afhMap
  621. );
  622. struct btc_bt_info {
  623. boolean bt_disabled;
  624. boolean bt_enable_disable_change;
  625. u8 rssi_adjust_for_agc_table_on;
  626. u8 rssi_adjust_for_1ant_coex_type;
  627. boolean pre_bt_ctrl_agg_buf_size;
  628. boolean bt_ctrl_agg_buf_size;
  629. boolean pre_reject_agg_pkt;
  630. boolean reject_agg_pkt;
  631. boolean increase_scan_dev_num;
  632. boolean bt_tx_rx_mask;
  633. u8 pre_agg_buf_size;
  634. u8 agg_buf_size;
  635. boolean bt_busy;
  636. boolean limited_dig;
  637. u16 bt_hci_ver;
  638. u16 bt_real_fw_ver;
  639. u8 bt_fw_ver;
  640. u32 get_bt_fw_ver_cnt;
  641. u32 bt_get_fw_ver;
  642. boolean miracast_plus_bt;
  643. boolean bt_disable_low_pwr;
  644. boolean bt_ctrl_lps;
  645. boolean bt_lps_on;
  646. boolean force_to_roam; /* for 1Ant solution */
  647. u8 lps_val;
  648. u8 rpwm_val;
  649. u32 ra_mask;
  650. };
  651. struct btc_stack_info {
  652. boolean profile_notified;
  653. u16 hci_version; /* stack hci version */
  654. u8 num_of_link;
  655. boolean bt_link_exist;
  656. boolean sco_exist;
  657. boolean acl_exist;
  658. boolean a2dp_exist;
  659. boolean hid_exist;
  660. u8 num_of_hid;
  661. boolean pan_exist;
  662. boolean unknown_acl_exist;
  663. s8 min_bt_rssi;
  664. };
  665. struct btc_bt_link_info {
  666. boolean bt_link_exist;
  667. boolean bt_hi_pri_link_exist;
  668. boolean sco_exist;
  669. boolean sco_only;
  670. boolean a2dp_exist;
  671. boolean a2dp_only;
  672. boolean hid_exist;
  673. boolean hid_only;
  674. boolean pan_exist;
  675. boolean pan_only;
  676. boolean slave_role;
  677. boolean acl_busy;
  678. };
  679. #ifdef CONFIG_RF4CE_COEXIST
  680. struct btc_rf4ce_info {
  681. u8 link_state;
  682. };
  683. #endif
  684. struct btc_statistics {
  685. u32 cnt_bind;
  686. u32 cnt_power_on;
  687. u32 cnt_pre_load_firmware;
  688. u32 cnt_init_hw_config;
  689. u32 cnt_init_coex_dm;
  690. u32 cnt_ips_notify;
  691. u32 cnt_lps_notify;
  692. u32 cnt_scan_notify;
  693. u32 cnt_connect_notify;
  694. u32 cnt_media_status_notify;
  695. u32 cnt_specific_packet_notify;
  696. u32 cnt_bt_info_notify;
  697. u32 cnt_rf_status_notify;
  698. u32 cnt_periodical;
  699. u32 cnt_coex_dm_switch;
  700. u32 cnt_stack_operation_notify;
  701. u32 cnt_dbg_ctrl;
  702. };
  703. struct btc_coexist {
  704. BOOLEAN bBinded; /*make sure only one adapter can bind the data context*/
  705. PVOID Adapter; /*default adapter*/
  706. struct btc_board_info board_info;
  707. struct btc_bt_info bt_info; /*some bt info referenced by non-bt module*/
  708. struct btc_stack_info stack_info;
  709. struct btc_bt_link_info bt_link_info;
  710. #ifdef CONFIG_RF4CE_COEXIST
  711. struct btc_rf4ce_info rf4ce_info;
  712. #endif
  713. BTC_CHIP_INTERFACE chip_interface;
  714. PVOID odm_priv;
  715. BOOLEAN initilized;
  716. BOOLEAN stop_coex_dm;
  717. BOOLEAN manual_control;
  718. BOOLEAN bdontenterLPS;
  719. pu1Byte cli_buf;
  720. struct btc_statistics statistics;
  721. u1Byte pwrModeVal[10];
  722. /* function pointers */
  723. /* io related */
  724. BFP_BTC_R1 btc_read_1byte;
  725. BFP_BTC_W1 btc_write_1byte;
  726. BFP_BTC_W1_BIT_MASK btc_write_1byte_bitmask;
  727. BFP_BTC_R2 btc_read_2byte;
  728. BFP_BTC_W2 btc_write_2byte;
  729. BFP_BTC_R4 btc_read_4byte;
  730. BFP_BTC_W4 btc_write_4byte;
  731. BFP_BTC_LOCAL_REG_W1 btc_write_local_reg_1byte;
  732. /* read/write bb related */
  733. BFP_BTC_SET_BB_REG btc_set_bb_reg;
  734. BFP_BTC_GET_BB_REG btc_get_bb_reg;
  735. /* read/write rf related */
  736. BFP_BTC_SET_RF_REG btc_set_rf_reg;
  737. BFP_BTC_GET_RF_REG btc_get_rf_reg;
  738. /* fill h2c related */
  739. BFP_BTC_FILL_H2C btc_fill_h2c;
  740. /* other */
  741. BFP_BTC_DISP_DBG_MSG btc_disp_dbg_msg;
  742. /* normal get/set related */
  743. BFP_BTC_GET btc_get;
  744. BFP_BTC_SET btc_set;
  745. BFP_BTC_GET_BT_REG btc_get_bt_reg;
  746. BFP_BTC_SET_BT_REG btc_set_bt_reg;
  747. BFP_BTC_SET_BT_ANT_DETECTION btc_set_bt_ant_detection;
  748. BFP_BTC_COEX_H2C_PROCESS btc_coex_h2c_process;
  749. BFP_BTC_SET_BT_TRX_MASK btc_set_bt_trx_mask;
  750. BFP_BTC_GET_BT_COEX_SUPPORTED_FEATURE btc_get_bt_coex_supported_feature;
  751. BFP_BTC_GET_BT_COEX_SUPPORTED_VERSION btc_get_bt_coex_supported_version;
  752. BFP_BTC_GET_PHYDM_VERSION btc_get_bt_phydm_version;
  753. BTC_PHYDM_MODIFY_RA_PCR_THRESHLOD btc_phydm_modify_RA_PCR_threshold;
  754. BTC_PHYDM_CMNINFOQUERY btc_phydm_query_PHY_counter;
  755. BFP_BTC_GET_ANT_DET_VAL_FROM_BT btc_get_ant_det_val_from_bt;
  756. BFP_BTC_GET_BLE_SCAN_TYPE_FROM_BT btc_get_ble_scan_type_from_bt;
  757. BFP_BTC_GET_BLE_SCAN_PARA_FROM_BT btc_get_ble_scan_para_from_bt;
  758. BFP_BTC_GET_BT_AFH_MAP_FROM_BT btc_get_bt_afh_map_from_bt;
  759. };
  760. typedef struct btc_coexist *PBTC_COEXIST;
  761. extern struct btc_coexist GLBtCoexist;
  762. BOOLEAN
  763. EXhalbtcoutsrc_InitlizeVariables(
  764. IN PVOID Adapter
  765. );
  766. VOID
  767. EXhalbtcoutsrc_PowerOnSetting(
  768. IN PBTC_COEXIST pBtCoexist
  769. );
  770. VOID
  771. EXhalbtcoutsrc_PreLoadFirmware(
  772. IN PBTC_COEXIST pBtCoexist
  773. );
  774. VOID
  775. EXhalbtcoutsrc_InitHwConfig(
  776. IN PBTC_COEXIST pBtCoexist,
  777. IN BOOLEAN bWifiOnly
  778. );
  779. VOID
  780. EXhalbtcoutsrc_InitCoexDm(
  781. IN PBTC_COEXIST pBtCoexist
  782. );
  783. VOID
  784. EXhalbtcoutsrc_IpsNotify(
  785. IN PBTC_COEXIST pBtCoexist,
  786. IN u1Byte type
  787. );
  788. VOID
  789. EXhalbtcoutsrc_LpsNotify(
  790. IN PBTC_COEXIST pBtCoexist,
  791. IN u1Byte type
  792. );
  793. VOID
  794. EXhalbtcoutsrc_ScanNotify(
  795. IN PBTC_COEXIST pBtCoexist,
  796. IN u1Byte type
  797. );
  798. VOID
  799. EXhalbtcoutsrc_SetAntennaPathNotify(
  800. IN PBTC_COEXIST pBtCoexist,
  801. IN u1Byte type
  802. );
  803. VOID
  804. EXhalbtcoutsrc_ConnectNotify(
  805. IN PBTC_COEXIST pBtCoexist,
  806. IN u1Byte action
  807. );
  808. VOID
  809. EXhalbtcoutsrc_MediaStatusNotify(
  810. IN PBTC_COEXIST pBtCoexist,
  811. IN RT_MEDIA_STATUS mediaStatus
  812. );
  813. VOID
  814. EXhalbtcoutsrc_SpecificPacketNotify(
  815. IN PBTC_COEXIST pBtCoexist,
  816. IN u1Byte pktType
  817. );
  818. VOID
  819. EXhalbtcoutsrc_BtInfoNotify(
  820. IN PBTC_COEXIST pBtCoexist,
  821. IN pu1Byte tmpBuf,
  822. IN u1Byte length
  823. );
  824. VOID
  825. EXhalbtcoutsrc_RfStatusNotify(
  826. IN PBTC_COEXIST pBtCoexist,
  827. IN u1Byte type
  828. );
  829. VOID
  830. EXhalbtcoutsrc_StackOperationNotify(
  831. IN PBTC_COEXIST pBtCoexist,
  832. IN u1Byte type
  833. );
  834. VOID
  835. EXhalbtcoutsrc_HaltNotify(
  836. IN PBTC_COEXIST pBtCoexist
  837. );
  838. VOID
  839. EXhalbtcoutsrc_PnpNotify(
  840. IN PBTC_COEXIST pBtCoexist,
  841. IN u1Byte pnpState
  842. );
  843. VOID
  844. EXhalbtcoutsrc_CoexDmSwitch(
  845. IN PBTC_COEXIST pBtCoexist
  846. );
  847. VOID
  848. EXhalbtcoutsrc_Periodical(
  849. IN PBTC_COEXIST pBtCoexist
  850. );
  851. VOID
  852. EXhalbtcoutsrc_DbgControl(
  853. IN PBTC_COEXIST pBtCoexist,
  854. IN u1Byte opCode,
  855. IN u1Byte opLen,
  856. IN pu1Byte pData
  857. );
  858. VOID
  859. EXhalbtcoutsrc_AntennaDetection(
  860. IN PBTC_COEXIST pBtCoexist,
  861. IN u4Byte centFreq,
  862. IN u4Byte offset,
  863. IN u4Byte span,
  864. IN u4Byte seconds
  865. );
  866. VOID
  867. EXhalbtcoutsrc_StackUpdateProfileInfo(
  868. VOID
  869. );
  870. VOID
  871. EXhalbtcoutsrc_SetHciVersion(
  872. IN u2Byte hciVersion
  873. );
  874. VOID
  875. EXhalbtcoutsrc_SetBtPatchVersion(
  876. IN u2Byte btHciVersion,
  877. IN u2Byte btPatchVersion
  878. );
  879. VOID
  880. EXhalbtcoutsrc_UpdateMinBtRssi(
  881. IN s1Byte btRssi
  882. );
  883. #if 0
  884. VOID
  885. EXhalbtcoutsrc_SetBtExist(
  886. IN BOOLEAN bBtExist
  887. );
  888. #endif
  889. VOID
  890. EXhalbtcoutsrc_SetChipType(
  891. IN u1Byte chipType
  892. );
  893. VOID
  894. EXhalbtcoutsrc_SetAntNum(
  895. IN u1Byte type,
  896. IN u1Byte antNum
  897. );
  898. VOID
  899. EXhalbtcoutsrc_SetSingleAntPath(
  900. IN u1Byte singleAntPath
  901. );
  902. VOID
  903. EXhalbtcoutsrc_DisplayBtCoexInfo(
  904. IN PBTC_COEXIST pBtCoexist
  905. );
  906. VOID
  907. EXhalbtcoutsrc_DisplayAntDetection(
  908. IN PBTC_COEXIST pBtCoexist
  909. );
  910. #define MASKBYTE0 0xff
  911. #define MASKBYTE1 0xff00
  912. #define MASKBYTE2 0xff0000
  913. #define MASKBYTE3 0xff000000
  914. #define MASKHWORD 0xffff0000
  915. #define MASKLWORD 0x0000ffff
  916. #define MASKDWORD 0xffffffff
  917. #define MASK12BITS 0xfff
  918. #define MASKH4BITS 0xf0000000
  919. #define MASKOFDM_D 0xffc00000
  920. #define MASKCCK 0x3f3f3f3f
  921. #endif