diff options
author | Abhijeet Kolekar <abhijeet.kolekar@intel.com> | 2008-04-16 17:02:04 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2008-04-23 21:25:34 -0400 |
commit | a46f025d053e47b9ce602f53f6d30e94d304a51c (patch) | |
tree | 21b453785f61c8dd3113721d651aafa7ce01b0f0 | |
parent | d7d313000ba2fc94a5383511a17ff38a39bab928 (diff) |
mac80211: Fix n-band association problem
There are two structures named wmm_info and wmm_param, they are used while
parsing the beacon frame. (Check the function ieee802_11_parse_elems).
Certain APs like D-link does not set the fifth bit in WMM IE.
While sending the association request to n-only ap it checks for wmm_ie.
If it is set then only ieee80211_ht_cap is sent during association request.
So n-only association fails.
And this patch fixes this problem by copying the wmm_info to wmm_ie,
which enables the "wmm" flag in iee80211_send_assoc.
Signed-off-by: Abhijeet Kolekar <abhijeet.kolekar@intel.com>
Acked-by: Ron Rindjunsky <ron.rindjunsky@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | net/mac80211/mlme.c | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index 6b75cb6c6300..c0a5345c8a61 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c | |||
@@ -2709,7 +2709,26 @@ static void ieee80211_rx_bss_info(struct net_device *dev, | |||
2709 | bss->wmm_ie_len = elems.wmm_param_len + 2; | 2709 | bss->wmm_ie_len = elems.wmm_param_len + 2; |
2710 | } else | 2710 | } else |
2711 | bss->wmm_ie_len = 0; | 2711 | bss->wmm_ie_len = 0; |
2712 | } else if (!elems.wmm_param && bss->wmm_ie) { | 2712 | } else if (elems.wmm_info && |
2713 | (!bss->wmm_ie || bss->wmm_ie_len != elems.wmm_info_len || | ||
2714 | memcmp(bss->wmm_ie, elems.wmm_info, elems.wmm_info_len))) { | ||
2715 | /* As for certain AP's Fifth bit is not set in WMM IE in | ||
2716 | * beacon frames.So while parsing the beacon frame the | ||
2717 | * wmm_info structure is used instead of wmm_param. | ||
2718 | * wmm_info structure was never used to set bss->wmm_ie. | ||
2719 | * This code fixes this problem by copying the WME | ||
2720 | * information from wmm_info to bss->wmm_ie and enabling | ||
2721 | * n-band association. | ||
2722 | */ | ||
2723 | kfree(bss->wmm_ie); | ||
2724 | bss->wmm_ie = kmalloc(elems.wmm_info_len + 2, GFP_ATOMIC); | ||
2725 | if (bss->wmm_ie) { | ||
2726 | memcpy(bss->wmm_ie, elems.wmm_info - 2, | ||
2727 | elems.wmm_info_len + 2); | ||
2728 | bss->wmm_ie_len = elems.wmm_info_len + 2; | ||
2729 | } else | ||
2730 | bss->wmm_ie_len = 0; | ||
2731 | } else if (!elems.wmm_param && !elems.wmm_info && bss->wmm_ie) { | ||
2713 | kfree(bss->wmm_ie); | 2732 | kfree(bss->wmm_ie); |
2714 | bss->wmm_ie = NULL; | 2733 | bss->wmm_ie = NULL; |
2715 | bss->wmm_ie_len = 0; | 2734 | bss->wmm_ie_len = 0; |