libertas: better scan response debugging
Make it a bit easier to debug scan results in the future. Signed-off-by: Dan Williams <dcbw@redhat.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
1e51b2ff0a
commit
4083858c8b
|
@ -524,20 +524,31 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy,
|
||||||
|
|
||||||
pos = scanresp->bssdesc_and_tlvbuffer;
|
pos = scanresp->bssdesc_and_tlvbuffer;
|
||||||
|
|
||||||
|
lbs_deb_hex(LBS_DEB_SCAN, "SCAN_RSP", scanresp->bssdesc_and_tlvbuffer,
|
||||||
|
scanresp->bssdescriptsize);
|
||||||
|
|
||||||
tsfdesc = pos + bsssize;
|
tsfdesc = pos + bsssize;
|
||||||
tsfsize = 4 + 8 * scanresp->nr_sets;
|
tsfsize = 4 + 8 * scanresp->nr_sets;
|
||||||
|
lbs_deb_hex(LBS_DEB_SCAN, "SCAN_TSF", (u8 *) tsfdesc, tsfsize);
|
||||||
|
|
||||||
/* Validity check: we expect a Marvell-Local TLV */
|
/* Validity check: we expect a Marvell-Local TLV */
|
||||||
i = get_unaligned_le16(tsfdesc);
|
i = get_unaligned_le16(tsfdesc);
|
||||||
tsfdesc += 2;
|
tsfdesc += 2;
|
||||||
if (i != TLV_TYPE_TSFTIMESTAMP)
|
if (i != TLV_TYPE_TSFTIMESTAMP) {
|
||||||
|
lbs_deb_scan("scan response: invalid TSF Timestamp %d\n", i);
|
||||||
goto done;
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
/* Validity check: the TLV holds TSF values with 8 bytes each, so
|
/* Validity check: the TLV holds TSF values with 8 bytes each, so
|
||||||
* the size in the TLV must match the nr_sets value */
|
* the size in the TLV must match the nr_sets value */
|
||||||
i = get_unaligned_le16(tsfdesc);
|
i = get_unaligned_le16(tsfdesc);
|
||||||
tsfdesc += 2;
|
tsfdesc += 2;
|
||||||
if (i / 8 != scanresp->nr_sets)
|
if (i / 8 != scanresp->nr_sets) {
|
||||||
|
lbs_deb_scan("scan response: invalid number of TSF timestamp "
|
||||||
|
"sets (expected %d got %d)\n", scanresp->nr_sets,
|
||||||
|
i / 8);
|
||||||
goto done;
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
for (i = 0; i < scanresp->nr_sets; i++) {
|
for (i = 0; i < scanresp->nr_sets; i++) {
|
||||||
const u8 *bssid;
|
const u8 *bssid;
|
||||||
|
@ -579,8 +590,11 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy,
|
||||||
id = *pos++;
|
id = *pos++;
|
||||||
elen = *pos++;
|
elen = *pos++;
|
||||||
left -= 2;
|
left -= 2;
|
||||||
if (elen > left || elen == 0)
|
if (elen > left || elen == 0) {
|
||||||
|
lbs_deb_scan("scan response: invalid IE fmt\n");
|
||||||
goto done;
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
if (id == WLAN_EID_DS_PARAMS)
|
if (id == WLAN_EID_DS_PARAMS)
|
||||||
chan_no = *pos;
|
chan_no = *pos;
|
||||||
if (id == WLAN_EID_SSID) {
|
if (id == WLAN_EID_SSID) {
|
||||||
|
@ -611,7 +625,9 @@ static int lbs_ret_scan(struct lbs_private *priv, unsigned long dummy,
|
||||||
capa, intvl, ie, ielen,
|
capa, intvl, ie, ielen,
|
||||||
LBS_SCAN_RSSI_TO_MBM(rssi),
|
LBS_SCAN_RSSI_TO_MBM(rssi),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
}
|
} else
|
||||||
|
lbs_deb_scan("scan response: missing BSS channel IE\n");
|
||||||
|
|
||||||
tsfdesc += 8;
|
tsfdesc += 8;
|
||||||
}
|
}
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
Loading…
Reference in New Issue