123438Smckusick /* 235796Ssklower * Copyright (c) 1982,1985,1986,1988 Regents of the University of California. 333186Sbostic * All rights reserved. 423438Smckusick * 544523Sbostic * %sccs.include.redist.c% 633186Sbostic * 7*58896Smckusick * @(#)socket.h 7.19 (Berkeley) 03/31/93 823438Smckusick */ 94658Swnj 104658Swnj /* 1112787Ssam * Definitions related to sockets: types, address families, options. 124658Swnj */ 134892Swnj 144892Swnj /* 1512787Ssam * Types 164892Swnj */ 174930Swnj #define SOCK_STREAM 1 /* stream socket */ 184930Swnj #define SOCK_DGRAM 2 /* datagram socket */ 194930Swnj #define SOCK_RAW 3 /* raw-protocol interface */ 204930Swnj #define SOCK_RDM 4 /* reliably-delivered message */ 2112787Ssam #define SOCK_SEQPACKET 5 /* sequenced packet stream */ 224658Swnj 234812Swnj /* 244812Swnj * Option flags per-socket. 254812Swnj */ 2627192Skarels #define SO_DEBUG 0x0001 /* turn on debugging info recording */ 2727192Skarels #define SO_ACCEPTCONN 0x0002 /* socket has had listen() */ 2827192Skarels #define SO_REUSEADDR 0x0004 /* allow local address reuse */ 2927192Skarels #define SO_KEEPALIVE 0x0008 /* keep connections alive */ 3027192Skarels #define SO_DONTROUTE 0x0010 /* just use interface addresses */ 3127192Skarels #define SO_BROADCAST 0x0020 /* permit sending of broadcast msgs */ 3227192Skarels #define SO_USELOOPBACK 0x0040 /* bypass hardware when possible */ 3327192Skarels #define SO_LINGER 0x0080 /* linger on close if data present */ 3427192Skarels #define SO_OOBINLINE 0x0100 /* leave received OOB data in line */ 3555346Ssklower #define SO_REUSEPORT 0x0200 /* allow local address & port reuse */ 364930Swnj 374930Swnj /* 3817552Skarels * Additional options, not kept in so_options. 3917552Skarels */ 4017552Skarels #define SO_SNDBUF 0x1001 /* send buffer size */ 4117552Skarels #define SO_RCVBUF 0x1002 /* receive buffer size */ 4217552Skarels #define SO_SNDLOWAT 0x1003 /* send low-water mark */ 4317552Skarels #define SO_RCVLOWAT 0x1004 /* receive low-water mark */ 4417552Skarels #define SO_SNDTIMEO 0x1005 /* send timeout */ 4517552Skarels #define SO_RCVTIMEO 0x1006 /* receive timeout */ 4624825Skarels #define SO_ERROR 0x1007 /* get error status and clear */ 4725503Skarels #define SO_TYPE 0x1008 /* get socket type */ 4817552Skarels 4917552Skarels /* 5017160Ssam * Structure used for manipulating linger option. 5117052Skarels */ 5217160Ssam struct linger { 5317160Ssam int l_onoff; /* option on/off */ 5417160Ssam int l_linger; /* linger time */ 5517160Ssam }; 5617052Skarels 5717052Skarels /* 5817160Ssam * Level number for (get/set)sockopt() to apply to socket itself. 5917160Ssam */ 6017160Ssam #define SOL_SOCKET 0xffff /* options for socket level */ 6117160Ssam 6217160Ssam /* 6312787Ssam * Address families. 644930Swnj */ 6512787Ssam #define AF_UNSPEC 0 /* unspecified */ 6612787Ssam #define AF_UNIX 1 /* local to host (pipes, portals) */ 6712787Ssam #define AF_INET 2 /* internetwork: UDP, TCP, etc. */ 6812787Ssam #define AF_IMPLINK 3 /* arpanet imp addresses */ 6912787Ssam #define AF_PUP 4 /* pup protocols: e.g. BSP */ 7012787Ssam #define AF_CHAOS 5 /* mit CHAOS protocols */ 7112787Ssam #define AF_NS 6 /* XEROX NS protocols */ 7236353Ssklower #define AF_ISO 7 /* ISO protocols */ 7340764Skarels #define AF_OSI AF_ISO 7412787Ssam #define AF_ECMA 8 /* european computer manufacturers */ 7512787Ssam #define AF_DATAKIT 9 /* datakit protocols */ 7612787Ssam #define AF_CCITT 10 /* CCITT protocols, X.25 etc */ 7712787Ssam #define AF_SNA 11 /* IBM SNA */ 7823751Skarels #define AF_DECnet 12 /* DECnet */ 7940764Skarels #define AF_DLI 13 /* DEC Direct data link interface */ 8023751Skarels #define AF_LAT 14 /* LAT */ 8123751Skarels #define AF_HYLINK 15 /* NSC Hyperchannel */ 8228881Skarels #define AF_APPLETALK 16 /* Apple Talk */ 8336353Ssklower #define AF_ROUTE 17 /* Internal Routing Protocol */ 8440764Skarels #define AF_LINK 18 /* Link layer interface */ 8540764Skarels #define pseudo_AF_XTP 19 /* eXpress Transfer Protocol (no AF) */ 8651008Skarels #define AF_COIP 20 /* connection-oriented IP, aka ST II */ 8753622Ssklower #define AF_CNT 21 /* Computer Network Technology */ 884930Swnj 8953622Ssklower #define AF_MAX 22 904930Swnj 914930Swnj /* 9212787Ssam * Structure used by kernel to store most 9312787Ssam * addresses. 944930Swnj */ 954930Swnj struct sockaddr { 9635796Ssklower u_char sa_len; /* total length */ 9735796Ssklower u_char sa_family; /* address family */ 9836353Ssklower char sa_data[14]; /* actually longer; address value */ 9935796Ssklower }; 1004930Swnj 1014930Swnj /* 10212787Ssam * Structure used by kernel to pass protocol 10312787Ssam * information in raw sockets. 1044930Swnj */ 10512787Ssam struct sockproto { 10612787Ssam u_short sp_family; /* address family */ 10712787Ssam u_short sp_protocol; /* protocol */ 10812787Ssam }; 1096620Ssam 11012787Ssam /* 11112787Ssam * Protocol families, same as address families for now. 11212787Ssam */ 11312787Ssam #define PF_UNSPEC AF_UNSPEC 11412787Ssam #define PF_UNIX AF_UNIX 11512787Ssam #define PF_INET AF_INET 11612787Ssam #define PF_IMPLINK AF_IMPLINK 11712787Ssam #define PF_PUP AF_PUP 11812787Ssam #define PF_CHAOS AF_CHAOS 11912787Ssam #define PF_NS AF_NS 12036353Ssklower #define PF_ISO AF_ISO 12140764Skarels #define PF_OSI AF_ISO 12212787Ssam #define PF_ECMA AF_ECMA 12312787Ssam #define PF_DATAKIT AF_DATAKIT 12412787Ssam #define PF_CCITT AF_CCITT 12512787Ssam #define PF_SNA AF_SNA 12623751Skarels #define PF_DECnet AF_DECnet 12723751Skarels #define PF_DLI AF_DLI 12823751Skarels #define PF_LAT AF_LAT 12923751Skarels #define PF_HYLINK AF_HYLINK 13028881Skarels #define PF_APPLETALK AF_APPLETALK 13136353Ssklower #define PF_ROUTE AF_ROUTE 13240764Skarels #define PF_LINK AF_LINK 13340764Skarels #define PF_XTP pseudo_AF_XTP /* really just proto family, no AF */ 13451008Skarels #define PF_COIP AF_COIP 13553622Ssklower #define PF_CNT AF_CNT 1368274Sroot 13723751Skarels #define PF_MAX AF_MAX 13812787Ssam 13912787Ssam /* 14057838Smckusick * Definitions for network related sysctl, CTL_NET. 14157838Smckusick * 14257838Smckusick * Second level is protocol family. 14357838Smckusick * Third level is protocol number. 14457838Smckusick * 14557838Smckusick * Further levels are defined by the individual families below. 14657838Smckusick */ 147*58896Smckusick #define NET_MAXID AF_MAX 148*58896Smckusick 149*58896Smckusick #define CTL_NET_NAMES { \ 150*58896Smckusick "unspec", \ 151*58896Smckusick "unix", \ 152*58896Smckusick "inet", \ 153*58896Smckusick "implink", \ 154*58896Smckusick "pup", \ 155*58896Smckusick "chaos", \ 156*58896Smckusick "xerox_ns", \ 157*58896Smckusick "iso", \ 158*58896Smckusick "emca", \ 159*58896Smckusick "datakit", \ 160*58896Smckusick "ccitt", \ 161*58896Smckusick "ibm_sna", \ 162*58896Smckusick "decnet", \ 163*58896Smckusick "dec_dli", \ 164*58896Smckusick "lat", \ 165*58896Smckusick "hylink", \ 166*58896Smckusick "appletalk", \ 167*58896Smckusick "route", \ 168*58896Smckusick "link_layer", \ 169*58896Smckusick "xtp", \ 170*58896Smckusick "coip", \ 171*58896Smckusick "cnt", \ 172*58896Smckusick } 173*58896Smckusick 17457838Smckusick /* 17557838Smckusick * PF_ROUTE - Routing table 17657838Smckusick * 17757838Smckusick * Three additional levels are defined: 17857838Smckusick * Fourth: address family, 0 is wildcard 17957838Smckusick * Fifth: type of info, defined below 18057838Smckusick * Sixth: flag(s) to mask with for NET_RT_FLAGS 18157838Smckusick */ 18257838Smckusick #define NET_RT_DUMP 1 /* dump; may limit to a.f. */ 18357838Smckusick #define NET_RT_FLAGS 2 /* by flags, e.g. RESOLVING */ 18457838Smckusick #define NET_RT_IFLIST 3 /* survey interface list */ 18557838Smckusick 18657838Smckusick #define CTL_NET_RT_NAMES { \ 18757838Smckusick "unspec", \ 18857838Smckusick "dump", \ 18957838Smckusick "flags", \ 19057838Smckusick "iflist", \ 19157838Smckusick } 19257838Smckusick 19357838Smckusick /* 19412787Ssam * Maximum queue length specifiable by listen. 19512787Ssam */ 19612787Ssam #define SOMAXCONN 5 19712787Ssam 19812787Ssam /* 19912787Ssam * Message header for recvmsg and sendmsg calls. 20035796Ssklower * Used value-result for recvmsg, value only for sendmsg. 20112787Ssam */ 20212787Ssam struct msghdr { 20312787Ssam caddr_t msg_name; /* optional address */ 20442464Ssklower u_int msg_namelen; /* size of address */ 20512787Ssam struct iovec *msg_iov; /* scatter/gather array */ 20642464Ssklower u_int msg_iovlen; /* # elements in msg_iov */ 20740764Skarels caddr_t msg_control; /* ancillary data, see below */ 20842464Ssklower u_int msg_controllen; /* ancillary data buffer len */ 20935796Ssklower int msg_flags; /* flags on received message */ 21012787Ssam }; 21112787Ssam 21212787Ssam #define MSG_OOB 0x1 /* process out-of-band data */ 21312787Ssam #define MSG_PEEK 0x2 /* peek at incoming message */ 21412787Ssam #define MSG_DONTROUTE 0x4 /* send without using routing tables */ 21535796Ssklower #define MSG_EOR 0x8 /* data completes record */ 21635796Ssklower #define MSG_TRUNC 0x10 /* data discarded before delivery */ 21735796Ssklower #define MSG_CTRUNC 0x20 /* control data lost before delivery */ 21840764Skarels #define MSG_WAITALL 0x40 /* wait for full request or error */ 21951753Smckusick #define MSG_DONTWAIT 0x80 /* this message should be nonblocking */ 22012787Ssam 22135796Ssklower /* 22240764Skarels * Header for ancillary data objects in msg_control buffer. 22340764Skarels * Used for additional information with/about a datagram 22440764Skarels * not expressible by flags. The format is a sequence 22540764Skarels * of message elements headed by cmsghdr structures. 22640764Skarels */ 22740764Skarels struct cmsghdr { 22840764Skarels u_int cmsg_len; /* data byte count, including hdr */ 22942464Ssklower int cmsg_level; /* originating protocol */ 23042464Ssklower int cmsg_type; /* protocol-specific type */ 23140764Skarels /* followed by u_char cmsg_data[]; */ 23240764Skarels }; 23340764Skarels 23440764Skarels /* given pointer to struct adatahdr, return pointer to data */ 23540764Skarels #define CMSG_DATA(cmsg) ((u_char *)((cmsg) + 1)) 23640764Skarels 23740764Skarels /* given pointer to struct adatahdr, return pointer to next adatahdr */ 23840764Skarels #define CMSG_NXTHDR(mhdr, cmsg) \ 23940764Skarels (((caddr_t)(cmsg) + (cmsg)->cmsg_len + sizeof(struct cmsghdr) > \ 24040764Skarels (mhdr)->msg_control + (mhdr)->msg_controllen) ? \ 24140764Skarels (struct cmsghdr *)NULL : \ 24240764Skarels (struct cmsghdr *)((caddr_t)(cmsg) + ALIGN((cmsg)->cmsg_len))) 24340764Skarels 24440764Skarels #define CMSG_FIRSTHDR(mhdr) ((struct cmsghdr *)(mhdr)->msg_control) 24540764Skarels 24640764Skarels /* "Socket"-level control message types: */ 24740764Skarels #define SCM_RIGHTS 0x01 /* access rights (array of int) */ 24840764Skarels 24940764Skarels /* 25040764Skarels * 4.3 compat sockaddr, move to compat file later 25140764Skarels */ 25240764Skarels struct osockaddr { 25340764Skarels u_short sa_family; /* address family */ 25440764Skarels char sa_data[14]; /* up to 14 bytes of direct address */ 25540764Skarels }; 25640764Skarels 25740764Skarels /* 25835796Ssklower * 4.3-compat message header (move to compat file later). 25935796Ssklower */ 26035796Ssklower struct omsghdr { 26135796Ssklower caddr_t msg_name; /* optional address */ 26235796Ssklower int msg_namelen; /* size of address */ 26335796Ssklower struct iovec *msg_iov; /* scatter/gather array */ 26435796Ssklower int msg_iovlen; /* # elements in msg_iov */ 26535796Ssklower caddr_t msg_accrights; /* access rights sent/received */ 26635796Ssklower int msg_accrightslen; 26735796Ssklower }; 26846577Sdonn 26946577Sdonn #ifndef KERNEL 27046577Sdonn 27146577Sdonn #include <sys/cdefs.h> 27246577Sdonn 27346577Sdonn __BEGIN_DECLS 27446577Sdonn int accept __P((int, struct sockaddr *, int *)); 27546577Sdonn int bind __P((int, const struct sockaddr *, int)); 27646577Sdonn int connect __P((int, const struct sockaddr *, int)); 27746577Sdonn int getpeername __P((int, struct sockaddr *, int *)); 27846577Sdonn int getsockname __P((int, struct sockaddr *, int *)); 27946577Sdonn int getsockopt __P((int, int, int, void *, int *)); 28046577Sdonn int listen __P((int, int)); 28146577Sdonn int recv __P((int, void *, int, int)); 28246577Sdonn int recvfrom __P((int, void *, int, int, 28346577Sdonn struct sockaddr *, int *)); 28448387Skarels int recvmsg __P((int, struct msghdr *, int)); 28546577Sdonn int send __P((int, const void *, int, int)); 28646972Sbostic int sendto __P((int, const void *, int, int, const struct sockaddr *, int)); 28746577Sdonn int sendmsg __P((int, const struct msghdr *, int)); 28846577Sdonn int setsockopt __P((int, int, int, const void *, int)); 28946577Sdonn int shutdown __P((int, int)); 29046577Sdonn int socket __P((int, int, int)); 29146577Sdonn int socketpair __P((int, int, int, int *)); 29246577Sdonn __END_DECLS 29346577Sdonn 29446577Sdonn #endif /* !KERNEL */ 295