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*59137Smckusick * @(#)socket.h 7.21 (Berkeley) 04/18/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 */ 8859012Ssklower #define pseudo_AF_RTIP 22 /* Help Identify RTIP packets */ 8959012Ssklower #define AF_IPX 23 /* Novell Internet Protocol */ 9059012Ssklower #define AF_SIP 24 /* Simple Internet Protocol */ 9159012Ssklower #define pseudo_AF_PIP 25 /* Help Identify PIP packets */ 924930Swnj 9359012Ssklower #define AF_MAX 26 944930Swnj 954930Swnj /* 9612787Ssam * Structure used by kernel to store most 9712787Ssam * addresses. 984930Swnj */ 994930Swnj struct sockaddr { 10035796Ssklower u_char sa_len; /* total length */ 10135796Ssklower u_char sa_family; /* address family */ 10236353Ssklower char sa_data[14]; /* actually longer; address value */ 10335796Ssklower }; 1044930Swnj 1054930Swnj /* 10612787Ssam * Structure used by kernel to pass protocol 10712787Ssam * information in raw sockets. 1084930Swnj */ 10912787Ssam struct sockproto { 11012787Ssam u_short sp_family; /* address family */ 11112787Ssam u_short sp_protocol; /* protocol */ 11212787Ssam }; 1136620Ssam 11412787Ssam /* 11512787Ssam * Protocol families, same as address families for now. 11612787Ssam */ 11712787Ssam #define PF_UNSPEC AF_UNSPEC 11812787Ssam #define PF_UNIX AF_UNIX 11912787Ssam #define PF_INET AF_INET 12012787Ssam #define PF_IMPLINK AF_IMPLINK 12112787Ssam #define PF_PUP AF_PUP 12212787Ssam #define PF_CHAOS AF_CHAOS 12312787Ssam #define PF_NS AF_NS 12436353Ssklower #define PF_ISO AF_ISO 12540764Skarels #define PF_OSI AF_ISO 12612787Ssam #define PF_ECMA AF_ECMA 12712787Ssam #define PF_DATAKIT AF_DATAKIT 12812787Ssam #define PF_CCITT AF_CCITT 12912787Ssam #define PF_SNA AF_SNA 13023751Skarels #define PF_DECnet AF_DECnet 13123751Skarels #define PF_DLI AF_DLI 13223751Skarels #define PF_LAT AF_LAT 13323751Skarels #define PF_HYLINK AF_HYLINK 13428881Skarels #define PF_APPLETALK AF_APPLETALK 13536353Ssklower #define PF_ROUTE AF_ROUTE 13640764Skarels #define PF_LINK AF_LINK 13740764Skarels #define PF_XTP pseudo_AF_XTP /* really just proto family, no AF */ 13851008Skarels #define PF_COIP AF_COIP 13953622Ssklower #define PF_CNT AF_CNT 14059012Ssklower #define PF_SIP AF_SIP 14159012Ssklower #define PF_IPX AF_IPX /* same format as AF_NS */ 14259012Ssklower #define PF_RTIP pseudo_AF_FTIP /* same format as AF_INET */ 14359012Ssklower #define PF_PIP pseudo_AF_PIP 1448274Sroot 14523751Skarels #define PF_MAX AF_MAX 14612787Ssam 14712787Ssam /* 14857838Smckusick * Definitions for network related sysctl, CTL_NET. 14957838Smckusick * 15057838Smckusick * Second level is protocol family. 15157838Smckusick * Third level is protocol number. 15257838Smckusick * 15357838Smckusick * Further levels are defined by the individual families below. 15457838Smckusick */ 15558896Smckusick #define NET_MAXID AF_MAX 15658896Smckusick 15758896Smckusick #define CTL_NET_NAMES { \ 158*59137Smckusick { 0, 0 }, \ 159*59137Smckusick { "unix", CTLTYPE_NODE }, \ 160*59137Smckusick { "inet", CTLTYPE_NODE }, \ 161*59137Smckusick { "implink", CTLTYPE_NODE }, \ 162*59137Smckusick { "pup", CTLTYPE_NODE }, \ 163*59137Smckusick { "chaos", CTLTYPE_NODE }, \ 164*59137Smckusick { "xerox_ns", CTLTYPE_NODE }, \ 165*59137Smckusick { "iso", CTLTYPE_NODE }, \ 166*59137Smckusick { "emca", CTLTYPE_NODE }, \ 167*59137Smckusick { "datakit", CTLTYPE_NODE }, \ 168*59137Smckusick { "ccitt", CTLTYPE_NODE }, \ 169*59137Smckusick { "ibm_sna", CTLTYPE_NODE }, \ 170*59137Smckusick { "decnet", CTLTYPE_NODE }, \ 171*59137Smckusick { "dec_dli", CTLTYPE_NODE }, \ 172*59137Smckusick { "lat", CTLTYPE_NODE }, \ 173*59137Smckusick { "hylink", CTLTYPE_NODE }, \ 174*59137Smckusick { "appletalk", CTLTYPE_NODE }, \ 175*59137Smckusick { "route", CTLTYPE_NODE }, \ 176*59137Smckusick { "link_layer", CTLTYPE_NODE }, \ 177*59137Smckusick { "xtp", CTLTYPE_NODE }, \ 178*59137Smckusick { "coip", CTLTYPE_NODE }, \ 179*59137Smckusick { "cnt", CTLTYPE_NODE }, \ 180*59137Smckusick { "rtip", CTLTYPE_NODE }, \ 181*59137Smckusick { "ipx", CTLTYPE_NODE }, \ 182*59137Smckusick { "sip", CTLTYPE_NODE }, \ 183*59137Smckusick { "pip", CTLTYPE_NODE }, \ 18458896Smckusick } 18558896Smckusick 18657838Smckusick /* 18757838Smckusick * PF_ROUTE - Routing table 18857838Smckusick * 18957838Smckusick * Three additional levels are defined: 19057838Smckusick * Fourth: address family, 0 is wildcard 19157838Smckusick * Fifth: type of info, defined below 19257838Smckusick * Sixth: flag(s) to mask with for NET_RT_FLAGS 19357838Smckusick */ 19457838Smckusick #define NET_RT_DUMP 1 /* dump; may limit to a.f. */ 19557838Smckusick #define NET_RT_FLAGS 2 /* by flags, e.g. RESOLVING */ 19657838Smckusick #define NET_RT_IFLIST 3 /* survey interface list */ 197*59137Smckusick #define NET_RT_MAXID 4 19857838Smckusick 19957838Smckusick #define CTL_NET_RT_NAMES { \ 200*59137Smckusick { 0, 0 }, \ 201*59137Smckusick { "dump", CTLTYPE_STRUCT }, \ 202*59137Smckusick { "flags", CTLTYPE_STRUCT }, \ 203*59137Smckusick { "iflist", CTLTYPE_STRUCT }, \ 20457838Smckusick } 20557838Smckusick 20657838Smckusick /* 20712787Ssam * Maximum queue length specifiable by listen. 20812787Ssam */ 20912787Ssam #define SOMAXCONN 5 21012787Ssam 21112787Ssam /* 21212787Ssam * Message header for recvmsg and sendmsg calls. 21335796Ssklower * Used value-result for recvmsg, value only for sendmsg. 21412787Ssam */ 21512787Ssam struct msghdr { 21612787Ssam caddr_t msg_name; /* optional address */ 21742464Ssklower u_int msg_namelen; /* size of address */ 21812787Ssam struct iovec *msg_iov; /* scatter/gather array */ 21942464Ssklower u_int msg_iovlen; /* # elements in msg_iov */ 22040764Skarels caddr_t msg_control; /* ancillary data, see below */ 22142464Ssklower u_int msg_controllen; /* ancillary data buffer len */ 22235796Ssklower int msg_flags; /* flags on received message */ 22312787Ssam }; 22412787Ssam 22512787Ssam #define MSG_OOB 0x1 /* process out-of-band data */ 22612787Ssam #define MSG_PEEK 0x2 /* peek at incoming message */ 22712787Ssam #define MSG_DONTROUTE 0x4 /* send without using routing tables */ 22835796Ssklower #define MSG_EOR 0x8 /* data completes record */ 22935796Ssklower #define MSG_TRUNC 0x10 /* data discarded before delivery */ 23035796Ssklower #define MSG_CTRUNC 0x20 /* control data lost before delivery */ 23140764Skarels #define MSG_WAITALL 0x40 /* wait for full request or error */ 23251753Smckusick #define MSG_DONTWAIT 0x80 /* this message should be nonblocking */ 23312787Ssam 23435796Ssklower /* 23540764Skarels * Header for ancillary data objects in msg_control buffer. 23640764Skarels * Used for additional information with/about a datagram 23740764Skarels * not expressible by flags. The format is a sequence 23840764Skarels * of message elements headed by cmsghdr structures. 23940764Skarels */ 24040764Skarels struct cmsghdr { 24140764Skarels u_int cmsg_len; /* data byte count, including hdr */ 24242464Ssklower int cmsg_level; /* originating protocol */ 24342464Ssklower int cmsg_type; /* protocol-specific type */ 24440764Skarels /* followed by u_char cmsg_data[]; */ 24540764Skarels }; 24640764Skarels 24740764Skarels /* given pointer to struct adatahdr, return pointer to data */ 24840764Skarels #define CMSG_DATA(cmsg) ((u_char *)((cmsg) + 1)) 24940764Skarels 25040764Skarels /* given pointer to struct adatahdr, return pointer to next adatahdr */ 25140764Skarels #define CMSG_NXTHDR(mhdr, cmsg) \ 25240764Skarels (((caddr_t)(cmsg) + (cmsg)->cmsg_len + sizeof(struct cmsghdr) > \ 25340764Skarels (mhdr)->msg_control + (mhdr)->msg_controllen) ? \ 25440764Skarels (struct cmsghdr *)NULL : \ 25540764Skarels (struct cmsghdr *)((caddr_t)(cmsg) + ALIGN((cmsg)->cmsg_len))) 25640764Skarels 25740764Skarels #define CMSG_FIRSTHDR(mhdr) ((struct cmsghdr *)(mhdr)->msg_control) 25840764Skarels 25940764Skarels /* "Socket"-level control message types: */ 26040764Skarels #define SCM_RIGHTS 0x01 /* access rights (array of int) */ 26140764Skarels 26240764Skarels /* 26340764Skarels * 4.3 compat sockaddr, move to compat file later 26440764Skarels */ 26540764Skarels struct osockaddr { 26640764Skarels u_short sa_family; /* address family */ 26740764Skarels char sa_data[14]; /* up to 14 bytes of direct address */ 26840764Skarels }; 26940764Skarels 27040764Skarels /* 27135796Ssklower * 4.3-compat message header (move to compat file later). 27235796Ssklower */ 27335796Ssklower struct omsghdr { 27435796Ssklower caddr_t msg_name; /* optional address */ 27535796Ssklower int msg_namelen; /* size of address */ 27635796Ssklower struct iovec *msg_iov; /* scatter/gather array */ 27735796Ssklower int msg_iovlen; /* # elements in msg_iov */ 27835796Ssklower caddr_t msg_accrights; /* access rights sent/received */ 27935796Ssklower int msg_accrightslen; 28035796Ssklower }; 28146577Sdonn 28246577Sdonn #ifndef KERNEL 28346577Sdonn 28446577Sdonn #include <sys/cdefs.h> 28546577Sdonn 28646577Sdonn __BEGIN_DECLS 28746577Sdonn int accept __P((int, struct sockaddr *, int *)); 28846577Sdonn int bind __P((int, const struct sockaddr *, int)); 28946577Sdonn int connect __P((int, const struct sockaddr *, int)); 29046577Sdonn int getpeername __P((int, struct sockaddr *, int *)); 29146577Sdonn int getsockname __P((int, struct sockaddr *, int *)); 29246577Sdonn int getsockopt __P((int, int, int, void *, int *)); 29346577Sdonn int listen __P((int, int)); 29446577Sdonn int recv __P((int, void *, int, int)); 29546577Sdonn int recvfrom __P((int, void *, int, int, 29646577Sdonn struct sockaddr *, int *)); 29748387Skarels int recvmsg __P((int, struct msghdr *, int)); 29846577Sdonn int send __P((int, const void *, int, int)); 29946972Sbostic int sendto __P((int, const void *, int, int, const struct sockaddr *, int)); 30046577Sdonn int sendmsg __P((int, const struct msghdr *, int)); 30146577Sdonn int setsockopt __P((int, int, int, const void *, int)); 30246577Sdonn int shutdown __P((int, int)); 30346577Sdonn int socket __P((int, int, int)); 30446577Sdonn int socketpair __P((int, int, int, int *)); 30546577Sdonn __END_DECLS 30646577Sdonn 30746577Sdonn #endif /* !KERNEL */ 308