xref: /titanic_51/usr/src/uts/common/net/if_arp.h (revision 8a40a695ee676a322b094e9afe5375567bfb51e3)
1 /*
2  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
3  * Use is subject to license terms.
4  */
5 
6 /*
7  * Copyright (c) 1986 Regents of the University of California.
8  * All rights reserved.  The Berkeley software License Agreement
9  * specifies the terms and conditions for redistribution.
10  */
11 
12 #ifndef	_NET_IF_ARP_H
13 #define	_NET_IF_ARP_H
14 
15 #pragma ident	"%Z%%M%	%I%	%E% SMI"
16 /* if_arp.h 1.5 88/08/19 SMI; from UCB 7.1 1/24/86	*/
17 
18 #include <sys/types.h>
19 #include <sys/socket.h>
20 
21 #ifdef	__cplusplus
22 extern "C" {
23 #endif
24 
25 /*
26  * Address Resolution Protocol.
27  *
28  * See RFC 826 for protocol description.  ARP packets are variable
29  * in size; the arphdr structure defines the fixed-length portion.
30  * Protocol type values are the same as those for 10 Mb/s Ethernet.
31  * It is followed by the variable-sized fields ar_sha, arp_spa,
32  * arp_tha and arp_tpa in that order, according to the lengths
33  * specified.  Field names used correspond to RFC 826.
34  */
35 struct	arphdr {
36 	ushort_t ar_hrd;	/* format of hardware address */
37 #define	ARPHRD_ETHER 	1	/* ethernet hardware address */
38 #define	ARPHRD_IEEE802 	6	/* IEEE 802 hardware address */
39 #define	ARPHRD_IB	32	/* IPoIB hardware address */
40 	ushort_t ar_pro;	/* format of protocol address */
41 	uchar_t	ar_hln;		/* length of hardware address */
42 	uchar_t	ar_pln;		/* length of protocol address */
43 	ushort_t ar_op;		/* one of: */
44 #define	ARPOP_REQUEST	1	/* request to resolve address */
45 #define	ARPOP_REPLY	2	/* response to previous request */
46 #define	REVARP_REQUEST	3	/* Reverse ARP request */
47 #define	REVARP_REPLY	4	/* Reverse ARP reply */
48 	/*
49 	 * The remaining fields are variable in size,
50 	 * according to the sizes above, and are defined
51 	 * as appropriate for specific hardware/protocol
52 	 * combinations.  (E.g., see <netinet/if_ether.h>.)
53 	 */
54 #ifdef	notdef
55 	uchar_t	ar_sha[];	/* sender hardware address */
56 	uchar_t	ar_spa[];	/* sender protocol address */
57 	uchar_t	ar_tha[];	/* target hardware address */
58 	uchar_t	ar_tpa[];	/* target protocol address */
59 #endif	/* notdef */
60 };
61 
62 /* Maximum hardware and protocol address length */
63 #define	ARP_MAX_ADDR_LEN	255
64 
65 /*
66  * Extended ARP ioctl request
67  */
68 struct xarpreq {
69 	struct	sockaddr_storage xarp_pa;	/* protocol address */
70 	struct	sockaddr_dl	 xarp_ha;	/* hardware address */
71 	int	xarp_flags;			/* flags */
72 };
73 
74 /*
75  * BSD ARP ioctl request
76  */
77 struct arpreq {
78 	struct	sockaddr arp_pa;		/* protocol address */
79 	struct	sockaddr arp_ha;		/* hardware address */
80 	int	arp_flags;			/* flags */
81 };
82 /*  arp_flags field values */
83 #define	ATF_INUSE	0x01	/* entry in use */
84 #define	ATF_COM		0x02	/* completed entry (enaddr valid) */
85 #define	ATF_PERM	0x04	/* permanent entry */
86 #define	ATF_PUBL	0x08	/* publish entry (respond for other host) */
87 #define	ATF_USETRAILERS	0x10	/* has requested trailers */
88 #define	ATF_AUTHORITY	0x20	/* hardware address is authoritative */
89 
90 /*
91  * This data structure is used by kernel protocol modules to register
92  * their interest in a particular packet type with the Ethernet drivers.
93  * For example, other kinds of ARP would use this, XNS, ApleTalk, etc.
94  */
95 struct ether_family {
96 	int		ef_family;	/* address family */
97 	ushort_t	ef_ethertype;	/* ethernet type field */
98 	struct ifqueue *(*ef_infunc)();	/* input function */
99 	int		(*ef_outfunc)();	/* output function */
100 	int		(*ef_netisr)();	/* soft interrupt function */
101 	struct ether_family *ef_next;	/* link to next on list */
102 };
103 
104 #ifdef	__cplusplus
105 }
106 #endif
107 
108 #endif	/* _NET_IF_ARP_H */
109