in.h 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. /* Copyright (C) 1991-1999, 2000, 2004, 2008, 2010 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. The GNU C Library is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU Lesser General Public
  5. License as published by the Free Software Foundation; either
  6. version 2.1 of the License, or (at your option) any later version.
  7. The GNU C Library is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  10. Lesser General Public License for more details.
  11. You should have received a copy of the GNU Lesser General Public
  12. License along with the GNU C Library; if not, write to the Free
  13. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  14. 02111-1307 USA. */
  15. /* Linux version. */
  16. #ifndef _NETINET_IN_H
  17. # error "Never use <bits/in.h> directly; include <netinet/in.h> instead."
  18. #endif
  19. /* Options for use with `getsockopt' and `setsockopt' at the IP level.
  20. The first word in the comment at the right is the data type used;
  21. "bool" means a boolean value stored in an `int'. */
  22. #define IP_OPTIONS 4 /* ip_opts; IP per-packet options. */
  23. #define IP_HDRINCL 3 /* int; Header is included with data. */
  24. #define IP_TOS 1 /* int; IP type of service and precedence. */
  25. #define IP_TTL 2 /* int; IP time to live. */
  26. #define IP_RECVOPTS 6 /* bool; Receive all IP options w/datagram. */
  27. /* For BSD compatibility. */
  28. #define IP_RECVRETOPTS IP_RETOPTS /* bool; Receive IP options for response. */
  29. #define IP_RETOPTS 7 /* ip_opts; Set/get IP per-packet options. */
  30. #define IP_MULTICAST_IF 32 /* in_addr; set/get IP multicast i/f */
  31. #define IP_MULTICAST_TTL 33 /* u_char; set/get IP multicast ttl */
  32. #define IP_MULTICAST_LOOP 34 /* i_char; set/get IP multicast loopback */
  33. #define IP_ADD_MEMBERSHIP 35 /* ip_mreq; add an IP group membership */
  34. #define IP_DROP_MEMBERSHIP 36 /* ip_mreq; drop an IP group membership */
  35. #define IP_UNBLOCK_SOURCE 37 /* ip_mreq_source: unblock data from source */
  36. #define IP_BLOCK_SOURCE 38 /* ip_mreq_source: block data from source */
  37. #define IP_ADD_SOURCE_MEMBERSHIP 39 /* ip_mreq_source: join source group */
  38. #define IP_DROP_SOURCE_MEMBERSHIP 40 /* ip_mreq_source: leave source group */
  39. #define IP_MSFILTER 41
  40. #if defined __USE_MISC || defined __USE_GNU
  41. # define MCAST_JOIN_GROUP 42 /* group_req: join any-source group */
  42. # define MCAST_BLOCK_SOURCE 43 /* group_source_req: block from given group */
  43. # define MCAST_UNBLOCK_SOURCE 44 /* group_source_req: unblock from given group*/
  44. # define MCAST_LEAVE_GROUP 45 /* group_req: leave any-source group */
  45. # define MCAST_JOIN_SOURCE_GROUP 46 /* group_source_req: join source-spec gr */
  46. # define MCAST_LEAVE_SOURCE_GROUP 47 /* group_source_req: leave source-spec gr*/
  47. # define MCAST_MSFILTER 48
  48. # define MCAST_EXCLUDE 0
  49. # define MCAST_INCLUDE 1
  50. #endif
  51. #define IP_ROUTER_ALERT 5 /* bool */
  52. #define IP_PKTINFO 8 /* bool */
  53. #define IP_PKTOPTIONS 9
  54. #define IP_PMTUDISC 10 /* obsolete name? */
  55. #define IP_MTU_DISCOVER 10 /* int; see below */
  56. #define IP_RECVERR 11 /* bool */
  57. #define IP_RECVTTL 12 /* bool */
  58. #define IP_RECVTOS 13 /* bool */
  59. #define IP_MTU 14 /* int */
  60. #define IP_FREEBIND 15
  61. #define IP_IPSEC_POLICY 16
  62. #define IP_XFRM_POLICY 17
  63. #define IP_PASSSEC 18
  64. #define IP_TRANSPARENT 19
  65. #define IP_MULTICAST_ALL 49 /* bool */
  66. /* TProxy original addresses */
  67. #define IP_ORIGDSTADDR 20
  68. #define IP_RECVORIGDSTADDR IP_ORIGDSTADDR
  69. #define IP_MINTTL 21
  70. /* IP_MTU_DISCOVER arguments. */
  71. #define IP_PMTUDISC_DONT 0 /* Never send DF frames. */
  72. #define IP_PMTUDISC_WANT 1 /* Use per route hints. */
  73. #define IP_PMTUDISC_DO 2 /* Always DF. */
  74. #define IP_PMTUDISC_PROBE 3 /* Ignore dst pmtu. */
  75. /* To select the IP level. */
  76. #define SOL_IP 0
  77. #define IP_DEFAULT_MULTICAST_TTL 1
  78. #define IP_DEFAULT_MULTICAST_LOOP 1
  79. #define IP_MAX_MEMBERSHIPS 20
  80. #if defined __USE_MISC || defined __USE_GNU
  81. /* Structure used to describe IP options for IP_OPTIONS and IP_RETOPTS.
  82. The `ip_dst' field is used for the first-hop gateway when using a
  83. source route (this gets put into the header proper). */
  84. struct ip_opts
  85. {
  86. struct in_addr ip_dst; /* First hop; zero without source route. */
  87. char ip_opts[40]; /* Actually variable in size. */
  88. };
  89. /* Like `struct ip_mreq' but including interface specification by index. */
  90. struct ip_mreqn
  91. {
  92. struct in_addr imr_multiaddr; /* IP multicast address of group */
  93. struct in_addr imr_address; /* local IP address of interface */
  94. int imr_ifindex; /* Interface index */
  95. };
  96. /* Structure used for IP_PKTINFO. */
  97. struct in_pktinfo
  98. {
  99. int ipi_ifindex; /* Interface index */
  100. struct in_addr ipi_spec_dst; /* Routing destination address */
  101. struct in_addr ipi_addr; /* Header destination address */
  102. };
  103. #endif
  104. /* Options for use with `getsockopt' and `setsockopt' at the IPv6 level.
  105. The first word in the comment at the right is the data type used;
  106. "bool" means a boolean value stored in an `int'. */
  107. #define IPV6_ADDRFORM 1
  108. #define IPV6_2292PKTINFO 2
  109. #define IPV6_2292HOPOPTS 3
  110. #define IPV6_2292DSTOPTS 4
  111. #define IPV6_2292RTHDR 5
  112. #define IPV6_2292PKTOPTIONS 6
  113. #define IPV6_CHECKSUM 7
  114. #define IPV6_2292HOPLIMIT 8
  115. #define SCM_SRCRT IPV6_RXSRCRT
  116. #define IPV6_NEXTHOP 9
  117. #define IPV6_AUTHHDR 10
  118. #define IPV6_UNICAST_HOPS 16
  119. #define IPV6_MULTICAST_IF 17
  120. #define IPV6_MULTICAST_HOPS 18
  121. #define IPV6_MULTICAST_LOOP 19
  122. #define IPV6_JOIN_GROUP 20
  123. #define IPV6_LEAVE_GROUP 21
  124. #define IPV6_ROUTER_ALERT 22
  125. #define IPV6_MTU_DISCOVER 23
  126. #define IPV6_MTU 24
  127. #define IPV6_RECVERR 25
  128. #define IPV6_V6ONLY 26
  129. #define IPV6_JOIN_ANYCAST 27
  130. #define IPV6_LEAVE_ANYCAST 28
  131. #define IPV6_IPSEC_POLICY 34
  132. #define IPV6_XFRM_POLICY 35
  133. #define IPV6_RECVPKTINFO 49
  134. #define IPV6_PKTINFO 50
  135. #define IPV6_RECVHOPLIMIT 51
  136. #define IPV6_HOPLIMIT 52
  137. #define IPV6_RECVHOPOPTS 53
  138. #define IPV6_HOPOPTS 54
  139. #define IPV6_RTHDRDSTOPTS 55
  140. #define IPV6_RECVRTHDR 56
  141. #define IPV6_RTHDR 57
  142. #define IPV6_RECVDSTOPTS 58
  143. #define IPV6_DSTOPTS 59
  144. #define IPV6_RECVTCLASS 66
  145. #define IPV6_TCLASS 67
  146. /* Obsolete synonyms for the above. */
  147. #define IPV6_ADD_MEMBERSHIP IPV6_JOIN_GROUP
  148. #define IPV6_DROP_MEMBERSHIP IPV6_LEAVE_GROUP
  149. #define IPV6_RXHOPOPTS IPV6_HOPOPTS
  150. #define IPV6_RXDSTOPTS IPV6_DSTOPTS
  151. /* IPV6_MTU_DISCOVER values. */
  152. #define IPV6_PMTUDISC_DONT 0 /* Never send DF frames. */
  153. #define IPV6_PMTUDISC_WANT 1 /* Use per route hints. */
  154. #define IPV6_PMTUDISC_DO 2 /* Always DF. */
  155. #define IPV6_PMTUDISC_PROBE 3 /* Ignore dst pmtu. */
  156. /* Socket level values for IPv6. */
  157. #define SOL_IPV6 41
  158. #define SOL_ICMPV6 58
  159. /* Routing header options for IPv6. */
  160. #define IPV6_RTHDR_LOOSE 0 /* Hop doesn't need to be neighbour. */
  161. #define IPV6_RTHDR_STRICT 1 /* Hop must be a neighbour. */
  162. #define IPV6_RTHDR_TYPE_0 0 /* IPv6 Routing header type 0. */