rtlwifi: cleanup 8723be ant_sel definition
Some HP laptops have only a single wifi antenna. This would not be a problem except that they were shipped with an incorrectly encoded EFUSE. It should have been possible to open the computer and transfer the antenna connection to the other terminal except that such action might void the warranty, and moving the antenna broke the Windows driver. The fix was to add a module option that would override the EFUSE encoding. That was done with commitc18d8f5095
("rtlwifi: rtl8723be: Add antenna select module parameter"). There was still a problem with Bluetooth coexistence, which was addressed with commitbaa1702290
("rtlwifi: btcoexist: Implement antenna selection"). There were still problems, thus there were commit0ff78adeef
("rtlwifi: rtl8723be: fix ant_sel code") and commit6d62269283
("rtlwifi: btcoexist: Fix antenna selection code"). Despite all these attempts at fixing the problem, the code is not yet right. A proper fix is important as there are now instances of laptops having RTL8723DE chips with the same problem. The module parameter ant_sel is used to control antenna number and path. At present enum ANT_{X2,X1} is used to define the antenna number, but this choice is not intuitive, thus change to a new enum ANT_{MAIN,AUX} to make it more readable. This change showed examples where incorrect values were used. It was also possible to remove a workaround in halbtcoutsrc.c. The experimental results with single antenna connected to specific path are now as follows: ant_sel ANT_MAIN(#1) ANT_AUX(#2) 0 -8 -62 1 -62 -10 2 -6 -60 Signed-off-by: Ping-Ke Shih <pkshih@realtek.com> Fixes:c18d8f5095
("rtlwifi: rtl8723be: Add antenna select module parameter") Fixes:baa1702290
("rtlwifi: btcoexist: Implement antenna selection") Fixes:0ff78adeef
("rtlwifi: rtl8723be: fix ant_sel code") Fixes:6d62269283
("rtlwifi: btcoexist: Fix antenna selection code") Cc: Stable <stable@vger.kernel.org> # 4.7+ Reviewed-by: Larry Finger <Larry.Finger@lwfinger.net> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
a083429e13
commit
af8a41cccf
|
@ -158,16 +158,6 @@ static u8 halbtc_get_wifi_central_chnl(struct btc_coexist *btcoexist)
|
|||
|
||||
static u8 rtl_get_hwpg_single_ant_path(struct rtl_priv *rtlpriv)
|
||||
{
|
||||
struct rtl_mod_params *mod_params = rtlpriv->cfg->mod_params;
|
||||
|
||||
/* override ant_num / ant_path */
|
||||
if (mod_params->ant_sel) {
|
||||
rtlpriv->btcoexist.btc_info.ant_num =
|
||||
(mod_params->ant_sel == 1 ? ANT_X2 : ANT_X1);
|
||||
|
||||
rtlpriv->btcoexist.btc_info.single_ant_path =
|
||||
(mod_params->ant_sel == 1 ? 0 : 1);
|
||||
}
|
||||
return rtlpriv->btcoexist.btc_info.single_ant_path;
|
||||
}
|
||||
|
||||
|
@ -178,7 +168,6 @@ static u8 rtl_get_hwpg_bt_type(struct rtl_priv *rtlpriv)
|
|||
|
||||
static u8 rtl_get_hwpg_ant_num(struct rtl_priv *rtlpriv)
|
||||
{
|
||||
struct rtl_mod_params *mod_params = rtlpriv->cfg->mod_params;
|
||||
u8 num;
|
||||
|
||||
if (rtlpriv->btcoexist.btc_info.ant_num == ANT_X2)
|
||||
|
@ -186,10 +175,6 @@ static u8 rtl_get_hwpg_ant_num(struct rtl_priv *rtlpriv)
|
|||
else
|
||||
num = 1;
|
||||
|
||||
/* override ant_num / ant_path */
|
||||
if (mod_params->ant_sel)
|
||||
num = (mod_params->ant_sel == 1 ? ANT_X2 : ANT_X1) + 1;
|
||||
|
||||
return num;
|
||||
}
|
||||
|
||||
|
|
|
@ -848,6 +848,9 @@ static bool _rtl8723be_init_mac(struct ieee80211_hw *hw)
|
|||
return false;
|
||||
}
|
||||
|
||||
if (rtlpriv->cfg->ops->get_btc_status())
|
||||
rtlpriv->btcoexist.btc_ops->btc_power_on_setting(rtlpriv);
|
||||
|
||||
bytetmp = rtl_read_byte(rtlpriv, REG_MULTI_FUNC_CTRL);
|
||||
rtl_write_byte(rtlpriv, REG_MULTI_FUNC_CTRL, bytetmp | BIT(3));
|
||||
|
||||
|
@ -2696,21 +2699,21 @@ void rtl8723be_read_bt_coexist_info_from_hwpg(struct ieee80211_hw *hw,
|
|||
rtlpriv->btcoexist.btc_info.bt_type = BT_RTL8723B;
|
||||
rtlpriv->btcoexist.btc_info.ant_num = (value & 0x1);
|
||||
rtlpriv->btcoexist.btc_info.single_ant_path =
|
||||
(value & 0x40); /*0xc3[6]*/
|
||||
(value & 0x40 ? ANT_AUX : ANT_MAIN); /*0xc3[6]*/
|
||||
} else {
|
||||
rtlpriv->btcoexist.btc_info.btcoexist = 0;
|
||||
rtlpriv->btcoexist.btc_info.bt_type = BT_RTL8723B;
|
||||
rtlpriv->btcoexist.btc_info.ant_num = ANT_X2;
|
||||
rtlpriv->btcoexist.btc_info.single_ant_path = 0;
|
||||
rtlpriv->btcoexist.btc_info.single_ant_path = ANT_MAIN;
|
||||
}
|
||||
|
||||
/* override ant_num / ant_path */
|
||||
if (mod_params->ant_sel) {
|
||||
rtlpriv->btcoexist.btc_info.ant_num =
|
||||
(mod_params->ant_sel == 1 ? ANT_X2 : ANT_X1);
|
||||
(mod_params->ant_sel == 1 ? ANT_X1 : ANT_X2);
|
||||
|
||||
rtlpriv->btcoexist.btc_info.single_ant_path =
|
||||
(mod_params->ant_sel == 1 ? 0 : 1);
|
||||
(mod_params->ant_sel == 1 ? ANT_AUX : ANT_MAIN);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -2823,6 +2823,11 @@ enum bt_ant_num {
|
|||
ANT_X1 = 1,
|
||||
};
|
||||
|
||||
enum bt_ant_path {
|
||||
ANT_MAIN = 0,
|
||||
ANT_AUX = 1,
|
||||
};
|
||||
|
||||
enum bt_co_type {
|
||||
BT_2WIRE = 0,
|
||||
BT_ISSC_3WIRE = 1,
|
||||
|
|
Loading…
Reference in New Issue