diff options
Diffstat (limited to 'net/ipv6/route.c')
| -rw-r--r-- | net/ipv6/route.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/net/ipv6/route.c b/net/ipv6/route.c index 52cd3eff31dc..05ebd7833043 100644 --- a/net/ipv6/route.c +++ b/net/ipv6/route.c | |||
| @@ -40,6 +40,7 @@ | |||
| 40 | #include <linux/proc_fs.h> | 40 | #include <linux/proc_fs.h> |
| 41 | #include <linux/seq_file.h> | 41 | #include <linux/seq_file.h> |
| 42 | #include <linux/nsproxy.h> | 42 | #include <linux/nsproxy.h> |
| 43 | #include <linux/slab.h> | ||
| 43 | #include <net/net_namespace.h> | 44 | #include <net/net_namespace.h> |
| 44 | #include <net/snmp.h> | 45 | #include <net/snmp.h> |
| 45 | #include <net/ipv6.h> | 46 | #include <net/ipv6.h> |
| @@ -814,7 +815,7 @@ struct dst_entry * ip6_route_output(struct net *net, struct sock *sk, | |||
| 814 | { | 815 | { |
| 815 | int flags = 0; | 816 | int flags = 0; |
| 816 | 817 | ||
| 817 | if (rt6_need_strict(&fl->fl6_dst)) | 818 | if (fl->oif || rt6_need_strict(&fl->fl6_dst)) |
| 818 | flags |= RT6_LOOKUP_F_IFACE; | 819 | flags |= RT6_LOOKUP_F_IFACE; |
| 819 | 820 | ||
| 820 | if (!ipv6_addr_any(&fl->fl6_src)) | 821 | if (!ipv6_addr_any(&fl->fl6_src)) |
| @@ -879,7 +880,7 @@ static struct dst_entry *ip6_dst_check(struct dst_entry *dst, u32 cookie) | |||
| 879 | 880 | ||
| 880 | rt = (struct rt6_info *) dst; | 881 | rt = (struct rt6_info *) dst; |
| 881 | 882 | ||
| 882 | if (rt && rt->rt6i_node && (rt->rt6i_node->fn_sernum == cookie)) | 883 | if (rt->rt6i_node && (rt->rt6i_node->fn_sernum == cookie)) |
| 883 | return dst; | 884 | return dst; |
| 884 | 885 | ||
| 885 | return NULL; | 886 | return NULL; |
| @@ -890,12 +891,17 @@ static struct dst_entry *ip6_negative_advice(struct dst_entry *dst) | |||
| 890 | struct rt6_info *rt = (struct rt6_info *) dst; | 891 | struct rt6_info *rt = (struct rt6_info *) dst; |
| 891 | 892 | ||
| 892 | if (rt) { | 893 | if (rt) { |
| 893 | if (rt->rt6i_flags & RTF_CACHE) | 894 | if (rt->rt6i_flags & RTF_CACHE) { |
| 894 | ip6_del_rt(rt); | 895 | if (rt6_check_expired(rt)) { |
| 895 | else | 896 | ip6_del_rt(rt); |
| 897 | dst = NULL; | ||
| 898 | } | ||
| 899 | } else { | ||
| 896 | dst_release(dst); | 900 | dst_release(dst); |
| 901 | dst = NULL; | ||
| 902 | } | ||
| 897 | } | 903 | } |
| 898 | return NULL; | 904 | return dst; |
| 899 | } | 905 | } |
| 900 | 906 | ||
| 901 | static void ip6_link_failure(struct sk_buff *skb) | 907 | static void ip6_link_failure(struct sk_buff *skb) |
