revert handling of ssid and bssid to be manadatory instead of advisory
Prodded by: Kevin Gerry Reviewed by: thompsa, sephe Approved by: re (kensmith)
This commit is contained in:
parent
93fe42b62f
commit
c4ed2c08ad
@ -81,8 +81,6 @@ struct sta_entry {
|
|||||||
uint8_t se_seen; /* seen during current scan */
|
uint8_t se_seen; /* seen during current scan */
|
||||||
uint8_t se_notseen; /* not seen in previous scans */
|
uint8_t se_notseen; /* not seen in previous scans */
|
||||||
uint8_t se_flags;
|
uint8_t se_flags;
|
||||||
#define STA_SSID_MATCH 0x01
|
|
||||||
#define STA_BSSID_MATCH 0x02
|
|
||||||
uint32_t se_avgrssi; /* LPF rssi state */
|
uint32_t se_avgrssi; /* LPF rssi state */
|
||||||
unsigned long se_lastupdate; /* time of last update */
|
unsigned long se_lastupdate; /* time of last update */
|
||||||
unsigned long se_lastfail; /* time of last failure */
|
unsigned long se_lastfail; /* time of last failure */
|
||||||
@ -105,6 +103,21 @@ struct sta_table {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static void sta_flush_table(struct sta_table *);
|
static void sta_flush_table(struct sta_table *);
|
||||||
|
/*
|
||||||
|
* match_bss returns a bitmask describing if an entry is suitable
|
||||||
|
* for use. If non-zero the entry was deemed not suitable and it's
|
||||||
|
* contents explains why. The following flags are or'd to to this
|
||||||
|
* mask and can be used to figure out why the entry was rejected.
|
||||||
|
*/
|
||||||
|
#define MATCH_CHANNEL 0x001 /* channel mismatch */
|
||||||
|
#define MATCH_CAPINFO 0x002 /* capabilities mismatch, e.g. no ess */
|
||||||
|
#define MATCH_PRIVACY 0x004 /* privacy mismatch */
|
||||||
|
#define MATCH_RATE 0x008 /* rate set mismatch */
|
||||||
|
#define MATCH_SSID 0x010 /* ssid mismatch */
|
||||||
|
#define MATCH_BSSID 0x020 /* bssid mismatch */
|
||||||
|
#define MATCH_FAILS 0x040 /* too many failed auth attempts */
|
||||||
|
#define MATCH_NOTSEEN 0x080 /* not seen in recent scans */
|
||||||
|
#define MATCH_RSSI 0x100 /* rssi deemed too low to use */
|
||||||
static int match_bss(struct ieee80211com *,
|
static int match_bss(struct ieee80211com *,
|
||||||
const struct ieee80211_scan_state *, struct sta_entry *, int);
|
const struct ieee80211_scan_state *, struct sta_entry *, int);
|
||||||
|
|
||||||
@ -637,10 +650,6 @@ sta_compare(const struct sta_entry *a, const struct sta_entry *b)
|
|||||||
int8_t rssia, rssib;
|
int8_t rssia, rssib;
|
||||||
int weight;
|
int weight;
|
||||||
|
|
||||||
/* desired bssid */
|
|
||||||
PREFER(a->se_flags, b->se_flags, STA_BSSID_MATCH);
|
|
||||||
/* desired ssid */
|
|
||||||
PREFER(a->se_flags, b->se_flags, STA_SSID_MATCH);
|
|
||||||
/* privacy support */
|
/* privacy support */
|
||||||
PREFER(a->base.se_capinfo, b->base.se_capinfo,
|
PREFER(a->base.se_capinfo, b->base.se_capinfo,
|
||||||
IEEE80211_CAPINFO_PRIVACY);
|
IEEE80211_CAPINFO_PRIVACY);
|
||||||
@ -768,7 +777,7 @@ match_bss(struct ieee80211com *ic,
|
|||||||
|
|
||||||
fail = 0;
|
fail = 0;
|
||||||
if (isclr(ic->ic_chan_active, ieee80211_chan2ieee(ic, se->se_chan)))
|
if (isclr(ic->ic_chan_active, ieee80211_chan2ieee(ic, se->se_chan)))
|
||||||
fail |= 0x01;
|
fail |= MATCH_CHANNEL;
|
||||||
/*
|
/*
|
||||||
* NB: normally the desired mode is used to construct
|
* NB: normally the desired mode is used to construct
|
||||||
* the channel list, but it's possible for the scan
|
* the channel list, but it's possible for the scan
|
||||||
@ -779,64 +788,62 @@ match_bss(struct ieee80211com *ic,
|
|||||||
if (ic->ic_des_mode != IEEE80211_MODE_AUTO &&
|
if (ic->ic_des_mode != IEEE80211_MODE_AUTO &&
|
||||||
(se->se_chan->ic_flags & IEEE80211_CHAN_ALLTURBO) !=
|
(se->se_chan->ic_flags & IEEE80211_CHAN_ALLTURBO) !=
|
||||||
chanflags[ic->ic_des_mode])
|
chanflags[ic->ic_des_mode])
|
||||||
fail |= 0x01;
|
fail |= MATCH_CHANNEL;
|
||||||
if (ic->ic_opmode == IEEE80211_M_IBSS) {
|
if (ic->ic_opmode == IEEE80211_M_IBSS) {
|
||||||
if ((se->se_capinfo & IEEE80211_CAPINFO_IBSS) == 0)
|
if ((se->se_capinfo & IEEE80211_CAPINFO_IBSS) == 0)
|
||||||
fail |= 0x02;
|
fail |= MATCH_CAPINFO;
|
||||||
} else {
|
} else {
|
||||||
if ((se->se_capinfo & IEEE80211_CAPINFO_ESS) == 0)
|
if ((se->se_capinfo & IEEE80211_CAPINFO_ESS) == 0)
|
||||||
fail |= 0x02;
|
fail |= MATCH_CAPINFO;
|
||||||
}
|
}
|
||||||
if (ic->ic_flags & IEEE80211_F_PRIVACY) {
|
if (ic->ic_flags & IEEE80211_F_PRIVACY) {
|
||||||
if ((se->se_capinfo & IEEE80211_CAPINFO_PRIVACY) == 0)
|
if ((se->se_capinfo & IEEE80211_CAPINFO_PRIVACY) == 0)
|
||||||
fail |= 0x04;
|
fail |= MATCH_PRIVACY;
|
||||||
} else {
|
} else {
|
||||||
/* XXX does this mean privacy is supported or required? */
|
/* XXX does this mean privacy is supported or required? */
|
||||||
if (se->se_capinfo & IEEE80211_CAPINFO_PRIVACY)
|
if (se->se_capinfo & IEEE80211_CAPINFO_PRIVACY)
|
||||||
fail |= 0x04;
|
fail |= MATCH_PRIVACY;
|
||||||
}
|
}
|
||||||
rate = check_rate(ic, se);
|
rate = check_rate(ic, se);
|
||||||
if (rate & IEEE80211_RATE_BASIC)
|
if (rate & IEEE80211_RATE_BASIC)
|
||||||
fail |= 0x08;
|
fail |= MATCH_RATE;
|
||||||
if (ss->ss_nssid != 0 &&
|
if (ss->ss_nssid != 0 &&
|
||||||
match_ssid(se->se_ssid, ss->ss_nssid, ss->ss_ssid))
|
!match_ssid(se->se_ssid, ss->ss_nssid, ss->ss_ssid))
|
||||||
se0->se_flags |= STA_SSID_MATCH;
|
fail |= MATCH_SSID;
|
||||||
else
|
|
||||||
se0->se_flags &= ~STA_SSID_MATCH;
|
|
||||||
if ((ic->ic_flags & IEEE80211_F_DESBSSID) &&
|
if ((ic->ic_flags & IEEE80211_F_DESBSSID) &&
|
||||||
IEEE80211_ADDR_EQ(ic->ic_des_bssid, se->se_bssid))
|
!IEEE80211_ADDR_EQ(ic->ic_des_bssid, se->se_bssid))
|
||||||
se0->se_flags |= STA_BSSID_MATCH;
|
fail |= MATCH_BSSID;
|
||||||
else
|
|
||||||
se0->se_flags &= ~STA_BSSID_MATCH;
|
|
||||||
if (se0->se_fails >= STA_FAILS_MAX)
|
if (se0->se_fails >= STA_FAILS_MAX)
|
||||||
fail |= 0x40;
|
fail |= MATCH_FAILS;
|
||||||
|
/* NB: entries may be present awaiting purge, skip */
|
||||||
if (se0->se_notseen >= STA_PURGE_SCANS)
|
if (se0->se_notseen >= STA_PURGE_SCANS)
|
||||||
fail |= 0x80;
|
fail |= MATCH_NOTSEEN;
|
||||||
if (se->se_rssi < STA_RSSI_MIN)
|
if (se->se_rssi < STA_RSSI_MIN)
|
||||||
fail |= 0x100;
|
fail |= MATCH_RSSI;
|
||||||
#ifdef IEEE80211_DEBUG
|
#ifdef IEEE80211_DEBUG
|
||||||
if (ieee80211_msg(ic, debug)) {
|
if (ieee80211_msg(ic, debug)) {
|
||||||
printf(" %c %s",
|
printf(" %c %s",
|
||||||
fail & 0x40 ? '=' : fail & 0x80 ? '^' : fail ? '-' : '+',
|
fail & MATCH_FAILS ? '=' :
|
||||||
ether_sprintf(se->se_macaddr));
|
fail & MATCH_NOTSEEN ? '^' :
|
||||||
|
fail ? '-' : '+', ether_sprintf(se->se_macaddr));
|
||||||
printf(" %s%c", ether_sprintf(se->se_bssid),
|
printf(" %s%c", ether_sprintf(se->se_bssid),
|
||||||
se0->se_flags & STA_BSSID_MATCH ? '*' : ' ');
|
fail & MATCH_BSSID ? '!' : ' ');
|
||||||
printf(" %3d%c", ieee80211_chan2ieee(ic, se->se_chan),
|
printf(" %3d%c", ieee80211_chan2ieee(ic, se->se_chan),
|
||||||
fail & 0x01 ? '!' : ' ');
|
fail & MATCH_CHANNEL ? '!' : ' ');
|
||||||
printf(" %+4d%c", se->se_rssi, fail & 0x100 ? '!' : ' ');
|
printf(" %+4d%c", se->se_rssi, fail & MATCH_RSSI ? '!' : ' ');
|
||||||
printf(" %2dM%c", (rate & IEEE80211_RATE_VAL) / 2,
|
printf(" %2dM%c", (rate & IEEE80211_RATE_VAL) / 2,
|
||||||
fail & 0x08 ? '!' : ' ');
|
fail & MATCH_RATE ? '!' : ' ');
|
||||||
printf(" %4s%c",
|
printf(" %4s%c",
|
||||||
(se->se_capinfo & IEEE80211_CAPINFO_ESS) ? "ess" :
|
(se->se_capinfo & IEEE80211_CAPINFO_ESS) ? "ess" :
|
||||||
(se->se_capinfo & IEEE80211_CAPINFO_IBSS) ? "ibss" :
|
(se->se_capinfo & IEEE80211_CAPINFO_IBSS) ? "ibss" :
|
||||||
"????",
|
"????",
|
||||||
fail & 0x02 ? '!' : ' ');
|
fail & MATCH_CAPINFO ? '!' : ' ');
|
||||||
printf(" %3s%c ",
|
printf(" %3s%c ",
|
||||||
(se->se_capinfo & IEEE80211_CAPINFO_PRIVACY) ?
|
(se->se_capinfo & IEEE80211_CAPINFO_PRIVACY) ?
|
||||||
"wep" : "no",
|
"wep" : "no",
|
||||||
fail & 0x04 ? '!' : ' ');
|
fail & MATCH_PRIVACY ? '!' : ' ');
|
||||||
ieee80211_print_essid(se->se_ssid+2, se->se_ssid[1]);
|
ieee80211_print_essid(se->se_ssid+2, se->se_ssid[1]);
|
||||||
printf("%s\n", se0->se_flags & STA_SSID_MATCH ? "*" : "");
|
printf("%s\n", fail & MATCH_SSID ? "!" : "");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
return fail;
|
return fail;
|
||||||
|
Loading…
Reference in New Issue
Block a user