if_arp.h
上传用户:luoyougen
上传日期:2008-05-12
资源大小:23136k
文件大小:5k
源码类别:

VxWorks

开发平台:

C/C++

  1. /* if_arp.h - network interface address resolution protocol header file */
  2. /* Copyright 1984 - 2001 Wind River Systems, Inc. */
  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. All advertising materials mentioning features or use of this software
  16.  *    must display the following acknowledgement:
  17.  * This product includes software developed by the University of
  18.  * California, Berkeley and its contributors.
  19.  * 4. Neither the name of the University nor the names of its contributors
  20.  *    may be used to endorse or promote products derived from this software
  21.  *    without specific prior written permission.
  22.  *
  23.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  24.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  25.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  26.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  27.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  28.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  29.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  30.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  31.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  32.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  33.  * SUCH DAMAGE.
  34.  *
  35.  * @(#)if_arp.h 8.1 (Berkeley) 6/10/93
  36.  */
  37. /*
  38. modification history
  39. --------------------
  40. 01d,10oct01,rae  merge from truestack (ATF_INCOMPLETE)
  41. 01c,07feb01,spm  added merge record for 30jan01 update from version 01b of
  42.                  tor2_0_x branch (base 01a) and fixed modification history
  43. 01b,30jan01,ijm  merged SPR# 28602 fixes: proxy ARP services are obsolete 
  44. 01a,03mar96,vin  created from BSD4.4 stuff,integrated with 02h of if_arp.h
  45. */
  46. #ifndef __INCif_arph
  47. #define __INCif_arph
  48. #ifdef __cplusplus
  49. extern "C" {
  50. #endif
  51. #if ((CPU_FAMILY==I960) && (defined __GNUC__))
  52. #pragma align 1                 /* tell gcc960 not to optimize alignments */
  53. #endif /* CPU_FAMILY==I960 */
  54. /*
  55.  * Address Resolution Protocol.
  56.  *
  57.  * See RFC 826 for protocol description.  ARP packets are variable
  58.  * in size; the arphdr structure defines the fixed-length portion.
  59.  * Protocol type values are the same as those for 10 Mb/s Ethernet.
  60.  * It is followed by the variable-sized fields ar_sha, arp_spa,
  61.  * arp_tha and arp_tpa in that order, according to the lengths
  62.  * specified.  Field names used correspond to RFC 826.
  63.  */
  64. struct arphdr {
  65. u_short ar_hrd; /* format of hardware address */
  66. #define ARPHRD_ETHER  1 /* ethernet hardware format */
  67. #define ARPHRD_FRELAY  15 /* frame relay hardware format */
  68. u_short ar_pro; /* format of protocol address */
  69. u_char ar_hln; /* length of hardware address */
  70. u_char ar_pln; /* length of protocol address */
  71. u_short ar_op; /* one of: */
  72. #define ARPOP_REQUEST 1 /* request to resolve address */
  73. #define ARPOP_REPLY 2 /* response to previous request */
  74. #define ARPOP_REVREQUEST 3 /* request protocol address given hardware */
  75. #define ARPOP_REVREPLY 4 /* response giving protocol address */
  76. #define ARPOP_INVREQUEST 8  /* request to identify peer */
  77. #define ARPOP_INVREPLY 9 /* response identifying peer */
  78. /*
  79.  * The remaining fields are variable in size,
  80.  * according to the sizes above.
  81.  */
  82. #ifdef COMMENT_ONLY
  83. u_char ar_sha[]; /* sender hardware address */
  84. u_char ar_spa[]; /* sender protocol address */
  85. u_char ar_tha[]; /* target hardware address */
  86. u_char ar_tpa[]; /* target protocol address */
  87. #endif
  88. };
  89. /*
  90.  * ARP ioctl request
  91.  */
  92. struct arpreq {
  93. struct sockaddr arp_pa; /* protocol address */
  94. struct sockaddr arp_ha; /* hardware address */
  95. int arp_flags; /* flags */
  96. };
  97. /*  arp_flags and at_flags field values */
  98. #define ATF_INUSE 0x01 /* entry in use */
  99. #define ATF_COM 0x02 /* completed entry (enaddr valid) */
  100. #define ATF_PERM 0x04 /* permanent entry */
  101. #define ATF_PUBL 0x08 /* publish entry (respond for other host) */
  102. #define ATF_PROXY 0x10 /* proxy server entry (wildcard h/w address) */
  103. #define ATF_INCOMPLETE 0x20 /* Complete a host entry */
  104. #if ((CPU_FAMILY==I960) && (defined __GNUC__))
  105. #pragma align 0                 /* turn off alignment requirement */
  106. #endif /* CPU_FAMILY==I960 */
  107. #ifdef __cplusplus
  108. }
  109. #endif
  110. #endif /* __INCif_arph */