Add drv_event_eapol_rx() helper
This commit is contained in:
parent
1d041bec84
commit
baac649094
10 changed files with 29 additions and 75 deletions
|
@ -2305,4 +2305,15 @@ static inline void drv_event_disassoc(void *ctx, const u8 *addr)
|
||||||
wpa_supplicant_event(ctx, EVENT_DISASSOC, &event);
|
wpa_supplicant_event(ctx, EVENT_DISASSOC, &event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void drv_event_eapol_rx(void *ctx, const u8 *src, const u8 *data,
|
||||||
|
size_t data_len)
|
||||||
|
{
|
||||||
|
union wpa_event_data event;
|
||||||
|
os_memset(&event, 0, sizeof(event));
|
||||||
|
event.eapol_rx.src = src;
|
||||||
|
event.eapol_rx.data = data;
|
||||||
|
event.eapol_rx.data_len = data_len;
|
||||||
|
wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* DRIVER_H */
|
#endif /* DRIVER_H */
|
||||||
|
|
|
@ -1071,12 +1071,8 @@ static void
|
||||||
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
|
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
|
||||||
{
|
{
|
||||||
struct madwifi_driver_data *drv = ctx;
|
struct madwifi_driver_data *drv = ctx;
|
||||||
union wpa_event_data event;
|
drv_event_eapol_rx(drv->hapd, src_addr, buf + sizeof(struct l2_ethhdr),
|
||||||
os_memset(&event, 0, sizeof(event));
|
len - sizeof(struct l2_ethhdr));
|
||||||
event.eapol_rx.src = src_addr;
|
|
||||||
event.eapol_rx.data = buf + sizeof(struct l2_ethhdr);
|
|
||||||
event.eapol_rx.data_len = len - sizeof(struct l2_ethhdr);
|
|
||||||
wpa_supplicant_event(drv->hapd, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void *
|
static void *
|
||||||
|
|
|
@ -736,12 +736,8 @@ static void
|
||||||
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
|
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
|
||||||
{
|
{
|
||||||
struct bsd_driver_data *drv = ctx;
|
struct bsd_driver_data *drv = ctx;
|
||||||
union wpa_event_data event;
|
drv_event_eapol_rx(drv->hapd, src_addr, buf + sizeof(struct l2_ethhdr),
|
||||||
os_memset(&event, 0, sizeof(event));
|
len - sizeof(struct l2_ethhdr));
|
||||||
event.eapol_rx.src = src_addr;
|
|
||||||
event.eapol_rx.data = buf + sizeof(struct l2_ethhdr);
|
|
||||||
event.eapol_rx.data_len = len - sizeof(struct l2_ethhdr);
|
|
||||||
wpa_supplicant_event(drv->hapd, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
|
|
@ -112,11 +112,7 @@ static void handle_data(struct hostap_driver_data *drv, u8 *buf, size_t len,
|
||||||
left -= 2;
|
left -= 2;
|
||||||
switch (ethertype) {
|
switch (ethertype) {
|
||||||
case ETH_P_PAE:
|
case ETH_P_PAE:
|
||||||
os_memset(&event, 0, sizeof(event));
|
drv_event_eapol_rx(drv->hapd, sa, pos, left);
|
||||||
event.eapol_rx.src = sa;
|
|
||||||
event.eapol_rx.data = pos;
|
|
||||||
event.eapol_rx.data_len = left;
|
|
||||||
wpa_supplicant_event(drv->hapd, EVENT_EAPOL_RX, &event);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -1141,12 +1141,8 @@ static void
|
||||||
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
|
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
|
||||||
{
|
{
|
||||||
struct madwifi_driver_data *drv = ctx;
|
struct madwifi_driver_data *drv = ctx;
|
||||||
union wpa_event_data event;
|
drv_event_eapol_rx(drv->hapd, src_addr, buf + sizeof(struct l2_ethhdr),
|
||||||
os_memset(&event, 0, sizeof(event));
|
len - sizeof(struct l2_ethhdr));
|
||||||
event.eapol_rx.src = src_addr;
|
|
||||||
event.eapol_rx.data = buf + sizeof(struct l2_ethhdr);
|
|
||||||
event.eapol_rx.data_len = len - sizeof(struct l2_ethhdr);
|
|
||||||
wpa_supplicant_event(drv->hapd, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void *
|
static void *
|
||||||
|
|
|
@ -4233,14 +4233,8 @@ static void handle_eapol(int sock, void *eloop_ctx, void *sock_ctx)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (have_ifidx(drv, lladdr.sll_ifindex)) {
|
if (have_ifidx(drv, lladdr.sll_ifindex))
|
||||||
union wpa_event_data event;
|
drv_event_eapol_rx(drv->ctx, lladdr.sll_addr, buf, len);
|
||||||
os_memset(&event, 0, sizeof(event));
|
|
||||||
event.eapol_rx.src = lladdr.sll_addr;
|
|
||||||
event.eapol_rx.data = buf;
|
|
||||||
event.eapol_rx.data_len = len;
|
|
||||||
wpa_supplicant_event(drv->ctx, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -432,16 +432,9 @@ static void wpa_driver_privsep_event_ft_response(void *ctx, u8 *buf,
|
||||||
|
|
||||||
static void wpa_driver_privsep_event_rx_eapol(void *ctx, u8 *buf, size_t len)
|
static void wpa_driver_privsep_event_rx_eapol(void *ctx, u8 *buf, size_t len)
|
||||||
{
|
{
|
||||||
union wpa_event_data event;
|
|
||||||
|
|
||||||
if (len < ETH_ALEN)
|
if (len < ETH_ALEN)
|
||||||
return;
|
return;
|
||||||
|
drv_event_eapol_rx(ctx, buf, buf + ETH_ALEN, len - ETH_ALEN);
|
||||||
os_memset(&event, 0, sizeof(event));
|
|
||||||
event.eapol_rx.src = buf;
|
|
||||||
event.eapol_rx.data = buf + ETH_ALEN;
|
|
||||||
event.eapol_rx.data_len = len - ETH_ALEN;
|
|
||||||
wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -179,14 +179,8 @@ static void wpa_driver_roboswitch_receive(void *priv, const u8 *src_addr,
|
||||||
struct wpa_driver_roboswitch_data *drv = priv;
|
struct wpa_driver_roboswitch_data *drv = priv;
|
||||||
|
|
||||||
if (len > 14 && WPA_GET_BE16(buf + 12) == ETH_P_EAPOL &&
|
if (len > 14 && WPA_GET_BE16(buf + 12) == ETH_P_EAPOL &&
|
||||||
os_memcmp(buf, drv->own_addr, ETH_ALEN) == 0) {
|
os_memcmp(buf, drv->own_addr, ETH_ALEN) == 0)
|
||||||
union wpa_event_data event;
|
drv_event_eapol_rx(drv->ctx, src_addr, buf + 14, len - 14);
|
||||||
os_memset(&event, 0, sizeof(event));
|
|
||||||
event.eapol_rx.src = src_addr;
|
|
||||||
event.eapol_rx.data = buf + 14;
|
|
||||||
event.eapol_rx.data_len = len - 14;
|
|
||||||
wpa_supplicant_event(drv->ctx, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -647,8 +647,6 @@ static void test_driver_eapol(struct wpa_driver_test_data *drv,
|
||||||
struct test_client_socket *cli;
|
struct test_client_socket *cli;
|
||||||
#endif /* HOSTAPD */
|
#endif /* HOSTAPD */
|
||||||
const u8 *src = NULL;
|
const u8 *src = NULL;
|
||||||
union wpa_event_data event;
|
|
||||||
void *ctx;
|
|
||||||
|
|
||||||
if (datalen > 14) {
|
if (datalen > 14) {
|
||||||
/* Skip Ethernet header */
|
/* Skip Ethernet header */
|
||||||
|
@ -661,29 +659,19 @@ static void test_driver_eapol(struct wpa_driver_test_data *drv,
|
||||||
datalen -= 14;
|
datalen -= 14;
|
||||||
}
|
}
|
||||||
|
|
||||||
os_memset(&event, 0, sizeof(event));
|
|
||||||
event.eapol_rx.data = data;
|
|
||||||
event.eapol_rx.data_len = datalen;
|
|
||||||
|
|
||||||
#ifdef HOSTAPD
|
#ifdef HOSTAPD
|
||||||
cli = test_driver_get_cli(drv, from, fromlen);
|
cli = test_driver_get_cli(drv, from, fromlen);
|
||||||
if (cli) {
|
if (cli) {
|
||||||
event.eapol_rx.src = cli->addr;
|
drv_event_eapol_rx(cli->bss->bss_ctx, cli->addr, data,
|
||||||
ctx = cli->bss->bss_ctx;
|
datalen);
|
||||||
} else {
|
} else {
|
||||||
wpa_printf(MSG_DEBUG, "test_socket: EAPOL from unknown "
|
wpa_printf(MSG_DEBUG, "test_socket: EAPOL from unknown "
|
||||||
"client");
|
"client");
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
#else /* HOSTAPD */
|
#else /* HOSTAPD */
|
||||||
if (src) {
|
if (src)
|
||||||
event.eapol_rx.src = src;
|
drv_event_eapol_rx(drv->ctx, src, data, datalen);
|
||||||
ctx = drv->ctx;
|
|
||||||
} else
|
|
||||||
return;
|
|
||||||
#endif /* HOSTAPD */
|
#endif /* HOSTAPD */
|
||||||
|
|
||||||
wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1811,7 +1799,6 @@ static void wpa_driver_test_eapol(struct wpa_driver_test_data *drv,
|
||||||
const u8 *data, size_t data_len)
|
const u8 *data, size_t data_len)
|
||||||
{
|
{
|
||||||
const u8 *src = drv->bssid;
|
const u8 *src = drv->bssid;
|
||||||
union wpa_event_data event;
|
|
||||||
|
|
||||||
if (data_len > 14) {
|
if (data_len > 14) {
|
||||||
/* Skip Ethernet header */
|
/* Skip Ethernet header */
|
||||||
|
@ -1820,11 +1807,7 @@ static void wpa_driver_test_eapol(struct wpa_driver_test_data *drv,
|
||||||
data_len -= 14;
|
data_len -= 14;
|
||||||
}
|
}
|
||||||
|
|
||||||
os_memset(&event, 0, sizeof(event));
|
drv_event_eapol_rx(drv->ctx, src, data, data_len);
|
||||||
event.eapol_rx.src = src;
|
|
||||||
event.eapol_rx.data = data;
|
|
||||||
event.eapol_rx.data_len = data_len;
|
|
||||||
wpa_supplicant_event(drv->ctx, EVENT_EAPOL_RX, &event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -140,12 +140,7 @@ static void handle_data(void *ctx, unsigned char *buf, size_t len)
|
||||||
|
|
||||||
pos = (u8 *) (hdr + 1);
|
pos = (u8 *) (hdr + 1);
|
||||||
left = len - sizeof(*hdr);
|
left = len - sizeof(*hdr);
|
||||||
|
drv_event_eapol_rx(ctx, sa, pos, left);
|
||||||
os_memset(&event, 0, sizeof(event));
|
|
||||||
event.eapol_rx.src = sa;
|
|
||||||
event.eapol_rx.data = pos;
|
|
||||||
event.eapol_rx.data_len = left;
|
|
||||||
wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in a new issue