aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211/main.c
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2012-04-03 10:28:50 -0400
committerJohn W. Linville <linville@tuxdriver.com>2012-04-11 16:23:50 -0400
commit3a25a8c8b75b430c4f4022918e26fa51d557ecde (patch)
treed4863b7f17c2ea44fb523e29951b6bd202ddb1ad /net/mac80211/main.c
parent4b6f1dd6a6faf4ed8d209bbd548e78b15e55aee8 (diff)
mac80211: add improved HW queue control
mac80211 currently only supports one hardware queue per AC. This is already problematic for off-channel uses since if we go off channel while the BE queue is full and then try to send an off-channel frame the frame will never go out. This will become worse when we support multi-channel since then a queue on one channel might be full, but we have to stop the software queue for all channels. That is obviously not desirable. To address this problem allow drivers to register more hardware queues, and allow them to map them to virtual interfaces. When they stop a hardware queue the corresponding AC software queues on the correct interfaces will be stopped as well. Additionally, there's an off-channel queue to solve that problem and a per-interface after-DTIM beacon queue. This allows drivers to manage software queues closer to how the hardware works. Currently, there's a limit of 16 hardware queues. This may or may not be sufficient, we can adjust it as needed. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/main.c')
-rw-r--r--net/mac80211/main.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/net/mac80211/main.c b/net/mac80211/main.c
index d019f0d3a0fe..ac79d5e8e0d0 100644
--- a/net/mac80211/main.c
+++ b/net/mac80211/main.c
@@ -591,6 +591,7 @@ struct ieee80211_hw *ieee80211_alloc_hw(size_t priv_data_len,
591 local->hw.max_report_rates = 0; 591 local->hw.max_report_rates = 0;
592 local->hw.max_rx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF; 592 local->hw.max_rx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF;
593 local->hw.max_tx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF; 593 local->hw.max_tx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF;
594 local->hw.offchannel_tx_hw_queue = IEEE80211_INVAL_HW_QUEUE;
594 local->hw.conf.long_frame_max_tx_count = wiphy->retry_long; 595 local->hw.conf.long_frame_max_tx_count = wiphy->retry_long;
595 local->hw.conf.short_frame_max_tx_count = wiphy->retry_short; 596 local->hw.conf.short_frame_max_tx_count = wiphy->retry_short;
596 local->user_power_level = -1; 597 local->user_power_level = -1;
@@ -687,6 +688,11 @@ int ieee80211_register_hw(struct ieee80211_hw *hw)
687 WLAN_CIPHER_SUITE_AES_CMAC 688 WLAN_CIPHER_SUITE_AES_CMAC
688 }; 689 };
689 690
691 if (hw->flags & IEEE80211_HW_QUEUE_CONTROL &&
692 (local->hw.offchannel_tx_hw_queue == IEEE80211_INVAL_HW_QUEUE ||
693 local->hw.offchannel_tx_hw_queue >= local->hw.queues))
694 return -EINVAL;
695
690 if ((hw->wiphy->wowlan.flags || hw->wiphy->wowlan.n_patterns) 696 if ((hw->wiphy->wowlan.flags || hw->wiphy->wowlan.n_patterns)
691#ifdef CONFIG_PM 697#ifdef CONFIG_PM
692 && (!local->ops->suspend || !local->ops->resume) 698 && (!local->ops->suspend || !local->ops->resume)