}
                list_add_tail(&ra_list->list,
                              &priv->wmm.tid_tbl_ptr[i].ra_list);
-
-               if (!priv->wmm.tid_tbl_ptr[i].ra_list_curr)
-                       priv->wmm.tid_tbl_ptr[i].ra_list_curr = ra_list;
        }
 }
 
                        priv->aggr_prio_tbl[i].amsdu = tos_to_tid_inv[i];
                        priv->aggr_prio_tbl[i].ampdu_ap = tos_to_tid_inv[i];
                        priv->aggr_prio_tbl[i].ampdu_user = tos_to_tid_inv[i];
-                       priv->wmm.tid_tbl_ptr[i].ra_list_curr = NULL;
                }
 
                priv->aggr_prio_tbl[6].amsdu
                }
 
                INIT_LIST_HEAD(&priv->wmm.tid_tbl_ptr[i].ra_list);
-
-               priv->wmm.tid_tbl_ptr[i].ra_list_curr = NULL;
        }
 }
 
                                     struct mwifiex_private **priv, int *tid)
 {
        struct mwifiex_private *priv_tmp;
-       struct mwifiex_ra_list_tbl *ptr, *head;
+       struct mwifiex_ra_list_tbl *ptr;
        struct mwifiex_bss_prio_node *bssprio_node, *bssprio_head;
        struct mwifiex_tid_tbl *tid_ptr;
        atomic_t *hqp;
                                tid_ptr = &(priv_tmp)->wmm.
                                        tid_tbl_ptr[tos_to_tid[i]];
 
-                               /* For non-STA ra_list_curr may be NULL */
-                               if (!tid_ptr->ra_list_curr)
-                                       goto skip_wmm_queue;
-
-                               if (list_empty(&tid_ptr->ra_list))
-                                       goto skip_wmm_queue;
-
-                               /*
-                                * Always choose the next ra we transmitted
-                                * last time, this way we pick the ra's in
-                                * round robin fashion.
-                                */
-                               ptr = list_first_entry(
-                                               &tid_ptr->ra_list_curr->list,
-                                               struct mwifiex_ra_list_tbl,
-                                               list);
+                               /* iterate over receiver addresses */
+                               list_for_each_entry(ptr, &tid_ptr->ra_list,
+                                                   list) {
 
-                               head = ptr;
-                               if (ptr == (struct mwifiex_ra_list_tbl *)
-                                               &tid_ptr->ra_list) {
-                                       /* Get next ra */
-                                       ptr = list_first_entry(&ptr->list,
-                                           struct mwifiex_ra_list_tbl, list);
-                                       head = ptr;
-                               }
-
-                               do {
                                        if (!skb_queue_empty(&ptr->skb_head))
                                                /* holds both locks */
                                                goto found;
+                               }
 
-                                       /* Get next ra */
-                                       ptr = list_first_entry(&ptr->list,
-                                                struct mwifiex_ra_list_tbl,
-                                                list);
-                                       if (ptr ==
-                                           (struct mwifiex_ra_list_tbl *)
-                                           &tid_ptr->ra_list)
-                                               ptr = list_first_entry(
-                                                   &ptr->list,
-                                                   struct mwifiex_ra_list_tbl,
-                                                   list);
-                               } while (ptr != head);
-
-skip_wmm_queue:
                                spin_unlock_irqrestore(&priv_tmp->wmm.
                                                       ra_list_spinlock,
                                                       flags_ra);
        return ptr;
 }
 
+/* This functions rotates ra lists so packets are picked in round robin
+ * fashion.
+ *
+ * After a packet is successfully transmitted, rotate the ra list, so the ra
+ * next to the one transmitted, will come first in the list. This way we pick
+ * the ra in a round robin fashion.
+ *
+ * Function also increments wmm.packets_out counter.
+ */
+void mwifiex_rotate_priolists(struct mwifiex_private *priv,
+                                struct mwifiex_ra_list_tbl *ra,
+                                int tid)
+{
+       struct mwifiex_tid_tbl *tid_ptr = &priv->wmm.tid_tbl_ptr[tid];
+       unsigned long flags;
+
+       spin_lock_irqsave(&priv->wmm.ra_list_spinlock, flags);
+       if (mwifiex_is_ralist_valid(priv, ra, tid)) {
+               priv->wmm.packets_out[tid]++;
+               /*
+                * dirty trick: we remove 'head' temporarily and reinsert it
+                * after curr bss node. imagine list to stay fixed while only
+                * head is moved
+                */
+               list_move(&tid_ptr->ra_list, &ra->list);
+       }
+       spin_unlock_irqrestore(&priv->wmm.ra_list_spinlock, flags);
+}
+
 /*
  * This function checks if 11n aggregation is possible.
  */
                spin_unlock_irqrestore(&priv->wmm.ra_list_spinlock,
                                       ra_list_flags);
        } else {
-               spin_lock_irqsave(&priv->wmm.ra_list_spinlock, ra_list_flags);
-               if (mwifiex_is_ralist_valid(priv, ptr, ptr_index)) {
-                       priv->wmm.packets_out[ptr_index]++;
-                       priv->wmm.tid_tbl_ptr[ptr_index].ra_list_curr = ptr;
-               }
+               mwifiex_rotate_priolists(priv, ptr, ptr_index);
                adapter->bss_prio_tbl[priv->bss_priority].bss_prio_cur =
                        list_first_entry(
                                &adapter->bss_prio_tbl[priv->bss_priority]
                                struct mwifiex_bss_prio_node,
                                list);
                atomic_dec(&priv->wmm.tx_pkts_queued);
-               spin_unlock_irqrestore(&priv->wmm.ra_list_spinlock,
-                                      ra_list_flags);
        }
 }
 
                break;
        }
        if (ret != -EBUSY) {
-               spin_lock_irqsave(&priv->wmm.ra_list_spinlock, ra_list_flags);
-               if (mwifiex_is_ralist_valid(priv, ptr, ptr_index)) {
-                       priv->wmm.packets_out[ptr_index]++;
-                       priv->wmm.tid_tbl_ptr[ptr_index].ra_list_curr = ptr;
-               }
+               mwifiex_rotate_priolists(priv, ptr, ptr_index);
                adapter->bss_prio_tbl[priv->bss_priority].bss_prio_cur =
                        list_first_entry(
                                &adapter->bss_prio_tbl[priv->bss_priority]
                                struct mwifiex_bss_prio_node,
                                list);
                atomic_dec(&priv->wmm.tx_pkts_queued);
-               spin_unlock_irqrestore(&priv->wmm.ra_list_spinlock,
-                                      ra_list_flags);
        }
 }