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 */
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
{
struct madwifi_driver_data *drv = ctx;
- union wpa_event_data event;
- os_memset(&event, 0, sizeof(event));
- 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);
+ drv_event_eapol_rx(drv->hapd, src_addr, buf + sizeof(struct l2_ethhdr),
+ len - sizeof(struct l2_ethhdr));
}
static void *
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
{
struct bsd_driver_data *drv = ctx;
- union wpa_event_data event;
- os_memset(&event, 0, sizeof(event));
- 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);
+ drv_event_eapol_rx(drv->hapd, src_addr, buf + sizeof(struct l2_ethhdr),
+ len - sizeof(struct l2_ethhdr));
}
static int
left -= 2;
switch (ethertype) {
case ETH_P_PAE:
- 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(drv->hapd, EVENT_EAPOL_RX, &event);
+ drv_event_eapol_rx(drv->hapd, sa, pos, left);
break;
default:
handle_read(void *ctx, const u8 *src_addr, const u8 *buf, size_t len)
{
struct madwifi_driver_data *drv = ctx;
- union wpa_event_data event;
- os_memset(&event, 0, sizeof(event));
- 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);
+ drv_event_eapol_rx(drv->hapd, src_addr, buf + sizeof(struct l2_ethhdr),
+ len - sizeof(struct l2_ethhdr));
}
static void *
return;
}
- if (have_ifidx(drv, lladdr.sll_ifindex)) {
- union wpa_event_data event;
- 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);
- }
+ if (have_ifidx(drv, lladdr.sll_ifindex))
+ drv_event_eapol_rx(drv->ctx, lladdr.sll_addr, buf, 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)
return;
-
- 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);
+ drv_event_eapol_rx(ctx, buf, buf + ETH_ALEN, len - ETH_ALEN);
}
struct wpa_driver_roboswitch_data *drv = priv;
if (len > 14 && WPA_GET_BE16(buf + 12) == ETH_P_EAPOL &&
- os_memcmp(buf, drv->own_addr, ETH_ALEN) == 0) {
- union wpa_event_data event;
- 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);
- }
+ os_memcmp(buf, drv->own_addr, ETH_ALEN) == 0)
+ drv_event_eapol_rx(drv->ctx, src_addr, buf + 14, len - 14);
}
struct test_client_socket *cli;
#endif /* HOSTAPD */
const u8 *src = NULL;
- union wpa_event_data event;
- void *ctx;
if (datalen > 14) {
/* Skip Ethernet header */
datalen -= 14;
}
- os_memset(&event, 0, sizeof(event));
- event.eapol_rx.data = data;
- event.eapol_rx.data_len = datalen;
-
#ifdef HOSTAPD
cli = test_driver_get_cli(drv, from, fromlen);
if (cli) {
- event.eapol_rx.src = cli->addr;
- ctx = cli->bss->bss_ctx;
+ drv_event_eapol_rx(cli->bss->bss_ctx, cli->addr, data,
+ datalen);
} else {
wpa_printf(MSG_DEBUG, "test_socket: EAPOL from unknown "
"client");
- return;
}
#else /* HOSTAPD */
- if (src) {
- event.eapol_rx.src = src;
- ctx = drv->ctx;
- } else
- return;
+ if (src)
+ drv_event_eapol_rx(drv->ctx, src, data, datalen);
#endif /* HOSTAPD */
-
- wpa_supplicant_event(ctx, EVENT_EAPOL_RX, &event);
}
const u8 *data, size_t data_len)
{
const u8 *src = drv->bssid;
- union wpa_event_data event;
if (data_len > 14) {
/* Skip Ethernet header */
data_len -= 14;
}
- 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(drv->ctx, EVENT_EAPOL_RX, &event);
+ drv_event_eapol_rx(drv->ctx, src, data, data_len);
}
pos = (u8 *) (hdr + 1);
left = len - sizeof(*hdr);
-
- 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);
+ drv_event_eapol_rx(ctx, sa, pos, left);
break;
default: