mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-26 21:54:11 +08:00
vhost: lock receive queue, not the socket
vhost takes a sock lock to try and prevent the skb from being pulled from the receive queue after skb_peek. However this is not the right lock to use for that, sk_receive_queue.lock is. Fix that up. Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
94249369e9
commit
783e398854
@ -213,12 +213,13 @@ static int peek_head_len(struct sock *sk)
|
||||
{
|
||||
struct sk_buff *head;
|
||||
int len = 0;
|
||||
unsigned long flags;
|
||||
|
||||
lock_sock(sk);
|
||||
spin_lock_irqsave(&sk->sk_receive_queue.lock, flags);
|
||||
head = skb_peek(&sk->sk_receive_queue);
|
||||
if (head)
|
||||
if (likely(head))
|
||||
len = head->len;
|
||||
release_sock(sk);
|
||||
spin_unlock_irqrestore(&sk->sk_receive_queue.lock, flags);
|
||||
return len;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user