Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files. =================================================================== RCS file: /ftp/cvs/cvsroot/src/sys/sys/socket.h,v retrieving revision 1.46.2.1 retrieving revision 1.47 diff -u -p -r1.46.2.1 -r1.47 --- src/sys/sys/socket.h 2000/11/20 18:11:35 1.46.2.1 +++ src/sys/sys/socket.h 1999/11/19 10:41:41 1.47 @@ -1,4 +1,4 @@ -/* $NetBSD: socket.h,v 1.46.2.1 2000/11/20 18:11:35 bouyer Exp $ */ +/* $NetBSD: socket.h,v 1.47 1999/11/19 10:41:41 bouyer Exp $ */ /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. @@ -74,17 +74,7 @@ /* * Data types. */ -#include - -#ifndef sa_family_t -typedef __sa_family_t sa_family_t; -#define sa_family_t __sa_family_t -#endif - -#ifndef socklen_t -typedef __socklen_t socklen_t; -#define socklen_t __socklen_t -#endif +typedef unsigned int socklen_t; /* * Socket types. @@ -189,9 +179,9 @@ struct linger { * addresses. */ struct sockaddr { - u_char sa_len; /* total length */ - sa_family_t sa_family; /* address family */ - char sa_data[14]; /* actually longer; address value */ + u_char sa_len; /* total length */ + u_char sa_family; /* address family */ + char sa_data[14]; /* actually longer; address value */ }; #if defined(_KERNEL) @@ -217,11 +207,11 @@ struct sockproto { #if !defined(_XOPEN_SOURCE) || (_XOPEN_SOURCE - 0) >= 500 struct sockaddr_storage { - u_char ss_len; /* address length */ - sa_family_t ss_family; /* address family */ - char __ss_pad1[_SS_PAD1SIZE]; - int64_t __ss_align;/* force desired structure storage alignment */ - char __ss_pad2[_SS_PAD2SIZE]; + u_char __ss_len; /* address length */ + u_char __ss_family; /* address family */ + char __ss_pad1[_SS_PAD1SIZE]; + int64_t __ss_align; /* force desired structure storage alignment */ + char __ss_pad2[_SS_PAD2SIZE]; }; #endif /* !_XOPEN_SOURCE || ... */ #endif /* 1 */ @@ -233,6 +223,7 @@ struct sockaddr_storage { #define PF_LOCAL AF_LOCAL #define PF_UNIX PF_LOCAL /* backward compatibility */ #define PF_INET AF_INET +#define PF_INET6 AF_INET6 #define PF_IMPLINK AF_IMPLINK #define PF_PUP AF_PUP #define PF_CHAOS AF_CHAOS @@ -406,35 +397,26 @@ struct cmsghdr { }; /* given pointer to struct cmsghdr, return pointer to data */ -#define CMSG_DATA(cmsg) \ - ((u_char *)(void *)(cmsg) + __CMSG_ALIGN(sizeof(struct cmsghdr))) +#define CMSG_DATA(cmsg) ((u_char *)((cmsg) + 1)) /* * Alignment requirement for CMSG struct manipulation. - * This basically behaves the same as ALIGN() ARCH/include/param.h. - * We declare it separately for two reasons: - * (1) avoid dependency between machine/param.h, and (2) to sync with kernel's - * idea of ALIGNBYTES at runtime. - * without (2), we can't guarantee binary compatibility in case of future - * changes in ALIGNBYTES. - */ -#define __CMSG_ALIGN(n) (((n) + __cmsg_alignbytes()) & ~__cmsg_alignbytes()) -#ifdef _KERNEL -#define CMSG_ALIGN(n) __CMSG_ALIGN(n) -#endif + * This is different from ALIGN() defined in ARCH/include/param.h. + * XXX think again carefully about architecture dependencies. + */ +#define CMSG_ALIGN(n) (((n) + 3) & ~3) /* given pointer to struct cmsghdr, return pointer to next cmsghdr */ #define CMSG_NXTHDR(mhdr, cmsg) \ - (((caddr_t)(cmsg) + __CMSG_ALIGN((cmsg)->cmsg_len) + \ - __CMSG_ALIGN(sizeof(struct cmsghdr)) > \ + (((caddr_t)(cmsg) + (cmsg)->cmsg_len + sizeof(struct cmsghdr) > \ (((caddr_t)(mhdr)->msg_control) + (mhdr)->msg_controllen)) ? \ (struct cmsghdr *)NULL : \ - (struct cmsghdr *)((caddr_t)(cmsg) + __CMSG_ALIGN((cmsg)->cmsg_len))) + (struct cmsghdr *)((caddr_t)(cmsg) + CMSG_ALIGN((cmsg)->cmsg_len))) #define CMSG_FIRSTHDR(mhdr) ((struct cmsghdr *)(mhdr)->msg_control) -#define CMSG_SPACE(l) (__CMSG_ALIGN(sizeof(struct cmsghdr)) + __CMSG_ALIGN(l)) -#define CMSG_LEN(l) (__CMSG_ALIGN(sizeof(struct cmsghdr)) + (l)) +#define CMSG_SPACE(l) (CMSG_ALIGN(sizeof(struct cmsghdr)) + CMSG_ALIGN(l)) +#define CMSG_LEN(l) (CMSG_ALIGN(sizeof(struct cmsghdr)) + (l)) /* "Socket"-level control message types: */ #define SCM_RIGHTS 0x01 /* access rights (array of int) */ @@ -472,14 +454,10 @@ struct omsghdr { }; #endif -#include - -__BEGIN_DECLS -int __cmsg_alignbytes __P((void)); -__END_DECLS - #ifndef _KERNEL +#include + __BEGIN_DECLS int accept __P((int, struct sockaddr *, socklen_t *)); int bind __P((int, const struct sockaddr *, socklen_t)); @@ -505,6 +483,8 @@ __END_DECLS #ifdef COMPAT_OLDSOCK #define MSG_COMPAT 0x8000 #endif + +void pfctlinput __P((int, struct sockaddr *)); #endif /* !_KERNEL */ #endif /* !_SYS_SOCKET_H_ */