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.87.6.1 retrieving revision 1.91 diff -u -p -r1.87.6.1 -r1.91 --- src/sys/sys/socket.h 2007/09/03 16:49:14 1.87.6.1 +++ src/sys/sys/socket.h 2008/08/04 03:55:47 1.91 @@ -1,4 +1,4 @@ -/* $NetBSD: socket.h,v 1.87.6.1 2007/09/03 16:49:14 jmcneill Exp $ */ +/* $NetBSD: socket.h,v 1.91 2008/08/04 03:55:47 tls Exp $ */ /* * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. @@ -121,6 +121,7 @@ typedef _BSD_SSIZE_T_ ssize_t; #define SO_OOBINLINE 0x0100 /* leave received OOB data in line */ #define SO_REUSEPORT 0x0200 /* allow local address & port reuse */ #define SO_TIMESTAMP 0x0400 /* timestamp received dgram traffic */ +#define SO_ACCEPTFILTER 0x1000 /* there is an accept filter */ /* @@ -136,6 +137,10 @@ typedef _BSD_SSIZE_T_ ssize_t; #define SO_TYPE 0x1008 /* get socket type */ #define SO_OVERFLOWED 0x1009 /* datagrams: return packets dropped */ +#define SO_NOHEADER 0x100a /* user supplies no header to kernel; + * kernel removes header and supplies + * payload + */ /* * Structure used for manipulating linger option. */ @@ -144,6 +149,11 @@ struct linger { int l_linger; /* linger time in seconds */ }; +struct accept_filter_arg { + char af_name[16]; + char af_arg[256-16]; +}; + /* * Level number for (get/set)sockopt() to apply to socket itself. */ @@ -196,8 +206,9 @@ struct linger { in interface output routine */ #endif #define AF_BLUETOOTH 31 /* Bluetooth: HCI, SCO, L2CAP, RFCOMM */ +#define AF_IEEE80211 32 /* IEEE80211 */ -#define AF_MAX 32 +#define AF_MAX 33 /* * Structure used by kernel to store most @@ -238,6 +249,8 @@ struct sockaddr_storage { __int64_t __ss_align;/* force desired structure storage alignment */ char __ss_pad2[_SS_PAD2SIZE]; }; +#define sstosa(__ss) ((struct sockaddr *)(__ss)) +#define sstocsa(__ss) ((const struct sockaddr *)(__ss)) #endif /* _XOPEN_SOURCE >= 500 || _NETBSD_SOURCE */ #endif /* 1 */ @@ -545,10 +558,20 @@ int __cmsg_alignbytes(void); __END_DECLS #ifdef _KERNEL +static inline socklen_t +sockaddr_getlen(const struct sockaddr *sa) +{ + return sa->sa_len; +} + __BEGIN_DECLS struct sockaddr *sockaddr_copy(struct sockaddr *, socklen_t, const struct sockaddr *); struct sockaddr *sockaddr_alloc(sa_family_t, socklen_t, int); +const void *sockaddr_const_addr(const struct sockaddr *, socklen_t *); +void *sockaddr_addr(struct sockaddr *, socklen_t *); +const struct sockaddr *sockaddr_any(const struct sockaddr *); +const void *sockaddr_anyaddr(const struct sockaddr *, socklen_t *); int sockaddr_cmp(const struct sockaddr *, const struct sockaddr *); struct sockaddr *sockaddr_dup(const struct sockaddr *, int); void sockaddr_free(struct sockaddr *);