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 rcsdiff: /ftp/cvs/cvsroot/src/sys/sys/socket.h,v: warning: Unknown phrases like `commitid ...;' are present. retrieving revision 1.82.10.1 retrieving revision 1.84.2.3 diff -u -p -r1.82.10.1 -r1.84.2.3 --- src/sys/sys/socket.h 2007/02/27 16:55:17 1.82.10.1 +++ src/sys/sys/socket.h 2007/07/15 13:28:12 1.84.2.3 @@ -1,4 +1,4 @@ -/* $NetBSD: socket.h,v 1.82.10.1 2007/02/27 16:55:17 yamt Exp $ */ +/* $NetBSD: socket.h,v 1.84.2.3 2007/07/15 13:28:12 ad Exp $ */ /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. @@ -462,6 +462,13 @@ struct msghdr { #define MSG_MCAST 0x0200 /* this message was rcvd using link-level mcast */ #define MSG_NOSIGNAL 0x0400 /* do not generate SIGPIPE on EOF */ +/* Extra flags used internally only */ +#define MSG_USERFLAGS 0x0ffffff +#define MSG_NAMEMBUF 0x1000000 /* msg_name is an mbuf */ +#define MSG_CONTROLMBUF 0x2000000 /* msg_control is an mbuf */ +#define MSG_IOVUSRSPACE 0x4000000 /* msg_iov is in user space */ +#define MSG_LENUSRSPACE 0x8000000 /* address length is in user space */ + /* * Header for ancillary data objects in msg_control buffer. * Used for additional information with/about a datagram @@ -498,11 +505,11 @@ struct cmsghdr { /* given pointer to struct cmsghdr, return pointer to next cmsghdr */ #define CMSG_NXTHDR(mhdr, cmsg) \ - (((__caddr_t)(cmsg) + __CMSG_ALIGN((cmsg)->cmsg_len) + \ + (((char *)(cmsg) + __CMSG_ALIGN((cmsg)->cmsg_len) + \ __CMSG_ALIGN(sizeof(struct cmsghdr)) > \ - (((__caddr_t)(mhdr)->msg_control) + (mhdr)->msg_controllen)) ? \ + (((char *)(mhdr)->msg_control) + (mhdr)->msg_controllen)) ? \ (struct cmsghdr *)0 : \ - (struct cmsghdr *)((__caddr_t)(cmsg) + \ + (struct cmsghdr *)((char *)(cmsg) + \ __CMSG_ALIGN((cmsg)->cmsg_len))) /* @@ -537,6 +544,16 @@ __BEGIN_DECLS int __cmsg_alignbytes(void); __END_DECLS +#ifdef _KERNEL +__BEGIN_DECLS +struct sockaddr *sockaddr_copy(struct sockaddr *, const struct sockaddr *); +struct sockaddr *sockaddr_alloc(sa_family_t, int); +int sockaddr_cmp(const struct sockaddr *, const struct sockaddr *); +struct sockaddr *sockaddr_dup(const struct sockaddr *, int); +void sockaddr_free(struct sockaddr *); +__END_DECLS +#endif /* _KERNEL */ + #ifndef _KERNEL __BEGIN_DECLS @@ -545,10 +562,10 @@ int bind(int, const struct sockaddr *, s int connect(int, const struct sockaddr *, socklen_t); int getpeername(int, struct sockaddr * __restrict, socklen_t * __restrict); int getsockname(int, struct sockaddr * __restrict, socklen_t * __restrict); -int getsockopt(int, int, int, void * __restrict, socklen_t * __restrict); +int getsockopt(int, int, int, void *__restrict, socklen_t * __restrict); int listen(int, int); ssize_t recv(int, void *, size_t, int); -ssize_t recvfrom(int, void * __restrict, size_t, int, +ssize_t recvfrom(int, void *__restrict, size_t, int, struct sockaddr * __restrict, socklen_t * __restrict); ssize_t recvmsg(int, struct msghdr *, int); ssize_t send(int, const void *, size_t, int);