ipv6: ip6_finish_output2: set sk into newly allocated nskb
authorVasily Averin <vvs@virtuozzo.com>
Mon, 19 Jul 2021 07:55:14 +0000 (10:55 +0300)
committerJakub Kicinski <kuba@kernel.org>
Tue, 20 Jul 2021 09:52:36 +0000 (11:52 +0200)
skb_set_owner_w() should set sk not to old skb but to new nskb.

Fixes: 5796015fa968 ("ipv6: allocate enough headroom in ip6_finish_output2()")
Signed-off-by: Vasily Averin <vvs@virtuozzo.com>
Link: https://lore.kernel.org/r/70c0744f-89ae-1869-7e3e-4fa292158f4b@virtuozzo.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
net/ipv6/ip6_output.c

index 01bea76..e1b9f7a 100644 (file)
@@ -74,7 +74,7 @@ static int ip6_finish_output2(struct net *net, struct sock *sk, struct sk_buff *
 
                        if (likely(nskb)) {
                                if (skb->sk)
-                                       skb_set_owner_w(skb, skb->sk);
+                                       skb_set_owner_w(nskb, skb->sk);
                                consume_skb(skb);
                        } else {
                                kfree_skb(skb);