1df8bae1dSRodney W. Grimes /* 2df8bae1dSRodney W. Grimes * Copyright (c) 1982, 1986, 1990, 1993 3df8bae1dSRodney W. Grimes * The Regents of the University of California. All rights reserved. 4df8bae1dSRodney W. Grimes * 5df8bae1dSRodney W. Grimes * Redistribution and use in source and binary forms, with or without 6df8bae1dSRodney W. Grimes * modification, are permitted provided that the following conditions 7df8bae1dSRodney W. Grimes * are met: 8df8bae1dSRodney W. Grimes * 1. Redistributions of source code must retain the above copyright 9df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer. 10df8bae1dSRodney W. Grimes * 2. Redistributions in binary form must reproduce the above copyright 11df8bae1dSRodney W. Grimes * notice, this list of conditions and the following disclaimer in the 12df8bae1dSRodney W. Grimes * documentation and/or other materials provided with the distribution. 13df8bae1dSRodney W. Grimes * 3. All advertising materials mentioning features or use of this software 14df8bae1dSRodney W. Grimes * must display the following acknowledgement: 15df8bae1dSRodney W. Grimes * This product includes software developed by the University of 16df8bae1dSRodney W. Grimes * California, Berkeley and its contributors. 17df8bae1dSRodney W. Grimes * 4. Neither the name of the University nor the names of its contributors 18df8bae1dSRodney W. Grimes * may be used to endorse or promote products derived from this software 19df8bae1dSRodney W. Grimes * without specific prior written permission. 20df8bae1dSRodney W. Grimes * 21df8bae1dSRodney W. Grimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 22df8bae1dSRodney W. Grimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23df8bae1dSRodney W. Grimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24df8bae1dSRodney W. Grimes * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 25df8bae1dSRodney W. Grimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26df8bae1dSRodney W. Grimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27df8bae1dSRodney W. Grimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28df8bae1dSRodney W. Grimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29df8bae1dSRodney W. Grimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30df8bae1dSRodney W. Grimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31df8bae1dSRodney W. Grimes * SUCH DAMAGE. 32df8bae1dSRodney W. Grimes * 33df8bae1dSRodney W. Grimes * @(#)in.h 8.3 (Berkeley) 1/3/94 34c3aac50fSPeter Wemm * $FreeBSD$ 35df8bae1dSRodney W. Grimes */ 36df8bae1dSRodney W. Grimes 37707f139eSPaul Richards #ifndef _NETINET_IN_H_ 38707f139eSPaul Richards #define _NETINET_IN_H_ 39707f139eSPaul Richards 4058631bbeSMike Barcroft #include <sys/cdefs.h> 418822d3fbSMike Barcroft #include <sys/_types.h> 4258631bbeSMike Barcroft #include <machine/endian.h> 438822d3fbSMike Barcroft 4458631bbeSMike Barcroft /* Protocols common to RFC 1700, POSIX, and X/Open. */ 4558631bbeSMike Barcroft #define IPPROTO_IP 0 /* dummy for IP */ 4658631bbeSMike Barcroft #define IPPROTO_ICMP 1 /* control message protocol */ 4758631bbeSMike Barcroft #define IPPROTO_TCP 6 /* tcp */ 4858631bbeSMike Barcroft #define IPPROTO_UDP 17 /* user datagram protocol */ 4958631bbeSMike Barcroft 5058631bbeSMike Barcroft #define INADDR_ANY (u_int32_t)0x00000000 5158631bbeSMike Barcroft #define INADDR_BROADCAST (u_int32_t)0xffffffff /* must be masked */ 5258631bbeSMike Barcroft 5358631bbeSMike Barcroft #ifndef _UINT8_T_DECLARED 5458631bbeSMike Barcroft typedef __uint8_t uint8_t; 5558631bbeSMike Barcroft #define _UINT8_T_DECLARED 5658631bbeSMike Barcroft #endif 5758631bbeSMike Barcroft 5858631bbeSMike Barcroft #ifndef _UINT16_T_DECLARED 5958631bbeSMike Barcroft typedef __uint16_t uint16_t; 6058631bbeSMike Barcroft #define _UINT16_T_DECLARED 6158631bbeSMike Barcroft #endif 6258631bbeSMike Barcroft 6358631bbeSMike Barcroft #ifndef _UINT32_T_DECLARED 6458631bbeSMike Barcroft typedef __uint32_t uint32_t; 6558631bbeSMike Barcroft #define _UINT32_T_DECLARED 6658631bbeSMike Barcroft #endif 6758631bbeSMike Barcroft 6858631bbeSMike Barcroft #ifndef _IN_ADDR_T_DECLARED 6958631bbeSMike Barcroft typedef uint32_t in_addr_t; 7058631bbeSMike Barcroft #define _IN_ADDR_T_DECLARED 7158631bbeSMike Barcroft #endif 7258631bbeSMike Barcroft 7358631bbeSMike Barcroft #ifndef _IN_PORT_T_DECLARED 7458631bbeSMike Barcroft typedef uint16_t in_port_t; 7558631bbeSMike Barcroft #define _IN_PORT_T_DECLARED 7658631bbeSMike Barcroft #endif 7758631bbeSMike Barcroft 78abbd8902SMike Barcroft #ifndef _SA_FAMILY_T_DECLARED 79abbd8902SMike Barcroft typedef __sa_family_t sa_family_t; 80abbd8902SMike Barcroft #define _SA_FAMILY_T_DECLARED 8158631bbeSMike Barcroft #endif 8258631bbeSMike Barcroft 8358631bbeSMike Barcroft /* Internet address (a structure for historical reasons). */ 8458631bbeSMike Barcroft #ifndef _STRUCT_IN_ADDR_DECLARED 8558631bbeSMike Barcroft struct in_addr { 8658631bbeSMike Barcroft in_addr_t s_addr; 8758631bbeSMike Barcroft }; 8858631bbeSMike Barcroft #define _STRUCT_IN_ADDR_DECLARED 8958631bbeSMike Barcroft #endif 9058631bbeSMike Barcroft 9158631bbeSMike Barcroft /* Socket address, internet style. */ 9258631bbeSMike Barcroft struct sockaddr_in { 9358631bbeSMike Barcroft uint8_t sin_len; 9458631bbeSMike Barcroft sa_family_t sin_family; 9558631bbeSMike Barcroft in_port_t sin_port; 9658631bbeSMike Barcroft struct in_addr sin_addr; 9758631bbeSMike Barcroft char sin_zero[8]; 9858631bbeSMike Barcroft }; 9958631bbeSMike Barcroft 10058631bbeSMike Barcroft #ifndef _KERNEL 10158631bbeSMike Barcroft 10258631bbeSMike Barcroft #ifndef _BYTEORDER_PROTOTYPED 10358631bbeSMike Barcroft #define _BYTEORDER_PROTOTYPED 10458631bbeSMike Barcroft __BEGIN_DECLS 10558631bbeSMike Barcroft uint32_t htonl(uint32_t); 10658631bbeSMike Barcroft uint16_t htons(uint16_t); 10758631bbeSMike Barcroft uint32_t ntohl(uint32_t); 10858631bbeSMike Barcroft uint16_t ntohs(uint16_t); 10958631bbeSMike Barcroft __END_DECLS 11058631bbeSMike Barcroft #endif 11158631bbeSMike Barcroft 11258631bbeSMike Barcroft #ifndef _BYTEORDER_FUNC_DEFINED 11358631bbeSMike Barcroft #define _BYTEORDER_FUNC_DEFINED 11458631bbeSMike Barcroft #define htonl(x) __htonl(x) 11558631bbeSMike Barcroft #define htons(x) __htons(x) 11658631bbeSMike Barcroft #define ntohl(x) __ntohl(x) 11758631bbeSMike Barcroft #define ntohs(x) __ntohs(x) 11858631bbeSMike Barcroft #endif 11958631bbeSMike Barcroft 12058631bbeSMike Barcroft #endif /* !_KERNEL */ 12158631bbeSMike Barcroft 12258631bbeSMike Barcroft #if __POSIX_VISIBLE >= 200112 12358631bbeSMike Barcroft #define IPPROTO_RAW 255 /* raw IP packet */ 12458631bbeSMike Barcroft #define INET_ADDRSTRLEN 16 12558631bbeSMike Barcroft #endif 12658631bbeSMike Barcroft 12758631bbeSMike Barcroft #if __BSD_VISIBLE 128df8bae1dSRodney W. Grimes /* 129df8bae1dSRodney W. Grimes * Constants and structures defined by the internet system, 130df8bae1dSRodney W. Grimes * Per RFC 790, September 1981, and numerous additions. 131df8bae1dSRodney W. Grimes */ 132df8bae1dSRodney W. Grimes 133df8bae1dSRodney W. Grimes /* 134cfaa93b2SJulian Elischer * Protocols (RFC 1700) 135df8bae1dSRodney W. Grimes */ 13676429de4SYoshinobu Inoue #define IPPROTO_HOPOPTS 0 /* IP6 hop-by-hop options */ 137df8bae1dSRodney W. Grimes #define IPPROTO_IGMP 2 /* group mgmt protocol */ 138df8bae1dSRodney W. Grimes #define IPPROTO_GGP 3 /* gateway^2 (deprecated) */ 13976429de4SYoshinobu Inoue #define IPPROTO_IPV4 4 /* IPv4 encapsulation */ 14076429de4SYoshinobu Inoue #define IPPROTO_IPIP IPPROTO_IPV4 /* for compatibility */ 141cfaa93b2SJulian Elischer #define IPPROTO_ST 7 /* Stream protocol II */ 142df8bae1dSRodney W. Grimes #define IPPROTO_EGP 8 /* exterior gateway protocol */ 143cfaa93b2SJulian Elischer #define IPPROTO_PIGP 9 /* private interior gateway */ 144cfaa93b2SJulian Elischer #define IPPROTO_RCCMON 10 /* BBN RCC Monitoring */ 145cfaa93b2SJulian Elischer #define IPPROTO_NVPII 11 /* network voice protocol*/ 146df8bae1dSRodney W. Grimes #define IPPROTO_PUP 12 /* pup */ 147cfaa93b2SJulian Elischer #define IPPROTO_ARGUS 13 /* Argus */ 148cfaa93b2SJulian Elischer #define IPPROTO_EMCON 14 /* EMCON */ 149cfaa93b2SJulian Elischer #define IPPROTO_XNET 15 /* Cross Net Debugger */ 150cfaa93b2SJulian Elischer #define IPPROTO_CHAOS 16 /* Chaos*/ 151cfaa93b2SJulian Elischer #define IPPROTO_MUX 18 /* Multiplexing */ 152cfaa93b2SJulian Elischer #define IPPROTO_MEAS 19 /* DCN Measurement Subsystems */ 153cfaa93b2SJulian Elischer #define IPPROTO_HMP 20 /* Host Monitoring */ 154cfaa93b2SJulian Elischer #define IPPROTO_PRM 21 /* Packet Radio Measurement */ 155df8bae1dSRodney W. Grimes #define IPPROTO_IDP 22 /* xns idp */ 156cfaa93b2SJulian Elischer #define IPPROTO_TRUNK1 23 /* Trunk-1 */ 157cfaa93b2SJulian Elischer #define IPPROTO_TRUNK2 24 /* Trunk-2 */ 158cfaa93b2SJulian Elischer #define IPPROTO_LEAF1 25 /* Leaf-1 */ 159cfaa93b2SJulian Elischer #define IPPROTO_LEAF2 26 /* Leaf-2 */ 160cfaa93b2SJulian Elischer #define IPPROTO_RDP 27 /* Reliable Data */ 161cfaa93b2SJulian Elischer #define IPPROTO_IRTP 28 /* Reliable Transaction */ 162df8bae1dSRodney W. Grimes #define IPPROTO_TP 29 /* tp-4 w/ class negotiation */ 163cfaa93b2SJulian Elischer #define IPPROTO_BLT 30 /* Bulk Data Transfer */ 164cfaa93b2SJulian Elischer #define IPPROTO_NSP 31 /* Network Services */ 165cfaa93b2SJulian Elischer #define IPPROTO_INP 32 /* Merit Internodal */ 166cfaa93b2SJulian Elischer #define IPPROTO_SEP 33 /* Sequential Exchange */ 167cfaa93b2SJulian Elischer #define IPPROTO_3PC 34 /* Third Party Connect */ 168cfaa93b2SJulian Elischer #define IPPROTO_IDPR 35 /* InterDomain Policy Routing */ 169cfaa93b2SJulian Elischer #define IPPROTO_XTP 36 /* XTP */ 170cfaa93b2SJulian Elischer #define IPPROTO_DDP 37 /* Datagram Delivery */ 171cfaa93b2SJulian Elischer #define IPPROTO_CMTP 38 /* Control Message Transport */ 172cfaa93b2SJulian Elischer #define IPPROTO_TPXX 39 /* TP++ Transport */ 173cfaa93b2SJulian Elischer #define IPPROTO_IL 40 /* IL transport protocol */ 17476429de4SYoshinobu Inoue #define IPPROTO_IPV6 41 /* IP6 header */ 175cfaa93b2SJulian Elischer #define IPPROTO_SDRP 42 /* Source Demand Routing */ 17676429de4SYoshinobu Inoue #define IPPROTO_ROUTING 43 /* IP6 routing header */ 17776429de4SYoshinobu Inoue #define IPPROTO_FRAGMENT 44 /* IP6 fragmentation header */ 178cfaa93b2SJulian Elischer #define IPPROTO_IDRP 45 /* InterDomain Routing*/ 179f0068c4aSGarrett Wollman #define IPPROTO_RSVP 46 /* resource reservation */ 180cfaa93b2SJulian Elischer #define IPPROTO_GRE 47 /* General Routing Encap. */ 181cfaa93b2SJulian Elischer #define IPPROTO_MHRP 48 /* Mobile Host Routing */ 182cfaa93b2SJulian Elischer #define IPPROTO_BHA 49 /* BHA */ 18376429de4SYoshinobu Inoue #define IPPROTO_ESP 50 /* IP6 Encap Sec. Payload */ 18476429de4SYoshinobu Inoue #define IPPROTO_AH 51 /* IP6 Auth Header */ 185cfaa93b2SJulian Elischer #define IPPROTO_INLSP 52 /* Integ. Net Layer Security */ 186cfaa93b2SJulian Elischer #define IPPROTO_SWIPE 53 /* IP with encryption */ 187cfaa93b2SJulian Elischer #define IPPROTO_NHRP 54 /* Next Hop Resolution */ 188e61c4bedSJeroen Ruigrok van der Werven #define IPPROTO_MOBILE 55 /* IP Mobility */ 189e61c4bedSJeroen Ruigrok van der Werven #define IPPROTO_TLSP 56 /* Transport Layer Security */ 190e61c4bedSJeroen Ruigrok van der Werven #define IPPROTO_SKIP 57 /* SKIP */ 19176429de4SYoshinobu Inoue #define IPPROTO_ICMPV6 58 /* ICMP6 */ 19276429de4SYoshinobu Inoue #define IPPROTO_NONE 59 /* IP6 no next header */ 19376429de4SYoshinobu Inoue #define IPPROTO_DSTOPTS 60 /* IP6 destination option */ 194cfaa93b2SJulian Elischer #define IPPROTO_AHIP 61 /* any host internal protocol */ 195cfaa93b2SJulian Elischer #define IPPROTO_CFTP 62 /* CFTP */ 196cfaa93b2SJulian Elischer #define IPPROTO_HELLO 63 /* "hello" routing protocol */ 197cfaa93b2SJulian Elischer #define IPPROTO_SATEXPAK 64 /* SATNET/Backroom EXPAK */ 198cfaa93b2SJulian Elischer #define IPPROTO_KRYPTOLAN 65 /* Kryptolan */ 199cfaa93b2SJulian Elischer #define IPPROTO_RVD 66 /* Remote Virtual Disk */ 200cfaa93b2SJulian Elischer #define IPPROTO_IPPC 67 /* Pluribus Packet Core */ 201cfaa93b2SJulian Elischer #define IPPROTO_ADFS 68 /* Any distributed FS */ 202cfaa93b2SJulian Elischer #define IPPROTO_SATMON 69 /* Satnet Monitoring */ 203cfaa93b2SJulian Elischer #define IPPROTO_VISA 70 /* VISA Protocol */ 204cfaa93b2SJulian Elischer #define IPPROTO_IPCV 71 /* Packet Core Utility */ 205cfaa93b2SJulian Elischer #define IPPROTO_CPNX 72 /* Comp. Prot. Net. Executive */ 206cfaa93b2SJulian Elischer #define IPPROTO_CPHB 73 /* Comp. Prot. HeartBeat */ 207cfaa93b2SJulian Elischer #define IPPROTO_WSN 74 /* Wang Span Network */ 208cfaa93b2SJulian Elischer #define IPPROTO_PVP 75 /* Packet Video Protocol */ 209cfaa93b2SJulian Elischer #define IPPROTO_BRSATMON 76 /* BackRoom SATNET Monitoring */ 210cfaa93b2SJulian Elischer #define IPPROTO_ND 77 /* Sun net disk proto (temp.) */ 211cfaa93b2SJulian Elischer #define IPPROTO_WBMON 78 /* WIDEBAND Monitoring */ 212cfaa93b2SJulian Elischer #define IPPROTO_WBEXPAK 79 /* WIDEBAND EXPAK */ 213df8bae1dSRodney W. Grimes #define IPPROTO_EON 80 /* ISO cnlp */ 214cfaa93b2SJulian Elischer #define IPPROTO_VMTP 81 /* VMTP */ 215cfaa93b2SJulian Elischer #define IPPROTO_SVMTP 82 /* Secure VMTP */ 216cfaa93b2SJulian Elischer #define IPPROTO_VINES 83 /* Banyon VINES */ 217cfaa93b2SJulian Elischer #define IPPROTO_TTP 84 /* TTP */ 218cfaa93b2SJulian Elischer #define IPPROTO_IGP 85 /* NSFNET-IGP */ 219cfaa93b2SJulian Elischer #define IPPROTO_DGP 86 /* dissimilar gateway prot. */ 22047f049d7SJulian Elischer #define IPPROTO_TCF 87 /* TCF */ 221cfaa93b2SJulian Elischer #define IPPROTO_IGRP 88 /* Cisco/GXS IGRP */ 222cfaa93b2SJulian Elischer #define IPPROTO_OSPFIGP 89 /* OSPFIGP */ 223cfaa93b2SJulian Elischer #define IPPROTO_SRPC 90 /* Strite RPC protocol */ 224cfaa93b2SJulian Elischer #define IPPROTO_LARP 91 /* Locus Address Resoloution */ 225cfaa93b2SJulian Elischer #define IPPROTO_MTP 92 /* Multicast Transport */ 226cfaa93b2SJulian Elischer #define IPPROTO_AX25 93 /* AX.25 Frames */ 227cfaa93b2SJulian Elischer #define IPPROTO_IPEIP 94 /* IP encapsulated in IP */ 228cfaa93b2SJulian Elischer #define IPPROTO_MICP 95 /* Mobile Int.ing control */ 229cfaa93b2SJulian Elischer #define IPPROTO_SCCSP 96 /* Semaphore Comm. security */ 230cfaa93b2SJulian Elischer #define IPPROTO_ETHERIP 97 /* Ethernet IP encapsulation */ 231df8bae1dSRodney W. Grimes #define IPPROTO_ENCAP 98 /* encapsulation header */ 232cfaa93b2SJulian Elischer #define IPPROTO_APES 99 /* any private encr. scheme */ 233cfaa93b2SJulian Elischer #define IPPROTO_GMTP 100 /* GMTP*/ 23476429de4SYoshinobu Inoue #define IPPROTO_IPCOMP 108 /* payload compression (IPComp) */ 235eaa726beSLuigi Rizzo /* 101-254: Partly Unassigned */ 23676429de4SYoshinobu Inoue #define IPPROTO_PIM 103 /* Protocol Independent Mcast */ 237eaa726beSLuigi Rizzo #define IPPROTO_PGM 113 /* PGM */ 238cfaa93b2SJulian Elischer /* 255: Reserved */ 2394d3ffc98SBill Fenner /* BSD Private, local use, namespace incursion, no longer used */ 2404d3ffc98SBill Fenner #define IPPROTO_OLD_DIVERT 254 /* OLD divert pseudo-proto */ 241df8bae1dSRodney W. Grimes #define IPPROTO_MAX 256 242df8bae1dSRodney W. Grimes 24376429de4SYoshinobu Inoue /* last return value of *_input(), meaning "all job for this pkt is done". */ 24476429de4SYoshinobu Inoue #define IPPROTO_DONE 257 245df8bae1dSRodney W. Grimes 2464d3ffc98SBill Fenner /* Only used internally, so can be outside the range of valid IP protocols. */ 2474d3ffc98SBill Fenner #define IPPROTO_DIVERT 258 /* divert pseudo-protocol */ 2484d3ffc98SBill Fenner 249df8bae1dSRodney W. Grimes /* 250df8bae1dSRodney W. Grimes * Local port number conventions: 25133b3ac06SPeter Wemm * 25233b3ac06SPeter Wemm * When a user does a bind(2) or connect(2) with a port number of zero, 25333b3ac06SPeter Wemm * a non-conflicting local port address is chosen. 254c3b2fe55SMike Silbersack * The default range is IPPORT_HIFIRSTAUTO through 255c3b2fe55SMike Silbersack * IPPORT_HILASTAUTO, although that is settable by sysctl. 25633b3ac06SPeter Wemm * 25733b3ac06SPeter Wemm * A user may set the IPPROTO_IP option IP_PORTRANGE to change this 25833b3ac06SPeter Wemm * default assignment range. 25933b3ac06SPeter Wemm * 26033b3ac06SPeter Wemm * The value IP_PORTRANGE_DEFAULT causes the default behavior. 26133b3ac06SPeter Wemm * 26233b3ac06SPeter Wemm * The value IP_PORTRANGE_HIGH changes the range of candidate port numbers 26333b3ac06SPeter Wemm * into the "high" range. These are reserved for client outbound connections 264c3b2fe55SMike Silbersack * which do not want to be filtered by any firewalls. Note that by default 265c3b2fe55SMike Silbersack * this is the same as IP_PORTRANGE_DEFAULT. 26633b3ac06SPeter Wemm * 26733b3ac06SPeter Wemm * The value IP_PORTRANGE_LOW changes the range to the "low" are 26833b3ac06SPeter Wemm * that is (by convention) restricted to privileged processes. This 26933b3ac06SPeter Wemm * convention is based on "vouchsafe" principles only. It is only secure 27033b3ac06SPeter Wemm * if you trust the remote host to restrict these ports. 27133b3ac06SPeter Wemm * 27233b3ac06SPeter Wemm * The default range of ports and the high range can be changed by 273bbd42ad0SPeter Wemm * sysctl(3). (net.inet.ip.port{hi,low}{first,last}_auto) 27433b3ac06SPeter Wemm * 27533b3ac06SPeter Wemm * Changing those values has bad security implications if you are 2769d5abbddSJens Schweikhardt * using a stateless firewall that is allowing packets outside of that 27733b3ac06SPeter Wemm * range in order to allow transparent outgoing connections. 27833b3ac06SPeter Wemm * 27933b3ac06SPeter Wemm * Such a firewall configuration will generally depend on the use of these 28033b3ac06SPeter Wemm * default values. If you change them, you may find your Security 28133b3ac06SPeter Wemm * Administrator looking for you with a heavy object. 2824565cbeaSPoul-Henning Kamp * 2834565cbeaSPoul-Henning Kamp * For a slightly more orthodox text view on this: 2844565cbeaSPoul-Henning Kamp * 2854565cbeaSPoul-Henning Kamp * ftp://ftp.isi.edu/in-notes/iana/assignments/port-numbers 2864565cbeaSPoul-Henning Kamp * 2874565cbeaSPoul-Henning Kamp * port numbers are divided into three ranges: 2884565cbeaSPoul-Henning Kamp * 2894565cbeaSPoul-Henning Kamp * 0 - 1023 Well Known Ports 2904565cbeaSPoul-Henning Kamp * 1024 - 49151 Registered Ports 2914565cbeaSPoul-Henning Kamp * 49152 - 65535 Dynamic and/or Private Ports 2924565cbeaSPoul-Henning Kamp * 29333b3ac06SPeter Wemm */ 29433b3ac06SPeter Wemm 29533b3ac06SPeter Wemm /* 296df8bae1dSRodney W. Grimes * Ports < IPPORT_RESERVED are reserved for 29733b3ac06SPeter Wemm * privileged processes (e.g. root). (IP_PORTRANGE_LOW) 298df8bae1dSRodney W. Grimes */ 299df8bae1dSRodney W. Grimes #define IPPORT_RESERVED 1024 300df8bae1dSRodney W. Grimes 301df8bae1dSRodney W. Grimes /* 302f2697d4dSMike Silbersack * Default local port range, used by both IP_PORTRANGE_DEFAULT 303f2697d4dSMike Silbersack * and IP_PORTRANGE_HIGH. 304101f9fc8SPeter Wemm */ 3054565cbeaSPoul-Henning Kamp #define IPPORT_HIFIRSTAUTO 49152 3064565cbeaSPoul-Henning Kamp #define IPPORT_HILASTAUTO 65535 307101f9fc8SPeter Wemm 308101f9fc8SPeter Wemm /* 309bbd42ad0SPeter Wemm * Scanning for a free reserved port return a value below IPPORT_RESERVED, 310bbd42ad0SPeter Wemm * but higher than IPPORT_RESERVEDSTART. Traditionally the start value was 311bbd42ad0SPeter Wemm * 512, but that conflicts with some well-known-services that firewalls may 312bbd42ad0SPeter Wemm * have a fit if we use. 313bbd42ad0SPeter Wemm */ 314bbd42ad0SPeter Wemm #define IPPORT_RESERVEDSTART 600 315bbd42ad0SPeter Wemm 316de2656d0SMike Barcroft #define IPPORT_MAX 65535 317de2656d0SMike Barcroft 318df8bae1dSRodney W. Grimes /* 319df8bae1dSRodney W. Grimes * Definitions of bits in internet address integers. 320df8bae1dSRodney W. Grimes * On subnets, the decomposition of addresses to host and net parts 321df8bae1dSRodney W. Grimes * is done according to subnet mask, not the masks here. 322df8bae1dSRodney W. Grimes */ 323fac6d93bSJohn Birrell #define IN_CLASSA(i) (((u_int32_t)(i) & 0x80000000) == 0) 324df8bae1dSRodney W. Grimes #define IN_CLASSA_NET 0xff000000 325df8bae1dSRodney W. Grimes #define IN_CLASSA_NSHIFT 24 326df8bae1dSRodney W. Grimes #define IN_CLASSA_HOST 0x00ffffff 327df8bae1dSRodney W. Grimes #define IN_CLASSA_MAX 128 328df8bae1dSRodney W. Grimes 329fac6d93bSJohn Birrell #define IN_CLASSB(i) (((u_int32_t)(i) & 0xc0000000) == 0x80000000) 330df8bae1dSRodney W. Grimes #define IN_CLASSB_NET 0xffff0000 331df8bae1dSRodney W. Grimes #define IN_CLASSB_NSHIFT 16 332df8bae1dSRodney W. Grimes #define IN_CLASSB_HOST 0x0000ffff 333df8bae1dSRodney W. Grimes #define IN_CLASSB_MAX 65536 334df8bae1dSRodney W. Grimes 335fac6d93bSJohn Birrell #define IN_CLASSC(i) (((u_int32_t)(i) & 0xe0000000) == 0xc0000000) 336df8bae1dSRodney W. Grimes #define IN_CLASSC_NET 0xffffff00 337df8bae1dSRodney W. Grimes #define IN_CLASSC_NSHIFT 8 338df8bae1dSRodney W. Grimes #define IN_CLASSC_HOST 0x000000ff 339df8bae1dSRodney W. Grimes 340fac6d93bSJohn Birrell #define IN_CLASSD(i) (((u_int32_t)(i) & 0xf0000000) == 0xe0000000) 341df8bae1dSRodney W. Grimes #define IN_CLASSD_NET 0xf0000000 /* These ones aren't really */ 342df8bae1dSRodney W. Grimes #define IN_CLASSD_NSHIFT 28 /* net and host fields, but */ 343df8bae1dSRodney W. Grimes #define IN_CLASSD_HOST 0x0fffffff /* routing needn't know. */ 344df8bae1dSRodney W. Grimes #define IN_MULTICAST(i) IN_CLASSD(i) 345df8bae1dSRodney W. Grimes 346fac6d93bSJohn Birrell #define IN_EXPERIMENTAL(i) (((u_int32_t)(i) & 0xf0000000) == 0xf0000000) 347fac6d93bSJohn Birrell #define IN_BADCLASS(i) (((u_int32_t)(i) & 0xf0000000) == 0xf0000000) 348df8bae1dSRodney W. Grimes 349fac6d93bSJohn Birrell #define INADDR_LOOPBACK (u_int32_t)0x7f000001 350664a31e4SPeter Wemm #ifndef _KERNEL 351df8bae1dSRodney W. Grimes #define INADDR_NONE 0xffffffff /* -1 return */ 352df8bae1dSRodney W. Grimes #endif 353df8bae1dSRodney W. Grimes 354fac6d93bSJohn Birrell #define INADDR_UNSPEC_GROUP (u_int32_t)0xe0000000 /* 224.0.0.0 */ 355fac6d93bSJohn Birrell #define INADDR_ALLHOSTS_GROUP (u_int32_t)0xe0000001 /* 224.0.0.1 */ 356fac6d93bSJohn Birrell #define INADDR_ALLRTRS_GROUP (u_int32_t)0xe0000002 /* 224.0.0.2 */ 357fac6d93bSJohn Birrell #define INADDR_MAX_LOCAL_GROUP (u_int32_t)0xe00000ff /* 224.0.0.255 */ 358df8bae1dSRodney W. Grimes 359df8bae1dSRodney W. Grimes #define IN_LOOPBACKNET 127 /* official! */ 360df8bae1dSRodney W. Grimes 361df8bae1dSRodney W. Grimes /* 362df8bae1dSRodney W. Grimes * Options for use with [gs]etsockopt at the IP level. 363df8bae1dSRodney W. Grimes * First word of comment is data type; bool is stored in int. 364df8bae1dSRodney W. Grimes */ 365df8bae1dSRodney W. Grimes #define IP_OPTIONS 1 /* buf/ip_opts; set/get IP options */ 366df8bae1dSRodney W. Grimes #define IP_HDRINCL 2 /* int; header is included with data */ 367df8bae1dSRodney W. Grimes #define IP_TOS 3 /* int; IP type of service and preced. */ 368df8bae1dSRodney W. Grimes #define IP_TTL 4 /* int; IP time to live */ 369df8bae1dSRodney W. Grimes #define IP_RECVOPTS 5 /* bool; receive all IP opts w/dgram */ 370df8bae1dSRodney W. Grimes #define IP_RECVRETOPTS 6 /* bool; receive IP opts for response */ 371df8bae1dSRodney W. Grimes #define IP_RECVDSTADDR 7 /* bool; receive IP dst addr w/dgram */ 372c557ae16SIan Dowse #define IP_SENDSRCADDR IP_RECVDSTADDR /* cmsg_type to set src addr */ 373df8bae1dSRodney W. Grimes #define IP_RETOPTS 8 /* ip_opts; set/get IP options */ 374df8bae1dSRodney W. Grimes #define IP_MULTICAST_IF 9 /* u_char; set/get IP multicast i/f */ 375df8bae1dSRodney W. Grimes #define IP_MULTICAST_TTL 10 /* u_char; set/get IP multicast ttl */ 376df8bae1dSRodney W. Grimes #define IP_MULTICAST_LOOP 11 /* u_char; set/get IP multicast loopback */ 377df8bae1dSRodney W. Grimes #define IP_ADD_MEMBERSHIP 12 /* ip_mreq; add an IP group membership */ 378df8bae1dSRodney W. Grimes #define IP_DROP_MEMBERSHIP 13 /* ip_mreq; drop an IP group membership */ 379f0068c4aSGarrett Wollman #define IP_MULTICAST_VIF 14 /* set/get IP mcast virt. iface */ 380f0068c4aSGarrett Wollman #define IP_RSVP_ON 15 /* enable RSVP in kernel */ 381f0068c4aSGarrett Wollman #define IP_RSVP_OFF 16 /* disable RSVP in kernel */ 3821c5de19aSGarrett Wollman #define IP_RSVP_VIF_ON 17 /* set RSVP per-vif socket */ 3831c5de19aSGarrett Wollman #define IP_RSVP_VIF_OFF 18 /* unset RSVP per-vif socket */ 38433b3ac06SPeter Wemm #define IP_PORTRANGE 19 /* int; range to choose for unspec port */ 38582c23ebaSBill Fenner #define IP_RECVIF 20 /* bool; receive reception if w/dgram */ 38676429de4SYoshinobu Inoue /* for IPSEC */ 38776429de4SYoshinobu Inoue #define IP_IPSEC_POLICY 21 /* int; set/get security policy */ 38876429de4SYoshinobu Inoue #define IP_FAITH 22 /* bool; accept FAITH'ed connections */ 389df8bae1dSRodney W. Grimes 390fed1c7e9SSøren Schmidt #define IP_FW_ADD 50 /* add a firewall rule to chain */ 391fed1c7e9SSøren Schmidt #define IP_FW_DEL 51 /* delete a firewall rule from chain */ 392fed1c7e9SSøren Schmidt #define IP_FW_FLUSH 52 /* flush firewall rule chain */ 393af44ef0aSAlexander Langer #define IP_FW_ZERO 53 /* clear single/all firewall counter(s) */ 394fed1c7e9SSøren Schmidt #define IP_FW_GET 54 /* get entire firewall rule chain */ 3950b6c1a83SBrian Feldman #define IP_FW_RESETLOG 55 /* reset logging counters */ 396fed1c7e9SSøren Schmidt 397b715f178SLuigi Rizzo #define IP_DUMMYNET_CONFIGURE 60 /* add/configure a dummynet pipe */ 398b715f178SLuigi Rizzo #define IP_DUMMYNET_DEL 61 /* delete a dummynet pipe from chain */ 399b715f178SLuigi Rizzo #define IP_DUMMYNET_FLUSH 62 /* flush dummynet */ 400b715f178SLuigi Rizzo #define IP_DUMMYNET_GET 64 /* get entire dummynet pipes */ 401b715f178SLuigi Rizzo 4024957466bSMatthew N. Dodd #define IP_RECVTTL 65 /* bool; receive IP TTL w/dgram */ 4034957466bSMatthew N. Dodd 404df8bae1dSRodney W. Grimes /* 405df8bae1dSRodney W. Grimes * Defaults and limits for options 406df8bae1dSRodney W. Grimes */ 407df8bae1dSRodney W. Grimes #define IP_DEFAULT_MULTICAST_TTL 1 /* normally limit m'casts to 1 hop */ 408df8bae1dSRodney W. Grimes #define IP_DEFAULT_MULTICAST_LOOP 1 /* normally hear sends if a member */ 4091c5de19aSGarrett Wollman #define IP_MAX_MEMBERSHIPS 20 /* per socket */ 410df8bae1dSRodney W. Grimes 411df8bae1dSRodney W. Grimes /* 412df8bae1dSRodney W. Grimes * Argument structure for IP_ADD_MEMBERSHIP and IP_DROP_MEMBERSHIP. 413df8bae1dSRodney W. Grimes */ 414df8bae1dSRodney W. Grimes struct ip_mreq { 415df8bae1dSRodney W. Grimes struct in_addr imr_multiaddr; /* IP multicast address of group */ 416df8bae1dSRodney W. Grimes struct in_addr imr_interface; /* local IP address of interface */ 417df8bae1dSRodney W. Grimes }; 418df8bae1dSRodney W. Grimes 419df8bae1dSRodney W. Grimes /* 42033b3ac06SPeter Wemm * Argument for IP_PORTRANGE: 42133b3ac06SPeter Wemm * - which range to search when port is unspecified at bind() or connect() 42233b3ac06SPeter Wemm */ 42333b3ac06SPeter Wemm #define IP_PORTRANGE_DEFAULT 0 /* default range */ 42433b3ac06SPeter Wemm #define IP_PORTRANGE_HIGH 1 /* "high" - request firewall bypass */ 42533b3ac06SPeter Wemm #define IP_PORTRANGE_LOW 2 /* "low" - vouchsafe security */ 42633b3ac06SPeter Wemm 42733b3ac06SPeter Wemm /* 428df8bae1dSRodney W. Grimes * Definitions for inet sysctl operations. 429df8bae1dSRodney W. Grimes * 430df8bae1dSRodney W. Grimes * Third level is protocol number. 431df8bae1dSRodney W. Grimes * Fourth level is desired variable within that protocol. 432df8bae1dSRodney W. Grimes */ 433686cdd19SJun-ichiro itojun Hagino #define IPPROTO_MAXID (IPPROTO_AH + 1) /* don't list to IPPROTO_MAX */ 434df8bae1dSRodney W. Grimes 435df8bae1dSRodney W. Grimes #define CTL_IPPROTO_NAMES { \ 436df8bae1dSRodney W. Grimes { "ip", CTLTYPE_NODE }, \ 437df8bae1dSRodney W. Grimes { "icmp", CTLTYPE_NODE }, \ 438df8bae1dSRodney W. Grimes { "igmp", CTLTYPE_NODE }, \ 439df8bae1dSRodney W. Grimes { "ggp", CTLTYPE_NODE }, \ 440df8bae1dSRodney W. Grimes { 0, 0 }, \ 441df8bae1dSRodney W. Grimes { 0, 0 }, \ 442df8bae1dSRodney W. Grimes { "tcp", CTLTYPE_NODE }, \ 443df8bae1dSRodney W. Grimes { 0, 0 }, \ 444df8bae1dSRodney W. Grimes { "egp", CTLTYPE_NODE }, \ 445df8bae1dSRodney W. Grimes { 0, 0 }, \ 446df8bae1dSRodney W. Grimes { 0, 0 }, \ 447df8bae1dSRodney W. Grimes { 0, 0 }, \ 448df8bae1dSRodney W. Grimes { "pup", CTLTYPE_NODE }, \ 449df8bae1dSRodney W. Grimes { 0, 0 }, \ 450df8bae1dSRodney W. Grimes { 0, 0 }, \ 451df8bae1dSRodney W. Grimes { 0, 0 }, \ 452df8bae1dSRodney W. Grimes { 0, 0 }, \ 453df8bae1dSRodney W. Grimes { "udp", CTLTYPE_NODE }, \ 454df8bae1dSRodney W. Grimes { 0, 0 }, \ 455df8bae1dSRodney W. Grimes { 0, 0 }, \ 456df8bae1dSRodney W. Grimes { 0, 0 }, \ 457df8bae1dSRodney W. Grimes { 0, 0 }, \ 458df8bae1dSRodney W. Grimes { "idp", CTLTYPE_NODE }, \ 459686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 460686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 461686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 462686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 463686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 464686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 465686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 466686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 467686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 468686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 469686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 470686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 471686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 472686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 473686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 474686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 475686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 476686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 477686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 478686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 479686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 480686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 481686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 482686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 483686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 484686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 485686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 486686cdd19SJun-ichiro itojun Hagino { 0, 0 }, \ 487686cdd19SJun-ichiro itojun Hagino { "ipsec", CTLTYPE_NODE }, \ 488df8bae1dSRodney W. Grimes } 489df8bae1dSRodney W. Grimes 490df8bae1dSRodney W. Grimes /* 491df8bae1dSRodney W. Grimes * Names for IP sysctl objects 492df8bae1dSRodney W. Grimes */ 493df8bae1dSRodney W. Grimes #define IPCTL_FORWARDING 1 /* act as router */ 494df8bae1dSRodney W. Grimes #define IPCTL_SENDREDIRECTS 2 /* may send redirects when forwarding */ 495df8bae1dSRodney W. Grimes #define IPCTL_DEFTTL 3 /* default TTL */ 496df8bae1dSRodney W. Grimes #ifdef notyet 497df8bae1dSRodney W. Grimes #define IPCTL_DEFMTU 4 /* default MTU */ 498df8bae1dSRodney W. Grimes #endif 4995be2baf8SGarrett Wollman #define IPCTL_RTEXPIRE 5 /* cloned route expiration time */ 500ea80aed1SGarrett Wollman #define IPCTL_RTMINEXPIRE 6 /* min value for expiration time */ 501ea80aed1SGarrett Wollman #define IPCTL_RTMAXCACHE 7 /* trigger level for dynamic expire */ 5021025071fSGarrett Wollman #define IPCTL_SOURCEROUTE 8 /* may perform source routes */ 50342c03a52SPeter Wemm #define IPCTL_DIRECTEDBROADCAST 9 /* may re-broadcast received packets */ 504054ef370SGarrett Wollman #define IPCTL_INTRQMAXLEN 10 /* max length of netisr queue */ 505054ef370SGarrett Wollman #define IPCTL_INTRQDROPS 11 /* number of netisr q drops */ 5066fce01c9SGarrett Wollman #define IPCTL_STATS 12 /* ipstat structure */ 5074fce5804SGuido van Rooij #define IPCTL_ACCEPTSOURCEROUTE 13 /* may accept source routed packets */ 5081f91d8c5SDavid Greenman #define IPCTL_FASTFORWARDING 14 /* use fast IP forwarding code */ 5096a800098SYoshinobu Inoue #define IPCTL_KEEPFAITH 15 /* FAITH IPv4->IPv6 translater ctl */ 51076429de4SYoshinobu Inoue #define IPCTL_GIF_TTL 16 /* default TTL for gif encap packet */ 51176429de4SYoshinobu Inoue #define IPCTL_MAXID 17 512df8bae1dSRodney W. Grimes 513df8bae1dSRodney W. Grimes #define IPCTL_NAMES { \ 514df8bae1dSRodney W. Grimes { 0, 0 }, \ 515df8bae1dSRodney W. Grimes { "forwarding", CTLTYPE_INT }, \ 516df8bae1dSRodney W. Grimes { "redirect", CTLTYPE_INT }, \ 517df8bae1dSRodney W. Grimes { "ttl", CTLTYPE_INT }, \ 518df8bae1dSRodney W. Grimes { "mtu", CTLTYPE_INT }, \ 5195be2baf8SGarrett Wollman { "rtexpire", CTLTYPE_INT }, \ 520ea80aed1SGarrett Wollman { "rtminexpire", CTLTYPE_INT }, \ 521ea80aed1SGarrett Wollman { "rtmaxcache", CTLTYPE_INT }, \ 5221025071fSGarrett Wollman { "sourceroute", CTLTYPE_INT }, \ 52342c03a52SPeter Wemm { "directed-broadcast", CTLTYPE_INT }, \ 524054ef370SGarrett Wollman { "intr-queue-maxlen", CTLTYPE_INT }, \ 525054ef370SGarrett Wollman { "intr-queue-drops", CTLTYPE_INT }, \ 5266fce01c9SGarrett Wollman { "stats", CTLTYPE_STRUCT }, \ 5274fce5804SGuido van Rooij { "accept_sourceroute", CTLTYPE_INT }, \ 5281f91d8c5SDavid Greenman { "fastforwarding", CTLTYPE_INT }, \ 529df8bae1dSRodney W. Grimes } 530df8bae1dSRodney W. Grimes 53158631bbeSMike Barcroft #endif /* __BSD_VISIBLE */ 53258631bbeSMike Barcroft 533215db137SPeter Wemm #ifdef _KERNEL 53458631bbeSMike Barcroft 535215db137SPeter Wemm struct ifnet; struct mbuf; /* forward declarations for Standard C */ 536ef0cdf33SGarrett Wollman 5374d77a549SAlfred Perlstein int in_broadcast(struct in_addr, struct ifnet *); 5384d77a549SAlfred Perlstein int in_canforward(struct in_addr); 5394d77a549SAlfred Perlstein int in_localaddr(struct in_addr); 5404d77a549SAlfred Perlstein char *inet_ntoa(struct in_addr); /* in libkern */ 5414d77a549SAlfred Perlstein char *inet_ntoa_r(struct in_addr ina, char *buf); /* in libkern */ 54223bf9953SPoul-Henning Kamp 543386fefa3SMaxim Sobolev #define in_hosteq(s, t) ((s).s_addr == (t).s_addr) 544386fefa3SMaxim Sobolev #define in_nullhost(x) ((x).s_addr == INADDR_ANY) 545386fefa3SMaxim Sobolev 5469a10980eSJonathan Lemon #define satosin(sa) ((struct sockaddr_in *)(sa)) 5479a10980eSJonathan Lemon #define sintosa(sin) ((struct sockaddr *)(sin)) 5489a10980eSJonathan Lemon #define ifatoia(ifa) ((struct in_ifaddr *)(ifa)) 5499a10980eSJonathan Lemon 550fd8e4ebcSMike Barcroft #endif /* _KERNEL */ 551fd8e4ebcSMike Barcroft 55258631bbeSMike Barcroft /* INET6 stuff */ 55358631bbeSMike Barcroft #if __POSIX_VISIBLE >= 200112 55458631bbeSMike Barcroft #define __KAME_NETINET_IN_H_INCLUDED_ 55558631bbeSMike Barcroft #include <netinet6/in6.h> 55658631bbeSMike Barcroft #undef __KAME_NETINET_IN_H_INCLUDED_ 557707f139eSPaul Richards #endif 55858631bbeSMike Barcroft 55958631bbeSMike Barcroft #endif /* !_NETINET_IN_H_*/ 560