diff options
author | David S. Miller <davem@davemloft.net> | 2018-10-18 09:55:08 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2018-10-18 09:55:08 -0700 |
commit | 2ee653f644ab203364724cac85a7efd371367979 (patch) | |
tree | ef4bec49238cf32b0eb32624c2db14daa2edaf8b /net/ipv6 | |
parent | eddf016b910486d2123675a6b5fd7d64f77cdca8 (diff) | |
parent | 9dffff200fd178f11dd50eb1fd8ccd0650c9284e (diff) | |
download | linux-2ee653f644ab203364724cac85a7efd371367979.tar.gz linux-2ee653f644ab203364724cac85a7efd371367979.tar.bz2 linux-2ee653f644ab203364724cac85a7efd371367979.zip |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/klassert/ipsec
Steffen Klassert says:
====================
pull request (net): ipsec 2018-10-18
1) Free the xfrm interface gro_cells when deleting the
interface, otherwise we leak it. From Li RongQing.
2) net/core/flow.c does not exist anymore, so remove it
from the MAINTAINERS file.
3) Fix a slab-out-of-bounds in _decode_session6.
From Alexei Starovoitov.
4) Fix RCU protection when policies inserted into
thei bydst lists. From Florian Westphal.
Please pull or let me know if there are problems.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6')
-rw-r--r-- | net/ipv6/xfrm6_policy.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/ipv6/xfrm6_policy.c b/net/ipv6/xfrm6_policy.c index ef3defaf43b9..d35bcf92969c 100644 --- a/net/ipv6/xfrm6_policy.c +++ b/net/ipv6/xfrm6_policy.c @@ -146,8 +146,8 @@ _decode_session6(struct sk_buff *skb, struct flowi *fl, int reverse) fl6->daddr = reverse ? hdr->saddr : hdr->daddr; fl6->saddr = reverse ? hdr->daddr : hdr->saddr; - while (nh + offset + 1 < skb->data || - pskb_may_pull(skb, nh + offset + 1 - skb->data)) { + while (nh + offset + sizeof(*exthdr) < skb->data || + pskb_may_pull(skb, nh + offset + sizeof(*exthdr) - skb->data)) { nh = skb_network_header(skb); exthdr = (struct ipv6_opt_hdr *)(nh + offset); |