in6_pcb.c (222488) | in6_pcb.c (222691) |
---|---|
1/*- 2 * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. 3 * Copyright (c) 2010-2011 Juniper Networks, Inc. 4 * All rights reserved. 5 * 6 * Portions of this software were developed by Robert N. M. Watson under 7 * contract to Juniper Networks, Inc. 8 * --- 51 unchanged lines hidden (view full) --- 60 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 61 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 62 * SUCH DAMAGE. 63 * 64 * @(#)in_pcb.c 8.2 (Berkeley) 1/4/94 65 */ 66 67#include <sys/cdefs.h> | 1/*- 2 * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. 3 * Copyright (c) 2010-2011 Juniper Networks, Inc. 4 * All rights reserved. 5 * 6 * Portions of this software were developed by Robert N. M. Watson under 7 * contract to Juniper Networks, Inc. 8 * --- 51 unchanged lines hidden (view full) --- 60 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 61 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 62 * SUCH DAMAGE. 63 * 64 * @(#)in_pcb.c 8.2 (Berkeley) 1/4/94 65 */ 66 67#include <sys/cdefs.h> |
68__FBSDID("$FreeBSD: head/sys/netinet6/in6_pcb.c 222488 2011-05-30 09:43:55Z rwatson $"); | 68__FBSDID("$FreeBSD: head/sys/netinet6/in6_pcb.c 222691 2011-06-04 16:33:06Z rwatson $"); |
69 70#include "opt_inet.h" 71#include "opt_inet6.h" 72#include "opt_ipsec.h" 73 74#include <sys/param.h> 75#include <sys/systm.h> 76#include <sys/malloc.h> --- 282 unchanged lines hidden (view full) --- 359/* 360 * Outer subroutine: 361 * Connect from a socket to a specified address. 362 * Both address and port must be specified in argument sin. 363 * If don't have a local address for this socket yet, 364 * then pick one. 365 */ 366int | 69 70#include "opt_inet.h" 71#include "opt_inet6.h" 72#include "opt_ipsec.h" 73 74#include <sys/param.h> 75#include <sys/systm.h> 76#include <sys/malloc.h> --- 282 unchanged lines hidden (view full) --- 359/* 360 * Outer subroutine: 361 * Connect from a socket to a specified address. 362 * Both address and port must be specified in argument sin. 363 * If don't have a local address for this socket yet, 364 * then pick one. 365 */ 366int |
367in6_pcbconnect(register struct inpcb *inp, struct sockaddr *nam, 368 struct ucred *cred) | 367in6_pcbconnect_mbuf(register struct inpcb *inp, struct sockaddr *nam, 368 struct ucred *cred, struct mbuf *m) |
369{ 370 struct inpcbinfo *pcbinfo = inp->inp_pcbinfo; 371 register struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *)nam; 372 struct in6_addr addr6; 373 int error; 374 375 INP_WLOCK_ASSERT(inp); 376 INP_HASH_WLOCK_ASSERT(pcbinfo); --- 23 unchanged lines hidden (view full) --- 400 inp->in6p_faddr = sin6->sin6_addr; 401 inp->inp_fport = sin6->sin6_port; 402 /* update flowinfo - draft-itojun-ipv6-flowlabel-api-00 */ 403 inp->inp_flow &= ~IPV6_FLOWLABEL_MASK; 404 if (inp->inp_flags & IN6P_AUTOFLOWLABEL) 405 inp->inp_flow |= 406 (htonl(ip6_randomflowlabel()) & IPV6_FLOWLABEL_MASK); 407 | 369{ 370 struct inpcbinfo *pcbinfo = inp->inp_pcbinfo; 371 register struct sockaddr_in6 *sin6 = (struct sockaddr_in6 *)nam; 372 struct in6_addr addr6; 373 int error; 374 375 INP_WLOCK_ASSERT(inp); 376 INP_HASH_WLOCK_ASSERT(pcbinfo); --- 23 unchanged lines hidden (view full) --- 400 inp->in6p_faddr = sin6->sin6_addr; 401 inp->inp_fport = sin6->sin6_port; 402 /* update flowinfo - draft-itojun-ipv6-flowlabel-api-00 */ 403 inp->inp_flow &= ~IPV6_FLOWLABEL_MASK; 404 if (inp->inp_flags & IN6P_AUTOFLOWLABEL) 405 inp->inp_flow |= 406 (htonl(ip6_randomflowlabel()) & IPV6_FLOWLABEL_MASK); 407 |
408 in_pcbrehash(inp); | 408 in_pcbrehash_mbuf(inp, m); |
409 410 return (0); 411} 412 | 409 410 return (0); 411} 412 |
413int 414in6_pcbconnect(struct inpcb *inp, struct sockaddr *nam, struct ucred *cred) 415{ 416 417 return (in6_pcbconnect_mbuf(inp, nam, cred, NULL)); 418} 419 |
|
413void 414in6_pcbdisconnect(struct inpcb *inp) 415{ 416 417 INP_WLOCK_ASSERT(inp); 418 INP_HASH_WLOCK_ASSERT(inp->inp_pcbinfo); 419 420 bzero((caddr_t)&inp->in6p_faddr, sizeof(inp->in6p_faddr)); --- 548 unchanged lines hidden (view full) --- 969 } else 970 panic("%s: locking bug", __func__); 971 } else 972 INP_HASH_RUNLOCK(pcbinfo); 973 return (inp); 974} 975 976/* | 420void 421in6_pcbdisconnect(struct inpcb *inp) 422{ 423 424 INP_WLOCK_ASSERT(inp); 425 INP_HASH_WLOCK_ASSERT(inp->inp_pcbinfo); 426 427 bzero((caddr_t)&inp->in6p_faddr, sizeof(inp->in6p_faddr)); --- 548 unchanged lines hidden (view full) --- 976 } else 977 panic("%s: locking bug", __func__); 978 } else 979 INP_HASH_RUNLOCK(pcbinfo); 980 return (inp); 981} 982 983/* |
977 * Public inpcb lookup routines, accepting a 4-tuple. | 984 * Public inpcb lookup routines, accepting a 4-tuple, and optionally, an mbuf 985 * from which a pre-calculated hash value may be extracted. |
978 */ 979struct inpcb * 980in6_pcblookup(struct inpcbinfo *pcbinfo, struct in6_addr *faddr, u_int fport, 981 struct in6_addr *laddr, u_int lport, int lookupflags, struct ifnet *ifp) 982{ | 986 */ 987struct inpcb * 988in6_pcblookup(struct inpcbinfo *pcbinfo, struct in6_addr *faddr, u_int fport, 989 struct in6_addr *laddr, u_int lport, int lookupflags, struct ifnet *ifp) 990{ |
991 KASSERT((lookupflags & ~INPLOOKUP_MASK) == 0, 992 ("%s: invalid lookup flags %d", __func__, lookupflags)); 993 KASSERT((lookupflags & (INPLOOKUP_RLOCKPCB | INPLOOKUP_WLOCKPCB)) != 0, 994 ("%s: LOCKPCB not set", __func__)); |
|
983 | 995 |
996 return (in6_pcblookup_hash(pcbinfo, faddr, fport, laddr, lport, 997 lookupflags, ifp)); 998} 999 1000struct inpcb * 1001in6_pcblookup_mbuf(struct inpcbinfo *pcbinfo, struct in6_addr *faddr, 1002 u_int fport, struct in6_addr *laddr, u_int lport, int lookupflags, 1003 struct ifnet *ifp, struct mbuf *m) 1004{ |
|
984 KASSERT((lookupflags & ~INPLOOKUP_MASK) == 0, 985 ("%s: invalid lookup flags %d", __func__, lookupflags)); 986 KASSERT((lookupflags & (INPLOOKUP_RLOCKPCB | INPLOOKUP_WLOCKPCB)) != 0, 987 ("%s: LOCKPCB not set", __func__)); 988 989 return (in6_pcblookup_hash(pcbinfo, faddr, fport, laddr, lport, 990 lookupflags, ifp)); 991} --- 16 unchanged lines hidden --- | 1005 KASSERT((lookupflags & ~INPLOOKUP_MASK) == 0, 1006 ("%s: invalid lookup flags %d", __func__, lookupflags)); 1007 KASSERT((lookupflags & (INPLOOKUP_RLOCKPCB | INPLOOKUP_WLOCKPCB)) != 0, 1008 ("%s: LOCKPCB not set", __func__)); 1009 1010 return (in6_pcblookup_hash(pcbinfo, faddr, fport, laddr, lport, 1011 lookupflags, ifp)); 1012} --- 16 unchanged lines hidden --- |