Commit fb208dc7 authored by Felix Fietkau's avatar Felix Fietkau Committed by Kalle Valo

mt76: avoid re-queueing A-MPDU rx reorder work if no frames are pending

Fixes: aee5b8cf ("mt76: implement A-MPDU rx reordering in the driver code")
Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
Signed-off-by: default avatarKalle Valo <kvalo@codeaurora.org>
parent 17cf68b7
...@@ -98,6 +98,7 @@ mt76_rx_aggr_reorder_work(struct work_struct *work) ...@@ -98,6 +98,7 @@ mt76_rx_aggr_reorder_work(struct work_struct *work)
reorder_work.work); reorder_work.work);
struct mt76_dev *dev = tid->dev; struct mt76_dev *dev = tid->dev;
struct sk_buff_head frames; struct sk_buff_head frames;
int nframes;
__skb_queue_head_init(&frames); __skb_queue_head_init(&frames);
...@@ -105,9 +106,12 @@ mt76_rx_aggr_reorder_work(struct work_struct *work) ...@@ -105,9 +106,12 @@ mt76_rx_aggr_reorder_work(struct work_struct *work)
spin_lock(&tid->lock); spin_lock(&tid->lock);
mt76_rx_aggr_check_release(tid, &frames); mt76_rx_aggr_check_release(tid, &frames);
nframes = tid->nframes;
spin_unlock(&tid->lock); spin_unlock(&tid->lock);
ieee80211_queue_delayed_work(tid->dev->hw, &tid->reorder_work, REORDER_TIMEOUT); if (nframes)
ieee80211_queue_delayed_work(tid->dev->hw, &tid->reorder_work,
REORDER_TIMEOUT);
mt76_rx_complete(dev, &frames, -1); mt76_rx_complete(dev, &frames, -1);
local_bh_enable(); local_bh_enable();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment