Date: Tue, 29 Jan 2013 19:55:53 +0000 (UTC) From: "Andrey V. Elsukov" <ae@FreeBSD.org> To: src-committers@freebsd.org, svn-src-user@freebsd.org Subject: svn commit: r246088 - user/ae/inet6/sys/netinet6 Message-ID: <201301291955.r0TJtrCv031222@svn.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: ae Date: Tue Jan 29 19:55:53 2013 New Revision: 246088 URL: http://svnweb.freebsd.org/changeset/base/246088 Log: The in6ifa_ifwithaddr function now takes as arguments to lookup a pointer to the struct in6_addr and zone id. This allows use it without need of fill sockaddr_in6 structure, when we operate with a in6_addr. Modified: user/ae/inet6/sys/netinet6/in6.c user/ae/inet6/sys/netinet6/in6_pcb.c user/ae/inet6/sys/netinet6/in6_var.h Modified: user/ae/inet6/sys/netinet6/in6.c ============================================================================== --- user/ae/inet6/sys/netinet6/in6.c Tue Jan 29 19:06:16 2013 (r246087) +++ user/ae/inet6/sys/netinet6/in6.c Tue Jan 29 19:55:53 2013 (r246088) @@ -1908,19 +1908,15 @@ in6ifa_ifpwithaddr(struct ifnet *ifp, st * ifaddr is returned referenced. */ struct in6_ifaddr * -in6ifa_ifwithaddr(const struct sockaddr_in6 *sa6) +in6ifa_ifwithaddr(const struct in6_addr *addr, uint32_t zoneid) { struct in6_ifaddr *ia; IN6_IFADDR_RLOCK(); - LIST_FOREACH(ia, IN6ADDR_HASH(&sa6->sin6_addr), ia6_hash) { - if (IN6_ARE_ADDR_EQUAL(IA6_IN6(ia), &sa6->sin6_addr)) { - /* - * XXX: should we determine the scope and compare - * sin6_scope_id with corresponding zone id? - */ - if (sa6->sin6_scope_id != 0 && - sa6->sin6_scope_id != in6_getlinkzone(ia->ia_ifp)) + LIST_FOREACH(ia, IN6ADDR_HASH(addr), ia6_hash) { + if (IN6_ARE_ADDR_EQUAL(IA6_IN6(ia), addr)) { + if (zoneid != 0 && + zoneid != ia->ia_addr.sin6_scope_id) continue; ifa_ref(ia); break; Modified: user/ae/inet6/sys/netinet6/in6_pcb.c ============================================================================== --- user/ae/inet6/sys/netinet6/in6_pcb.c Tue Jan 29 19:06:16 2013 (r246087) +++ user/ae/inet6/sys/netinet6/in6_pcb.c Tue Jan 29 19:55:53 2013 (r246088) @@ -164,7 +164,9 @@ in6_pcbbind(register struct inpcb *inp, struct in6_ifaddr *ifa; sin6->sin6_port = 0; /* yech... */ - if ((ifa = in6ifa_ifwithaddr(sin6)) == NULL && + ifa = in6ifa_ifwithaddr(&sin6->sin6_addr, + sin6->sin6_scope_id); + if (ifa == NULL && (inp->inp_flags & INP_BINDANY) == 0) { return (EADDRNOTAVAIL); } Modified: user/ae/inet6/sys/netinet6/in6_var.h ============================================================================== --- user/ae/inet6/sys/netinet6/in6_var.h Tue Jan 29 19:06:16 2013 (r246087) +++ user/ae/inet6/sys/netinet6/in6_var.h Tue Jan 29 19:55:53 2013 (r246088) @@ -801,7 +801,7 @@ void in6_setmaxmtu(void); int in6_if2idlen(struct ifnet *); struct in6_ifaddr *in6ifa_ifpforlinklocal(struct ifnet *, int); struct in6_ifaddr *in6ifa_ifpwithaddr(struct ifnet *, struct in6_addr *); -struct in6_ifaddr *in6ifa_ifwithaddr(const struct sockaddr_in6 *); +struct in6_ifaddr *in6ifa_ifwithaddr(const struct in6_addr *, uint32_t); char *ip6_sprintf(char *, const struct in6_addr *); int in6_addr2zoneid(struct ifnet *, struct in6_addr *, u_int32_t *); int in6_matchlen(struct in6_addr *, struct in6_addr *);
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201301291955.r0TJtrCv031222>