summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorStefan Sperling <stsp@cvs.openbsd.org>2019-11-09 13:21:05 +0000
committerStefan Sperling <stsp@cvs.openbsd.org>2019-11-09 13:21:05 +0000
commit92d6e64261be3d96eefe8d2fd37397253cdb14c9 (patch)
treec623fcfe56b4eb3458b1ddb03c4fc487d3cb76ca /sys
parentafcc405018f894692c6140cc328cf3f54156aae4 (diff)
Give access points which fail to AUTH or ASSOC less priority during
the next selection of networks from the join list. Prevents endless attempts to connect to an AP which is out of reach but still somehow manages to get a beacon or two across to us during scan. Tested with wifi networks at the University of Bucharest. Makes switching wifi networks possible after walking to a different room without having to down/up the interface or suspend/resume. ok phessler@
Diffstat (limited to 'sys')
-rw-r--r--sys/net80211/ieee80211.c21
-rw-r--r--sys/net80211/ieee80211_node.c15
-rw-r--r--sys/net80211/ieee80211_var.h3
3 files changed, 35 insertions, 4 deletions
diff --git a/sys/net80211/ieee80211.c b/sys/net80211/ieee80211.c
index bf2b2858f03..d57ed713006 100644
--- a/sys/net80211/ieee80211.c
+++ b/sys/net80211/ieee80211.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211.c,v 1.79 2019/11/06 13:55:44 stsp Exp $ */
+/* $OpenBSD: ieee80211.c,v 1.80 2019/11/09 13:21:04 stsp Exp $ */
/* $NetBSD: ieee80211.c,v 1.19 2004/06/06 05:45:29 dyoung Exp $ */
/*-
@@ -772,8 +772,25 @@ ieee80211_watchdog(struct ifnet *ifp)
{
struct ieee80211com *ic = (void *)ifp;
- if (ic->ic_mgt_timer && --ic->ic_mgt_timer == 0)
+ if (ic->ic_mgt_timer && --ic->ic_mgt_timer == 0) {
+ if (ic->ic_opmode == IEEE80211_M_STA &&
+ (ic->ic_state == IEEE80211_S_AUTH ||
+ ic->ic_state == IEEE80211_S_ASSOC)) {
+ struct ieee80211_node *ni;
+ if (ifp->if_flags & IFF_DEBUG)
+ printf("%s: %s timed out for %s\n",
+ ifp->if_xname,
+ ic->ic_state == IEEE80211_S_ASSOC ?
+ "association" : "authentication",
+ ether_sprintf(ic->ic_bss->ni_macaddr));
+ ni = ieee80211_find_node(ic, ic->ic_bss->ni_macaddr);
+ if (ni)
+ ni->ni_fails++;
+ if (ISSET(ic->ic_flags, IEEE80211_F_AUTO_JOIN))
+ ieee80211_deselect_ess(ic);
+ }
ieee80211_new_state(ic, IEEE80211_S_SCAN, -1);
+ }
if (ic->ic_mgt_timer != 0)
ifp->if_timer = 1;
diff --git a/sys/net80211/ieee80211_node.c b/sys/net80211/ieee80211_node.c
index 55fd874670f..0380a8d9ab9 100644
--- a/sys/net80211/ieee80211_node.c
+++ b/sys/net80211/ieee80211_node.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_node.c,v 1.175 2019/11/09 09:03:24 stsp Exp $ */
+/* $OpenBSD: ieee80211_node.c,v 1.176 2019/11/09 13:21:04 stsp Exp $ */
/* $NetBSD: ieee80211_node.c,v 1.14 2004/05/09 09:18:47 dyoung Exp $ */
/*-
@@ -476,6 +476,10 @@ ieee80211_ess_calculate_score(struct ieee80211com *ic,
ni->ni_rssi > min_5ghz_rssi)
score += 2;
+ /* Boost this AP if it had no auth/assoc failures in the past. */
+ if (ni->ni_fails == 0)
+ score += 21;
+
return score;
}
@@ -672,6 +676,15 @@ ieee80211_set_ess(struct ieee80211com *ic, struct ieee80211_ess *ess,
}
void
+ieee80211_deselect_ess(struct ieee80211com *ic)
+{
+ memset(ic->ic_des_essid, 0, IEEE80211_NWID_LEN);
+ ic->ic_des_esslen = 0;
+ ieee80211_disable_wep(ic);
+ ieee80211_disable_rsn(ic);
+}
+
+void
ieee80211_node_attach(struct ifnet *ifp)
{
struct ieee80211com *ic = (void *)ifp;
diff --git a/sys/net80211/ieee80211_var.h b/sys/net80211/ieee80211_var.h
index bf3ac419f64..f1f71296a97 100644
--- a/sys/net80211/ieee80211_var.h
+++ b/sys/net80211/ieee80211_var.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ieee80211_var.h,v 1.100 2019/11/09 11:39:15 stsp Exp $ */
+/* $OpenBSD: ieee80211_var.h,v 1.101 2019/11/09 13:21:04 stsp Exp $ */
/* $NetBSD: ieee80211_var.h,v 1.7 2004/05/06 03:07:10 dyoung Exp $ */
/*-
@@ -472,6 +472,7 @@ int ieee80211_add_ess(struct ieee80211com *, struct ieee80211_join *);
void ieee80211_del_ess(struct ieee80211com *, char *, int, int);
void ieee80211_set_ess(struct ieee80211com *, struct ieee80211_ess *,
struct ieee80211_node *);
+void ieee80211_deselect_ess(struct ieee80211com *);
struct ieee80211_ess *ieee80211_get_ess(struct ieee80211com *, const char *, int);
void ieee80211_begin_bgscan(struct ifnet *);