Commit b5f61ab9 authored by David S. Miller's avatar David S. Miller

usbatm: Use skb_queue_walk_safe() instead of by-hand implementation.

Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 47a227db
...@@ -640,14 +640,13 @@ static void usbatm_cancel_send(struct usbatm_data *instance, ...@@ -640,14 +640,13 @@ static void usbatm_cancel_send(struct usbatm_data *instance,
atm_dbg(instance, "%s entered\n", __func__); atm_dbg(instance, "%s entered\n", __func__);
spin_lock_irq(&instance->sndqueue.lock); spin_lock_irq(&instance->sndqueue.lock);
for (skb = instance->sndqueue.next, n = skb->next; skb_queue_walk_safe(&instance->sndqueue, skb, n) {
skb != (struct sk_buff *)&instance->sndqueue;
skb = n, n = skb->next)
if (UDSL_SKB(skb)->atm.vcc == vcc) { if (UDSL_SKB(skb)->atm.vcc == vcc) {
atm_dbg(instance, "%s: popping skb 0x%p\n", __func__, skb); atm_dbg(instance, "%s: popping skb 0x%p\n", __func__, skb);
__skb_unlink(skb, &instance->sndqueue); __skb_unlink(skb, &instance->sndqueue);
usbatm_pop(vcc, skb); usbatm_pop(vcc, skb);
} }
}
spin_unlock_irq(&instance->sndqueue.lock); spin_unlock_irq(&instance->sndqueue.lock);
tasklet_disable(&instance->tx_channel.tasklet); tasklet_disable(&instance->tx_channel.tasklet);
......
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