diff options
author | Stefan Sperling <stsp@cvs.openbsd.org> | 2019-11-09 13:21:05 +0000 |
---|---|---|
committer | Stefan Sperling <stsp@cvs.openbsd.org> | 2019-11-09 13:21:05 +0000 |
commit | 92d6e64261be3d96eefe8d2fd37397253cdb14c9 (patch) | |
tree | c623fcfe56b4eb3458b1ddb03c4fc487d3cb76ca /sys | |
parent | afcc405018f894692c6140cc328cf3f54156aae4 (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.c | 21 | ||||
-rw-r--r-- | sys/net80211/ieee80211_node.c | 15 | ||||
-rw-r--r-- | sys/net80211/ieee80211_var.h | 3 |
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 *); |