skmsg: Lock ingress_skb when purging
authorCong Wang <cong.wang@bytedance.com>
Wed, 31 Mar 2021 02:32:22 +0000 (19:32 -0700)
committerAlexei Starovoitov <ast@kernel.org>
Thu, 1 Apr 2021 17:56:13 +0000 (10:56 -0700)
Currently we purge the ingress_skb queue only when psock
refcnt goes down to 0, so locking the queue is not necessary,
but in order to be called during ->close, we have to lock it
here.

Signed-off-by: Cong Wang <cong.wang@bytedance.com>
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Jakub Sitnicki <jakub@cloudflare.com>
Acked-by: John Fastabend <john.fastabend@gmail.com>
Link: https://lore.kernel.org/bpf/20210331023237.41094-2-xiyou.wangcong@gmail.com
net/core/skmsg.c

index 07f54015238a6dcb540f3b0a2e1a659693ee05a7..bebf84ed4e30a64622519d552d37f34d2b448595 100644 (file)
@@ -634,7 +634,7 @@ static void sk_psock_zap_ingress(struct sk_psock *psock)
 {
        struct sk_buff *skb;
 
-       while ((skb = __skb_dequeue(&psock->ingress_skb)) != NULL) {
+       while ((skb = skb_dequeue(&psock->ingress_skb)) != NULL) {
                skb_bpf_redirect_clear(skb);
                kfree_skb(skb);
        }