nl80211: Simplify event processing error paths
These are practically unreachable code since cfg80211 fills in the required attributes or does not send the event. Keep the checks in place, but minimize the extra code in wpa_supplicant/hostapd. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
38751d8bd5
commit
dcf8fbc058
1 changed files with 22 additions and 43 deletions
|
@ -180,7 +180,7 @@ static void mlme_event_auth(struct wpa_driver_nl80211_data *drv,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int nl80211_parse_wmm_params(struct nlattr *wmm_attr,
|
static void nl80211_parse_wmm_params(struct nlattr *wmm_attr,
|
||||||
struct wmm_params *wmm_params)
|
struct wmm_params *wmm_params)
|
||||||
{
|
{
|
||||||
struct nlattr *wmm_info[NL80211_STA_WME_MAX + 1];
|
struct nlattr *wmm_info[NL80211_STA_WME_MAX + 1];
|
||||||
|
@ -188,26 +188,15 @@ static int nl80211_parse_wmm_params(struct nlattr *wmm_attr,
|
||||||
[NL80211_STA_WME_UAPSD_QUEUES] = { .type = NLA_U8 },
|
[NL80211_STA_WME_UAPSD_QUEUES] = { .type = NLA_U8 },
|
||||||
};
|
};
|
||||||
|
|
||||||
if (!wmm_attr) {
|
if (!wmm_attr ||
|
||||||
wpa_printf(MSG_DEBUG, "nl80211: WMM data missing");
|
nla_parse_nested(wmm_info, NL80211_STA_WME_MAX, wmm_attr,
|
||||||
return -1;
|
wme_policy) ||
|
||||||
}
|
!wmm_info[NL80211_STA_WME_UAPSD_QUEUES])
|
||||||
|
return;
|
||||||
if (nla_parse_nested(wmm_info, NL80211_STA_WME_MAX, wmm_attr,
|
|
||||||
wme_policy)) {
|
|
||||||
wpa_printf(MSG_DEBUG,
|
|
||||||
"nl80211: Failed to parse nested attributes");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!wmm_info[NL80211_STA_WME_UAPSD_QUEUES])
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
wmm_params->uapsd_queues =
|
wmm_params->uapsd_queues =
|
||||||
nla_get_u8(wmm_info[NL80211_STA_WME_UAPSD_QUEUES]);
|
nla_get_u8(wmm_info[NL80211_STA_WME_UAPSD_QUEUES]);
|
||||||
wmm_params->info_bitmap |= WMM_PARAMS_UAPSD_QUEUES_INFO;
|
wmm_params->info_bitmap |= WMM_PARAMS_UAPSD_QUEUES_INFO;
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1104,10 +1093,8 @@ static void nl80211_new_peer_candidate(struct wpa_driver_nl80211_data *drv,
|
||||||
const u8 *addr;
|
const u8 *addr;
|
||||||
union wpa_event_data data;
|
union wpa_event_data data;
|
||||||
|
|
||||||
if (drv->nlmode != NL80211_IFTYPE_MESH_POINT)
|
if (drv->nlmode != NL80211_IFTYPE_MESH_POINT ||
|
||||||
return;
|
!tb[NL80211_ATTR_MAC] || !tb[NL80211_ATTR_IE])
|
||||||
|
|
||||||
if (!tb[NL80211_ATTR_MAC] || !tb[NL80211_ATTR_IE])
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
addr = nla_data(tb[NL80211_ATTR_MAC]);
|
addr = nla_data(tb[NL80211_ATTR_MAC]);
|
||||||
|
@ -1201,14 +1188,11 @@ static void nl80211_rekey_offload_event(struct wpa_driver_nl80211_data *drv,
|
||||||
};
|
};
|
||||||
union wpa_event_data data;
|
union wpa_event_data data;
|
||||||
|
|
||||||
if (!tb[NL80211_ATTR_MAC])
|
if (!tb[NL80211_ATTR_MAC] ||
|
||||||
return;
|
!tb[NL80211_ATTR_REKEY_DATA] ||
|
||||||
if (!tb[NL80211_ATTR_REKEY_DATA])
|
nla_parse_nested(rekey_info, MAX_NL80211_REKEY_DATA,
|
||||||
return;
|
tb[NL80211_ATTR_REKEY_DATA], rekey_policy) ||
|
||||||
if (nla_parse_nested(rekey_info, MAX_NL80211_REKEY_DATA,
|
!rekey_info[NL80211_REKEY_DATA_REPLAY_CTR])
|
||||||
tb[NL80211_ATTR_REKEY_DATA], rekey_policy))
|
|
||||||
return;
|
|
||||||
if (!rekey_info[NL80211_REKEY_DATA_REPLAY_CTR])
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
os_memset(&data, 0, sizeof(data));
|
os_memset(&data, 0, sizeof(data));
|
||||||
|
@ -1239,12 +1223,10 @@ static void nl80211_pmksa_candidate_event(struct wpa_driver_nl80211_data *drv,
|
||||||
|
|
||||||
wpa_printf(MSG_DEBUG, "nl80211: PMKSA candidate event");
|
wpa_printf(MSG_DEBUG, "nl80211: PMKSA candidate event");
|
||||||
|
|
||||||
if (!tb[NL80211_ATTR_PMKSA_CANDIDATE])
|
if (!tb[NL80211_ATTR_PMKSA_CANDIDATE] ||
|
||||||
return;
|
nla_parse_nested(cand, MAX_NL80211_PMKSA_CANDIDATE,
|
||||||
if (nla_parse_nested(cand, MAX_NL80211_PMKSA_CANDIDATE,
|
tb[NL80211_ATTR_PMKSA_CANDIDATE], cand_policy) ||
|
||||||
tb[NL80211_ATTR_PMKSA_CANDIDATE], cand_policy))
|
!cand[NL80211_PMKSA_CANDIDATE_INDEX] ||
|
||||||
return;
|
|
||||||
if (!cand[NL80211_PMKSA_CANDIDATE_INDEX] ||
|
|
||||||
!cand[NL80211_PMKSA_CANDIDATE_BSSID])
|
!cand[NL80211_PMKSA_CANDIDATE_BSSID])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -1502,10 +1484,8 @@ static void qca_nl80211_acs_select_ch(struct wpa_driver_nl80211_data *drv,
|
||||||
"nl80211: ACS channel selection vendor event received");
|
"nl80211: ACS channel selection vendor event received");
|
||||||
|
|
||||||
if (nla_parse(tb, QCA_WLAN_VENDOR_ATTR_ACS_MAX,
|
if (nla_parse(tb, QCA_WLAN_VENDOR_ATTR_ACS_MAX,
|
||||||
(struct nlattr *) data, len, NULL))
|
(struct nlattr *) data, len, NULL) ||
|
||||||
return;
|
!tb[QCA_WLAN_VENDOR_ATTR_ACS_PRIMARY_CHANNEL] ||
|
||||||
|
|
||||||
if (!tb[QCA_WLAN_VENDOR_ATTR_ACS_PRIMARY_CHANNEL] ||
|
|
||||||
!tb[QCA_WLAN_VENDOR_ATTR_ACS_SECONDARY_CHANNEL])
|
!tb[QCA_WLAN_VENDOR_ATTR_ACS_SECONDARY_CHANNEL])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -1529,9 +1509,8 @@ static void qca_nl80211_key_mgmt_auth(struct wpa_driver_nl80211_data *drv,
|
||||||
"nl80211: Key management roam+auth vendor event received");
|
"nl80211: Key management roam+auth vendor event received");
|
||||||
|
|
||||||
if (nla_parse(tb, QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_MAX,
|
if (nla_parse(tb, QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_MAX,
|
||||||
(struct nlattr *) data, len, NULL))
|
(struct nlattr *) data, len, NULL) ||
|
||||||
return;
|
!tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_BSSID] ||
|
||||||
if (!tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_BSSID] ||
|
|
||||||
nla_len(tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_BSSID]) != ETH_ALEN ||
|
nla_len(tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_BSSID]) != ETH_ALEN ||
|
||||||
!tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_REQ_IE] ||
|
!tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_REQ_IE] ||
|
||||||
!tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_RESP_IE] ||
|
!tb[QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_RESP_IE] ||
|
||||||
|
|
Loading…
Reference in a new issue