1*53ee8cc1Swenshuai.xi /* 2*53ee8cc1Swenshuai.xi * INET An implementation of the TCP/IP protocol suite for the LINUX 3*53ee8cc1Swenshuai.xi * operating system. INET is implemented using the BSD Socket 4*53ee8cc1Swenshuai.xi * interface as the means of communication with the user level. 5*53ee8cc1Swenshuai.xi * 6*53ee8cc1Swenshuai.xi * Global definitions for the ARP (RFC 826) protocol. 7*53ee8cc1Swenshuai.xi * 8*53ee8cc1Swenshuai.xi * Version: @(#)if_arp.h 1.0.1 04/16/93 9*53ee8cc1Swenshuai.xi * 10*53ee8cc1Swenshuai.xi * Authors: Original taken from Berkeley UNIX 4.3, (c) UCB 1986-1988 11*53ee8cc1Swenshuai.xi * Portions taken from the KA9Q/NOS (v2.00m PA0GRI) source. 12*53ee8cc1Swenshuai.xi * Ross Biro 13*53ee8cc1Swenshuai.xi * Fred N. van Kempen, <waltje@uWalt.NL.Mugnet.ORG> 14*53ee8cc1Swenshuai.xi * Florian La Roche, 15*53ee8cc1Swenshuai.xi * Jonathan Layes <layes@loran.com> 16*53ee8cc1Swenshuai.xi * Arnaldo Carvalho de Melo <acme@conectiva.com.br> ARPHRD_HWX25 17*53ee8cc1Swenshuai.xi * 18*53ee8cc1Swenshuai.xi * This program is free software; you can redistribute it and/or 19*53ee8cc1Swenshuai.xi * modify it under the terms of the GNU General Public License 20*53ee8cc1Swenshuai.xi * as published by the Free Software Foundation; either version 21*53ee8cc1Swenshuai.xi * 2 of the License, or (at your option) any later version. 22*53ee8cc1Swenshuai.xi */ 23*53ee8cc1Swenshuai.xi #ifndef _LINUX_IF_ARP_H 24*53ee8cc1Swenshuai.xi #define _LINUX_IF_ARP_H 25*53ee8cc1Swenshuai.xi 26*53ee8cc1Swenshuai.xi #include <linux/netdevice.h> 27*53ee8cc1Swenshuai.xi 28*53ee8cc1Swenshuai.xi /* ARP protocol HARDWARE identifiers. */ 29*53ee8cc1Swenshuai.xi #define ARPHRD_NETROM 0 /* from KA9Q: NET/ROM pseudo */ 30*53ee8cc1Swenshuai.xi #define ARPHRD_ETHER 1 /* Ethernet 10Mbps */ 31*53ee8cc1Swenshuai.xi #define ARPHRD_EETHER 2 /* Experimental Ethernet */ 32*53ee8cc1Swenshuai.xi #define ARPHRD_AX25 3 /* AX.25 Level 2 */ 33*53ee8cc1Swenshuai.xi #define ARPHRD_PRONET 4 /* PROnet token ring */ 34*53ee8cc1Swenshuai.xi #define ARPHRD_CHAOS 5 /* Chaosnet */ 35*53ee8cc1Swenshuai.xi #define ARPHRD_IEEE802 6 /* IEEE 802.2 Ethernet/TR/TB */ 36*53ee8cc1Swenshuai.xi #define ARPHRD_ARCNET 7 /* ARCnet */ 37*53ee8cc1Swenshuai.xi #define ARPHRD_APPLETLK 8 /* APPLEtalk */ 38*53ee8cc1Swenshuai.xi #define ARPHRD_DLCI 15 /* Frame Relay DLCI */ 39*53ee8cc1Swenshuai.xi #define ARPHRD_ATM 19 /* ATM */ 40*53ee8cc1Swenshuai.xi #define ARPHRD_METRICOM 23 /* Metricom STRIP (new IANA id) */ 41*53ee8cc1Swenshuai.xi #define ARPHRD_IEEE1394 24 /* IEEE 1394 IPv4 - RFC 2734 */ 42*53ee8cc1Swenshuai.xi #define ARPHRD_EUI64 27 /* EUI-64 */ 43*53ee8cc1Swenshuai.xi #define ARPHRD_INFINIBAND 32 /* InfiniBand */ 44*53ee8cc1Swenshuai.xi 45*53ee8cc1Swenshuai.xi /* Dummy types for non ARP hardware */ 46*53ee8cc1Swenshuai.xi #define ARPHRD_SLIP 256 47*53ee8cc1Swenshuai.xi #define ARPHRD_CSLIP 257 48*53ee8cc1Swenshuai.xi #define ARPHRD_SLIP6 258 49*53ee8cc1Swenshuai.xi #define ARPHRD_CSLIP6 259 50*53ee8cc1Swenshuai.xi #define ARPHRD_RSRVD 260 /* Notional KISS type */ 51*53ee8cc1Swenshuai.xi #define ARPHRD_ADAPT 264 52*53ee8cc1Swenshuai.xi #define ARPHRD_ROSE 270 53*53ee8cc1Swenshuai.xi #define ARPHRD_X25 271 /* CCITT X.25 */ 54*53ee8cc1Swenshuai.xi #define ARPHRD_HWX25 272 /* Boards with X.25 in firmware */ 55*53ee8cc1Swenshuai.xi #define ARPHRD_CAN 280 /* Controller Area Network */ 56*53ee8cc1Swenshuai.xi #define ARPHRD_PPP 512 57*53ee8cc1Swenshuai.xi #define ARPHRD_CISCO 513 /* Cisco HDLC */ 58*53ee8cc1Swenshuai.xi #define ARPHRD_HDLC ARPHRD_CISCO 59*53ee8cc1Swenshuai.xi #define ARPHRD_LAPB 516 /* LAPB */ 60*53ee8cc1Swenshuai.xi #define ARPHRD_DDCMP 517 /* Digital's DDCMP protocol */ 61*53ee8cc1Swenshuai.xi #define ARPHRD_RAWHDLC 518 /* Raw HDLC */ 62*53ee8cc1Swenshuai.xi 63*53ee8cc1Swenshuai.xi #define ARPHRD_TUNNEL 768 /* IPIP tunnel */ 64*53ee8cc1Swenshuai.xi #define ARPHRD_TUNNEL6 769 /* IP6IP6 tunnel */ 65*53ee8cc1Swenshuai.xi #define ARPHRD_FRAD 770 /* Frame Relay Access Device */ 66*53ee8cc1Swenshuai.xi #define ARPHRD_SKIP 771 /* SKIP vif */ 67*53ee8cc1Swenshuai.xi #define ARPHRD_LOOPBACK 772 /* Loopback device */ 68*53ee8cc1Swenshuai.xi #define ARPHRD_LOCALTLK 773 /* Localtalk device */ 69*53ee8cc1Swenshuai.xi #define ARPHRD_FDDI 774 /* Fiber Distributed Data Interface */ 70*53ee8cc1Swenshuai.xi #define ARPHRD_BIF 775 /* AP1000 BIF */ 71*53ee8cc1Swenshuai.xi #define ARPHRD_SIT 776 /* sit0 device - IPv6-in-IPv4 */ 72*53ee8cc1Swenshuai.xi #define ARPHRD_IPDDP 777 /* IP over DDP tunneller */ 73*53ee8cc1Swenshuai.xi #define ARPHRD_IPGRE 778 /* GRE over IP */ 74*53ee8cc1Swenshuai.xi #define ARPHRD_PIMREG 779 /* PIMSM register interface */ 75*53ee8cc1Swenshuai.xi #define ARPHRD_HIPPI 780 /* High Performance Parallel Interface */ 76*53ee8cc1Swenshuai.xi #define ARPHRD_ASH 781 /* Nexus 64Mbps Ash */ 77*53ee8cc1Swenshuai.xi #define ARPHRD_ECONET 782 /* Acorn Econet */ 78*53ee8cc1Swenshuai.xi #define ARPHRD_IRDA 783 /* Linux-IrDA */ 79*53ee8cc1Swenshuai.xi /* ARP works differently on different FC media .. so */ 80*53ee8cc1Swenshuai.xi #define ARPHRD_FCPP 784 /* Point to point fibrechannel */ 81*53ee8cc1Swenshuai.xi #define ARPHRD_FCAL 785 /* Fibrechannel arbitrated loop */ 82*53ee8cc1Swenshuai.xi #define ARPHRD_FCPL 786 /* Fibrechannel public loop */ 83*53ee8cc1Swenshuai.xi #define ARPHRD_FCFABRIC 787 /* Fibrechannel fabric */ 84*53ee8cc1Swenshuai.xi /* 787->799 reserved for fibrechannel media types */ 85*53ee8cc1Swenshuai.xi #define ARPHRD_IEEE802_TR 800 /* Magic type ident for TR */ 86*53ee8cc1Swenshuai.xi #define ARPHRD_IEEE80211 801 /* IEEE 802.11 */ 87*53ee8cc1Swenshuai.xi #define ARPHRD_IEEE80211_PRISM 802 /* IEEE 802.11 + Prism2 header */ 88*53ee8cc1Swenshuai.xi #define ARPHRD_IEEE80211_RADIOTAP 803 /* IEEE 802.11 + radiotap header */ 89*53ee8cc1Swenshuai.xi 90*53ee8cc1Swenshuai.xi #define ARPHRD_VOID 0xFFFF /* Void type, nothing is known */ 91*53ee8cc1Swenshuai.xi #define ARPHRD_NONE 0xFFFE /* zero header length */ 92*53ee8cc1Swenshuai.xi 93*53ee8cc1Swenshuai.xi /* ARP protocol opcodes. */ 94*53ee8cc1Swenshuai.xi #define ARPOP_REQUEST 1 /* ARP request */ 95*53ee8cc1Swenshuai.xi #define ARPOP_REPLY 2 /* ARP reply */ 96*53ee8cc1Swenshuai.xi #define ARPOP_RREQUEST 3 /* RARP request */ 97*53ee8cc1Swenshuai.xi #define ARPOP_RREPLY 4 /* RARP reply */ 98*53ee8cc1Swenshuai.xi #define ARPOP_InREQUEST 8 /* InARP request */ 99*53ee8cc1Swenshuai.xi #define ARPOP_InREPLY 9 /* InARP reply */ 100*53ee8cc1Swenshuai.xi #define ARPOP_NAK 10 /* (ATM)ARP NAK */ 101*53ee8cc1Swenshuai.xi 102*53ee8cc1Swenshuai.xi 103*53ee8cc1Swenshuai.xi /* ARP ioctl request. */ 104*53ee8cc1Swenshuai.xi struct arpreq { 105*53ee8cc1Swenshuai.xi struct sockaddr arp_pa; /* protocol address */ 106*53ee8cc1Swenshuai.xi struct sockaddr arp_ha; /* hardware address */ 107*53ee8cc1Swenshuai.xi int arp_flags; /* flags */ 108*53ee8cc1Swenshuai.xi struct sockaddr arp_netmask; /* netmask (only for proxy arps) */ 109*53ee8cc1Swenshuai.xi char arp_dev[16]; 110*53ee8cc1Swenshuai.xi }; 111*53ee8cc1Swenshuai.xi 112*53ee8cc1Swenshuai.xi struct arpreq_old { 113*53ee8cc1Swenshuai.xi struct sockaddr arp_pa; /* protocol address */ 114*53ee8cc1Swenshuai.xi struct sockaddr arp_ha; /* hardware address */ 115*53ee8cc1Swenshuai.xi int arp_flags; /* flags */ 116*53ee8cc1Swenshuai.xi struct sockaddr arp_netmask; /* netmask (only for proxy arps) */ 117*53ee8cc1Swenshuai.xi }; 118*53ee8cc1Swenshuai.xi 119*53ee8cc1Swenshuai.xi /* ARP Flag values. */ 120*53ee8cc1Swenshuai.xi #define ATF_COM 0x02 /* completed entry (ha valid) */ 121*53ee8cc1Swenshuai.xi #define ATF_PERM 0x04 /* permanent entry */ 122*53ee8cc1Swenshuai.xi #define ATF_PUBL 0x08 /* publish entry */ 123*53ee8cc1Swenshuai.xi #define ATF_USETRAILERS 0x10 /* has requested trailers */ 124*53ee8cc1Swenshuai.xi #define ATF_NETMASK 0x20 /* want to use a netmask (only 125*53ee8cc1Swenshuai.xi for proxy entries) */ 126*53ee8cc1Swenshuai.xi #define ATF_DONTPUB 0x40 /* don't answer this addresses */ 127*53ee8cc1Swenshuai.xi 128*53ee8cc1Swenshuai.xi /* 129*53ee8cc1Swenshuai.xi * This structure defines an ethernet arp header. 130*53ee8cc1Swenshuai.xi */ 131*53ee8cc1Swenshuai.xi 132*53ee8cc1Swenshuai.xi struct arphdr 133*53ee8cc1Swenshuai.xi { 134*53ee8cc1Swenshuai.xi __be16 ar_hrd; /* format of hardware address */ 135*53ee8cc1Swenshuai.xi __be16 ar_pro; /* format of protocol address */ 136*53ee8cc1Swenshuai.xi unsigned char ar_hln; /* length of hardware address */ 137*53ee8cc1Swenshuai.xi unsigned char ar_pln; /* length of protocol address */ 138*53ee8cc1Swenshuai.xi __be16 ar_op; /* ARP opcode (command) */ 139*53ee8cc1Swenshuai.xi 140*53ee8cc1Swenshuai.xi #if 0 141*53ee8cc1Swenshuai.xi /* 142*53ee8cc1Swenshuai.xi * Ethernet looks like this : This bit is variable sized however... 143*53ee8cc1Swenshuai.xi */ 144*53ee8cc1Swenshuai.xi unsigned char ar_sha[ETH_ALEN]; /* sender hardware address */ 145*53ee8cc1Swenshuai.xi unsigned char ar_sip[4]; /* sender IP address */ 146*53ee8cc1Swenshuai.xi unsigned char ar_tha[ETH_ALEN]; /* target hardware address */ 147*53ee8cc1Swenshuai.xi unsigned char ar_tip[4]; /* target IP address */ 148*53ee8cc1Swenshuai.xi #endif 149*53ee8cc1Swenshuai.xi 150*53ee8cc1Swenshuai.xi }; 151*53ee8cc1Swenshuai.xi 152*53ee8cc1Swenshuai.xi 153*53ee8cc1Swenshuai.xi #endif /* _LINUX_IF_ARP_H */ 154