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*57838Smckusick * @(#)socket.h 7.18 (Berkeley) 02/04/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 /* 140*57838Smckusick * Definitions for network related sysctl, CTL_NET. 141*57838Smckusick * 142*57838Smckusick * Second level is protocol family. 143*57838Smckusick * Third level is protocol number. 144*57838Smckusick * 145*57838Smckusick * Further levels are defined by the individual families below. 146*57838Smckusick */ 147*57838Smckusick /* 148*57838Smckusick * PF_ROUTE - Routing table 149*57838Smckusick * 150*57838Smckusick * Three additional levels are defined: 151*57838Smckusick * Fourth: address family, 0 is wildcard 152*57838Smckusick * Fifth: type of info, defined below 153*57838Smckusick * Sixth: flag(s) to mask with for NET_RT_FLAGS 154*57838Smckusick */ 155*57838Smckusick #define NET_RT_DUMP 1 /* dump; may limit to a.f. */ 156*57838Smckusick #define NET_RT_FLAGS 2 /* by flags, e.g. RESOLVING */ 157*57838Smckusick #define NET_RT_IFLIST 3 /* survey interface list */ 158*57838Smckusick 159*57838Smckusick #define CTL_NET_RT_NAMES { \ 160*57838Smckusick "unspec", \ 161*57838Smckusick "dump", \ 162*57838Smckusick "flags", \ 163*57838Smckusick "iflist", \ 164*57838Smckusick } 165*57838Smckusick 166*57838Smckusick /* 16712787Ssam * Maximum queue length specifiable by listen. 16812787Ssam */ 16912787Ssam #define SOMAXCONN 5 17012787Ssam 17112787Ssam /* 17212787Ssam * Message header for recvmsg and sendmsg calls. 17335796Ssklower * Used value-result for recvmsg, value only for sendmsg. 17412787Ssam */ 17512787Ssam struct msghdr { 17612787Ssam caddr_t msg_name; /* optional address */ 17742464Ssklower u_int msg_namelen; /* size of address */ 17812787Ssam struct iovec *msg_iov; /* scatter/gather array */ 17942464Ssklower u_int msg_iovlen; /* # elements in msg_iov */ 18040764Skarels caddr_t msg_control; /* ancillary data, see below */ 18142464Ssklower u_int msg_controllen; /* ancillary data buffer len */ 18235796Ssklower int msg_flags; /* flags on received message */ 18312787Ssam }; 18412787Ssam 18512787Ssam #define MSG_OOB 0x1 /* process out-of-band data */ 18612787Ssam #define MSG_PEEK 0x2 /* peek at incoming message */ 18712787Ssam #define MSG_DONTROUTE 0x4 /* send without using routing tables */ 18835796Ssklower #define MSG_EOR 0x8 /* data completes record */ 18935796Ssklower #define MSG_TRUNC 0x10 /* data discarded before delivery */ 19035796Ssklower #define MSG_CTRUNC 0x20 /* control data lost before delivery */ 19140764Skarels #define MSG_WAITALL 0x40 /* wait for full request or error */ 19251753Smckusick #define MSG_DONTWAIT 0x80 /* this message should be nonblocking */ 19312787Ssam 19435796Ssklower /* 19540764Skarels * Header for ancillary data objects in msg_control buffer. 19640764Skarels * Used for additional information with/about a datagram 19740764Skarels * not expressible by flags. The format is a sequence 19840764Skarels * of message elements headed by cmsghdr structures. 19940764Skarels */ 20040764Skarels struct cmsghdr { 20140764Skarels u_int cmsg_len; /* data byte count, including hdr */ 20242464Ssklower int cmsg_level; /* originating protocol */ 20342464Ssklower int cmsg_type; /* protocol-specific type */ 20440764Skarels /* followed by u_char cmsg_data[]; */ 20540764Skarels }; 20640764Skarels 20740764Skarels /* given pointer to struct adatahdr, return pointer to data */ 20840764Skarels #define CMSG_DATA(cmsg) ((u_char *)((cmsg) + 1)) 20940764Skarels 21040764Skarels /* given pointer to struct adatahdr, return pointer to next adatahdr */ 21140764Skarels #define CMSG_NXTHDR(mhdr, cmsg) \ 21240764Skarels (((caddr_t)(cmsg) + (cmsg)->cmsg_len + sizeof(struct cmsghdr) > \ 21340764Skarels (mhdr)->msg_control + (mhdr)->msg_controllen) ? \ 21440764Skarels (struct cmsghdr *)NULL : \ 21540764Skarels (struct cmsghdr *)((caddr_t)(cmsg) + ALIGN((cmsg)->cmsg_len))) 21640764Skarels 21740764Skarels #define CMSG_FIRSTHDR(mhdr) ((struct cmsghdr *)(mhdr)->msg_control) 21840764Skarels 21940764Skarels /* "Socket"-level control message types: */ 22040764Skarels #define SCM_RIGHTS 0x01 /* access rights (array of int) */ 22140764Skarels 22240764Skarels /* 22340764Skarels * 4.3 compat sockaddr, move to compat file later 22440764Skarels */ 22540764Skarels struct osockaddr { 22640764Skarels u_short sa_family; /* address family */ 22740764Skarels char sa_data[14]; /* up to 14 bytes of direct address */ 22840764Skarels }; 22940764Skarels 23040764Skarels /* 23135796Ssklower * 4.3-compat message header (move to compat file later). 23235796Ssklower */ 23335796Ssklower struct omsghdr { 23435796Ssklower caddr_t msg_name; /* optional address */ 23535796Ssklower int msg_namelen; /* size of address */ 23635796Ssklower struct iovec *msg_iov; /* scatter/gather array */ 23735796Ssklower int msg_iovlen; /* # elements in msg_iov */ 23835796Ssklower caddr_t msg_accrights; /* access rights sent/received */ 23935796Ssklower int msg_accrightslen; 24035796Ssklower }; 24146577Sdonn 24246577Sdonn #ifndef KERNEL 24346577Sdonn 24446577Sdonn #include <sys/cdefs.h> 24546577Sdonn 24646577Sdonn __BEGIN_DECLS 24746577Sdonn int accept __P((int, struct sockaddr *, int *)); 24846577Sdonn int bind __P((int, const struct sockaddr *, int)); 24946577Sdonn int connect __P((int, const struct sockaddr *, int)); 25046577Sdonn int getpeername __P((int, struct sockaddr *, int *)); 25146577Sdonn int getsockname __P((int, struct sockaddr *, int *)); 25246577Sdonn int getsockopt __P((int, int, int, void *, int *)); 25346577Sdonn int listen __P((int, int)); 25446577Sdonn int recv __P((int, void *, int, int)); 25546577Sdonn int recvfrom __P((int, void *, int, int, 25646577Sdonn struct sockaddr *, int *)); 25748387Skarels int recvmsg __P((int, struct msghdr *, int)); 25846577Sdonn int send __P((int, const void *, int, int)); 25946972Sbostic int sendto __P((int, const void *, int, int, const struct sockaddr *, int)); 26046577Sdonn int sendmsg __P((int, const struct msghdr *, int)); 26146577Sdonn int setsockopt __P((int, int, int, const void *, int)); 26246577Sdonn int shutdown __P((int, int)); 26346577Sdonn int socket __P((int, int, int)); 26446577Sdonn int socketpair __P((int, int, int, int *)); 26546577Sdonn __END_DECLS 26646577Sdonn 26746577Sdonn #endif /* !KERNEL */ 268