0529c6b817
Not only does this patch update the driver to match the latest Realtek release, it is an important step in getting the internal code source at Realtek to match the code in the kernel. The primary reason for this is to make it easier for Realtek to maintain the kernel source without requiring an intermediate like me. In this process of merging the two source repositories, there are a lot of changes in both, and this commit is rather large. Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
175 lines
4.6 KiB
C
175 lines
4.6 KiB
C
/******************************************************************************
|
|
*
|
|
* Copyright(c) 2009-2012 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with
|
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
|
*
|
|
* 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 __RTL8723E_DM_H__
|
|
#define __RTL8723E_DM_H__
|
|
|
|
#define HAL_DM_DIG_DISABLE BIT(0)
|
|
#define HAL_DM_HIPWR_DISABLE BIT(1)
|
|
|
|
#define OFDM_TABLE_LENGTH 37
|
|
#define CCK_TABLE_LENGTH 33
|
|
|
|
#define OFDM_TABLE_SIZE 37
|
|
#define CCK_TABLE_SIZE 33
|
|
|
|
#define BW_AUTO_SWITCH_HIGH_LOW 25
|
|
#define BW_AUTO_SWITCH_LOW_HIGH 30
|
|
|
|
#define DM_DIG_THRESH_HIGH 40
|
|
#define DM_DIG_THRESH_LOW 35
|
|
|
|
#define DM_FALSEALARM_THRESH_LOW 400
|
|
#define DM_FALSEALARM_THRESH_HIGH 1000
|
|
|
|
#define DM_DIG_MAX 0x3e
|
|
#define DM_DIG_MIN 0x1e
|
|
|
|
#define DM_DIG_FA_UPPER 0x32
|
|
#define DM_DIG_FA_LOWER 0x20
|
|
#define DM_DIG_FA_TH0 0x20
|
|
#define DM_DIG_FA_TH1 0x100
|
|
#define DM_DIG_FA_TH2 0x200
|
|
|
|
#define DM_DIG_BACKOFF_MAX 12
|
|
#define DM_DIG_BACKOFF_MIN -4
|
|
#define DM_DIG_BACKOFF_DEFAULT 10
|
|
|
|
#define RXPATHSELECTION_SS_TH_LOW 30
|
|
#define RXPATHSELECTION_DIFF_TH 18
|
|
|
|
#define DM_RATR_STA_INIT 0
|
|
#define DM_RATR_STA_HIGH 1
|
|
#define DM_RATR_STA_MIDDLE 2
|
|
#define DM_RATR_STA_LOW 3
|
|
|
|
#define CTS2SELF_THVAL 30
|
|
#define REGC38_TH 20
|
|
|
|
#define WAIOTTHVAL 25
|
|
|
|
#define TXHIGHPWRLEVEL_NORMAL 0
|
|
#define TXHIGHPWRLEVEL_LEVEL1 1
|
|
#define TXHIGHPWRLEVEL_LEVEL2 2
|
|
#define TXHIGHPWRLEVEL_BT1 3
|
|
#define TXHIGHPWRLEVEL_BT2 4
|
|
|
|
#define DM_TYPE_BYFW 0
|
|
#define DM_TYPE_BYDRIVER 1
|
|
|
|
#define TX_POWER_NEAR_FIELD_THRESH_LVL2 74
|
|
#define TX_POWER_NEAR_FIELD_THRESH_LVL1 67
|
|
|
|
struct swat_t {
|
|
u8 failure_cnt;
|
|
u8 try_flag;
|
|
u8 stop_trying;
|
|
long pre_rssi;
|
|
long trying_threshold;
|
|
u8 cur_antenna;
|
|
u8 pre_antenna;
|
|
|
|
};
|
|
|
|
enum tag_dynamic_init_gain_operation_type_definition {
|
|
DIG_TYPE_THRESH_HIGH = 0,
|
|
DIG_TYPE_THRESH_LOW = 1,
|
|
DIG_TYPE_BACKOFF = 2,
|
|
DIG_TYPE_RX_GAIN_MIN = 3,
|
|
DIG_TYPE_RX_GAIN_MAX = 4,
|
|
DIG_TYPE_ENABLE = 5,
|
|
DIG_TYPE_DISABLE = 6,
|
|
DIG_OP_TYPE_MAX
|
|
};
|
|
|
|
enum tag_cck_packet_detection_threshold_type_definition {
|
|
CCK_PD_STAGE_LowRssi = 0,
|
|
CCK_PD_STAGE_HighRssi = 1,
|
|
CCK_FA_STAGE_LOW = 2,
|
|
CCK_FA_STAGE_High = 3,
|
|
CCK_PD_STAGE_MAX = 4,
|
|
};
|
|
|
|
enum dm_1r_cca_e {
|
|
CCA_1R = 0,
|
|
CCA_2R = 1,
|
|
CCA_MAX = 2,
|
|
};
|
|
|
|
enum dm_rf_e {
|
|
RF_SAVE = 0,
|
|
RF_NORMAL = 1,
|
|
RF_MAX = 2,
|
|
};
|
|
|
|
enum dm_sw_ant_switch_e {
|
|
ANS_ANTENNA_B = 1,
|
|
ANS_ANTENNA_A = 2,
|
|
ANS_ANTENNA_MAX = 3,
|
|
};
|
|
|
|
enum dm_dig_ext_port_alg_e {
|
|
DIG_EXT_PORT_STAGE_0 = 0,
|
|
DIG_EXT_PORT_STAGE_1 = 1,
|
|
DIG_EXT_PORT_STAGE_2 = 2,
|
|
DIG_EXT_PORT_STAGE_3 = 3,
|
|
DIG_EXT_PORT_STAGE_MAX = 4,
|
|
};
|
|
|
|
enum dm_dig_connect_e {
|
|
DIG_STA_DISCONNECT = 0,
|
|
DIG_STA_CONNECT = 1,
|
|
DIG_STA_BEFORE_CONNECT = 2,
|
|
DIG_MULTISTA_DISCONNECT = 3,
|
|
DIG_MULTISTA_CONNECT = 4,
|
|
DIG_CONNECT_MAX
|
|
};
|
|
|
|
#define BT_RSSI_STATE_NORMAL_POWER BIT_OFFSET_LEN_MASK_32(0, 1)
|
|
#define BT_RSSI_STATE_AMDPU_OFF BIT_OFFSET_LEN_MASK_32(1, 1)
|
|
#define BT_RSSI_STATE_SPECIAL_LOW BIT_OFFSET_LEN_MASK_32(2, 1)
|
|
#define BT_RSSI_STATE_BG_EDCA_LOW BIT_OFFSET_LEN_MASK_32(3, 1)
|
|
#define BT_RSSI_STATE_TXPOWER_LOW BIT_OFFSET_LEN_MASK_32(4, 1)
|
|
#define GET_UNDECORATED_AVERAGE_RSSI(_priv) \
|
|
( \
|
|
(((struct rtl_priv *)(_priv))->mac80211.opmode == \
|
|
NL80211_IFTYPE_ADHOC) ? \
|
|
(((struct rtl_priv *)(_priv))->dm.entry_min_undec_sm_pwdb) : \
|
|
(((struct rtl_priv *)(_priv))->dm.undec_sm_pwdb) \
|
|
)
|
|
|
|
void rtl8723e_dm_init(struct ieee80211_hw *hw);
|
|
void rtl8723e_dm_watchdog(struct ieee80211_hw *hw);
|
|
void rtl8723e_dm_write_dig(struct ieee80211_hw *hw);
|
|
void rtl8723e_dm_check_txpower_tracking(struct ieee80211_hw *hw);
|
|
void rtl8723e_dm_init_rate_adaptive_mask(struct ieee80211_hw *hw);
|
|
void rtl8723e_dm_rf_saving(struct ieee80211_hw *hw, u8 bforce_in_normal);
|
|
void rtl8723e_dm_bt_coexist(struct ieee80211_hw *hw);
|
|
#endif
|