1df6ad731Slogwang /*- 2*d4a07e70Sfengbojiang * SPDX-License-Identifier: BSD-3-Clause 3*d4a07e70Sfengbojiang * 4df6ad731Slogwang * Copyright (c) 1982, 1985, 1986, 1988, 1993, 1994 5df6ad731Slogwang * The Regents of the University of California. All rights reserved. 6df6ad731Slogwang * 7df6ad731Slogwang * Redistribution and use in source and binary forms, with or without 8df6ad731Slogwang * modification, are permitted provided that the following conditions 9df6ad731Slogwang * are met: 10df6ad731Slogwang * 1. Redistributions of source code must retain the above copyright 11df6ad731Slogwang * notice, this list of conditions and the following disclaimer. 12df6ad731Slogwang * 2. Redistributions in binary form must reproduce the above copyright 13df6ad731Slogwang * notice, this list of conditions and the following disclaimer in the 14df6ad731Slogwang * documentation and/or other materials provided with the distribution. 15*d4a07e70Sfengbojiang * 3. Neither the name of the University nor the names of its contributors 16df6ad731Slogwang * may be used to endorse or promote products derived from this software 17df6ad731Slogwang * without specific prior written permission. 18df6ad731Slogwang * 19df6ad731Slogwang * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20df6ad731Slogwang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21df6ad731Slogwang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22df6ad731Slogwang * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23df6ad731Slogwang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24df6ad731Slogwang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25df6ad731Slogwang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26df6ad731Slogwang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27df6ad731Slogwang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28df6ad731Slogwang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29df6ad731Slogwang * SUCH DAMAGE. 30df6ad731Slogwang * 31df6ad731Slogwang * @(#)socket.h 8.4 (Berkeley) 2/21/94 32df6ad731Slogwang * $FreeBSD$ 33df6ad731Slogwang */ 34df6ad731Slogwang 35df6ad731Slogwang #ifndef _COMPAT_SYS_SOCKET_H_ 36df6ad731Slogwang #define _COMPAT_SYS_SOCKET_H_ 37df6ad731Slogwang 38df6ad731Slogwang #include <sys/cdefs.h> 39df6ad731Slogwang #include <sys/_types.h> 40df6ad731Slogwang #include <sys/_iovec.h> 41df6ad731Slogwang 42df6ad731Slogwang /* 43df6ad731Slogwang * Definitions related to sockets: types, address families, options. 44df6ad731Slogwang */ 45df6ad731Slogwang 46df6ad731Slogwang /* 47df6ad731Slogwang * Data types. 48df6ad731Slogwang */ 49df6ad731Slogwang #if __BSD_VISIBLE 50df6ad731Slogwang #ifndef _GID_T_DECLARED 51df6ad731Slogwang typedef __gid_t gid_t; 52df6ad731Slogwang #define _GID_T_DECLARED 53df6ad731Slogwang #endif 54df6ad731Slogwang 55df6ad731Slogwang #ifndef _OFF_T_DECLARED 56df6ad731Slogwang typedef __off_t off_t; 57df6ad731Slogwang #define _OFF_T_DECLARED 58df6ad731Slogwang #endif 59df6ad731Slogwang 60df6ad731Slogwang #ifndef _PID_T_DECLARED 61df6ad731Slogwang typedef __pid_t pid_t; 62df6ad731Slogwang #define _PID_T_DECLARED 63df6ad731Slogwang #endif 64df6ad731Slogwang #endif 65df6ad731Slogwang 66df6ad731Slogwang #ifndef _SA_FAMILY_T_DECLARED 67df6ad731Slogwang typedef __sa_family_t sa_family_t; 68df6ad731Slogwang #define _SA_FAMILY_T_DECLARED 69df6ad731Slogwang #endif 70df6ad731Slogwang 71df6ad731Slogwang #ifndef _SOCKLEN_T_DECLARED 72df6ad731Slogwang typedef __socklen_t socklen_t; 73df6ad731Slogwang #define _SOCKLEN_T_DECLARED 74df6ad731Slogwang #endif 75df6ad731Slogwang 76df6ad731Slogwang #ifndef _SSIZE_T_DECLARED 77df6ad731Slogwang typedef __ssize_t ssize_t; 78df6ad731Slogwang #define _SSIZE_T_DECLARED 79df6ad731Slogwang #endif 80df6ad731Slogwang 81df6ad731Slogwang #if __BSD_VISIBLE 82df6ad731Slogwang #ifndef _UID_T_DECLARED 83df6ad731Slogwang typedef __uid_t uid_t; 84df6ad731Slogwang #define _UID_T_DECLARED 85df6ad731Slogwang #endif 86df6ad731Slogwang #endif 87df6ad731Slogwang 88df6ad731Slogwang #ifndef _UINT32_T_DECLARED 89df6ad731Slogwang typedef __uint32_t uint32_t; 90df6ad731Slogwang #define _UINT32_T_DECLARED 91df6ad731Slogwang #endif 92df6ad731Slogwang 93df6ad731Slogwang /* 94df6ad731Slogwang * Types 95df6ad731Slogwang */ 96df6ad731Slogwang #define SOCK_STREAM 1 /* stream socket */ 97df6ad731Slogwang #define SOCK_DGRAM 2 /* datagram socket */ 98df6ad731Slogwang #define SOCK_RAW 3 /* raw-protocol interface */ 99df6ad731Slogwang #if __BSD_VISIBLE 100df6ad731Slogwang #define SOCK_RDM 4 /* reliably-delivered message */ 101df6ad731Slogwang #endif 102df6ad731Slogwang #define SOCK_SEQPACKET 5 /* sequenced packet stream */ 103df6ad731Slogwang 104df6ad731Slogwang #if __BSD_VISIBLE 105df6ad731Slogwang /* 106df6ad731Slogwang * Creation flags, OR'ed into socket() and socketpair() type argument. 107df6ad731Slogwang */ 108df6ad731Slogwang #define SOCK_CLOEXEC 0x10000000 109df6ad731Slogwang #define SOCK_NONBLOCK 0x20000000 110*d4a07e70Sfengbojiang #ifdef _KERNEL 111*d4a07e70Sfengbojiang /* 112*d4a07e70Sfengbojiang * Flags for accept1(), kern_accept4() and solisten_dequeue, in addition 113*d4a07e70Sfengbojiang * to SOCK_CLOEXEC and SOCK_NONBLOCK. 114*d4a07e70Sfengbojiang */ 115*d4a07e70Sfengbojiang #define ACCEPT4_INHERIT 0x1 116*d4a07e70Sfengbojiang #define ACCEPT4_COMPAT 0x2 117*d4a07e70Sfengbojiang #endif /* _KERNEL */ 118*d4a07e70Sfengbojiang #endif /* __BSD_VISIBLE */ 119df6ad731Slogwang 120df6ad731Slogwang /* 121df6ad731Slogwang * Option flags per-socket. 122df6ad731Slogwang */ 123*d4a07e70Sfengbojiang #define SO_DEBUG 0x00000001 /* turn on debugging info recording */ 124*d4a07e70Sfengbojiang #define SO_ACCEPTCONN 0x00000002 /* socket has had listen() */ 125*d4a07e70Sfengbojiang #define SO_REUSEADDR 0x00000004 /* allow local address reuse */ 126*d4a07e70Sfengbojiang #define SO_KEEPALIVE 0x00000008 /* keep connections alive */ 127*d4a07e70Sfengbojiang #define SO_DONTROUTE 0x00000010 /* just use interface addresses */ 128*d4a07e70Sfengbojiang #define SO_BROADCAST 0x00000020 /* permit sending of broadcast msgs */ 129df6ad731Slogwang #if __BSD_VISIBLE 130*d4a07e70Sfengbojiang #define SO_USELOOPBACK 0x00000040 /* bypass hardware when possible */ 131df6ad731Slogwang #endif 132*d4a07e70Sfengbojiang #define SO_LINGER 0x00000080 /* linger on close if data present */ 133*d4a07e70Sfengbojiang #define SO_OOBINLINE 0x00000100 /* leave received OOB data in line */ 134df6ad731Slogwang #if __BSD_VISIBLE 135*d4a07e70Sfengbojiang #define SO_REUSEPORT 0x00000200 /* allow local address & port reuse */ 136*d4a07e70Sfengbojiang #define SO_TIMESTAMP 0x00000400 /* timestamp received dgram traffic */ 137*d4a07e70Sfengbojiang #define SO_NOSIGPIPE 0x00000800 /* no SIGPIPE from EPIPE */ 138*d4a07e70Sfengbojiang #define SO_ACCEPTFILTER 0x00001000 /* there is an accept filter */ 139*d4a07e70Sfengbojiang #define SO_BINTIME 0x00002000 /* timestamp received dgram traffic */ 140df6ad731Slogwang #endif 141*d4a07e70Sfengbojiang #define SO_NO_OFFLOAD 0x00004000 /* socket cannot be offloaded */ 142*d4a07e70Sfengbojiang #define SO_NO_DDP 0x00008000 /* disable direct data placement */ 143*d4a07e70Sfengbojiang #define SO_REUSEPORT_LB 0x00010000 /* reuse with load balancing */ 144df6ad731Slogwang 145df6ad731Slogwang /* 146df6ad731Slogwang * Additional options, not kept in so_options. 147df6ad731Slogwang */ 148df6ad731Slogwang #define SO_SNDBUF 0x1001 /* send buffer size */ 149df6ad731Slogwang #define SO_RCVBUF 0x1002 /* receive buffer size */ 150df6ad731Slogwang #define SO_SNDLOWAT 0x1003 /* send low-water mark */ 151df6ad731Slogwang #define SO_RCVLOWAT 0x1004 /* receive low-water mark */ 152df6ad731Slogwang #define SO_SNDTIMEO 0x1005 /* send timeout */ 153df6ad731Slogwang #define SO_RCVTIMEO 0x1006 /* receive timeout */ 154df6ad731Slogwang #define SO_ERROR 0x1007 /* get error status and clear */ 155df6ad731Slogwang #define SO_TYPE 0x1008 /* get socket type */ 156df6ad731Slogwang #if __BSD_VISIBLE 157df6ad731Slogwang #define SO_LABEL 0x1009 /* socket's MAC label */ 158df6ad731Slogwang #define SO_PEERLABEL 0x1010 /* socket's peer's MAC label */ 159df6ad731Slogwang #define SO_LISTENQLIMIT 0x1011 /* socket's backlog limit */ 160df6ad731Slogwang #define SO_LISTENQLEN 0x1012 /* socket's complete queue length */ 161df6ad731Slogwang #define SO_LISTENINCQLEN 0x1013 /* socket's incomplete queue length */ 162df6ad731Slogwang #define SO_SETFIB 0x1014 /* use this FIB to route */ 163df6ad731Slogwang #define SO_USER_COOKIE 0x1015 /* user cookie (dummynet etc.) */ 164df6ad731Slogwang #define SO_PROTOCOL 0x1016 /* get socket protocol (Linux name) */ 165df6ad731Slogwang #define SO_PROTOTYPE SO_PROTOCOL /* alias for SO_PROTOCOL (SunOS name) */ 166*d4a07e70Sfengbojiang #define SO_TS_CLOCK 0x1017 /* clock type used for SO_TIMESTAMP */ 167*d4a07e70Sfengbojiang #define SO_MAX_PACING_RATE 0x1018 /* socket's max TX pacing rate (Linux name) */ 168*d4a07e70Sfengbojiang #define SO_DOMAIN 0x1019 /* get socket domain */ 169*d4a07e70Sfengbojiang #endif 170*d4a07e70Sfengbojiang 171*d4a07e70Sfengbojiang #if __BSD_VISIBLE 172*d4a07e70Sfengbojiang #define SO_TS_REALTIME_MICRO 0 /* microsecond resolution, realtime */ 173*d4a07e70Sfengbojiang #define SO_TS_BINTIME 1 /* sub-nanosecond resolution, realtime */ 174*d4a07e70Sfengbojiang #define SO_TS_REALTIME 2 /* nanosecond resolution, realtime */ 175*d4a07e70Sfengbojiang #define SO_TS_MONOTONIC 3 /* nanosecond resolution, monotonic */ 176*d4a07e70Sfengbojiang #define SO_TS_DEFAULT SO_TS_REALTIME_MICRO 177*d4a07e70Sfengbojiang #define SO_TS_CLOCK_MAX SO_TS_MONOTONIC 178df6ad731Slogwang #endif 179df6ad731Slogwang 180df6ad731Slogwang /* 181df6ad731Slogwang * Space reserved for new socket options added by third-party vendors. 182df6ad731Slogwang * This range applies to all socket option levels. New socket options 183df6ad731Slogwang * in FreeBSD should always use an option value less than SO_VENDOR. 184df6ad731Slogwang */ 185df6ad731Slogwang #if __BSD_VISIBLE 186df6ad731Slogwang #define SO_VENDOR 0x80000000 187df6ad731Slogwang #endif 188df6ad731Slogwang 189df6ad731Slogwang /* 190df6ad731Slogwang * Structure used for manipulating linger option. 191df6ad731Slogwang */ 192df6ad731Slogwang struct linger { 193df6ad731Slogwang int l_onoff; /* option on/off */ 194df6ad731Slogwang int l_linger; /* linger time */ 195df6ad731Slogwang }; 196df6ad731Slogwang 197df6ad731Slogwang #if __BSD_VISIBLE 198df6ad731Slogwang struct accept_filter_arg { 199df6ad731Slogwang char af_name[16]; 200df6ad731Slogwang char af_arg[256-16]; 201df6ad731Slogwang }; 202df6ad731Slogwang #endif 203df6ad731Slogwang 204df6ad731Slogwang /* 205df6ad731Slogwang * Level number for (get/set)sockopt() to apply to socket itself. 206df6ad731Slogwang */ 207df6ad731Slogwang #define SOL_SOCKET 0xffff /* options for socket level */ 208df6ad731Slogwang 209df6ad731Slogwang /* 210df6ad731Slogwang * Address families. 211df6ad731Slogwang */ 212df6ad731Slogwang #define AF_UNSPEC 0 /* unspecified */ 213df6ad731Slogwang #if __BSD_VISIBLE 214df6ad731Slogwang #define AF_LOCAL AF_UNIX /* local to host (pipes, portals) */ 215df6ad731Slogwang #endif 216df6ad731Slogwang #define AF_UNIX 1 /* standardized name for AF_LOCAL */ 217df6ad731Slogwang #define AF_INET 2 /* internetwork: UDP, TCP, etc. */ 218df6ad731Slogwang #if __BSD_VISIBLE 219df6ad731Slogwang #define AF_IMPLINK 3 /* arpanet imp addresses */ 220df6ad731Slogwang #define AF_PUP 4 /* pup protocols: e.g. BSP */ 221df6ad731Slogwang #define AF_CHAOS 5 /* mit CHAOS protocols */ 222df6ad731Slogwang #define AF_NETBIOS 6 /* SMB protocols */ 223df6ad731Slogwang #define AF_ISO 7 /* ISO protocols */ 224df6ad731Slogwang #define AF_OSI AF_ISO 225df6ad731Slogwang #define AF_ECMA 8 /* European computer manufacturers */ 226df6ad731Slogwang #define AF_DATAKIT 9 /* datakit protocols */ 227df6ad731Slogwang #define AF_CCITT 10 /* CCITT protocols, X.25 etc */ 228df6ad731Slogwang #define AF_SNA 11 /* IBM SNA */ 229df6ad731Slogwang #define AF_DECnet 12 /* DECnet */ 230df6ad731Slogwang #define AF_DLI 13 /* DEC Direct data link interface */ 231df6ad731Slogwang #define AF_LAT 14 /* LAT */ 232df6ad731Slogwang #define AF_HYLINK 15 /* NSC Hyperchannel */ 233df6ad731Slogwang #define AF_APPLETALK 16 /* Apple Talk */ 234df6ad731Slogwang #define AF_ROUTE 17 /* Internal Routing Protocol */ 235df6ad731Slogwang #define AF_LINK 18 /* Link layer interface */ 236df6ad731Slogwang #define pseudo_AF_XTP 19 /* eXpress Transfer Protocol (no AF) */ 237df6ad731Slogwang #define AF_COIP 20 /* connection-oriented IP, aka ST II */ 238df6ad731Slogwang #define AF_CNT 21 /* Computer Network Technology */ 239df6ad731Slogwang #define pseudo_AF_RTIP 22 /* Help Identify RTIP packets */ 240df6ad731Slogwang #define AF_IPX 23 /* Novell Internet Protocol */ 241df6ad731Slogwang #define AF_SIP 24 /* Simple Internet Protocol */ 242df6ad731Slogwang #define pseudo_AF_PIP 25 /* Help Identify PIP packets */ 243df6ad731Slogwang #define AF_ISDN 26 /* Integrated Services Digital Network*/ 244df6ad731Slogwang #define AF_E164 AF_ISDN /* CCITT E.164 recommendation */ 245df6ad731Slogwang #define pseudo_AF_KEY 27 /* Internal key-management function */ 246df6ad731Slogwang #endif 247df6ad731Slogwang #define AF_INET6 28 /* IPv6 */ 248df6ad731Slogwang #if __BSD_VISIBLE 249df6ad731Slogwang #define AF_NATM 29 /* native ATM access */ 250df6ad731Slogwang #define AF_ATM 30 /* ATM */ 251df6ad731Slogwang #define pseudo_AF_HDRCMPLT 31 /* Used by BPF to not rewrite headers 252df6ad731Slogwang * in interface output routine 253df6ad731Slogwang */ 254df6ad731Slogwang #define AF_NETGRAPH 32 /* Netgraph sockets */ 255df6ad731Slogwang #define AF_SLOW 33 /* 802.3ad slow protocol */ 256df6ad731Slogwang #define AF_SCLUSTER 34 /* Sitara cluster protocol */ 257df6ad731Slogwang #define AF_ARP 35 258df6ad731Slogwang #define AF_BLUETOOTH 36 /* Bluetooth sockets */ 259df6ad731Slogwang #define AF_IEEE80211 37 /* IEEE 802.11 protocol */ 260df6ad731Slogwang #define AF_INET_SDP 40 /* OFED Socket Direct Protocol ipv4 */ 261df6ad731Slogwang #define AF_INET6_SDP 42 /* OFED Socket Direct Protocol ipv6 */ 262*d4a07e70Sfengbojiang #define AF_HYPERV 43 /* HyperV sockets */ 263*d4a07e70Sfengbojiang #define AF_MAX 43 264df6ad731Slogwang /* 265df6ad731Slogwang * When allocating a new AF_ constant, please only allocate 266df6ad731Slogwang * even numbered constants for FreeBSD until 134 as odd numbered AF_ 267df6ad731Slogwang * constants 39-133 are now reserved for vendors. 268df6ad731Slogwang */ 269df6ad731Slogwang #define AF_VENDOR00 39 270df6ad731Slogwang #define AF_VENDOR01 41 271df6ad731Slogwang #define AF_VENDOR03 45 272df6ad731Slogwang #define AF_VENDOR04 47 273df6ad731Slogwang #define AF_VENDOR05 49 274df6ad731Slogwang #define AF_VENDOR06 51 275df6ad731Slogwang #define AF_VENDOR07 53 276df6ad731Slogwang #define AF_VENDOR08 55 277df6ad731Slogwang #define AF_VENDOR09 57 278df6ad731Slogwang #define AF_VENDOR10 59 279df6ad731Slogwang #define AF_VENDOR11 61 280df6ad731Slogwang #define AF_VENDOR12 63 281df6ad731Slogwang #define AF_VENDOR13 65 282df6ad731Slogwang #define AF_VENDOR14 67 283df6ad731Slogwang #define AF_VENDOR15 69 284df6ad731Slogwang #define AF_VENDOR16 71 285df6ad731Slogwang #define AF_VENDOR17 73 286df6ad731Slogwang #define AF_VENDOR18 75 287df6ad731Slogwang #define AF_VENDOR19 77 288df6ad731Slogwang #define AF_VENDOR20 79 289df6ad731Slogwang #define AF_VENDOR21 81 290df6ad731Slogwang #define AF_VENDOR22 83 291df6ad731Slogwang #define AF_VENDOR23 85 292df6ad731Slogwang #define AF_VENDOR24 87 293df6ad731Slogwang #define AF_VENDOR25 89 294df6ad731Slogwang #define AF_VENDOR26 91 295df6ad731Slogwang #define AF_VENDOR27 93 296df6ad731Slogwang #define AF_VENDOR28 95 297df6ad731Slogwang #define AF_VENDOR29 97 298df6ad731Slogwang #define AF_VENDOR30 99 299df6ad731Slogwang #define AF_VENDOR31 101 300df6ad731Slogwang #define AF_VENDOR32 103 301df6ad731Slogwang #define AF_VENDOR33 105 302df6ad731Slogwang #define AF_VENDOR34 107 303df6ad731Slogwang #define AF_VENDOR35 109 304df6ad731Slogwang #define AF_VENDOR36 111 305df6ad731Slogwang #define AF_VENDOR37 113 306df6ad731Slogwang #define AF_VENDOR38 115 307df6ad731Slogwang #define AF_VENDOR39 117 308df6ad731Slogwang #define AF_VENDOR40 119 309df6ad731Slogwang #define AF_VENDOR41 121 310df6ad731Slogwang #define AF_VENDOR42 123 311df6ad731Slogwang #define AF_VENDOR43 125 312df6ad731Slogwang #define AF_VENDOR44 127 313df6ad731Slogwang #define AF_VENDOR45 129 314df6ad731Slogwang #define AF_VENDOR46 131 315df6ad731Slogwang #define AF_VENDOR47 133 316df6ad731Slogwang #endif 317df6ad731Slogwang 318df6ad731Slogwang /* 319df6ad731Slogwang * Structure used by kernel to store most 320df6ad731Slogwang * addresses. 321df6ad731Slogwang */ 322df6ad731Slogwang struct sockaddr { 323df6ad731Slogwang unsigned char sa_len; /* total length */ 324df6ad731Slogwang sa_family_t sa_family; /* address family */ 325df6ad731Slogwang char sa_data[14]; /* actually longer; address value */ 326df6ad731Slogwang }; 327df6ad731Slogwang #if __BSD_VISIBLE 328df6ad731Slogwang #define SOCK_MAXADDRLEN 255 /* longest possible addresses */ 329df6ad731Slogwang 330df6ad731Slogwang /* 331df6ad731Slogwang * Structure used by kernel to pass protocol 332df6ad731Slogwang * information in raw sockets. 333df6ad731Slogwang */ 334df6ad731Slogwang struct sockproto { 335df6ad731Slogwang unsigned short sp_family; /* address family */ 336df6ad731Slogwang unsigned short sp_protocol; /* protocol */ 337df6ad731Slogwang }; 338df6ad731Slogwang #endif 339df6ad731Slogwang 340df6ad731Slogwang #include <sys/_sockaddr_storage.h> 341df6ad731Slogwang 342df6ad731Slogwang #if __BSD_VISIBLE 343df6ad731Slogwang /* 344df6ad731Slogwang * Protocol families, same as address families for now. 345df6ad731Slogwang */ 346df6ad731Slogwang #define PF_UNSPEC AF_UNSPEC 347df6ad731Slogwang #define PF_LOCAL AF_LOCAL 348df6ad731Slogwang #define PF_UNIX PF_LOCAL /* backward compatibility */ 349df6ad731Slogwang #define PF_INET AF_INET 350df6ad731Slogwang #define PF_IMPLINK AF_IMPLINK 351df6ad731Slogwang #define PF_PUP AF_PUP 352df6ad731Slogwang #define PF_CHAOS AF_CHAOS 353df6ad731Slogwang #define PF_NETBIOS AF_NETBIOS 354df6ad731Slogwang #define PF_ISO AF_ISO 355df6ad731Slogwang #define PF_OSI AF_ISO 356df6ad731Slogwang #define PF_ECMA AF_ECMA 357df6ad731Slogwang #define PF_DATAKIT AF_DATAKIT 358df6ad731Slogwang #define PF_CCITT AF_CCITT 359df6ad731Slogwang #define PF_SNA AF_SNA 360df6ad731Slogwang #define PF_DECnet AF_DECnet 361df6ad731Slogwang #define PF_DLI AF_DLI 362df6ad731Slogwang #define PF_LAT AF_LAT 363df6ad731Slogwang #define PF_HYLINK AF_HYLINK 364df6ad731Slogwang #define PF_APPLETALK AF_APPLETALK 365df6ad731Slogwang #define PF_ROUTE AF_ROUTE 366df6ad731Slogwang #define PF_LINK AF_LINK 367df6ad731Slogwang #define PF_XTP pseudo_AF_XTP /* really just proto family, no AF */ 368df6ad731Slogwang #define PF_COIP AF_COIP 369df6ad731Slogwang #define PF_CNT AF_CNT 370df6ad731Slogwang #define PF_SIP AF_SIP 371df6ad731Slogwang #define PF_IPX AF_IPX 372df6ad731Slogwang #define PF_RTIP pseudo_AF_RTIP /* same format as AF_INET */ 373df6ad731Slogwang #define PF_PIP pseudo_AF_PIP 374df6ad731Slogwang #define PF_ISDN AF_ISDN 375df6ad731Slogwang #define PF_KEY pseudo_AF_KEY 376df6ad731Slogwang #define PF_INET6 AF_INET6 377df6ad731Slogwang #define PF_NATM AF_NATM 378df6ad731Slogwang #define PF_ATM AF_ATM 379df6ad731Slogwang #define PF_NETGRAPH AF_NETGRAPH 380df6ad731Slogwang #define PF_SLOW AF_SLOW 381df6ad731Slogwang #define PF_SCLUSTER AF_SCLUSTER 382df6ad731Slogwang #define PF_ARP AF_ARP 383df6ad731Slogwang #define PF_BLUETOOTH AF_BLUETOOTH 384df6ad731Slogwang #define PF_IEEE80211 AF_IEEE80211 385df6ad731Slogwang #define PF_INET_SDP AF_INET_SDP 386df6ad731Slogwang #define PF_INET6_SDP AF_INET6_SDP 387df6ad731Slogwang 388df6ad731Slogwang #define PF_MAX AF_MAX 389df6ad731Slogwang 390df6ad731Slogwang /* 391df6ad731Slogwang * Definitions for network related sysctl, CTL_NET. 392df6ad731Slogwang * 393df6ad731Slogwang * Second level is protocol family. 394df6ad731Slogwang * Third level is protocol number. 395df6ad731Slogwang * 396df6ad731Slogwang * Further levels are defined by the individual families. 397df6ad731Slogwang */ 398df6ad731Slogwang 399df6ad731Slogwang /* 400df6ad731Slogwang * PF_ROUTE - Routing table 401df6ad731Slogwang * 402df6ad731Slogwang * Three additional levels are defined: 403df6ad731Slogwang * Fourth: address family, 0 is wildcard 404df6ad731Slogwang * Fifth: type of info, defined below 405df6ad731Slogwang * Sixth: flag(s) to mask with for NET_RT_FLAGS 406df6ad731Slogwang */ 407df6ad731Slogwang #define NET_RT_DUMP 1 /* dump; may limit to a.f. */ 408df6ad731Slogwang #define NET_RT_FLAGS 2 /* by flags, e.g. RESOLVING */ 409df6ad731Slogwang #define NET_RT_IFLIST 3 /* survey interface list */ 410df6ad731Slogwang #define NET_RT_IFMALIST 4 /* return multicast address list */ 411df6ad731Slogwang #define NET_RT_IFLISTL 5 /* Survey interface list, using 'l'en 412df6ad731Slogwang * versions of msghdr structs. */ 413*d4a07e70Sfengbojiang #define NET_RT_NHOP 6 /* dump routing nexthops */ 414*d4a07e70Sfengbojiang #define NET_RT_NHGRP 7 /* dump routing nexthop groups */ 415df6ad731Slogwang #endif /* __BSD_VISIBLE */ 416df6ad731Slogwang 417df6ad731Slogwang /* 418df6ad731Slogwang * Maximum queue length specifiable by listen. 419df6ad731Slogwang */ 420df6ad731Slogwang #define SOMAXCONN 128 421df6ad731Slogwang 422df6ad731Slogwang /* 423df6ad731Slogwang * Message header for recvmsg and sendmsg calls. 424df6ad731Slogwang * Used value-result for recvmsg, value only for sendmsg. 425df6ad731Slogwang */ 426df6ad731Slogwang struct msghdr { 427df6ad731Slogwang void *msg_name; /* optional address */ 428df6ad731Slogwang socklen_t msg_namelen; /* size of address */ 429df6ad731Slogwang struct iovec *msg_iov; /* scatter/gather array */ 430df6ad731Slogwang int msg_iovlen; /* # elements in msg_iov */ 431df6ad731Slogwang void *msg_control; /* ancillary data, see below */ 432df6ad731Slogwang socklen_t msg_controllen; /* ancillary data buffer len */ 433df6ad731Slogwang int msg_flags; /* flags on received message */ 434df6ad731Slogwang }; 435df6ad731Slogwang 436*d4a07e70Sfengbojiang #define MSG_OOB 0x00000001 /* process out-of-band data */ 437*d4a07e70Sfengbojiang #define MSG_PEEK 0x00000002 /* peek at incoming message */ 438*d4a07e70Sfengbojiang #define MSG_DONTROUTE 0x00000004 /* send without using routing tables */ 439*d4a07e70Sfengbojiang #define MSG_EOR 0x00000008 /* data completes record */ 440*d4a07e70Sfengbojiang #define MSG_TRUNC 0x00000010 /* data discarded before delivery */ 441*d4a07e70Sfengbojiang #define MSG_CTRUNC 0x00000020 /* control data lost before delivery */ 442*d4a07e70Sfengbojiang #define MSG_WAITALL 0x00000040 /* wait for full request or error */ 443df6ad731Slogwang #if __BSD_VISIBLE 444*d4a07e70Sfengbojiang #define MSG_DONTWAIT 0x00000080 /* this message should be nonblocking */ 445*d4a07e70Sfengbojiang #define MSG_EOF 0x00000100 /* data completes connection */ 446*d4a07e70Sfengbojiang /* 0x00000200 unused */ 447*d4a07e70Sfengbojiang /* 0x00000400 unused */ 448*d4a07e70Sfengbojiang /* 0x00000800 unused */ 449*d4a07e70Sfengbojiang /* 0x00001000 unused */ 450*d4a07e70Sfengbojiang #define MSG_NOTIFICATION 0x00002000 /* SCTP notification */ 451*d4a07e70Sfengbojiang #define MSG_NBIO 0x00004000 /* FIONBIO mode, used by fifofs */ 452*d4a07e70Sfengbojiang #define MSG_COMPAT 0x00008000 /* used in sendit() */ 453df6ad731Slogwang #endif 454df6ad731Slogwang #ifdef _KERNEL 455*d4a07e70Sfengbojiang #define MSG_SOCALLBCK 0x00010000 /* for use by socket callbacks - soreceive (TCP) */ 456*d4a07e70Sfengbojiang #endif 457*d4a07e70Sfengbojiang #if __POSIX_VISIBLE >= 200809 458*d4a07e70Sfengbojiang #define MSG_NOSIGNAL 0x00020000 /* do not generate SIGPIPE on EOF */ 459*d4a07e70Sfengbojiang #endif 460*d4a07e70Sfengbojiang #if __BSD_VISIBLE 461*d4a07e70Sfengbojiang #define MSG_CMSG_CLOEXEC 0x00040000 /* make received fds close-on-exec */ 462*d4a07e70Sfengbojiang #define MSG_WAITFORONE 0x00080000 /* for recvmmsg() */ 463*d4a07e70Sfengbojiang #endif 464*d4a07e70Sfengbojiang #ifdef _KERNEL 465*d4a07e70Sfengbojiang #define MSG_MORETOCOME 0x00100000 /* additional data pending */ 466*d4a07e70Sfengbojiang #define MSG_TLSAPPDATA 0x00200000 /* only soreceive() app. data (TLS) */ 467df6ad731Slogwang #endif 468df6ad731Slogwang 469df6ad731Slogwang /* 470df6ad731Slogwang * Header for ancillary data objects in msg_control buffer. 471df6ad731Slogwang * Used for additional information with/about a datagram 472df6ad731Slogwang * not expressible by flags. The format is a sequence 473df6ad731Slogwang * of message elements headed by cmsghdr structures. 474df6ad731Slogwang */ 475df6ad731Slogwang struct cmsghdr { 476df6ad731Slogwang socklen_t cmsg_len; /* data byte count, including hdr */ 477df6ad731Slogwang int cmsg_level; /* originating protocol */ 478df6ad731Slogwang int cmsg_type; /* protocol-specific type */ 479df6ad731Slogwang /* followed by u_char cmsg_data[]; */ 480df6ad731Slogwang }; 481df6ad731Slogwang 482df6ad731Slogwang #if __BSD_VISIBLE 483df6ad731Slogwang /* 484df6ad731Slogwang * While we may have more groups than this, the cmsgcred struct must 485df6ad731Slogwang * be able to fit in an mbuf and we have historically supported a 486df6ad731Slogwang * maximum of 16 groups. 487df6ad731Slogwang */ 488df6ad731Slogwang #define CMGROUP_MAX 16 489df6ad731Slogwang 490df6ad731Slogwang /* 491df6ad731Slogwang * Credentials structure, used to verify the identity of a peer 492df6ad731Slogwang * process that has sent us a message. This is allocated by the 493df6ad731Slogwang * peer process but filled in by the kernel. This prevents the 494df6ad731Slogwang * peer from lying about its identity. (Note that cmcred_groups[0] 495df6ad731Slogwang * is the effective GID.) 496df6ad731Slogwang */ 497df6ad731Slogwang struct cmsgcred { 498df6ad731Slogwang pid_t cmcred_pid; /* PID of sending process */ 499df6ad731Slogwang uid_t cmcred_uid; /* real UID of sending process */ 500df6ad731Slogwang uid_t cmcred_euid; /* effective UID of sending process */ 501df6ad731Slogwang gid_t cmcred_gid; /* real GID of sending process */ 502df6ad731Slogwang short cmcred_ngroups; /* number or groups */ 503df6ad731Slogwang gid_t cmcred_groups[CMGROUP_MAX]; /* groups */ 504df6ad731Slogwang }; 505df6ad731Slogwang 506df6ad731Slogwang /* 507*d4a07e70Sfengbojiang * Socket credentials (LOCAL_CREDS). 508df6ad731Slogwang */ 509df6ad731Slogwang struct sockcred { 510df6ad731Slogwang uid_t sc_uid; /* real user id */ 511df6ad731Slogwang uid_t sc_euid; /* effective user id */ 512df6ad731Slogwang gid_t sc_gid; /* real group id */ 513df6ad731Slogwang gid_t sc_egid; /* effective group id */ 514df6ad731Slogwang int sc_ngroups; /* number of supplemental groups */ 515df6ad731Slogwang gid_t sc_groups[1]; /* variable length */ 516df6ad731Slogwang }; 517df6ad731Slogwang 518df6ad731Slogwang /* 519df6ad731Slogwang * Compute size of a sockcred structure with groups. 520df6ad731Slogwang */ 521df6ad731Slogwang #define SOCKCREDSIZE(ngrps) \ 522df6ad731Slogwang (sizeof(struct sockcred) + (sizeof(gid_t) * ((ngrps) - 1))) 523df6ad731Slogwang 524*d4a07e70Sfengbojiang /* 525*d4a07e70Sfengbojiang * Socket credentials (LOCAL_CREDS_PERSISTENT). 526*d4a07e70Sfengbojiang */ 527*d4a07e70Sfengbojiang struct sockcred2 { 528*d4a07e70Sfengbojiang int sc_version; /* version of this structure */ 529*d4a07e70Sfengbojiang pid_t sc_pid; /* PID of sending process */ 530*d4a07e70Sfengbojiang uid_t sc_uid; /* real user id */ 531*d4a07e70Sfengbojiang uid_t sc_euid; /* effective user id */ 532*d4a07e70Sfengbojiang gid_t sc_gid; /* real group id */ 533*d4a07e70Sfengbojiang gid_t sc_egid; /* effective group id */ 534*d4a07e70Sfengbojiang int sc_ngroups; /* number of supplemental groups */ 535*d4a07e70Sfengbojiang gid_t sc_groups[1]; /* variable length */ 536*d4a07e70Sfengbojiang }; 537*d4a07e70Sfengbojiang #define SOCKCRED2SIZE(ngrps) \ 538*d4a07e70Sfengbojiang (sizeof(struct sockcred2) + (sizeof(gid_t) * ((ngrps) - 1))) 539*d4a07e70Sfengbojiang 540df6ad731Slogwang #endif /* __BSD_VISIBLE */ 541df6ad731Slogwang 542df6ad731Slogwang /* given pointer to struct cmsghdr, return pointer to data */ 543df6ad731Slogwang #define CMSG_DATA(cmsg) ((unsigned char *)(cmsg) + \ 544df6ad731Slogwang _ALIGN(sizeof(struct cmsghdr))) 545df6ad731Slogwang 546df6ad731Slogwang /* given pointer to struct cmsghdr, return pointer to next cmsghdr */ 547df6ad731Slogwang #define CMSG_NXTHDR(mhdr, cmsg) \ 548df6ad731Slogwang ((char *)(cmsg) == (char *)0 ? CMSG_FIRSTHDR(mhdr) : \ 549df6ad731Slogwang ((char *)(cmsg) + _ALIGN(((struct cmsghdr *)(cmsg))->cmsg_len) + \ 550df6ad731Slogwang _ALIGN(sizeof(struct cmsghdr)) > \ 551df6ad731Slogwang (char *)(mhdr)->msg_control + (mhdr)->msg_controllen) ? \ 552df6ad731Slogwang (struct cmsghdr *)0 : \ 553df6ad731Slogwang (struct cmsghdr *)(void *)((char *)(cmsg) + \ 554df6ad731Slogwang _ALIGN(((struct cmsghdr *)(cmsg))->cmsg_len))) 555df6ad731Slogwang 556df6ad731Slogwang /* 557df6ad731Slogwang * RFC 2292 requires to check msg_controllen, in case that the kernel returns 558df6ad731Slogwang * an empty list for some reasons. 559df6ad731Slogwang */ 560df6ad731Slogwang #define CMSG_FIRSTHDR(mhdr) \ 561df6ad731Slogwang ((mhdr)->msg_controllen >= sizeof(struct cmsghdr) ? \ 562df6ad731Slogwang (struct cmsghdr *)(mhdr)->msg_control : \ 563df6ad731Slogwang (struct cmsghdr *)0) 564df6ad731Slogwang 565df6ad731Slogwang #if __BSD_VISIBLE 566df6ad731Slogwang /* RFC 2292 additions */ 567df6ad731Slogwang #define CMSG_SPACE(l) (_ALIGN(sizeof(struct cmsghdr)) + _ALIGN(l)) 568df6ad731Slogwang #define CMSG_LEN(l) (_ALIGN(sizeof(struct cmsghdr)) + (l)) 569df6ad731Slogwang #endif 570df6ad731Slogwang 571df6ad731Slogwang #ifdef _KERNEL 572df6ad731Slogwang #define CMSG_ALIGN(n) _ALIGN(n) 573df6ad731Slogwang #endif 574df6ad731Slogwang 575df6ad731Slogwang /* "Socket"-level control message types: */ 576df6ad731Slogwang #define SCM_RIGHTS 0x01 /* access rights (array of int) */ 577df6ad731Slogwang #if __BSD_VISIBLE 578df6ad731Slogwang #define SCM_TIMESTAMP 0x02 /* timestamp (struct timeval) */ 579df6ad731Slogwang #define SCM_CREDS 0x03 /* process creds (struct cmsgcred) */ 580df6ad731Slogwang #define SCM_BINTIME 0x04 /* timestamp (struct bintime) */ 581*d4a07e70Sfengbojiang #define SCM_REALTIME 0x05 /* timestamp (struct timespec) */ 582*d4a07e70Sfengbojiang #define SCM_MONOTONIC 0x06 /* timestamp (struct timespec) */ 583*d4a07e70Sfengbojiang #define SCM_TIME_INFO 0x07 /* timestamp info */ 584*d4a07e70Sfengbojiang #define SCM_CREDS2 0x08 /* process creds (struct sockcred2) */ 585*d4a07e70Sfengbojiang 586*d4a07e70Sfengbojiang struct sock_timestamp_info { 587*d4a07e70Sfengbojiang __uint32_t st_info_flags; 588*d4a07e70Sfengbojiang __uint32_t st_info_pad0; 589*d4a07e70Sfengbojiang __uint64_t st_info_rsv[7]; 590*d4a07e70Sfengbojiang }; 591*d4a07e70Sfengbojiang 592*d4a07e70Sfengbojiang #define ST_INFO_HW 0x0001 /* SCM_TIMESTAMP was hw */ 593*d4a07e70Sfengbojiang #define ST_INFO_HW_HPREC 0x0002 /* SCM_TIMESTAMP was hw-assisted 594*d4a07e70Sfengbojiang on entrance */ 595df6ad731Slogwang #endif 596df6ad731Slogwang 597df6ad731Slogwang #if __BSD_VISIBLE 598df6ad731Slogwang /* 599df6ad731Slogwang * 4.3 compat sockaddr, move to compat file later 600df6ad731Slogwang */ 601df6ad731Slogwang struct osockaddr { 602df6ad731Slogwang unsigned short sa_family; /* address family */ 603df6ad731Slogwang char sa_data[14]; /* up to 14 bytes of direct address */ 604df6ad731Slogwang }; 605df6ad731Slogwang 606df6ad731Slogwang /* 607df6ad731Slogwang * 4.3-compat message header (move to compat file later). 608df6ad731Slogwang */ 609df6ad731Slogwang struct omsghdr { 610df6ad731Slogwang char *msg_name; /* optional address */ 611df6ad731Slogwang int msg_namelen; /* size of address */ 612df6ad731Slogwang struct iovec *msg_iov; /* scatter/gather array */ 613df6ad731Slogwang int msg_iovlen; /* # elements in msg_iov */ 614df6ad731Slogwang char *msg_accrights; /* access rights sent/received */ 615df6ad731Slogwang int msg_accrightslen; 616df6ad731Slogwang }; 617df6ad731Slogwang #endif 618df6ad731Slogwang 619df6ad731Slogwang /* 620df6ad731Slogwang * howto arguments for shutdown(2), specified by Posix.1g. 621df6ad731Slogwang */ 622df6ad731Slogwang #define SHUT_RD 0 /* shut down the reading side */ 623df6ad731Slogwang #define SHUT_WR 1 /* shut down the writing side */ 624df6ad731Slogwang #define SHUT_RDWR 2 /* shut down both sides */ 625df6ad731Slogwang 626df6ad731Slogwang #if __BSD_VISIBLE 627df6ad731Slogwang /* for SCTP */ 628df6ad731Slogwang /* we cheat and use the SHUT_XX defines for these */ 629df6ad731Slogwang #define PRU_FLUSH_RD SHUT_RD 630df6ad731Slogwang #define PRU_FLUSH_WR SHUT_WR 631df6ad731Slogwang #define PRU_FLUSH_RDWR SHUT_RDWR 632df6ad731Slogwang #endif 633df6ad731Slogwang 634df6ad731Slogwang #if __BSD_VISIBLE 635df6ad731Slogwang /* 636df6ad731Slogwang * sendfile(2) header/trailer struct 637df6ad731Slogwang */ 638df6ad731Slogwang struct sf_hdtr { 639df6ad731Slogwang struct iovec *headers; /* pointer to an array of header struct iovec's */ 640df6ad731Slogwang int hdr_cnt; /* number of header iovec's */ 641df6ad731Slogwang struct iovec *trailers; /* pointer to an array of trailer struct iovec's */ 642df6ad731Slogwang int trl_cnt; /* number of trailer iovec's */ 643df6ad731Slogwang }; 644df6ad731Slogwang 645df6ad731Slogwang /* 646df6ad731Slogwang * Sendfile-specific flag(s) 647df6ad731Slogwang */ 648df6ad731Slogwang #define SF_NODISKIO 0x00000001 649df6ad731Slogwang #define SF_MNOWAIT 0x00000002 /* obsolete */ 650df6ad731Slogwang #define SF_SYNC 0x00000004 651*d4a07e70Sfengbojiang #define SF_USER_READAHEAD 0x00000008 652df6ad731Slogwang #define SF_NOCACHE 0x00000010 653df6ad731Slogwang #define SF_FLAGS(rh, flags) (((rh) << 16) | (flags)) 654df6ad731Slogwang 655df6ad731Slogwang #ifdef _KERNEL 656df6ad731Slogwang #define SF_READAHEAD(flags) ((flags) >> 16) 657df6ad731Slogwang #endif /* _KERNEL */ 658df6ad731Slogwang 659df6ad731Slogwang /* 660df6ad731Slogwang * Sendmmsg/recvmmsg specific structure(s) 661df6ad731Slogwang */ 662df6ad731Slogwang struct mmsghdr { 663df6ad731Slogwang struct msghdr msg_hdr; /* message header */ 664df6ad731Slogwang ssize_t msg_len; /* message length */ 665df6ad731Slogwang }; 666df6ad731Slogwang #endif /* __BSD_VISIBLE */ 667df6ad731Slogwang 6681eaf0ac3Slogwang #ifndef _KERNEL 6691eaf0ac3Slogwang 6701eaf0ac3Slogwang #include <sys/cdefs.h> 6711eaf0ac3Slogwang 6721eaf0ac3Slogwang __BEGIN_DECLS 6731eaf0ac3Slogwang int accept(int, struct sockaddr * __restrict, socklen_t * __restrict); 6741eaf0ac3Slogwang int bind(int, const struct sockaddr *, socklen_t); 6751eaf0ac3Slogwang int connect(int, const struct sockaddr *, socklen_t); 6761eaf0ac3Slogwang #if __BSD_VISIBLE 6771eaf0ac3Slogwang int accept4(int, struct sockaddr * __restrict, socklen_t * __restrict, int); 6781eaf0ac3Slogwang int bindat(int, int, const struct sockaddr *, socklen_t); 6791eaf0ac3Slogwang int connectat(int, int, const struct sockaddr *, socklen_t); 6801eaf0ac3Slogwang #endif 6811eaf0ac3Slogwang int getpeername(int, struct sockaddr * __restrict, socklen_t * __restrict); 6821eaf0ac3Slogwang int getsockname(int, struct sockaddr * __restrict, socklen_t * __restrict); 6831eaf0ac3Slogwang int getsockopt(int, int, int, void * __restrict, socklen_t * __restrict); 6841eaf0ac3Slogwang int listen(int, int); 6851eaf0ac3Slogwang ssize_t recv(int, void *, size_t, int); 6861eaf0ac3Slogwang ssize_t recvfrom(int, void *, size_t, int, struct sockaddr * __restrict, socklen_t * __restrict); 6871eaf0ac3Slogwang ssize_t recvmsg(int, struct msghdr *, int); 6881eaf0ac3Slogwang #if __BSD_VISIBLE 6891eaf0ac3Slogwang struct timespec; 6901eaf0ac3Slogwang ssize_t recvmmsg(int, struct mmsghdr * __restrict, size_t, int, 6911eaf0ac3Slogwang const struct timespec * __restrict); 6921eaf0ac3Slogwang #endif 6931eaf0ac3Slogwang ssize_t send(int, const void *, size_t, int); 6941eaf0ac3Slogwang ssize_t sendto(int, const void *, 6951eaf0ac3Slogwang size_t, int, const struct sockaddr *, socklen_t); 6961eaf0ac3Slogwang ssize_t sendmsg(int, const struct msghdr *, int); 6971eaf0ac3Slogwang #if __BSD_VISIBLE 6981eaf0ac3Slogwang int sendfile(int, int, off_t, size_t, struct sf_hdtr *, off_t *, int); 6991eaf0ac3Slogwang ssize_t sendmmsg(int, struct mmsghdr * __restrict, size_t, int); 7001eaf0ac3Slogwang int setfib(int); 7011eaf0ac3Slogwang #endif 7021eaf0ac3Slogwang int setsockopt(int, int, int, const void *, socklen_t); 7031eaf0ac3Slogwang int shutdown(int, int); 7041eaf0ac3Slogwang int sockatmark(int); 7051eaf0ac3Slogwang int socket(int, int, int); 7061eaf0ac3Slogwang int socketpair(int, int, int, int *); 7071eaf0ac3Slogwang __END_DECLS 7081eaf0ac3Slogwang 7091eaf0ac3Slogwang #endif /* !_KERNEL */ 7101eaf0ac3Slogwang 711df6ad731Slogwang #endif /* !_COMPAT_SYS_SOCKET_H_ */ 712