rtlwifi: rtl8723ae: rtl8723-common: Create new driver for common code
The drivers for RTL8723AE and RTL8723BE have some code in common. This commit creates a driver for this code that will be shared, and copies those common routines from rtl8723ae's phy code. Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
2cddad3c73
commit
0a168b48cd
drivers/net/wireless/rtlwifi
@ -48,6 +48,7 @@ config RTL8723AE
|
|||||||
depends on PCI
|
depends on PCI
|
||||||
select RTLWIFI
|
select RTLWIFI
|
||||||
select RTLWIFI_PCI
|
select RTLWIFI_PCI
|
||||||
|
select RTL8723_COMMON
|
||||||
select RTLBTCOEXIST
|
select RTLBTCOEXIST
|
||||||
---help---
|
---help---
|
||||||
This is the driver for Realtek RTL8723AE 802.11n PCIe
|
This is the driver for Realtek RTL8723AE 802.11n PCIe
|
||||||
@ -102,6 +103,11 @@ config RTL8192C_COMMON
|
|||||||
depends on RTL8192CE || RTL8192CU
|
depends on RTL8192CE || RTL8192CU
|
||||||
default y
|
default y
|
||||||
|
|
||||||
|
config RTL8723_COMMON
|
||||||
|
tristate
|
||||||
|
depends on RTL8723AE
|
||||||
|
default y
|
||||||
|
|
||||||
config RTLBTCOEXIST
|
config RTLBTCOEXIST
|
||||||
tristate
|
tristate
|
||||||
depends on RTL8723AE
|
depends on RTL8723AE
|
||||||
|
@ -26,5 +26,6 @@ obj-$(CONFIG_RTL8192DE) += rtl8192de/
|
|||||||
obj-$(CONFIG_RTL8723AE) += rtl8723ae/
|
obj-$(CONFIG_RTL8723AE) += rtl8723ae/
|
||||||
obj-$(CONFIG_RTL8188EE) += rtl8188ee/
|
obj-$(CONFIG_RTL8188EE) += rtl8188ee/
|
||||||
obj-$(CONFIG_RTLBTCOEXIST) += btcoexist/
|
obj-$(CONFIG_RTLBTCOEXIST) += btcoexist/
|
||||||
|
obj-$(CONFIG_RTL8723_COMMON) += rtl8723com/
|
||||||
|
|
||||||
ccflags-y += -D__CHECK_ENDIAN__
|
ccflags-y += -D__CHECK_ENDIAN__
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "hal_btc.h"
|
#include "hal_btc.h"
|
||||||
#include "../pci.h"
|
#include "../pci.h"
|
||||||
#include "phy.h"
|
#include "phy.h"
|
||||||
|
#include "../rtl8723com/phy_common.h"
|
||||||
#include "fw.h"
|
#include "fw.h"
|
||||||
#include "reg.h"
|
#include "reg.h"
|
||||||
#include "def.h"
|
#include "def.h"
|
||||||
@ -391,13 +392,13 @@ static void rtl8723ae_dm_bt_set_sw_full_time_dac_swing(struct ieee80211_hw *hw,
|
|||||||
if (sw_dac_swing_on) {
|
if (sw_dac_swing_on) {
|
||||||
RT_TRACE(rtlpriv, COMP_BT_COEXIST, DBG_TRACE,
|
RT_TRACE(rtlpriv, COMP_BT_COEXIST, DBG_TRACE,
|
||||||
"[BTCoex], SwDacSwing = 0x%x\n", sw_dac_swing_lvl);
|
"[BTCoex], SwDacSwing = 0x%x\n", sw_dac_swing_lvl);
|
||||||
rtl8723ae_phy_set_bb_reg(hw, 0x880, 0xff000000,
|
rtl8723_phy_set_bb_reg(hw, 0x880, 0xff000000,
|
||||||
sw_dac_swing_lvl);
|
sw_dac_swing_lvl);
|
||||||
rtlpcipriv->bt_coexist.sw_coexist_all_off = false;
|
rtlpcipriv->bt_coexist.sw_coexist_all_off = false;
|
||||||
} else {
|
} else {
|
||||||
RT_TRACE(rtlpriv, COMP_BT_COEXIST, DBG_TRACE,
|
RT_TRACE(rtlpriv, COMP_BT_COEXIST, DBG_TRACE,
|
||||||
"[BTCoex], SwDacSwing Off!\n");
|
"[BTCoex], SwDacSwing Off!\n");
|
||||||
rtl8723ae_phy_set_bb_reg(hw, 0x880, 0xff000000, 0xc0);
|
rtl8723_phy_set_bb_reg(hw, 0x880, 0xff000000, 0xc0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
#include "rf.h"
|
#include "rf.h"
|
||||||
#include "dm.h"
|
#include "dm.h"
|
||||||
#include "table.h"
|
#include "table.h"
|
||||||
|
#include "../rtl8723com/phy_common.h"
|
||||||
|
|
||||||
/* static forward definitions */
|
/* static forward definitions */
|
||||||
static u32 _phy_fw_rf_serial_read(struct ieee80211_hw *hw,
|
static u32 _phy_fw_rf_serial_read(struct ieee80211_hw *hw,
|
||||||
@ -43,72 +44,17 @@ static u32 _phy_fw_rf_serial_read(struct ieee80211_hw *hw,
|
|||||||
static void _phy_fw_rf_serial_write(struct ieee80211_hw *hw,
|
static void _phy_fw_rf_serial_write(struct ieee80211_hw *hw,
|
||||||
enum radio_path rfpath,
|
enum radio_path rfpath,
|
||||||
u32 offset, u32 data);
|
u32 offset, u32 data);
|
||||||
static u32 _phy_rf_serial_read(struct ieee80211_hw *hw,
|
|
||||||
enum radio_path rfpath, u32 offset);
|
|
||||||
static void _phy_rf_serial_write(struct ieee80211_hw *hw,
|
|
||||||
enum radio_path rfpath, u32 offset, u32 data);
|
|
||||||
static u32 _phy_calculate_bit_shift(u32 bitmask);
|
|
||||||
static bool _phy_bb8192c_config_parafile(struct ieee80211_hw *hw);
|
static bool _phy_bb8192c_config_parafile(struct ieee80211_hw *hw);
|
||||||
static bool _phy_cfg_mac_w_header(struct ieee80211_hw *hw);
|
static bool _phy_cfg_mac_w_header(struct ieee80211_hw *hw);
|
||||||
static bool _phy_cfg_bb_w_header(struct ieee80211_hw *hw, u8 configtype);
|
static bool _phy_cfg_bb_w_header(struct ieee80211_hw *hw, u8 configtype);
|
||||||
static bool _phy_cfg_bb_w_pgheader(struct ieee80211_hw *hw, u8 configtype);
|
static bool _phy_cfg_bb_w_pgheader(struct ieee80211_hw *hw, u8 configtype);
|
||||||
static void _phy_init_bb_rf_reg_def(struct ieee80211_hw *hw);
|
|
||||||
static bool _phy_set_sw_chnl_cmdarray(struct swchnlcmd *cmdtable,
|
|
||||||
u32 cmdtableidx, u32 cmdtablesz,
|
|
||||||
enum swchnlcmd_id cmdid,
|
|
||||||
u32 para1, u32 para2,
|
|
||||||
u32 msdelay);
|
|
||||||
static bool _phy_sw_chnl_step_by_step(struct ieee80211_hw *hw, u8 channel,
|
static bool _phy_sw_chnl_step_by_step(struct ieee80211_hw *hw, u8 channel,
|
||||||
u8 *stage, u8 *step, u32 *delay);
|
u8 *stage, u8 *step, u32 *delay);
|
||||||
static u8 _phy_dbm_to_txpwr_Idx(struct ieee80211_hw *hw,
|
static u8 _phy_dbm_to_txpwr_Idx(struct ieee80211_hw *hw,
|
||||||
enum wireless_mode wirelessmode,
|
enum wireless_mode wirelessmode,
|
||||||
long power_indbm);
|
long power_indbm);
|
||||||
static long _phy_txpwr_idx_to_dbm(struct ieee80211_hw *hw,
|
|
||||||
enum wireless_mode wirelessmode, u8 txpwridx);
|
|
||||||
static void rtl8723ae_phy_set_io(struct ieee80211_hw *hw);
|
static void rtl8723ae_phy_set_io(struct ieee80211_hw *hw);
|
||||||
|
|
||||||
u32 rtl8723ae_phy_query_bb_reg(struct ieee80211_hw *hw, u32 regaddr,
|
|
||||||
u32 bitmask)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
u32 returnvalue, originalvalue, bitshift;
|
|
||||||
|
|
||||||
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
|
||||||
"regaddr(%#x), bitmask(%#x)\n", regaddr, bitmask);
|
|
||||||
originalvalue = rtl_read_dword(rtlpriv, regaddr);
|
|
||||||
bitshift = _phy_calculate_bit_shift(bitmask);
|
|
||||||
returnvalue = (originalvalue & bitmask) >> bitshift;
|
|
||||||
|
|
||||||
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
|
||||||
"BBR MASK=0x%x Addr[0x%x]=0x%x\n", bitmask, regaddr,
|
|
||||||
originalvalue);
|
|
||||||
|
|
||||||
return returnvalue;
|
|
||||||
}
|
|
||||||
|
|
||||||
void rtl8723ae_phy_set_bb_reg(struct ieee80211_hw *hw,
|
|
||||||
u32 regaddr, u32 bitmask, u32 data)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
u32 originalvalue, bitshift;
|
|
||||||
|
|
||||||
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
|
||||||
"regaddr(%#x), bitmask(%#x), data(%#x)\n", regaddr,
|
|
||||||
bitmask, data);
|
|
||||||
|
|
||||||
if (bitmask != MASKDWORD) {
|
|
||||||
originalvalue = rtl_read_dword(rtlpriv, regaddr);
|
|
||||||
bitshift = _phy_calculate_bit_shift(bitmask);
|
|
||||||
data = ((originalvalue & (~bitmask)) | (data << bitshift));
|
|
||||||
}
|
|
||||||
|
|
||||||
rtl_write_dword(rtlpriv, regaddr, data);
|
|
||||||
|
|
||||||
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
|
||||||
"regaddr(%#x), bitmask(%#x), data(%#x)\n",
|
|
||||||
regaddr, bitmask, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
u32 rtl8723ae_phy_query_rf_reg(struct ieee80211_hw *hw,
|
u32 rtl8723ae_phy_query_rf_reg(struct ieee80211_hw *hw,
|
||||||
enum radio_path rfpath, u32 regaddr, u32 bitmask)
|
enum radio_path rfpath, u32 regaddr, u32 bitmask)
|
||||||
{
|
{
|
||||||
@ -124,11 +70,11 @@ u32 rtl8723ae_phy_query_rf_reg(struct ieee80211_hw *hw,
|
|||||||
spin_lock_irqsave(&rtlpriv->locks.rf_lock, flags);
|
spin_lock_irqsave(&rtlpriv->locks.rf_lock, flags);
|
||||||
|
|
||||||
if (rtlphy->rf_mode != RF_OP_BY_FW)
|
if (rtlphy->rf_mode != RF_OP_BY_FW)
|
||||||
original_value = _phy_rf_serial_read(hw, rfpath, regaddr);
|
original_value = rtl8723_phy_rf_serial_read(hw, rfpath, regaddr);
|
||||||
else
|
else
|
||||||
original_value = _phy_fw_rf_serial_read(hw, rfpath, regaddr);
|
original_value = _phy_fw_rf_serial_read(hw, rfpath, regaddr);
|
||||||
|
|
||||||
bitshift = _phy_calculate_bit_shift(bitmask);
|
bitshift = rtl8723_phy_calculate_bit_shift(bitmask);
|
||||||
readback_value = (original_value & bitmask) >> bitshift;
|
readback_value = (original_value & bitmask) >> bitshift;
|
||||||
|
|
||||||
spin_unlock_irqrestore(&rtlpriv->locks.rf_lock, flags);
|
spin_unlock_irqrestore(&rtlpriv->locks.rf_lock, flags);
|
||||||
@ -157,19 +103,19 @@ void rtl8723ae_phy_set_rf_reg(struct ieee80211_hw *hw,
|
|||||||
|
|
||||||
if (rtlphy->rf_mode != RF_OP_BY_FW) {
|
if (rtlphy->rf_mode != RF_OP_BY_FW) {
|
||||||
if (bitmask != RFREG_OFFSET_MASK) {
|
if (bitmask != RFREG_OFFSET_MASK) {
|
||||||
original_value = _phy_rf_serial_read(hw, rfpath,
|
original_value = rtl8723_phy_rf_serial_read(hw, rfpath,
|
||||||
regaddr);
|
regaddr);
|
||||||
bitshift = _phy_calculate_bit_shift(bitmask);
|
bitshift = rtl8723_phy_calculate_bit_shift(bitmask);
|
||||||
data = ((original_value & (~bitmask)) |
|
data = ((original_value & (~bitmask)) |
|
||||||
(data << bitshift));
|
(data << bitshift));
|
||||||
}
|
}
|
||||||
|
|
||||||
_phy_rf_serial_write(hw, rfpath, regaddr, data);
|
rtl8723_phy_rf_serial_write(hw, rfpath, regaddr, data);
|
||||||
} else {
|
} else {
|
||||||
if (bitmask != RFREG_OFFSET_MASK) {
|
if (bitmask != RFREG_OFFSET_MASK) {
|
||||||
original_value = _phy_fw_rf_serial_read(hw, rfpath,
|
original_value = _phy_fw_rf_serial_read(hw, rfpath,
|
||||||
regaddr);
|
regaddr);
|
||||||
bitshift = _phy_calculate_bit_shift(bitmask);
|
bitshift = rtl8723_phy_calculate_bit_shift(bitmask);
|
||||||
data = ((original_value & (~bitmask)) |
|
data = ((original_value & (~bitmask)) |
|
||||||
(data << bitshift));
|
(data << bitshift));
|
||||||
}
|
}
|
||||||
@ -197,87 +143,6 @@ static void _phy_fw_rf_serial_write(struct ieee80211_hw *hw,
|
|||||||
RT_ASSERT(false, "deprecated!\n");
|
RT_ASSERT(false, "deprecated!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
static u32 _phy_rf_serial_read(struct ieee80211_hw *hw,
|
|
||||||
enum radio_path rfpath, u32 offset)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
struct rtl_phy *rtlphy = &(rtlpriv->phy);
|
|
||||||
struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
|
|
||||||
u32 newoffset;
|
|
||||||
u32 tmplong, tmplong2;
|
|
||||||
u8 rfpi_enable = 0;
|
|
||||||
u32 retvalue;
|
|
||||||
|
|
||||||
offset &= 0x3f;
|
|
||||||
newoffset = offset;
|
|
||||||
if (RT_CANNOT_IO(hw)) {
|
|
||||||
RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "return all one\n");
|
|
||||||
return 0xFFFFFFFF;
|
|
||||||
}
|
|
||||||
tmplong = rtl_get_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD);
|
|
||||||
if (rfpath == RF90_PATH_A)
|
|
||||||
tmplong2 = tmplong;
|
|
||||||
else
|
|
||||||
tmplong2 = rtl_get_bbreg(hw, pphyreg->rfhssi_para2, MASKDWORD);
|
|
||||||
tmplong2 = (tmplong2 & (~BLSSIREADADDRESS)) |
|
|
||||||
(newoffset << 23) | BLSSIREADEDGE;
|
|
||||||
rtl_set_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD,
|
|
||||||
tmplong & (~BLSSIREADEDGE));
|
|
||||||
mdelay(1);
|
|
||||||
rtl_set_bbreg(hw, pphyreg->rfhssi_para2, MASKDWORD, tmplong2);
|
|
||||||
mdelay(1);
|
|
||||||
rtl_set_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD,
|
|
||||||
tmplong | BLSSIREADEDGE);
|
|
||||||
mdelay(1);
|
|
||||||
if (rfpath == RF90_PATH_A)
|
|
||||||
rfpi_enable = (u8) rtl_get_bbreg(hw, RFPGA0_XA_HSSIPARAMETER1,
|
|
||||||
BIT(8));
|
|
||||||
else if (rfpath == RF90_PATH_B)
|
|
||||||
rfpi_enable = (u8) rtl_get_bbreg(hw, RFPGA0_XB_HSSIPARAMETER1,
|
|
||||||
BIT(8));
|
|
||||||
if (rfpi_enable)
|
|
||||||
retvalue = rtl_get_bbreg(hw, pphyreg->rf_rbpi,
|
|
||||||
BLSSIREADBACKDATA);
|
|
||||||
else
|
|
||||||
retvalue = rtl_get_bbreg(hw, pphyreg->rf_rb,
|
|
||||||
BLSSIREADBACKDATA);
|
|
||||||
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE, "RFR-%d Addr[0x%x]=0x%x\n",
|
|
||||||
rfpath, pphyreg->rf_rb, retvalue);
|
|
||||||
return retvalue;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _phy_rf_serial_write(struct ieee80211_hw *hw,
|
|
||||||
enum radio_path rfpath, u32 offset, u32 data)
|
|
||||||
{
|
|
||||||
u32 data_and_addr;
|
|
||||||
u32 newoffset;
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
struct rtl_phy *rtlphy = &(rtlpriv->phy);
|
|
||||||
struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
|
|
||||||
|
|
||||||
if (RT_CANNOT_IO(hw)) {
|
|
||||||
RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "stop\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
offset &= 0x3f;
|
|
||||||
newoffset = offset;
|
|
||||||
data_and_addr = ((newoffset << 20) | (data & 0x000fffff)) & 0x0fffffff;
|
|
||||||
rtl_set_bbreg(hw, pphyreg->rf3wire_offset, MASKDWORD, data_and_addr);
|
|
||||||
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE, "RFW-%d Addr[0x%x]=0x%x\n",
|
|
||||||
rfpath, pphyreg->rf3wire_offset, data_and_addr);
|
|
||||||
}
|
|
||||||
|
|
||||||
static u32 _phy_calculate_bit_shift(u32 bitmask)
|
|
||||||
{
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
for (i = 0; i <= 31; i++) {
|
|
||||||
if (((bitmask >> i) & 0x1) == 1)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _rtl8723ae_phy_bb_config_1t(struct ieee80211_hw *hw)
|
static void _rtl8723ae_phy_bb_config_1t(struct ieee80211_hw *hw)
|
||||||
{
|
{
|
||||||
rtl_set_bbreg(hw, RFPGA0_TXINFO, 0x3, 0x2);
|
rtl_set_bbreg(hw, RFPGA0_TXINFO, 0x3, 0x2);
|
||||||
@ -307,7 +172,7 @@ bool rtl8723ae_phy_bb_config(struct ieee80211_hw *hw)
|
|||||||
u8 tmpu1b;
|
u8 tmpu1b;
|
||||||
u8 reg_hwparafile = 1;
|
u8 reg_hwparafile = 1;
|
||||||
|
|
||||||
_phy_init_bb_rf_reg_def(hw);
|
rtl8723_phy_init_bb_rf_reg_def(hw);
|
||||||
|
|
||||||
/* 1. 0x28[1] = 1 */
|
/* 1. 0x28[1] = 1 */
|
||||||
tmpu1b = rtl_read_byte(rtlpriv, REG_AFE_PLL_CTRL);
|
tmpu1b = rtl_read_byte(rtlpriv, REG_AFE_PLL_CTRL);
|
||||||
@ -690,92 +555,6 @@ void rtl8723ae_phy_get_hw_reg_originalvalue(struct ieee80211_hw *hw)
|
|||||||
ROFDM0_RXDETECTOR3, rtlphy->framesync);
|
ROFDM0_RXDETECTOR3, rtlphy->framesync);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void _phy_init_bb_rf_reg_def(struct ieee80211_hw *hw)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
struct rtl_phy *rtlphy = &(rtlpriv->phy);
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfintfs = RFPGA0_XAB_RFINTERFACESW;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfintfs = RFPGA0_XAB_RFINTERFACESW;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfintfs = RFPGA0_XCD_RFINTERFACESW;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfintfs = RFPGA0_XCD_RFINTERFACESW;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfintfi = RFPGA0_XAB_RFINTERFACERB;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfintfi = RFPGA0_XAB_RFINTERFACERB;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfintfi = RFPGA0_XCD_RFINTERFACERB;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfintfi = RFPGA0_XCD_RFINTERFACERB;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfintfo = RFPGA0_XA_RFINTERFACEOE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfintfo = RFPGA0_XB_RFINTERFACEOE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfintfe = RFPGA0_XA_RFINTERFACEOE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfintfe = RFPGA0_XB_RFINTERFACEOE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rf3wire_offset =
|
|
||||||
RFPGA0_XA_LSSIPARAMETER;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rf3wire_offset =
|
|
||||||
RFPGA0_XB_LSSIPARAMETER;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rflssi_select = rFPGA0_XAB_RFPARAMETER;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rflssi_select = rFPGA0_XAB_RFPARAMETER;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rflssi_select = rFPGA0_XCD_RFPARAMETER;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rflssi_select = rFPGA0_XCD_RFPARAMETER;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfhssi_para1 = RFPGA0_XA_HSSIPARAMETER1;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfhssi_para1 = RFPGA0_XB_HSSIPARAMETER1;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfhssi_para2 = RFPGA0_XA_HSSIPARAMETER2;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfhssi_para2 = RFPGA0_XB_HSSIPARAMETER2;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfsw_ctrl = RFPGA0_XAB_SWITCHCONTROL;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfsw_ctrl = RFPGA0_XAB_SWITCHCONTROL;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfsw_ctrl = RFPGA0_XCD_SWITCHCONTROL;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfsw_ctrl = RFPGA0_XCD_SWITCHCONTROL;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfagc_control1 = ROFDM0_XAAGCCORE1;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfagc_control1 = ROFDM0_XBAGCCORE1;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfagc_control1 = ROFDM0_XCAGCCORE1;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfagc_control1 = ROFDM0_XDAGCCORE1;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfagc_control2 = ROFDM0_XAAGCCORE2;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfagc_control2 = ROFDM0_XBAGCCORE2;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfagc_control2 = ROFDM0_XCAGCCORE2;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfagc_control2 = ROFDM0_XDAGCCORE2;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfrxiq_imbal = ROFDM0_XARXIQIMBALANCE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfrxiq_imbal = ROFDM0_XBRXIQIMBALANCE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfrxiq_imbal = ROFDM0_XCRXIQIMBANLANCE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfrxiq_imbal = ROFDM0_XDRXIQIMBALANCE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rfrx_afe = ROFDM0_XARXAFE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rfrx_afe = ROFDM0_XBRXAFE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rfrx_afe = ROFDM0_XCRXAFE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rfrx_afe = ROFDM0_XDRXAFE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rftxiq_imbal = ROFDM0_XATXIQIMBALANCE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rftxiq_imbal = ROFDM0_XBTXIQIMBALANCE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rftxiq_imbal = ROFDM0_XCTXIQIMBALANCE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rftxiq_imbal = ROFDM0_XDTXIQIMBALANCE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rftx_afe = ROFDM0_XATXAFE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rftx_afe = ROFDM0_XBTXAFE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rftx_afe = ROFDM0_XCTXAFE;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rftx_afe = ROFDM0_XDTXAFE;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rf_rb = RFPGA0_XA_LSSIREADBACK;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rf_rb = RFPGA0_XB_LSSIREADBACK;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_C].rf_rb = RFPGA0_XC_LSSIREADBACK;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_D].rf_rb = RFPGA0_XD_LSSIREADBACK;
|
|
||||||
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_A].rf_rbpi = TRANSCEIVEA_HSPI_READBACK;
|
|
||||||
rtlphy->phyreg_def[RF90_PATH_B].rf_rbpi = TRANSCEIVEB_HSPI_READBACK;
|
|
||||||
}
|
|
||||||
|
|
||||||
void rtl8723ae_phy_get_txpower_level(struct ieee80211_hw *hw, long *powerlevel)
|
void rtl8723ae_phy_get_txpower_level(struct ieee80211_hw *hw, long *powerlevel)
|
||||||
{
|
{
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
@ -785,17 +564,17 @@ void rtl8723ae_phy_get_txpower_level(struct ieee80211_hw *hw, long *powerlevel)
|
|||||||
long txpwr_dbm;
|
long txpwr_dbm;
|
||||||
|
|
||||||
txpwr_level = rtlphy->cur_cck_txpwridx;
|
txpwr_level = rtlphy->cur_cck_txpwridx;
|
||||||
txpwr_dbm = _phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_B, txpwr_level);
|
txpwr_dbm = rtl8723_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_B, txpwr_level);
|
||||||
txpwr_level = rtlphy->cur_ofdm24g_txpwridx +
|
txpwr_level = rtlphy->cur_ofdm24g_txpwridx +
|
||||||
rtlefuse->legacy_ht_txpowerdiff;
|
rtlefuse->legacy_ht_txpowerdiff;
|
||||||
if (_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_G, txpwr_level) > txpwr_dbm)
|
if (rtl8723_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_G, txpwr_level) > txpwr_dbm)
|
||||||
txpwr_dbm = _phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_G,
|
txpwr_dbm = rtl8723_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_G,
|
||||||
txpwr_level);
|
txpwr_level);
|
||||||
txpwr_level = rtlphy->cur_ofdm24g_txpwridx;
|
txpwr_level = rtlphy->cur_ofdm24g_txpwridx;
|
||||||
if (_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_N_24G, txpwr_level) >
|
if (rtl8723_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_N_24G, txpwr_level) >
|
||||||
txpwr_dbm)
|
txpwr_dbm)
|
||||||
txpwr_dbm = _phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_N_24G,
|
txpwr_dbm = rtl8723_phy_txpwr_idx_to_dbm(hw, WIRELESS_MODE_N_24G,
|
||||||
txpwr_level);
|
txpwr_level);
|
||||||
*powerlevel = txpwr_dbm;
|
*powerlevel = txpwr_dbm;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -912,28 +691,6 @@ static u8 _phy_dbm_to_txpwr_Idx(struct ieee80211_hw *hw,
|
|||||||
return txpwridx;
|
return txpwridx;
|
||||||
}
|
}
|
||||||
|
|
||||||
static long _phy_txpwr_idx_to_dbm(struct ieee80211_hw *hw,
|
|
||||||
enum wireless_mode wirelessmode, u8 txpwridx)
|
|
||||||
{
|
|
||||||
long offset;
|
|
||||||
long pwrout_dbm;
|
|
||||||
|
|
||||||
switch (wirelessmode) {
|
|
||||||
case WIRELESS_MODE_B:
|
|
||||||
offset = -7;
|
|
||||||
break;
|
|
||||||
case WIRELESS_MODE_G:
|
|
||||||
case WIRELESS_MODE_N_24G:
|
|
||||||
offset = -8;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
offset = -8;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
pwrout_dbm = txpwridx / 2 + offset;
|
|
||||||
return pwrout_dbm;
|
|
||||||
}
|
|
||||||
|
|
||||||
void rtl8723ae_phy_set_bw_mode_callback(struct ieee80211_hw *hw)
|
void rtl8723ae_phy_set_bw_mode_callback(struct ieee80211_hw *hw)
|
||||||
{
|
{
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
@ -1117,26 +874,26 @@ static bool _phy_sw_chnl_step_by_step(struct ieee80211_hw *hw, u8 channel,
|
|||||||
u8 num_total_rfpath = rtlphy->num_total_rfpath;
|
u8 num_total_rfpath = rtlphy->num_total_rfpath;
|
||||||
|
|
||||||
precommoncmdcnt = 0;
|
precommoncmdcnt = 0;
|
||||||
_phy_set_sw_chnl_cmdarray(precommoncmd, precommoncmdcnt++,
|
rtl8723_phy_set_sw_chnl_cmdarray(precommoncmd, precommoncmdcnt++,
|
||||||
MAX_PRECMD_CNT, CMDID_SET_TXPOWEROWER_LEVEL,
|
MAX_PRECMD_CNT, CMDID_SET_TXPOWEROWER_LEVEL,
|
||||||
0, 0, 0);
|
0, 0, 0);
|
||||||
_phy_set_sw_chnl_cmdarray(precommoncmd, precommoncmdcnt++,
|
rtl8723_phy_set_sw_chnl_cmdarray(precommoncmd, precommoncmdcnt++,
|
||||||
MAX_PRECMD_CNT, CMDID_END, 0, 0, 0);
|
MAX_PRECMD_CNT, CMDID_END, 0, 0, 0);
|
||||||
postcommoncmdcnt = 0;
|
postcommoncmdcnt = 0;
|
||||||
|
|
||||||
_phy_set_sw_chnl_cmdarray(postcommoncmd, postcommoncmdcnt++,
|
rtl8723_phy_set_sw_chnl_cmdarray(postcommoncmd, postcommoncmdcnt++,
|
||||||
MAX_POSTCMD_CNT, CMDID_END, 0, 0, 0);
|
MAX_POSTCMD_CNT, CMDID_END, 0, 0, 0);
|
||||||
rfdependcmdcnt = 0;
|
rfdependcmdcnt = 0;
|
||||||
|
|
||||||
RT_ASSERT((channel >= 1 && channel <= 14),
|
RT_ASSERT((channel >= 1 && channel <= 14),
|
||||||
"illegal channel for Zebra: %d\n", channel);
|
"illegal channel for Zebra: %d\n", channel);
|
||||||
|
|
||||||
_phy_set_sw_chnl_cmdarray(rfdependcmd, rfdependcmdcnt++,
|
rtl8723_phy_set_sw_chnl_cmdarray(rfdependcmd, rfdependcmdcnt++,
|
||||||
MAX_RFDEPENDCMD_CNT, CMDID_RF_WRITEREG,
|
MAX_RFDEPENDCMD_CNT, CMDID_RF_WRITEREG,
|
||||||
RF_CHNLBW, channel, 10);
|
RF_CHNLBW, channel, 10);
|
||||||
|
|
||||||
_phy_set_sw_chnl_cmdarray(rfdependcmd, rfdependcmdcnt++,
|
rtl8723_phy_set_sw_chnl_cmdarray(rfdependcmd, rfdependcmdcnt++,
|
||||||
MAX_RFDEPENDCMD_CNT, CMDID_END, 0, 0, 0);
|
MAX_RFDEPENDCMD_CNT, CMDID_END, 0, 0, 0);
|
||||||
|
|
||||||
do {
|
do {
|
||||||
switch (*stage) {
|
switch (*stage) {
|
||||||
@ -1204,29 +961,6 @@ static bool _phy_sw_chnl_step_by_step(struct ieee80211_hw *hw, u8 channel,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool _phy_set_sw_chnl_cmdarray(struct swchnlcmd *cmdtable,
|
|
||||||
u32 cmdtableidx, u32 cmdtablesz,
|
|
||||||
enum swchnlcmd_id cmdid, u32 para1,
|
|
||||||
u32 para2, u32 msdelay)
|
|
||||||
{
|
|
||||||
struct swchnlcmd *pcmd;
|
|
||||||
|
|
||||||
if (cmdtable == NULL) {
|
|
||||||
RT_ASSERT(false, "cmdtable cannot be NULL.\n");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cmdtableidx >= cmdtablesz)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
pcmd = cmdtable + cmdtableidx;
|
|
||||||
pcmd->cmdid = cmdid;
|
|
||||||
pcmd->para1 = para1;
|
|
||||||
pcmd->para2 = para2;
|
|
||||||
pcmd->msdelay = msdelay;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
static u8 _rtl8723ae_phy_path_a_iqk(struct ieee80211_hw *hw, bool config_pathb)
|
static u8 _rtl8723ae_phy_path_a_iqk(struct ieee80211_hw *hw, bool config_pathb)
|
||||||
{
|
{
|
||||||
u32 reg_eac, reg_e94, reg_e9c, reg_ea4;
|
u32 reg_eac, reg_e94, reg_e9c, reg_ea4;
|
||||||
@ -1297,136 +1031,6 @@ static u8 _rtl8723ae_phy_path_b_iqk(struct ieee80211_hw *hw)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void phy_path_a_fill_iqk_matrix(struct ieee80211_hw *hw, bool iqk_ok,
|
|
||||||
long result[][8], u8 final_candidate,
|
|
||||||
bool btxonly)
|
|
||||||
{
|
|
||||||
u32 oldval_0, x, tx0_a, reg;
|
|
||||||
long y, tx0_c;
|
|
||||||
|
|
||||||
if (final_candidate == 0xFF) {
|
|
||||||
return;
|
|
||||||
} else if (iqk_ok) {
|
|
||||||
oldval_0 = (rtl_get_bbreg(hw, ROFDM0_XATXIQIMBALANCE,
|
|
||||||
MASKDWORD) >> 22) & 0x3FF;
|
|
||||||
x = result[final_candidate][0];
|
|
||||||
if ((x & 0x00000200) != 0)
|
|
||||||
x = x | 0xFFFFFC00;
|
|
||||||
tx0_a = (x * oldval_0) >> 8;
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, 0x3FF, tx0_a);
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(31),
|
|
||||||
((x * oldval_0 >> 7) & 0x1));
|
|
||||||
y = result[final_candidate][1];
|
|
||||||
if ((y & 0x00000200) != 0)
|
|
||||||
y = y | 0xFFFFFC00;
|
|
||||||
tx0_c = (y * oldval_0) >> 8;
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_XCTXAFE, 0xF0000000,
|
|
||||||
((tx0_c & 0x3C0) >> 6));
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, 0x003F0000,
|
|
||||||
(tx0_c & 0x3F));
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(29),
|
|
||||||
((y * oldval_0 >> 7) & 0x1));
|
|
||||||
if (btxonly)
|
|
||||||
return;
|
|
||||||
reg = result[final_candidate][2];
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, 0x3FF, reg);
|
|
||||||
reg = result[final_candidate][3] & 0x3F;
|
|
||||||
rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, 0xFC00, reg);
|
|
||||||
reg = (result[final_candidate][3] >> 6) & 0xF;
|
|
||||||
rtl_set_bbreg(hw, 0xca0, 0xF0000000, reg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void phy_save_adda_regs(struct ieee80211_hw *hw,
|
|
||||||
u32 *addareg, u32 *addabackup,
|
|
||||||
u32 registernum)
|
|
||||||
{
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
for (i = 0; i < registernum; i++)
|
|
||||||
addabackup[i] = rtl_get_bbreg(hw, addareg[i], MASKDWORD);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void phy_save_mac_regs(struct ieee80211_hw *hw, u32 *macreg,
|
|
||||||
u32 *macbackup)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
|
|
||||||
macbackup[i] = rtl_read_byte(rtlpriv, macreg[i]);
|
|
||||||
macbackup[i] = rtl_read_dword(rtlpriv, macreg[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void phy_reload_adda_regs(struct ieee80211_hw *hw, u32 *addareg,
|
|
||||||
u32 *addabackup, u32 regiesternum)
|
|
||||||
{
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
for (i = 0; i < regiesternum; i++)
|
|
||||||
rtl_set_bbreg(hw, addareg[i], MASKDWORD, addabackup[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void phy_reload_mac_regs(struct ieee80211_hw *hw, u32 *macreg,
|
|
||||||
u32 *macbackup)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
|
|
||||||
rtl_write_byte(rtlpriv, macreg[i], (u8) macbackup[i]);
|
|
||||||
rtl_write_dword(rtlpriv, macreg[i], macbackup[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _rtl8723ae_phy_path_adda_on(struct ieee80211_hw *hw,
|
|
||||||
u32 *addareg, bool is_patha_on,
|
|
||||||
bool is2t)
|
|
||||||
{
|
|
||||||
u32 pathOn;
|
|
||||||
u32 i;
|
|
||||||
|
|
||||||
pathOn = is_patha_on ? 0x04db25a4 : 0x0b1b25a4;
|
|
||||||
if (false == is2t) {
|
|
||||||
pathOn = 0x0bdb25a0;
|
|
||||||
rtl_set_bbreg(hw, addareg[0], MASKDWORD, 0x0b1b25a0);
|
|
||||||
} else {
|
|
||||||
rtl_set_bbreg(hw, addareg[0], MASKDWORD, pathOn);
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 1; i < IQK_ADDA_REG_NUM; i++)
|
|
||||||
rtl_set_bbreg(hw, addareg[i], MASKDWORD, pathOn);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _rtl8723ae_phy_mac_setting_calibration(struct ieee80211_hw *hw,
|
|
||||||
u32 *macreg, u32 *macbackup)
|
|
||||||
{
|
|
||||||
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
|
||||||
u32 i = 0;
|
|
||||||
|
|
||||||
rtl_write_byte(rtlpriv, macreg[i], 0x3F);
|
|
||||||
|
|
||||||
for (i = 1; i < (IQK_MAC_REG_NUM - 1); i++)
|
|
||||||
rtl_write_byte(rtlpriv, macreg[i],
|
|
||||||
(u8) (macbackup[i] & (~BIT(3))));
|
|
||||||
rtl_write_byte(rtlpriv, macreg[i], (u8) (macbackup[i] & (~BIT(5))));
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _rtl8723ae_phy_path_a_standby(struct ieee80211_hw *hw)
|
|
||||||
{
|
|
||||||
rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x0);
|
|
||||||
rtl_set_bbreg(hw, 0x840, MASKDWORD, 0x00010000);
|
|
||||||
rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x80800000);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _rtl8723ae_phy_pi_mode_switch(struct ieee80211_hw *hw, bool pi_mode)
|
|
||||||
{
|
|
||||||
u32 mode;
|
|
||||||
|
|
||||||
mode = pi_mode ? 0x01000100 : 0x01000000;
|
|
||||||
rtl_set_bbreg(hw, 0x820, MASKDWORD, mode);
|
|
||||||
rtl_set_bbreg(hw, 0x828, MASKDWORD, mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
static bool phy_simularity_comp(struct ieee80211_hw *hw, long result[][8],
|
static bool phy_simularity_comp(struct ieee80211_hw *hw, long result[][8],
|
||||||
u8 c1, u8 c2)
|
u8 c1, u8 c2)
|
||||||
{
|
{
|
||||||
@ -1498,10 +1102,12 @@ static void _rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw,
|
|||||||
const u32 retrycount = 2;
|
const u32 retrycount = 2;
|
||||||
|
|
||||||
if (t == 0) {
|
if (t == 0) {
|
||||||
phy_save_adda_regs(hw, adda_reg, rtlphy->adda_backup, 16);
|
rtl8723_save_adda_registers(hw, adda_reg, rtlphy->adda_backup,
|
||||||
phy_save_mac_regs(hw, iqk_mac_reg, rtlphy->iqk_mac_backup);
|
16);
|
||||||
|
rtl8723_phy_save_mac_registers(hw, iqk_mac_reg,
|
||||||
|
rtlphy->iqk_mac_backup);
|
||||||
}
|
}
|
||||||
_rtl8723ae_phy_path_adda_on(hw, adda_reg, true, is2t);
|
rtl8723_phy_path_adda_on(hw, adda_reg, true, is2t);
|
||||||
if (t == 0) {
|
if (t == 0) {
|
||||||
rtlphy->rfpi_enable = (u8) rtl_get_bbreg(hw,
|
rtlphy->rfpi_enable = (u8) rtl_get_bbreg(hw,
|
||||||
RFPGA0_XA_HSSIPARAMETER1,
|
RFPGA0_XA_HSSIPARAMETER1,
|
||||||
@ -1509,7 +1115,7 @@ static void _rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!rtlphy->rfpi_enable)
|
if (!rtlphy->rfpi_enable)
|
||||||
_rtl8723ae_phy_pi_mode_switch(hw, true);
|
rtl8723_phy_pi_mode_switch(hw, true);
|
||||||
if (t == 0) {
|
if (t == 0) {
|
||||||
rtlphy->reg_c04 = rtl_get_bbreg(hw, 0xc04, MASKDWORD);
|
rtlphy->reg_c04 = rtl_get_bbreg(hw, 0xc04, MASKDWORD);
|
||||||
rtlphy->reg_c08 = rtl_get_bbreg(hw, 0xc08, MASKDWORD);
|
rtlphy->reg_c08 = rtl_get_bbreg(hw, 0xc08, MASKDWORD);
|
||||||
@ -1522,7 +1128,7 @@ static void _rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw,
|
|||||||
rtl_set_bbreg(hw, 0x840, MASKDWORD, 0x00010000);
|
rtl_set_bbreg(hw, 0x840, MASKDWORD, 0x00010000);
|
||||||
rtl_set_bbreg(hw, 0x844, MASKDWORD, 0x00010000);
|
rtl_set_bbreg(hw, 0x844, MASKDWORD, 0x00010000);
|
||||||
}
|
}
|
||||||
_rtl8723ae_phy_mac_setting_calibration(hw, iqk_mac_reg,
|
rtl8723_phy_mac_setting_calibration(hw, iqk_mac_reg,
|
||||||
rtlphy->iqk_mac_backup);
|
rtlphy->iqk_mac_backup);
|
||||||
rtl_set_bbreg(hw, 0xb68, MASKDWORD, 0x00080000);
|
rtl_set_bbreg(hw, 0xb68, MASKDWORD, 0x00080000);
|
||||||
if (is2t)
|
if (is2t)
|
||||||
@ -1552,8 +1158,8 @@ static void _rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (is2t) {
|
if (is2t) {
|
||||||
_rtl8723ae_phy_path_a_standby(hw);
|
rtl8723_phy_path_a_standby(hw);
|
||||||
_rtl8723ae_phy_path_adda_on(hw, adda_reg, false, is2t);
|
rtl8723_phy_path_adda_on(hw, adda_reg, false, is2t);
|
||||||
for (i = 0; i < retrycount; i++) {
|
for (i = 0; i < retrycount; i++) {
|
||||||
pathb_ok = _rtl8723ae_phy_path_b_iqk(hw);
|
pathb_ok = _rtl8723ae_phy_path_b_iqk(hw);
|
||||||
if (pathb_ok == 0x03) {
|
if (pathb_ok == 0x03) {
|
||||||
@ -1588,9 +1194,11 @@ static void _rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw,
|
|||||||
rtl_set_bbreg(hw, 0x844, MASKDWORD, 0x00032ed3);
|
rtl_set_bbreg(hw, 0x844, MASKDWORD, 0x00032ed3);
|
||||||
if (t != 0) {
|
if (t != 0) {
|
||||||
if (!rtlphy->rfpi_enable)
|
if (!rtlphy->rfpi_enable)
|
||||||
_rtl8723ae_phy_pi_mode_switch(hw, false);
|
rtl8723_phy_pi_mode_switch(hw, false);
|
||||||
phy_reload_adda_regs(hw, adda_reg, rtlphy->adda_backup, 16);
|
rtl8723_phy_reload_adda_registers(hw, adda_reg,
|
||||||
phy_reload_mac_regs(hw, iqk_mac_reg, rtlphy->iqk_mac_backup);
|
rtlphy->adda_backup, 16);
|
||||||
|
rtl8723_phy_reload_mac_registers(hw, iqk_mac_reg,
|
||||||
|
rtlphy->iqk_mac_backup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1691,7 +1299,8 @@ void rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw, bool recovery)
|
|||||||
};
|
};
|
||||||
|
|
||||||
if (recovery) {
|
if (recovery) {
|
||||||
phy_reload_adda_regs(hw, iqk_bb_reg, rtlphy->iqk_bb_backup, 10);
|
rtl8723_phy_reload_adda_registers(hw, iqk_bb_reg,
|
||||||
|
rtlphy->iqk_bb_backup, 10);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (start_conttx || singletone)
|
if (start_conttx || singletone)
|
||||||
@ -1756,9 +1365,10 @@ void rtl8723ae_phy_iq_calibrate(struct ieee80211_hw *hw, bool recovery)
|
|||||||
rtlphy->reg_e9c = rtlphy->reg_ebc = 0x0;
|
rtlphy->reg_e9c = rtlphy->reg_ebc = 0x0;
|
||||||
}
|
}
|
||||||
if (reg_e94 != 0) /*&&(reg_ea4 != 0) */
|
if (reg_e94 != 0) /*&&(reg_ea4 != 0) */
|
||||||
phy_path_a_fill_iqk_matrix(hw, patha_ok, result,
|
rtl8723_phy_path_a_fill_iqk_matrix(hw, patha_ok, result,
|
||||||
final_candidate, (reg_ea4 == 0));
|
final_candidate,
|
||||||
phy_save_adda_regs(hw, iqk_bb_reg, rtlphy->iqk_bb_backup, 10);
|
(reg_ea4 == 0));
|
||||||
|
rtl8723_save_adda_registers(hw, iqk_bb_reg, rtlphy->iqk_bb_backup, 10);
|
||||||
}
|
}
|
||||||
|
|
||||||
void rtl8723ae_phy_lc_calibrate(struct ieee80211_hw *hw)
|
void rtl8723ae_phy_lc_calibrate(struct ieee80211_hw *hw)
|
||||||
|
@ -76,23 +76,6 @@
|
|||||||
|
|
||||||
#define RTL92C_MAX_PATH_NUM 2
|
#define RTL92C_MAX_PATH_NUM 2
|
||||||
|
|
||||||
enum swchnlcmd_id {
|
|
||||||
CMDID_END,
|
|
||||||
CMDID_SET_TXPOWEROWER_LEVEL,
|
|
||||||
CMDID_BBREGWRITE10,
|
|
||||||
CMDID_WRITEPORT_ULONG,
|
|
||||||
CMDID_WRITEPORT_USHORT,
|
|
||||||
CMDID_WRITEPORT_UCHAR,
|
|
||||||
CMDID_RF_WRITEREG,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct swchnlcmd {
|
|
||||||
enum swchnlcmd_id cmdid;
|
|
||||||
u32 para1;
|
|
||||||
u32 para2;
|
|
||||||
u32 msdelay;
|
|
||||||
};
|
|
||||||
|
|
||||||
enum hw90_block_e {
|
enum hw90_block_e {
|
||||||
HW90_BLOCK_MAC = 0,
|
HW90_BLOCK_MAC = 0,
|
||||||
HW90_BLOCK_PHY0 = 1,
|
HW90_BLOCK_PHY0 = 1,
|
||||||
@ -183,10 +166,6 @@ struct tx_power_struct {
|
|||||||
u32 mcs_original_offset[4][16];
|
u32 mcs_original_offset[4][16];
|
||||||
};
|
};
|
||||||
|
|
||||||
u32 rtl8723ae_phy_query_bb_reg(struct ieee80211_hw *hw,
|
|
||||||
u32 regaddr, u32 bitmask);
|
|
||||||
void rtl8723ae_phy_set_bb_reg(struct ieee80211_hw *hw,
|
|
||||||
u32 regaddr, u32 bitmask, u32 data);
|
|
||||||
u32 rtl8723ae_phy_query_rf_reg(struct ieee80211_hw *hw,
|
u32 rtl8723ae_phy_query_rf_reg(struct ieee80211_hw *hw,
|
||||||
enum radio_path rfpath, u32 regaddr,
|
enum radio_path rfpath, u32 regaddr,
|
||||||
u32 bitmask);
|
u32 bitmask);
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include "reg.h"
|
#include "reg.h"
|
||||||
#include "def.h"
|
#include "def.h"
|
||||||
#include "phy.h"
|
#include "phy.h"
|
||||||
|
#include "../rtl8723com/phy_common.h"
|
||||||
#include "dm.h"
|
#include "dm.h"
|
||||||
#include "hw.h"
|
#include "hw.h"
|
||||||
#include "sw.h"
|
#include "sw.h"
|
||||||
@ -231,8 +232,8 @@ static struct rtl_hal_ops rtl8723ae_hal_ops = {
|
|||||||
.set_key = rtl8723ae_set_key,
|
.set_key = rtl8723ae_set_key,
|
||||||
.init_sw_leds = rtl8723ae_init_sw_leds,
|
.init_sw_leds = rtl8723ae_init_sw_leds,
|
||||||
.allow_all_destaddr = rtl8723ae_allow_all_destaddr,
|
.allow_all_destaddr = rtl8723ae_allow_all_destaddr,
|
||||||
.get_bbreg = rtl8723ae_phy_query_bb_reg,
|
.get_bbreg = rtl8723_phy_query_bb_reg,
|
||||||
.set_bbreg = rtl8723ae_phy_set_bb_reg,
|
.set_bbreg = rtl8723_phy_set_bb_reg,
|
||||||
.get_rfreg = rtl8723ae_phy_query_rf_reg,
|
.get_rfreg = rtl8723ae_phy_query_rf_reg,
|
||||||
.set_rfreg = rtl8723ae_phy_set_rf_reg,
|
.set_rfreg = rtl8723ae_phy_set_rf_reg,
|
||||||
.c2h_command_handle = rtl_8723e_c2h_command_handle,
|
.c2h_command_handle = rtl_8723e_c2h_command_handle,
|
||||||
|
7
drivers/net/wireless/rtlwifi/rtl8723com/Makefile
Normal file
7
drivers/net/wireless/rtlwifi/rtl8723com/Makefile
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
rtl8723-common-objs := \
|
||||||
|
main.o \
|
||||||
|
phy_common.o
|
||||||
|
|
||||||
|
obj-$(CONFIG_RTL8723_COMMON) += rtl8723-common.o
|
||||||
|
|
||||||
|
ccflags-y += -D__CHECK_ENDIAN__
|
33
drivers/net/wireless/rtlwifi/rtl8723com/main.c
Normal file
33
drivers/net/wireless/rtlwifi/rtl8723com/main.c
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2009-2014 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>
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#include "../wifi.h"
|
||||||
|
#include <linux/module.h>
|
||||||
|
|
||||||
|
|
||||||
|
MODULE_AUTHOR("Realtek WlanFAE <wlanfae@realtek.com>");
|
||||||
|
MODULE_AUTHOR("Larry Finger <Larry.Finger@lwfinger.net>");
|
||||||
|
MODULE_LICENSE("GPL");
|
||||||
|
MODULE_DESCRIPTION("Realtek RTL8723AE/RTL8723BE 802.11n PCI wireless common routines");
|
434
drivers/net/wireless/rtlwifi/rtl8723com/phy_common.c
Normal file
434
drivers/net/wireless/rtlwifi/rtl8723com/phy_common.c
Normal file
@ -0,0 +1,434 @@
|
|||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2009-2014 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>
|
||||||
|
*
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#include "../wifi.h"
|
||||||
|
#include "phy_common.h"
|
||||||
|
#include "../rtl8723ae/reg.h"
|
||||||
|
#include <linux/module.h>
|
||||||
|
|
||||||
|
/* These routines are common to RTL8723AE and RTL8723bE */
|
||||||
|
|
||||||
|
u32 rtl8723_phy_query_bb_reg(struct ieee80211_hw *hw,
|
||||||
|
u32 regaddr, u32 bitmask)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
u32 returnvalue, originalvalue, bitshift;
|
||||||
|
|
||||||
|
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
||||||
|
"regaddr(%#x), bitmask(%#x)\n", regaddr, bitmask);
|
||||||
|
originalvalue = rtl_read_dword(rtlpriv, regaddr);
|
||||||
|
bitshift = rtl8723_phy_calculate_bit_shift(bitmask);
|
||||||
|
returnvalue = (originalvalue & bitmask) >> bitshift;
|
||||||
|
|
||||||
|
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
||||||
|
"BBR MASK = 0x%x Addr[0x%x]= 0x%x\n",
|
||||||
|
bitmask, regaddr, originalvalue);
|
||||||
|
|
||||||
|
return returnvalue;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_query_bb_reg);
|
||||||
|
|
||||||
|
void rtl8723_phy_set_bb_reg(struct ieee80211_hw *hw, u32 regaddr,
|
||||||
|
u32 bitmask, u32 data)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
u32 originalvalue, bitshift;
|
||||||
|
|
||||||
|
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
||||||
|
"regaddr(%#x), bitmask(%#x), data(%#x)\n",
|
||||||
|
regaddr, bitmask, data);
|
||||||
|
|
||||||
|
if (bitmask != MASKDWORD) {
|
||||||
|
originalvalue = rtl_read_dword(rtlpriv, regaddr);
|
||||||
|
bitshift = rtl8723_phy_calculate_bit_shift(bitmask);
|
||||||
|
data = ((originalvalue & (~bitmask)) | (data << bitshift));
|
||||||
|
}
|
||||||
|
|
||||||
|
rtl_write_dword(rtlpriv, regaddr, data);
|
||||||
|
|
||||||
|
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
||||||
|
"regaddr(%#x), bitmask(%#x), data(%#x)\n",
|
||||||
|
regaddr, bitmask, data);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_set_bb_reg);
|
||||||
|
|
||||||
|
u32 rtl8723_phy_calculate_bit_shift(u32 bitmask)
|
||||||
|
{
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
for (i = 0; i <= 31; i++) {
|
||||||
|
if (((bitmask >> i) & 0x1) == 1)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_calculate_bit_shift);
|
||||||
|
|
||||||
|
u32 rtl8723_phy_rf_serial_read(struct ieee80211_hw *hw,
|
||||||
|
enum radio_path rfpath, u32 offset)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
struct rtl_phy *rtlphy = &(rtlpriv->phy);
|
||||||
|
struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
|
||||||
|
u32 newoffset;
|
||||||
|
u32 tmplong, tmplong2;
|
||||||
|
u8 rfpi_enable = 0;
|
||||||
|
u32 retvalue;
|
||||||
|
|
||||||
|
offset &= 0xff;
|
||||||
|
newoffset = offset;
|
||||||
|
if (RT_CANNOT_IO(hw)) {
|
||||||
|
RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "return all one\n");
|
||||||
|
return 0xFFFFFFFF;
|
||||||
|
}
|
||||||
|
tmplong = rtl_get_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD);
|
||||||
|
if (rfpath == RF90_PATH_A)
|
||||||
|
tmplong2 = tmplong;
|
||||||
|
else
|
||||||
|
tmplong2 = rtl_get_bbreg(hw, pphyreg->rfhssi_para2, MASKDWORD);
|
||||||
|
tmplong2 = (tmplong2 & (~BLSSIREADADDRESS)) |
|
||||||
|
(newoffset << 23) | BLSSIREADEDGE;
|
||||||
|
rtl_set_bbreg(hw, RFPGA0_XA_HSSIPARAMETER2, MASKDWORD,
|
||||||
|
tmplong & (~BLSSIREADEDGE));
|
||||||
|
mdelay(1);
|
||||||
|
rtl_set_bbreg(hw, pphyreg->rfhssi_para2, MASKDWORD, tmplong2);
|
||||||
|
mdelay(2);
|
||||||
|
if (rfpath == RF90_PATH_A)
|
||||||
|
rfpi_enable = (u8) rtl_get_bbreg(hw, RFPGA0_XA_HSSIPARAMETER1,
|
||||||
|
BIT(8));
|
||||||
|
else if (rfpath == RF90_PATH_B)
|
||||||
|
rfpi_enable = (u8) rtl_get_bbreg(hw, RFPGA0_XB_HSSIPARAMETER1,
|
||||||
|
BIT(8));
|
||||||
|
if (rfpi_enable)
|
||||||
|
retvalue = rtl_get_bbreg(hw, pphyreg->rf_rbpi,
|
||||||
|
BLSSIREADBACKDATA);
|
||||||
|
else
|
||||||
|
retvalue = rtl_get_bbreg(hw, pphyreg->rf_rb,
|
||||||
|
BLSSIREADBACKDATA);
|
||||||
|
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
||||||
|
"RFR-%d Addr[0x%x]= 0x%x\n",
|
||||||
|
rfpath, pphyreg->rf_rb, retvalue);
|
||||||
|
return retvalue;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_rf_serial_read);
|
||||||
|
|
||||||
|
void rtl8723_phy_rf_serial_write(struct ieee80211_hw *hw,
|
||||||
|
enum radio_path rfpath,
|
||||||
|
u32 offset, u32 data)
|
||||||
|
{
|
||||||
|
u32 data_and_addr;
|
||||||
|
u32 newoffset;
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
struct rtl_phy *rtlphy = &(rtlpriv->phy);
|
||||||
|
struct bb_reg_def *pphyreg = &rtlphy->phyreg_def[rfpath];
|
||||||
|
|
||||||
|
if (RT_CANNOT_IO(hw)) {
|
||||||
|
RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG, "stop\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
offset &= 0xff;
|
||||||
|
newoffset = offset;
|
||||||
|
data_and_addr = ((newoffset << 20) | (data & 0x000fffff)) & 0x0fffffff;
|
||||||
|
rtl_set_bbreg(hw, pphyreg->rf3wire_offset, MASKDWORD, data_and_addr);
|
||||||
|
RT_TRACE(rtlpriv, COMP_RF, DBG_TRACE,
|
||||||
|
"RFW-%d Addr[0x%x]= 0x%x\n", rfpath,
|
||||||
|
pphyreg->rf3wire_offset, data_and_addr);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_rf_serial_write);
|
||||||
|
|
||||||
|
long rtl8723_phy_txpwr_idx_to_dbm(struct ieee80211_hw *hw,
|
||||||
|
enum wireless_mode wirelessmode,
|
||||||
|
u8 txpwridx)
|
||||||
|
{
|
||||||
|
long offset;
|
||||||
|
long pwrout_dbm;
|
||||||
|
|
||||||
|
switch (wirelessmode) {
|
||||||
|
case WIRELESS_MODE_B:
|
||||||
|
offset = -7;
|
||||||
|
break;
|
||||||
|
case WIRELESS_MODE_G:
|
||||||
|
case WIRELESS_MODE_N_24G:
|
||||||
|
default:
|
||||||
|
offset = -8;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pwrout_dbm = txpwridx / 2 + offset;
|
||||||
|
return pwrout_dbm;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_txpwr_idx_to_dbm);
|
||||||
|
|
||||||
|
void rtl8723_phy_init_bb_rf_reg_def(struct ieee80211_hw *hw)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
struct rtl_phy *rtlphy = &(rtlpriv->phy);
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfintfs = RFPGA0_XAB_RFINTERFACESW;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfintfs = RFPGA0_XAB_RFINTERFACESW;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfintfs = RFPGA0_XCD_RFINTERFACESW;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfintfs = RFPGA0_XCD_RFINTERFACESW;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfintfi = RFPGA0_XAB_RFINTERFACERB;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfintfi = RFPGA0_XAB_RFINTERFACERB;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfintfi = RFPGA0_XCD_RFINTERFACERB;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfintfi = RFPGA0_XCD_RFINTERFACERB;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfintfo = RFPGA0_XA_RFINTERFACEOE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfintfo = RFPGA0_XB_RFINTERFACEOE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfintfe = RFPGA0_XA_RFINTERFACEOE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfintfe = RFPGA0_XB_RFINTERFACEOE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rf3wire_offset =
|
||||||
|
RFPGA0_XA_LSSIPARAMETER;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rf3wire_offset =
|
||||||
|
RFPGA0_XB_LSSIPARAMETER;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rflssi_select = rFPGA0_XAB_RFPARAMETER;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rflssi_select = rFPGA0_XAB_RFPARAMETER;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rflssi_select = rFPGA0_XCD_RFPARAMETER;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rflssi_select = rFPGA0_XCD_RFPARAMETER;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rftxgain_stage = RFPGA0_TXGAINSTAGE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfhssi_para1 = RFPGA0_XA_HSSIPARAMETER1;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfhssi_para1 = RFPGA0_XB_HSSIPARAMETER1;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfhssi_para2 = RFPGA0_XA_HSSIPARAMETER2;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfhssi_para2 = RFPGA0_XB_HSSIPARAMETER2;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfsw_ctrl = RFPGA0_XAB_SWITCHCONTROL;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfsw_ctrl = RFPGA0_XAB_SWITCHCONTROL;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfsw_ctrl = RFPGA0_XCD_SWITCHCONTROL;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfsw_ctrl = RFPGA0_XCD_SWITCHCONTROL;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfagc_control1 = ROFDM0_XAAGCCORE1;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfagc_control1 = ROFDM0_XBAGCCORE1;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfagc_control1 = ROFDM0_XCAGCCORE1;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfagc_control1 = ROFDM0_XDAGCCORE1;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfagc_control2 = ROFDM0_XAAGCCORE2;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfagc_control2 = ROFDM0_XBAGCCORE2;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfagc_control2 = ROFDM0_XCAGCCORE2;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfagc_control2 = ROFDM0_XDAGCCORE2;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfrxiq_imbal = ROFDM0_XARXIQIMBALANCE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfrxiq_imbal = ROFDM0_XBRXIQIMBALANCE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfrxiq_imbal = ROFDM0_XCRXIQIMBANLANCE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfrxiq_imbal = ROFDM0_XDRXIQIMBALANCE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rfrx_afe = ROFDM0_XARXAFE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rfrx_afe = ROFDM0_XBRXAFE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rfrx_afe = ROFDM0_XCRXAFE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rfrx_afe = ROFDM0_XDRXAFE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rftxiq_imbal = ROFDM0_XATXIQIMBALANCE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rftxiq_imbal = ROFDM0_XBTXIQIMBALANCE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rftxiq_imbal = ROFDM0_XCTXIQIMBALANCE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rftxiq_imbal = ROFDM0_XDTXIQIMBALANCE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rftx_afe = ROFDM0_XATXAFE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rftx_afe = ROFDM0_XBTXAFE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rftx_afe = ROFDM0_XCTXAFE;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rftx_afe = ROFDM0_XDTXAFE;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rf_rb = RFPGA0_XA_LSSIREADBACK;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rf_rb = RFPGA0_XB_LSSIREADBACK;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_C].rf_rb = RFPGA0_XC_LSSIREADBACK;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_D].rf_rb = RFPGA0_XD_LSSIREADBACK;
|
||||||
|
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_A].rf_rbpi = TRANSCEIVEA_HSPI_READBACK;
|
||||||
|
rtlphy->phyreg_def[RF90_PATH_B].rf_rbpi = TRANSCEIVEB_HSPI_READBACK;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_init_bb_rf_reg_def);
|
||||||
|
|
||||||
|
bool rtl8723_phy_set_sw_chnl_cmdarray(struct swchnlcmd *cmdtable,
|
||||||
|
u32 cmdtableidx,
|
||||||
|
u32 cmdtablesz,
|
||||||
|
enum swchnlcmd_id cmdid,
|
||||||
|
u32 para1, u32 para2,
|
||||||
|
u32 msdelay)
|
||||||
|
{
|
||||||
|
struct swchnlcmd *pcmd;
|
||||||
|
|
||||||
|
if (cmdtable == NULL) {
|
||||||
|
RT_ASSERT(false, "cmdtable cannot be NULL.\n");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cmdtableidx >= cmdtablesz)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
pcmd = cmdtable + cmdtableidx;
|
||||||
|
pcmd->cmdid = cmdid;
|
||||||
|
pcmd->para1 = para1;
|
||||||
|
pcmd->para2 = para2;
|
||||||
|
pcmd->msdelay = msdelay;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_set_sw_chnl_cmdarray);
|
||||||
|
|
||||||
|
void rtl8723_phy_path_a_fill_iqk_matrix(struct ieee80211_hw *hw,
|
||||||
|
bool iqk_ok,
|
||||||
|
long result[][8],
|
||||||
|
u8 final_candidate,
|
||||||
|
bool btxonly)
|
||||||
|
{
|
||||||
|
u32 oldval_0, x, tx0_a, reg;
|
||||||
|
long y, tx0_c;
|
||||||
|
|
||||||
|
if (final_candidate == 0xFF) {
|
||||||
|
return;
|
||||||
|
} else if (iqk_ok) {
|
||||||
|
oldval_0 = (rtl_get_bbreg(hw, ROFDM0_XATXIQIMBALANCE,
|
||||||
|
MASKDWORD) >> 22) & 0x3FF;
|
||||||
|
x = result[final_candidate][0];
|
||||||
|
if ((x & 0x00000200) != 0)
|
||||||
|
x = x | 0xFFFFFC00;
|
||||||
|
tx0_a = (x * oldval_0) >> 8;
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, 0x3FF, tx0_a);
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(31),
|
||||||
|
((x * oldval_0 >> 7) & 0x1));
|
||||||
|
y = result[final_candidate][1];
|
||||||
|
if ((y & 0x00000200) != 0)
|
||||||
|
y = y | 0xFFFFFC00;
|
||||||
|
tx0_c = (y * oldval_0) >> 8;
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_XCTXAFE, 0xF0000000,
|
||||||
|
((tx0_c & 0x3C0) >> 6));
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_XATXIQIMBALANCE, 0x003F0000,
|
||||||
|
(tx0_c & 0x3F));
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_ECCATHRESHOLD, BIT(29),
|
||||||
|
((y * oldval_0 >> 7) & 0x1));
|
||||||
|
if (btxonly)
|
||||||
|
return;
|
||||||
|
reg = result[final_candidate][2];
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, 0x3FF, reg);
|
||||||
|
reg = result[final_candidate][3] & 0x3F;
|
||||||
|
rtl_set_bbreg(hw, ROFDM0_XARXIQIMBALANCE, 0xFC00, reg);
|
||||||
|
reg = (result[final_candidate][3] >> 6) & 0xF;
|
||||||
|
rtl_set_bbreg(hw, 0xca0, 0xF0000000, reg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_path_a_fill_iqk_matrix);
|
||||||
|
|
||||||
|
void rtl8723_save_adda_registers(struct ieee80211_hw *hw, u32 *addareg,
|
||||||
|
u32 *addabackup, u32 registernum)
|
||||||
|
{
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < registernum; i++)
|
||||||
|
addabackup[i] = rtl_get_bbreg(hw, addareg[i], MASKDWORD);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_save_adda_registers);
|
||||||
|
|
||||||
|
void rtl8723_phy_save_mac_registers(struct ieee80211_hw *hw,
|
||||||
|
u32 *macreg, u32 *macbackup)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
|
||||||
|
macbackup[i] = rtl_read_byte(rtlpriv, macreg[i]);
|
||||||
|
macbackup[i] = rtl_read_dword(rtlpriv, macreg[i]);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_save_mac_registers);
|
||||||
|
|
||||||
|
void rtl8723_phy_reload_adda_registers(struct ieee80211_hw *hw,
|
||||||
|
u32 *addareg, u32 *addabackup,
|
||||||
|
u32 regiesternum)
|
||||||
|
{
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < regiesternum; i++)
|
||||||
|
rtl_set_bbreg(hw, addareg[i], MASKDWORD, addabackup[i]);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_reload_adda_registers);
|
||||||
|
|
||||||
|
void rtl8723_phy_reload_mac_registers(struct ieee80211_hw *hw,
|
||||||
|
u32 *macreg, u32 *macbackup)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < (IQK_MAC_REG_NUM - 1); i++)
|
||||||
|
rtl_write_byte(rtlpriv, macreg[i], (u8) macbackup[i]);
|
||||||
|
rtl_write_dword(rtlpriv, macreg[i], macbackup[i]);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_reload_mac_registers);
|
||||||
|
|
||||||
|
void rtl8723_phy_path_adda_on(struct ieee80211_hw *hw, u32 *addareg,
|
||||||
|
bool is_patha_on, bool is2t)
|
||||||
|
{
|
||||||
|
u32 pathon;
|
||||||
|
u32 i;
|
||||||
|
|
||||||
|
pathon = is_patha_on ? 0x04db25a4 : 0x0b1b25a4;
|
||||||
|
if (!is2t) {
|
||||||
|
pathon = 0x0bdb25a0;
|
||||||
|
rtl_set_bbreg(hw, addareg[0], MASKDWORD, 0x0b1b25a0);
|
||||||
|
} else {
|
||||||
|
rtl_set_bbreg(hw, addareg[0], MASKDWORD, pathon);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 1; i < IQK_ADDA_REG_NUM; i++)
|
||||||
|
rtl_set_bbreg(hw, addareg[i], MASKDWORD, pathon);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_path_adda_on);
|
||||||
|
|
||||||
|
void rtl8723_phy_mac_setting_calibration(struct ieee80211_hw *hw,
|
||||||
|
u32 *macreg, u32 *macbackup)
|
||||||
|
{
|
||||||
|
struct rtl_priv *rtlpriv = rtl_priv(hw);
|
||||||
|
u32 i = 0;
|
||||||
|
|
||||||
|
rtl_write_byte(rtlpriv, macreg[i], 0x3F);
|
||||||
|
|
||||||
|
for (i = 1; i < (IQK_MAC_REG_NUM - 1); i++)
|
||||||
|
rtl_write_byte(rtlpriv, macreg[i],
|
||||||
|
(u8) (macbackup[i] & (~BIT(3))));
|
||||||
|
rtl_write_byte(rtlpriv, macreg[i], (u8) (macbackup[i] & (~BIT(5))));
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_mac_setting_calibration);
|
||||||
|
|
||||||
|
void rtl8723_phy_path_a_standby(struct ieee80211_hw *hw)
|
||||||
|
{
|
||||||
|
rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x0);
|
||||||
|
rtl_set_bbreg(hw, 0x840, MASKDWORD, 0x00010000);
|
||||||
|
rtl_set_bbreg(hw, 0xe28, MASKDWORD, 0x80800000);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_path_a_standby);
|
||||||
|
|
||||||
|
void rtl8723_phy_pi_mode_switch(struct ieee80211_hw *hw, bool pi_mode)
|
||||||
|
{
|
||||||
|
u32 mode;
|
||||||
|
|
||||||
|
mode = pi_mode ? 0x01000100 : 0x01000000;
|
||||||
|
rtl_set_bbreg(hw, 0x820, MASKDWORD, mode);
|
||||||
|
rtl_set_bbreg(hw, 0x828, MASKDWORD, mode);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(rtl8723_phy_pi_mode_switch);
|
@ -26,6 +26,25 @@
|
|||||||
#ifndef __PHY_COMMON__
|
#ifndef __PHY_COMMON__
|
||||||
#define __PHY_COMMON__
|
#define __PHY_COMMON__
|
||||||
|
|
||||||
|
#define RT_CANNOT_IO(hw) false
|
||||||
|
|
||||||
|
enum swchnlcmd_id {
|
||||||
|
CMDID_END,
|
||||||
|
CMDID_SET_TXPOWEROWER_LEVEL,
|
||||||
|
CMDID_BBREGWRITE10,
|
||||||
|
CMDID_WRITEPORT_ULONG,
|
||||||
|
CMDID_WRITEPORT_USHORT,
|
||||||
|
CMDID_WRITEPORT_UCHAR,
|
||||||
|
CMDID_RF_WRITEREG,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct swchnlcmd {
|
||||||
|
enum swchnlcmd_id cmdid;
|
||||||
|
u32 para1;
|
||||||
|
u32 para2;
|
||||||
|
u32 msdelay;
|
||||||
|
};
|
||||||
|
|
||||||
u32 rtl8723_phy_query_bb_reg(struct ieee80211_hw *hw,
|
u32 rtl8723_phy_query_bb_reg(struct ieee80211_hw *hw,
|
||||||
u32 regaddr, u32 bitmask);
|
u32 regaddr, u32 bitmask);
|
||||||
void rtl8723_phy_set_bb_reg(struct ieee80211_hw *hw, u32 regaddr,
|
void rtl8723_phy_set_bb_reg(struct ieee80211_hw *hw, u32 regaddr,
|
||||||
@ -36,11 +55,6 @@ u32 rtl8723_phy_rf_serial_read(struct ieee80211_hw *hw,
|
|||||||
void rtl8723_phy_rf_serial_write(struct ieee80211_hw *hw,
|
void rtl8723_phy_rf_serial_write(struct ieee80211_hw *hw,
|
||||||
enum radio_path rfpath,
|
enum radio_path rfpath,
|
||||||
u32 offset, u32 data);
|
u32 offset, u32 data);
|
||||||
u32 rtl8723_phy_query_bb_reg(struct ieee80211_hw *hw,
|
|
||||||
u32 regaddr, u32 bitmask);
|
|
||||||
u32 rtl8723_phy_calculate_bit_shift(u32 bitmask);
|
|
||||||
void rtl8723_phy_set_bb_reg(struct ieee80211_hw *hw, u32 regaddr,
|
|
||||||
u32 bitmask, u32 data);
|
|
||||||
long rtl8723_phy_txpwr_idx_to_dbm(struct ieee80211_hw *hw,
|
long rtl8723_phy_txpwr_idx_to_dbm(struct ieee80211_hw *hw,
|
||||||
enum wireless_mode wirelessmode,
|
enum wireless_mode wirelessmode,
|
||||||
u8 txpwridx);
|
u8 txpwridx);
|
||||||
@ -58,8 +72,8 @@ void rtl8723_phy_path_a_fill_iqk_matrix(struct ieee80211_hw *hw,
|
|||||||
bool btxonly);
|
bool btxonly);
|
||||||
void rtl8723_save_adda_registers(struct ieee80211_hw *hw, u32 *addareg,
|
void rtl8723_save_adda_registers(struct ieee80211_hw *hw, u32 *addareg,
|
||||||
u32 *addabackup, u32 registernum);
|
u32 *addabackup, u32 registernum);
|
||||||
static void rtl8723_phy_save_mac_registers(struct ieee80211_hw *hw,
|
void rtl8723_phy_save_mac_registers(struct ieee80211_hw *hw,
|
||||||
u32 *macreg, u32 *macbackup);
|
u32 *macreg, u32 *macbackup);
|
||||||
void rtl8723_phy_reload_adda_registers(struct ieee80211_hw *hw,
|
void rtl8723_phy_reload_adda_registers(struct ieee80211_hw *hw,
|
||||||
u32 *addareg, u32 *addabackup,
|
u32 *addareg, u32 *addabackup,
|
||||||
u32 regiesternum);
|
u32 regiesternum);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user