mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-15 09:19:57 +00:00
42d7efd083
SVN-Revision: 9564
174 lines
6.8 KiB
Diff
174 lines
6.8 KiB
Diff
---
|
|
hostapd/driver.h | 8 ++++----
|
|
hostapd/driver_bsd.c | 3 ++-
|
|
hostapd/driver_devicescape.c | 6 +++---
|
|
hostapd/driver_hostap.c | 4 ++--
|
|
hostapd/driver_madwifi.c | 3 ++-
|
|
hostapd/driver_prism54.c | 3 ++-
|
|
hostapd/ieee802_11.c | 4 ++--
|
|
hostapd/ieee802_1x.c | 4 ++--
|
|
hostapd/wme.c | 6 ++++--
|
|
9 files changed, 23 insertions(+), 18 deletions(-)
|
|
|
|
--- hostap.orig/hostapd/driver.h 2007-11-14 17:30:38.000000000 +0100
|
|
+++ hostap/hostapd/driver.h 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -92,7 +92,7 @@ struct wpa_driver_ops {
|
|
int (*get_retry)(void *priv, int *short_retry, int *long_retry);
|
|
|
|
int (*sta_set_flags)(void *priv, const u8 *addr,
|
|
- int flags_or, int flags_and);
|
|
+ int total_flags, int flags_or, int flags_and);
|
|
int (*set_rate_sets)(void *priv, int *supp_rates, int *basic_rates,
|
|
int mode);
|
|
int (*set_channel_flag)(void *priv, int mode, int chan, int flag,
|
|
@@ -427,12 +427,12 @@ hostapd_get_retry(struct hostapd_data *h
|
|
|
|
static inline int
|
|
hostapd_sta_set_flags(struct hostapd_data *hapd, u8 *addr,
|
|
- int flags_or, int flags_and)
|
|
+ int total_flags, int flags_or, int flags_and)
|
|
{
|
|
if (hapd->driver == NULL || hapd->driver->sta_set_flags == NULL)
|
|
return 0;
|
|
- return hapd->driver->sta_set_flags(hapd->drv_priv, addr, flags_or,
|
|
- flags_and);
|
|
+ return hapd->driver->sta_set_flags(hapd->drv_priv, addr, total_flags,
|
|
+ flags_or, flags_and);
|
|
}
|
|
|
|
static inline int
|
|
--- hostap.orig/hostapd/driver_bsd.c 2007-11-14 17:30:38.000000000 +0100
|
|
+++ hostap/hostapd/driver_bsd.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -322,7 +322,8 @@ bsd_set_sta_authorized(void *priv, const
|
|
}
|
|
|
|
static int
|
|
-bsd_sta_set_flags(void *priv, const u8 *addr, int flags_or, int flags_and)
|
|
+bsd_sta_set_flags(void *priv, const u8 *addr, int total_flags, int flags_or,
|
|
+ int flags_and)
|
|
{
|
|
/* For now, only support setting Authorized flag */
|
|
if (flags_or & WLAN_STA_AUTHORIZED)
|
|
--- hostap.orig/hostapd/driver_devicescape.c 2007-11-14 17:30:39.000000000 +0100
|
|
+++ hostap/hostapd/driver_devicescape.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -74,7 +74,7 @@ struct i802_driver_data {
|
|
#define HAPD_DECL struct hostapd_data *hapd = iface->bss[0]
|
|
|
|
static int i802_sta_set_flags(void *priv, const u8 *addr,
|
|
- int flags_or, int flags_and);
|
|
+ int total_flags, int flags_or, int flags_and);
|
|
|
|
|
|
static int hostapd_set_iface_flags(struct i802_driver_data *drv, int dev_up)
|
|
@@ -666,7 +666,7 @@ static int i802_sta_remove(void *priv, c
|
|
struct i802_driver_data *drv = priv;
|
|
struct prism2_hostapd_param param;
|
|
|
|
- i802_sta_set_flags(drv, addr, 0, ~WLAN_STA_AUTHORIZED);
|
|
+ i802_sta_set_flags(drv, addr, 0, 0, ~WLAN_STA_AUTHORIZED);
|
|
|
|
memset(¶m, 0, sizeof(param));
|
|
param.cmd = PRISM2_HOSTAPD_REMOVE_STA;
|
|
@@ -678,7 +678,7 @@ static int i802_sta_remove(void *priv, c
|
|
|
|
|
|
static int i802_sta_set_flags(void *priv, const u8 *addr,
|
|
- int flags_or, int flags_and)
|
|
+ int total_flags, int flags_or, int flags_and)
|
|
{
|
|
struct i802_driver_data *drv = priv;
|
|
struct prism2_hostapd_param param;
|
|
--- hostap.orig/hostapd/driver_hostap.c 2007-11-14 17:30:38.000000000 +0100
|
|
+++ hostap/hostapd/driver_hostap.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -374,7 +374,7 @@ static int hostap_send_eapol(void *priv,
|
|
|
|
|
|
static int hostap_sta_set_flags(void *priv, const u8 *addr,
|
|
- int flags_or, int flags_and)
|
|
+ int total_flags, int flags_or, int flags_and)
|
|
{
|
|
struct hostap_driver_data *drv = priv;
|
|
struct prism2_hostapd_param param;
|
|
@@ -694,7 +694,7 @@ static int hostap_sta_remove(void *priv,
|
|
struct hostap_driver_data *drv = priv;
|
|
struct prism2_hostapd_param param;
|
|
|
|
- hostap_sta_set_flags(drv, addr, 0, ~WLAN_STA_AUTHORIZED);
|
|
+ hostap_sta_set_flags(drv, addr, 0, 0, ~WLAN_STA_AUTHORIZED);
|
|
|
|
memset(¶m, 0, sizeof(param));
|
|
param.cmd = PRISM2_HOSTAPD_REMOVE_STA;
|
|
--- hostap.orig/hostapd/driver_madwifi.c 2007-11-14 17:30:38.000000000 +0100
|
|
+++ hostap/hostapd/driver_madwifi.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -410,7 +410,8 @@ madwifi_set_sta_authorized(void *priv, c
|
|
}
|
|
|
|
static int
|
|
-madwifi_sta_set_flags(void *priv, const u8 *addr, int flags_or, int flags_and)
|
|
+madwifi_sta_set_flags(void *priv, const u8 *addr, int total_flags,
|
|
+ int flags_or, int flags_and)
|
|
{
|
|
/* For now, only support setting Authorized flag */
|
|
if (flags_or & WLAN_STA_AUTHORIZED)
|
|
--- hostap.orig/hostapd/driver_prism54.c 2007-11-14 17:30:38.000000000 +0100
|
|
+++ hostap/hostapd/driver_prism54.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -187,7 +187,8 @@ static int prism54_set_sta_authorized(vo
|
|
|
|
|
|
static int
|
|
-prism54_sta_set_flags(void *priv, const u8 *addr, int flags_or, int flags_and)
|
|
+prism54_sta_set_flags(void *priv, const u8 *addr, int total_flags,
|
|
+ int flags_or, int flags_and)
|
|
{
|
|
/* For now, only support setting Authorized flag */
|
|
if (flags_or & WLAN_STA_AUTHORIZED)
|
|
--- hostap.orig/hostapd/ieee802_11.c 2007-11-14 17:30:37.000000000 +0100
|
|
+++ hostap/hostapd/ieee802_11.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -1625,10 +1625,10 @@ static void handle_assoc_cb(struct hosta
|
|
ap_sta_bind_vlan(hapd, sta, 0);
|
|
}
|
|
if (sta->flags & WLAN_STA_SHORT_PREAMBLE) {
|
|
- hostapd_sta_set_flags(hapd, sta->addr,
|
|
+ hostapd_sta_set_flags(hapd, sta->addr, sta->flags,
|
|
WLAN_STA_SHORT_PREAMBLE, ~0);
|
|
} else {
|
|
- hostapd_sta_set_flags(hapd, sta->addr,
|
|
+ hostapd_sta_set_flags(hapd, sta->addr, sta->flags,
|
|
0, ~WLAN_STA_SHORT_PREAMBLE);
|
|
}
|
|
|
|
--- hostap.orig/hostapd/ieee802_1x.c 2007-11-14 17:30:37.000000000 +0100
|
|
+++ hostap/hostapd/ieee802_1x.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -94,13 +94,13 @@ void ieee802_1x_set_sta_authorized(struc
|
|
|
|
if (authorized) {
|
|
sta->flags |= WLAN_STA_AUTHORIZED;
|
|
- res = hostapd_sta_set_flags(hapd, sta->addr,
|
|
+ res = hostapd_sta_set_flags(hapd, sta->addr, sta->flags,
|
|
WLAN_STA_AUTHORIZED, ~0);
|
|
hostapd_logger(hapd, sta->addr, HOSTAPD_MODULE_IEEE8021X,
|
|
HOSTAPD_LEVEL_DEBUG, "authorizing port");
|
|
} else {
|
|
sta->flags &= ~WLAN_STA_AUTHORIZED;
|
|
- res = hostapd_sta_set_flags(hapd, sta->addr,
|
|
+ res = hostapd_sta_set_flags(hapd, sta->addr, sta->flags,
|
|
0, ~WLAN_STA_AUTHORIZED);
|
|
hostapd_logger(hapd, sta->addr, HOSTAPD_MODULE_IEEE8021X,
|
|
HOSTAPD_LEVEL_DEBUG, "unauthorizing port");
|
|
--- hostap.orig/hostapd/wme.c 2007-11-14 17:30:38.000000000 +0100
|
|
+++ hostap/hostapd/wme.c 2007-11-14 17:30:47.000000000 +0100
|
|
@@ -110,9 +110,11 @@ int hostapd_wme_sta_config(struct hostap
|
|
{
|
|
/* update kernel STA data for WME related items (WLAN_STA_WPA flag) */
|
|
if (sta->flags & WLAN_STA_WME)
|
|
- hostapd_sta_set_flags(hapd, sta->addr, WLAN_STA_WME, ~0);
|
|
+ hostapd_sta_set_flags(hapd, sta->addr, sta->flags,
|
|
+ WLAN_STA_WME, ~0);
|
|
else
|
|
- hostapd_sta_set_flags(hapd, sta->addr, 0, ~WLAN_STA_WME);
|
|
+ hostapd_sta_set_flags(hapd, sta->addr, sta->flags,
|
|
+ 0, ~WLAN_STA_WME);
|
|
|
|
return 0;
|
|
}
|