mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-31 05:54:26 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			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;
 | |
|  }
 |