summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/net80211/ieee80211_node.c60
-rw-r--r--sys/net80211/ieee80211_node.h11
-rw-r--r--sys/net80211/ieee80211_var.h3
3 files changed, 32 insertions, 42 deletions
diff --git a/sys/net80211/ieee80211_node.c b/sys/net80211/ieee80211_node.c
index 9b7762632da..21398865fe6 100644
--- a/sys/net80211/ieee80211_node.c
+++ b/sys/net80211/ieee80211_node.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_node.c,v 1.20 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211_node.c,v 1.21 2007/06/07 20:24:42 damien Exp $ */
/* $NetBSD: ieee80211_node.c,v 1.14 2004/05/09 09:18:47 dyoung Exp $ */
/*-
@@ -95,7 +95,6 @@ ieee80211_node_attach(struct ifnet *ifp)
struct ieee80211com *ic = (void *)ifp;
int size;
- IEEE80211_NODE_LOCK_INIT(ic, ifp->if_xname);
RB_INIT(&ic->ic_tree);
ic->ic_node_alloc = ieee80211_node_alloc;
ic->ic_node_free = ieee80211_node_free;
@@ -156,7 +155,6 @@ ieee80211_node_detach(struct ifnet *ifp)
ic->ic_bss = NULL;
}
ieee80211_free_allnodes(ic);
- IEEE80211_NODE_LOCK_DESTROY(ic);
if (ic->ic_aid_bitmap != NULL)
FREE(ic->ic_aid_bitmap, M_DEVBUF);
}
@@ -559,10 +557,11 @@ static void
ieee80211_setup_node(struct ieee80211com *ic,
struct ieee80211_node *ni, u_int8_t *macaddr)
{
+ int s;
+
IEEE80211_DPRINTF(("%s %s\n", __func__, ether_sprintf(macaddr)));
IEEE80211_ADDR_COPY(ni->ni_macaddr, macaddr);
ieee80211_node_newstate(ni, IEEE80211_STA_CACHE);
- IEEE80211_NODE_LOCK_BH(ic);
/*
* Note we don't enable the inactive timer when acting
@@ -573,11 +572,12 @@ ieee80211_setup_node(struct ieee80211com *ic,
* more importantly, we'll incorrectly deauthenticate
* ourself because the inactivity timer will kick us off.
*/
+ s = splnet();
if (ic->ic_opmode != IEEE80211_M_STA &&
RB_EMPTY(&ic->ic_tree))
ic->ic_inact_timer = IEEE80211_INACT_WAIT;
RB_INSERT(ieee80211_tree, &ic->ic_tree, ni);
- IEEE80211_NODE_UNLOCK_BH(ic);
+ splx(s);
}
struct ieee80211_node *
@@ -627,6 +627,7 @@ struct ieee80211_node *
ieee80211_find_txnode(struct ieee80211com *ic, u_int8_t *macaddr)
{
struct ieee80211_node *ni;
+ int s;
/*
* The destination address should be in the node table
@@ -636,10 +637,9 @@ ieee80211_find_txnode(struct ieee80211com *ic, u_int8_t *macaddr)
if (ic->ic_opmode == IEEE80211_M_STA || IEEE80211_IS_MULTICAST(macaddr))
return ieee80211_ref_node(ic->ic_bss);
- /* XXX can't hold lock across dup_bss 'cuz of recursive locking */
- IEEE80211_NODE_LOCK(ic);
+ s = splnet();
ni = ieee80211_find_node(ic, macaddr);
- IEEE80211_NODE_UNLOCK(ic);
+ splx(s);
if (ni == NULL) {
if (ic->ic_opmode != IEEE80211_M_IBSS &&
ic->ic_opmode != IEEE80211_M_AHDEMO)
@@ -755,13 +755,14 @@ ieee80211_find_rxnode(struct ieee80211com *ic, struct ieee80211_frame *wh)
struct ieee80211_node *ni;
const static u_int8_t zero[IEEE80211_ADDR_LEN];
u_int8_t *bssid;
+ int s;
if (!ieee80211_needs_rxnode(ic, wh, &bssid))
return ieee80211_ref_node(ic->ic_bss);
- IEEE80211_NODE_LOCK(ic);
+ s = splnet();
ni = ieee80211_find_node(ic, wh->i_addr2);
- IEEE80211_NODE_UNLOCK(ic);
+ splx(s);
if (ni != NULL)
return ieee80211_ref_node(ni);
@@ -790,10 +791,10 @@ ieee80211_find_node_for_beacon(struct ieee80211com *ic, u_int8_t *macaddr,
struct ieee80211_channel *chan, char *ssid, u_int8_t rssi)
{
struct ieee80211_node *ni, *keep = NULL;
- int score = 0;
+ int s, score = 0;
if ((ni = ieee80211_find_node(ic, macaddr)) != NULL) {
- IEEE80211_NODE_LOCK(ic);
+ s = splnet();
if (ni->ni_chan != chan && ni->ni_rssi >= rssi)
score++;
@@ -802,7 +803,7 @@ ieee80211_find_node_for_beacon(struct ieee80211com *ic, u_int8_t *macaddr,
if (score > 0)
keep = ni;
- IEEE80211_NODE_UNLOCK(ic);
+ splx(s);
}
return (keep);
@@ -832,13 +833,15 @@ ieee80211_free_node(struct ieee80211com *ic, struct ieee80211_node *ni)
void
ieee80211_release_node(struct ieee80211com *ic, struct ieee80211_node *ni)
{
+ int s;
+
IEEE80211_DPRINTF(("%s %s refcnt %d\n", __func__,
ether_sprintf(ni->ni_macaddr), ni->ni_refcnt));
if (ieee80211_node_decref(ni) == 0 &&
ni->ni_state == IEEE80211_STA_COLLECT) {
- IEEE80211_NODE_LOCK_BH(ic);
+ s = splnet();
ieee80211_free_node(ic, ni);
- IEEE80211_NODE_UNLOCK_BH(ic);
+ splx(s);
}
}
@@ -846,33 +849,29 @@ void
ieee80211_free_allnodes(struct ieee80211com *ic)
{
struct ieee80211_node *ni;
+ int s;
IEEE80211_DPRINTF(("%s\n", __func__));
- IEEE80211_NODE_LOCK_BH(ic);
+ s = splnet();
while ((ni = RB_MIN(ieee80211_tree, &ic->ic_tree)) != NULL)
ieee80211_free_node(ic, ni);
- IEEE80211_NODE_UNLOCK_BH(ic);
+ splx(s);
if (ic->ic_bss != NULL)
ieee80211_node_cleanup(ic, ic->ic_bss); /* for station mode */
}
/*
- * Timeout inactive nodes. Note that we cannot hold the node
- * lock while sending a frame as this would lead to a LOR.
- * Instead we use a generation number to mark nodes that we've
- * scanned and drop the lock and restart a scan if we have to
- * time out a node. Since we are single-threaded by virtue of
- * controlling the inactivity timer we can be sure this will
- * process each node only once.
+ * Timeout inactive nodes.
*/
void
ieee80211_clean_nodes(struct ieee80211com *ic)
{
struct ieee80211_node *ni, *next_ni;
u_int gen = ic->ic_scangen++; /* NB: ok 'cuz single-threaded*/
+ int s;
- IEEE80211_NODE_LOCK(ic);
+ s = splnet();
for (ni = RB_MIN(ieee80211_tree, &ic->ic_tree);
ni != NULL; ni = next_ni) {
next_ni = RB_NEXT(ieee80211_tree, &ic->ic_tree, ni);
@@ -889,17 +888,17 @@ ieee80211_clean_nodes(struct ieee80211com *ic)
* Send a deauthenticate frame.
*/
if (ic->ic_opmode == IEEE80211_M_HOSTAP) {
- IEEE80211_NODE_UNLOCK(ic);
+ splx(s);
IEEE80211_SEND_MGMT(ic, ni,
IEEE80211_FC0_SUBTYPE_DEAUTH,
IEEE80211_REASON_AUTH_EXPIRE);
- IEEE80211_NODE_LOCK(ic);
+ s = splnet();
ieee80211_node_leave(ic, ni);
} else
ieee80211_free_node(ic, ni);
ic->ic_stats.is_node_timeout++;
}
- IEEE80211_NODE_UNLOCK(ic);
+ splx(s);
}
void
@@ -907,11 +906,12 @@ ieee80211_iterate_nodes(struct ieee80211com *ic, ieee80211_iter_func *f,
void *arg)
{
struct ieee80211_node *ni;
+ int s;
- IEEE80211_NODE_LOCK(ic);
+ s = splnet();
RB_FOREACH(ni, ieee80211_tree, &ic->ic_tree)
(*f)(arg, ni);
- IEEE80211_NODE_UNLOCK(ic);
+ splx(s);
}
/*
diff --git a/sys/net80211/ieee80211_node.h b/sys/net80211/ieee80211_node.h
index ee56cc5a56c..8713fc067b3 100644
--- a/sys/net80211/ieee80211_node.h
+++ b/sys/net80211/ieee80211_node.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_node.h,v 1.11 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211_node.h,v 1.12 2007/06/07 20:24:42 damien Exp $ */
/* $NetBSD: ieee80211_node.h,v 1.9 2004/04/30 22:57:32 dyoung Exp $ */
/*-
@@ -159,15 +159,6 @@ ieee80211_unref_node(struct ieee80211_node **ni)
*ni = NULL; /* guard against use */
}
-typedef int ieee80211_node_lock_t;
-#define IEEE80211_NODE_LOCK_INIT(_ic, _name)
-#define IEEE80211_NODE_LOCK_DESTROY(_ic)
-#define IEEE80211_NODE_LOCK(_ic) (_ic)->ic_nodelock = splnet()
-#define IEEE80211_NODE_UNLOCK(_ic) splx((_ic)->ic_nodelock)
-#define IEEE80211_NODE_LOCK_ASSERT(_ic)
-#define IEEE80211_NODE_LOCK_BH IEEE80211_NODE_LOCK
-#define IEEE80211_NODE_UNLOCK_BH IEEE80211_NODE_UNLOCK
-
struct ieee80211com;
#ifdef MALLOC_DECLARE
diff --git a/sys/net80211/ieee80211_var.h b/sys/net80211/ieee80211_var.h
index 6ba230d3024..5ff921b67aa 100644
--- a/sys/net80211/ieee80211_var.h
+++ b/sys/net80211/ieee80211_var.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_var.h,v 1.19 2007/06/06 19:31:07 damien Exp $ */
+/* $OpenBSD: ieee80211_var.h,v 1.20 2007/06/07 20:24:42 damien Exp $ */
/* $NetBSD: ieee80211_var.h,v 1.7 2004/05/06 03:07:10 dyoung Exp $ */
/*-
@@ -180,7 +180,6 @@ struct ieee80211com {
int ic_fixed_rate; /* index to ic_sup_rates[] */
u_int16_t ic_rtsthreshold;
u_int16_t ic_fragthreshold;
- ieee80211_node_lock_t ic_nodelock; /* on node table */
u_int ic_scangen; /* gen# for timeout scan */
struct ieee80211_node *(*ic_node_alloc)(struct ieee80211com *);
void (*ic_node_free)(struct ieee80211com *,