svn commit: r258933 - user/ae/inet6/sys/netinet6
Andrey V. Elsukov
ae at FreeBSD.org
Wed Dec 4 20:02:17 UTC 2013
Author: ae
Date: Wed Dec 4 20:02:16 2013
New Revision: 258933
URL: http://svnweb.freebsd.org/changeset/base/258933
Log:
Compare zone indexes only when connection has link-local scope.
Modified:
user/ae/inet6/sys/netinet6/in6_pcb.c
Modified: user/ae/inet6/sys/netinet6/in6_pcb.c
==============================================================================
--- user/ae/inet6/sys/netinet6/in6_pcb.c Wed Dec 4 19:51:44 2013 (r258932)
+++ user/ae/inet6/sys/netinet6/in6_pcb.c Wed Dec 4 20:02:16 2013 (r258933)
@@ -973,9 +973,8 @@ in6_pcblookup_hash_locked(struct inpcbin
continue;
if (IN6_ARE_ADDR_EQUAL(&inp->in6p_faddr, faddr) &&
IN6_ARE_ADDR_EQUAL(&inp->in6p_laddr, laddr) &&
- inp->inp_fport == fport &&
- inp->inp_lport == lport &&
- inp->in6p_zoneid == zoneid) {
+ inp->inp_fport == fport && inp->inp_lport == lport && (
+ inp->in6p_zoneid == 0 || inp->in6p_zoneid == zoneid)) {
/*
* XXX We should be able to directly return
* the inp here, without any checks.
@@ -1031,8 +1030,9 @@ in6_pcblookup_hash_locked(struct inpcbin
continue;
}
- if (IN6_ARE_ADDR_EQUAL(&inp->in6p_laddr, laddr) &&
- inp->in6p_zoneid == zoneid) {
+ if (IN6_ARE_ADDR_EQUAL(&inp->in6p_laddr, laddr) && (
+ inp->in6p_zoneid == 0 ||
+ inp->in6p_zoneid == zoneid)) {
if (injail)
return (inp);
else
More information about the svn-src-user
mailing list