WNM: Always parse candidate list
The preferred candidate list included bit just makes parsing the list mandatory. The AP may still include a candidate list which we should use to be able to optimize scanning. As such, always parse out the list but still verify that if the list is not empty if the bit is set. Signed-off-by: Benjamin Berg <benjamin.berg@intel.com>
This commit is contained in:
parent
d9d8627873
commit
54b25b7c1d
1 changed files with 16 additions and 13 deletions
|
@ -1373,12 +1373,6 @@ static void wnm_set_scan_freqs(struct wpa_supplicant *wpa_s)
|
||||||
static int wnm_parse_candidate_list(struct wpa_supplicant *wpa_s,
|
static int wnm_parse_candidate_list(struct wpa_supplicant *wpa_s,
|
||||||
const u8 *pos, const u8 *end)
|
const u8 *pos, const u8 *end)
|
||||||
{
|
{
|
||||||
wpa_s->wnm_neighbor_report_elements = os_calloc(
|
|
||||||
WNM_MAX_NEIGHBOR_REPORT,
|
|
||||||
sizeof(struct neighbor_report));
|
|
||||||
if (wpa_s->wnm_neighbor_report_elements == NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
while (end - pos >= 2 &&
|
while (end - pos >= 2 &&
|
||||||
wpa_s->wnm_num_neighbor_report < WNM_MAX_NEIGHBOR_REPORT) {
|
wpa_s->wnm_num_neighbor_report < WNM_MAX_NEIGHBOR_REPORT) {
|
||||||
u8 tag = *pos++;
|
u8 tag = *pos++;
|
||||||
|
@ -1392,6 +1386,14 @@ static int wnm_parse_candidate_list(struct wpa_supplicant *wpa_s,
|
||||||
if (tag == WLAN_EID_NEIGHBOR_REPORT) {
|
if (tag == WLAN_EID_NEIGHBOR_REPORT) {
|
||||||
struct neighbor_report *rep;
|
struct neighbor_report *rep;
|
||||||
|
|
||||||
|
if (!wpa_s->wnm_num_neighbor_report) {
|
||||||
|
wpa_s->wnm_neighbor_report_elements = os_calloc(
|
||||||
|
WNM_MAX_NEIGHBOR_REPORT,
|
||||||
|
sizeof(struct neighbor_report));
|
||||||
|
if (!wpa_s->wnm_neighbor_report_elements)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
rep = &wpa_s->wnm_neighbor_report_elements[
|
rep = &wpa_s->wnm_neighbor_report_elements[
|
||||||
wpa_s->wnm_num_neighbor_report];
|
wpa_s->wnm_num_neighbor_report];
|
||||||
wnm_parse_neighbor_report(wpa_s, pos, len, rep);
|
wnm_parse_neighbor_report(wpa_s, pos, len, rep);
|
||||||
|
@ -1562,14 +1564,10 @@ static void ieee802_11_rx_bss_trans_mgmt_req(struct wpa_supplicant *wpa_s,
|
||||||
wpas_mbo_ie_trans_req(wpa_s, vendor + 2, vendor[1]);
|
wpas_mbo_ie_trans_req(wpa_s, vendor + 2, vendor[1]);
|
||||||
#endif /* CONFIG_MBO */
|
#endif /* CONFIG_MBO */
|
||||||
|
|
||||||
|
if (wnm_parse_candidate_list(wpa_s, pos, end) < 0)
|
||||||
|
goto reset;
|
||||||
|
|
||||||
if (wpa_s->wnm_mode & WNM_BSS_TM_REQ_PREF_CAND_LIST_INCLUDED) {
|
if (wpa_s->wnm_mode & WNM_BSS_TM_REQ_PREF_CAND_LIST_INCLUDED) {
|
||||||
unsigned int valid_ms;
|
|
||||||
|
|
||||||
wpa_msg(wpa_s, MSG_INFO, "WNM: Preferred List Available");
|
|
||||||
|
|
||||||
if (wnm_parse_candidate_list(wpa_s, pos, end) < 0)
|
|
||||||
goto reset;
|
|
||||||
|
|
||||||
if (!wpa_s->wnm_num_neighbor_report) {
|
if (!wpa_s->wnm_num_neighbor_report) {
|
||||||
wpa_printf(MSG_DEBUG,
|
wpa_printf(MSG_DEBUG,
|
||||||
"WNM: Candidate list included bit is set, but no candidates found");
|
"WNM: Candidate list included bit is set, but no candidates found");
|
||||||
|
@ -1579,6 +1577,11 @@ static void ieee802_11_rx_bss_trans_mgmt_req(struct wpa_supplicant *wpa_s,
|
||||||
NULL);
|
NULL);
|
||||||
goto reset;
|
goto reset;
|
||||||
}
|
}
|
||||||
|
wpa_msg(wpa_s, MSG_INFO, "WNM: Preferred List Available");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wpa_s->wnm_num_neighbor_report) {
|
||||||
|
unsigned int valid_ms;
|
||||||
|
|
||||||
wnm_sort_cand_list(wpa_s);
|
wnm_sort_cand_list(wpa_s);
|
||||||
wnm_dump_cand_list(wpa_s);
|
wnm_dump_cand_list(wpa_s);
|
||||||
|
|
Loading…
Reference in a new issue