diff options
Diffstat (limited to 'sys/netinet6')
-rw-r--r-- | sys/netinet6/debug.h | 215 | ||||
-rw-r--r-- | sys/netinet6/debug_inet6.c | 121 | ||||
-rw-r--r-- | sys/netinet6/debug_inet6.h | 25 | ||||
-rw-r--r-- | sys/netinet6/icmpv6.h | 2 | ||||
-rw-r--r-- | sys/netinet6/icmpv6_var.h | 2 | ||||
-rw-r--r-- | sys/netinet6/in6.c | 1 | ||||
-rw-r--r-- | sys/netinet6/in6.h | 1 | ||||
-rw-r--r-- | sys/netinet6/in6_cksum.c | 2 | ||||
-rw-r--r-- | sys/netinet6/in6_pcb.c | 2 | ||||
-rw-r--r-- | sys/netinet6/in6_proto.c | 2 | ||||
-rw-r--r-- | sys/netinet6/in6_var.h | 2 | ||||
-rw-r--r-- | sys/netinet6/nd6_protocol.h | 2 | ||||
-rw-r--r-- | sys/netinet6/osdep.h | 148 | ||||
-rw-r--r-- | sys/netinet6/raw_ipv6.c | 317 | ||||
-rw-r--r-- | sys/netinet6/tcpipv6.h | 2 |
15 files changed, 35 insertions, 809 deletions
diff --git a/sys/netinet6/debug.h b/sys/netinet6/debug.h deleted file mode 100644 index a27b9fb427b..00000000000 --- a/sys/netinet6/debug.h +++ /dev/null @@ -1,215 +0,0 @@ -/* -%%% portions-copyright-nrl-95 -Portions of this software are Copyright 1995-1998 by Randall Atkinson, -Ronald Lee, Daniel McDonald, Bao Phan, and Chris Winters. All Rights -Reserved. All rights under this copyright have been assigned to the US -Naval Research Laboratory (NRL). The NRL Copyright Notice and License -Agreement Version 1.1 (January 17, 1995) applies to these portions of the -software. -You should have received a copy of the license with this software. If you -didn't get a copy, you may request one from <license@ipv6.nrl.navy.mil>. - -*/ - -#ifndef _SYS_DEBUG_H -#define _SYS_DEBUG_H 1 - -#ifdef DEBUG_NRL -#include <sys/osdep.h> -#else /* DEBUG_NRL */ -#if __OpenBSD__ -#include <netinet6/osdep.h> -#else /* __OpenBSD__ */ -#include <sys/osdep.h> -#endif /* __OpenBSD__ */ -#endif /* DEBUG_NRL */ - -/* Non-ANSI compilers don't stand a chance. You PROBABLY need GNU C. */ -#ifndef __STDC__ -#error An ANSI C compiler is required here. -#endif /* __STDC__ */ - -#ifndef _KERN_DEBUG_GENERIC_C -extern int debug_level; -#endif /* _KERN_DEBUG_GENERIC_DEBUG_C */ - -/* Debugging levels */ - -#define __DEBUG_LEVEL_ALL (INT_MAX-1) /* Report all messages. */ -#define __DEBUG_LEVEL_NONE 0 /* Report no messages. */ - -#define __DEBUG_LEVEL_CRITICAL 3 -#define __DEBUG_LEVEL_ERROR 7 -#define __DEBUG_LEVEL_MAJOREVENT 10 -#define __DEBUG_LEVEL_EVENT 15 -#define __DEBUG_LEVEL_GROSSEVENT 20 -#define __DEBUG_LEVEL_FINISHED 1000 - -/* Compatibility macros */ - -#define __DEBUG_LEVEL_MAJOR_EVENT __DEBUG_LEVEL_MAJOREVENT -#define __DEBUG_LEVEL_GROSS_EVENT __DEBUG_LEVEL_GROSSEVENT -#define __DEBUG_LEVEL_IDL_CRITICAL __DEBUG_LEVEL_CRITICAL -#define __DEBUG_LEVEL_IDL_ERROR __DEBUG_LEVEL_ERROR -#define __DEBUG_LEVEL_IDL_MAJOR_EVENT __DEBUG_LEVEL_MAJOREVENT -#define __DEBUG_LEVEL_IDL_EVENT __DEBUG_LEVEL_EVENT -#define __DEBUG_LEVEL_IDL_GROSS_EVENT __DEBUG_LEVEL_GROSSEVENT -#define __DEBUG_LEVEL_IDL_FINISHED __DEBUG_LEVEL_FINISHED - -/* Unless you have optimization turned off and your compiler is drain bamaged, - this will turn in to a syntactically inert no-op - cmetz */ -#define __DEBUG_NOP do { } while (0) - -#ifdef DEBUG_NRL -/* - * Make sure argument for DPRINTF is in parentheses. - * - * For both DPRINTF and DDO, and attempt was made to make both macros - * be usable as normal C statments. There is a small amount of compiler - * trickery (if-else clauses with effectively null statements), which may - * cause a few compilers to complain. - */ - -#ifndef __GENERIC_DEBUG_LEVEL -#define __GENERIC_DEBUG_LEVEL debug_level -#endif /* __GENERIC_DEBUG_LEVEL */ - -/* - * DPRINTF() is a general printf statement. The "arg" is literally what - * would follow the function name printf, which means it has to be in - * parenthesis. Unlimited arguments can be used this way. - * - * EXAMPLE: - * DPRINTF(IDL_MAJOR_EVENT,("Hello, world. IP version %d.\n",vers)); - */ -#undef DPRINTF -#define DPRINTF(lev,arg) \ - if (__DEBUG_LEVEL_ ## lev <= __GENERIC_DEBUG_LEVEL) { \ - printf arg; \ - } else \ - __DEBUG_NOP - -/* - * DDO() executes a series of statements at a certain debug level. The - * "stmt" argument is a statement in the sense of a "statement list" in a - * C grammar. "stmt" does not have to end with a semicolon. - * - * EXAMPLE: - * DDO(IDL_CRITICAL,dump_ipv6(header), dump_inpcb(inp)); - */ -#undef DDO -#define DDO(lev,stmt) \ - if (__DEBUG_LEVEL_ ## lev <= __GENERIC_DEBUG_LEVEL) { \ - stmt ; \ - } else \ - __DEBUG_NOP - -/* - * DP() is a shortcut for DPRINTF(). Basically: - * - * DP(lev, var, fmt) == DPRINTF(IDL_lev, ("var = %fmt\n", var)) - * - * It is handy for printing single variables without a lot of typing. - * - * EXAMPLE: - * - * DP(CRITICAL,length,d); - * same as DPRINTF(IDL_CRITICAL, ("length = %d\n", length)) - */ -#undef DP -#define DP(lev, var, fmt) \ - DPRINTF(lev, (#var " = %" #fmt "\n", var)) - -#undef DEBUG_STATUS -#if defined(__GNUC__) && (__GNUC__ >= 2) -#define DEBUG_STATUS debug_status(__FILE__ ":" __FUNCTION__, __LINE__, __builtin_return_address(0)) -#else /* defined(__GNUC__) && (__GNUC__ >= 2) */ -#define DEBUG_STATUS debug_status(__FILE__, __LINE__, (void *)0) -#endif /* defined(__GNUC__) && (__GNUC__ >= 2) */ - -/* Call as: - - DS(); -*/ -#undef DS -#define DS() DPRINTF(IDL_CRITICAL, ("%s\n", DEBUG_STATUS)) -#else /* DEBUG_NRL */ -#undef DPRINTF -#define DPRINTF(lev,arg) __DEBUG_NOP -#undef DDO -#define DDO(lev, stmt) __DEBUG_NOP -#undef DP -#define DP(x, y, z) __DEBUG_NOP -#undef DS -#define DS() __DEBUG_NOP -#endif /* DEBUG_NRL */ - -#ifdef DEBUG_MALLOC -void *debug_malloc_malloc(unsigned int n, char *creator); -void debug_malloc_free(void *p); -void debug_malloc_dump(void); -void debug_malloc_flush(void); -#endif /* DEBUG_MALLOC */ - -#ifdef DEBUG_NRL -char *debug_status(char *filefunction, unsigned int line, void *returnaddress); -void dump_buf_small(void *, int); -void debug_dump_buf(void *, int); -void dump_packet(void *buf, int len); - -struct dump_flags { - int val; - char *name; -}; -void dump_flags(struct dump_flags *, int); - -struct sockaddr; -void dump_sockaddr(struct sockaddr *); -void dump_smart_sockaddr(void *); - -#ifdef __linux__ -struct sk_buff; -void dump_skb(struct sk_buff *); -#endif /* __linux__ */ - -#ifdef OSDEP_BSD -struct sockaddr_dl; -void dump_sockaddr_dl(struct sockaddr_dl *); -struct mbuf; -void dump_mbuf_flags(struct mbuf *); -void dump_mbuf_hdr(struct mbuf *); -void dump_mbuf(struct mbuf *); -void dump_mchain_hdr(struct mbuf *); -void dump_mchain(struct mbuf *); -void dump_mbuf_tcpdump(struct mbuf *); -struct ifaddr; -void dump_ifa(struct ifaddr *); -struct ifnet; -void dump_ifp(struct ifnet *); -struct route; -void dump_route(struct route *); -struct rtentry; -void dump_rtentry(struct rtentry *); -struct inpcb; -void dump_inpcb(struct inpcb *); -#if __NetBSD__ || __OpenBSD__ -struct inpcbtable; -void dump_inpcbs(struct inpcbtable *); -#else /* __NetBSD__ || __OpenBSD__ */ -void dump_inpcbs(struct inpcb *); -#endif /* __NetBSD__ || __OpenBSD__ */ -#endif /* OSDEP_BSD */ - -#ifdef INET -struct in_addr; -void dump_in_addr(struct in_addr *); -struct sockaddr_in; -void dump_sockaddr_in(struct sockaddr_in *); -#endif /* INET */ - -#ifdef INET6 -#include <netinet6/debug_inet6.h> -#endif /* INET6 */ -#endif /* DEBUG_NRL */ - -#endif /* _SYS_DEBUG_H */ diff --git a/sys/netinet6/debug_inet6.c b/sys/netinet6/debug_inet6.c deleted file mode 100644 index e90b090c50d..00000000000 --- a/sys/netinet6/debug_inet6.c +++ /dev/null @@ -1,121 +0,0 @@ -/* -%%% copyright-nrl-95 -This software is Copyright 1995-1998 by Randall Atkinson, Ronald Lee, -Daniel McDonald, Bao Phan, and Chris Winters. All Rights Reserved. All -rights under this copyright have been assigned to the US Naval Research -Laboratory (NRL). The NRL Copyright Notice and License Agreement Version -1.1 (January 17, 1995) applies to this software. -You should have received a copy of the license with this software. If you -didn't get a copy, you may request one from <license@ipv6.nrl.navy.mil>. - -*/ - -#include <sys/osdep.h> - -#ifdef OSDEP_BSD -#include <netinet6/ipv6.h> -#include <netinet6/ipv6_icmp.h> -#endif /* OSDEP_BSD */ - -#include <sys/debug.h> - -/* - * Globals - */ - -/*---------------------------------------------------------------------- - * Dump an IPv6 address. Don't compress 0's out because of debugging. - ----------------------------------------------------------------------*/ -void dump_in6_addr(struct in6_addr *in6_addr) -{ - uint16_t *p = (uint16_t *)in6_addr; - int i = 0; - - if (!in6_addr) { - printf("Dereference a NULL in6_addr? I don't think so.\n"); - return; - } - - while (i++ < 7) - printf("%04x:", ntohs(*(p++))); - printf("%04x\n", ntohs(*p)); -} - -/*---------------------------------------------------------------------- - * Dump an IPv6 socket address. - ----------------------------------------------------------------------*/ -void dump_sockaddr_in6(struct sockaddr_in6 *sin6) -{ - printf("sockaddr_in6 at %08x: ", OSDEP_PCAST(sin6)); - if (!sin6) - goto ret; - -#if OSDEP_SALEN - printf("len=%d, ", sin6->sin6_len); -#endif /* OSDEP_SALEN */ - printf("family=%d, port=%d, flowinfo=%lx, addr=", sin6->sin6_family, ntohs(sin6->sin6_port), (unsigned long)ntohl(sin6->sin6_flowinfo)); - dump_in6_addr(&sin6->sin6_addr); - -ret: - printf("\n"); -}; - -#ifdef OSDEP_BSD -/*---------------------------------------------------------------------- - * Dump an IPv6 header. - ----------------------------------------------------------------------*/ -void dump_ipv6(struct ipv6 *ipv6) -{ - if (!ipv6) { - printf("Dereference a NULL ipv6? I don't think so.\n"); - return; - } - - printf("Vers & flow label (conv to host order) 0x%x\n", - (unsigned int)htonl(ipv6->ipv6_versfl)); - printf("Length (conv) = %d, nexthdr = %d, hoplimit = %d.\n", - htons(ipv6->ipv6_length),ipv6->ipv6_nexthdr,ipv6->ipv6_hoplimit); - printf("Src: "); - dump_in6_addr(&ipv6->ipv6_src); - printf("Dst: "); - dump_in6_addr(&ipv6->ipv6_dst); -} - -/*---------------------------------------------------------------------- - * Dump an ICMPv6 header. This function is not very smart beyond the - * type, code, and checksum. - ----------------------------------------------------------------------*/ -void dump_ipv6_icmp(struct ipv6_icmp *icp) -{ - if (!icp) { - printf("Dereference a NULL ipv6_icmp? I don't think so.\n"); - return; - } - - printf("type %d, code %d, cksum (conv) = 0x%x\n",icp->icmp_type, - icp->icmp_code,htons(icp->icmp_cksum)); - printf("First four bytes: 0x%x", (unsigned int)htonl(icp->icmp_unused)); - printf("Next four bytes: 0x"); - debug_dump_buf((void *)icp->icmp_echodata, 4); - printf("\n"); -} - -#ifdef KERNEL -/*---------------------------------------------------------------------- - * Dump an IPv6 discovery queue structure. - ----------------------------------------------------------------------*/ -void dump_discq(struct discq *dq) -{ - if (!dq) { - printf("Dereference a NULL discq? I don't think so.\n"); - return; - } - - printf("dq_next = 0x%lx, dq_prev = 0x%lx, dq_rt = 0x%lx,\n", (unsigned long)dq->dq_next, - (unsigned long)dq->dq_prev, (unsigned long)dq->dq_rt); - printf("dq_queue = 0x%lx.\n", (unsigned long)dq->dq_queue); - /* Dump first mbuf chain? */ - /*printf("dq_expire = %d (0x%x).\n",dq->dq_expire,dq->dq_expire);*/ -} -#endif /* KERNEL */ -#endif /* OSDEP_BSD */ diff --git a/sys/netinet6/debug_inet6.h b/sys/netinet6/debug_inet6.h deleted file mode 100644 index b443db4ef70..00000000000 --- a/sys/netinet6/debug_inet6.h +++ /dev/null @@ -1,25 +0,0 @@ -/* -%%% copyright-nrl-95 -This software is Copyright 1995-1998 by Randall Atkinson, Ronald Lee, -Daniel McDonald, Bao Phan, and Chris Winters. All Rights Reserved. All -rights under this copyright have been assigned to the US Naval Research -Laboratory (NRL). The NRL Copyright Notice and License Agreement Version -1.1 (January 17, 1995) applies to this software. -You should have received a copy of the license with this software. If you -didn't get a copy, you may request one from <license@ipv6.nrl.navy.mil>. - -*/ -#ifndef _NETINET6_DEBUG_INET6_H -#define _NETINET6_DEBUG_INET6_H 1 - -struct in6_addr; -void dump_in6_addr(struct in6_addr *); -struct sockaddr_in6; -void dump_sockaddr_in6(struct sockaddr_in6 *); -struct ipv6; -void dump_ipv6(struct ipv6 *ipv6); -struct ipv6_icmp; -void dump_ipv6_icmp(struct ipv6_icmp *icp); -struct discq; -void dump_discq(struct discq *dq); -#endif /* _NETINET6_DEBUG_INET6_H */ diff --git a/sys/netinet6/icmpv6.h b/sys/netinet6/icmpv6.h index 31ac045a677..11a337f3809 100644 --- a/sys/netinet6/icmpv6.h +++ b/sys/netinet6/icmpv6.h @@ -1,3 +1,5 @@ +/* $OpenBSD: icmpv6.h,v 1.2 1999/12/10 08:53:17 angelos Exp $ */ + /* %%% portions-copyright-nrl-97 Portions of this software are Copyright 1997-1998 by Randall Atkinson, diff --git a/sys/netinet6/icmpv6_var.h b/sys/netinet6/icmpv6_var.h index d92bd7bb120..ad468c848c7 100644 --- a/sys/netinet6/icmpv6_var.h +++ b/sys/netinet6/icmpv6_var.h @@ -1,3 +1,5 @@ +/* $OpenBSD: icmpv6_var.h,v 1.5 1999/12/10 08:53:17 angelos Exp $ */ + /* %%% copyright-nrl-95 This software is Copyright 1995-1998 by Randall Atkinson, Ronald Lee, diff --git a/sys/netinet6/in6.c b/sys/netinet6/in6.c index 02f3da2447f..f8c50848539 100644 --- a/sys/netinet6/in6.c +++ b/sys/netinet6/in6.c @@ -1,3 +1,4 @@ +/* $OpenBSD: in6.c,v 1.8 1999/12/10 08:53:17 angelos Exp $ */ /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. * All rights reserved. diff --git a/sys/netinet6/in6.h b/sys/netinet6/in6.h index 8bafafe7bb9..4043de425f6 100644 --- a/sys/netinet6/in6.h +++ b/sys/netinet6/in6.h @@ -1,3 +1,4 @@ +/* $OpenBSD: in6.h,v 1.9 1999/12/10 08:53:17 angelos Exp $ */ /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. * All rights reserved. diff --git a/sys/netinet6/in6_cksum.c b/sys/netinet6/in6_cksum.c index 16bb1ea124a..a8775312bce 100644 --- a/sys/netinet6/in6_cksum.c +++ b/sys/netinet6/in6_cksum.c @@ -1,3 +1,5 @@ +/* $OpenBSD: in6_cksum.c,v 1.3 1999/12/10 08:53:17 angelos Exp $ */ + /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. * All rights reserved. diff --git a/sys/netinet6/in6_pcb.c b/sys/netinet6/in6_pcb.c index 22322457a00..02191ec6d24 100644 --- a/sys/netinet6/in6_pcb.c +++ b/sys/netinet6/in6_pcb.c @@ -1,3 +1,5 @@ +/* $OpenBSD: in6_pcb.c,v 1.8 1999/12/10 08:53:17 angelos Exp $ */ + /* %%% copyright-nrl-95 This software is Copyright 1995-1998 by Randall Atkinson, Ronald Lee, diff --git a/sys/netinet6/in6_proto.c b/sys/netinet6/in6_proto.c index e9903a4f54e..599e0af4a37 100644 --- a/sys/netinet6/in6_proto.c +++ b/sys/netinet6/in6_proto.c @@ -1,3 +1,5 @@ +/* $OpenBSD: in6_proto.c,v 1.5 1999/12/10 08:53:17 angelos Exp $ */ + /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. * All rights reserved. diff --git a/sys/netinet6/in6_var.h b/sys/netinet6/in6_var.h index 9db4753fbd2..31ff8983a6e 100644 --- a/sys/netinet6/in6_var.h +++ b/sys/netinet6/in6_var.h @@ -1,3 +1,5 @@ +/* $OpenBSD: in6_var.h,v 1.5 1999/12/10 08:53:17 angelos Exp $ */ + /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. * All rights reserved. diff --git a/sys/netinet6/nd6_protocol.h b/sys/netinet6/nd6_protocol.h index 58e813bf547..0121a7390b6 100644 --- a/sys/netinet6/nd6_protocol.h +++ b/sys/netinet6/nd6_protocol.h @@ -1,3 +1,5 @@ +/* $OpenBSD: nd6_protocol.h,v 1.3 1999/12/10 08:53:17 angelos Exp $ */ + /* %%% portions-copyright-nrl-97 Portions of this software are Copyright 1997-1998 by Randall Atkinson, diff --git a/sys/netinet6/osdep.h b/sys/netinet6/osdep.h index 3e3f2a93f7a..6501a3f17b7 100644 --- a/sys/netinet6/osdep.h +++ b/sys/netinet6/osdep.h @@ -1,3 +1,4 @@ +/* $OpenBSD: osdep.h,v 1.3 1999/12/10 08:53:18 angelos Exp $ */ /* %%% copyright-nrl-97 This software is Copyright 1997-1998 by Randall Atkinson, Ronald Lee, @@ -18,137 +19,8 @@ you didn't get a copy, you may request one from <license@inner.net>. #ifndef __OSDEP_H #define __OSDEP_H 1 -#if __linux__ -#ifdef __KERNEL__ -#define KERNEL 1 -#include <linux/types.h> -#include <linux/kernel.h> -#include <linux/socket.h> -#include <net/sock.h> -#include <linux/random.h> -#include <asm/uaccess.h> -#include <linux/malloc.h> - -#define printf printk - -/* XXX */ -#define OSDEP_CRITICALDCL unsigned long flags; -#define OSDEP_CRITICALSTART save_flags(flags); cli() -#define OSDEP_CRITICALEND restore_flags(flags) - -#define OSDEP_TIMESECONDS (xtime.tv_sec) - -#define OSDEP_PROCESS struct task_struct -#define OSDEP_PROCESSCURRENT (current) -#define OSDEP_PROCESSPARENT(x) ((x)->p_pptr) -#define OSDEP_PROCESSPID(x) ((x)->pid) - -#define OSDEP_PCAST(x) ((unsigned int)(x) & 0xffffffff) -#define OSDEP_SOCKET struct sock -#define OSDEP_PACKET struct sk_buff -struct sk_buff; - -#define OSDEP_REAL_MALLOC(n) kmalloc(n, GFP_ATOMIC) -#define OSDEP_REAL_FREE(p) kfree(p) - -#define OSDEP_SOCKETFAMILY(socket) (socket->family) -#define OSDEP_SOCKETPRIVELEGED(socket) (suser()) - -static inline uint32_t __osdep_pseudorandom(void) -{ - static uint32_t seed=152; - seed=seed*69069+1; - return seed^jiffies; -}; -#define OSDEP_PSEUDORANDOM __osdep_pseudorandom() - -static inline int __osdep_datatopacket(void *data, int len, OSDEP_PACKET **packet) -{ - if (!(*packet = alloc_skb(len, GFP_ATOMIC))) - return -ENOMEM; - - memcpy((*packet)->h.raw = skb_put(*packet, len), data, len); - - return 0; -}; -#define OSDEP_DATATOPACKET(data, len, packet) __osdep_datatopacket(data, len, packet) -#define OSDEP_ZEROPACKET(packet) memset(packet->head, 0, packet->end - packet->head) -#define OSDEP_FREEPACKET(packet) kfree_skb(packet) - -#define OSDEP_COPYFROMUSER(dst, src, len) \ - (copy_from_user(dst, src, len) ? -EFAULT : 0) - -#define OSDEP_COPYTOUSER(dst, src, len) \ - (copy_to_user(dst, src, len) ? -EFAULT : 0) - -#define __P(x) x -#else /* __KERNEL__ */ -#include <sys/types.h> -#include <sys/socket.h> -#include <netinet/in.h> -#include <errno.h> -#endif /* __KERNEL__ */ - -#define OSDEP_SALEN 0 -#define OSDEP_ERROR(x) (-(x)) - -#ifndef IN6_IS_ADDR_UNSPECIFIED -#define IN6_IS_ADDR_UNSPECIFIED(a) \ - ((((uint32_t *)(a))[0] == 0) && (((uint32_t *)(a))[1] == 0) && \ - (((uint32_t *)(a))[2] == 0) && (((uint32_t *)(a))[3] == 0)) -#endif /* IN6_IS_ADDR_UNSPECIFIED */ - -/* Stupid C trick: We can define the structures that are members of union - sockaddr_union as empty and later redefine them as non-empty. We CAN'T, - however, define them as non-empty and later redefine them as empty. So - the empty declarations must be wrapped to ensure that we don't do that. - - WARNING: gcc < 2.8 generates incorrect debugging information for this; - the symptom is that gdb thinks that all struct sockaddr_*'s are empty - structures. gcc >= 2.8 correctly figures out what's going on. - cmetz -*/ - -#ifdef KERNEL -#ifndef _NETINET_IN_H_ -/* struct sockaddr_in {}; */ -#endif /* _NETINET_IN_H_ */ -#ifndef _NETINET6_IN6_H -/* struct sockaddr_in6 {}; */ -#endif /* _NETINET6_IN6_H */ -#ifndef _SYS_UN_H_ -struct sockaddr_un {}; -#endif /* _SYS_UN_H_ */ - -union sockaddr_union { - struct sockaddr sa; - struct sockaddr_in sin; - struct sockaddr_in6 sin6; - struct sockaddr_un sun; - char __maxsize[128]; /* should probably be MHLEN on BSD */ -}; - -static inline uint8_t __osdep_sa_len(struct sockaddr *sockaddr) -{ - switch(sockaddr->sa_family) { - case AF_INET: - return 16; /* sizeof(struct sockaddr_in); */ - case AF_INET6: - return 24; /* sizeof(struct sockaddr_in6); */ - default: - return 0; - }; -}; -#define SA_LEN(sockaddr) __osdep_sa_len(sockaddr) -#endif /* KERNEL */ -#endif /* __linux__ */ - -#if __NetBSD__ || __bsdi__ || __OpenBSD__ || __FreeBSD__ #define OSDEP_BSD 1 -#if __OpenBSD__ || __NetBSD__ -#define KERNEL 1 -#endif /* __OpenBSD__ || __NetBSD__ */ - #include <sys/types.h> #include <sys/param.h> #include <sys/socket.h> @@ -179,20 +51,9 @@ struct route6; #define OSDEP_CRITICALDCL int __s; #define OSDEP_CRITICALSTART __s = splnet() #define OSDEP_CRITICALEND splx(__s) - -#ifdef __FreeBSD__ -#define OSDEP_TIMESECONDS (time_second) -#else /* __FreeBSD__ */ #define OSDEP_TIMESECONDS (time.tv_sec) -#endif /* __FreeBSD__ */ - #define OSDEP_PROCESS struct proc -#if !defined(_BSDI_VERSION) || (_BSDI_VERSION < 199802) #define OSDEP_PROCESSCURRENT (curproc) -#else /* !defined(_BSDI_VERSION) || (_BSDI_VERSION < 199802) */ -#include <machine/pcpu.h> -#define OSDEP_PROCESSCURRENT (PCPU(curproc)) -#endif /* !defined(_BSDI_VERSION) || (_BSDI_VERSION < 199802) */ #define OSDEP_PROCESSPARENT(x) ((x)->p_pptr) #define OSDEP_PROCESSPID(x) ((x)->p_pid) @@ -212,10 +73,8 @@ struct mbuf; #define OSDEP_FAMILY(socket) (socket->so_proto->pr_domain->dom_family) #define OSDEP_PSEUDORANDOM (uint32_t)random() -#if !__FreeBSD__ struct ifnet; struct mbuf *m_devget(char *, int, int, struct ifnet *, void (*)(const void *, void *, size_t)); -#endif /* !__FreeBSD__ */ static __inline__ int __osdep_datatopacket(void *data, int len, OSDEP_PACKET **packet) { @@ -238,14 +97,9 @@ static __inline__ int __osdep_datatopacket(void *data, int len, OSDEP_PACKET **p #define OSDEP_COPYFROMUSER(dst, src, len) copyin(src, dst, len) #define OSDEP_COPYTOUSER(dst, src, len) copyout(src, dst, len) -#if __FreeBSD__ -#define M_SOCKET M_TEMP -#define MT_SOOPTS MT_DATA -#endif /* __FreeBSD__ */ #endif /* KERNEL */ #define OSDEP_SALEN 1 #define OSDEP_ERROR(x) (x) -#endif /* __NetBSD__ || __bsdi__ || __OpenBSD__ || __FreeBSD__ */ #define ENETSECURITYPOLICY -ECOMM diff --git a/sys/netinet6/raw_ipv6.c b/sys/netinet6/raw_ipv6.c index a32e501f699..3adf99b2002 100644 --- a/sys/netinet6/raw_ipv6.c +++ b/sys/netinet6/raw_ipv6.c @@ -1,3 +1,4 @@ +/* $OpenBSD: raw_ipv6.c,v 1.6 1999/12/10 08:53:18 angelos Exp $ */ /* %%% copyright-nrl-95 This software is Copyright 1995-1998 by Randall Atkinson, Ronald Lee, @@ -42,7 +43,7 @@ didn't get a copy, you may request one from <license@ipv6.nrl.navy.mil>. * SUCH DAMAGE. * * @(#)raw_ip.c 8.7 (Berkeley) 5/15/95 - * $Id: raw_ipv6.c,v 1.5 1999/12/08 06:50:23 itojun Exp $ + * $Id: raw_ipv6.c,v 1.6 1999/12/10 08:53:18 angelos Exp $ */ #include <sys/param.h> @@ -56,13 +57,6 @@ didn't get a copy, you may request one from <license@ipv6.nrl.navy.mil>. #include <sys/errno.h> #include <sys/time.h> #include <sys/kernel.h> -#if __NetBSD__ || __FreeBSD__ -#include <sys/proc.h> -#endif /* __NetBSD__ || __FreeBSD__ */ -#if __FreeBSD__ -#include <vm/vm_zone.h> -#endif /* __FreeBSD__ */ - #include <net/if.h> #include <net/route.h> @@ -79,36 +73,13 @@ didn't get a copy, you may request one from <license@ipv6.nrl.navy.mil>. #if __OpenBSD__ #undef IPSEC -#ifdef NRL_IPSEC -#define IPSEC 1 -#endif /* NRL_IPSEC */ -#endif /* __OpenBSD__ */ - -#ifdef IPSEC -#include <sys/osdep.h> -#include <net/netproc.h> -#include <net/netproc_var.h> -#endif /* IPSEC */ - -#ifdef DEBUG_NRL -#include <sys/debug.h> -#else /* DEBUG_NRL */ -#if __OpenBSD__ -#include <netinet6/debug.h> -#else /* __OpenBSD__ */ -#include <sys/debug.h> #endif /* __OpenBSD__ */ -#endif /* DEBUG_NRL */ /* * Globals */ -#if __NetBSD__ || __OpenBSD__ struct inpcbtable rawin6pcbtable; -#else /* __NetBSD__ || __OpenBSD__ */ -struct inpcb rawin6pcb; -#endif /* __NetBSD__ || __OpenBSD__ */ struct sockaddr_in6 rip6src = { sizeof(struct sockaddr_in6), AF_INET6 }; /* @@ -117,6 +88,7 @@ struct sockaddr_in6 rip6src = { sizeof(struct sockaddr_in6), AF_INET6 }; #define RIPV6SNDQ 8192 #define RIPV6RCVQ 8192 + #if 0 u_long rip6_sendspace = RIPV6SNDQ; u_long rip6_recvspace = RIPV6RCVQ; @@ -128,24 +100,11 @@ extern u_long rip6_recvspace; /* * External globals */ -#if __FreeBSD__ -static struct inpcbhead ri6pcb; -static struct inpcbinfo ri6pcbinfo; -#endif /* __FreeBSD__ */ #if 0 extern struct ip6_hdrstat ipv6stat; #endif -#define RETURN_ERROR(x) { \ - DPRINTF(EVENT, ("%s: returning %s\n", DEBUG_STATUS, #x)); \ - return x; \ -} -#define RETURN_VALUE(x) { \ - DPRINTF(EVENT, ("%s: returning %d\n", DEBUG_STATUS, x)); \ - return x; \ -} - /*---------------------------------------------------------------------- * Raw IPv6 PCB initialization. ----------------------------------------------------------------------*/ @@ -153,29 +112,7 @@ extern struct ip6_hdrstat ipv6stat; void rip6_init() { -#if __FreeBSD__ - LIST_INIT(&ri6pcb); - ri6pcbinfo.listhead = &ri6pcb; - /* - * XXX We don't use the hash list for raw IP, but it's easier - * to allocate a one entry hash list than it is to check all - * over the place for hashbase == NULL. - */ - ri6pcbinfo.hashbase = hashinit(1, M_PCB, M_WAITOK, &ri6pcbinfo.hashmask); - ri6pcbinfo.porthashbase = hashinit(1, M_PCB, M_WAITOK, &ri6pcbinfo.porthashmask); - ri6pcbinfo.ipi_zone = zinit("ri6pcb", sizeof(struct inpcb), - nmbclusters / 4, ZONE_INTERRUPT, 0); -#else /* __FreeBSD__ */ -#if __NetBSD__ - in_pcbinit(&rawin6pcbtable, 1, 1); -#else /* __NetBSD__ */ -#if __OpenBSD__ in_pcbinit(&rawin6pcbtable, 1); -#else /* __OpenBSD__ */ - rawin6pcb.inp_next = rawin6pcb.inp_prev = &rawin6pcb; -#endif /* __OpenBSD__ */ -#endif /* __NetBSD__ */ -#endif /* __FreeBSD__ */ } /* At the point where this function gets called, we don't know the nexthdr of @@ -277,15 +214,6 @@ rip6_input(mp, offp, proto) #endif /* IPSEC */ int extra = *offp; - DPRINTF(FINISHED, ("rip6_input(m=%08x, extra=%d)\n", OSDEP_PCAST(m), extra)); - DP(FINISHED, m->m_pkthdr.len, d); - DDO(FINISHED,printf("In rip6_input(), header is:\n");dump_mchain(m)); - DPRINTF(EVENT, ("In rip6_input()\n")); - DPRINTF(EVENT, ("Header is: ")); -#if 0 - DDO(GROSSEVENT, dump_ipv6(ipv6)); -#endif - bzero(&srcsa, sizeof(struct sockaddr_in6)); srcsa.sin6_family = AF_INET6; srcsa.sin6_len = sizeof(struct sockaddr_in6); @@ -317,19 +245,14 @@ rip6_input(mp, offp, proto) } #endif /* 0 */ - if ((nexthdr = ipv6_findnexthdr(m, extra)) < 0) { - DPRINTF(ERROR, ("rip6_input: ipv6_findnexthdr failed\n")); + if ((nexthdr = ipv6_findnexthdr(m, extra)) < 0) goto ret; - } - - DP(FINISHED, nexthdr, d); if (nexthdr == IPPROTO_ICMPV6) { if (m->m_len < extra + sizeof(struct icmp6_hdr)) { - if (!(m = m_pullup2(m, extra + sizeof(struct icmp6_hdr)))) { - DPRINTF(ERROR, ("rip6_input: m_pullup2 failed\n")); + if (!(m = m_pullup2(m, extra + sizeof(struct icmp6_hdr)))) goto ret; - } + ip6 = mtod(m, struct ip6_hdr *); } icmp6type = ((struct icmp6_hdr *)(mtod(m, caddr_t) + extra))->icmp6_type; @@ -339,17 +262,9 @@ rip6_input(mp, offp, proto) /* * Locate raw PCB for incoming datagram. */ -#if __FreeBSD__ - for (inp = ri6pcb.lh_first; inp != NULL; inp = inp->inp_list.le_next) { -#else /* __FreeBSD__ */ -#if __NetBSD__ || __OpenBSD__ for (inp = rawin6pcbtable.inpt_queue.cqh_first; inp != (struct inpcb *)&rawin6pcbtable.inpt_queue; inp = inp->inp_queue.cqe_next) -#else /* __NetBSD__ || __OpenBSD__ */ - for (inp = rawin6pcb.inp_next; inp != &rawin6pcb; inp = inp->inp_next) -#endif /* __NetBSD__ || __OpenBSD__ */ -#endif /* __FreeBSD__ */ { if (inp->inp_ipv6.ip6_nxt && inp->inp_ipv6.ip6_nxt != nexthdr) continue; @@ -363,7 +278,6 @@ rip6_input(mp, offp, proto) ICMP6_FILTER_WILLBLOCK(icmp6type, inp->inp_icmp6filt)) continue; - DPRINTF(IDL_EVENT, ("Found a raw pcb (>1)\n")); foundone = 1; #ifdef IPSEC @@ -377,13 +291,12 @@ rip6_input(mp, offp, proto) (struct sockaddr *)&dstsa, nexthdr, m, NULL, NULL)) #endif /* IPSEC */ - DP(FINISHED, m->m_pkthdr.len, d); /* Note the inefficiency here; this is a consequence of the interfaces of the functions being used. The raw code is not performance critical enough to require an immediate fix. - cmetz */ if ((m2 = m_copym(m, 0, (int)M_COPYALL, M_DONTWAIT))) { m_adj(m2, extra); - DP(FINISHED, m2->m_pkthdr.len, d); + if (inp->inp_flags & IN6P_CONTROLOPTS) ip6_savecontrol(inp, &opts, ip6, m); else @@ -412,7 +325,6 @@ ret: if (m) m_freem(m); - DPRINTF(FINISHED, ("rip6_input\n")); return IPPROTO_DONE; } @@ -421,16 +333,7 @@ ret: * ipv6_icmp_usrreq(). ----------------------------------------------------------------------*/ -#if __OpenBSD__ int rip6_output(struct mbuf *m, ...) -#else /* __OpenBSD__ */ -int -rip6_output(m, so, dst, control) - struct mbuf *m; - struct socket *so; - struct in6_addr *dst; - struct mbuf *control; -#endif /* __OpenBSD__ */ { register struct ip6_hdr *ip6; register struct inpcb *inp; @@ -441,7 +344,7 @@ rip6_output(m, so, dst, control) #endif struct ip6_pktopts opt, *optp = NULL; struct ifnet *oifp = NULL; -#if __OpenBSD__ + va_list ap; struct socket *so; struct sockaddr_in6 *dst; @@ -452,7 +355,6 @@ rip6_output(m, so, dst, control) dst = va_arg(ap, struct sockaddr_in6 *); control = va_arg(ap, struct mbuf *); va_end(ap); -#endif /* __OpenBSD__ */ inp = sotoinpcb(so); flags = (so->so_options & SO_DONTROUTE); @@ -548,7 +450,6 @@ rip6_output(m, so, dst, control) uint16_t *csum; if (!(m = m_pullup2(m, payload + inp->inp_csumoffset))) { - DPRINTF(IDL_ERROR, ("rip6_output: m_pullup2(m, %d) failed\n", payload + inp->inp_csumoffset)); m_freem(m); return ENOBUFS; }; @@ -572,32 +473,6 @@ bad: * Handles [gs]etsockopt() calls. ----------------------------------------------------------------------*/ -#if __FreeBSD__ -int rip6_ctloutput(struct socket *so, struct sockopt *sopt) -{ - register struct inpcb *inp = sotoinpcb(so); - int op; - int level; - int optname; - int optval; - - DPRINTF(FINISHED, ("rip6_ctloutput(so=%08x, sopt=%08x)\n", - OSDEP_PCAST(so), OSDEP_PCAST(sopt))); - - switch(sopt->sopt_dir) { - case SOPT_GET: - op = PRCO_GETOPT; - break; - case SOPT_SET: - op = PRCO_SETOPT; - break; - default: - RETURN_ERROR(EINVAL); - }; - - level = sopt->sopt_level; - optname = sopt->sopt_name; -#else /* __FreeBSD__ */ int rip6_ctloutput (op, so, level, optname, m) int op; @@ -607,35 +482,17 @@ rip6_ctloutput (op, so, level, optname, m) { register struct inpcb *inp = sotoinpcb(so); - DPRINTF(FINISHED, ("rip6_ctloutput(op=%x,so,level=%x,optname=%x,m)\n", op, level, optname)); -#endif /* __FreeBSD__ */ - if ((level != IPPROTO_IP) && (level != IPPROTO_IPV6) && (level != IPPROTO_ICMPV6)) { -#if !__FreeBSD__ if (op == PRCO_SETOPT && *m) (void)m_free(*m); -#endif /* !__FreeBSD__ */ - RETURN_ERROR(EINVAL); + return(EINVAL); } switch (optname) { case IPV6_CHECKSUM: if (op == PRCO_SETOPT || op == PRCO_GETOPT) { -#if __FreeBSD__ - if (!sopt->sopt_val || (sopt->sopt_valsize != sizeof(int))) - RETURN_ERROR(EINVAL); - if (op == PRCO_SETOPT) { - int error = sooptcopyin(sopt, &optval, sizeof(int), sizeof(int)); - if (error) - RETURN_VALUE(error); - inp->inp_csumoffset = optval; - - return 0; - } else - return sooptcopyout(sopt, &inp->inp_csumoffset, sizeof(int)); -#else /* __FreeBSD__ */ if (!m || !*m || (*m)->m_len != sizeof(int)) - RETURN_ERROR(EINVAL); + return(EINVAL); if (op == PRCO_SETOPT) { inp->inp_csumoffset = *(mtod(*m, int *)); m_freem(*m); @@ -643,32 +500,13 @@ rip6_ctloutput (op, so, level, optname, m) (*m)->m_len = sizeof(int); *(mtod(*m, int *)) = inp->inp_csumoffset; }; -#endif /* __FreeBSD__ */ return 0; }; break; case ICMP6_FILTER: if (op == PRCO_SETOPT || op == PRCO_GETOPT) { -#if __FreeBSD__ - if (!sopt->sopt_val || (sopt->sopt_valsize != - sizeof(struct icmp6_filter))) - RETURN_ERROR(EINVAL); - if (op == PRCO_SETOPT) { - struct icmp6_filter icmp6_filter; - int error = sooptcopyin(sopt, &icmp6_filter, - sizeof(struct icmp6_filter), sizeof(struct icmp6_filter)); - if (error) - return error; - - bcopy(&icmp6_filter, inp->inp_icmp6filt, sizeof(icmp6_filter)); - - return 0; - } else - return sooptcopyout(sopt, inp->inp_icmp6filt, - sizeof(struct icmp6_filter)); -#else /* __FreeBSD__ */ if (!m || !*m || (*m)->m_len != sizeof(struct icmp6_filter)) - RETURN_ERROR(EINVAL); + return(EINVAL); if (op == PRCO_SETOPT) { bcopy(mtod(*m, struct icmp6_filter *), inp->inp_icmp6filt, sizeof(struct icmp6_filter)); @@ -678,7 +516,6 @@ rip6_ctloutput (op, so, level, optname, m) *mtod(*m, struct icmp6_filter *) = *inp->inp_icmp6filt; }; return 0; -#endif /* __FreeBSD__ */ }; break; @@ -686,27 +523,8 @@ rip6_ctloutput (op, so, level, optname, m) case IP_HDRINCL: if (op == PRCO_SETOPT || op == PRCO_GETOPT) { -#if __FreeBSD__ - if (!sopt->sopt_val || (sopt->sopt_valsize != sizeof(int))) - RETURN_ERROR(EINVAL); - if (op == PRCO_SETOPT) { - int error = sooptcopyin(sopt, &optval, sizeof(int), sizeof(int)); - if (error) - return error; - - if (optval) - inp->inp_flags |= INP_HDRINCL; - else - inp->inp_flags &= ~INP_HDRINCL; - - return 0; - } else { - optval = (inp->inp_flags & INP_HDRINCL) ? 1 : 0; - return sooptcopyout(sopt, &optval, sizeof(int)); - }; -#else /* __FreeBSD__ */ if (m == 0 || *m == 0 || (*m)->m_len != sizeof(int)) - RETURN_ERROR(EINVAL); + return(EINVAL); if (op == PRCO_SETOPT) { if (*mtod(*m, int *)) @@ -720,7 +538,6 @@ rip6_ctloutput (op, so, level, optname, m) *(mtod(*m, int *)) = (inp->inp_flags & INP_HDRINCL) ? 1 : 0; } return 0; -#endif /* __FreeBSD__ */ } break; @@ -748,21 +565,16 @@ rip6_ctloutput (op, so, level, optname, m) } else error = EINVAL; return (error);*/ - RETURN_ERROR(EOPNOTSUPP); + return(EOPNOTSUPP); #else /* MROUTING */ -#if !__FreeBSD__ if (op == PRCO_SETOPT && *m) (void)m_free(*m); -#endif /* !__FreeBSD__ */ - RETURN_ERROR(EOPNOTSUPP); + return(EOPNOTSUPP); #endif /* MROUTING */ }; } -#if __FreeBSD__ - return ip6_ctloutput(so, sopt); -#else /* __FreeBSD__ */ + return ip6_ctloutput(op, so, level, optname, m); -#endif /* __FreeBSD__ */ } #if __GNUC__ && __GNUC__ >= 2 && __OPTIMIZE__ && !__FreeBSD__ @@ -773,12 +585,7 @@ rip6_ctloutput (op, so, level, optname, m) #define MAYBEINLINE #endif /* __GNUC__ && __GNUC__ >= 2 && __OPTIMIZE__ && !__FreeBSD__ */ -#if __NetBSD__ || __FreeBSD__ -MAYBESTATIC MAYBEINLINE int rip6_usrreq_attach(struct socket *so, int proto, - struct proc *p) -#else /* __NetBSD__ || __FreeBSD__ */ MAYBESTATIC MAYBEINLINE int rip6_usrreq_attach(struct socket *so, int proto) -#endif /* __NetBSD__ || __FreeBSD__ */ { register struct inpcb *inp = sotoinpcb(so); register int error = 0; @@ -786,26 +593,13 @@ MAYBESTATIC MAYBEINLINE int rip6_usrreq_attach(struct socket *so, int proto) if (inp) panic("rip6_attach - Already got PCB"); -#if __NetBSD__ || __FreeBSD__ - if (p == 0 || (error = suser(p->p_ucred, &p->p_acflag))) -#else /* __NetBSD__ || __FreeBSD__ */ if ((so->so_state & SS_PRIV) == 0) -#endif /* __NetBSD__ || __FreeBSD__ */ { error = EACCES; return error; } if ((error = soreserve(so, rip6_sendspace, rip6_recvspace)) || - -#if __FreeBSD__ - (error = in_pcballoc(so, &ri6pcbinfo, p))) -#else /* __FreeBSD__ */ -#if __NetBSD__ || __OpenBSD__ - (error = in_pcballoc(so, &rawin6pcbtable))) -#else /* __NetBSD__ || __OpenBSD__ */ - (error = in_pcballoc(so, &rawin6pcb))) -#endif /* __NetBSD__ || __OpenBSD__ */ -#endif /* __FreeBSD__ */ + (error = in_pcballoc(so, &rawin6pcbtable))) return error; @@ -855,23 +649,14 @@ static MAYBEINLINE int rip6_usrreq_disconnect(struct socket *so) return rip6_usrreq_abort(so); } -#if __NetBSD__ || __FreeBSD__ -MAYBESTATIC MAYBEINLINE int rip6_usrreq_bind(struct socket *so, - struct sockaddr *nam, struct proc *p) -#else /* __NetBSD__ || __FreeBSD__ */ MAYBESTATIC MAYBEINLINE int rip6_usrreq_bind(struct socket *so, struct sockaddr *nam) -#endif /* __NetBSD__ || __FreeBSD__ */ { register struct inpcb *inp = sotoinpcb(so); register struct sockaddr_in6 *addr = (struct sockaddr_in6 *)nam; /* 'ifnet' is declared in one of the net/ header files. */ -#if __NetBSD__ || __OpenBSD__ || __FreeBSD__ if ((ifnet.tqh_first == 0) || -#else /* __NetBSD__ || __OpenBSD__ || __FreeBSD__ */ - if ((ifnet == 0) || -#endif /* __NetBSD__ || __OpenBSD__ || __FreeBSD__ */ (addr->sin6_family != AF_INET6) || /* I only allow AF_INET6 */ (!IN6_IS_ADDR_UNSPECIFIED(&addr->sin6_addr) && ifa_ifwithaddr((struct sockaddr *)addr) == 0 ) ) @@ -882,13 +667,8 @@ MAYBESTATIC MAYBEINLINE int rip6_usrreq_bind(struct socket *so, return 0; } -#if __NetBSD__ || __FreeBSD__ -MAYBESTATIC MAYBEINLINE int rip6_usrreq_connect(struct socket *so, - struct sockaddr *nam, struct proc *p) -#else /* __NetBSD__ || __FreeBSD__ */ MAYBESTATIC MAYBEINLINE int rip6_usrreq_connect(struct socket *so, struct sockaddr *nam) -#endif /* __NetBSD__ || __FreeBSD__ */ { register struct inpcb *inp = sotoinpcb(so); register struct sockaddr_in6 *addr = (struct sockaddr_in6 *) nam; @@ -923,18 +703,8 @@ MAYBESTATIC MAYBEINLINE int rip6_usrreq_shutdown(struct socket *so) static int rip6_usrreq_send __P((struct socket *so, int flags, struct mbuf *m, struct sockaddr *addr, struct mbuf *control)); -#if __NetBSD__ || __FreeBSD__ -/* - * Note that flags and p are not used, but required by protosw in - * FreeBSD. - */ -static int rip6_usrreq_send(struct socket *so, int flags, struct mbuf *m, - struct sockaddr *addr, struct mbuf *control, - struct proc *p) -#else /* __NetBSD__ || __FreeBSD__ */ static int rip6_usrreq_send(struct socket *so, int flags, struct mbuf *m, struct sockaddr *addr, struct mbuf *control) -#endif /* __NetBSD__ || __FreeBSD__ */ { register struct inpcb *inp = sotoinpcb(so); register int error = 0; @@ -973,21 +743,12 @@ static int rip6_usrreq_send(struct socket *so, int flags, struct mbuf *m, return error; } -#if __NetBSD__ || __FreeBSD__ -MAYBESTATIC MAYBEINLINE int rip6_usrreq_control(struct socket *so, u_long cmd, - caddr_t data, struct ifnet *ifp, struct proc *p) -#else /* __NetBSD__ || __FreeBSD__ */ MAYBESTATIC MAYBEINLINE int rip6_usrreq_control(struct socket *so, int cmd, caddr_t data, struct ifnet *ifp) -#endif /* __NetBSD__ || __FreeBSD__ */ { /* Notice that IPv4 raw sockets don't pass PRU_CONTROL. I wonder if they panic as well? */ -#if __NetBSD__ || __FreeBSD__ - return in6_control(so, cmd, data, ifp, 0, p); -#else /* __NetBSD__ || __FreeBSD__ */ return in6_control(so, cmd, data, ifp, 0); -#endif /* __NetBSD__ || __FreeBSD__ */ } MAYBESTATIC MAYBEINLINE int rip6_usrreq_sense(struct socket *so, @@ -997,45 +758,23 @@ MAYBESTATIC MAYBEINLINE int rip6_usrreq_sense(struct socket *so, return 0; } -#if __FreeBSD__ -MAYBESTATIC MAYBEINLINE int rip6_usrreq_sockaddr(struct socket *so, - struct sockaddr **nam) -#else /* __FreeBSD__ */ MAYBESTATIC MAYBEINLINE int rip6_usrreq_sockaddr(struct socket *so, struct mbuf *nam) -#endif /* __FreeBSD__ */ { register struct inpcb *inp = sotoinpcb(so); return in6_setsockaddr(inp, nam); } -#if __FreeBSD__ -MAYBESTATIC MAYBEINLINE int rip6_usrreq_peeraddr(struct socket *so, - struct sockaddr **nam) -#else /* __FreeBSD__ */ MAYBESTATIC MAYBEINLINE int rip6_usrreq_peeraddr(struct socket *so, struct mbuf *nam) -#endif /* __FreeBSD__ */ { register struct inpcb *inp = sotoinpcb(so); return in6_setpeeraddr(inp, nam); } -#if __FreeBSD__ -struct pr_usrreqs rip6_usrreqs = { - rip6_usrreq_abort, pru_accept_notsupp, rip6_usrreq_attach, - rip6_usrreq_bind, rip6_usrreq_connect, pru_connect2_notsupp, - rip6_usrreq_control, rip6_usrreq_detach, rip6_usrreq_detach, - pru_listen_notsupp, rip6_usrreq_peeraddr, pru_rcvd_notsupp, - pru_rcvoob_notsupp, rip6_usrreq_send, rip6_usrreq_sense, - rip6_usrreq_shutdown, rip6_usrreq_sockaddr, sosend, soreceive, sopoll -}; -#endif /* __FreeBSD__ */ - /*---------------------------------------------------------------------- * Handles PRU_* for raw IPv6 sockets. ----------------------------------------------------------------------*/ -#if !__FreeBSD__ int rip6_usrreq(so, req, m, nam, control, p) struct socket *so; @@ -1045,8 +784,6 @@ rip6_usrreq(so, req, m, nam, control, p) { register int error = 0; - DPRINTF(IDL_EVENT, ("rip6_usrreq(so, req, m, nam, control)\n")); - #ifdef MROUTING /* * Ummm, like, multicast routing stuff goes here, huh huh huh. @@ -1060,11 +797,7 @@ rip6_usrreq(so, req, m, nam, control, p) switch (req) { case PRU_ATTACH: -#if __NetBSD__ - error = rip6_usrreq_attach(so, (long)nam, p); -#else /* __NetBSD__ */ error = rip6_usrreq_attach(so, (long)nam); -#endif /* __NetBSD__ */ break; case PRU_DISCONNECT: error = rip6_usrreq_disconnect(so); @@ -1085,11 +818,7 @@ rip6_usrreq(so, req, m, nam, control, p) /* * Be strict regarding sockaddr_in6 fields. */ -#if __NetBSD__ - error = rip6_usrreq_bind(so, mtod(nam, struct sockaddr *), p); -#else /* __NetBSD__ */ error = rip6_usrreq_bind(so, mtod(nam, struct sockaddr *)); -#endif /* __NetBSD__ */ break; case PRU_CONNECT: /* @@ -1097,11 +826,7 @@ rip6_usrreq(so, req, m, nam, control, p) */ if (nam->m_len != sizeof(struct sockaddr_in6)) return EINVAL; -#if __NetBSD__ - error = rip6_usrreq_connect(so, mtod(nam, struct sockaddr *), p); -#else /* __NetBSD__ */ error = rip6_usrreq_connect(so, mtod(nam, struct sockaddr *)); -#endif /* __NetBSD__ */ break; case PRU_SHUTDOWN: error = rip6_usrreq_shutdown(so); @@ -1112,21 +837,12 @@ rip6_usrreq(so, req, m, nam, control, p) */ if (nam->m_len != sizeof(struct sockaddr_in6)) return EINVAL; -#if __NetBSD__ - error = rip6_usrreq_send(so, 0, m, mtod(nam, struct sockaddr *), control, p); -#else /* __NetBSD__ */ error = rip6_usrreq_send(so, 0, m, mtod(nam, struct sockaddr *), control); -#endif /* __NetBSD__ */ m = NULL; break; case PRU_CONTROL: -#if __NetBSD__ - return rip6_usrreq_control(so, (u_long)m, (caddr_t) nam, - (struct ifnet *) control, p); -#else /* __NetBSD__ */ return rip6_usrreq_control(so, (int)m, (caddr_t) nam, (struct ifnet *) control); -#endif /* __NetBSD__ */ case PRU_SENSE: return rip6_usrreq_sense(so, NULL); /* XXX */ case PRU_CONNECT2: @@ -1150,4 +866,3 @@ rip6_usrreq(so, req, m, nam, control, p) m_freem(m); return error; } -#endif /* !__FreeBSD__ */ diff --git a/sys/netinet6/tcpipv6.h b/sys/netinet6/tcpipv6.h index 27aec0a1864..37ab052e990 100644 --- a/sys/netinet6/tcpipv6.h +++ b/sys/netinet6/tcpipv6.h @@ -1,3 +1,5 @@ +/* $OpenBSD: tcpipv6.h,v 1.4 1999/12/10 08:53:18 angelos Exp $ */ + /* %%% copyright-nrl-95 This software is Copyright 1995-1998 by Randall Atkinson, Ronald Lee, |