diff options
author | Stanislaw Gruszka <sgruszka@redhat.com> | 2010-03-29 06:18:34 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-03-31 14:43:59 -0400 |
commit | e1b3ec1a2a336c328c336cfa5485a5f0484cc90d (patch) | |
tree | 9a71f61f773231fd439220bec60977f45e1ef65f /net/mac80211 | |
parent | ecdf94b81237d272b1514b76f27a5d22782bcaa6 (diff) |
mac80211: explicitly disable/enable QoS
Add interface to disable/enable QoS (aka WMM or WME). Currently drivers
enable it explicitly when ->conf_tx method is called, and newer disable.
Disabling is needed for some APs, which do not support QoS, such
we should send QoS frames to them.
Signed-off-by: Stanislaw Gruszka <sgruszka@redhat.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211')
-rw-r--r-- | net/mac80211/mlme.c | 9 | ||||
-rw-r--r-- | net/mac80211/util.c | 5 |
2 files changed, 13 insertions, 1 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c index 65eafda5738a..c686d1b90f9f 100644 --- a/net/mac80211/mlme.c +++ b/net/mac80211/mlme.c | |||
@@ -586,6 +586,9 @@ static void ieee80211_sta_wmm_params(struct ieee80211_local *local, | |||
586 | int count; | 586 | int count; |
587 | u8 *pos, uapsd_queues = 0; | 587 | u8 *pos, uapsd_queues = 0; |
588 | 588 | ||
589 | if (!local->ops->conf_tx) | ||
590 | return; | ||
591 | |||
589 | if (local->hw.queues < 4) | 592 | if (local->hw.queues < 4) |
590 | return; | 593 | return; |
591 | 594 | ||
@@ -660,11 +663,15 @@ static void ieee80211_sta_wmm_params(struct ieee80211_local *local, | |||
660 | params.aifs, params.cw_min, params.cw_max, params.txop, | 663 | params.aifs, params.cw_min, params.cw_max, params.txop, |
661 | params.uapsd); | 664 | params.uapsd); |
662 | #endif | 665 | #endif |
663 | if (drv_conf_tx(local, queue, ¶ms) && local->ops->conf_tx) | 666 | if (drv_conf_tx(local, queue, ¶ms)) |
664 | printk(KERN_DEBUG "%s: failed to set TX queue " | 667 | printk(KERN_DEBUG "%s: failed to set TX queue " |
665 | "parameters for queue %d\n", | 668 | "parameters for queue %d\n", |
666 | wiphy_name(local->hw.wiphy), queue); | 669 | wiphy_name(local->hw.wiphy), queue); |
667 | } | 670 | } |
671 | |||
672 | /* enable WMM or activate new settings */ | ||
673 | local->hw.conf.flags |= IEEE80211_CONF_QOS; | ||
674 | drv_config(local, IEEE80211_CONF_CHANGE_QOS); | ||
668 | } | 675 | } |
669 | 676 | ||
670 | static u32 ieee80211_handle_bss_capability(struct ieee80211_sub_if_data *sdata, | 677 | static u32 ieee80211_handle_bss_capability(struct ieee80211_sub_if_data *sdata, |
diff --git a/net/mac80211/util.c b/net/mac80211/util.c index c453226f06b2..7b2c170af71c 100644 --- a/net/mac80211/util.c +++ b/net/mac80211/util.c | |||
@@ -796,6 +796,11 @@ void ieee80211_set_wmm_default(struct ieee80211_sub_if_data *sdata) | |||
796 | 796 | ||
797 | drv_conf_tx(local, queue, &qparam); | 797 | drv_conf_tx(local, queue, &qparam); |
798 | } | 798 | } |
799 | |||
800 | /* after reinitialize QoS TX queues setting to default, | ||
801 | * disable QoS at all */ | ||
802 | local->hw.conf.flags &= ~IEEE80211_CONF_QOS; | ||
803 | drv_config(local, IEEE80211_CONF_CHANGE_QOS); | ||
799 | } | 804 | } |
800 | 805 | ||
801 | void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata, | 806 | void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata, |