diff options
author | Jouni Malinen <j@w1.fi> | 2009-12-12 20:39:25 +0200 |
---|---|---|
committer | Jouni Malinen <j@w1.fi> | 2009-12-12 20:39:25 +0200 |
commit | 0531006644d7854ad6492597d65296aadfe192b6 (patch) | |
tree | 04761150e5c6df036c0253cee751c916fc6d4ccf /src | |
parent | 7e683ceeb49eb25ffcf08318da9499aef256a091 (diff) | |
download | external_wpa_supplicant_8_ti-0531006644d7854ad6492597d65296aadfe192b6.zip external_wpa_supplicant_8_ti-0531006644d7854ad6492597d65296aadfe192b6.tar.gz external_wpa_supplicant_8_ti-0531006644d7854ad6492597d65296aadfe192b6.tar.bz2 |
driver_wired: Move STA entry processing away from driver wrapper
Get rid of hostapd/sta_info.h dependency by introducing a new driver
callback function for hostapd.
Diffstat (limited to 'src')
-rw-r--r-- | src/drivers/driver.h | 1 | ||||
-rw-r--r-- | src/drivers/driver_wired.c | 27 |
2 files changed, 4 insertions, 24 deletions
diff --git a/src/drivers/driver.h b/src/drivers/driver.h index c4e7b73..c889ba9 100644 --- a/src/drivers/driver.h +++ b/src/drivers/driver.h @@ -1918,6 +1918,7 @@ void hostapd_tx_status(struct hostapd_data *hapd, const u8 *addr, const u8 *buf, size_t len, int ack); void hostapd_rx_from_unknown_sta(struct hostapd_data *hapd, const struct ieee80211_hdr *hdr, size_t len); +int hostapd_notif_new_sta(struct hostapd_data *hapd, const u8 *addr); int hostapd_notif_assoc(struct hostapd_data *hapd, const u8 *addr, const u8 *ie, size_t ielen); void hostapd_notif_disassoc(struct hostapd_data *hapd, const u8 *addr); diff --git a/src/drivers/driver_wired.c b/src/drivers/driver_wired.c index 61ec1e5..68c34fe 100644 --- a/src/drivers/driver_wired.c +++ b/src/drivers/driver_wired.c @@ -1,6 +1,6 @@ /* * WPA Supplicant - wired Ethernet driver interface - * Copyright (c) 2005-2007, Jouni Malinen <j@w1.fi> + * Copyright (c) 2005-2009, Jouni Malinen <j@w1.fi> * Copyright (c) 2004, Gunter Burchardt <tira@isx.de> * * This program is free software; you can redistribute it and/or modify @@ -30,7 +30,6 @@ #ifdef HOSTAPD #include "eloop.h" -#include "../../hostapd/sta_info.h" #endif /* HOSTAPD */ #ifdef _MSC_VER @@ -94,26 +93,6 @@ struct dhcp_message { }; -static void wired_possible_new_sta(struct hostapd_data *hapd, u8 *addr) -{ - struct sta_info *sta; - - sta = ap_get_sta(hapd, addr); - if (sta) - return; - - wpa_printf(MSG_DEBUG, "Data frame from unknown STA " MACSTR - " - adding a new STA", MAC2STR(addr)); - sta = ap_sta_add(hapd, addr); - if (sta) { - hostapd_new_assoc_sta(hapd, sta, 0); - } else { - wpa_printf(MSG_DEBUG, "Failed to add STA entry for " MACSTR, - MAC2STR(addr)); - } -} - - static void handle_data(struct hostapd_data *hapd, unsigned char *buf, size_t len) { @@ -135,7 +114,7 @@ static void handle_data(struct hostapd_data *hapd, unsigned char *buf, case ETH_P_PAE: wpa_printf(MSG_MSGDUMP, "Received EAPOL packet"); sa = hdr->src; - wired_possible_new_sta(hapd, sa); + hostapd_notif_new_sta(hapd, sa); pos = (u8 *) (hdr + 1); left = len - sizeof(*hdr); @@ -193,7 +172,7 @@ static void handle_dhcp(int sock, void *eloop_ctx, void *sock_ctx) wpa_printf(MSG_MSGDUMP, "Got DHCP broadcast packet from " MACSTR, MAC2STR(mac_address)); - wired_possible_new_sta(hapd, mac_address); + hostapd_notif_new_sta(hapd, mac_address); } |