ipv6: call dst_hold_safe() properly
authorWei Wang <weiwan@google.com>
Sat, 17 Jun 2017 17:42:35 +0000 (10:42 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 18 Jun 2017 02:54:00 +0000 (22:54 -0400)
Similar as ipv4, ipv6 path also needs to call dst_hold_safe() when
necessary to avoid double free issue on the dst.

Signed-off-by: Wei Wang <weiwan@google.com>
Acked-by: Martin KaFai Lau <kafai@fb.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv6/addrconf.c
net/ipv6/route.c

index 0aa36b0..2a63977 100644 (file)
@@ -5576,8 +5576,8 @@ static void __ipv6_ifa_notify(int event, struct inet6_ifaddr *ifp)
                                ip6_del_rt(rt);
                }
                if (ifp->rt) {
-                       dst_hold(&ifp->rt->dst);
-                       ip6_del_rt(ifp->rt);
+                       if (dst_hold_safe(&ifp->rt->dst))
+                               ip6_del_rt(ifp->rt);
                }
                rt_genid_bump_ipv6(net);
                break;
index 908b711..c52c519 100644 (file)
@@ -1366,8 +1366,8 @@ static void ip6_link_failure(struct sk_buff *skb)
        rt = (struct rt6_info *) skb_dst(skb);
        if (rt) {
                if (rt->rt6i_flags & RTF_CACHE) {
-                       dst_hold(&rt->dst);
-                       ip6_del_rt(rt);
+                       if (dst_hold_safe(&rt->dst))
+                               ip6_del_rt(rt);
                } else if (rt->rt6i_node && (rt->rt6i_flags & RTF_DEFAULT)) {
                        rt->rt6i_node->fn_sernum = -1;
                }