nl80211: Provide link_id in EAPOL_RX and RX_MGMT events

Signed-off-by: Andrei Otcheretianski <andrei.otcheretianski@intel.com>
This commit is contained in:
Andrei Otcheretianski 2023-02-16 01:08:19 +02:00 committed by Jouni Malinen
parent 821374d43a
commit 2f8fc46ede
2 changed files with 38 additions and 10 deletions

View file

@ -6111,6 +6111,12 @@ union wpa_event_data {
* ssi_signal - Signal strength in dBm (or 0 if not available) * ssi_signal - Signal strength in dBm (or 0 if not available)
*/ */
int ssi_signal; int ssi_signal;
/**
* link_id - MLO link on which the frame was received or -1 for
* non MLD.
*/
int link_id;
} rx_mgmt; } rx_mgmt;
/** /**
@ -6211,6 +6217,7 @@ union wpa_event_data {
const u8 *data; const u8 *data;
size_t data_len; size_t data_len;
enum frame_encryption encrypted; enum frame_encryption encrypted;
int link_id;
} eapol_rx; } eapol_rx;
/** /**
@ -6565,12 +6572,14 @@ static inline void drv_event_eapol_rx(void *ctx, const u8 *src, const u8 *data,
event.eapol_rx.data = data; event.eapol_rx.data = data;
event.eapol_rx.data_len = data_len; event.eapol_rx.data_len = data_len;
event.eapol_rx.encrypted = FRAME_ENCRYPTION_UNKNOWN; event.eapol_rx.encrypted = FRAME_ENCRYPTION_UNKNOWN;
event.eapol_rx.link_id = -1;
wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event); wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
} }
static inline void drv_event_eapol_rx2(void *ctx, const u8 *src, const u8 *data, static inline void drv_event_eapol_rx2(void *ctx, const u8 *src, const u8 *data,
size_t data_len, size_t data_len,
enum frame_encryption encrypted) enum frame_encryption encrypted,
int link_id)
{ {
union wpa_event_data event; union wpa_event_data event;
os_memset(&event, 0, sizeof(event)); os_memset(&event, 0, sizeof(event));
@ -6578,6 +6587,7 @@ static inline void drv_event_eapol_rx2(void *ctx, const u8 *src, const u8 *data,
event.eapol_rx.data = data; event.eapol_rx.data = data;
event.eapol_rx.data_len = data_len; event.eapol_rx.data_len = data_len;
event.eapol_rx.encrypted = encrypted; event.eapol_rx.encrypted = encrypted;
event.eapol_rx.link_id = link_id;
wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event); wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
} }

View file

@ -1111,7 +1111,8 @@ static void mlme_timeout_event(struct wpa_driver_nl80211_data *drv,
static void mlme_event_mgmt(struct i802_bss *bss, static void mlme_event_mgmt(struct i802_bss *bss,
struct nlattr *freq, struct nlattr *sig, struct nlattr *freq, struct nlattr *sig,
const u8 *frame, size_t len) const u8 *frame, size_t len,
int link_id)
{ {
struct wpa_driver_nl80211_data *drv = bss->drv; struct wpa_driver_nl80211_data *drv = bss->drv;
const struct ieee80211_mgmt *mgmt; const struct ieee80211_mgmt *mgmt;
@ -1149,6 +1150,8 @@ static void mlme_event_mgmt(struct i802_bss *bss,
event.rx_mgmt.frame_len = len; event.rx_mgmt.frame_len = len;
event.rx_mgmt.ssi_signal = ssi_signal; event.rx_mgmt.ssi_signal = ssi_signal;
event.rx_mgmt.drv_priv = bss; event.rx_mgmt.drv_priv = bss;
event.rx_mgmt.link_id = link_id;
wpa_supplicant_event(drv->ctx, EVENT_RX_MGMT, &event); wpa_supplicant_event(drv->ctx, EVENT_RX_MGMT, &event);
} }
@ -1403,12 +1406,14 @@ static void mlme_event(struct i802_bss *bss,
struct nlattr *addr, struct nlattr *timed_out, struct nlattr *addr, struct nlattr *timed_out,
struct nlattr *freq, struct nlattr *ack, struct nlattr *freq, struct nlattr *ack,
struct nlattr *cookie, struct nlattr *sig, struct nlattr *cookie, struct nlattr *sig,
struct nlattr *wmm, struct nlattr *req_ie) struct nlattr *wmm, struct nlattr *req_ie,
struct nlattr *link)
{ {
struct wpa_driver_nl80211_data *drv = bss->drv; struct wpa_driver_nl80211_data *drv = bss->drv;
u16 stype = 0, auth_type = 0; u16 stype = 0, auth_type = 0;
const u8 *data; const u8 *data;
size_t len; size_t len;
int link_id;
if (timed_out && addr) { if (timed_out && addr) {
mlme_timeout_event(drv, cmd, addr); mlme_timeout_event(drv, cmd, addr);
@ -1422,6 +1427,11 @@ static void mlme_event(struct i802_bss *bss,
return; return;
} }
if (link)
link_id = nla_get_u8(link);
else
link_id = -1;
data = nla_data(frame); data = nla_data(frame);
len = nla_len(frame); len = nla_len(frame);
if (len < 4 + 2 * ETH_ALEN) { if (len < 4 + 2 * ETH_ALEN) {
@ -1432,10 +1442,10 @@ static void mlme_event(struct i802_bss *bss,
return; return;
} }
wpa_printf(MSG_MSGDUMP, "nl80211: MLME event %d (%s) on %s(" MACSTR wpa_printf(MSG_MSGDUMP, "nl80211: MLME event %d (%s) on %s(" MACSTR
") A1=" MACSTR " A2=" MACSTR, cmd, ") A1=" MACSTR " A2=" MACSTR " on link_id=%d", cmd,
nl80211_command_to_string(cmd), bss->ifname, nl80211_command_to_string(cmd), bss->ifname,
MAC2STR(bss->addr), MAC2STR(data + 4), MAC2STR(bss->addr), MAC2STR(data + 4),
MAC2STR(data + 4 + ETH_ALEN)); MAC2STR(data + 4 + ETH_ALEN), link_id);
/* PASN Authentication frame can be received with a different source MAC /* PASN Authentication frame can be received with a different source MAC
* address. Allow NL80211_CMD_FRAME event with foreign addresses also. * address. Allow NL80211_CMD_FRAME event with foreign addresses also.
@ -1489,7 +1499,7 @@ static void mlme_event(struct i802_bss *bss,
break; break;
case NL80211_CMD_FRAME: case NL80211_CMD_FRAME:
mlme_event_mgmt(bss, freq, sig, nla_data(frame), mlme_event_mgmt(bss, freq, sig, nla_data(frame),
nla_len(frame)); nla_len(frame), link_id);
break; break;
case NL80211_CMD_FRAME_TX_STATUS: case NL80211_CMD_FRAME_TX_STATUS:
mlme_event_mgmt_tx_status(drv, cookie, nla_data(frame), mlme_event_mgmt_tx_status(drv, cookie, nla_data(frame),
@ -3282,6 +3292,7 @@ static void nl80211_control_port_frame(struct wpa_driver_nl80211_data *drv,
u8 *src_addr; u8 *src_addr;
u16 ethertype; u16 ethertype;
enum frame_encryption encrypted; enum frame_encryption encrypted;
int link_id;
if (!tb[NL80211_ATTR_MAC] || if (!tb[NL80211_ATTR_MAC] ||
!tb[NL80211_ATTR_FRAME] || !tb[NL80211_ATTR_FRAME] ||
@ -3293,6 +3304,11 @@ static void nl80211_control_port_frame(struct wpa_driver_nl80211_data *drv,
encrypted = nla_get_flag(tb[NL80211_ATTR_CONTROL_PORT_NO_ENCRYPT]) ? encrypted = nla_get_flag(tb[NL80211_ATTR_CONTROL_PORT_NO_ENCRYPT]) ?
FRAME_NOT_ENCRYPTED : FRAME_ENCRYPTED; FRAME_NOT_ENCRYPTED : FRAME_ENCRYPTED;
if (tb[NL80211_ATTR_MLO_LINK_ID])
link_id = nla_get_u8(tb[NL80211_ATTR_MLO_LINK_ID]);
else
link_id = -1;
switch (ethertype) { switch (ethertype) {
case ETH_P_RSN_PREAUTH: case ETH_P_RSN_PREAUTH:
wpa_printf(MSG_INFO, "nl80211: Got pre-auth frame from " wpa_printf(MSG_INFO, "nl80211: Got pre-auth frame from "
@ -3303,7 +3319,7 @@ static void nl80211_control_port_frame(struct wpa_driver_nl80211_data *drv,
drv_event_eapol_rx2(drv->ctx, src_addr, drv_event_eapol_rx2(drv->ctx, src_addr,
nla_data(tb[NL80211_ATTR_FRAME]), nla_data(tb[NL80211_ATTR_FRAME]),
nla_len(tb[NL80211_ATTR_FRAME]), nla_len(tb[NL80211_ATTR_FRAME]),
encrypted); encrypted, link_id);
break; break;
default: default:
wpa_printf(MSG_INFO, wpa_printf(MSG_INFO,
@ -3553,7 +3569,8 @@ static void do_process_drv_event(struct i802_bss *bss, int cmd,
tb[NL80211_ATTR_COOKIE], tb[NL80211_ATTR_COOKIE],
tb[NL80211_ATTR_RX_SIGNAL_DBM], tb[NL80211_ATTR_RX_SIGNAL_DBM],
tb[NL80211_ATTR_STA_WME], tb[NL80211_ATTR_STA_WME],
tb[NL80211_ATTR_REQ_IE]); tb[NL80211_ATTR_REQ_IE],
tb[NL80211_ATTR_MLO_LINK_ID]);
break; break;
case NL80211_CMD_CONNECT: case NL80211_CMD_CONNECT:
case NL80211_CMD_ROAM: case NL80211_CMD_ROAM:
@ -3779,7 +3796,8 @@ int process_bss_event(struct nl_msg *msg, void *arg)
tb[NL80211_ATTR_WIPHY_FREQ], tb[NL80211_ATTR_ACK], tb[NL80211_ATTR_WIPHY_FREQ], tb[NL80211_ATTR_ACK],
tb[NL80211_ATTR_COOKIE], tb[NL80211_ATTR_COOKIE],
tb[NL80211_ATTR_RX_SIGNAL_DBM], tb[NL80211_ATTR_RX_SIGNAL_DBM],
tb[NL80211_ATTR_STA_WME], NULL); tb[NL80211_ATTR_STA_WME], NULL,
tb[NL80211_ATTR_MLO_LINK_ID]);
break; break;
case NL80211_CMD_UNEXPECTED_FRAME: case NL80211_CMD_UNEXPECTED_FRAME:
nl80211_spurious_frame(bss, tb, 0); nl80211_spurious_frame(bss, tb, 0);