phydm_antdiv.h 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710
  1. /******************************************************************************
  2. *
  3. * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
  4. *
  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.
  8. *
  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
  12. * more details.
  13. *
  14. * You should have received a copy of the GNU General Public License along with
  15. * this program; if not, write to the Free Software Foundation, Inc.,
  16. * 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
  17. *
  18. *
  19. ******************************************************************************/
  20. #ifndef __PHYDMANTDIV_H__
  21. #define __PHYDMANTDIV_H__
  22. /*#define ANTDIV_VERSION "2.0" //2014.11.04*/
  23. /*#define ANTDIV_VERSION "2.1" //2015.01.13 Dino*/
  24. /*#define ANTDIV_VERSION "2.2" 2015.01.16 Dino*/
  25. /*#define ANTDIV_VERSION "3.1" 2015.07.29 YuChen, remove 92c 92d 8723a*/
  26. /*#define ANTDIV_VERSION "3.2" 2015.08.11 Stanley, disable antenna diversity when BT is enable for 8723B*/
  27. /*#define ANTDIV_VERSION "3.3" 2015.08.12 Stanley. 8723B does not need to check the antenna is control by BT,
  28. because antenna diversity only works when BT is disable or radio off*/
  29. /*#define ANTDIV_VERSION "3.4" 2015.08.28 Dino 1.Add 8821A Smart Antenna 2. Add 8188F SW S0S1 Antenna Diversity*/
  30. /*#define ANTDIV_VERSION "3.5" 2015.10.07 Stanley Always check antenna detection result from BT-coex. for 8723B, not from PHYDM*/
  31. /*#define ANTDIV_VERSION "3.6"*/ /*2015.11.16 Stanley */
  32. /*#define ANTDIV_VERSION "3.7"*/ /*2015.11.20 Dino Add SmartAnt FAT Patch */
  33. /*#define ANTDIV_VERSION "3.8" 2015.12.21 Dino, Add SmartAnt dynamic training packet num */
  34. #define ANTDIV_VERSION "3.9" /*2016.01.05 Dino, Add SmartAnt cmd for converting single & two smtant, and add cmd for adjust truth table */
  35. /* 1 ============================================================
  36. * 1 Definition
  37. * 1 ============================================================ */
  38. #define ANTDIV_INIT 0xff
  39. #define MAIN_ANT 1 /*ant A or ant Main or S1*/
  40. #define AUX_ANT 2 /*AntB or ant Aux or S0*/
  41. #define MAX_ANT 3 /* 3 for AP using*/
  42. #define ANT1_2G 0 /* = ANT2_5G for 8723D BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
  43. #define ANT2_2G 1 /* = ANT1_5G for 8723D BTG S0 RX S0S1 diversity for 8723D, TX fixed at S1 */
  44. /*smart antenna*/
  45. #define SUPPORT_RF_PATH_NUM 4
  46. #define SUPPORT_BEAM_PATTERN_NUM 4
  47. #define NUM_ANTENNA_8821A 2
  48. #define SUPPORT_BEAM_SET_PATTERN_NUM 16
  49. #define NO_FIX_TX_ANT 0
  50. #define FIX_TX_AT_MAIN 1
  51. #define FIX_AUX_AT_MAIN 2
  52. /* Antenna Diversty Control type */
  53. #define ODM_AUTO_ANT 0
  54. #define ODM_FIX_MAIN_ANT 1
  55. #define ODM_FIX_AUX_ANT 2
  56. #define ODM_N_ANTDIV_SUPPORT (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A)
  57. #define ODM_AC_ANTDIV_SUPPORT (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
  58. #define ODM_ANTDIV_SUPPORT (ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
  59. #define ODM_SMART_ANT_SUPPORT (ODM_RTL8188E | ODM_RTL8192E)
  60. #define ODM_HL_SMART_ANT_TYPE1_SUPPORT (ODM_RTL8821 | ODM_RTL8822B)
  61. #define ODM_ANTDIV_2G_SUPPORT_IC (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D)
  62. #define ODM_ANTDIV_5G_SUPPORT_IC (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C)
  63. #define ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC (ODM_RTL8192E)
  64. #define ODM_ANTDIV_2G BIT(0)
  65. #define ODM_ANTDIV_5G BIT(1)
  66. #define ANTDIV_ON 1
  67. #define ANTDIV_OFF 0
  68. #define FAT_ON 1
  69. #define FAT_OFF 0
  70. #define TX_BY_DESC 1
  71. #define TX_BY_REG 0
  72. #define RSSI_METHOD 0
  73. #define EVM_METHOD 1
  74. #define CRC32_METHOD 2
  75. #define INIT_ANTDIV_TIMMER 0
  76. #define CANCEL_ANTDIV_TIMMER 1
  77. #define RELEASE_ANTDIV_TIMMER 2
  78. #define CRC32_FAIL 1
  79. #define CRC32_OK 0
  80. #define evm_rssi_th_high 25
  81. #define evm_rssi_th_low 20
  82. #define NORMAL_STATE_MIAN 1
  83. #define NORMAL_STATE_AUX 2
  84. #define TRAINING_STATE 3
  85. #define FORCE_RSSI_DIFF 10
  86. #define CSI_ON 1
  87. #define CSI_OFF 0
  88. #define DIVON_CSIOFF 1
  89. #define DIVOFF_CSION 2
  90. #define BDC_DIV_TRAIN_STATE 0
  91. #define bdc_bfer_train_state 1
  92. #define BDC_DECISION_STATE 2
  93. #define BDC_BF_HOLD_STATE 3
  94. #define BDC_DIV_HOLD_STATE 4
  95. #define BDC_MODE_1 1
  96. #define BDC_MODE_2 2
  97. #define BDC_MODE_3 3
  98. #define BDC_MODE_4 4
  99. #define BDC_MODE_NULL 0xff
  100. /*SW S0S1 antenna diversity*/
  101. #define SWAW_STEP_INIT 0xff
  102. #define SWAW_STEP_PEEK 0
  103. #define SWAW_STEP_DETERMINE 1
  104. #define RSSI_CHECK_RESET_PERIOD 10
  105. #define RSSI_CHECK_THRESHOLD 50
  106. /*Hong Lin Smart antenna*/
  107. #define HL_SMTANT_2WIRE_DATA_LEN 24
  108. /* 1 ============================================================
  109. * 1 structure
  110. * 1 ============================================================ */
  111. struct _sw_antenna_switch_ {
  112. u8 double_chk_flag; /*If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*/
  113. u8 try_flag;
  114. s32 pre_rssi;
  115. u8 cur_antenna;
  116. u8 pre_antenna;
  117. u8 rssi_trying;
  118. u8 reset_idx;
  119. u8 train_time;
  120. u8 train_time_flag; /*base on RSSI difference between two antennas*/
  121. struct timer_list phydm_sw_antenna_switch_timer;
  122. u32 pkt_cnt_sw_ant_div_by_ctrl_frame;
  123. boolean is_sw_ant_div_by_ctrl_frame;
  124. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  125. #if USE_WORKITEM
  126. RT_WORK_ITEM phydm_sw_antenna_switch_workitem;
  127. #endif
  128. #endif
  129. /* AntDect (Before link Antenna Switch check) need to be moved*/
  130. u16 single_ant_counter;
  131. u16 dual_ant_counter;
  132. u16 aux_fail_detec_counter;
  133. u16 retry_counter;
  134. u8 swas_no_link_state;
  135. u32 swas_no_link_bk_reg948;
  136. boolean ANTA_ON; /*To indicate ant A is or not*/
  137. boolean ANTB_ON; /*To indicate ant B is on or not*/
  138. boolean pre_aux_fail_detec;
  139. boolean rssi_ant_dect_result;
  140. u8 ant_5g;
  141. u8 ant_2g;
  142. };
  143. #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
  144. #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
  145. struct _BF_DIV_COEX_ {
  146. boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];
  147. boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];
  148. u32 MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
  149. u32 MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
  150. u8 bd_ccoex_type_wbfer;
  151. u8 num_txbfee_client;
  152. u8 num_txbfer_client;
  153. u8 bdc_try_counter;
  154. u8 bdc_hold_counter;
  155. u8 bdc_mode;
  156. u8 bdc_active_mode;
  157. u8 BDC_state;
  158. u8 bdc_rx_idle_update_counter;
  159. u8 num_client;
  160. u8 pre_num_client;
  161. u8 num_bf_tar;
  162. u8 num_div_tar;
  163. boolean is_all_div_sta_idle;
  164. boolean is_all_bf_sta_idle;
  165. boolean bdc_try_flag;
  166. boolean BF_pass;
  167. boolean DIV_pass;
  168. };
  169. #endif
  170. #endif
  171. #if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1)) || (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))
  172. struct _SMART_ANTENNA_TRAINNING_ {
  173. u32 latch_time;
  174. boolean pkt_skip_statistic_en;
  175. u32 fix_beam_pattern_en;
  176. u32 fix_training_num_en;
  177. u32 fix_beam_pattern_codeword;
  178. u32 update_beam_codeword;
  179. u32 ant_num; /*number of "used" smart beam antenna*/
  180. u32 ant_num_total;/*number of "total" smart beam antenna*/
  181. u32 first_train_ant; /*decide witch antenna to train first*/
  182. #ifdef CONFIG_HL_SMART_ANTENNA_TYPE1
  183. u32 pkt_rssi_pre[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];/*rssi of each path with a certain beam pattern*/
  184. u8 beam_train_rssi_diff[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
  185. u8 beam_train_cnt[SUPPORT_RF_PATH_NUM][SUPPORT_BEAM_PATTERN_NUM];
  186. u32 rfu_codeword_table[4]; /*2G beam truth table*/
  187. u32 rfu_codeword_table_5g[4]; /*5G beam truth table*/
  188. u32 beam_patten_num_each_ant;/*number of beam can be switched in each antenna*/
  189. u32 rx_idle_beam[SUPPORT_RF_PATH_NUM];
  190. u32 pkt_rssi_sum[8][SUPPORT_BEAM_PATTERN_NUM];
  191. u32 pkt_rssi_cnt[8][SUPPORT_BEAM_PATTERN_NUM];
  192. #endif
  193. u32 fast_training_beam_num;/*current training beam_set index*/
  194. u32 pre_fast_training_beam_num;/*pre training beam_set index*/
  195. u32 rfu_codeword_total_bit_num; /* total bit number of RFU protocol*/
  196. u32 rfu_each_ant_bit_num; /* bit number of RFU protocol for each ant*/
  197. u8 per_beam_training_pkt_num;
  198. u8 decision_holding_period;
  199. u32 pre_codeword;
  200. boolean force_update_beam_en;
  201. u32 beacon_counter;
  202. u32 pre_beacon_counter;
  203. u8 pkt_counter; /*packet number that each beam-set should be colected in training state*/
  204. u8 update_beam_idx; /*the index announce that the beam can be updated*/
  205. u8 rfu_protocol_type;
  206. u16 rfu_protocol_delay_time;
  207. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  208. RT_WORK_ITEM hl_smart_antenna_workitem;
  209. RT_WORK_ITEM hl_smart_antenna_decision_workitem;
  210. #endif
  211. #ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
  212. u8 beam_set_avg_rssi_pre[SUPPORT_BEAM_SET_PATTERN_NUM]; /*avg pre_rssi of each beam set*/
  213. u8 beam_set_train_rssi_diff[SUPPORT_BEAM_SET_PATTERN_NUM]; /*rssi of a beam pattern set, ex: a set = {ant1_beam=1, ant2_beam=3}*/
  214. u8 beam_set_train_cnt[SUPPORT_BEAM_SET_PATTERN_NUM]; /*training pkt num of each beam set*/
  215. u32 beam_set_rssi_avg_sum[SUPPORT_BEAM_SET_PATTERN_NUM]; /*RSSI_sum of avg(pathA,pathB) for each beam-set)*/
  216. u32 beam_path_rssi_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*RSSI_sum of each path for each beam-set)*/
  217. u32 beam_path_evm_2ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B];/*2SS evm_sum of each path for each beam-set)*/
  218. u32 beam_path_evm_2ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
  219. u32 beam_path_evm_1ss_sum[SUPPORT_BEAM_SET_PATTERN_NUM];/*1SS evm_sum of each path for each beam-set)*/
  220. u32 beam_path_evm_1ss_cnt[SUPPORT_BEAM_SET_PATTERN_NUM];
  221. u32 statistic_pkt_cnt[SUPPORT_BEAM_SET_PATTERN_NUM]; /*statistic_pkt_cnt for SmtAnt make decision*/
  222. u8 total_beam_set_num; /*number of beam set can be switched*/
  223. u8 total_beam_set_num_2g;/*number of beam set can be switched in 2G*/
  224. u8 total_beam_set_num_5g;/*number of beam set can be switched in 5G*/
  225. u8 rfu_codeword_table_2g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*2G beam truth table*/
  226. u8 rfu_codeword_table_5g[SUPPORT_BEAM_SET_PATTERN_NUM][MAX_PATH_NUM_8822B]; /*5G beam truth table*/
  227. u8 rx_idle_beam_set_idx; /*the filanl decsion result*/
  228. #endif
  229. };
  230. #endif
  231. struct _FAST_ANTENNA_TRAINNING_ {
  232. u8 bssid[6];
  233. u8 antsel_rx_keep_0;
  234. u8 antsel_rx_keep_1;
  235. u8 antsel_rx_keep_2;
  236. u8 antsel_rx_keep_3;
  237. u32 ant_sum_rssi[7];
  238. u32 ant_rssi_cnt[7];
  239. u32 ant_ave_rssi[7];
  240. u8 fat_state;
  241. u32 train_idx;
  242. u8 antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
  243. u8 antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
  244. u8 antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
  245. u16 main_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
  246. u16 aux_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
  247. u16 main_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
  248. u16 aux_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
  249. u16 main_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
  250. u16 aux_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
  251. u16 main_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
  252. u16 aux_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
  253. u8 rx_idle_ant;
  254. u8 ant_div_on_off;
  255. boolean is_become_linked;
  256. u32 min_max_rssi;
  257. u8 idx_ant_div_counter_2g;
  258. u8 idx_ant_div_counter_5g;
  259. u8 ant_div_2g_5g;
  260. #ifdef ODM_EVM_ENHANCE_ANTDIV
  261. u32 main_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
  262. u32 aux_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
  263. u32 main_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
  264. u32 aux_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
  265. boolean EVM_method_enable;
  266. u8 target_ant_evm;
  267. u8 target_ant_crc32;
  268. u8 target_ant_enhance;
  269. u8 pre_target_ant_enhance;
  270. u16 main_mpdu_ok_cnt;
  271. u16 aux_mpdu_ok_cnt;
  272. u32 crc32_ok_cnt;
  273. u32 crc32_fail_cnt;
  274. u32 main_crc32_ok_cnt;
  275. u32 aux_crc32_ok_cnt;
  276. u32 main_crc32_fail_cnt;
  277. u32 aux_crc32_fail_cnt;
  278. #endif
  279. #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
  280. u32 cck_ctrl_frame_cnt_main;
  281. u32 cck_ctrl_frame_cnt_aux;
  282. u32 ofdm_ctrl_frame_cnt_main;
  283. u32 ofdm_ctrl_frame_cnt_aux;
  284. u32 main_ant_ctrl_frame_sum;
  285. u32 aux_ant_ctrl_frame_sum;
  286. u32 main_ant_ctrl_frame_cnt;
  287. u32 aux_ant_ctrl_frame_cnt;
  288. #endif
  289. u8 b_fix_tx_ant;
  290. boolean fix_ant_bfee;
  291. boolean enable_ctrl_frame_antdiv;
  292. boolean use_ctrl_frame_antdiv;
  293. u8 hw_antsw_occur;
  294. u8 *p_force_tx_ant_by_desc;
  295. u8 force_tx_ant_by_desc; /*A temp value, will hook to driver team's outer parameter later*/
  296. u8 *p_default_s0_s1;
  297. u8 default_s0_s1;
  298. };
  299. /* 1 ============================================================
  300. * 1 enumeration
  301. * 1 ============================================================ */
  302. enum fat_state_e /*Fast antenna training*/
  303. {
  304. FAT_BEFORE_LINK_STATE = 0,
  305. FAT_PREPARE_STATE = 1,
  306. FAT_TRAINING_STATE = 2,
  307. FAT_DECISION_STATE = 3
  308. };
  309. enum ant_div_type_e {
  310. NO_ANTDIV = 0xFF,
  311. CG_TRX_HW_ANTDIV = 0x01,
  312. CGCS_RX_HW_ANTDIV = 0x02,
  313. FIXED_HW_ANTDIV = 0x03,
  314. CG_TRX_SMART_ANTDIV = 0x04,
  315. CGCS_RX_SW_ANTDIV = 0x05,
  316. S0S1_SW_ANTDIV = 0x06, /*8723B intrnal switch S0 S1*/
  317. S0S1_TRX_HW_ANTDIV = 0x07, /*TRX S0S1 diversity for 8723D*/
  318. HL_SW_SMART_ANT_TYPE1 = 0x10, /*Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys, and each ant. is equipped with 4 antenna patterns*/
  319. HL_SW_SMART_ANT_TYPE2 = 0x11 /*Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
  320. };
  321. /* 1 ============================================================
  322. * 1 function prototype
  323. * 1 ============================================================ */
  324. void
  325. odm_stop_antenna_switch_dm(
  326. void *p_dm_void
  327. );
  328. void
  329. phydm_enable_antenna_diversity(
  330. void *p_dm_void
  331. );
  332. void
  333. odm_set_ant_config(
  334. void *p_dm_void,
  335. u8 ant_setting /* 0=A, 1=B, 2=C, .... */
  336. );
  337. #define sw_ant_div_rest_after_link odm_sw_ant_div_rest_after_link
  338. void odm_sw_ant_div_rest_after_link(
  339. void *p_dm_void
  340. );
  341. #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
  342. void
  343. phydm_antdiv_reset_statistic(
  344. void *p_dm_void,
  345. u32 macid
  346. );
  347. void
  348. odm_update_rx_idle_ant(
  349. void *p_dm_void,
  350. u8 ant
  351. );
  352. #if (RTL8723B_SUPPORT == 1)
  353. void
  354. odm_update_rx_idle_ant_8723b(
  355. void *p_dm_void,
  356. u8 ant,
  357. u32 default_ant,
  358. u32 optional_ant
  359. );
  360. #endif
  361. #if (RTL8188F_SUPPORT == 1)
  362. void
  363. phydm_update_rx_idle_antenna_8188F(
  364. void *p_dm_void,
  365. u32 default_ant
  366. );
  367. #endif
  368. #if (RTL8723D_SUPPORT == 1)
  369. void
  370. phydm_set_tx_ant_pwr_8723d(
  371. void *p_dm_void,
  372. u8 ant
  373. );
  374. void
  375. odm_update_rx_idle_ant_8723d(
  376. void *p_dm_void,
  377. u8 ant,
  378. u32 default_ant,
  379. u32 optional_ant
  380. );
  381. #endif
  382. #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
  383. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  384. void
  385. odm_sw_antdiv_callback(
  386. struct timer_list *p_timer
  387. );
  388. void
  389. odm_sw_antdiv_workitem_callback(
  390. void *p_context
  391. );
  392. #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
  393. void
  394. odm_sw_antdiv_workitem_callback(
  395. void *p_context
  396. );
  397. void
  398. odm_sw_antdiv_callback(
  399. void *function_context
  400. );
  401. #endif
  402. void
  403. odm_s0s1_sw_ant_div_by_ctrl_frame(
  404. void *p_dm_void,
  405. u8 step
  406. );
  407. void
  408. odm_antsel_statistics_of_ctrl_frame(
  409. void *p_dm_void,
  410. u8 antsel_tr_mux,
  411. u32 rx_pwdb_all
  412. );
  413. void
  414. odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
  415. void *p_dm_void,
  416. void *p_phy_info_void,
  417. void *p_pkt_info_void
  418. );
  419. #endif
  420. #ifdef ODM_EVM_ENHANCE_ANTDIV
  421. void
  422. odm_evm_fast_ant_training_callback(
  423. void *p_dm_void
  424. );
  425. #endif
  426. void
  427. odm_hw_ant_div(
  428. void *p_dm_void
  429. );
  430. #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
  431. void
  432. odm_fast_ant_training(
  433. void *p_dm_void
  434. );
  435. void
  436. odm_fast_ant_training_callback(
  437. void *p_dm_void
  438. );
  439. void
  440. odm_fast_ant_training_work_item_callback(
  441. void *p_dm_void
  442. );
  443. #endif
  444. #if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1)) || (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))
  445. #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
  446. void
  447. phydm_beam_switch_workitem_callback(
  448. void *p_context
  449. );
  450. void
  451. phydm_beam_decision_workitem_callback(
  452. void *p_context
  453. );
  454. #endif
  455. #ifdef CONFIG_HL_SMART_ANTENNA_TYPE2
  456. void
  457. phydm_update_beam_pattern_type2(
  458. void *p_dm_void,
  459. u32 codeword,
  460. u32 codeword_length
  461. );
  462. void
  463. phydm_set_rfu_beam_pattern_type2(
  464. void *p_dm_void
  465. );
  466. void
  467. phydm_hl_smart_ant_debug_type2(
  468. void *p_dm_void,
  469. char input[][16],
  470. u32 *_used,
  471. char *output,
  472. u32 *_out_len,
  473. u32 input_num
  474. );
  475. #elif (defined(CONFIG_HL_SMART_ANTENNA_TYPE1))
  476. void
  477. phydm_update_beam_pattern(
  478. void *p_dm_void,
  479. u32 codeword,
  480. u32 codeword_length
  481. );
  482. void
  483. phydm_set_all_ant_same_beam_num(
  484. void *p_dm_void
  485. );
  486. void
  487. phydm_hl_smart_ant_debug(
  488. void *p_dm_void,
  489. char input[][16],
  490. u32 *_used,
  491. char *output,
  492. u32 *_out_len,
  493. u32 input_num
  494. );
  495. #endif
  496. #endif/*#if (defined(CONFIG_HL_SMART_ANTENNA_TYPE1)) || (defined(CONFIG_HL_SMART_ANTENNA_TYPE2))*/
  497. void
  498. odm_ant_div_init(
  499. void *p_dm_void
  500. );
  501. void
  502. odm_ant_div(
  503. void *p_dm_void
  504. );
  505. void
  506. odm_antsel_statistics(
  507. void *p_dm_void,
  508. u8 antsel_tr_mux,
  509. u32 mac_id,
  510. u32 utility,
  511. u8 method,
  512. u8 is_cck_rate
  513. );
  514. void
  515. odm_process_rssi_for_ant_div(
  516. void *p_dm_void,
  517. void *p_phy_info_void,
  518. void *p_pkt_info_void
  519. );
  520. #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
  521. void
  522. odm_set_tx_ant_by_tx_info(
  523. void *p_dm_void,
  524. u8 *p_desc,
  525. u8 mac_id
  526. );
  527. #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
  528. struct tx_desc; /*declared tx_desc here or compile error happened when enabled 8822B*/
  529. void
  530. odm_set_tx_ant_by_tx_info(
  531. struct rtl8192cd_priv *priv,
  532. struct tx_desc *pdesc,
  533. unsigned short aid
  534. );
  535. #if 1/*def def CONFIG_WLAN_HAL*/
  536. void
  537. odm_set_tx_ant_by_tx_info_hal(
  538. struct rtl8192cd_priv *priv,
  539. void *pdesc_data,
  540. u16 aid
  541. );
  542. #endif /*#ifdef CONFIG_WLAN_HAL*/
  543. #endif
  544. void
  545. odm_ant_div_config(
  546. void *p_dm_void
  547. );
  548. void
  549. odm_ant_div_timers(
  550. void *p_dm_void,
  551. u8 state
  552. );
  553. void
  554. phydm_antdiv_debug(
  555. void *p_dm_void,
  556. u32 *const dm_value,
  557. u32 *_used,
  558. char *output,
  559. u32 *_out_len
  560. );
  561. #endif /*#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))*/
  562. void
  563. odm_ant_div_reset(
  564. void *p_dm_void
  565. );
  566. void
  567. odm_antenna_diversity_init(
  568. void *p_dm_void
  569. );
  570. void
  571. odm_antenna_diversity(
  572. void *p_dm_void
  573. );
  574. #endif /*#ifndef __ODMANTDIV_H__*/