1/* Definitions for Address Resolution Protocol.
2 Copyright (C) 1997-2022 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
4
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
9
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
14
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <https://www.gnu.org/licenses/>. */
18
19/* Based on the 4.4BSD and Linux version of this file. */
20
21#ifndef _NET_IF_ARP_H
22#define _NET_IF_ARP_H 1
23
24#include <sys/types.h>
25#include <sys/socket.h>
26#include <stdint.h>
27
28__BEGIN_DECLS
29
30/* Some internals from deep down in the kernel. */
31#define MAX_ADDR_LEN 7
32
33
34/* This structure defines an ethernet arp header. */
35
36/* ARP protocol opcodes. */
37#define ARPOP_REQUEST 1 /* ARP request. */
38#define ARPOP_REPLY 2 /* ARP reply. */
39#define ARPOP_RREQUEST 3 /* RARP request. */
40#define ARPOP_RREPLY 4 /* RARP reply. */
41#define ARPOP_InREQUEST 8 /* InARP request. */
42#define ARPOP_InREPLY 9 /* InARP reply. */
43#define ARPOP_NAK 10 /* (ATM)ARP NAK. */
44
45/* See RFC 826 for protocol description. ARP packets are variable
46 in size; the arphdr structure defines the fixed-length portion.
47 Protocol type values are the same as those for 10 Mb/s Ethernet.
48 It is followed by the variable-sized fields ar_sha, arp_spa,
49 arp_tha and arp_tpa in that order, according to the lengths
50 specified. Field names used correspond to RFC 826. */
51
52struct arphdr
53 {
54 unsigned short int ar_hrd; /* Format of hardware address. */
55 unsigned short int ar_pro; /* Format of protocol address. */
56 unsigned char ar_hln; /* Length of hardware address. */
57 unsigned char ar_pln; /* Length of protocol address. */
58 unsigned short int ar_op; /* ARP opcode (command). */
59#if 0
60 /* Ethernet looks like this : This bit is variable sized
61 however... */
62 unsigned char __ar_sha[ETH_ALEN]; /* Sender hardware address. */
63 unsigned char __ar_sip[4]; /* Sender IP address. */
64 unsigned char __ar_tha[ETH_ALEN]; /* Target hardware address. */
65 unsigned char __ar_tip[4]; /* Target IP address. */
66#endif
67 };
68
69
70/* ARP protocol HARDWARE identifiers. */
71#define ARPHRD_NETROM 0 /* From KA9Q: NET/ROM pseudo. */
72#define ARPHRD_ETHER 1 /* Ethernet 10/100Mbps. */
73#define ARPHRD_EETHER 2 /* Experimental Ethernet. */
74#define ARPHRD_AX25 3 /* AX.25 Level 2. */
75#define ARPHRD_PRONET 4 /* PROnet token ring. */
76#define ARPHRD_CHAOS 5 /* Chaosnet. */
77#define ARPHRD_IEEE802 6 /* IEEE 802.2 Ethernet/TR/TB. */
78#define ARPHRD_ARCNET 7 /* ARCnet. */
79#define ARPHRD_APPLETLK 8 /* APPLEtalk. */
80#define ARPHRD_DLCI 15 /* Frame Relay DLCI. */
81#define ARPHRD_ATM 19 /* ATM. */
82#define ARPHRD_METRICOM 23 /* Metricom STRIP (new IANA id). */
83#define ARPHRD_IEEE1394 24 /* IEEE 1394 IPv4 - RFC 2734. */
84#define ARPHRD_EUI64 27 /* EUI-64. */
85#define ARPHRD_INFINIBAND 32 /* InfiniBand. */
86
87/* Dummy types for non ARP hardware */
88#define ARPHRD_SLIP 256
89#define ARPHRD_CSLIP 257
90#define ARPHRD_SLIP6 258
91#define ARPHRD_CSLIP6 259
92#define ARPHRD_RSRVD 260 /* Notional KISS type. */
93#define ARPHRD_ADAPT 264
94#define ARPHRD_ROSE 270
95#define ARPHRD_X25 271 /* CCITT X.25. */
96#define ARPHRD_HWX25 272 /* Boards with X.25 in firmware. */
97#define ARPHRD_CAN 280 /* Controller Area Network. */
98#define ARPHRD_MCTP 290
99#define ARPHRD_PPP 512
100#define ARPHRD_CISCO 513 /* Cisco HDLC. */
101#define ARPHRD_HDLC ARPHRD_CISCO
102#define ARPHRD_LAPB 516 /* LAPB. */
103#define ARPHRD_DDCMP 517 /* Digital's DDCMP. */
104#define ARPHRD_RAWHDLC 518 /* Raw HDLC. */
105#define ARPHRD_RAWIP 519 /* Raw IP. */
106
107#define ARPHRD_TUNNEL 768 /* IPIP tunnel. */
108#define ARPHRD_TUNNEL6 769 /* IPIP6 tunnel. */
109#define ARPHRD_FRAD 770 /* Frame Relay Access Device. */
110#define ARPHRD_SKIP 771 /* SKIP vif. */
111#define ARPHRD_LOOPBACK 772 /* Loopback device. */
112#define ARPHRD_LOCALTLK 773 /* Localtalk device. */
113#define ARPHRD_FDDI 774 /* Fiber Distributed Data Interface. */
114#define ARPHRD_BIF 775 /* AP1000 BIF. */
115#define ARPHRD_SIT 776 /* sit0 device - IPv6-in-IPv4. */
116#define ARPHRD_IPDDP 777 /* IP-in-DDP tunnel. */
117#define ARPHRD_IPGRE 778 /* GRE over IP. */
118#define ARPHRD_PIMREG 779 /* PIMSM register interface. */
119#define ARPHRD_HIPPI 780 /* High Performance Parallel I'face. */
120#define ARPHRD_ASH 781 /* (Nexus Electronics) Ash. */
121#define ARPHRD_ECONET 782 /* Acorn Econet. */
122#define ARPHRD_IRDA 783 /* Linux-IrDA. */
123#define ARPHRD_FCPP 784 /* Point to point fibrechanel. */
124#define ARPHRD_FCAL 785 /* Fibrechanel arbitrated loop. */
125#define ARPHRD_FCPL 786 /* Fibrechanel public loop. */
126#define ARPHRD_FCFABRIC 787 /* Fibrechanel fabric. */
127#define ARPHRD_IEEE802_TR 800 /* Magic type ident for TR. */
128#define ARPHRD_IEEE80211 801 /* IEEE 802.11. */
129#define ARPHRD_IEEE80211_PRISM 802 /* IEEE 802.11 + Prism2 header. */
130#define ARPHRD_IEEE80211_RADIOTAP 803 /* IEEE 802.11 + radiotap header. */
131#define ARPHRD_IEEE802154 804 /* IEEE 802.15.4 header. */
132#define ARPHRD_IEEE802154_PHY 805 /* IEEE 802.15.4 PHY header. */
133
134#define ARPHRD_VOID 0xFFFF /* Void type, nothing is known. */
135#define ARPHRD_NONE 0xFFFE /* Zero header length. */
136
137
138/* ARP ioctl request. */
139struct arpreq
140 {
141 struct sockaddr arp_pa; /* Protocol address. */
142 struct sockaddr arp_ha; /* Hardware address. */
143 int arp_flags; /* Flags. */
144 struct sockaddr arp_netmask; /* Netmask (only for proxy arps). */
145 char arp_dev[16];
146 };
147
148struct arpreq_old
149 {
150 struct sockaddr arp_pa; /* Protocol address. */
151 struct sockaddr arp_ha; /* Hardware address. */
152 int arp_flags; /* Flags. */
153 struct sockaddr arp_netmask; /* Netmask (only for proxy arps). */
154 };
155
156/* ARP Flag values. */
157#define ATF_COM 0x02 /* Completed entry (ha valid). */
158#define ATF_PERM 0x04 /* Permanent entry. */
159#define ATF_PUBL 0x08 /* Publish entry. */
160#define ATF_USETRAILERS 0x10 /* Has requested trailers. */
161#define ATF_NETMASK 0x20 /* Want to use a netmask (only
162 for proxy entries). */
163#define ATF_DONTPUB 0x40 /* Don't answer this addresses. */
164#define ATF_MAGIC 0x80 /* Automatically added entry. */
165
166
167/* Support for the user space arp daemon, arpd. */
168#define ARPD_UPDATE 0x01
169#define ARPD_LOOKUP 0x02
170#define ARPD_FLUSH 0x03
171
172struct arpd_request
173 {
174 unsigned short int req; /* Request type. */
175 uint32_t ip; /* IP address of entry. */
176 unsigned long int dev; /* Device entry is tied to. */
177 unsigned long int stamp;
178 unsigned long int updated;
179 unsigned char ha[MAX_ADDR_LEN]; /* Hardware address. */
180 };
181
182__END_DECLS
183
184#endif /* net/if_arp.h */
185