ip.h 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  1. /*-
  2. * SPDX-License-Identifier: BSD-3-Clause
  3. *
  4. * Copyright (c) 1982, 1986, 1993
  5. * The Regents of the University of California.
  6. * All rights reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions
  10. * are met:
  11. * 1. Redistributions of source code must retain the above copyright
  12. * notice, this list of conditions and the following disclaimer.
  13. * 2. Redistributions in binary form must reproduce the above copyright
  14. * notice, this list of conditions and the following disclaimer in the
  15. * documentation and/or other materials provided with the distribution.
  16. * 3. Neither the name of the University nor the names of its contributors
  17. * may be used to endorse or promote products derived from this software
  18. * without specific prior written permission.
  19. *
  20. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  21. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  22. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  23. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  24. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  25. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  26. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  27. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  28. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  29. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  30. * SUCH DAMAGE.
  31. *
  32. * @(#)ip.h 8.2 (Berkeley) 6/1/94
  33. * $FreeBSD$
  34. */
  35. #ifndef _NETINET_IP_H_
  36. #define _NETINET_IP_H_
  37. #include <sys/cdefs.h>
  38. /*
  39. * Definitions for internet protocol version 4.
  40. *
  41. * Per RFC 791, September 1981.
  42. */
  43. #define IPVERSION 4
  44. /*
  45. * Structure of an internet header, naked of options.
  46. */
  47. struct ip {
  48. #if BYTE_ORDER == LITTLE_ENDIAN
  49. u_char ip_hl:4, /* header length */
  50. ip_v:4; /* version */
  51. #endif
  52. #if BYTE_ORDER == BIG_ENDIAN
  53. u_char ip_v:4, /* version */
  54. ip_hl:4; /* header length */
  55. #endif
  56. u_char ip_tos; /* type of service */
  57. u_short ip_len; /* total length */
  58. u_short ip_id; /* identification */
  59. u_short ip_off; /* fragment offset field */
  60. #define IP_RF 0x8000 /* reserved fragment flag */
  61. #define IP_DF 0x4000 /* dont fragment flag */
  62. #define IP_MF 0x2000 /* more fragments flag */
  63. #define IP_OFFMASK 0x1fff /* mask for fragmenting bits */
  64. u_char ip_ttl; /* time to live */
  65. u_char ip_p; /* protocol */
  66. u_short ip_sum; /* checksum */
  67. struct in_addr ip_src,ip_dst; /* source and dest address */
  68. } __packed __aligned(2);
  69. #define IP_MAXPACKET 65535 /* maximum packet size */
  70. /*
  71. * Definitions for IP type of service (ip_tos).
  72. */
  73. #define IPTOS_LOWDELAY 0x10
  74. #define IPTOS_THROUGHPUT 0x08
  75. #define IPTOS_RELIABILITY 0x04
  76. #define IPTOS_MINCOST 0x02
  77. /*
  78. * Definitions for IP precedence (also in ip_tos) (deprecated).
  79. */
  80. #define IPTOS_PREC_NETCONTROL IPTOS_DSCP_CS7
  81. #define IPTOS_PREC_INTERNETCONTROL IPTOS_DSCP_CS6
  82. #define IPTOS_PREC_CRITIC_ECP IPTOS_DSCP_CS5
  83. #define IPTOS_PREC_FLASHOVERRIDE IPTOS_DSCP_CS4
  84. #define IPTOS_PREC_FLASH IPTOS_DSCP_CS3
  85. #define IPTOS_PREC_IMMEDIATE IPTOS_DSCP_CS2
  86. #define IPTOS_PREC_PRIORITY IPTOS_DSCP_CS1
  87. #define IPTOS_PREC_ROUTINE IPTOS_DSCP_CS0
  88. /*
  89. * Offset of Diffserv decimal value to convert it to tos value .
  90. */
  91. #define IPTOS_DSCP_OFFSET 2
  92. /*
  93. * Definitions for DiffServ Codepoints as per RFC2474 and RFC5865.
  94. */
  95. #define IPTOS_DSCP_CS0 0x00
  96. #define IPTOS_DSCP_CS1 0x20
  97. #define IPTOS_DSCP_AF11 0x28
  98. #define IPTOS_DSCP_AF12 0x30
  99. #define IPTOS_DSCP_AF13 0x38
  100. #define IPTOS_DSCP_CS2 0x40
  101. #define IPTOS_DSCP_AF21 0x48
  102. #define IPTOS_DSCP_AF22 0x50
  103. #define IPTOS_DSCP_AF23 0x58
  104. #define IPTOS_DSCP_CS3 0x60
  105. #define IPTOS_DSCP_AF31 0x68
  106. #define IPTOS_DSCP_AF32 0x70
  107. #define IPTOS_DSCP_AF33 0x78
  108. #define IPTOS_DSCP_CS4 0x80
  109. #define IPTOS_DSCP_AF41 0x88
  110. #define IPTOS_DSCP_AF42 0x90
  111. #define IPTOS_DSCP_AF43 0x98
  112. #define IPTOS_DSCP_CS5 0xa0
  113. #define IPTOS_DSCP_VA 0xb0
  114. #define IPTOS_DSCP_EF 0xb8
  115. #define IPTOS_DSCP_CS6 0xc0
  116. #define IPTOS_DSCP_CS7 0xe0
  117. /*
  118. * ECN (Explicit Congestion Notification) codepoints in RFC3168 mapped to the
  119. * lower 2 bits of the TOS field.
  120. */
  121. #define IPTOS_ECN_NOTECT 0x00 /* not-ECT */
  122. #define IPTOS_ECN_ECT1 0x01 /* ECN-capable transport (1) */
  123. #define IPTOS_ECN_ECT0 0x02 /* ECN-capable transport (0) */
  124. #define IPTOS_ECN_CE 0x03 /* congestion experienced */
  125. #define IPTOS_ECN_MASK 0x03 /* ECN field mask */
  126. /*
  127. * Definitions for options.
  128. */
  129. #define IPOPT_COPIED(o) ((o)&0x80)
  130. #define IPOPT_CLASS(o) ((o)&0x60)
  131. #define IPOPT_NUMBER(o) ((o)&0x1f)
  132. #define IPOPT_CONTROL 0x00
  133. #define IPOPT_RESERVED1 0x20
  134. #define IPOPT_DEBMEAS 0x40
  135. #define IPOPT_RESERVED2 0x60
  136. #define IPOPT_EOL 0 /* end of option list */
  137. #define IPOPT_NOP 1 /* no operation */
  138. #define IPOPT_RR 7 /* record packet route */
  139. #define IPOPT_TS 68 /* timestamp */
  140. #define IPOPT_SECURITY 130 /* provide s,c,h,tcc */
  141. #define IPOPT_LSRR 131 /* loose source route */
  142. #define IPOPT_ESO 133 /* extended security */
  143. #define IPOPT_CIPSO 134 /* commercial security */
  144. #define IPOPT_SATID 136 /* satnet id */
  145. #define IPOPT_SSRR 137 /* strict source route */
  146. #define IPOPT_RA 148 /* router alert */
  147. /*
  148. * Offsets to fields in options other than EOL and NOP.
  149. */
  150. #define IPOPT_OPTVAL 0 /* option ID */
  151. #define IPOPT_OLEN 1 /* option length */
  152. #define IPOPT_OFFSET 2 /* offset within option */
  153. #define IPOPT_MINOFF 4 /* min value of above */
  154. /*
  155. * Time stamp option structure.
  156. */
  157. struct ip_timestamp {
  158. u_char ipt_code; /* IPOPT_TS */
  159. u_char ipt_len; /* size of structure (variable) */
  160. u_char ipt_ptr; /* index of current entry */
  161. #if BYTE_ORDER == LITTLE_ENDIAN
  162. u_char ipt_flg:4, /* flags, see below */
  163. ipt_oflw:4; /* overflow counter */
  164. #endif
  165. #if BYTE_ORDER == BIG_ENDIAN
  166. u_char ipt_oflw:4, /* overflow counter */
  167. ipt_flg:4; /* flags, see below */
  168. #endif
  169. union ipt_timestamp {
  170. uint32_t ipt_time[1]; /* network format */
  171. struct ipt_ta {
  172. struct in_addr ipt_addr;
  173. uint32_t ipt_time; /* network format */
  174. } ipt_ta[1];
  175. } ipt_timestamp;
  176. };
  177. /* Flag bits for ipt_flg. */
  178. #define IPOPT_TS_TSONLY 0 /* timestamps only */
  179. #define IPOPT_TS_TSANDADDR 1 /* timestamps and addresses */
  180. #define IPOPT_TS_PRESPEC 3 /* specified modules only */
  181. /* Bits for security (not byte swapped). */
  182. #define IPOPT_SECUR_UNCLASS 0x0000
  183. #define IPOPT_SECUR_CONFID 0xf135
  184. #define IPOPT_SECUR_EFTO 0x789a
  185. #define IPOPT_SECUR_MMMM 0xbc4d
  186. #define IPOPT_SECUR_RESTR 0xaf13
  187. #define IPOPT_SECUR_SECRET 0xd788
  188. #define IPOPT_SECUR_TOPSECRET 0x6bc5
  189. /*
  190. * Internet implementation parameters.
  191. */
  192. #define MAXTTL 255 /* maximum time to live (seconds) */
  193. #define IPDEFTTL 64 /* default ttl, from RFC 1340 */
  194. #define IPFRAGTTL 60 /* time to live for frags, slowhz */
  195. #define IPTTLDEC 1 /* subtracted when forwarding */
  196. #define IP_MSS 576 /* default maximum segment size */
  197. /*
  198. * This is the real IPv4 pseudo header, used for computing the TCP and UDP
  199. * checksums. For the Internet checksum, struct ipovly can be used instead.
  200. * For stronger checksums, the real thing must be used.
  201. */
  202. struct ippseudo {
  203. struct in_addr ippseudo_src; /* source internet address */
  204. struct in_addr ippseudo_dst; /* destination internet address */
  205. u_char ippseudo_pad; /* pad, must be zero */
  206. u_char ippseudo_p; /* protocol */
  207. u_short ippseudo_len; /* protocol length */
  208. };
  209. #endif