mac80211: Allow HT capa override to add 40 MHz intolerant
This can be useful for testing purposes to confirm valid AP behavior on HT 20/40 co-existence functionality. Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
96cce12ff6
commit
9a07bf507d
@ -31,6 +31,18 @@ static void __check_htcap_disable(struct ieee80211_ht_cap *ht_capa,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void __check_htcap_enable(struct ieee80211_ht_cap *ht_capa,
|
||||||
|
struct ieee80211_ht_cap *ht_capa_mask,
|
||||||
|
struct ieee80211_sta_ht_cap *ht_cap,
|
||||||
|
u16 flag)
|
||||||
|
{
|
||||||
|
__le16 le_flag = cpu_to_le16(flag);
|
||||||
|
|
||||||
|
if ((ht_capa_mask->cap_info & le_flag) &&
|
||||||
|
(ht_capa->cap_info & le_flag))
|
||||||
|
ht_cap->cap |= flag;
|
||||||
|
}
|
||||||
|
|
||||||
void ieee80211_apply_htcap_overrides(struct ieee80211_sub_if_data *sdata,
|
void ieee80211_apply_htcap_overrides(struct ieee80211_sub_if_data *sdata,
|
||||||
struct ieee80211_sta_ht_cap *ht_cap)
|
struct ieee80211_sta_ht_cap *ht_cap)
|
||||||
{
|
{
|
||||||
@ -59,7 +71,7 @@ void ieee80211_apply_htcap_overrides(struct ieee80211_sub_if_data *sdata,
|
|||||||
smask = (u8 *)(&ht_capa_mask->mcs.rx_mask);
|
smask = (u8 *)(&ht_capa_mask->mcs.rx_mask);
|
||||||
|
|
||||||
/* NOTE: If you add more over-rides here, update register_hw
|
/* NOTE: If you add more over-rides here, update register_hw
|
||||||
* ht_capa_mod_msk logic in main.c as well.
|
* ht_capa_mod_mask logic in main.c as well.
|
||||||
* And, if this method can ever change ht_cap.ht_supported, fix
|
* And, if this method can ever change ht_cap.ht_supported, fix
|
||||||
* the check in ieee80211_add_ht_ie.
|
* the check in ieee80211_add_ht_ie.
|
||||||
*/
|
*/
|
||||||
@ -90,6 +102,10 @@ void ieee80211_apply_htcap_overrides(struct ieee80211_sub_if_data *sdata,
|
|||||||
__check_htcap_disable(ht_capa, ht_capa_mask, ht_cap,
|
__check_htcap_disable(ht_capa, ht_capa_mask, ht_cap,
|
||||||
IEEE80211_HT_CAP_LDPC_CODING);
|
IEEE80211_HT_CAP_LDPC_CODING);
|
||||||
|
|
||||||
|
/* Allow user to enable 40 MHz intolerant bit. */
|
||||||
|
__check_htcap_enable(ht_capa, ht_capa_mask, ht_cap,
|
||||||
|
IEEE80211_HT_CAP_40MHZ_INTOLERANT);
|
||||||
|
|
||||||
/* Allow user to decrease AMPDU factor */
|
/* Allow user to decrease AMPDU factor */
|
||||||
if (ht_capa_mask->ampdu_params_info &
|
if (ht_capa_mask->ampdu_params_info &
|
||||||
IEEE80211_HT_AMPDU_PARM_FACTOR) {
|
IEEE80211_HT_AMPDU_PARM_FACTOR) {
|
||||||
|
@ -445,7 +445,8 @@ static const struct ieee80211_ht_cap mac80211_ht_capa_mod_mask = {
|
|||||||
IEEE80211_HT_CAP_MAX_AMSDU |
|
IEEE80211_HT_CAP_MAX_AMSDU |
|
||||||
IEEE80211_HT_CAP_SGI_20 |
|
IEEE80211_HT_CAP_SGI_20 |
|
||||||
IEEE80211_HT_CAP_SGI_40 |
|
IEEE80211_HT_CAP_SGI_40 |
|
||||||
IEEE80211_HT_CAP_LDPC_CODING),
|
IEEE80211_HT_CAP_LDPC_CODING |
|
||||||
|
IEEE80211_HT_CAP_40MHZ_INTOLERANT),
|
||||||
.mcs = {
|
.mcs = {
|
||||||
.rx_mask = { 0xff, 0xff, 0xff, 0xff, 0xff,
|
.rx_mask = { 0xff, 0xff, 0xff, 0xff, 0xff,
|
||||||
0xff, 0xff, 0xff, 0xff, 0xff, },
|
0xff, 0xff, 0xff, 0xff, 0xff, },
|
||||||
|
Loading…
Reference in New Issue
Block a user