summaryrefslogtreecommitdiff
path: root/package/madwifi/patches
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2009-09-23 13:32:38 +0000
committerFelix Fietkau <nbd@openwrt.org>2009-09-23 13:32:38 +0000
commitca1b63e891dff25920436f963ea8f91ed19bb9fc (patch)
treef6a71117fe5350ea4a3e495b01356024bc6d00db /package/madwifi/patches
parentbbc97003109138e7f7c90ee91104317a42f9b959 (diff)
downloadmtk-20170518-ca1b63e891dff25920436f963ea8f91ed19bb9fc.zip
mtk-20170518-ca1b63e891dff25920436f963ea8f91ed19bb9fc.tar.gz
mtk-20170518-ca1b63e891dff25920436f963ea8f91ed19bb9fc.tar.bz2
madwifi: fix sta mode reconnect when roaming between different aps of the same essid
SVN-Revision: 17688
Diffstat (limited to 'package/madwifi/patches')
-rw-r--r--package/madwifi/patches/447-sta_reconnect.patch33
1 files changed, 33 insertions, 0 deletions
diff --git a/package/madwifi/patches/447-sta_reconnect.patch b/package/madwifi/patches/447-sta_reconnect.patch
new file mode 100644
index 0000000..e6f019e
--- /dev/null
+++ b/package/madwifi/patches/447-sta_reconnect.patch
@@ -0,0 +1,33 @@
+--- a/net80211/ieee80211_node.c
++++ b/net80211/ieee80211_node.c
+@@ -647,8 +647,11 @@ ieee80211_sta_join1(struct ieee80211_nod
+ (vap->iv_state == IEEE80211_S_RUN) && bssid_equal(obss, selbs)); */
+ vap->iv_bss = selbs;
+ IEEE80211_ADDR_COPY(vap->iv_bssid, selbs->ni_bssid);
+- if (obss != NULL)
++ if (obss != NULL) {
++ if (obss->ni_table)
++ ieee80211_node_leave(obss);
+ ieee80211_unref_node(&obss);
++ }
+ ic->ic_bsschan = selbs->ni_chan;
+ ic->ic_curchan = ic->ic_bsschan;
+ ic->ic_curmode = ieee80211_chan2mode(ic->ic_curchan);
+--- a/net80211/ieee80211_proto.c
++++ b/net80211/ieee80211_proto.c
+@@ -1512,14 +1512,13 @@ __ieee80211_newstate(struct ieee80211vap
+ if (arg != 0)
+ ieee80211_scan_assoc_fail(ic,
+ vap->iv_bss->ni_macaddr, arg);
++ ieee80211_node_leave(vap->iv_bss);
+ if (ic->ic_roaming == IEEE80211_ROAMING_AUTO)
+ ieee80211_check_scan(vap,
+ IEEE80211_SCAN_ACTIVE,
+ IEEE80211_SCAN_FOREVER,
+ vap->iv_des_nssid, vap->iv_des_ssid,
+ NULL);
+- else
+- ieee80211_node_leave(vap->iv_bss);
+ break;
+ case IEEE80211_S_RUN: /* beacon miss */
+ if (vap->iv_opmode == IEEE80211_M_STA) {