From: Hannes Frederic Sowa Date: Sun, 18 Aug 2013 11:46:57 +0000 (+0200) Subject: ipv6: xfrm: dereference inner ipv6 header if encapsulated X-Git-Tag: upstream/snapshot3+hdmi~4489^2~9^2~4 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5d0ff542d0264f61dc4bdb34eba39ffb4ea3bc23;p=platform%2Fadaptation%2Frenesas_rcar%2Frenesas_kernel.git ipv6: xfrm: dereference inner ipv6 header if encapsulated In xfrm6_local_error use inner_header if the packet was encapsulated. Cc: Steffen Klassert Acked-by: Eric Dumazet Signed-off-by: Hannes Frederic Sowa Signed-off-by: Steffen Klassert --- diff --git a/net/ipv6/xfrm6_output.c b/net/ipv6/xfrm6_output.c index 3ac5ab2..e092e30 100644 --- a/net/ipv6/xfrm6_output.c +++ b/net/ipv6/xfrm6_output.c @@ -59,10 +59,12 @@ static void xfrm6_local_rxpmtu(struct sk_buff *skb, u32 mtu) void xfrm6_local_error(struct sk_buff *skb, u32 mtu) { struct flowi6 fl6; + const struct ipv6hdr *hdr; struct sock *sk = skb->sk; + hdr = skb->encapsulation ? inner_ipv6_hdr(skb) : ipv6_hdr(skb); fl6.fl6_dport = inet_sk(sk)->inet_dport; - fl6.daddr = ipv6_hdr(skb)->daddr; + fl6.daddr = hdr->daddr; ipv6_local_error(sk, EMSGSIZE, &fl6, mtu); }