123438Smckusick /* 261064Sbostic * Copyright (c) 1993, 1982198519861988 361064Sbostic * The Regents of the University of California. All rights reserved. 423438Smckusick * 544523Sbostic * %sccs.include.redist.c% 633186Sbostic * 7*65420Sbostic * @(#)socket.h 8.2 (Berkeley) 01/04/94 823438Smckusick */ 94658Swnj 10*65420Sbostic #ifndef _SYS_SOCKET_H_ 11*65420Sbostic #define _SYS_SOCKET_H_ 1259439Smckusick 134658Swnj /* 1412787Ssam * Definitions related to sockets: types, address families, options. 154658Swnj */ 164892Swnj 174892Swnj /* 1812787Ssam * Types 194892Swnj */ 204930Swnj #define SOCK_STREAM 1 /* stream socket */ 214930Swnj #define SOCK_DGRAM 2 /* datagram socket */ 224930Swnj #define SOCK_RAW 3 /* raw-protocol interface */ 234930Swnj #define SOCK_RDM 4 /* reliably-delivered message */ 2412787Ssam #define SOCK_SEQPACKET 5 /* sequenced packet stream */ 254658Swnj 264812Swnj /* 274812Swnj * Option flags per-socket. 284812Swnj */ 2927192Skarels #define SO_DEBUG 0x0001 /* turn on debugging info recording */ 3027192Skarels #define SO_ACCEPTCONN 0x0002 /* socket has had listen() */ 3127192Skarels #define SO_REUSEADDR 0x0004 /* allow local address reuse */ 3227192Skarels #define SO_KEEPALIVE 0x0008 /* keep connections alive */ 3327192Skarels #define SO_DONTROUTE 0x0010 /* just use interface addresses */ 3427192Skarels #define SO_BROADCAST 0x0020 /* permit sending of broadcast msgs */ 3527192Skarels #define SO_USELOOPBACK 0x0040 /* bypass hardware when possible */ 3627192Skarels #define SO_LINGER 0x0080 /* linger on close if data present */ 3727192Skarels #define SO_OOBINLINE 0x0100 /* leave received OOB data in line */ 3855346Ssklower #define SO_REUSEPORT 0x0200 /* allow local address & port reuse */ 394930Swnj 404930Swnj /* 4117552Skarels * Additional options, not kept in so_options. 4217552Skarels */ 4317552Skarels #define SO_SNDBUF 0x1001 /* send buffer size */ 4417552Skarels #define SO_RCVBUF 0x1002 /* receive buffer size */ 4517552Skarels #define SO_SNDLOWAT 0x1003 /* send low-water mark */ 4617552Skarels #define SO_RCVLOWAT 0x1004 /* receive low-water mark */ 4717552Skarels #define SO_SNDTIMEO 0x1005 /* send timeout */ 4817552Skarels #define SO_RCVTIMEO 0x1006 /* receive timeout */ 4924825Skarels #define SO_ERROR 0x1007 /* get error status and clear */ 5025503Skarels #define SO_TYPE 0x1008 /* get socket type */ 5117552Skarels 5217552Skarels /* 5317160Ssam * Structure used for manipulating linger option. 5417052Skarels */ 5517160Ssam struct linger { 5617160Ssam int l_onoff; /* option on/off */ 5717160Ssam int l_linger; /* linger time */ 5817160Ssam }; 5917052Skarels 6017052Skarels /* 6117160Ssam * Level number for (get/set)sockopt() to apply to socket itself. 6217160Ssam */ 6317160Ssam #define SOL_SOCKET 0xffff /* options for socket level */ 6417160Ssam 6517160Ssam /* 6612787Ssam * Address families. 674930Swnj */ 6812787Ssam #define AF_UNSPEC 0 /* unspecified */ 6912787Ssam #define AF_UNIX 1 /* local to host (pipes, portals) */ 7012787Ssam #define AF_INET 2 /* internetwork: UDP, TCP, etc. */ 7112787Ssam #define AF_IMPLINK 3 /* arpanet imp addresses */ 7212787Ssam #define AF_PUP 4 /* pup protocols: e.g. BSP */ 7312787Ssam #define AF_CHAOS 5 /* mit CHAOS protocols */ 7412787Ssam #define AF_NS 6 /* XEROX NS protocols */ 7536353Ssklower #define AF_ISO 7 /* ISO protocols */ 7640764Skarels #define AF_OSI AF_ISO 7712787Ssam #define AF_ECMA 8 /* european computer manufacturers */ 7812787Ssam #define AF_DATAKIT 9 /* datakit protocols */ 7912787Ssam #define AF_CCITT 10 /* CCITT protocols, X.25 etc */ 8012787Ssam #define AF_SNA 11 /* IBM SNA */ 8123751Skarels #define AF_DECnet 12 /* DECnet */ 8240764Skarels #define AF_DLI 13 /* DEC Direct data link interface */ 8323751Skarels #define AF_LAT 14 /* LAT */ 8423751Skarels #define AF_HYLINK 15 /* NSC Hyperchannel */ 8528881Skarels #define AF_APPLETALK 16 /* Apple Talk */ 8636353Ssklower #define AF_ROUTE 17 /* Internal Routing Protocol */ 8740764Skarels #define AF_LINK 18 /* Link layer interface */ 8840764Skarels #define pseudo_AF_XTP 19 /* eXpress Transfer Protocol (no AF) */ 8951008Skarels #define AF_COIP 20 /* connection-oriented IP, aka ST II */ 9053622Ssklower #define AF_CNT 21 /* Computer Network Technology */ 9159012Ssklower #define pseudo_AF_RTIP 22 /* Help Identify RTIP packets */ 9259012Ssklower #define AF_IPX 23 /* Novell Internet Protocol */ 9359012Ssklower #define AF_SIP 24 /* Simple Internet Protocol */ 9459012Ssklower #define pseudo_AF_PIP 25 /* Help Identify PIP packets */ 954930Swnj 9659012Ssklower #define AF_MAX 26 974930Swnj 984930Swnj /* 9912787Ssam * Structure used by kernel to store most 10012787Ssam * addresses. 1014930Swnj */ 1024930Swnj struct sockaddr { 10335796Ssklower u_char sa_len; /* total length */ 10435796Ssklower u_char sa_family; /* address family */ 10536353Ssklower char sa_data[14]; /* actually longer; address value */ 10635796Ssklower }; 1074930Swnj 1084930Swnj /* 10912787Ssam * Structure used by kernel to pass protocol 11012787Ssam * information in raw sockets. 1114930Swnj */ 11212787Ssam struct sockproto { 11312787Ssam u_short sp_family; /* address family */ 11412787Ssam u_short sp_protocol; /* protocol */ 11512787Ssam }; 1166620Ssam 11712787Ssam /* 11812787Ssam * Protocol families, same as address families for now. 11912787Ssam */ 12012787Ssam #define PF_UNSPEC AF_UNSPEC 12112787Ssam #define PF_UNIX AF_UNIX 12212787Ssam #define PF_INET AF_INET 12312787Ssam #define PF_IMPLINK AF_IMPLINK 12412787Ssam #define PF_PUP AF_PUP 12512787Ssam #define PF_CHAOS AF_CHAOS 12612787Ssam #define PF_NS AF_NS 12736353Ssklower #define PF_ISO AF_ISO 12840764Skarels #define PF_OSI AF_ISO 12912787Ssam #define PF_ECMA AF_ECMA 13012787Ssam #define PF_DATAKIT AF_DATAKIT 13112787Ssam #define PF_CCITT AF_CCITT 13212787Ssam #define PF_SNA AF_SNA 13323751Skarels #define PF_DECnet AF_DECnet 13423751Skarels #define PF_DLI AF_DLI 13523751Skarels #define PF_LAT AF_LAT 13623751Skarels #define PF_HYLINK AF_HYLINK 13728881Skarels #define PF_APPLETALK AF_APPLETALK 13836353Ssklower #define PF_ROUTE AF_ROUTE 13940764Skarels #define PF_LINK AF_LINK 14040764Skarels #define PF_XTP pseudo_AF_XTP /* really just proto family, no AF */ 14151008Skarels #define PF_COIP AF_COIP 14253622Ssklower #define PF_CNT AF_CNT 14359012Ssklower #define PF_SIP AF_SIP 14459012Ssklower #define PF_IPX AF_IPX /* same format as AF_NS */ 14559012Ssklower #define PF_RTIP pseudo_AF_FTIP /* same format as AF_INET */ 14659012Ssklower #define PF_PIP pseudo_AF_PIP 1478274Sroot 14823751Skarels #define PF_MAX AF_MAX 14912787Ssam 15012787Ssam /* 15157838Smckusick * Definitions for network related sysctl, CTL_NET. 15257838Smckusick * 15357838Smckusick * Second level is protocol family. 15457838Smckusick * Third level is protocol number. 15557838Smckusick * 15657838Smckusick * Further levels are defined by the individual families below. 15757838Smckusick */ 15858896Smckusick #define NET_MAXID AF_MAX 15958896Smckusick 16058896Smckusick #define CTL_NET_NAMES { \ 16159137Smckusick { 0, 0 }, \ 16259137Smckusick { "unix", CTLTYPE_NODE }, \ 16359137Smckusick { "inet", CTLTYPE_NODE }, \ 16459137Smckusick { "implink", CTLTYPE_NODE }, \ 16559137Smckusick { "pup", CTLTYPE_NODE }, \ 16659137Smckusick { "chaos", CTLTYPE_NODE }, \ 16759137Smckusick { "xerox_ns", CTLTYPE_NODE }, \ 16859137Smckusick { "iso", CTLTYPE_NODE }, \ 16959137Smckusick { "emca", CTLTYPE_NODE }, \ 17059137Smckusick { "datakit", CTLTYPE_NODE }, \ 17159137Smckusick { "ccitt", CTLTYPE_NODE }, \ 17259137Smckusick { "ibm_sna", CTLTYPE_NODE }, \ 17359137Smckusick { "decnet", CTLTYPE_NODE }, \ 17459137Smckusick { "dec_dli", CTLTYPE_NODE }, \ 17559137Smckusick { "lat", CTLTYPE_NODE }, \ 17659137Smckusick { "hylink", CTLTYPE_NODE }, \ 17759137Smckusick { "appletalk", CTLTYPE_NODE }, \ 17859137Smckusick { "route", CTLTYPE_NODE }, \ 17959137Smckusick { "link_layer", CTLTYPE_NODE }, \ 18059137Smckusick { "xtp", CTLTYPE_NODE }, \ 18159137Smckusick { "coip", CTLTYPE_NODE }, \ 18259137Smckusick { "cnt", CTLTYPE_NODE }, \ 18359137Smckusick { "rtip", CTLTYPE_NODE }, \ 18459137Smckusick { "ipx", CTLTYPE_NODE }, \ 18559137Smckusick { "sip", CTLTYPE_NODE }, \ 18659137Smckusick { "pip", CTLTYPE_NODE }, \ 18758896Smckusick } 18858896Smckusick 18957838Smckusick /* 19057838Smckusick * PF_ROUTE - Routing table 19157838Smckusick * 19257838Smckusick * Three additional levels are defined: 19357838Smckusick * Fourth: address family, 0 is wildcard 19457838Smckusick * Fifth: type of info, defined below 19557838Smckusick * Sixth: flag(s) to mask with for NET_RT_FLAGS 19657838Smckusick */ 19757838Smckusick #define NET_RT_DUMP 1 /* dump; may limit to a.f. */ 19857838Smckusick #define NET_RT_FLAGS 2 /* by flags, e.g. RESOLVING */ 19957838Smckusick #define NET_RT_IFLIST 3 /* survey interface list */ 20059137Smckusick #define NET_RT_MAXID 4 20157838Smckusick 20257838Smckusick #define CTL_NET_RT_NAMES { \ 20359137Smckusick { 0, 0 }, \ 20459137Smckusick { "dump", CTLTYPE_STRUCT }, \ 20559137Smckusick { "flags", CTLTYPE_STRUCT }, \ 20659137Smckusick { "iflist", CTLTYPE_STRUCT }, \ 20757838Smckusick } 20857838Smckusick 20957838Smckusick /* 21012787Ssam * Maximum queue length specifiable by listen. 21112787Ssam */ 21212787Ssam #define SOMAXCONN 5 21312787Ssam 21412787Ssam /* 21512787Ssam * Message header for recvmsg and sendmsg calls. 21635796Ssklower * Used value-result for recvmsg, value only for sendmsg. 21712787Ssam */ 21812787Ssam struct msghdr { 21912787Ssam caddr_t msg_name; /* optional address */ 22042464Ssklower u_int msg_namelen; /* size of address */ 22112787Ssam struct iovec *msg_iov; /* scatter/gather array */ 22242464Ssklower u_int msg_iovlen; /* # elements in msg_iov */ 22340764Skarels caddr_t msg_control; /* ancillary data, see below */ 22442464Ssklower u_int msg_controllen; /* ancillary data buffer len */ 22535796Ssklower int msg_flags; /* flags on received message */ 22612787Ssam }; 22712787Ssam 22812787Ssam #define MSG_OOB 0x1 /* process out-of-band data */ 22912787Ssam #define MSG_PEEK 0x2 /* peek at incoming message */ 23012787Ssam #define MSG_DONTROUTE 0x4 /* send without using routing tables */ 23135796Ssklower #define MSG_EOR 0x8 /* data completes record */ 23235796Ssklower #define MSG_TRUNC 0x10 /* data discarded before delivery */ 23335796Ssklower #define MSG_CTRUNC 0x20 /* control data lost before delivery */ 23440764Skarels #define MSG_WAITALL 0x40 /* wait for full request or error */ 23551753Smckusick #define MSG_DONTWAIT 0x80 /* this message should be nonblocking */ 23612787Ssam 23735796Ssklower /* 23840764Skarels * Header for ancillary data objects in msg_control buffer. 23940764Skarels * Used for additional information with/about a datagram 24040764Skarels * not expressible by flags. The format is a sequence 24140764Skarels * of message elements headed by cmsghdr structures. 24240764Skarels */ 24340764Skarels struct cmsghdr { 24440764Skarels u_int cmsg_len; /* data byte count, including hdr */ 24542464Ssklower int cmsg_level; /* originating protocol */ 24642464Ssklower int cmsg_type; /* protocol-specific type */ 24740764Skarels /* followed by u_char cmsg_data[]; */ 24840764Skarels }; 24940764Skarels 25060017Sandrew /* given pointer to struct cmsghdr, return pointer to data */ 25140764Skarels #define CMSG_DATA(cmsg) ((u_char *)((cmsg) + 1)) 25240764Skarels 25360017Sandrew /* given pointer to struct cmsghdr, return pointer to next cmsghdr */ 25440764Skarels #define CMSG_NXTHDR(mhdr, cmsg) \ 25540764Skarels (((caddr_t)(cmsg) + (cmsg)->cmsg_len + sizeof(struct cmsghdr) > \ 25640764Skarels (mhdr)->msg_control + (mhdr)->msg_controllen) ? \ 25740764Skarels (struct cmsghdr *)NULL : \ 25840764Skarels (struct cmsghdr *)((caddr_t)(cmsg) + ALIGN((cmsg)->cmsg_len))) 25940764Skarels 26040764Skarels #define CMSG_FIRSTHDR(mhdr) ((struct cmsghdr *)(mhdr)->msg_control) 26140764Skarels 26240764Skarels /* "Socket"-level control message types: */ 26340764Skarels #define SCM_RIGHTS 0x01 /* access rights (array of int) */ 26440764Skarels 26540764Skarels /* 26640764Skarels * 4.3 compat sockaddr, move to compat file later 26740764Skarels */ 26840764Skarels struct osockaddr { 26940764Skarels u_short sa_family; /* address family */ 27040764Skarels char sa_data[14]; /* up to 14 bytes of direct address */ 27140764Skarels }; 27240764Skarels 27340764Skarels /* 27435796Ssklower * 4.3-compat message header (move to compat file later). 27535796Ssklower */ 27635796Ssklower struct omsghdr { 27735796Ssklower caddr_t msg_name; /* optional address */ 27835796Ssklower int msg_namelen; /* size of address */ 27935796Ssklower struct iovec *msg_iov; /* scatter/gather array */ 28035796Ssklower int msg_iovlen; /* # elements in msg_iov */ 28135796Ssklower caddr_t msg_accrights; /* access rights sent/received */ 28235796Ssklower int msg_accrightslen; 28335796Ssklower }; 28446577Sdonn 28546577Sdonn #ifndef KERNEL 28646577Sdonn 28746577Sdonn #include <sys/cdefs.h> 28846577Sdonn 28946577Sdonn __BEGIN_DECLS 29046577Sdonn int accept __P((int, struct sockaddr *, int *)); 29146577Sdonn int bind __P((int, const struct sockaddr *, int)); 29246577Sdonn int connect __P((int, const struct sockaddr *, int)); 29346577Sdonn int getpeername __P((int, struct sockaddr *, int *)); 29446577Sdonn int getsockname __P((int, struct sockaddr *, int *)); 29546577Sdonn int getsockopt __P((int, int, int, void *, int *)); 29646577Sdonn int listen __P((int, int)); 29746577Sdonn int recv __P((int, void *, int, int)); 29846577Sdonn int recvfrom __P((int, void *, int, int, 29946577Sdonn struct sockaddr *, int *)); 30048387Skarels int recvmsg __P((int, struct msghdr *, int)); 30146577Sdonn int send __P((int, const void *, int, int)); 30246972Sbostic int sendto __P((int, const void *, int, int, const struct sockaddr *, int)); 30346577Sdonn int sendmsg __P((int, const struct msghdr *, int)); 30446577Sdonn int setsockopt __P((int, int, int, const void *, int)); 30546577Sdonn int shutdown __P((int, int)); 30646577Sdonn int socket __P((int, int, int)); 30746577Sdonn int socketpair __P((int, int, int, int *)); 30846577Sdonn __END_DECLS 30946577Sdonn 31046577Sdonn #endif /* !KERNEL */ 311*65420Sbostic #endif /* !_SYS_SOCKET_H_ */ 312