Search Linux Wireless

Re: [PATCH 2/2] mac80211: use a struct for bss->mesh_config

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 2008-03-31 at 17:39 -0700, Luis Carlos Cobo wrote:
> This allows cleaner code when accesing bss->mesh_config components.
> 
> Signed-off-by: Luis Carlos Cobo <luisca@xxxxxxxxxxx>

Looks good to me.

> ---
>  net/mac80211/ieee80211_i.h   |   13 +++++++++++--
>  net/mac80211/ieee80211_sta.c |   32 ++++++++++++++++++++------------
>  net/mac80211/mesh.c          |    4 ----
>  net/mac80211/mesh.h          |   10 ++++++++++
>  4 files changed, 41 insertions(+), 18 deletions(-)
> 
> diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
> index 7ab8066..69e2bc5 100644
> --- a/net/mac80211/ieee80211_i.h
> +++ b/net/mac80211/ieee80211_i.h
> @@ -69,6 +69,14 @@ struct ieee80211_fragment_entry {
>  	u8 last_pn[6]; /* PN of the last fragment if CCMP was used */
>  };
>  
> +struct bss_mesh_config {
> +	u32 path_proto_id;
> +	u32 path_metric_id;
> +	u32 cong_control_id;
> +	u32 channel_precedence;
> +	u8 mesh_version;
> +};
> +
>  
>  struct ieee80211_sta_bss {
>  	struct list_head list;
> @@ -94,7 +102,7 @@ struct ieee80211_sta_bss {
>  #ifdef CONFIG_MAC80211_MESH
>  	u8 *mesh_id;
>  	size_t mesh_id_len;
> -	u8 *mesh_cfg;
> +	struct bss_mesh_config *mesh_cfg;
>  #endif
>  #define IEEE80211_MAX_SUPP_RATES 32
>  	u8 supp_rates[IEEE80211_MAX_SUPP_RATES];
> @@ -113,7 +121,8 @@ struct ieee80211_sta_bss {
>  	u8 erp_value;
>  };
>  
> -static inline u8 *bss_mesh_cfg(struct ieee80211_sta_bss *bss)
> +static inline
> +struct bss_mesh_config *bss_mesh_cfg(struct ieee80211_sta_bss *bss)
>  {
>  #ifdef CONFIG_MAC80211_MESH
>  	return bss->mesh_cfg;
> diff --git a/net/mac80211/ieee80211_sta.c b/net/mac80211/ieee80211_sta.c
> index feec201..fbe2da9 100644
> --- a/net/mac80211/ieee80211_sta.c
> +++ b/net/mac80211/ieee80211_sta.c
> @@ -27,6 +27,7 @@
>  #include <linux/rtnetlink.h>
>  #include <net/iw_handler.h>
>  #include <asm/types.h>
> +#include <asm/unaligned.h>
>  
>  #include <net/mac80211.h>
>  #include "ieee80211_i.h"
> @@ -2126,6 +2127,11 @@ ieee80211_rx_bss_get(struct net_device *dev, u8 *bssid, int freq,
>  }
>  
>  #ifdef CONFIG_MAC80211_MESH
> +static inline u32 bss_mesh_cfg_get(u8 *mesh_cfg, u8 offset)
> +{
> +	return be32_to_cpu(get_unaligned((__be32 *) (mesh_cfg + offset)));
> +}
> +
>  static struct ieee80211_sta_bss *
>  ieee80211_rx_mesh_bss_get(struct net_device *dev, u8 *mesh_id, int mesh_id_len,
>  			  u8 *mesh_cfg, int freq)
> @@ -2165,7 +2171,7 @@ ieee80211_rx_mesh_bss_add(struct net_device *dev, u8 *mesh_id, int mesh_id_len,
>  	if (!bss)
>  		return NULL;
>  
> -	bss->mesh_cfg = kmalloc(MESH_CFG_CMP_LEN, GFP_ATOMIC);
> +	bss->mesh_cfg = kmalloc(sizeof(struct bss_mesh_config), GFP_ATOMIC);
>  	if (!bss->mesh_cfg) {
>  		kfree(bss);
>  		return NULL;
> @@ -2183,7 +2189,12 @@ ieee80211_rx_mesh_bss_add(struct net_device *dev, u8 *mesh_id, int mesh_id_len,
>  
>  	atomic_inc(&bss->users);
>  	atomic_inc(&bss->users);
> -	memcpy(bss->mesh_cfg, mesh_cfg, MESH_CFG_CMP_LEN);
> +	bss->mesh_cfg->mesh_version = mesh_cfg[0];
> +	bss->mesh_cfg->path_proto_id = bss_mesh_cfg_get(mesh_cfg, PP_OFFSET);
> +	bss->mesh_cfg->path_metric_id = bss_mesh_cfg_get(mesh_cfg, PM_OFFSET);
> +	bss->mesh_cfg->cong_control_id = bss_mesh_cfg_get(mesh_cfg, CC_OFFSET);
> +	bss->mesh_cfg->channel_precedence = bss_mesh_cfg_get(mesh_cfg,
> +							     CP_OFFSET);
>  	bss->mesh_id_len = mesh_id_len;
>  	bss->freq = freq;
>  	spin_lock_bh(&local->sta_bss_lock);
> @@ -4059,36 +4070,33 @@ ieee80211_sta_scan_result(struct net_device *dev,
>  
>  	if (bss_mesh_cfg(bss)) {
>  		char *buf;
> -		u8 *cfg = bss_mesh_cfg(bss);
> +		struct bss_mesh_config *cfg = bss_mesh_cfg(bss);
>  		buf = kmalloc(50, GFP_ATOMIC);
>  		if (buf) {
>  			memset(&iwe, 0, sizeof(iwe));
>  			iwe.cmd = IWEVCUSTOM;
> -			sprintf(buf, "Mesh network (version %d)", cfg[0]);
> +			sprintf(buf, "Mesh network (version %d)",
> +				cfg->mesh_version);
>  			iwe.u.data.length = strlen(buf);
>  			current_ev = iwe_stream_add_point(current_ev, end_buf,
>  							  &iwe, buf);
>  			sprintf(buf, "Path Selection Protocol ID: "
> -				"0x%02X%02X%02X%02X", cfg[1], cfg[2], cfg[3],
> -							cfg[4]);
> +				"0x%08X", cfg->path_proto_id);
>  			iwe.u.data.length = strlen(buf);
>  			current_ev = iwe_stream_add_point(current_ev, end_buf,
>  							  &iwe, buf);
>  			sprintf(buf, "Path Selection Metric ID: "
> -				"0x%02X%02X%02X%02X", cfg[5], cfg[6], cfg[7],
> -							cfg[8]);
> +				"0x%08X", cfg->path_metric_id);
>  			iwe.u.data.length = strlen(buf);
>  			current_ev = iwe_stream_add_point(current_ev, end_buf,
>  							  &iwe, buf);
>  			sprintf(buf, "Congestion Control Mode ID: "
> -				"0x%02X%02X%02X%02X", cfg[9], cfg[10],
> -							cfg[11], cfg[12]);
> +				"0x%08X", cfg->cong_control_id);
>  			iwe.u.data.length = strlen(buf);
>  			current_ev = iwe_stream_add_point(current_ev, end_buf,
>  							  &iwe, buf);
>  			sprintf(buf, "Channel Precedence: "
> -				"0x%02X%02X%02X%02X", cfg[13], cfg[14],
> -							cfg[15], cfg[16]);
> +				"0x%08X", cfg->channel_precedence);
>  			iwe.u.data.length = strlen(buf);
>  			current_ev = iwe_stream_add_point(current_ev, end_buf,
>  							  &iwe, buf);
> diff --git a/net/mac80211/mesh.c b/net/mac80211/mesh.c
> index 594a335..b10f1e5 100644
> --- a/net/mac80211/mesh.c
> +++ b/net/mac80211/mesh.c
> @@ -11,10 +11,6 @@
>  #include "ieee80211_i.h"
>  #include "mesh.h"
>  
> -#define PP_OFFSET 	1		/* Path Selection Protocol */
> -#define PM_OFFSET	5		/* Path Selection Metric   */
> -#define CC_OFFSET	9		/* Congestion Control Mode */
> -#define CAPAB_OFFSET 17
>  #define ACCEPT_PLINKS 0x80
>  
>  int mesh_allocated;
> diff --git a/net/mac80211/mesh.h b/net/mac80211/mesh.h
> index 742003d..8ff46ea 100644
> --- a/net/mac80211/mesh.h
> +++ b/net/mac80211/mesh.h
> @@ -157,6 +157,16 @@ struct mesh_rmc {
>   */
>  #define MESH_CFG_CMP_LEN 	17
>  
> +/*
> + * Components offset within the mesh configuration IE
> + */
> +#define PP_OFFSET	1		/* Path Selection Protocol */
> +#define PM_OFFSET	5		/* Path Selection Metric   */
> +#define CC_OFFSET	9		/* Congestion Control Mode */
> +#define CP_OFFSET	13		/* Channel Precedence */
> +#define CAPAB_OFFSET	17		/* Mesh Capabilities */
> +
> +
>  /* Default values, timeouts in ms */
>  #define MESH_TTL 		5
>  #define MESH_MAX_RETR	 	3

Attachment: signature.asc
Description: This is a digitally signed message part


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]
  Powered by Linux