1 /* 2 * INET An implementation of the TCP/IP protocol suite for the LINUX 3 * operating system. INET is implemented using the BSD Socket 4 * interface as the means of communication with the user level. 5 * 6 * Global definitions for the ARP (RFC 826) protocol. 7 * 8 * Version: @(#)if_arp.h 1.0.1 04/16/93 9 * 10 * Authors: Original taken from Berkeley UNIX 4.3, (c) UCB 1986-1988 11 * Portions taken from the KA9Q/NOS (v2.00m PA0GRI) source. 12 * Ross Biro, <bir7@leland.Stanford.Edu> 13 * Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG> 14 * 15 * This program is free software; you can redistribute it and/or 16 * modify it under the terms of the GNU General Public License 17 * as published by the Free Software Foundation; either version 18 * 2 of the License, or (at your option) any later version. 19 */ 20 #ifndef _LINUX_IF_ARP_H 21 #define _LINUX_IF_ARP_H 22 23 /* ARP protocol HARDWARE identifiers. */ 24 #define ARPHRD_NETROM 0 /* from KA9Q: NET/ROM pseudo */ 25 #define ARPHRD_ETHER 1 /* Ethernet 10Mbps */ 26 #define ARPHRD_EETHER 2 /* Experimental Ethernet */ 27 #define ARPHRD_AX25 3 /* AX.25 Level 2 */ 28 #define ARPHRD_PRONET 4 /* PROnet token ring */ 29 #define ARPHRD_CHAOS 5 /* Chaosnet */ 30 #define ARPHRD_IEEE802 6 /* IEEE 802.2 Ethernet- huh? */ 31 #define ARPHRD_ARCNET 7 /* ARCnet */ 32 #define ARPHRD_APPLETLK 8 /* APPLEtalk */ 33 34 /* ARP protocol opcodes. */ 35 #define ARPOP_REQUEST 1 /* ARP request */ 36 #define ARPOP_REPLY 2 /* ARP reply */ 37 #define ARPOP_RREQUEST 3 /* RARP request */ 38 #define ARPOP_RREPLY 4 /* RARP reply */ 39 40 41 /* 42 * Address Resolution Protocol. 43 * 44 * See RFC 826 for protocol description. ARP packets are variable 45 * in size; the arphdr structure defines the fixed-length portion. 46 * Protocol type values are the same as those for 10 Mb/s Ethernet. 47 * It is followed by the variable-sized fields ar_sha, arp_spa, 48 * arp_tha and arp_tpa in that order, according to the lengths 49 * specified. Field names used correspond to RFC 826. 50 */ 51 struct arphdr { 52 unsigned short ar_hrd; /* format of hardware address */ 53 unsigned short ar_pro; /* format of protocol address */ 54 unsigned char ar_hln; /* length of hardware address */ 55 unsigned char ar_pln; /* length of protocol address */ 56 unsigned short ar_op; /* ARP opcode (command) */ 57 58 /* The rest is variable in size, according to the sizes above. */ 59 #if 0 60 unsigned char ar_sha[]; /* sender hardware address */ 61 unsigned char ar_spa[]; /* sender protocol address */ 62 unsigned char ar_tha[]; /* target hardware address */ 63 unsigned char ar_tpa[]; /* target protocol address */ 64 #endif /* not actually included! */ 65 }; 66 67 68 /* ARP ioctl request. */ 69 struct arpreq { 70 struct sockaddr arp_pa; /* protocol address */ 71 struct sockaddr arp_ha; /* hardware address */ 72 int arp_flags; /* flags */ 73 }; 74 75 /* ARP Flag values. */ 76 #define ATF_INUSE 0x01 /* entry in use */ 77 #define ATF_COM 0x02 /* completed entry (ha valid) */ 78 #define ATF_PERM 0x04 /* permanent entry */ 79 #define ATF_PUBL 0x08 /* publish entry */ 80 #define ATF_USETRAILERS 0x10 /* has requested trailers */ 81 82 83 #endif /* _LINUX_IF_ARP_H */