aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211
diff options
context:
space:
mode:
authorStanislaw Gruszka <sgruszka@redhat.com>2010-03-29 06:18:34 -0400
committerJohn W. Linville <linville@tuxdriver.com>2010-03-31 14:43:59 -0400
commite1b3ec1a2a336c328c336cfa5485a5f0484cc90d (patch)
tree9a71f61f773231fd439220bec60977f45e1ef65f /net/mac80211
parentecdf94b81237d272b1514b76f27a5d22782bcaa6 (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.c9
-rw-r--r--net/mac80211/util.c5
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, &params) && local->ops->conf_tx) 666 if (drv_conf_tx(local, queue, &params))
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
670static u32 ieee80211_handle_bss_capability(struct ieee80211_sub_if_data *sdata, 677static 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
801void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata, 806void ieee80211_sta_def_wmm_params(struct ieee80211_sub_if_data *sdata,