diff options
author | oliver <oliver@FreeBSD.org> | 2004-10-24 20:16:51 +0800 |
---|---|---|
committer | oliver <oliver@FreeBSD.org> | 2004-10-24 20:16:51 +0800 |
commit | 6d69eb2f7e41abefedf593a8eee5e5afd4f76bf4 (patch) | |
tree | 339dcf06668a7c2c8110c972ec4bdac2d24d6627 /security/oidentd/files | |
parent | 888f87e89a927acecce958b55d83739fe622e20b (diff) | |
download | freebsd-ports-gnome-6d69eb2f7e41abefedf593a8eee5e5afd4f76bf4.tar.gz freebsd-ports-gnome-6d69eb2f7e41abefedf593a8eee5e5afd4f76bf4.tar.zst freebsd-ports-gnome-6d69eb2f7e41abefedf593a8eee5e5afd4f76bf4.zip |
fix unprev. IPv6 for FreeBSD 4
Bump PORTREVISION
Noted By: Dariusz Kulinski <d.kulinski@gmail.com>
Diffstat (limited to 'security/oidentd/files')
-rw-r--r-- | security/oidentd/files/patch-unprivileged_ipv6 | 217 |
1 files changed, 215 insertions, 2 deletions
diff --git a/security/oidentd/files/patch-unprivileged_ipv6 b/security/oidentd/files/patch-unprivileged_ipv6 index a005c6eb5261..5a798d101d46 100644 --- a/security/oidentd/files/patch-unprivileged_ipv6 +++ b/security/oidentd/files/patch-unprivileged_ipv6 @@ -1,5 +1,218 @@ ---- src/kernel/freebsd5.c.orig Wed Feb 12 03:15:59 2003 -+++ src/kernel/freebsd5.c Fri Oct 15 19:36:01 2004 +diff -ru src.old/kernel/freebsd.c src/kernel/freebsd.c +--- src.old/kernel/freebsd.c Tue May 18 23:12:23 2004 ++++ src/kernel/freebsd.c Tue May 18 23:13:45 2004 +@@ -159,11 +159,11 @@ + + #ifdef _HAVE_OLD_INPCB + +-static struct socket *getlist4( void *arg, ++static struct socket *getlist( void *arg, + in_port_t lport, + in_port_t fport, +- const struct in_addr *laddr, +- const struct in_addr *faddr) ++ const struct sockaddr *laddr, ++ const struct sockaddr *faddr) + { + struct inpcb *pcbp = arg; + struct inpcb *head; +@@ -175,8 +175,8 @@ + + do { + if (opt_enabled(PROXY)) { +- if (faddr->s_addr == SIN4(&proxy)->sin_addr.s_addr && +- laddr->s_addr != SIN4(&proxy)->sin_addr.s_addr && ++ if (SIN4(faddr)->sin_addr.s_addr == SIN4(&proxy)->sin_addr.s_addr && ++ SIN4(laddr)->sin_addr.s_addr != SIN4(&proxy)->sin_addr.s_addr && + pcbp->inp_fport == fport && + pcbp->inp_lport == lport) + { +@@ -184,8 +184,8 @@ + } + } + +- if (pcbp->inp_faddr.s_addr == faddr->s_addr && +- pcbp->inp_laddr.s_addr == laddr->s_addr && ++ if (pcbp->inp_faddr.s_addr == SIN4(faddr)->sin_addr.s_addr && ++ pcbp->inp_laddr.s_addr == SIN4(laddr)->sin_addr.s_addr && + pcbp->inp_fport == fport && + pcbp->inp_lport == lport) + { +@@ -199,28 +199,45 @@ + + #else + +-static struct socket *getlist4( void *arg, ++static struct socket *getlist( void *arg, + in_port_t lport, + in_port_t fport, +- const struct in_addr *laddr, +- const struct in_addr *faddr) ++ const struct sockaddr *local, ++ const struct sockaddr *remote) + { + struct inpcb *head, pcbp; + struct inpcbhead *pcbhead = arg; ++ char *faddr, *laddr, *pfaddr, *pladdr; ++ int alen; + +- (void) laddr; ++ if (remote->sa_family != local->sa_family) ++ return (NULL); ++ switch (remote->sa_family) { ++ case AF_INET: ++ faddr = (char *)&SIN4(remote)->sin_addr; ++ laddr = (char *)&SIN4(local)->sin_addr; ++ break; ++#ifdef INP_IPV6 ++ case AF_INET6: ++ faddr = (char *)&SIN6(remote)->sin6_addr; ++ laddr = (char *)&SIN6(local)->sin6_addr; ++ break; ++#endif ++ default: ++ return (NULL); ++ } + + head = pcbhead->lh_first; + if (head == NULL) + return (NULL); + +- do { ++ for (; head != NULL; head = pcbp.inp_list.le_next) { + if (getbuf((u_long) head, &pcbp, sizeof(struct inpcb)) == -1) + break; + +- if (opt_enabled(PROXY)) { +- if (faddr->s_addr == SIN4(&proxy)->sin_addr.s_addr && +- laddr->s_addr != SIN4(&proxy)->sin_addr.s_addr && ++ if (opt_enabled(PROXY) && remote->sa_family == AF_INET) { ++ if (SIN4(remote)->sin_addr.s_addr == SIN4(&proxy)->sin_addr.s_addr && ++ SIN4(local)->sin_addr.s_addr != SIN4(&proxy)->sin_addr.s_addr && + pcbp.inp_fport == fport && + pcbp.inp_lport == lport) + { +@@ -228,16 +245,39 @@ + } + } + +- if (pcbp.inp_faddr.s_addr == faddr->s_addr && +- pcbp.inp_laddr.s_addr == laddr->s_addr && ++#ifdef INP_IPV6 ++ if (pcbp.inp_vflag & INP_IPV4) ++ { ++ if (remote->sa_family != AF_INET) ++ continue; ++ pfaddr = (char *)&pcbp.inp_faddr; ++ pladdr = (char *)&pcbp.inp_laddr; ++ alen = sizeof(struct in_addr); ++ } ++ else if (pcbp.inp_vflag & INP_IPV6) ++ { ++ if (remote->sa_family != AF_INET6) ++ continue; ++ pfaddr = (char *)&pcbp.in6p_faddr; ++ pladdr = (char *)&pcbp.in6p_laddr; ++ alen = sizeof(struct in6_addr); ++ } ++ else ++ continue; ++#else ++ pfaddr = (char *)&pcbp.inp_faddr; ++ pladdr = (char *)&pcbp.inp_laddr; ++ alen = sizeof(struct in_addr); ++#endif ++ if (memcmp(pfaddr, faddr, alen) == 0 && ++ memcmp(pladdr, laddr, alen) == 0 && + pcbp.inp_fport == fport && + pcbp.inp_lport == lport) + { + return (pcbp.inp_socket); + } + +- head = pcbp.inp_list.le_next; +- } while (head != NULL); ++ } + + return (NULL); + } +@@ -248,7 +288,7 @@ + ** Return the UID of the connection owner + */ + +-int get_user4( in_port_t lport, ++static int get_user( in_port_t lport, + in_port_t fport, + struct sockaddr_storage *laddr, + struct sockaddr_storage *faddr) +@@ -276,8 +316,9 @@ + tcb.inp_prev = (struct inpcb *) kinfo->nl[N_TCB].n_value; + #endif + +- sockp = getlist4(&tcb, lport, fport, +- &SIN4(laddr)->sin_addr, &SIN4(faddr)->sin_addr); ++ sockp = getlist(&tcb, lport, fport, ++ (struct sockaddr *)laddr, ++ (struct sockaddr *)faddr); + + if (sockp == NULL) + return (-1); +@@ -346,6 +387,14 @@ + return (-1); + } + ++int get_user4( in_port_t lport, ++ in_port_t fport, ++ struct sockaddr_storage *laddr, ++ struct sockaddr_storage *faddr) ++{ ++ return (get_user(lport, fport, laddr, faddr)); ++} ++ + #ifdef MASQ_SUPPORT + + /* +@@ -456,36 +505,7 @@ + struct sockaddr_storage *laddr, + struct sockaddr_storage *faddr) + { +- struct ucred ucred; +- struct sockaddr_in6 sin6[2]; +- int len; +- int ret; +- +- len = sizeof(struct ucred); +- +- memset(sin6, 0, sizeof(sin6)); +- +- sin6[0].sin6_len = sizeof(struct sockaddr_in6); +- sin6[0].sin6_family = AF_INET6; +- sin6[0].sin6_port = lport; +- memcpy(&sin6[0].sin6_addr, &SIN6(laddr)->sin6_addr, +- sizeof(sin6[0].sin6_addr)); +- +- sin6[1].sin6_len = sizeof(struct sockaddr_in6); +- sin6[1].sin6_family = AF_INET6; +- sin6[1].sin6_port = fport; +- memcpy(&sin6[1].sin6_addr, &SIN6(faddr)->sin6_addr, +- sizeof(sin6[1].sin6_addr)); +- +- ret = sysctlbyname("net.inet6.tcp6.getcred", +- &ucred, &len, sin6, sizeof(sin6)); +- +- if (ret == -1) { +- debug("sysctlbyname: %s", strerror(errno)); +- return (-1); +- } +- +- return (ucred.cr_uid); ++ return (get_user(lport, fport, laddr, faddr)); + } + + #endif +diff -ru src.old/kernel/freebsd5.c src/kernel/freebsd5.c +--- src.old/kernel/freebsd5.c Tue May 18 23:12:23 2004 ++++ src/kernel/freebsd5.c Tue May 18 23:12:46 2004 @@ -160,11 +160,11 @@ #ifdef _HAVE_OLD_INPCB |