]> git.itanic.dy.fi Git - linux-stable/commitdiff
[PATCH] IPSEC: Fix panic when using inter address familiy IPsec on loopback.
authorKazunori MIYAZAWA <kazunori@miyazawa.org>
Thu, 7 Jun 2007 05:41:52 +0000 (22:41 -0700)
committerChris Wright <chrisw@sous-sol.org>
Mon, 11 Jun 2007 18:37:12 +0000 (11:37 -0700)
Signed-off-by: Kazunori MIYAZAWA <kazunori@miyazawa.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Chris Wright <chrisw@sous-sol.org>
net/ipv4/xfrm4_input.c
net/ipv4/xfrm4_mode_tunnel.c
net/ipv6/xfrm6_input.c
net/ipv6/xfrm6_mode_tunnel.c

index 8655d038364cba364880f8cb9595e94708fe14db..ce69187eed8372ed2af1d12465978f1b2ff7fe0d 100644 (file)
@@ -136,10 +136,8 @@ int xfrm4_rcv_encap(struct sk_buff *skb, __u16 encap_type)
        nf_reset(skb);
 
        if (decaps) {
-               if (!(skb->dev->flags&IFF_LOOPBACK)) {
-                       dst_release(skb->dst);
-                       skb->dst = NULL;
-               }
+               dst_release(skb->dst);
+               skb->dst = NULL;
                netif_rx(skb);
                return 0;
        } else {
index 21ed667c23ccff7cc49b24882a5f2815cf117c8a..f020d06c7d9bc1d48354098bc8539cf8237be82a 100644 (file)
@@ -66,6 +66,8 @@ static int xfrm4_tunnel_output(struct xfrm_state *x, struct sk_buff *skb)
        top_iph->daddr = x->id.daddr.a4;
        top_iph->protocol = IPPROTO_IPIP;
 
+       skb->protocol = htons(ETH_P_IP);
+
        memset(&(IPCB(skb)->opt), 0, sizeof(struct ip_options));
        return 0;
 }
index 5c8b7a5688003dcf7c21ca0923be689b42d7cd40..8174daebf9325e9b82b6938387cdf99f541e2484 100644 (file)
@@ -103,10 +103,8 @@ int xfrm6_rcv_spi(struct sk_buff *skb, __be32 spi)
        nf_reset(skb);
 
        if (decaps) {
-               if (!(skb->dev->flags&IFF_LOOPBACK)) {
-                       dst_release(skb->dst);
-                       skb->dst = NULL;
-               }
+               dst_release(skb->dst);
+               skb->dst = NULL;
                netif_rx(skb);
                return -1;
        } else {
index 5e7d8a7d6414cc85a01fd463485c016af1d5a219..a5a96daa6dd3a40de71138ed743b0ee025117a11 100644 (file)
@@ -65,6 +65,7 @@ static int xfrm6_tunnel_output(struct xfrm_state *x, struct sk_buff *skb)
        top_iph->hop_limit = dst_metric(dst->child, RTAX_HOPLIMIT);
        ipv6_addr_copy(&top_iph->saddr, (struct in6_addr *)&x->props.saddr);
        ipv6_addr_copy(&top_iph->daddr, (struct in6_addr *)&x->id.daddr);
+       skb->protocol = htons(ETH_P_IPV6);
        return 0;
 }