Path: blob/master/ALFA-W1F1/RTL8814AU/hal/phydm/phydm_antdiv.h
1307 views
/******************************************************************************1*2* Copyright(c) 2007 - 2017 Realtek Corporation.3*4* This program is free software; you can redistribute it and/or modify it5* under the terms of version 2 of the GNU General Public License as6* published by the Free Software Foundation.7*8* This program is distributed in the hope that it will be useful, but WITHOUT9* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or10* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for11* more details.12*13* The full GNU General Public License is included in this distribution in the14* file called LICENSE.15*16* Contact Information:17* wlanfae <[email protected]>18* Realtek Corporation, No. 2, Innovation Road II, Hsinchu Science Park,19* Hsinchu 300, Taiwan.20*21* Larry Finger <[email protected]>22*23*****************************************************************************/2425#ifndef __PHYDMANTDIV_H__26#define __PHYDMANTDIV_H__2728/*@#define ANTDIV_VERSION "2.0" //2014.11.04*/29/*@#define ANTDIV_VERSION "2.1" //2015.01.13 Dino*/30/*@#define ANTDIV_VERSION "2.2" 2015.01.16 Dino*/31/*@#define ANTDIV_VERSION "3.1" 2015.07.29 YuChen,remove 92c 92d 8723a*/32/*@#define ANTDIV_VERSION "3.2" 2015.08.11 Stanley, disable antenna*/33/*@diversity when BT is enable for 8723B*/34/*@#define ANTDIV_VERSION "3.3" 2015.08.12 Stanley. 8723B does not*/35/*@need to check the antenna is control by BT,*/36/*@because antenna diversity only works when */37/*@BT is disable or radio off*/38/*@#define ANTDIV_VERSION "3.4" 2015.08.28 Dino 1.Add 8821A Smart */39/*@Antenna 2. Add 8188F SW S0S1 Antenna*/40/*@Diversity*/41/*@#define ANTDIV_VERSION "3.5" 2015.10.07 Stanley Always check antenna*/42/*@detection result from BT-coex. for 8723B,*/43/*@not from PHYDM*/44/*@#define ANTDIV_VERSION "3.6"*/ /*@2015.11.16 Stanley */45/*@#define ANTDIV_VERSION "3.7" 2015.11.20 Dino Add SmartAnt FAT Patch */46/*@#define ANTDIV_VERSION "3.8" 2015.12.21 Dino, Add SmartAnt dynamic*/47/*@training packet num */48/*@#define ANTDIV_VERSION "3.9" 2016.01.05 Dino, Add SmartAnt cmd for*/49/*@converting single & two smtant, and add cmd*/50/*@for adjust truth table */51#define ANTDIV_VERSION "4.0" /*@2017.05.25 Mark, Add SW antenna diversity*/52/*@for 8821c because HW transient issue */5354/* @1 ============================================================55* 1 Definition56* 1 ============================================================57*/5859#define ANTDIV_INIT 0xff60#define MAIN_ANT 1 /*@ant A or ant Main or S1*/61#define AUX_ANT 2 /*@AntB or ant Aux or S0*/62#define MAX_ANT 3 /* @3 for AP using*/6364#define ANT1_2G 065/* @= ANT2_5G for 8723D BTG S1 RX S0S1 diversity for 8723D, TX fixed at S1 */66#define ANT2_2G 167/* @= ANT1_5G for 8723D BTG S0 RX S0S1 diversity for 8723D, TX fixed at S1 */68/*smart antenna*/69#define SUPPORT_RF_PATH_NUM 470#define SUPPORT_BEAM_PATTERN_NUM 471#define NUM_ANTENNA_8821A 27273#define SUPPORT_BEAM_SET_PATTERN_NUM 167475#define NO_FIX_TX_ANT 076#define FIX_TX_AT_MAIN 177#define FIX_AUX_AT_MAIN 27879/* @Antenna Diversty Control type */80#define ODM_AUTO_ANT 081#define ODM_FIX_MAIN_ANT 182#define ODM_FIX_AUX_ANT 28384#define ODM_N_ANTDIV_SUPPORT (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B |\85ODM_RTL8188F | ODM_RTL8723D | ODM_RTL8195A |\86ODM_RTL8197F | ODM_RTL8721D)87#define ODM_AC_ANTDIV_SUPPORT (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 |\88ODM_RTL8821C | ODM_RTL8822B | ODM_RTL8814B)89#define ODM_ANTDIV_SUPPORT (ODM_N_ANTDIV_SUPPORT | ODM_AC_ANTDIV_SUPPORT)90#define ODM_SMART_ANT_SUPPORT (ODM_RTL8188E | ODM_RTL8192E)91#define ODM_HL_SMART_ANT_TYPE1_SUPPORT (ODM_RTL8821 | ODM_RTL8822B)9293#define ODM_ANTDIV_2G_SUPPORT_IC (ODM_RTL8188E | ODM_RTL8192E | ODM_RTL8723B |\94ODM_RTL8881A | ODM_RTL8188F | ODM_RTL8723D |\95ODM_RTL8197F)96#define ODM_ANTDIV_5G_SUPPORT_IC (ODM_RTL8821 | ODM_RTL8881A | ODM_RTL8812 |\97ODM_RTL8821C | ODM_RTL8822B)9899#define ODM_EVM_ANTDIV_IC (ODM_RTL8192E | ODM_RTL8197F | ODM_RTL8822B)100101#define ODM_ANTDIV_2G BIT(0)102#define ODM_ANTDIV_5G BIT(1)103104#define ANTDIV_ON 1105#define ANTDIV_OFF 0106107#define ANT_PATH_A 0108#define ANT_PATH_B 1109#define ANT_PATH_AB 2110111#define FAT_ON 1112#define FAT_OFF 0113114#define TX_BY_DESC 1115#define TX_BY_REG 0116117#define RSSI_METHOD 0118#define EVM_METHOD 1119#define CRC32_METHOD 2120#define TP_METHOD 3121122#define INIT_ANTDIV_TIMMER 0123#define CANCEL_ANTDIV_TIMMER 1124#define RELEASE_ANTDIV_TIMMER 2125126#define CRC32_FAIL 1127#define CRC32_OK 0128129#define evm_rssi_th_high 25130#define evm_rssi_th_low 20131132#define NORMAL_STATE_MIAN 1133#define NORMAL_STATE_AUX 2134#define TRAINING_STATE 3135136#define FORCE_RSSI_DIFF 10137138#define HT_IDX 16139#define VHT_IDX 20140141#define CSI_ON 1142#define CSI_OFF 0143144#define DIVON_CSIOFF 1145#define DIVOFF_CSION 2146147#define BDC_DIV_TRAIN_STATE 0148#define bdc_bfer_train_state 1149#define BDC_DECISION_STATE 2150#define BDC_BF_HOLD_STATE 3151#define BDC_DIV_HOLD_STATE 4152153#define BDC_MODE_1 1154#define BDC_MODE_2 2155#define BDC_MODE_3 3156#define BDC_MODE_4 4157#define BDC_MODE_NULL 0xff158159/*SW S0S1 antenna diversity*/160#define SWAW_STEP_INIT 0xff161#define SWAW_STEP_PEEK 0162#define SWAW_STEP_DETERMINE 1163164#define RSSI_CHECK_RESET_PERIOD 10165#define RSSI_CHECK_THRESHOLD 50166167/*@Hong Lin Smart antenna*/168#define HL_SMTANT_2WIRE_DATA_LEN 24169170#if (RTL8723D_SUPPORT == 1)171#ifndef CONFIG_ANTDIV_PERIOD172#define CONFIG_ANTDIV_PERIOD 1173#endif174#endif175/* @1 ============================================================176* 1 structure177* 1 ============================================================178*/179180181struct sw_antenna_switch {182u8 double_chk_flag;183/*@If current antenna RSSI > "RSSI_CHECK_THRESHOLD", than*/184/*@check this antenna again*/185u8 try_flag;186s32 pre_rssi;187u8 cur_antenna;188u8 pre_ant;189u8 rssi_trying;190u8 reset_idx;191u8 train_time;192u8 train_time_flag;193/*@base on RSSI difference between two antennas*/194struct phydm_timer_list sw_antdiv_timer;195u32 pkt_cnt_sw_ant_div_by_ctrl_frame;196boolean is_sw_ant_div_by_ctrl_frame;197198#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)199#if USE_WORKITEM200RT_WORK_ITEM phydm_sw_antenna_switch_workitem;201#endif202#endif203204/* @AntDect (Before link Antenna Switch check) need to be moved*/205u16 single_ant_counter;206u16 dual_ant_counter;207u16 aux_fail_detec_counter;208u16 retry_counter;209u8 swas_no_link_state;210u32 swas_no_link_bk_reg948;211boolean ANTA_ON; /*To indicate ant A is or not*/212boolean ANTB_ON; /*@To indicate ant B is on or not*/213boolean pre_aux_fail_detec;214boolean rssi_ant_dect_result;215u8 ant_5g;216u8 ant_2g;217};218219#if (DM_ODM_SUPPORT_TYPE & (ODM_AP))220#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))221struct _BF_DIV_COEX_ {222boolean w_bfer_client[ODM_ASSOCIATE_ENTRY_NUM];223boolean w_bfee_client[ODM_ASSOCIATE_ENTRY_NUM];224u32 MA_rx_TP[ODM_ASSOCIATE_ENTRY_NUM];225u32 MA_rx_TP_DIV[ODM_ASSOCIATE_ENTRY_NUM];226227u8 bd_ccoex_type_wbfer;228u8 num_txbfee_client;229u8 num_txbfer_client;230u8 bdc_try_counter;231u8 bdc_hold_counter;232u8 bdc_mode;233u8 bdc_active_mode;234u8 BDC_state;235u8 bdc_rx_idle_update_counter;236u8 num_client;237u8 pre_num_client;238u8 num_bf_tar;239u8 num_div_tar;240241boolean is_all_div_sta_idle;242boolean is_all_bf_sta_idle;243boolean bdc_try_flag;244boolean BF_pass;245boolean DIV_pass;246};247#endif248#endif249250struct phydm_fat_struct {251u8 bssid[6];252u8 antsel_rx_keep_0;253u8 antsel_rx_keep_1;254u8 antsel_rx_keep_2;255u8 antsel_rx_keep_3;256u32 ant_sum_rssi[7];257u32 ant_rssi_cnt[7];258u32 ant_ave_rssi[7];259u8 fat_state;260u8 fat_state_cnt;261u32 train_idx;262u8 antsel_a[ODM_ASSOCIATE_ENTRY_NUM];263u8 antsel_b[ODM_ASSOCIATE_ENTRY_NUM];264u8 antsel_c[ODM_ASSOCIATE_ENTRY_NUM];265u16 main_ht_cnt[HT_IDX];266u16 aux_ht_cnt[HT_IDX];267u16 main_vht_cnt[VHT_IDX];268u16 aux_vht_cnt[VHT_IDX];269u16 main_sum[ODM_ASSOCIATE_ENTRY_NUM];270u16 aux_sum[ODM_ASSOCIATE_ENTRY_NUM];271u16 main_cnt[ODM_ASSOCIATE_ENTRY_NUM];272u16 aux_cnt[ODM_ASSOCIATE_ENTRY_NUM];273u16 main_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];274u16 aux_sum_cck[ODM_ASSOCIATE_ENTRY_NUM];275u16 main_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];276u16 aux_cnt_cck[ODM_ASSOCIATE_ENTRY_NUM];277u8 rx_idle_ant;278u8 rx_idle_ant2;279u32 rvrt_val; /*all rvrt_val for pause API must set to u32*/280u8 ant_div_on_off;281u8 div_path_type;282boolean is_become_linked;283boolean get_stats;284u32 min_max_rssi;285u8 idx_ant_div_counter_2g;286u8 idx_ant_div_counter_5g;287u8 ant_div_2g_5g;288289#ifdef ODM_EVM_ENHANCE_ANTDIV290/*@For 1SS RX phy rate*/291u32 main_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];292u32 aux_evm_sum[ODM_ASSOCIATE_ENTRY_NUM];293u32 main_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];294u32 aux_evm_cnt[ODM_ASSOCIATE_ENTRY_NUM];295296/*@For 2SS RX phy rate*/297u32 main_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];/*@2SS with A1+B*/298u32 aux_evm_2ss_sum[ODM_ASSOCIATE_ENTRY_NUM][2];/*@2SS with A2+B*/299u32 main_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];300u32 aux_evm_2ss_cnt[ODM_ASSOCIATE_ENTRY_NUM];301302boolean evm_method_enable;303u8 target_ant_evm;304u8 target_ant_crc32;305u8 target_ant_tp;306u8 target_ant_enhance;307u8 pre_target_ant_enhance;308u16 main_mpdu_ok_cnt;309u16 aux_mpdu_ok_cnt;310311u32 crc32_ok_cnt;312u32 crc32_fail_cnt;313u32 main_crc32_ok_cnt;314u32 aux_crc32_ok_cnt;315u32 main_crc32_fail_cnt;316u32 aux_crc32_fail_cnt;317318u32 main_tp;319u32 aux_tp;320u32 main_tp_cnt;321u32 aux_tp_cnt;322323u8 pre_antdiv_rssi;324u8 pre_antdiv_tp;325#endif326#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))327u32 cck_ctrl_frame_cnt_main;328u32 cck_ctrl_frame_cnt_aux;329u32 ofdm_ctrl_frame_cnt_main;330u32 ofdm_ctrl_frame_cnt_aux;331u32 main_ctrl_sum;332u32 aux_ctrl_sum;333u32 main_ctrl_cnt;334u32 aux_ctrl_cnt;335#endif336u8 b_fix_tx_ant;337boolean fix_ant_bfee;338boolean enable_ctrl_frame_antdiv;339boolean use_ctrl_frame_antdiv;340boolean *is_no_csi_feedback;341boolean force_antdiv_type;342u8 antdiv_type_dbg;343u8 hw_antsw_occur;344u8 *p_force_tx_by_desc;345u8 force_tx_by_desc;346/*@A temp value, will hook to driver team's outer parameter later*/347u8 *p_default_s0_s1;348u8 default_s0_s1;349};350351/* @1 ============================================================352* 1 enumeration353* 1 ============================================================354*/355356enum fat_state /*@Fast antenna training*/357{358FAT_BEFORE_LINK_STATE = 0,359FAT_PREPARE_STATE = 1,360FAT_TRAINING_STATE = 2,361FAT_DECISION_STATE = 3362};363364enum ant_div_type {365NO_ANTDIV = 0xFF,366CG_TRX_HW_ANTDIV = 0x01,367CGCS_RX_HW_ANTDIV = 0x02,368FIXED_HW_ANTDIV = 0x03,369CG_TRX_SMART_ANTDIV = 0x04,370CGCS_RX_SW_ANTDIV = 0x05,371S0S1_SW_ANTDIV = 0x06, /*@8723B intrnal switch S0 S1*/372S0S1_TRX_HW_ANTDIV = 0x07, /*TRX S0S1 diversity for 8723D*/373HL_SW_SMART_ANT_TYPE1 = 0x10,374/*@Hong-Lin Smart antenna use for 8821AE which is a 2 ant. entitys,*/375/*@and each ant. is equipped with 4 antenna patterns*/376HL_SW_SMART_ANT_TYPE2 = 0x11377/*@Hong-Bo Smart antenna use for 8822B which is a 2 ant. entitys*/378};379380/* @1 ============================================================381* 1 function prototype382* 1 ============================================================383*/384385void odm_stop_antenna_switch_dm(void *dm_void);386387void phydm_enable_antenna_diversity(void *dm_void);388389void odm_set_ant_config(void *dm_void, u8 ant_setting /* @0=A, 1=B, 2=C,....*/390);391392#define sw_ant_div_rest_after_link odm_sw_ant_div_rest_after_link393394void odm_sw_ant_div_rest_after_link(void *dm_void);395396void odm_ant_div_on_off(void *dm_void, u8 swch, u8 path);397398void odm_tx_by_tx_desc_or_reg(void *dm_void, u8 swch);399400#if (defined(CONFIG_PHYDM_ANTENNA_DIVERSITY))401402void phydm_antdiv_reset_statistic(void *dm_void, u32 macid);403404void odm_update_rx_idle_ant(void *dm_void, u8 ant);405406void phydm_update_rx_idle_ant_pathb(void *dm_void, u8 ant);407408void phydm_set_antdiv_val(void *dm_void, u32 *val_buf, u8 val_len);409410#if (RTL8723B_SUPPORT == 1)411void odm_update_rx_idle_ant_8723b(void *dm_void, u8 ant, u32 default_ant,412u32 optional_ant);413#endif414415#if (RTL8188F_SUPPORT == 1)416void phydm_update_rx_idle_antenna_8188F(void *dm_void, u32 default_ant);417#endif418419#if (RTL8723D_SUPPORT == 1)420421void phydm_set_tx_ant_pwr_8723d(void *dm_void, u8 ant);422423void odm_update_rx_idle_ant_8723d(void *dm_void, u8 ant, u32 default_ant,424u32 optional_ant);425426#endif427428#ifdef CONFIG_S0S1_SW_ANTENNA_DIVERSITY429430#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)431void odm_sw_antdiv_callback(struct phydm_timer_list *timer);432433void odm_sw_antdiv_workitem_callback(void *context);434435#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)436437void odm_sw_antdiv_workitem_callback(void *context);438439void odm_sw_antdiv_callback(void *function_context);440441#endif442443void odm_s0s1_sw_ant_div_by_ctrl_frame(void *dm_void, u8 step);444445void odm_antsel_statistics_ctrl(void *dm_void, u8 antsel_tr_mux,446u32 rx_pwdb_all);447448void odm_s0s1_sw_ant_div_by_ctrl_frame_process_rssi(void *dm_void,449void *phy_info_void,450void *pkt_info_void);451452#endif453454#ifdef ODM_EVM_ENHANCE_ANTDIV455void phydm_evm_sw_antdiv_init(void *dm_void);456457void phydm_rx_rate_for_antdiv(void *dm_void, void *pkt_info_void);458459void phydm_antdiv_reset_rx_rate(void *dm_void);460461#if (DM_ODM_SUPPORT_TYPE == ODM_WIN)462void phydm_evm_antdiv_callback(struct phydm_timer_list *timer);463464void phydm_evm_antdiv_workitem_callback(void *context);465466#elif (DM_ODM_SUPPORT_TYPE == ODM_CE)467void phydm_evm_antdiv_callback(void *dm_void);468469void phydm_evm_antdiv_workitem_callback(void *context);470471#else472void phydm_evm_antdiv_callback(void *dm_void);473#endif474475#endif476477void odm_hw_ant_div(void *dm_void);478479#if (defined(CONFIG_5G_CG_SMART_ANT_DIVERSITY)) ||\480(defined(CONFIG_2G_CG_SMART_ANT_DIVERSITY))481void odm_fast_ant_training(482void *dm_void);483484void odm_fast_ant_training_callback(void *dm_void);485486void odm_fast_ant_training_work_item_callback(void *dm_void);487#endif488489void odm_ant_div_init(void *dm_void);490491void odm_ant_div(void *dm_void);492493void odm_antsel_statistics(void *dm_void, void *phy_info_void,494u8 antsel_tr_mux, u32 mac_id, u32 utility, u8 method,495u8 is_cck_rate);496497void odm_process_rssi_for_ant_div(void *dm_void, void *phy_info_void,498void *pkt_info_void);499500#if (DM_ODM_SUPPORT_TYPE & (ODM_WIN | ODM_CE))501void odm_set_tx_ant_by_tx_info(void *dm_void, u8 *desc, u8 mac_id);502503#elif (DM_ODM_SUPPORT_TYPE == ODM_AP)504505struct tx_desc;506/*@declared tx_desc here or compile error happened when enabled 8822B*/507508void odm_set_tx_ant_by_tx_info(struct rtl8192cd_priv *priv,509struct tx_desc *pdesc, unsigned short aid);510511#if 1 /*@def def CONFIG_WLAN_HAL*/512void odm_set_tx_ant_by_tx_info_hal(struct rtl8192cd_priv *priv,513void *pdesc_data, u16 aid);514#endif /*@#ifdef CONFIG_WLAN_HAL*/515#endif516517void odm_ant_div_config(void *dm_void);518519void odm_ant_div_timers(void *dm_void, u8 state);520521void phydm_antdiv_debug(void *dm_void, char input[][16], u32 *_used,522char *output, u32 *_out_len);523524void odm_ant_div_reset(void *dm_void);525526void odm_antenna_diversity_init(void *dm_void);527528void odm_antenna_diversity(void *dm_void);529#endif /*@#ifdef CONFIG_PHYDM_ANTENNA_DIVERSITY*/530#endif /*@#ifndef __ODMANTDIV_H__*/531532533