From f5b824509f56dcc76148c4844f0395f64782be35 Mon Sep 17 00:00:00 2001 From: Daniel Lezcano Date: Thu, 10 Jan 2008 22:44:40 -0800 Subject: [PATCH] --- yaml --- r: 78766 b: refs/heads/master c: 389f661224cdbdf178553fb09a52dc6c8bf86890 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/include/net/addrconf.h | 3 ++- trunk/net/ipv6/addrconf.c | 4 +++- trunk/net/ipv6/exthdrs.c | 2 +- 4 files changed, 7 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 88f0270855a9..c601413806e9 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 1cab3da6be6c7659f62d0d297b389cc0e48b2178 +refs/heads/master: 389f661224cdbdf178553fb09a52dc6c8bf86890 diff --git a/trunk/include/net/addrconf.h b/trunk/include/net/addrconf.h index 77f630f12806..8b1509bfc695 100644 --- a/trunk/include/net/addrconf.h +++ b/trunk/include/net/addrconf.h @@ -65,7 +65,8 @@ extern int ipv6_chk_addr(struct net *net, int strict); #if defined(CONFIG_IPV6_MIP6) || defined(CONFIG_IPV6_MIP6_MODULE) -extern int ipv6_chk_home_addr(struct in6_addr *addr); +extern int ipv6_chk_home_addr(struct net *net, + struct in6_addr *addr); #endif extern struct inet6_ifaddr *ipv6_get_ifaddr(struct net *net, struct in6_addr *addr, diff --git a/trunk/net/ipv6/addrconf.c b/trunk/net/ipv6/addrconf.c index c4df6cdff650..803caf1a3890 100644 --- a/trunk/net/ipv6/addrconf.c +++ b/trunk/net/ipv6/addrconf.c @@ -2883,13 +2883,15 @@ void if6_proc_exit(void) #if defined(CONFIG_IPV6_MIP6) || defined(CONFIG_IPV6_MIP6_MODULE) /* Check if address is a home address configured on any interface. */ -int ipv6_chk_home_addr(struct in6_addr *addr) +int ipv6_chk_home_addr(struct net *net, struct in6_addr *addr) { int ret = 0; struct inet6_ifaddr * ifp; u8 hash = ipv6_addr_hash(addr); read_lock_bh(&addrconf_hash_lock); for (ifp = inet6_addr_lst[hash]; ifp; ifp = ifp->lst_next) { + if (ifp->idev->dev->nd_net != net) + continue; if (ipv6_addr_cmp(&ifp->addr, addr) == 0 && (ifp->flags & IFA_F_HOMEADDRESS)) { ret = 1; diff --git a/trunk/net/ipv6/exthdrs.c b/trunk/net/ipv6/exthdrs.c index 2df34ed276f1..3cd1c993d52b 100644 --- a/trunk/net/ipv6/exthdrs.c +++ b/trunk/net/ipv6/exthdrs.c @@ -445,7 +445,7 @@ static int ipv6_rthdr_rcv(struct sk_buff *skb) kfree_skb(skb); return -1; } - if (!ipv6_chk_home_addr(addr)) { + if (!ipv6_chk_home_addr(&init_net, addr)) { IP6_INC_STATS_BH(ip6_dst_idev(skb->dst), IPSTATS_MIB_INADDRERRORS); kfree_skb(skb);