Skip to content

Commit

Permalink
ipv6: ndisc: Convert to dst_neigh_lookup()
Browse files Browse the repository at this point in the history
Now all code paths grab a local reference to the neigh, so if neigh
is not NULL we unconditionally release it at the end.  The old logic
would only release if we didn't have a non-NULL 'rt'.

Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
David S. Miller committed Jan 28, 2012
1 parent 0ec8866 commit eb85718
Showing 1 changed file with 12 additions and 6 deletions.
18 changes: 12 additions & 6 deletions net/ipv6/ndisc.c
Original file line number Diff line number Diff line change
Expand Up @@ -1223,11 +1223,17 @@ static void ndisc_router_discovery(struct sk_buff *skb)

rt = rt6_get_dflt_router(&ipv6_hdr(skb)->saddr, skb->dev);

if (rt)
neigh = dst_get_neighbour_noref(&rt->dst);

if (rt) {
neigh = dst_neigh_lookup(&rt->dst, &ipv6_hdr(skb)->saddr);
if (!neigh) {
ND_PRINTK0(KERN_ERR
"ICMPv6 RA: %s() got default router without neighbour.\n",
__func__);
dst_release(&rt->dst);
return;
}
}
if (rt && lifetime == 0) {
neigh_clone(neigh);
ip6_del_rt(rt);
rt = NULL;
}
Expand All @@ -1244,7 +1250,7 @@ static void ndisc_router_discovery(struct sk_buff *skb)
return;
}

neigh = dst_get_neighbour_noref(&rt->dst);
neigh = dst_neigh_lookup(&rt->dst, &ipv6_hdr(skb)->saddr);
if (neigh == NULL) {
ND_PRINTK0(KERN_ERR
"ICMPv6 RA: %s() got default router without neighbour.\n",
Expand Down Expand Up @@ -1411,7 +1417,7 @@ static void ndisc_router_discovery(struct sk_buff *skb)
out:
if (rt)
dst_release(&rt->dst);
else if (neigh)
if (neigh)
neigh_release(neigh);
}

Expand Down

0 comments on commit eb85718

Please sign in to comment.