if_inarp.h revision 1.25.2.1 1 1.25.2.1 is /* $NetBSD: if_inarp.h,v 1.25.2.1 1997/02/07 18:08:59 is Exp $ */
2 1.10 cgd
3 1.1 cgd /*
4 1.9 mycroft * Copyright (c) 1982, 1986, 1993
5 1.9 mycroft * The Regents of the University of California. All rights reserved.
6 1.1 cgd *
7 1.1 cgd * Redistribution and use in source and binary forms, with or without
8 1.1 cgd * modification, are permitted provided that the following conditions
9 1.1 cgd * are met:
10 1.1 cgd * 1. Redistributions of source code must retain the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer.
12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 cgd * notice, this list of conditions and the following disclaimer in the
14 1.1 cgd * documentation and/or other materials provided with the distribution.
15 1.1 cgd * 3. All advertising materials mentioning features or use of this software
16 1.1 cgd * must display the following acknowledgement:
17 1.1 cgd * This product includes software developed by the University of
18 1.1 cgd * California, Berkeley and its contributors.
19 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
20 1.1 cgd * may be used to endorse or promote products derived from this software
21 1.1 cgd * without specific prior written permission.
22 1.1 cgd *
23 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 cgd * SUCH DAMAGE.
34 1.1 cgd *
35 1.10 cgd * @(#)if_ether.h 8.1 (Berkeley) 6/10/93
36 1.1 cgd */
37 1.1 cgd
38 1.6 deraadt /*
39 1.1 cgd * Ethernet Address Resolution Protocol.
40 1.1 cgd *
41 1.1 cgd * See RFC 826 for protocol description. Structure below is adapted
42 1.1 cgd * to resolving internet addresses. Field names used correspond to
43 1.1 cgd * RFC 826.
44 1.1 cgd */
45 1.1 cgd struct ether_arp {
46 1.18 cgd struct arphdr ea_hdr; /* fixed-size header */
47 1.18 cgd u_int8_t arp_sha[ETHER_ADDR_LEN]; /* sender hardware address */
48 1.18 cgd u_int8_t arp_spa[4]; /* sender protocol address */
49 1.18 cgd u_int8_t arp_tha[ETHER_ADDR_LEN]; /* target hardware address */
50 1.18 cgd u_int8_t arp_tpa[4]; /* target protocol address */
51 1.1 cgd };
52 1.1 cgd #define arp_hrd ea_hdr.ar_hrd
53 1.1 cgd #define arp_pro ea_hdr.ar_pro
54 1.1 cgd #define arp_hln ea_hdr.ar_hln
55 1.1 cgd #define arp_pln ea_hdr.ar_pln
56 1.1 cgd #define arp_op ea_hdr.ar_op
57 1.1 cgd
58 1.9 mycroft struct llinfo_arp {
59 1.20 mycroft LIST_ENTRY(llinfo_arp) la_list;
60 1.9 mycroft struct rtentry *la_rt;
61 1.9 mycroft struct mbuf *la_hold; /* last packet until resolved/timeout */
62 1.9 mycroft long la_asked; /* last time we QUERIED for this addr */
63 1.9 mycroft #define la_timer la_rt->rt_rmx.rmx_expire /* deletion time in seconds */
64 1.9 mycroft };
65 1.9 mycroft
66 1.9 mycroft struct sockaddr_inarp {
67 1.16 cgd u_int8_t sin_len;
68 1.16 cgd u_int8_t sin_family;
69 1.16 cgd u_int16_t sin_port;
70 1.16 cgd struct in_addr sin_addr;
71 1.16 cgd struct in_addr sin_srcaddr;
72 1.16 cgd u_int16_t sin_tos;
73 1.16 cgd u_int16_t sin_other;
74 1.9 mycroft #define SIN_PROXY 1
75 1.1 cgd };
76 1.1 cgd
77 1.1 cgd /*
78 1.9 mycroft * IP and ethernet specific routing flags
79 1.1 cgd */
80 1.9 mycroft #define RTF_USETRAILERS RTF_PROTO1 /* use trailers */
81 1.9 mycroft #define RTF_ANNOUNCE RTF_PROTO2 /* announce new arp entry */
82 1.1 cgd
83 1.14 briggs #ifdef _KERNEL
84 1.9 mycroft struct ifqueue arpintrq;
85 1.9 mycroft
86 1.25.2.1 is void arpwhohas __P((struct ifnet *, struct in_addr *));
87 1.9 mycroft void arpintr __P((void));
88 1.25.2.1 is int arpresolve __P((struct ifnet *,
89 1.17 cgd struct rtentry *, struct mbuf *, struct sockaddr *, u_char *));
90 1.25.2.1 is void arp_ifinit __P((struct ifnet *, struct ifaddr *));
91 1.9 mycroft void arp_rtrequest __P((int, struct rtentry *, struct sockaddr *));
92 1.9 mycroft
93 1.18 cgd #endif /* _KERNEL */
94 1.5 hpeyerl
95 1.21 christos #ifdef _KERNEL
96 1.21 christos void arp_rtrequest __P((int, struct rtentry *, struct sockaddr *));
97 1.25.2.1 is int arpresolve __P((struct ifnet *, struct rtentry *, struct mbuf *,
98 1.21 christos struct sockaddr *, u_char *));
99 1.21 christos void arpintr __P((void));
100 1.21 christos int arpioctl __P((u_long, caddr_t));
101 1.25.2.1 is void arp_ifinit __P((struct ifnet *, struct ifaddr *));
102 1.21 christos void revarpinput __P((struct mbuf *));
103 1.21 christos void in_revarpinput __P((struct mbuf *));
104 1.21 christos void revarprequest __P((struct ifnet *));
105 1.21 christos int revarpwhoarewe __P((struct ifnet *, struct in_addr *, struct in_addr *));
106 1.21 christos int revarpwhoami __P((struct in_addr *, struct ifnet *));
107 1.21 christos int db_show_arptab __P((void));
108 1.21 christos #endif
109