if_arp.h 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /* $OpenBSD: if_arp.h,v 1.6 2003/06/02 23:28:12 millert Exp $ */
  2. /* $NetBSD: if_arp.h,v 1.8 1995/03/08 02:56:52 cgd Exp $ */
  3. /*
  4. * Copyright (c) 1986, 1993
  5. * The Regents of the University of California. All rights reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the name of the University nor the names of its contributors
  16. * may be used to endorse or promote products derived from this software
  17. * without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  20. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  21. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  22. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  23. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  24. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  25. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  26. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  27. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  28. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  29. * SUCH DAMAGE.
  30. *
  31. * @(#)if_arp.h 8.1 (Berkeley) 6/10/93
  32. */
  33. #ifndef _NET_IF_ARP_H_
  34. #define _NET_IF_ARP_H_
  35. /*
  36. * Address Resolution Protocol.
  37. *
  38. * See RFC 826 for protocol description. ARP packets are variable
  39. * in size; the arphdr structure defines the fixed-length portion.
  40. * Protocol type values are the same as those for 10 Mb/s Ethernet.
  41. * It is followed by the variable-sized fields ar_sha, arp_spa,
  42. * arp_tha and arp_tpa in that order, according to the lengths
  43. * specified. Field names used correspond to RFC 826.
  44. */
  45. struct arphdr {
  46. u_int16_t ar_hrd; /* format of hardware address */
  47. #define ARPHRD_ETHER 1 /* ethernet hardware format */
  48. #define ARPHRD_IEEE802 6 /* IEEE 802 hardware format */
  49. #define ARPHRD_FRELAY 15 /* frame relay hardware format */
  50. #define ARPHRD_IEEE1394 24 /* IEEE 1394 (FireWire) hardware format */
  51. u_int16_t ar_pro; /* format of protocol address */
  52. u_int8_t ar_hln; /* length of hardware address */
  53. u_int8_t ar_pln; /* length of protocol address */
  54. u_int16_t ar_op; /* one of: */
  55. #define ARPOP_REQUEST 1 /* request to resolve address */
  56. #define ARPOP_REPLY 2 /* response to previous request */
  57. #define ARPOP_REVREQUEST 3 /* request protocol address given hardware */
  58. #define ARPOP_REVREPLY 4 /* response giving protocol address */
  59. #define ARPOP_INVREQUEST 8 /* request to identify peer */
  60. #define ARPOP_INVREPLY 9 /* response identifying peer */
  61. /*
  62. * The remaining fields are variable in size,
  63. * according to the sizes above.
  64. */
  65. #ifdef COMMENT_ONLY
  66. u_int8_t ar_sha[]; /* sender hardware address */
  67. u_int8_t ar_spa[]; /* sender protocol address */
  68. u_int8_t ar_tha[]; /* target hardware address */
  69. u_int8_t ar_tpa[]; /* target protocol address */
  70. #endif
  71. };
  72. /*
  73. * ARP ioctl request
  74. */
  75. struct arpreq {
  76. struct sockaddr arp_pa; /* protocol address */
  77. struct sockaddr arp_ha; /* hardware address */
  78. int arp_flags; /* flags */
  79. };
  80. /* arp_flags and at_flags field values */
  81. #define ATF_INUSE 0x01 /* entry in use */
  82. #define ATF_COM 0x02 /* completed entry (enaddr valid) */
  83. #define ATF_PERM 0x04 /* permanent entry */
  84. #define ATF_PUBL 0x08 /* publish entry (respond for other host) */
  85. #define ATF_USETRAILERS 0x10 /* has requested trailers */
  86. #endif /* _NET_IF_ARP_H_ */