2008-07-12 22:23:46 +00:00
|
|
|
This patch fixes the detection of hidden SSIDs as transmitted
|
|
|
|
by some cisco systems.
|
|
|
|
|
|
|
|
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
|
|
|
|
|
2008-07-25 22:41:13 +00:00
|
|
|
--- a/net80211/ieee80211_scan_sta.c
|
|
|
|
+++ b/net80211/ieee80211_scan_sta.c
|
2008-11-02 13:04:36 +00:00
|
|
|
@@ -209,6 +209,19 @@ saveie(u_int8_t **iep, const u_int8_t *i
|
2008-07-12 22:23:46 +00:00
|
|
|
ieee80211_saveie(iep, ie);
|
|
|
|
}
|
|
|
|
|
|
|
|
+
|
|
|
|
+static inline int is_empty_ssid(u_int8_t *ssid)
|
|
|
|
+{
|
|
|
|
+ if (!ssid)
|
|
|
|
+ return 1;
|
|
|
|
+ if (ssid[1] == 0)
|
|
|
|
+ return 1;
|
|
|
|
+ if ((ssid[1] == 1) && (ssid[2] == 0))
|
|
|
|
+ return 1;
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+
|
|
|
|
/*
|
|
|
|
* Process a beacon or probe response frame; create an
|
|
|
|
* entry in the scan cache or update any previous entry.
|
2008-11-02 13:04:36 +00:00
|
|
|
@@ -233,8 +246,8 @@ sta_add(struct ieee80211_scan_state *ss,
|
2008-07-25 22:35:56 +00:00
|
|
|
SCAN_STA_LOCK_IRQ(st);
|
|
|
|
LIST_FOREACH(se, &st->st_hash[hash], se_hash)
|
|
|
|
if (IEEE80211_ADDR_EQ(se->base.se_macaddr, macaddr) &&
|
|
|
|
- sp->ssid[1] == se->base.se_ssid[1] &&
|
|
|
|
- !memcmp(se->base.se_ssid+2, sp->ssid+2, se->base.se_ssid[1]))
|
|
|
|
+ (is_empty_ssid(sp->ssid) || (sp->ssid[1] == se->base.se_ssid[1] &&
|
|
|
|
+ !memcmp(se->base.se_ssid+2, sp->ssid+2, se->base.se_ssid[1]))))
|
|
|
|
goto found;
|
|
|
|
|
|
|
|
MALLOC(se, struct sta_entry *, sizeof(struct sta_entry),
|
2008-11-02 13:04:36 +00:00
|
|
|
@@ -252,8 +265,8 @@ found:
|
2008-07-12 22:23:46 +00:00
|
|
|
ise = &se->base;
|
|
|
|
|
|
|
|
/* XXX ap beaconing multiple ssid w/ same bssid */
|
|
|
|
- if (sp->ssid[1] != 0 &&
|
|
|
|
- (ISPROBE(subtype) || ise->se_ssid[1] == 0))
|
|
|
|
+ if (!is_empty_ssid(sp->ssid) &&
|
|
|
|
+ (ISPROBE(subtype) || is_empty_ssid(ise->se_ssid)))
|
|
|
|
memcpy(ise->se_ssid, sp->ssid, 2 + sp->ssid[1]);
|
|
|
|
|
|
|
|
memcpy(ise->se_rates, sp->rates,
|