OCV: Report OCI validation failures with OCV-FAILURE messages (STA)
Convert the previously used text log entries to use the more formal OCV-FAILURE prefix and always send these as control interface events to allow upper layers to get information about unexpected operating channel mismatches. Signed-off-by: Jouni Malinen <jouni@codeaurora.org>
This commit is contained in:
parent
661e661186
commit
8c1f61e820
3 changed files with 18 additions and 8 deletions
|
@ -22,6 +22,7 @@
|
||||||
#include "common/ieee802_11_common.h"
|
#include "common/ieee802_11_common.h"
|
||||||
#include "common/ocv.h"
|
#include "common/ocv.h"
|
||||||
#include "common/dpp.h"
|
#include "common/dpp.h"
|
||||||
|
#include "common/wpa_ctrl.h"
|
||||||
#include "eap_common/eap_defs.h"
|
#include "eap_common/eap_defs.h"
|
||||||
#include "eapol_supp/eapol_supp_sm.h"
|
#include "eapol_supp/eapol_supp_sm.h"
|
||||||
#include "drivers/driver.h"
|
#include "drivers/driver.h"
|
||||||
|
@ -1717,8 +1718,9 @@ static void wpa_supplicant_process_3_of_4(struct wpa_sm *sm,
|
||||||
if (ocv_verify_tx_params(ie.oci, ie.oci_len, &ci,
|
if (ocv_verify_tx_params(ie.oci, ie.oci_len, &ci,
|
||||||
channel_width_to_int(ci.chanwidth),
|
channel_width_to_int(ci.chanwidth),
|
||||||
ci.seg1_idx) != 0) {
|
ci.seg1_idx) != 0) {
|
||||||
wpa_msg(sm->ctx->msg_ctx, MSG_WARNING, "OCV failed: %s",
|
wpa_msg(sm->ctx->msg_ctx, MSG_INFO, OCV_FAILURE
|
||||||
ocv_errorstr);
|
"addr=" MACSTR " frame=eapol-key-m3 error=%s",
|
||||||
|
MAC2STR(sm->bssid), ocv_errorstr);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1864,8 +1866,9 @@ static int wpa_supplicant_process_1_of_2_rsn(struct wpa_sm *sm,
|
||||||
if (ocv_verify_tx_params(ie.oci, ie.oci_len, &ci,
|
if (ocv_verify_tx_params(ie.oci, ie.oci_len, &ci,
|
||||||
channel_width_to_int(ci.chanwidth),
|
channel_width_to_int(ci.chanwidth),
|
||||||
ci.seg1_idx) != 0) {
|
ci.seg1_idx) != 0) {
|
||||||
wpa_msg(sm->ctx->msg_ctx, MSG_WARNING, "OCV failed: %s",
|
wpa_msg(sm->ctx->msg_ctx, MSG_INFO, OCV_FAILURE
|
||||||
ocv_errorstr);
|
"addr=" MACSTR " frame=eapol-key-g1 error=%s",
|
||||||
|
MAC2STR(sm->bssid), ocv_errorstr);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4764,8 +4767,9 @@ int fils_process_assoc_resp(struct wpa_sm *sm, const u8 *resp, size_t len)
|
||||||
if (ocv_verify_tx_params(elems.oci, elems.oci_len, &ci,
|
if (ocv_verify_tx_params(elems.oci, elems.oci_len, &ci,
|
||||||
channel_width_to_int(ci.chanwidth),
|
channel_width_to_int(ci.chanwidth),
|
||||||
ci.seg1_idx) != 0) {
|
ci.seg1_idx) != 0) {
|
||||||
wpa_printf(MSG_WARNING, "FILS: OCV failed: %s",
|
wpa_msg(sm->ctx->msg_ctx, MSG_INFO, OCV_FAILURE
|
||||||
ocv_errorstr);
|
"addr=" MACSTR " frame=fils-assoc error=%s",
|
||||||
|
MAC2STR(sm->bssid), ocv_errorstr);
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
#include "common/ieee802_11_defs.h"
|
#include "common/ieee802_11_defs.h"
|
||||||
#include "common/ieee802_11_common.h"
|
#include "common/ieee802_11_common.h"
|
||||||
#include "common/ocv.h"
|
#include "common/ocv.h"
|
||||||
|
#include "common/wpa_ctrl.h"
|
||||||
#include "drivers/driver.h"
|
#include "drivers/driver.h"
|
||||||
#include "wpa.h"
|
#include "wpa.h"
|
||||||
#include "wpa_i.h"
|
#include "wpa_i.h"
|
||||||
|
@ -1159,7 +1160,9 @@ int wpa_ft_validate_reassoc_resp(struct wpa_sm *sm, const u8 *ies,
|
||||||
if (ocv_verify_tx_params(parse.oci, parse.oci_len, &ci,
|
if (ocv_verify_tx_params(parse.oci, parse.oci_len, &ci,
|
||||||
channel_width_to_int(ci.chanwidth),
|
channel_width_to_int(ci.chanwidth),
|
||||||
ci.seg1_idx) != 0) {
|
ci.seg1_idx) != 0) {
|
||||||
wpa_printf(MSG_WARNING, "OCV failed: %s", ocv_errorstr);
|
wpa_msg(sm->ctx->msg_ctx, MSG_INFO, OCV_FAILURE
|
||||||
|
"addr=" MACSTR " frame=ft-assoc error=%s",
|
||||||
|
MAC2STR(sm->bssid), ocv_errorstr);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2827,7 +2827,10 @@ void sme_sa_query_rx(struct wpa_supplicant *wpa_s, const u8 *sa,
|
||||||
if (ocv_verify_tx_params(elems.oci, elems.oci_len, &ci,
|
if (ocv_verify_tx_params(elems.oci, elems.oci_len, &ci,
|
||||||
channel_width_to_int(ci.chanwidth),
|
channel_width_to_int(ci.chanwidth),
|
||||||
ci.seg1_idx) != 0) {
|
ci.seg1_idx) != 0) {
|
||||||
wpa_printf(MSG_WARNING, "OCV failed: %s", ocv_errorstr);
|
wpa_msg(wpa_s, MSG_INFO, OCV_FAILURE "addr=" MACSTR
|
||||||
|
" frame=saquery%s error=%s",
|
||||||
|
MAC2STR(sa), data[0] == WLAN_SA_QUERY_REQUEST ?
|
||||||
|
"req" : "resp", ocv_errorstr);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue