iwlwifi: mvm: use bss client queue for bss station
authorLiad Kaufman <liad.kaufman@intel.com>
Sun, 9 Aug 2015 12:50:51 +0000 (15:50 +0300)
committerEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Wed, 30 Mar 2016 13:24:46 +0000 (16:24 +0300)
Use the reserved BSS Client queue when connecting to an AP
in DQA mode.

Signed-off-by: Liad Kaufman <liad.kaufman@intel.com>
Signed-off-by: Emmanuel Grumbach <emmanuel.grumbach@intel.com>
drivers/net/wireless/intel/iwlwifi/mvm/fw-api.h
drivers/net/wireless/intel/iwlwifi/mvm/sta.c

index 8217eb25b0909fbc4ec64c87c73e51284f8940f4..965268766ac2ebe7515ff3ea8dd2e65bf9422c95 100644 (file)
@@ -89,6 +89,8 @@ enum {
 /*
  * DQA queue numbers
  *
+ * @IWL_MVM_DQA_BSS_CLIENT_QUEUE: a queue reserved for BSS activity, to ensure
+ *     that we are never left without the possibility to connect to an AP.
  * @IWL_MVM_DQA_MIN_MGMT_QUEUE: first TXQ in pool for MGMT and non-QOS frames.
  *     Each MGMT queue is mapped to a single STA
  *     MGMT frames are frames that return true on ieee80211_is_mgmt()
@@ -100,6 +102,7 @@ enum {
  * @IWL_MVM_DQA_MAX_DATA_QUEUE: last TXQ in pool for DATA frames
  */
 enum iwl_mvm_dqa_txq {
+       IWL_MVM_DQA_BSS_CLIENT_QUEUE = 4,
        IWL_MVM_DQA_MIN_MGMT_QUEUE = 5,
        IWL_MVM_DQA_MAX_MGMT_QUEUE = 8,
        IWL_MVM_DQA_MIN_DATA_QUEUE = 10,
index 3f36a661ec964134ff5f6ffc3fabaec4f0b13131..e157bd5a2204e56cf0c46367c52a2409b41a8834 100644 (file)
@@ -336,7 +336,8 @@ static int iwl_mvm_sta_alloc_queue(struct iwl_mvm *mvm,
         * as aggregatable.
         * Mark all DATA queues as allowing to be aggregated at some point
         */
-       cfg.aggregate = (queue >= IWL_MVM_DQA_MIN_DATA_QUEUE);
+       cfg.aggregate = (queue >= IWL_MVM_DQA_MIN_DATA_QUEUE ||
+                        queue == IWL_MVM_DQA_BSS_CLIENT_QUEUE);
 
        IWL_DEBUG_TX_QUEUES(mvm, "Allocating queue #%d to sta %d on tid %d\n",
                            queue, mvmsta->sta_id, tid);
@@ -448,7 +449,8 @@ void iwl_mvm_add_new_dqa_stream_wk(struct work_struct *wk)
 }
 
 static int iwl_mvm_reserve_sta_stream(struct iwl_mvm *mvm,
-                                     struct ieee80211_sta *sta)
+                                     struct ieee80211_sta *sta,
+                                     enum nl80211_iftype vif_type)
 {
        struct iwl_mvm_sta *mvmsta = iwl_mvm_sta_from_mac80211(sta);
        int queue;
@@ -456,8 +458,13 @@ static int iwl_mvm_reserve_sta_stream(struct iwl_mvm *mvm,
        spin_lock_bh(&mvm->queue_info_lock);
 
        /* Make sure we have free resources for this STA */
-       queue = iwl_mvm_find_free_queue(mvm, IWL_MVM_DQA_MIN_DATA_QUEUE,
-                                       IWL_MVM_DQA_MAX_DATA_QUEUE);
+       if (vif_type == NL80211_IFTYPE_STATION && !sta->tdls &&
+           !mvm->queue_info[IWL_MVM_DQA_BSS_CLIENT_QUEUE].hw_queue_refcount &&
+           !mvm->queue_info[IWL_MVM_DQA_BSS_CLIENT_QUEUE].setup_reserved)
+               queue = IWL_MVM_DQA_BSS_CLIENT_QUEUE;
+       else
+               queue = iwl_mvm_find_free_queue(mvm, IWL_MVM_DQA_MIN_DATA_QUEUE,
+                                               IWL_MVM_DQA_MAX_DATA_QUEUE);
        if (queue < 0) {
                spin_unlock_bh(&mvm->queue_info_lock);
                IWL_ERR(mvm, "No available queues for new station\n");
@@ -551,7 +558,8 @@ int iwl_mvm_add_sta(struct iwl_mvm *mvm,
        }
 
        if (iwl_mvm_is_dqa_supported(mvm)) {
-               ret = iwl_mvm_reserve_sta_stream(mvm, sta);
+               ret = iwl_mvm_reserve_sta_stream(mvm, sta,
+                                                ieee80211_vif_type_p2p(vif));
                if (ret)
                        goto err;
        }