| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544 |
- /******************************************************************************
- *
- * Copyright(c) 2007 - 2017 Realtek Corporation.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of version 2 of the GNU General Public License as
- * published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful, but WITHOUT
- * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
- * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
- * more details.
- *
- * The full GNU General Public License is included in this distribution in the
- * file called LICENSE.
- *
- * Contact Information:
- * wlanfae <wlanfae@realtek.com>
- * Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,
- * Hsinchu 300, Taiwan.
- *
- * Larry Finger <Larry.Finger@lwfinger.net>
- *
- *****************************************************************************/
- #ifndef __PHYDMANTDIV_H__
- #define __PHYDMANTDIV_H__
- /*@#define ANTDIV_VERSION "2.0" //2014.11.04*/
- /*@#define ANTDIV_VERSION "2.1" //2015.01.13 Dino*/
- /*@#define ANTDIV_VERSION "2.2" 2015.01.16 Dino*/
- /*@#define ANTDIV_VERSION "3.1" 2015.07.29 YuChen, remove 92c 92d 8723a*/
- /*@#define ANTDIV_VERSION "3.2" 2015.08.11 Stanley, disable antenna diversity when BT is enable for 8723B*/
- /*@#define ANTDIV_VERSION "3.3" 2015.08.12 Stanley. 8723B does not need to check the antenna is control by BT, because antenna diversity only works when BT is disable or radio off*/
- /*@#define ANTDIV_VERSION "3.4" 2015.08.28 Dino 1.Add 8821A Smart Antenna 2. Add 8188F SW S0S1 Antenna Diversity*/
- /*@#define ANTDIV_VERSION "3.5" 2015.10.07 Stanley Always check antenna detection result from BT-coex. for 8723B, not from PHYDM*/
- /*@#define ANTDIV_VERSION "3.6"*/ /*@2015.11.16 Stanley */
- /*@#define ANTDIV_VERSION "3.7"*/ /*@2015.11.20 Dino Add SmartAnt FAT Patch */
- /*@#define ANTDIV_VERSION "3.8" 2015.12.21 Dino, Add SmartAnt dynamic training packet num */
- /*@#define ANTDIV_VERSION "3.9" 2016.01.05 Dino, Add SmartAnt cmd for converting single & two smtant, and add cmd for adjust truth table */
- #define ANTDIV_VERSION "4.0" /*@2017.05.25 Mark, Add SW antenna diversity for 8821c because HW transient issue */
- /* @1 ============================================================
- * 1 Definition
- * 1 ============================================================
- */
- #define ANTDIV_INIT 0xff
- #define MAIN_ANT 1 /*@ant A or ant Main or S1*/
- #define AUX_ANT 2 /*@AntB or ant Aux or S0*/
- #define MAX_ANT 3 /* @3 for AP using*/
- #define ANT1_2G 0 /* @= ANT2_5G for 8723D BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */
- #define ANT2_2G 1 /* @= ANT1_5G for 8723D BTG S0 RX S0S1 diversity for 8723D, TX fixed at S1 */
- /*smart antenna*/
- #define SUPPORT_RF_PATH_NUM 4
- #define SUPPORT_BEAM_PATTERN_NUM 4
- #define NUM_ANTENNA_8821A 2
- #define SUPPORT_BEAM_SET_PATTERN_NUM 16
- #define NO_FIX_TX_ANT 0
- #define FIX_TX_AT_MAIN 1
- #define FIX_AUX_AT_MAIN 2
- /* @Antenna Diversty Control type */
- #define ODM_AUTO_ANT 0
- #define ODM_FIX_MAIN_ANT 1
- #define ODM_FIX_AUX_ANT 2
- #define ODM_N_ANTDIV_SUPPORT (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A | ODM_RTL8197F)
- #define ODM_AC_ANTDIV_SUPPORT (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)
- #define ODM_ANTDIV_SUPPORT (ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)
- #define ODM_SMART_ANT_SUPPORT (ODM_RTL8188E | ODM_RTL8192E)
- #define ODM_HL_SMART_ANT_TYPE1_SUPPORT (ODM_RTL8821 | ODM_RTL8822B)
- #define ODM_ANTDIV_2G_SUPPORT_IC (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B | ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8197F)
- #define ODM_ANTDIV_5G_SUPPORT_IC (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 | ODM_RTL8821C | ODM_RTL8822B)
- #define ODM_EVM_ENHANCE_ANTDIV_SUPPORT_IC (ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8822B)
- #define ODM_ANTDIV_2G BIT(0)
- #define ODM_ANTDIV_5G BIT(1)
- #define ANTDIV_ON 1
- #define ANTDIV_OFF 0
- #define ANT_PATH_A 0
- #define ANT_PATH_B 1
- #define ANT_PATH_AB 2
- #define FAT_ON 1
- #define FAT_OFF 0
- #define TX_BY_DESC 1
- #define TX_BY_REG 0
- #define RSSI_METHOD 0
- #define EVM_METHOD 1
- #define CRC32_METHOD 2
- #define TP_METHOD 3
- #define INIT_ANTDIV_TIMMER 0
- #define CANCEL_ANTDIV_TIMMER 1
- #define RELEASE_ANTDIV_TIMMER 2
- #define CRC32_FAIL 1
- #define CRC32_OK 0
- #define evm_rssi_th_high 25
- #define evm_rssi_th_low 20
- #define NORMAL_STATE_MIAN 1
- #define NORMAL_STATE_AUX 2
- #define TRAINING_STATE 3
- #define FORCE_RSSI_DIFF 10
- #define CSI_ON 1
- #define CSI_OFF 0
- #define DIVON_CSIOFF 1
- #define DIVOFF_CSION 2
- #define BDC_DIV_TRAIN_STATE 0
- #define bdc_bfer_train_state 1
- #define BDC_DECISION_STATE 2
- #define BDC_BF_HOLD_STATE 3
- #define BDC_DIV_HOLD_STATE 4
- #define BDC_MODE_1 1
- #define BDC_MODE_2 2
- #define BDC_MODE_3 3
- #define BDC_MODE_4 4
- #define BDC_MODE_NULL 0xff
- /*SW S0S1 antenna diversity*/
- #define SWAW_STEP_INIT 0xff
- #define SWAW_STEP_PEEK 0
- #define SWAW_STEP_DETERMINE 1
- #define RSSI_CHECK_RESET_PERIOD 10
- #define RSSI_CHECK_THRESHOLD 50
- /*@Hong Lin Smart antenna*/
- #define HL_SMTANT_2WIRE_DATA_LEN 24
- #if (RTL8723D_SUPPORT == 1)
- #ifndef CONFIG_ANTENNA_DIVERSITY_PERIOD
- #define CONFIG_ANTENNA_DIVERSITY_PERIOD 1
- #endif
- #endif
- /* @1 ============================================================
- * 1 structure
- * 1 ============================================================
- */
- struct sw_antenna_switch {
- u8 double_chk_flag; /*@If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than check this antenna again*/
- u8 try_flag;
- s32 pre_rssi;
- u8 cur_antenna;
- u8 pre_antenna;
- u8 rssi_trying;
- u8 reset_idx;
- u8 train_time;
- u8 train_time_flag; /*@base on RSSI difference between two antennas*/
- struct phydm_timer_list phydm_sw_antenna_switch_timer;
- u32 pkt_cnt_sw_ant_div_by_ctrl_frame;
- boolean is_sw_ant_div_by_ctrl_frame;
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- #if USE_WORKITEM
- RT_WORK_ITEM phydm_sw_antenna_switch_workitem;
- #endif
- #endif
- /* @AntDect (Before link Antenna Switch check) need to be moved*/
- u16 single_ant_counter;
- u16 dual_ant_counter;
- u16 aux_fail_detec_counter;
- u16 retry_counter;
- u8 swas_no_link_state;
- u32 swas_no_link_bk_reg948;
- boolean ANTA_ON; /*To indicate ant A is or not*/
- boolean ANTB_ON; /*@To indicate ant B is on or not*/
- boolean pre_aux_fail_detec;
- boolean rssi_ant_dect_result;
- u8 ant_5g;
- u8 ant_2g;
- };
- #if (DM_ODM_SUPPORT_TYPE & (ODM_AP))
- #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
- struct _BF_DIV_COEX_ {
- boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];
- boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];
- u32 MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];
- u32 MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];
- u8 bd_ccoex_type_wbfer;
- u8 num_txbfee_client;
- u8 num_txbfer_client;
- u8 bdc_try_counter;
- u8 bdc_hold_counter;
- u8 bdc_mode;
- u8 bdc_active_mode;
- u8 BDC_state;
- u8 bdc_rx_idle_update_counter;
- u8 num_client;
- u8 pre_num_client;
- u8 num_bf_tar;
- u8 num_div_tar;
- boolean is_all_div_sta_idle;
- boolean is_all_bf_sta_idle;
- boolean bdc_try_flag;
- boolean BF_pass;
- boolean DIV_pass;
- };
- #endif
- #endif
- struct phydm_fat_struct {
- u8 bssid[6];
- u8 antsel_rx_keep_0;
- u8 antsel_rx_keep_1;
- u8 antsel_rx_keep_2;
- u8 antsel_rx_keep_3;
- u32 ant_sum_rssi[7];
- u32 ant_rssi_cnt[7];
- u32 ant_ave_rssi[7];
- u8 fat_state;
- u8 fat_state_cnt;
- u32 train_idx;
- u8 antsel_a[ODM_ASSOCIATE_ENTRY_NUM];
- u8 antsel_b[ODM_ASSOCIATE_ENTRY_NUM];
- u8 antsel_c[ODM_ASSOCIATE_ENTRY_NUM];
- u16 main_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
- u16 aux_ant_sum[ODM_ASSOCIATE_ENTRY_NUM];
- u16 main_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
- u16 aux_ant_cnt[ODM_ASSOCIATE_ENTRY_NUM];
- u16 main_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
- u16 aux_ant_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];
- u16 main_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
- u16 aux_ant_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];
- u8 rx_idle_ant;
- u8 rx_idle_ant2;
- u8 rvrt_val;
- u8 ant_div_on_off;
- u8 div_path_type;
- boolean is_become_linked;
- u32 min_max_rssi;
- u8 idx_ant_div_counter_2g;
- u8 idx_ant_div_counter_5g;
- u8 ant_div_2g_5g;
- #ifdef ODM_EVM_ENHANCE_ANTDIV
- /*@For 1SS RX phy rate*/
- u32 main_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
- u32 aux_ant_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];
- u32 main_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
- u32 aux_ant_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];
- /*@For 2SS RX phy rate*/
- u32 main_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2]; /*@2SS with A1+B*/
- u32 aux_ant_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2]; /*@2SS with A2+B*/
- u32 main_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
- u32 aux_ant_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];
- boolean evm_method_enable;
- u8 target_ant_evm;
- u8 target_ant_crc32;
- u8 target_ant_tp;
- u8 target_ant_enhance;
- u8 pre_target_ant_enhance;
- u16 main_mpdu_ok_cnt;
- u16 aux_mpdu_ok_cnt;
- u32 crc32_ok_cnt;
- u32 crc32_fail_cnt;
- u32 main_crc32_ok_cnt;
- u32 aux_crc32_ok_cnt;
- u32 main_crc32_fail_cnt;
- u32 aux_crc32_fail_cnt;
- u32 antdiv_tp_main;
- u32 antdiv_tp_aux;
- u32 antdiv_tp_main_cnt;
- u32 antdiv_tp_aux_cnt;
- u8 pre_antdiv_rssi;
- u8 pre_antdiv_tp;
- #endif
- #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
- u32 cck_ctrl_frame_cnt_main;
- u32 cck_ctrl_frame_cnt_aux;
- u32 ofdm_ctrl_frame_cnt_main;
- u32 ofdm_ctrl_frame_cnt_aux;
- u32 main_ant_ctrl_frame_sum;
- u32 aux_ant_ctrl_frame_sum;
- u32 main_ant_ctrl_frame_cnt;
- u32 aux_ant_ctrl_frame_cnt;
- #endif
- u8 b_fix_tx_ant;
- boolean fix_ant_bfee;
- boolean enable_ctrl_frame_antdiv;
- boolean use_ctrl_frame_antdiv;
- boolean *is_no_csi_feedback;
- boolean force_antdiv_type;
- u8 antdiv_type_dbg;
- u8 hw_antsw_occur;
- u8 *p_force_tx_ant_by_desc;
- u8 force_tx_ant_by_desc; /*@A temp value, will hook to driver team's outer parameter later*/
- u8 *p_default_s0_s1;
- u8 default_s0_s1;
- };
- /* @1 ============================================================
- * 1 enumeration
- * 1 ============================================================
- */
- enum fat_state /*@Fast antenna training*/
- {
- FAT_BEFORE_LINK_STATE = 0,
- FAT_PREPARE_STATE = 1,
- FAT_TRAINING_STATE = 2,
- FAT_DECISION_STATE = 3
- };
- enum ant_div_type {
- NO_ANTDIV = 0xFF,
- CG_TRX_HW_ANTDIV = 0x01,
- CGCS_RX_HW_ANTDIV = 0x02,
- FIXED_HW_ANTDIV = 0x03,
- CG_TRX_SMART_ANTDIV = 0x04,
- CGCS_RX_SW_ANTDIV = 0x05,
- S0S1_SW_ANTDIV = 0x06, /*@8723B intrnal switch S0 S1*/
- S0S1_TRX_HW_ANTDIV = 0x07, /*TRX S0S1 diversity for 8723D*/
- 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*/
- HL_SW_SMART_ANT_TYPE2 = 0x11 /*@Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/
- };
- /* @1 ============================================================
- * 1 function prototype
- * 1 ============================================================
- */
- void odm_stop_antenna_switch_dm(void *dm_void);
- void phydm_enable_antenna_diversity(void *dm_void);
- void odm_set_ant_config(void *dm_void, u8 ant_setting /* @0=A, 1=B, 2=C, .... */
- );
- #define sw_ant_div_rest_after_link odm_sw_ant_div_rest_after_link
- void odm_sw_ant_div_rest_after_link(void *dm_void);
- void odm_ant_div_on_off(void *dm_void, u8 swch, u8 path);
- void odm_tx_by_tx_desc_or_reg(void *dm_void, u8 swch);
- #if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))
- void phydm_antdiv_reset_statistic(
- void *dm_void,
- u32 macid);
- void odm_update_rx_idle_ant(
- void *dm_void,
- u8 ant);
- void phydm_update_rx_idle_ant_pathb(void *dm_void, u8 ant);
- void phydm_set_antdiv_val(
- void *dm_void,
- u32 *val_buf,
- u8 val_len);
- #if (RTL8723B_SUPPORT == 1)
- void odm_update_rx_idle_ant_8723b(
- void *dm_void,
- u8 ant,
- u32 default_ant,
- u32 optional_ant);
- #endif
- #if (RTL8188F_SUPPORT == 1)
- void phydm_update_rx_idle_antenna_8188F(
- void *dm_void,
- u32 default_ant);
- #endif
- #if (RTL8723D_SUPPORT == 1)
- void phydm_set_tx_ant_pwr_8723d(
- void *dm_void,
- u8 ant);
- void odm_update_rx_idle_ant_8723d(
- void *dm_void,
- u8 ant,
- u32 default_ant,
- u32 optional_ant);
- #endif
- #ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- void odm_sw_antdiv_callback(
- struct phydm_timer_list *timer);
- void odm_sw_antdiv_workitem_callback(
- void *context);
- #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
- void odm_sw_antdiv_workitem_callback(
- void *context);
- void odm_sw_antdiv_callback(
- void *function_context);
- #endif
- void odm_s0s1_sw_ant_div_by_ctrl_frame(
- void *dm_void,
- u8 step);
- void odm_antsel_statistics_of_ctrl_frame(
- void *dm_void,
- u8 antsel_tr_mux,
- u32 rx_pwdb_all);
- void odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(
- void *dm_void,
- void *phy_info_void,
- void *pkt_info_void);
- #endif
- #ifdef ODM_EVM_ENHANCE_ANTDIV
- void phydm_evm_sw_antdiv_init(
- void *dm_void);
- #if (DM_ODM_SUPPORT_TYPE == ODM_WIN)
- void phydm_evm_antdiv_callback(
- struct phydm_timer_list *timer);
- void phydm_evm_antdiv_workitem_callback(
- void *context);
- #elif (DM_ODM_SUPPORT_TYPE == ODM_CE)
- void phydm_evm_antdiv_callback(
- void *dm_void);
- void phydm_evm_antdiv_workitem_callback(
- void *context);
- #else
- void phydm_evm_antdiv_callback(
- void *dm_void);
- #endif
- #endif
- void odm_hw_ant_div(
- void *dm_void);
- #if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) || (defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))
- void odm_fast_ant_training(
- void *dm_void);
- void odm_fast_ant_training_callback(
- void *dm_void);
- void odm_fast_ant_training_work_item_callback(
- void *dm_void);
- #endif
- void odm_ant_div_init(
- void *dm_void);
- void odm_ant_div(
- void *dm_void);
- void odm_antsel_statistics(
- void *dm_void,
- void *phy_info_void,
- u8 antsel_tr_mux,
- u32 mac_id,
- u32 utility,
- u8 method,
- u8 is_cck_rate);
- void odm_process_rssi_for_ant_div(
- void *dm_void,
- void *phy_info_void,
- void *pkt_info_void);
- #if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))
- void odm_set_tx_ant_by_tx_info(
- void *dm_void,
- u8 *desc,
- u8 mac_id);
- #elif (DM_ODM_SUPPORT_TYPE == ODM_AP)
- struct tx_desc; /*@declared tx_desc here or compile error happened when enabled 8822B*/
- void odm_set_tx_ant_by_tx_info(
- struct rtl8192cd_priv *priv,
- struct tx_desc *pdesc,
- unsigned short aid);
- #if 1 /*@def def CONFIG_WLAN_HAL*/
- void odm_set_tx_ant_by_tx_info_hal(
- struct rtl8192cd_priv *priv,
- void *pdesc_data,
- u16 aid);
- #endif /*@#ifdef CONFIG_WLAN_HAL*/
- #endif
- void odm_ant_div_config(
- void *dm_void);
- void odm_ant_div_timers(
- void *dm_void,
- u8 state);
- void phydm_antdiv_debug(void *dm_void, char input[][16], u32 *_used,
- char *output, u32 *_out_len);
- void odm_ant_div_reset(void *dm_void);
- void odm_antenna_diversity_init(void *dm_void);
- void odm_antenna_diversity(void *dm_void);
- #endif /*@#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY*/
- #endif /*@#ifndef __ODMANTDIV_H__*/
|