]> err.no Git - linux-2.6/blobdiff - net/ipv6/inet6_connection_sock.c
[PATCH] m68k: separate handler for auto and user vector interrupt
[linux-2.6] / net / ipv6 / inet6_connection_sock.c
index 792f90f0f9ece287c0d94a2fbfdf7073c09e7aff..eb2865d5ae286cdfffa2c098aa881c7c752b526e 100644 (file)
@@ -25,6 +25,7 @@
 #include <net/inet_hashtables.h>
 #include <net/ip6_route.h>
 #include <net/sock.h>
+#include <net/inet6_connection_sock.h>
 
 int inet6_csk_bind_conflict(const struct sock *sk,
                            const struct inet_bind_bucket *tb)
@@ -172,6 +173,7 @@ int inet6_csk_xmit(struct sk_buff *skb, int ipfragok)
 
                if (err) {
                        sk->sk_err_soft = -err;
+                       kfree_skb(skb);
                        return err;
                }
 
@@ -180,6 +182,7 @@ int inet6_csk_xmit(struct sk_buff *skb, int ipfragok)
 
                if ((err = xfrm_lookup(&dst, &fl, sk, 0)) < 0) {
                        sk->sk_route_caps = 0;
+                       kfree_skb(skb);
                        return err;
                }