]> git.baikalelectronics.ru Git - kernel.git/commitdiff
vti6: Fix memory leak of skb if input policy check fails
authorTorsten Hilbrich <torsten.hilbrich@secunet.com>
Wed, 11 Mar 2020 10:19:06 +0000 (11:19 +0100)
committerSteffen Klassert <steffen.klassert@secunet.com>
Mon, 16 Mar 2020 10:13:48 +0000 (11:13 +0100)
The vti6_rcv function performs some tests on the retrieved tunnel
including checking the IP protocol, the XFRM input policy, the
source and destination address.

In all but one places the skb is released in the error case. When
the input policy check fails the network packet is leaked.

Using the same goto-label discard in this case to fix this problem.

Fixes: 412b1ca7b3fd ("ipv6: Add support for IPsec virtual tunnel interfaces")
Signed-off-by: Torsten Hilbrich <torsten.hilbrich@secunet.com>
Reviewed-by: Nicolas Dichtel <nicolas.dichtel@6wind.com>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
net/ipv6/ip6_vti.c

index 56e642efefff779d5ca04f4128c07cabb5f946ad..cc6180e08a4fc2228c0f5208c2a6d598c4b82185 100644 (file)
@@ -311,7 +311,7 @@ static int vti6_rcv(struct sk_buff *skb)
 
                if (!xfrm6_policy_check(NULL, XFRM_POLICY_IN, skb)) {
                        rcu_read_unlock();
-                       return 0;
+                       goto discard;
                }
 
                ipv6h = ipv6_hdr(skb);