Search Linux Wireless

Re: [PATCH v2] mac80211: Extend the rate control API with an update callback

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

 



On Thu, 2009-02-12 at 11:38 +0530, Sujith wrote:
> The AP can switch dynamically between 20/40 Mhz channel width,
> in which case we switch the local operating channel, but the
> rate control algorithm is not notified. This patch adds a new callback
> to indicate such changes to the RC algorithm.
> 
> Currently, HT channel width change is notified, but this callback
> can be used to indicate any new requirements that might come up later on.

Looks good to me.

> Signed-off-by: Sujith <Sujith.Manoharan@xxxxxxxxxxx>

Acked-by: Johannes Berg <johannes@xxxxxxxxxxxxxxxx>

> ---
> v2:
> --
> * Rebased over [PATCH] mac80211: split IBSS/managed code
> 
>  include/net/mac80211.h |   13 +++++++++++++
>  net/mac80211/ht.c      |   13 +++++++++++++
>  net/mac80211/rate.h    |   12 ++++++++++++
>  3 files changed, 38 insertions(+), 0 deletions(-)
> 
> diff --git a/include/net/mac80211.h b/include/net/mac80211.h
> index 31fd8ba..e01c63a 100644
> --- a/include/net/mac80211.h
> +++ b/include/net/mac80211.h
> @@ -1975,6 +1975,16 @@ struct ieee80211_sta *ieee80211_find_sta(struct ieee80211_hw *hw,
>  /* Rate control API */
>  
>  /**
> + * enum rate_control_changed - flags to indicate which parameter changed
> + *
> + * @IEEE80211_RC_HT_CHANGED: The HT parameters of the operating channel have
> + *	changed, rate control algorithm can update its internal state if needed.
> + */
> +enum rate_control_changed {
> +	IEEE80211_RC_HT_CHANGED = BIT(0)
> +};
> +
> +/**
>   * struct ieee80211_tx_rate_control - rate control information for/from RC algo
>   *
>   * @hw: The hardware the algorithm is invoked for.
> @@ -2010,6 +2020,9 @@ struct rate_control_ops {
>  	void *(*alloc_sta)(void *priv, struct ieee80211_sta *sta, gfp_t gfp);
>  	void (*rate_init)(void *priv, struct ieee80211_supported_band *sband,
>  			  struct ieee80211_sta *sta, void *priv_sta);
> +	void (*rate_update)(void *priv, struct ieee80211_supported_band *sband,
> +			    struct ieee80211_sta *sta,
> +			    void *priv_sta, u32 changed);
>  	void (*free_sta)(void *priv, struct ieee80211_sta *sta,
>  			 void *priv_sta);
>  
> diff --git a/net/mac80211/ht.c b/net/mac80211/ht.c
> index 69b6e9a..4e3c72f 100644
> --- a/net/mac80211/ht.c
> +++ b/net/mac80211/ht.c
> @@ -17,6 +17,7 @@
>  #include <net/wireless.h>
>  #include <net/mac80211.h>
>  #include "ieee80211_i.h"
> +#include "rate.h"
>  
>  void ieee80211_ht_cap_ie_to_sta_ht_cap(struct ieee80211_supported_band *sband,
>  				       struct ieee80211_ht_cap *ht_cap_ie,
> @@ -93,7 +94,9 @@ u32 ieee80211_enable_ht(struct ieee80211_sub_if_data *sdata,
>  {
>  	struct ieee80211_local *local = sdata->local;
>  	struct ieee80211_supported_band *sband;
> +	struct ieee80211_if_managed *ifmgd = &sdata->u.mgd;
>  	struct ieee80211_bss_ht_conf ht;
> +	struct sta_info *sta;
>  	u32 changed = 0;
>  	bool enable_ht = true, ht_changed;
>  	enum nl80211_channel_type channel_type = NL80211_CHAN_NO_HT;
> @@ -136,6 +139,16 @@ u32 ieee80211_enable_ht(struct ieee80211_sub_if_data *sdata,
>  	if (ht_changed) {
>                  /* channel_type change automatically detected */
>  		ieee80211_hw_config(local, 0);
> +
> +		rcu_read_lock();
> +
> +		sta = sta_info_get(local, ifmgd->bssid);
> +		if (sta)
> +			rate_control_rate_update(local, sband, sta,
> +						 IEEE80211_RC_HT_CHANGED);
> +
> +		rcu_read_unlock();
> +
>          }
>  
>  	/* disable HT */
> diff --git a/net/mac80211/rate.h b/net/mac80211/rate.h
> index 928da62..b9164c9 100644
> --- a/net/mac80211/rate.h
> +++ b/net/mac80211/rate.h
> @@ -62,6 +62,18 @@ static inline void rate_control_rate_init(struct sta_info *sta)
>  	ref->ops->rate_init(ref->priv, sband, ista, priv_sta);
>  }
>  
> +static inline void rate_control_rate_update(struct ieee80211_local *local,
> +				    struct ieee80211_supported_band *sband,
> +				    struct sta_info *sta, u32 changed)
> +{
> +	struct rate_control_ref *ref = local->rate_ctrl;
> +	struct ieee80211_sta *ista = &sta->sta;
> +	void *priv_sta = sta->rate_ctrl_priv;
> +
> +	if (ref->ops->rate_update)
> +		ref->ops->rate_update(ref->priv, sband, ista,
> +				      priv_sta, changed);
> +}
>  
>  static inline void *rate_control_alloc_sta(struct rate_control_ref *ref,
>  					   struct ieee80211_sta *sta,

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