提交 4db4e0a1 编写于 作者: J Johannes Berg 提交者: John W. Linville

mac80211: fix TX warning

Emmanuel reported that my previous patches to enable
handing all fragments to drivers at once triggered
the warning that the SKB queue wasn't empty. This is
happening when we actually queue up some frames and
don't hand them to the driver (queues are stopped).

The reason for it is that my code that splices the
frame(s) over to the pending queue didn't re-init
the local queue, so skb_queue_empty() was false. Fix
this by using the _init versions of the splicing.

Also, convert the warning to WARN_ON_ONCE.
Reported-by: NEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
Tested-by: NEmmanuel Grumbach <emmanuel.grumbach@intel.com>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 48839938
...@@ -1227,9 +1227,10 @@ static bool ieee80211_tx_frags(struct ieee80211_local *local, ...@@ -1227,9 +1227,10 @@ static bool ieee80211_tx_frags(struct ieee80211_local *local,
* queue is woken again. * queue is woken again.
*/ */
if (txpending) if (txpending)
skb_queue_splice(skbs, &local->pending[q]); skb_queue_splice_init(skbs, &local->pending[q]);
else else
skb_queue_splice_tail(skbs, &local->pending[q]); skb_queue_splice_tail_init(skbs,
&local->pending[q]);
spin_unlock_irqrestore(&local->queue_stop_reason_lock, spin_unlock_irqrestore(&local->queue_stop_reason_lock,
flags); flags);
...@@ -1301,7 +1302,7 @@ static bool __ieee80211_tx(struct ieee80211_local *local, ...@@ -1301,7 +1302,7 @@ static bool __ieee80211_tx(struct ieee80211_local *local,
ieee80211_tpt_led_trig_tx(local, fc, led_len); ieee80211_tpt_led_trig_tx(local, fc, led_len);
ieee80211_led_tx(local, 1); ieee80211_led_tx(local, 1);
WARN_ON(!skb_queue_empty(skbs)); WARN_ON_ONCE(!skb_queue_empty(skbs));
return result; return result;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册