projects
/
openwrt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
madwifi: fix a potential race condition in the wds ap station interface setup/teardown
[openwrt.git]
/
package
/
madwifi
/
patches
/
370-wdsvap.patch
diff --git
a/package/madwifi/patches/370-wdsvap.patch
b/package/madwifi/patches/370-wdsvap.patch
index
d1f255d
..
f72e22f
100644
(file)
--- a/
package/madwifi/patches/370-wdsvap.patch
+++ b/
package/madwifi/patches/370-wdsvap.patch
@@
-903,7
+903,7
@@
}
/* This is overridden by ath_node_alloc in ath/if_ath.c, and so
}
/* This is overridden by ath_node_alloc in ath/if_ath.c, and so
-@@ -1134,6 +1145,6
2
@@ ieee80211_alloc_node(struct ieee80211vap
+@@ -1134,6 +1145,6
5
@@ ieee80211_alloc_node(struct ieee80211vap
return ni;
}
return ni;
}
@@
-957,6
+957,9
@@
+ if (ni->ni_subif)
+ return;
+
+ if (ni->ni_subif)
+ return;
+
++ if (!ni->ni_table)
++ return;
++
+ ieee80211_ref_node(ni);
+ ni->ni_subif = ni->ni_vap;
+ IEEE80211_INIT_WORK(&ni->ni_create, ieee80211_wds_do_addif);
+ ieee80211_ref_node(ni);
+ ni->ni_subif = ni->ni_vap;
+ IEEE80211_INIT_WORK(&ni->ni_create, ieee80211_wds_do_addif);
@@
-966,7
+969,7
@@
/* Add wds address to the node table */
int
#ifdef IEEE80211_DEBUG_REFCNT
/* Add wds address to the node table */
int
#ifdef IEEE80211_DEBUG_REFCNT
-@@ -1553,22 +162
0
,39 @@ ieee80211_find_rxnode(struct ieee80211co
+@@ -1553,22 +162
3
,39 @@ ieee80211_find_rxnode(struct ieee80211co
((wh->i_fc[0] & IEEE80211_FC0_SUBTYPE_MASK) == IEEE80211_FC0_SUBTYPE_PS_POLL)
struct ieee80211_node_table *nt;
struct ieee80211_node *ni;
((wh->i_fc[0] & IEEE80211_FC0_SUBTYPE_MASK) == IEEE80211_FC0_SUBTYPE_PS_POLL)
struct ieee80211_node_table *nt;
struct ieee80211_node *ni;
@@
-1015,7
+1018,7
@@
#endif
IEEE80211_NODE_TABLE_UNLOCK_IRQ(nt);
#endif
IEEE80211_NODE_TABLE_UNLOCK_IRQ(nt);
-@@ -1596,9 +168
0
,19 @@ ieee80211_find_txnode_debug(struct ieee8
+@@ -1596,9 +168
3
,19 @@ ieee80211_find_txnode_debug(struct ieee8
ieee80211_find_txnode(struct ieee80211vap *vap, const u_int8_t *mac)
#endif
{
ieee80211_find_txnode(struct ieee80211vap *vap, const u_int8_t *mac)
#endif
{
@@
-1035,7
+1038,7
@@
/*
* The destination address should be in the node table
* unless we are operating in station mode or this is a
/*
* The destination address should be in the node table
* unless we are operating in station mode or this is a
-@@ -1669,6 +176
3
,11 @@ ieee80211_free_node(struct ieee80211_nod
+@@ -1669,6 +176
6
,11 @@ ieee80211_free_node(struct ieee80211_nod
{
struct ieee80211vap *vap = ni->ni_vap;
{
struct ieee80211vap *vap = ni->ni_vap;
@@
-1047,7
+1050,7
@@
atomic_dec(&ni->ni_ic->ic_node_counter);
node_print_message(IEEE80211_MSG_NODE|IEEE80211_MSG_NODE_REF,
1 /* show counter */,
atomic_dec(&ni->ni_ic->ic_node_counter);
node_print_message(IEEE80211_MSG_NODE|IEEE80211_MSG_NODE_REF,
1 /* show counter */,
-@@ -1781,22 +188
0
,6 @@ restart:
+@@ -1781,22 +188
3
,6 @@ restart:
jiffies > ni->ni_rxfragstamp + HZ) {
ieee80211_dev_kfree_skb(&ni->ni_rxfrag);
}
jiffies > ni->ni_rxfragstamp + HZ) {
ieee80211_dev_kfree_skb(&ni->ni_rxfrag);
}
@@
-1070,7
+1073,7
@@
ni->ni_inact--;
if (ni->ni_associd != 0 || isadhoc) {
struct ieee80211vap *vap = ni->ni_vap;
ni->ni_inact--;
if (ni->ni_associd != 0 || isadhoc) {
struct ieee80211vap *vap = ni->ni_vap;
-@@ -2263,6 +234
6,36
@@ ieee80211_node_leave_11g(struct ieee8021
+@@ -2263,6 +234
9,35
@@ ieee80211_node_leave_11g(struct ieee8021
}
}
}
}
@@
-1081,15
+1084,14
@@
+ struct ieee80211vap *vap;
+ struct ieee80211com *ic;
+
+ struct ieee80211vap *vap;
+ struct ieee80211com *ic;
+
++ /* wait for full initialization before we start the teardown
++ * otherwise we could leak interfaces */
++ while (ni->ni_subif == ni->ni_vap)
++ schedule();
++
+ rtnl_lock();
+ vap = ni->ni_subif;
+
+ rtnl_lock();
+ vap = ni->ni_subif;
+
-+ /* if addif is waiting for the timer to fire, cancel! */
-+ if (vap == ni->ni_vap) {
-+ ni->ni_subif = NULL;
-+ goto done;
-+ }
-+
+ if (!vap)
+ goto done;
+
+ if (!vap)
+ goto done;
+
@@
-1107,7
+1109,7
@@
/*
* Handle bookkeeping for a station/neighbor leaving
* the bss when operating in ap or adhoc modes.
/*
* Handle bookkeeping for a station/neighbor leaving
* the bss when operating in ap or adhoc modes.
-@@ -2279,6 +239
2
,12 @@ ieee80211_node_leave(struct ieee80211_no
+@@ -2279,6 +239
4
,12 @@ ieee80211_node_leave(struct ieee80211_no
ni, "station with aid %d leaves (refcnt %u)",
IEEE80211_NODE_AID(ni), atomic_read(&ni->ni_refcnt));
ni, "station with aid %d leaves (refcnt %u)",
IEEE80211_NODE_AID(ni), atomic_read(&ni->ni_refcnt));
This page took
0.02923 seconds
and
4
git commands to generate.