aboutsummaryrefslogtreecommitdiffstats
path: root/net/tipc/link.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/tipc/link.c')
-rw-r--r--net/tipc/link.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/net/tipc/link.c b/net/tipc/link.c
index 8eb885eb1433..ddee498e74bc 100644
--- a/net/tipc/link.c
+++ b/net/tipc/link.c
@@ -367,15 +367,15 @@ static bool link_schedule_user(struct tipc_link *link, u32 oport,
367 */ 367 */
368static void link_prepare_wakeup(struct tipc_link *link) 368static void link_prepare_wakeup(struct tipc_link *link)
369{ 369{
370 struct sk_buff_head *wq = &link->waiting_sks;
371 struct sk_buff *buf;
372 uint pend_qsz = link->out_queue_size; 370 uint pend_qsz = link->out_queue_size;
371 struct sk_buff *skb, *tmp;
373 372
374 for (buf = skb_peek(wq); buf; buf = skb_peek(wq)) { 373 skb_queue_walk_safe(&link->waiting_sks, skb, tmp) {
375 if (pend_qsz >= link->queue_limit[TIPC_SKB_CB(buf)->chain_imp]) 374 if (pend_qsz >= link->queue_limit[TIPC_SKB_CB(skb)->chain_imp])
376 break; 375 break;
377 pend_qsz += TIPC_SKB_CB(buf)->chain_sz; 376 pend_qsz += TIPC_SKB_CB(skb)->chain_sz;
378 __skb_queue_tail(&link->owner->waiting_sks, __skb_dequeue(wq)); 377 __skb_unlink(skb, &link->waiting_sks);
378 __skb_queue_tail(&link->owner->waiting_sks, skb);
379 } 379 }
380} 380}
381 381