aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJouni Malinen <j@w1.fi>2009-12-12 20:39:25 +0200
committerJouni Malinen <j@w1.fi>2009-12-12 20:39:25 +0200
commit0531006644d7854ad6492597d65296aadfe192b6 (patch)
tree04761150e5c6df036c0253cee751c916fc6d4ccf /src
parent7e683ceeb49eb25ffcf08318da9499aef256a091 (diff)
downloadexternal_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.h1
-rw-r--r--src/drivers/driver_wired.c27
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);
}