xref: /illumos-gate/usr/src/uts/common/net/route.h (revision 7c478bd9)
1*7c478bd9Sstevel@tonic-gate /*
2*7c478bd9Sstevel@tonic-gate  * Copyright 1992-2002 Sun Microsystems, Inc.  All rights reserved.
3*7c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
4*7c478bd9Sstevel@tonic-gate  */
5*7c478bd9Sstevel@tonic-gate /*
6*7c478bd9Sstevel@tonic-gate  * Copyright (c) 1980, 1986, 1993
7*7c478bd9Sstevel@tonic-gate  *	The Regents of the University of California.  All rights reserved.
8*7c478bd9Sstevel@tonic-gate  *
9*7c478bd9Sstevel@tonic-gate  * Redistribution and use in source and binary forms, with or without
10*7c478bd9Sstevel@tonic-gate  * modification, are permitted provided that the following conditions
11*7c478bd9Sstevel@tonic-gate  * are met:
12*7c478bd9Sstevel@tonic-gate  * 1. Redistributions of source code must retain the above copyright
13*7c478bd9Sstevel@tonic-gate  *    notice, this list of conditions and the following disclaimer.
14*7c478bd9Sstevel@tonic-gate  * 2. Redistributions in binary form must reproduce the above copyright
15*7c478bd9Sstevel@tonic-gate  *    notice, this list of conditions and the following disclaimer in the
16*7c478bd9Sstevel@tonic-gate  *    documentation and/or other materials provided with the distribution.
17*7c478bd9Sstevel@tonic-gate  * 3. All advertising materials mentioning features or use of this software
18*7c478bd9Sstevel@tonic-gate  *    must display the following acknowledgement:
19*7c478bd9Sstevel@tonic-gate  *	This product includes software developed by the University of
20*7c478bd9Sstevel@tonic-gate  *	California, Berkeley and its contributors.
21*7c478bd9Sstevel@tonic-gate  * 4. Neither the name of the University nor the names of its contributors
22*7c478bd9Sstevel@tonic-gate  *    may be used to endorse or promote products derived from this software
23*7c478bd9Sstevel@tonic-gate  *    without specific prior written permission.
24*7c478bd9Sstevel@tonic-gate  *
25*7c478bd9Sstevel@tonic-gate  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
26*7c478bd9Sstevel@tonic-gate  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27*7c478bd9Sstevel@tonic-gate  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28*7c478bd9Sstevel@tonic-gate  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
29*7c478bd9Sstevel@tonic-gate  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30*7c478bd9Sstevel@tonic-gate  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31*7c478bd9Sstevel@tonic-gate  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32*7c478bd9Sstevel@tonic-gate  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33*7c478bd9Sstevel@tonic-gate  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34*7c478bd9Sstevel@tonic-gate  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35*7c478bd9Sstevel@tonic-gate  * SUCH DAMAGE.
36*7c478bd9Sstevel@tonic-gate  */
37*7c478bd9Sstevel@tonic-gate 
38*7c478bd9Sstevel@tonic-gate /*
39*7c478bd9Sstevel@tonic-gate  * Kernel resident routing tables.
40*7c478bd9Sstevel@tonic-gate  *
41*7c478bd9Sstevel@tonic-gate  * The routing tables are initialized when interface addresses
42*7c478bd9Sstevel@tonic-gate  * are set by making entries for all directly connected interfaces.
43*7c478bd9Sstevel@tonic-gate  */
44*7c478bd9Sstevel@tonic-gate 
45*7c478bd9Sstevel@tonic-gate #ifndef	_NET_ROUTE_H
46*7c478bd9Sstevel@tonic-gate #define	_NET_ROUTE_H
47*7c478bd9Sstevel@tonic-gate 
48*7c478bd9Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
49*7c478bd9Sstevel@tonic-gate /* from UCB 8.5 (Berkeley) 2/8/95 */
50*7c478bd9Sstevel@tonic-gate 
51*7c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
52*7c478bd9Sstevel@tonic-gate extern "C" {
53*7c478bd9Sstevel@tonic-gate #endif
54*7c478bd9Sstevel@tonic-gate 
55*7c478bd9Sstevel@tonic-gate /*
56*7c478bd9Sstevel@tonic-gate  * A route consists of a destination address and a reference
57*7c478bd9Sstevel@tonic-gate  * to a routing entry.  These are often held by protocols
58*7c478bd9Sstevel@tonic-gate  * in their control blocks, e.g. inpcb.
59*7c478bd9Sstevel@tonic-gate  */
60*7c478bd9Sstevel@tonic-gate struct route {
61*7c478bd9Sstevel@tonic-gate 	struct	rtentry *ro_rt;
62*7c478bd9Sstevel@tonic-gate 	struct	sockaddr ro_dst;
63*7c478bd9Sstevel@tonic-gate };
64*7c478bd9Sstevel@tonic-gate 
65*7c478bd9Sstevel@tonic-gate /*
66*7c478bd9Sstevel@tonic-gate  * These numbers are used by reliable protocols for determining
67*7c478bd9Sstevel@tonic-gate  * retransmission behavior and are included in the routing structure.
68*7c478bd9Sstevel@tonic-gate  *
69*7c478bd9Sstevel@tonic-gate  * rmx_rtt and rmx_rttvar are stored as microseconds;
70*7c478bd9Sstevel@tonic-gate  */
71*7c478bd9Sstevel@tonic-gate typedef struct rt_metrics {
72*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_locks;	/* Kernel must leave these values */
73*7c478bd9Sstevel@tonic-gate 					/* alone */
74*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_mtu;	/* MTU for this path */
75*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_hopcount;	/* max hops expected */
76*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_expire;	/* lifetime for route, e.g. redirect */
77*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_recvpipe;	/* inbound delay-bandwith product */
78*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_sendpipe;	/* outbound delay-bandwith product */
79*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_ssthresh;	/* outbound gateway buffer limit */
80*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_rtt;	/* estimated round trip time */
81*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_rttvar;	/* estimated rtt variance */
82*7c478bd9Sstevel@tonic-gate 	uint32_t	rmx_pksent;	/* packets sent using this route */
83*7c478bd9Sstevel@tonic-gate } rt_metrics_t;
84*7c478bd9Sstevel@tonic-gate 
85*7c478bd9Sstevel@tonic-gate /*
86*7c478bd9Sstevel@tonic-gate  * OLD rtentry structure not used in the kernel. Instead the kernel
87*7c478bd9Sstevel@tonic-gate  * uses struct ire defined in <inet/ip.h>.
88*7c478bd9Sstevel@tonic-gate  *
89*7c478bd9Sstevel@tonic-gate  * We distinguish between routes to hosts and routes to networks,
90*7c478bd9Sstevel@tonic-gate  * preferring the former if available.  For each route we infer
91*7c478bd9Sstevel@tonic-gate  * the interface to use from the gateway address supplied when
92*7c478bd9Sstevel@tonic-gate  * the route was entered.  Routes that forward packets through
93*7c478bd9Sstevel@tonic-gate  * gateways are marked so that the output routines know to address the
94*7c478bd9Sstevel@tonic-gate  * gateway rather than the ultimate destination.
95*7c478bd9Sstevel@tonic-gate  */
96*7c478bd9Sstevel@tonic-gate struct rtentry {
97*7c478bd9Sstevel@tonic-gate 	uint_t	rt_hash;		/* to speed lookups */
98*7c478bd9Sstevel@tonic-gate 	struct	sockaddr rt_dst;	/* key */
99*7c478bd9Sstevel@tonic-gate 	struct	sockaddr rt_gateway;	/* value */
100*7c478bd9Sstevel@tonic-gate 	short	rt_flags;		/* up/down?, host/net */
101*7c478bd9Sstevel@tonic-gate 	short	rt_refcnt;		/* # held references */
102*7c478bd9Sstevel@tonic-gate 	uint_t	rt_use;			/* raw # packets forwarded */
103*7c478bd9Sstevel@tonic-gate 
104*7c478bd9Sstevel@tonic-gate /*
105*7c478bd9Sstevel@tonic-gate  * The kernel does not use this field, and without it the structure is
106*7c478bd9Sstevel@tonic-gate  * datamodel independent.
107*7c478bd9Sstevel@tonic-gate  */
108*7c478bd9Sstevel@tonic-gate #if !defined(_KERNEL)
109*7c478bd9Sstevel@tonic-gate 	struct	ifnet *rt_ifp;		/* the answer: interface to use */
110*7c478bd9Sstevel@tonic-gate #endif /* !defined(_KERNEL) */
111*7c478bd9Sstevel@tonic-gate };
112*7c478bd9Sstevel@tonic-gate 
113*7c478bd9Sstevel@tonic-gate #define	RTF_UP		0x1		/* route usable */
114*7c478bd9Sstevel@tonic-gate #define	RTF_GATEWAY	0x2		/* destination is a gateway */
115*7c478bd9Sstevel@tonic-gate #define	RTF_HOST	0x4		/* host entry (net otherwise) */
116*7c478bd9Sstevel@tonic-gate #define	RTF_REJECT	0x8		/* host or net unreachable */
117*7c478bd9Sstevel@tonic-gate #define	RTF_DYNAMIC	0x10		/* created dynamically (by redirect) */
118*7c478bd9Sstevel@tonic-gate #define	RTF_MODIFIED	0x20		/* modified dynamically (by redirect) */
119*7c478bd9Sstevel@tonic-gate #define	RTF_DONE	0x40		/* message confirmed */
120*7c478bd9Sstevel@tonic-gate #define	RTF_MASK	0x80		/* subnet mask present */
121*7c478bd9Sstevel@tonic-gate #define	RTF_CLONING	0x100		/* generate new routes on use */
122*7c478bd9Sstevel@tonic-gate #define	RTF_XRESOLVE	0x200		/* external daemon resolves name */
123*7c478bd9Sstevel@tonic-gate #define	RTF_LLINFO	0x400		/* generated by ARP or ESIS */
124*7c478bd9Sstevel@tonic-gate #define	RTF_STATIC	0x800		/* manually added */
125*7c478bd9Sstevel@tonic-gate #define	RTF_BLACKHOLE	0x1000		/* just discard pkts (during updates) */
126*7c478bd9Sstevel@tonic-gate #define	RTF_PRIVATE	0x2000		/* do not advertise this route */
127*7c478bd9Sstevel@tonic-gate #define	RTF_PROTO2	0x4000		/* protocol specific routing flag */
128*7c478bd9Sstevel@tonic-gate #define	RTF_PROTO1	0x8000		/* protocol specific routing flag */
129*7c478bd9Sstevel@tonic-gate #define	RTF_MULTIRT	0x10000		/* multiroute */
130*7c478bd9Sstevel@tonic-gate #define	RTF_SETSRC	0x20000		/* set default outgoing src address */
131*7c478bd9Sstevel@tonic-gate 
132*7c478bd9Sstevel@tonic-gate 
133*7c478bd9Sstevel@tonic-gate /*
134*7c478bd9Sstevel@tonic-gate  * OLD statistics not used by the kernel. The kernel uses <inet/mib2.h>.
135*7c478bd9Sstevel@tonic-gate  *
136*7c478bd9Sstevel@tonic-gate  * Routing statistics.
137*7c478bd9Sstevel@tonic-gate  */
138*7c478bd9Sstevel@tonic-gate struct	rtstat {
139*7c478bd9Sstevel@tonic-gate 	short	rts_badredirect;	/* bogus redirect calls */
140*7c478bd9Sstevel@tonic-gate 	short	rts_dynamic;		/* routes created by redirects */
141*7c478bd9Sstevel@tonic-gate 	short	rts_newgateway;		/* routes modified by redirects */
142*7c478bd9Sstevel@tonic-gate 	short	rts_unreach;		/* lookups which failed */
143*7c478bd9Sstevel@tonic-gate 	short	rts_wildcard;		/* lookups satisfied by a wildcard */
144*7c478bd9Sstevel@tonic-gate };
145*7c478bd9Sstevel@tonic-gate 
146*7c478bd9Sstevel@tonic-gate /*
147*7c478bd9Sstevel@tonic-gate  * Structures for routing messages.
148*7c478bd9Sstevel@tonic-gate  */
149*7c478bd9Sstevel@tonic-gate typedef struct rt_msghdr {
150*7c478bd9Sstevel@tonic-gate 	ushort_t rtm_msglen;	/* to skip over non-understood messages */
151*7c478bd9Sstevel@tonic-gate 	uchar_t	rtm_version;	/* future binary compatibility */
152*7c478bd9Sstevel@tonic-gate 	uchar_t	rtm_type;	/* message type */
153*7c478bd9Sstevel@tonic-gate 	ushort_t rtm_index;	/* index for associated ifp */
154*7c478bd9Sstevel@tonic-gate 	int	rtm_flags;	/* flags, incl. kern & message, e.g. DONE */
155*7c478bd9Sstevel@tonic-gate 	int	rtm_addrs;	/* bitmask identifying sockaddrs in msg */
156*7c478bd9Sstevel@tonic-gate 	pid_t	rtm_pid;	/* identify sender */
157*7c478bd9Sstevel@tonic-gate 	int	rtm_seq;	/* for sender to identify action */
158*7c478bd9Sstevel@tonic-gate 	int	rtm_errno;	/* why failed */
159*7c478bd9Sstevel@tonic-gate 	int	rtm_use;	/* from rtentry */
160*7c478bd9Sstevel@tonic-gate 	uint_t	rtm_inits;	/* which metrics we are initializing */
161*7c478bd9Sstevel@tonic-gate 	struct	rt_metrics rtm_rmx; /* metrics themselves */
162*7c478bd9Sstevel@tonic-gate } rt_msghdr_t;
163*7c478bd9Sstevel@tonic-gate 
164*7c478bd9Sstevel@tonic-gate #define	RTM_VERSION	3	/* Up the ante and ignore older versions */
165*7c478bd9Sstevel@tonic-gate 
166*7c478bd9Sstevel@tonic-gate #define	RTM_ADD		0x1	/* Add Route */
167*7c478bd9Sstevel@tonic-gate #define	RTM_DELETE	0x2	/* Delete Route */
168*7c478bd9Sstevel@tonic-gate #define	RTM_CHANGE	0x3	/* Change Metrics or flags */
169*7c478bd9Sstevel@tonic-gate #define	RTM_GET		0x4	/* Report Metrics */
170*7c478bd9Sstevel@tonic-gate #define	RTM_LOSING	0x5	/* Kernel Suspects Partitioning */
171*7c478bd9Sstevel@tonic-gate #define	RTM_REDIRECT	0x6	/* Told to use different route */
172*7c478bd9Sstevel@tonic-gate #define	RTM_MISS	0x7	/* Lookup failed on this address */
173*7c478bd9Sstevel@tonic-gate #define	RTM_LOCK	0x8	/* fix specified metrics */
174*7c478bd9Sstevel@tonic-gate #define	RTM_OLDADD	0x9	/* caused by SIOCADDRT */
175*7c478bd9Sstevel@tonic-gate #define	RTM_OLDDEL	0xa	/* caused by SIOCDELRT */
176*7c478bd9Sstevel@tonic-gate #define	RTM_RESOLVE	0xb	/* req to resolve dst to LL addr */
177*7c478bd9Sstevel@tonic-gate #define	RTM_NEWADDR	0xc	/* address being added to iface */
178*7c478bd9Sstevel@tonic-gate #define	RTM_DELADDR	0xd	/* address being removed from iface */
179*7c478bd9Sstevel@tonic-gate #define	RTM_IFINFO	0xe	/* iface going up/down etc. */
180*7c478bd9Sstevel@tonic-gate 
181*7c478bd9Sstevel@tonic-gate #define	RTV_MTU		0x1	/* init or lock _mtu */
182*7c478bd9Sstevel@tonic-gate #define	RTV_HOPCOUNT	0x2	/* init or lock _hopcount */
183*7c478bd9Sstevel@tonic-gate #define	RTV_EXPIRE	0x4	/* init or lock _expire */
184*7c478bd9Sstevel@tonic-gate #define	RTV_RPIPE	0x8	/* init or lock _recvpipe */
185*7c478bd9Sstevel@tonic-gate #define	RTV_SPIPE	0x10	/* init or lock _sendpipe */
186*7c478bd9Sstevel@tonic-gate #define	RTV_SSTHRESH	0x20	/* init or lock _ssthresh */
187*7c478bd9Sstevel@tonic-gate #define	RTV_RTT		0x40	/* init or lock _rtt */
188*7c478bd9Sstevel@tonic-gate #define	RTV_RTTVAR	0x80	/* init or lock _rttvar */
189*7c478bd9Sstevel@tonic-gate 
190*7c478bd9Sstevel@tonic-gate /*
191*7c478bd9Sstevel@tonic-gate  * Bitmask values for rtm_addr.
192*7c478bd9Sstevel@tonic-gate  */
193*7c478bd9Sstevel@tonic-gate #define	RTA_DST		0x1	/* destination sockaddr present */
194*7c478bd9Sstevel@tonic-gate #define	RTA_GATEWAY	0x2	/* gateway sockaddr present */
195*7c478bd9Sstevel@tonic-gate #define	RTA_NETMASK	0x4	/* netmask sockaddr present */
196*7c478bd9Sstevel@tonic-gate #define	RTA_GENMASK	0x8	/* cloning mask sockaddr present */
197*7c478bd9Sstevel@tonic-gate #define	RTA_IFP		0x10	/* interface name sockaddr present */
198*7c478bd9Sstevel@tonic-gate #define	RTA_IFA		0x20	/* interface addr sockaddr present */
199*7c478bd9Sstevel@tonic-gate #define	RTA_AUTHOR	0x40	/* sockaddr for author of redirect */
200*7c478bd9Sstevel@tonic-gate #define	RTA_BRD		0x80	/* for NEWADDR, broadcast or p-p dest addr */
201*7c478bd9Sstevel@tonic-gate #define	RTA_SRC		0x100	/* source sockaddr present */
202*7c478bd9Sstevel@tonic-gate #define	RTA_SRCIFP	0x200	/* source interface index sockaddr present */
203*7c478bd9Sstevel@tonic-gate 
204*7c478bd9Sstevel@tonic-gate #define	RTA_NUMBITS	10	/* Number of bits used in RTA_* */
205*7c478bd9Sstevel@tonic-gate 
206*7c478bd9Sstevel@tonic-gate /*
207*7c478bd9Sstevel@tonic-gate  * Index offsets for sockaddr_storage array for alternate internal encoding.
208*7c478bd9Sstevel@tonic-gate  * There should be an RTAX_* associated with each RTA_*.
209*7c478bd9Sstevel@tonic-gate  */
210*7c478bd9Sstevel@tonic-gate #define	RTAX_DST	0
211*7c478bd9Sstevel@tonic-gate #define	RTAX_GATEWAY	1
212*7c478bd9Sstevel@tonic-gate #define	RTAX_NETMASK	2
213*7c478bd9Sstevel@tonic-gate #define	RTAX_GENMASK	3
214*7c478bd9Sstevel@tonic-gate #define	RTAX_IFP	4
215*7c478bd9Sstevel@tonic-gate #define	RTAX_IFA	5
216*7c478bd9Sstevel@tonic-gate #define	RTAX_AUTHOR	6
217*7c478bd9Sstevel@tonic-gate #define	RTAX_BRD	7
218*7c478bd9Sstevel@tonic-gate #define	RTAX_SRC	8
219*7c478bd9Sstevel@tonic-gate #define	RTAX_SRCIFP	9
220*7c478bd9Sstevel@tonic-gate #define	RTAX_MAX	RTA_NUMBITS	/* size of array to allocate */
221*7c478bd9Sstevel@tonic-gate 
222*7c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
223*7c478bd9Sstevel@tonic-gate }
224*7c478bd9Sstevel@tonic-gate #endif
225*7c478bd9Sstevel@tonic-gate 
226*7c478bd9Sstevel@tonic-gate #endif	/* _NET_ROUTE_H */
227