aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/ndisc.c
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2012-01-27 18:30:48 -0500
committerDavid S. Miller <davem@davemloft.net>2012-01-27 21:00:08 -0500
commit4991969a1027826c3db19dd3e600e145603e6928 (patch)
tree87e2986e22f64b746e550ba377a2b59f20b199a9 /net/ipv6/ndisc.c
parent5339ab8b1dd82f14df168fb9bf59449f3e24b03d (diff)
ipv6: Remove neigh argument from ndisc_send_redirect()
Instead, compute it as-needed inside of that function using dst_neigh_lookup(). Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/ndisc.c')
-rw-r--r--net/ipv6/ndisc.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/net/ipv6/ndisc.c b/net/ipv6/ndisc.c
index c574ebce3fb5..8d817018c188 100644
--- a/net/ipv6/ndisc.c
+++ b/net/ipv6/ndisc.c
@@ -1512,8 +1512,7 @@ static void ndisc_redirect_rcv(struct sk_buff *skb)
1512 } 1512 }
1513} 1513}
1514 1514
1515void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh, 1515void ndisc_send_redirect(struct sk_buff *skb, const struct in6_addr *target)
1516 const struct in6_addr *target)
1517{ 1516{
1518 struct net_device *dev = skb->dev; 1517 struct net_device *dev = skb->dev;
1519 struct net *net = dev_net(dev); 1518 struct net *net = dev_net(dev);
@@ -1571,6 +1570,13 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
1571 goto release; 1570 goto release;
1572 1571
1573 if (dev->addr_len) { 1572 if (dev->addr_len) {
1573 struct neighbour *neigh = dst_neigh_lookup(skb_dst(skb), target);
1574 if (!neigh) {
1575 ND_PRINTK2(KERN_WARNING
1576 "ICMPv6 Redirect: no neigh for target address\n");
1577 goto release;
1578 }
1579
1574 read_lock_bh(&neigh->lock); 1580 read_lock_bh(&neigh->lock);
1575 if (neigh->nud_state & NUD_VALID) { 1581 if (neigh->nud_state & NUD_VALID) {
1576 memcpy(ha_buf, neigh->ha, dev->addr_len); 1582 memcpy(ha_buf, neigh->ha, dev->addr_len);
@@ -1579,6 +1585,8 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
1579 len += ndisc_opt_addr_space(dev); 1585 len += ndisc_opt_addr_space(dev);
1580 } else 1586 } else
1581 read_unlock_bh(&neigh->lock); 1587 read_unlock_bh(&neigh->lock);
1588
1589 neigh_release(neigh);
1582 } 1590 }
1583 1591
1584 rd_len = min_t(unsigned int, 1592 rd_len = min_t(unsigned int,