mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-11 15:49:56 +00:00
tipc: fix missing spinlock init and nullptr oops
commit 908344cdda80 ("tipc: fix bug in multicast congestion handling") introduced two bugs with the bclink wakeup function. This commit fixes the missing spinlock init for the waiting_sks list. We also eliminate the race condition between the waiting_sks length check/dequeue operations in tipc_bclink_wakeup_users by simply removing the redundant length check. Signed-off-by: Erik Hugne <erik.hugne@ericsson.com> Acked-by: Tero Aho <Tero.Aho@coriant.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
d9a28c5b4c
commit
4988bb4a3f
@ -233,8 +233,11 @@ static void bclink_retransmit_pkt(u32 after, u32 to)
|
||||
*/
|
||||
void tipc_bclink_wakeup_users(void)
|
||||
{
|
||||
while (skb_queue_len(&bclink->link.waiting_sks))
|
||||
tipc_sk_rcv(skb_dequeue(&bclink->link.waiting_sks));
|
||||
struct sk_buff *skb;
|
||||
|
||||
while ((skb = skb_dequeue(&bclink->link.waiting_sks)))
|
||||
tipc_sk_rcv(skb);
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
@ -950,7 +953,7 @@ int tipc_bclink_init(void)
|
||||
spin_lock_init(&bclink->lock);
|
||||
__skb_queue_head_init(&bcl->outqueue);
|
||||
__skb_queue_head_init(&bcl->deferred_queue);
|
||||
__skb_queue_head_init(&bcl->waiting_sks);
|
||||
skb_queue_head_init(&bcl->waiting_sks);
|
||||
bcl->next_out_no = 1;
|
||||
spin_lock_init(&bclink->node.lock);
|
||||
__skb_queue_head_init(&bclink->node.waiting_sks);
|
||||
|
Loading…
x
Reference in New Issue
Block a user