]> git.karo-electronics.de Git - linux-beck.git/commitdiff
mac80211: fix rates setup on IBSS merge
authorBruno Randolf <br1@einfach.org>
Tue, 23 Feb 2010 09:51:13 +0000 (18:51 +0900)
committerJohn W. Linville <linville@tuxdriver.com>
Tue, 9 Mar 2010 20:03:06 +0000 (15:03 -0500)
when an IBSS merge happened, the supported rates for the newly added station
were left empty, causing the rate control module to be initialized with only
the basic rates.

also the section of the ibss code which deals with updating supported rates for
an already existing station fails to inform the rate control module about the
new rates. as i don't know how to fix this (minstrel does not have an update
function), i have just added a comment for now.

Signed-off-by: Bruno Randolf <br1@einfach.org>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
net/mac80211/ibss.c

index f3e94248674948afc3c1b29be81c9b1ce1f234f3..b840d9072de9245d61a30fe8abea57887b13b3ee 100644 (file)
@@ -276,6 +276,8 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata,
                                    (unsigned long long) sta->sta.supp_rates[band]);
 #endif
                        rcu_read_unlock();
+
+                       /* FIXME: update rate control */
                } else {
                        rcu_read_unlock();
                        ieee80211_ibss_add_sta(sdata, mgmt->bssid, mgmt->sa,
@@ -370,6 +372,7 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata,
                       sdata->name, mgmt->bssid);
 #endif
                ieee80211_sta_join_ibss(sdata, bss);
+               supp_rates = ieee80211_sta_get_rates(local, elems, band);
                ieee80211_ibss_add_sta(sdata, mgmt->bssid, mgmt->sa,
                                       supp_rates, GFP_KERNEL);
        }