aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid S. Miller <davem@nuts.ninka.net>2003-07-10 07:22:52 -0700
committerDavid S. Miller <davem@nuts.ninka.net>2003-07-10 07:22:52 -0700
commit6e4153afdfe36d5cb1469a73ba022b088fe5409d (patch)
tree39bb85b7fbd86030b25d4bb772a132a00624bafc
parentdc8b8b54d5c591f8d2275ce321691b58bd4526a9 (diff)
downloadhistory-6e4153afdfe36d5cb1469a73ba022b088fe5409d.tar.gz
[IPV6]: Fix dst reference counting in ndisc_send_redirect().
-rw-r--r--net/ipv6/ndisc.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/net/ipv6/ndisc.c b/net/ipv6/ndisc.c
index 6c573e39e2829d..d75fa9ce723d5a 100644
--- a/net/ipv6/ndisc.c
+++ b/net/ipv6/ndisc.c
@@ -1321,7 +1321,6 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
if (rt == NULL)
return;
dst = &rt->u.dst;
- dst_clone(dst);
err = xfrm_lookup(&dst, &fl, NULL, 0);
if (err) {
@@ -1329,16 +1328,17 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
return;
}
+ rt = (struct rt6_info *) dst;
+
if (rt->rt6i_flags & RTF_GATEWAY) {
ND_PRINTK1("ndisc_send_redirect: not a neighbour\n");
- dst_release(&rt->u.dst);
+ dst_release(dst);
return;
}
- if (!xrlim_allow(&rt->u.dst, 1*HZ)) {
- dst_release(&rt->u.dst);
+ if (!xrlim_allow(dst, 1*HZ)) {
+ dst_release(dst);
return;
}
- dst_release(&rt->u.dst);
if (dev->addr_len) {
if (neigh->nud_state&NUD_VALID) {
@@ -1348,6 +1348,7 @@ void ndisc_send_redirect(struct sk_buff *skb, struct neighbour *neigh,
We will make it later, when will be sure,
that it is alive.
*/
+ dst_release(dst);
return;
}
}