The net80211 stack currently provides a 'beacon miss timeout' value (in ms)
which specifies how much time may elapse without beacons before drivers
begin searching for a new AP.
Drivers convert this timeout value into the amount of beacons they're allowed
to miss. Having the stack provide this number upfront simplifies things.
ok?
Index: dev/ic/ath.c
===================================================================
RCS file: /cvs/src/sys/dev/ic/ath.c,v
retrieving revision 1.114
diff -u -p -r1.114 ath.c
--- dev/ic/ath.c 11 Apr 2017 14:43:49 -0000 1.114
+++ dev/ic/ath.c 31 May 2017 08:35:14 -0000
@@ -1417,7 +1417,6 @@ ath_beacon_config(struct ath_softc *sc)
__func__, ni->ni_intval, nexttbtt));
if (ic->ic_opmode == IEEE80211_M_STA) {
HAL_BEACON_STATE bs;
- u_int32_t bmisstime;
/* NB: no PCF support right now */
bzero(&bs, sizeof(bs));
@@ -1427,13 +1426,10 @@ ath_beacon_config(struct ath_softc *sc)
bs.bs_nextdtim = nexttbtt;
/*
* Calculate the number of consecutive beacons to miss
- * before taking a BMISS interrupt. The configuration
- * is specified in ms, so we need to convert that to
- * TU's and then calculate based on the beacon interval.
- * Note that we clamp the result to at most 10 beacons.
+ * before taking a BMISS interrupt.
+ * Note that we clamp the result to at most 7 beacons.
*/
- bmisstime = MAX(7, ic->ic_bmisstimeout);
- bs.bs_bmissthreshold = howmany(bmisstime, intval);
+ bs.bs_bmissthreshold = ic->ic_bmissthres;
if (bs.bs_bmissthreshold > 7) {
bs.bs_bmissthreshold = 7;
} else if (bs.bs_bmissthreshold <= 0) {
Index: dev/pci/if_iwm.c
===================================================================
RCS file: /cvs/src/sys/dev/pci/if_iwm.c,v
retrieving revision 1.186
diff -u -p -r1.186 if_iwm.c
--- dev/pci/if_iwm.c 31 May 2017 08:33:11 -0000 1.186
+++ dev/pci/if_iwm.c 31 May 2017 08:50:13 -0000
@@ -3542,7 +3542,6 @@ iwm_rx_bmiss(struct iwm_softc *sc, struc
struct iwm_rx_data *data)
{
struct ieee80211com *ic = &sc->sc_ic;
- int bmiss_threshold = ic->ic_bmisstimeout / ic->ic_lintval;
struct iwm_missed_beacons_notif *mbn = (void *)pkt->data;
if ((ic->ic_opmode != IEEE80211_M_STA) ||
@@ -3552,7 +3551,7 @@ iwm_rx_bmiss(struct iwm_softc *sc, struc
bus_dmamap_sync(sc->sc_dmat, data->map, sizeof(*pkt),
sizeof(*mbn), BUS_DMASYNC_POSTREAD);
- if (mbn->consec_missed_beacons_since_last_rx > bmiss_threshold) {
+ if (mbn->consec_missed_beacons_since_last_rx > ic->ic_bmissthres) {
/*
* Rather than go directly to scan state, try to send a
* directed probe request first. If that fails then the
Index: net80211/ieee80211.c
===================================================================
RCS file: /cvs/src/sys/net80211/ieee80211.c,v
retrieving revision 1.60
diff -u -p -r1.60 ieee80211.c
--- net80211/ieee80211.c 30 May 2017 16:21:55 -0000 1.60
+++ net80211/ieee80211.c 31 May 2017 08:35:05 -0000
@@ -147,7 +147,7 @@ ieee80211_ifattach(struct ifnet *ifp)
if (ic->ic_lintval == 0)
ic->ic_lintval = 100; /* default sleep */
- ic->ic_bmisstimeout = 7*ic->ic_lintval; /* default 7 beacons */
+ ic->ic_bmissthres = 7; /* default 7 beacons */
ic->ic_dtim_period = 1; /* all TIMs are DTIMs */
LIST_INSERT_HEAD(&ieee80211com_head, ic, ic_list);
Index: net80211/ieee80211_var.h
===================================================================
RCS file: /cvs/src/sys/net80211/ieee80211_var.h,v
retrieving revision 1.78
diff -u -p -r1.78 ieee80211_var.h
--- net80211/ieee80211_var.h 30 May 2017 11:00:38 -0000 1.78
+++ net80211/ieee80211_var.h 31 May 2017 08:34:47 -0000
@@ -262,7 +262,7 @@ struct ieee80211com {
int ic_max_nnodes; /* max length of ic_nnodes */
u_int16_t ic_lintval; /* listen interval */
int16_t ic_txpower; /* tx power setting (dBm) */
- u_int16_t ic_bmisstimeout;/* beacon miss threshold (ms) */
+ int ic_bmissthres; /* beacon miss threshold */
int ic_mgt_timer; /* mgmt timeout */
#ifndef IEEE80211_STA_ONLY
struct timeout ic_inact_timeout; /* node inactivity timeout */