xref: /openbmc/linux/include/uapi/linux/rtnetlink.h (revision 65ee00a9)
16f52b16cSGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2607ca46eSDavid Howells #ifndef _UAPI__LINUX_RTNETLINK_H
3607ca46eSDavid Howells #define _UAPI__LINUX_RTNETLINK_H
4607ca46eSDavid Howells 
5607ca46eSDavid Howells #include <linux/types.h>
6607ca46eSDavid Howells #include <linux/netlink.h>
7607ca46eSDavid Howells #include <linux/if_link.h>
8607ca46eSDavid Howells #include <linux/if_addr.h>
9607ca46eSDavid Howells #include <linux/neighbour.h>
10607ca46eSDavid Howells 
11607ca46eSDavid Howells /* rtnetlink families. Values up to 127 are reserved for real address
12607ca46eSDavid Howells  * families, values above 128 may be used arbitrarily.
13607ca46eSDavid Howells  */
14607ca46eSDavid Howells #define RTNL_FAMILY_IPMR		128
15607ca46eSDavid Howells #define RTNL_FAMILY_IP6MR		129
16607ca46eSDavid Howells #define RTNL_FAMILY_MAX			129
17607ca46eSDavid Howells 
18607ca46eSDavid Howells /****
19607ca46eSDavid Howells  *		Routing/neighbour discovery messages.
20607ca46eSDavid Howells  ****/
21607ca46eSDavid Howells 
22607ca46eSDavid Howells /* Types of messages */
23607ca46eSDavid Howells 
24607ca46eSDavid Howells enum {
25607ca46eSDavid Howells 	RTM_BASE	= 16,
26607ca46eSDavid Howells #define RTM_BASE	RTM_BASE
27607ca46eSDavid Howells 
28607ca46eSDavid Howells 	RTM_NEWLINK	= 16,
29607ca46eSDavid Howells #define RTM_NEWLINK	RTM_NEWLINK
30607ca46eSDavid Howells 	RTM_DELLINK,
31607ca46eSDavid Howells #define RTM_DELLINK	RTM_DELLINK
32607ca46eSDavid Howells 	RTM_GETLINK,
33607ca46eSDavid Howells #define RTM_GETLINK	RTM_GETLINK
34607ca46eSDavid Howells 	RTM_SETLINK,
35607ca46eSDavid Howells #define RTM_SETLINK	RTM_SETLINK
36607ca46eSDavid Howells 
37607ca46eSDavid Howells 	RTM_NEWADDR	= 20,
38607ca46eSDavid Howells #define RTM_NEWADDR	RTM_NEWADDR
39607ca46eSDavid Howells 	RTM_DELADDR,
40607ca46eSDavid Howells #define RTM_DELADDR	RTM_DELADDR
41607ca46eSDavid Howells 	RTM_GETADDR,
42607ca46eSDavid Howells #define RTM_GETADDR	RTM_GETADDR
43607ca46eSDavid Howells 
44607ca46eSDavid Howells 	RTM_NEWROUTE	= 24,
45607ca46eSDavid Howells #define RTM_NEWROUTE	RTM_NEWROUTE
46607ca46eSDavid Howells 	RTM_DELROUTE,
47607ca46eSDavid Howells #define RTM_DELROUTE	RTM_DELROUTE
48607ca46eSDavid Howells 	RTM_GETROUTE,
49607ca46eSDavid Howells #define RTM_GETROUTE	RTM_GETROUTE
50607ca46eSDavid Howells 
51607ca46eSDavid Howells 	RTM_NEWNEIGH	= 28,
52607ca46eSDavid Howells #define RTM_NEWNEIGH	RTM_NEWNEIGH
53607ca46eSDavid Howells 	RTM_DELNEIGH,
54607ca46eSDavid Howells #define RTM_DELNEIGH	RTM_DELNEIGH
55607ca46eSDavid Howells 	RTM_GETNEIGH,
56607ca46eSDavid Howells #define RTM_GETNEIGH	RTM_GETNEIGH
57607ca46eSDavid Howells 
58607ca46eSDavid Howells 	RTM_NEWRULE	= 32,
59607ca46eSDavid Howells #define RTM_NEWRULE	RTM_NEWRULE
60607ca46eSDavid Howells 	RTM_DELRULE,
61607ca46eSDavid Howells #define RTM_DELRULE	RTM_DELRULE
62607ca46eSDavid Howells 	RTM_GETRULE,
63607ca46eSDavid Howells #define RTM_GETRULE	RTM_GETRULE
64607ca46eSDavid Howells 
65607ca46eSDavid Howells 	RTM_NEWQDISC	= 36,
66607ca46eSDavid Howells #define RTM_NEWQDISC	RTM_NEWQDISC
67607ca46eSDavid Howells 	RTM_DELQDISC,
68607ca46eSDavid Howells #define RTM_DELQDISC	RTM_DELQDISC
69607ca46eSDavid Howells 	RTM_GETQDISC,
70607ca46eSDavid Howells #define RTM_GETQDISC	RTM_GETQDISC
71607ca46eSDavid Howells 
72607ca46eSDavid Howells 	RTM_NEWTCLASS	= 40,
73607ca46eSDavid Howells #define RTM_NEWTCLASS	RTM_NEWTCLASS
74607ca46eSDavid Howells 	RTM_DELTCLASS,
75607ca46eSDavid Howells #define RTM_DELTCLASS	RTM_DELTCLASS
76607ca46eSDavid Howells 	RTM_GETTCLASS,
77607ca46eSDavid Howells #define RTM_GETTCLASS	RTM_GETTCLASS
78607ca46eSDavid Howells 
79607ca46eSDavid Howells 	RTM_NEWTFILTER	= 44,
80607ca46eSDavid Howells #define RTM_NEWTFILTER	RTM_NEWTFILTER
81607ca46eSDavid Howells 	RTM_DELTFILTER,
82607ca46eSDavid Howells #define RTM_DELTFILTER	RTM_DELTFILTER
83607ca46eSDavid Howells 	RTM_GETTFILTER,
84607ca46eSDavid Howells #define RTM_GETTFILTER	RTM_GETTFILTER
85607ca46eSDavid Howells 
86607ca46eSDavid Howells 	RTM_NEWACTION	= 48,
87607ca46eSDavid Howells #define RTM_NEWACTION   RTM_NEWACTION
88607ca46eSDavid Howells 	RTM_DELACTION,
89607ca46eSDavid Howells #define RTM_DELACTION   RTM_DELACTION
90607ca46eSDavid Howells 	RTM_GETACTION,
91607ca46eSDavid Howells #define RTM_GETACTION   RTM_GETACTION
92607ca46eSDavid Howells 
93607ca46eSDavid Howells 	RTM_NEWPREFIX	= 52,
94607ca46eSDavid Howells #define RTM_NEWPREFIX	RTM_NEWPREFIX
95607ca46eSDavid Howells 
96607ca46eSDavid Howells 	RTM_GETMULTICAST = 58,
97607ca46eSDavid Howells #define RTM_GETMULTICAST RTM_GETMULTICAST
98607ca46eSDavid Howells 
99607ca46eSDavid Howells 	RTM_GETANYCAST	= 62,
100607ca46eSDavid Howells #define RTM_GETANYCAST	RTM_GETANYCAST
101607ca46eSDavid Howells 
102607ca46eSDavid Howells 	RTM_NEWNEIGHTBL	= 64,
103607ca46eSDavid Howells #define RTM_NEWNEIGHTBL	RTM_NEWNEIGHTBL
104607ca46eSDavid Howells 	RTM_GETNEIGHTBL	= 66,
105607ca46eSDavid Howells #define RTM_GETNEIGHTBL	RTM_GETNEIGHTBL
106607ca46eSDavid Howells 	RTM_SETNEIGHTBL,
107607ca46eSDavid Howells #define RTM_SETNEIGHTBL	RTM_SETNEIGHTBL
108607ca46eSDavid Howells 
109607ca46eSDavid Howells 	RTM_NEWNDUSEROPT = 68,
110607ca46eSDavid Howells #define RTM_NEWNDUSEROPT RTM_NEWNDUSEROPT
111607ca46eSDavid Howells 
112607ca46eSDavid Howells 	RTM_NEWADDRLABEL = 72,
113607ca46eSDavid Howells #define RTM_NEWADDRLABEL RTM_NEWADDRLABEL
114607ca46eSDavid Howells 	RTM_DELADDRLABEL,
115607ca46eSDavid Howells #define RTM_DELADDRLABEL RTM_DELADDRLABEL
116607ca46eSDavid Howells 	RTM_GETADDRLABEL,
117607ca46eSDavid Howells #define RTM_GETADDRLABEL RTM_GETADDRLABEL
118607ca46eSDavid Howells 
119607ca46eSDavid Howells 	RTM_GETDCB = 78,
120607ca46eSDavid Howells #define RTM_GETDCB RTM_GETDCB
121607ca46eSDavid Howells 	RTM_SETDCB,
122607ca46eSDavid Howells #define RTM_SETDCB RTM_SETDCB
123607ca46eSDavid Howells 
124d900082bSNicolas Dichtel 	RTM_NEWNETCONF = 80,
125d900082bSNicolas Dichtel #define RTM_NEWNETCONF RTM_NEWNETCONF
126983701ebSDavid Ahern 	RTM_DELNETCONF,
127983701ebSDavid Ahern #define RTM_DELNETCONF RTM_DELNETCONF
128d900082bSNicolas Dichtel 	RTM_GETNETCONF = 82,
129d900082bSNicolas Dichtel #define RTM_GETNETCONF RTM_GETNETCONF
130d900082bSNicolas Dichtel 
13137a393bcSCong Wang 	RTM_NEWMDB = 84,
13237a393bcSCong Wang #define RTM_NEWMDB RTM_NEWMDB
13337a393bcSCong Wang 	RTM_DELMDB = 85,
13437a393bcSCong Wang #define RTM_DELMDB RTM_DELMDB
135ee07c6e7SCong Wang 	RTM_GETMDB = 86,
136ee07c6e7SCong Wang #define RTM_GETMDB RTM_GETMDB
137ee07c6e7SCong Wang 
1380c7aecd4SNicolas Dichtel 	RTM_NEWNSID = 88,
1390c7aecd4SNicolas Dichtel #define RTM_NEWNSID RTM_NEWNSID
1409a963454SNicolas Dichtel 	RTM_DELNSID = 89,
1419a963454SNicolas Dichtel #define RTM_DELNSID RTM_DELNSID
1420c7aecd4SNicolas Dichtel 	RTM_GETNSID = 90,
1430c7aecd4SNicolas Dichtel #define RTM_GETNSID RTM_GETNSID
1440c7aecd4SNicolas Dichtel 
14510c9ead9SRoopa Prabhu 	RTM_NEWSTATS = 92,
14610c9ead9SRoopa Prabhu #define RTM_NEWSTATS RTM_NEWSTATS
14710c9ead9SRoopa Prabhu 	RTM_GETSTATS = 94,
14810c9ead9SRoopa Prabhu #define RTM_GETSTATS RTM_GETSTATS
14910c9ead9SRoopa Prabhu 
15094df30a6SJulien Gomes 	RTM_NEWCACHEREPORT = 96,
15194df30a6SJulien Gomes #define RTM_NEWCACHEREPORT RTM_NEWCACHEREPORT
15294df30a6SJulien Gomes 
15332a4f5ecSJiri Pirko 	RTM_NEWCHAIN = 100,
15432a4f5ecSJiri Pirko #define RTM_NEWCHAIN RTM_NEWCHAIN
15532a4f5ecSJiri Pirko 	RTM_DELCHAIN,
15632a4f5ecSJiri Pirko #define RTM_DELCHAIN RTM_DELCHAIN
15732a4f5ecSJiri Pirko 	RTM_GETCHAIN,
15832a4f5ecSJiri Pirko #define RTM_GETCHAIN RTM_GETCHAIN
15932a4f5ecSJiri Pirko 
16065ee00a9SDavid Ahern 	RTM_NEWNEXTHOP = 104,
16165ee00a9SDavid Ahern #define RTM_NEWNEXTHOP	RTM_NEWNEXTHOP
16265ee00a9SDavid Ahern 	RTM_DELNEXTHOP,
16365ee00a9SDavid Ahern #define RTM_DELNEXTHOP	RTM_DELNEXTHOP
16465ee00a9SDavid Ahern 	RTM_GETNEXTHOP,
16565ee00a9SDavid Ahern #define RTM_GETNEXTHOP	RTM_GETNEXTHOP
16665ee00a9SDavid Ahern 
167607ca46eSDavid Howells 	__RTM_MAX,
168607ca46eSDavid Howells #define RTM_MAX		(((__RTM_MAX + 3) & ~3) - 1)
169607ca46eSDavid Howells };
170607ca46eSDavid Howells 
171607ca46eSDavid Howells #define RTM_NR_MSGTYPES	(RTM_MAX + 1 - RTM_BASE)
172607ca46eSDavid Howells #define RTM_NR_FAMILIES	(RTM_NR_MSGTYPES >> 2)
173607ca46eSDavid Howells #define RTM_FAM(cmd)	(((cmd) - RTM_BASE) >> 2)
174607ca46eSDavid Howells 
175607ca46eSDavid Howells /*
176607ca46eSDavid Howells    Generic structure for encapsulation of optional route information.
177607ca46eSDavid Howells    It is reminiscent of sockaddr, but with sa_family replaced
178607ca46eSDavid Howells    with attribute type.
179607ca46eSDavid Howells  */
180607ca46eSDavid Howells 
181607ca46eSDavid Howells struct rtattr {
182607ca46eSDavid Howells 	unsigned short	rta_len;
183607ca46eSDavid Howells 	unsigned short	rta_type;
184607ca46eSDavid Howells };
185607ca46eSDavid Howells 
186607ca46eSDavid Howells /* Macros to handle rtattributes */
187607ca46eSDavid Howells 
188e8444637SArad, Ronen #define RTA_ALIGNTO	4U
189607ca46eSDavid Howells #define RTA_ALIGN(len) ( ((len)+RTA_ALIGNTO-1) & ~(RTA_ALIGNTO-1) )
190607ca46eSDavid Howells #define RTA_OK(rta,len) ((len) >= (int)sizeof(struct rtattr) && \
191607ca46eSDavid Howells 			 (rta)->rta_len >= sizeof(struct rtattr) && \
192607ca46eSDavid Howells 			 (rta)->rta_len <= (len))
193607ca46eSDavid Howells #define RTA_NEXT(rta,attrlen)	((attrlen) -= RTA_ALIGN((rta)->rta_len), \
194607ca46eSDavid Howells 				 (struct rtattr*)(((char*)(rta)) + RTA_ALIGN((rta)->rta_len)))
195607ca46eSDavid Howells #define RTA_LENGTH(len)	(RTA_ALIGN(sizeof(struct rtattr)) + (len))
196607ca46eSDavid Howells #define RTA_SPACE(len)	RTA_ALIGN(RTA_LENGTH(len))
197607ca46eSDavid Howells #define RTA_DATA(rta)   ((void*)(((char*)(rta)) + RTA_LENGTH(0)))
198607ca46eSDavid Howells #define RTA_PAYLOAD(rta) ((int)((rta)->rta_len) - RTA_LENGTH(0))
199607ca46eSDavid Howells 
200607ca46eSDavid Howells 
201607ca46eSDavid Howells 
202607ca46eSDavid Howells 
203607ca46eSDavid Howells /******************************************************************************
204607ca46eSDavid Howells  *		Definitions used in routing table administration.
205607ca46eSDavid Howells  ****/
206607ca46eSDavid Howells 
207607ca46eSDavid Howells struct rtmsg {
208607ca46eSDavid Howells 	unsigned char		rtm_family;
209607ca46eSDavid Howells 	unsigned char		rtm_dst_len;
210607ca46eSDavid Howells 	unsigned char		rtm_src_len;
211607ca46eSDavid Howells 	unsigned char		rtm_tos;
212607ca46eSDavid Howells 
213607ca46eSDavid Howells 	unsigned char		rtm_table;	/* Routing table id */
214607ca46eSDavid Howells 	unsigned char		rtm_protocol;	/* Routing protocol; see below	*/
215607ca46eSDavid Howells 	unsigned char		rtm_scope;	/* See below */
216607ca46eSDavid Howells 	unsigned char		rtm_type;	/* See below	*/
217607ca46eSDavid Howells 
218607ca46eSDavid Howells 	unsigned		rtm_flags;
219607ca46eSDavid Howells };
220607ca46eSDavid Howells 
221607ca46eSDavid Howells /* rtm_type */
222607ca46eSDavid Howells 
223607ca46eSDavid Howells enum {
224607ca46eSDavid Howells 	RTN_UNSPEC,
225607ca46eSDavid Howells 	RTN_UNICAST,		/* Gateway or direct route	*/
226607ca46eSDavid Howells 	RTN_LOCAL,		/* Accept locally		*/
227607ca46eSDavid Howells 	RTN_BROADCAST,		/* Accept locally as broadcast,
228607ca46eSDavid Howells 				   send as broadcast */
229607ca46eSDavid Howells 	RTN_ANYCAST,		/* Accept locally as broadcast,
230607ca46eSDavid Howells 				   but send as unicast */
231607ca46eSDavid Howells 	RTN_MULTICAST,		/* Multicast route		*/
232607ca46eSDavid Howells 	RTN_BLACKHOLE,		/* Drop				*/
233607ca46eSDavid Howells 	RTN_UNREACHABLE,	/* Destination is unreachable   */
234607ca46eSDavid Howells 	RTN_PROHIBIT,		/* Administratively prohibited	*/
235607ca46eSDavid Howells 	RTN_THROW,		/* Not in this table		*/
236607ca46eSDavid Howells 	RTN_NAT,		/* Translate this address	*/
237607ca46eSDavid Howells 	RTN_XRESOLVE,		/* Use external resolver	*/
238607ca46eSDavid Howells 	__RTN_MAX
239607ca46eSDavid Howells };
240607ca46eSDavid Howells 
241607ca46eSDavid Howells #define RTN_MAX (__RTN_MAX - 1)
242607ca46eSDavid Howells 
243607ca46eSDavid Howells 
244607ca46eSDavid Howells /* rtm_protocol */
245607ca46eSDavid Howells 
246607ca46eSDavid Howells #define RTPROT_UNSPEC	0
247607ca46eSDavid Howells #define RTPROT_REDIRECT	1	/* Route installed by ICMP redirects;
248607ca46eSDavid Howells 				   not used by current IPv4 */
249607ca46eSDavid Howells #define RTPROT_KERNEL	2	/* Route installed by kernel		*/
250607ca46eSDavid Howells #define RTPROT_BOOT	3	/* Route installed during boot		*/
251607ca46eSDavid Howells #define RTPROT_STATIC	4	/* Route installed by administrator	*/
252607ca46eSDavid Howells 
253607ca46eSDavid Howells /* Values of protocol >= RTPROT_STATIC are not interpreted by kernel;
254607ca46eSDavid Howells    they are just passed from user and back as is.
255607ca46eSDavid Howells    It will be used by hypothetical multiple routing daemons.
256607ca46eSDavid Howells    Note that protocol values should be standardized in order to
257607ca46eSDavid Howells    avoid conflicts.
258607ca46eSDavid Howells  */
259607ca46eSDavid Howells 
260607ca46eSDavid Howells #define RTPROT_GATED	8	/* Apparently, GateD */
261607ca46eSDavid Howells #define RTPROT_RA	9	/* RDISC/ND router advertisements */
262607ca46eSDavid Howells #define RTPROT_MRT	10	/* Merit MRT */
263607ca46eSDavid Howells #define RTPROT_ZEBRA	11	/* Zebra */
264607ca46eSDavid Howells #define RTPROT_BIRD	12	/* BIRD */
265607ca46eSDavid Howells #define RTPROT_DNROUTED	13	/* DECnet routing daemon */
266607ca46eSDavid Howells #define RTPROT_XORP	14	/* XORP */
267607ca46eSDavid Howells #define RTPROT_NTK	15	/* Netsukuku */
268607ca46eSDavid Howells #define RTPROT_DHCP	16      /* DHCP client */
2699a68ac72SNicolas Dichtel #define RTPROT_MROUTED	17      /* Multicast daemon */
270be955b29SDave Taht #define RTPROT_BABEL	42      /* Babel daemon */
27135aada99SDonald Sharp #define RTPROT_BGP	186     /* BGP Routes */
27235aada99SDonald Sharp #define RTPROT_ISIS	187     /* ISIS Routes */
27335aada99SDonald Sharp #define RTPROT_OSPF	188     /* OSPF Routes */
27435aada99SDonald Sharp #define RTPROT_RIP	189     /* RIP Routes */
27535aada99SDonald Sharp #define RTPROT_EIGRP	192     /* EIGRP Routes */
276607ca46eSDavid Howells 
277607ca46eSDavid Howells /* rtm_scope
278607ca46eSDavid Howells 
279607ca46eSDavid Howells    Really it is not scope, but sort of distance to the destination.
280607ca46eSDavid Howells    NOWHERE are reserved for not existing destinations, HOST is our
281607ca46eSDavid Howells    local addresses, LINK are destinations, located on directly attached
282607ca46eSDavid Howells    link and UNIVERSE is everywhere in the Universe.
283607ca46eSDavid Howells 
284607ca46eSDavid Howells    Intermediate values are also possible f.e. interior routes
285607ca46eSDavid Howells    could be assigned a value between UNIVERSE and LINK.
286607ca46eSDavid Howells */
287607ca46eSDavid Howells 
288607ca46eSDavid Howells enum rt_scope_t {
289607ca46eSDavid Howells 	RT_SCOPE_UNIVERSE=0,
290607ca46eSDavid Howells /* User defined values  */
291607ca46eSDavid Howells 	RT_SCOPE_SITE=200,
292607ca46eSDavid Howells 	RT_SCOPE_LINK=253,
293607ca46eSDavid Howells 	RT_SCOPE_HOST=254,
294607ca46eSDavid Howells 	RT_SCOPE_NOWHERE=255
295607ca46eSDavid Howells };
296607ca46eSDavid Howells 
297607ca46eSDavid Howells /* rtm_flags */
298607ca46eSDavid Howells 
299607ca46eSDavid Howells #define RTM_F_NOTIFY		0x100	/* Notify user of route change	*/
300607ca46eSDavid Howells #define RTM_F_CLONED		0x200	/* This route is cloned		*/
301607ca46eSDavid Howells #define RTM_F_EQUALIZE		0x400	/* Multipath equalizer: NI	*/
302607ca46eSDavid Howells #define RTM_F_PREFIX		0x800	/* Prefix addresses		*/
303c36ba660SDavid Ahern #define RTM_F_LOOKUP_TABLE	0x1000	/* set rtm_table to FIB lookup result */
3040be1b305SRoopa Prabhu #define RTM_F_FIB_MATCH	        0x2000	/* return full fib lookup match */
305607ca46eSDavid Howells 
306607ca46eSDavid Howells /* Reserved table identifiers */
307607ca46eSDavid Howells 
308607ca46eSDavid Howells enum rt_class_t {
309607ca46eSDavid Howells 	RT_TABLE_UNSPEC=0,
310607ca46eSDavid Howells /* User defined values */
311607ca46eSDavid Howells 	RT_TABLE_COMPAT=252,
312607ca46eSDavid Howells 	RT_TABLE_DEFAULT=253,
313607ca46eSDavid Howells 	RT_TABLE_MAIN=254,
314607ca46eSDavid Howells 	RT_TABLE_LOCAL=255,
315607ca46eSDavid Howells 	RT_TABLE_MAX=0xFFFFFFFF
316607ca46eSDavid Howells };
317607ca46eSDavid Howells 
318607ca46eSDavid Howells 
319607ca46eSDavid Howells /* Routing message attributes */
320607ca46eSDavid Howells 
321607ca46eSDavid Howells enum rtattr_type_t {
322607ca46eSDavid Howells 	RTA_UNSPEC,
323607ca46eSDavid Howells 	RTA_DST,
324607ca46eSDavid Howells 	RTA_SRC,
325607ca46eSDavid Howells 	RTA_IIF,
326607ca46eSDavid Howells 	RTA_OIF,
327607ca46eSDavid Howells 	RTA_GATEWAY,
328607ca46eSDavid Howells 	RTA_PRIORITY,
329607ca46eSDavid Howells 	RTA_PREFSRC,
330607ca46eSDavid Howells 	RTA_METRICS,
331607ca46eSDavid Howells 	RTA_MULTIPATH,
332607ca46eSDavid Howells 	RTA_PROTOINFO, /* no longer used */
333607ca46eSDavid Howells 	RTA_FLOW,
334607ca46eSDavid Howells 	RTA_CACHEINFO,
335607ca46eSDavid Howells 	RTA_SESSION, /* no longer used */
336607ca46eSDavid Howells 	RTA_MP_ALGO, /* no longer used */
337607ca46eSDavid Howells 	RTA_TABLE,
338607ca46eSDavid Howells 	RTA_MARK,
339adfa85e4SNicolas Dichtel 	RTA_MFC_STATS,
34003c05665SEric W. Biederman 	RTA_VIA,
34103c05665SEric W. Biederman 	RTA_NEWDST,
342c78ba6d6SLubomir Rintel 	RTA_PREF,
343a0d9a860SRoopa Prabhu 	RTA_ENCAP_TYPE,
344a0d9a860SRoopa Prabhu 	RTA_ENCAP,
34532bc201eSXin Long 	RTA_EXPIRES,
346a9a08042SNicolas Dichtel 	RTA_PAD,
347622ec2c9SLorenzo Colitti 	RTA_UID,
3485b441ac8SRobert Shearman 	RTA_TTL_PROPAGATE,
349404eb77eSRoopa Prabhu 	RTA_IP_PROTO,
350404eb77eSRoopa Prabhu 	RTA_SPORT,
351404eb77eSRoopa Prabhu 	RTA_DPORT,
35265ee00a9SDavid Ahern 	RTA_NH_ID,
353607ca46eSDavid Howells 	__RTA_MAX
354607ca46eSDavid Howells };
355607ca46eSDavid Howells 
356607ca46eSDavid Howells #define RTA_MAX (__RTA_MAX - 1)
357607ca46eSDavid Howells 
358607ca46eSDavid Howells #define RTM_RTA(r)  ((struct rtattr*)(((char*)(r)) + NLMSG_ALIGN(sizeof(struct rtmsg))))
359607ca46eSDavid Howells #define RTM_PAYLOAD(n) NLMSG_PAYLOAD(n,sizeof(struct rtmsg))
360607ca46eSDavid Howells 
361607ca46eSDavid Howells /* RTM_MULTIPATH --- array of struct rtnexthop.
362607ca46eSDavid Howells  *
363607ca46eSDavid Howells  * "struct rtnexthop" describes all necessary nexthop information,
364607ca46eSDavid Howells  * i.e. parameters of path to a destination via this nexthop.
365607ca46eSDavid Howells  *
366607ca46eSDavid Howells  * At the moment it is impossible to set different prefsrc, mtu, window
367607ca46eSDavid Howells  * and rtt for different paths from multipath.
368607ca46eSDavid Howells  */
369607ca46eSDavid Howells 
370607ca46eSDavid Howells struct rtnexthop {
371607ca46eSDavid Howells 	unsigned short		rtnh_len;
372607ca46eSDavid Howells 	unsigned char		rtnh_flags;
373607ca46eSDavid Howells 	unsigned char		rtnh_hops;
374607ca46eSDavid Howells 	int			rtnh_ifindex;
375607ca46eSDavid Howells };
376607ca46eSDavid Howells 
377607ca46eSDavid Howells /* rtnh_flags */
378607ca46eSDavid Howells 
379607ca46eSDavid Howells #define RTNH_F_DEAD		1	/* Nexthop is dead (used by multipath)	*/
380607ca46eSDavid Howells #define RTNH_F_PERVASIVE	2	/* Do recursive gateway lookup	*/
381607ca46eSDavid Howells #define RTNH_F_ONLINK		4	/* Gateway is forced on link	*/
382eea39946SRoopa Prabhu #define RTNH_F_OFFLOAD		8	/* offloaded route */
3838a3d0316SAndy Gospodarek #define RTNH_F_LINKDOWN		16	/* carrier-down on nexthop */
3841708ebc9SNikolay Aleksandrov #define RTNH_F_UNRESOLVED	32	/* The entry is unresolved (ipmr) */
3858a3d0316SAndy Gospodarek 
38685dda4e5SJiri Pirko #define RTNH_COMPARE_MASK	(RTNH_F_DEAD | RTNH_F_LINKDOWN | RTNH_F_OFFLOAD)
387607ca46eSDavid Howells 
388607ca46eSDavid Howells /* Macros to handle hexthops */
389607ca46eSDavid Howells 
390607ca46eSDavid Howells #define RTNH_ALIGNTO	4
391607ca46eSDavid Howells #define RTNH_ALIGN(len) ( ((len)+RTNH_ALIGNTO-1) & ~(RTNH_ALIGNTO-1) )
392607ca46eSDavid Howells #define RTNH_OK(rtnh,len) ((rtnh)->rtnh_len >= sizeof(struct rtnexthop) && \
393607ca46eSDavid Howells 			   ((int)(rtnh)->rtnh_len) <= (len))
394607ca46eSDavid Howells #define RTNH_NEXT(rtnh)	((struct rtnexthop*)(((char*)(rtnh)) + RTNH_ALIGN((rtnh)->rtnh_len)))
395607ca46eSDavid Howells #define RTNH_LENGTH(len) (RTNH_ALIGN(sizeof(struct rtnexthop)) + (len))
396607ca46eSDavid Howells #define RTNH_SPACE(len)	RTNH_ALIGN(RTNH_LENGTH(len))
397607ca46eSDavid Howells #define RTNH_DATA(rtnh)   ((struct rtattr*)(((char*)(rtnh)) + RTNH_LENGTH(0)))
398607ca46eSDavid Howells 
39903c05665SEric W. Biederman /* RTA_VIA */
40003c05665SEric W. Biederman struct rtvia {
40103c05665SEric W. Biederman 	__kernel_sa_family_t	rtvia_family;
40203c05665SEric W. Biederman 	__u8			rtvia_addr[0];
40303c05665SEric W. Biederman };
40403c05665SEric W. Biederman 
405607ca46eSDavid Howells /* RTM_CACHEINFO */
406607ca46eSDavid Howells 
407607ca46eSDavid Howells struct rta_cacheinfo {
408607ca46eSDavid Howells 	__u32	rta_clntref;
409607ca46eSDavid Howells 	__u32	rta_lastuse;
410607ca46eSDavid Howells 	__s32	rta_expires;
411607ca46eSDavid Howells 	__u32	rta_error;
412607ca46eSDavid Howells 	__u32	rta_used;
413607ca46eSDavid Howells 
414607ca46eSDavid Howells #define RTNETLINK_HAVE_PEERINFO 1
415607ca46eSDavid Howells 	__u32	rta_id;
416607ca46eSDavid Howells 	__u32	rta_ts;
417607ca46eSDavid Howells 	__u32	rta_tsage;
418607ca46eSDavid Howells };
419607ca46eSDavid Howells 
420607ca46eSDavid Howells /* RTM_METRICS --- array of struct rtattr with types of RTAX_* */
421607ca46eSDavid Howells 
422607ca46eSDavid Howells enum {
423607ca46eSDavid Howells 	RTAX_UNSPEC,
424607ca46eSDavid Howells #define RTAX_UNSPEC RTAX_UNSPEC
425607ca46eSDavid Howells 	RTAX_LOCK,
426607ca46eSDavid Howells #define RTAX_LOCK RTAX_LOCK
427607ca46eSDavid Howells 	RTAX_MTU,
428607ca46eSDavid Howells #define RTAX_MTU RTAX_MTU
429607ca46eSDavid Howells 	RTAX_WINDOW,
430607ca46eSDavid Howells #define RTAX_WINDOW RTAX_WINDOW
431607ca46eSDavid Howells 	RTAX_RTT,
432607ca46eSDavid Howells #define RTAX_RTT RTAX_RTT
433607ca46eSDavid Howells 	RTAX_RTTVAR,
434607ca46eSDavid Howells #define RTAX_RTTVAR RTAX_RTTVAR
435607ca46eSDavid Howells 	RTAX_SSTHRESH,
436607ca46eSDavid Howells #define RTAX_SSTHRESH RTAX_SSTHRESH
437607ca46eSDavid Howells 	RTAX_CWND,
438607ca46eSDavid Howells #define RTAX_CWND RTAX_CWND
439607ca46eSDavid Howells 	RTAX_ADVMSS,
440607ca46eSDavid Howells #define RTAX_ADVMSS RTAX_ADVMSS
441607ca46eSDavid Howells 	RTAX_REORDERING,
442607ca46eSDavid Howells #define RTAX_REORDERING RTAX_REORDERING
443607ca46eSDavid Howells 	RTAX_HOPLIMIT,
444607ca46eSDavid Howells #define RTAX_HOPLIMIT RTAX_HOPLIMIT
445607ca46eSDavid Howells 	RTAX_INITCWND,
446607ca46eSDavid Howells #define RTAX_INITCWND RTAX_INITCWND
447607ca46eSDavid Howells 	RTAX_FEATURES,
448607ca46eSDavid Howells #define RTAX_FEATURES RTAX_FEATURES
449607ca46eSDavid Howells 	RTAX_RTO_MIN,
450607ca46eSDavid Howells #define RTAX_RTO_MIN RTAX_RTO_MIN
451607ca46eSDavid Howells 	RTAX_INITRWND,
452607ca46eSDavid Howells #define RTAX_INITRWND RTAX_INITRWND
453bcefe17cSCong Wang 	RTAX_QUICKACK,
454bcefe17cSCong Wang #define RTAX_QUICKACK RTAX_QUICKACK
455ea697639SDaniel Borkmann 	RTAX_CC_ALGO,
456ea697639SDaniel Borkmann #define RTAX_CC_ALGO RTAX_CC_ALGO
45771c02379SChristoph Paasch 	RTAX_FASTOPEN_NO_COOKIE,
45871c02379SChristoph Paasch #define RTAX_FASTOPEN_NO_COOKIE RTAX_FASTOPEN_NO_COOKIE
459607ca46eSDavid Howells 	__RTAX_MAX
460607ca46eSDavid Howells };
461607ca46eSDavid Howells 
462607ca46eSDavid Howells #define RTAX_MAX (__RTAX_MAX - 1)
463607ca46eSDavid Howells 
464b8d3e416SDaniel Borkmann #define RTAX_FEATURE_ECN	(1 << 0)
465b8d3e416SDaniel Borkmann #define RTAX_FEATURE_SACK	(1 << 1)
466b8d3e416SDaniel Borkmann #define RTAX_FEATURE_TIMESTAMP	(1 << 2)
467b8d3e416SDaniel Borkmann #define RTAX_FEATURE_ALLFRAG	(1 << 3)
468b8d3e416SDaniel Borkmann 
469b8d3e416SDaniel Borkmann #define RTAX_FEATURE_MASK	(RTAX_FEATURE_ECN | RTAX_FEATURE_SACK | \
470b8d3e416SDaniel Borkmann 				 RTAX_FEATURE_TIMESTAMP | RTAX_FEATURE_ALLFRAG)
471607ca46eSDavid Howells 
472607ca46eSDavid Howells struct rta_session {
473607ca46eSDavid Howells 	__u8	proto;
474607ca46eSDavid Howells 	__u8	pad1;
475607ca46eSDavid Howells 	__u16	pad2;
476607ca46eSDavid Howells 
477607ca46eSDavid Howells 	union {
478607ca46eSDavid Howells 		struct {
479607ca46eSDavid Howells 			__u16	sport;
480607ca46eSDavid Howells 			__u16	dport;
481607ca46eSDavid Howells 		} ports;
482607ca46eSDavid Howells 
483607ca46eSDavid Howells 		struct {
484607ca46eSDavid Howells 			__u8	type;
485607ca46eSDavid Howells 			__u8	code;
486607ca46eSDavid Howells 			__u16	ident;
487607ca46eSDavid Howells 		} icmpt;
488607ca46eSDavid Howells 
489607ca46eSDavid Howells 		__u32		spi;
490607ca46eSDavid Howells 	} u;
491607ca46eSDavid Howells };
492607ca46eSDavid Howells 
493adfa85e4SNicolas Dichtel struct rta_mfc_stats {
494adfa85e4SNicolas Dichtel 	__u64	mfcs_packets;
495adfa85e4SNicolas Dichtel 	__u64	mfcs_bytes;
496adfa85e4SNicolas Dichtel 	__u64	mfcs_wrong_if;
497adfa85e4SNicolas Dichtel };
498adfa85e4SNicolas Dichtel 
499607ca46eSDavid Howells /****
500607ca46eSDavid Howells  *		General form of address family dependent message.
501607ca46eSDavid Howells  ****/
502607ca46eSDavid Howells 
503607ca46eSDavid Howells struct rtgenmsg {
504607ca46eSDavid Howells 	unsigned char		rtgen_family;
505607ca46eSDavid Howells };
506607ca46eSDavid Howells 
507607ca46eSDavid Howells /*****************************************************************
508607ca46eSDavid Howells  *		Link layer specific messages.
509607ca46eSDavid Howells  ****/
510607ca46eSDavid Howells 
511607ca46eSDavid Howells /* struct ifinfomsg
512607ca46eSDavid Howells  * passes link level specific information, not dependent
513607ca46eSDavid Howells  * on network protocol.
514607ca46eSDavid Howells  */
515607ca46eSDavid Howells 
516607ca46eSDavid Howells struct ifinfomsg {
517607ca46eSDavid Howells 	unsigned char	ifi_family;
518607ca46eSDavid Howells 	unsigned char	__ifi_pad;
519607ca46eSDavid Howells 	unsigned short	ifi_type;		/* ARPHRD_* */
520607ca46eSDavid Howells 	int		ifi_index;		/* Link index	*/
521607ca46eSDavid Howells 	unsigned	ifi_flags;		/* IFF_* flags	*/
522607ca46eSDavid Howells 	unsigned	ifi_change;		/* IFF_* change mask */
523607ca46eSDavid Howells };
524607ca46eSDavid Howells 
525607ca46eSDavid Howells /********************************************************************
526607ca46eSDavid Howells  *		prefix information
527607ca46eSDavid Howells  ****/
528607ca46eSDavid Howells 
529607ca46eSDavid Howells struct prefixmsg {
530607ca46eSDavid Howells 	unsigned char	prefix_family;
531607ca46eSDavid Howells 	unsigned char	prefix_pad1;
532607ca46eSDavid Howells 	unsigned short	prefix_pad2;
533607ca46eSDavid Howells 	int		prefix_ifindex;
534607ca46eSDavid Howells 	unsigned char	prefix_type;
535607ca46eSDavid Howells 	unsigned char	prefix_len;
536607ca46eSDavid Howells 	unsigned char	prefix_flags;
537607ca46eSDavid Howells 	unsigned char	prefix_pad3;
538607ca46eSDavid Howells };
539607ca46eSDavid Howells 
540607ca46eSDavid Howells enum
541607ca46eSDavid Howells {
542607ca46eSDavid Howells 	PREFIX_UNSPEC,
543607ca46eSDavid Howells 	PREFIX_ADDRESS,
544607ca46eSDavid Howells 	PREFIX_CACHEINFO,
545607ca46eSDavid Howells 	__PREFIX_MAX
546607ca46eSDavid Howells };
547607ca46eSDavid Howells 
548607ca46eSDavid Howells #define PREFIX_MAX	(__PREFIX_MAX - 1)
549607ca46eSDavid Howells 
550607ca46eSDavid Howells struct prefix_cacheinfo {
551607ca46eSDavid Howells 	__u32	preferred_time;
552607ca46eSDavid Howells 	__u32	valid_time;
553607ca46eSDavid Howells };
554607ca46eSDavid Howells 
555607ca46eSDavid Howells 
556607ca46eSDavid Howells /*****************************************************************
557607ca46eSDavid Howells  *		Traffic control messages.
558607ca46eSDavid Howells  ****/
559607ca46eSDavid Howells 
560607ca46eSDavid Howells struct tcmsg {
561607ca46eSDavid Howells 	unsigned char	tcm_family;
562607ca46eSDavid Howells 	unsigned char	tcm__pad1;
563607ca46eSDavid Howells 	unsigned short	tcm__pad2;
564607ca46eSDavid Howells 	int		tcm_ifindex;
565607ca46eSDavid Howells 	__u32		tcm_handle;
566607ca46eSDavid Howells 	__u32		tcm_parent;
5677960d1daSJiri Pirko /* tcm_block_index is used instead of tcm_parent
5687960d1daSJiri Pirko  * in case tcm_ifindex == TCM_IFINDEX_MAGIC_BLOCK
5697960d1daSJiri Pirko  */
5707960d1daSJiri Pirko #define tcm_block_index tcm_parent
571607ca46eSDavid Howells 	__u32		tcm_info;
572607ca46eSDavid Howells };
573607ca46eSDavid Howells 
5747960d1daSJiri Pirko /* For manipulation of filters in shared block, tcm_ifindex is set to
5757960d1daSJiri Pirko  * TCM_IFINDEX_MAGIC_BLOCK, and tcm_parent is aliased to tcm_block_index
5767960d1daSJiri Pirko  * which is the block index.
5777960d1daSJiri Pirko  */
5787960d1daSJiri Pirko #define TCM_IFINDEX_MAGIC_BLOCK (0xFFFFFFFFU)
5797960d1daSJiri Pirko 
580607ca46eSDavid Howells enum {
581607ca46eSDavid Howells 	TCA_UNSPEC,
582607ca46eSDavid Howells 	TCA_KIND,
583607ca46eSDavid Howells 	TCA_OPTIONS,
584607ca46eSDavid Howells 	TCA_STATS,
585607ca46eSDavid Howells 	TCA_XSTATS,
586607ca46eSDavid Howells 	TCA_RATE,
587607ca46eSDavid Howells 	TCA_FCNT,
588607ca46eSDavid Howells 	TCA_STATS2,
589607ca46eSDavid Howells 	TCA_STAB,
5909854518eSNicolas Dichtel 	TCA_PAD,
59149b49971SJiri Kosina 	TCA_DUMP_INVISIBLE,
5925bc17018SJiri Pirko 	TCA_CHAIN,
5937a4fa291SYuval Mintz 	TCA_HW_OFFLOAD,
594d47a6b0eSJiri Pirko 	TCA_INGRESS_BLOCK,
595d47a6b0eSJiri Pirko 	TCA_EGRESS_BLOCK,
596607ca46eSDavid Howells 	__TCA_MAX
597607ca46eSDavid Howells };
598607ca46eSDavid Howells 
599607ca46eSDavid Howells #define TCA_MAX (__TCA_MAX - 1)
600607ca46eSDavid Howells 
601607ca46eSDavid Howells #define TCA_RTA(r)  ((struct rtattr*)(((char*)(r)) + NLMSG_ALIGN(sizeof(struct tcmsg))))
602607ca46eSDavid Howells #define TCA_PAYLOAD(n) NLMSG_PAYLOAD(n,sizeof(struct tcmsg))
603607ca46eSDavid Howells 
604607ca46eSDavid Howells /********************************************************************
605607ca46eSDavid Howells  *		Neighbor Discovery userland options
606607ca46eSDavid Howells  ****/
607607ca46eSDavid Howells 
608607ca46eSDavid Howells struct nduseroptmsg {
609607ca46eSDavid Howells 	unsigned char	nduseropt_family;
610607ca46eSDavid Howells 	unsigned char	nduseropt_pad1;
611607ca46eSDavid Howells 	unsigned short	nduseropt_opts_len;	/* Total length of options */
612607ca46eSDavid Howells 	int		nduseropt_ifindex;
613607ca46eSDavid Howells 	__u8		nduseropt_icmp_type;
614607ca46eSDavid Howells 	__u8		nduseropt_icmp_code;
615607ca46eSDavid Howells 	unsigned short	nduseropt_pad2;
616607ca46eSDavid Howells 	unsigned int	nduseropt_pad3;
617607ca46eSDavid Howells 	/* Followed by one or more ND options */
618607ca46eSDavid Howells };
619607ca46eSDavid Howells 
620607ca46eSDavid Howells enum {
621607ca46eSDavid Howells 	NDUSEROPT_UNSPEC,
622607ca46eSDavid Howells 	NDUSEROPT_SRCADDR,
623607ca46eSDavid Howells 	__NDUSEROPT_MAX
624607ca46eSDavid Howells };
625607ca46eSDavid Howells 
626607ca46eSDavid Howells #define NDUSEROPT_MAX	(__NDUSEROPT_MAX - 1)
627607ca46eSDavid Howells 
628607ca46eSDavid Howells #ifndef __KERNEL__
629607ca46eSDavid Howells /* RTnetlink multicast groups - backwards compatibility for userspace */
630607ca46eSDavid Howells #define RTMGRP_LINK		1
631607ca46eSDavid Howells #define RTMGRP_NOTIFY		2
632607ca46eSDavid Howells #define RTMGRP_NEIGH		4
633607ca46eSDavid Howells #define RTMGRP_TC		8
634607ca46eSDavid Howells 
635607ca46eSDavid Howells #define RTMGRP_IPV4_IFADDR	0x10
636607ca46eSDavid Howells #define RTMGRP_IPV4_MROUTE	0x20
637607ca46eSDavid Howells #define RTMGRP_IPV4_ROUTE	0x40
638607ca46eSDavid Howells #define RTMGRP_IPV4_RULE	0x80
639607ca46eSDavid Howells 
640607ca46eSDavid Howells #define RTMGRP_IPV6_IFADDR	0x100
641607ca46eSDavid Howells #define RTMGRP_IPV6_MROUTE	0x200
642607ca46eSDavid Howells #define RTMGRP_IPV6_ROUTE	0x400
643607ca46eSDavid Howells #define RTMGRP_IPV6_IFINFO	0x800
644607ca46eSDavid Howells 
645607ca46eSDavid Howells #define RTMGRP_DECnet_IFADDR    0x1000
646607ca46eSDavid Howells #define RTMGRP_DECnet_ROUTE     0x4000
647607ca46eSDavid Howells 
648607ca46eSDavid Howells #define RTMGRP_IPV6_PREFIX	0x20000
649607ca46eSDavid Howells #endif
650607ca46eSDavid Howells 
651607ca46eSDavid Howells /* RTnetlink multicast groups */
652607ca46eSDavid Howells enum rtnetlink_groups {
653607ca46eSDavid Howells 	RTNLGRP_NONE,
654607ca46eSDavid Howells #define RTNLGRP_NONE		RTNLGRP_NONE
655607ca46eSDavid Howells 	RTNLGRP_LINK,
656607ca46eSDavid Howells #define RTNLGRP_LINK		RTNLGRP_LINK
657607ca46eSDavid Howells 	RTNLGRP_NOTIFY,
658607ca46eSDavid Howells #define RTNLGRP_NOTIFY		RTNLGRP_NOTIFY
659607ca46eSDavid Howells 	RTNLGRP_NEIGH,
660607ca46eSDavid Howells #define RTNLGRP_NEIGH		RTNLGRP_NEIGH
661607ca46eSDavid Howells 	RTNLGRP_TC,
662607ca46eSDavid Howells #define RTNLGRP_TC		RTNLGRP_TC
663607ca46eSDavid Howells 	RTNLGRP_IPV4_IFADDR,
664607ca46eSDavid Howells #define RTNLGRP_IPV4_IFADDR	RTNLGRP_IPV4_IFADDR
665607ca46eSDavid Howells 	RTNLGRP_IPV4_MROUTE,
666607ca46eSDavid Howells #define	RTNLGRP_IPV4_MROUTE	RTNLGRP_IPV4_MROUTE
667607ca46eSDavid Howells 	RTNLGRP_IPV4_ROUTE,
668607ca46eSDavid Howells #define RTNLGRP_IPV4_ROUTE	RTNLGRP_IPV4_ROUTE
669607ca46eSDavid Howells 	RTNLGRP_IPV4_RULE,
670607ca46eSDavid Howells #define RTNLGRP_IPV4_RULE	RTNLGRP_IPV4_RULE
671607ca46eSDavid Howells 	RTNLGRP_IPV6_IFADDR,
672607ca46eSDavid Howells #define RTNLGRP_IPV6_IFADDR	RTNLGRP_IPV6_IFADDR
673607ca46eSDavid Howells 	RTNLGRP_IPV6_MROUTE,
674607ca46eSDavid Howells #define RTNLGRP_IPV6_MROUTE	RTNLGRP_IPV6_MROUTE
675607ca46eSDavid Howells 	RTNLGRP_IPV6_ROUTE,
676607ca46eSDavid Howells #define RTNLGRP_IPV6_ROUTE	RTNLGRP_IPV6_ROUTE
677607ca46eSDavid Howells 	RTNLGRP_IPV6_IFINFO,
678607ca46eSDavid Howells #define RTNLGRP_IPV6_IFINFO	RTNLGRP_IPV6_IFINFO
679607ca46eSDavid Howells 	RTNLGRP_DECnet_IFADDR,
680607ca46eSDavid Howells #define RTNLGRP_DECnet_IFADDR	RTNLGRP_DECnet_IFADDR
681607ca46eSDavid Howells 	RTNLGRP_NOP2,
682607ca46eSDavid Howells 	RTNLGRP_DECnet_ROUTE,
683607ca46eSDavid Howells #define RTNLGRP_DECnet_ROUTE	RTNLGRP_DECnet_ROUTE
684607ca46eSDavid Howells 	RTNLGRP_DECnet_RULE,
685607ca46eSDavid Howells #define RTNLGRP_DECnet_RULE	RTNLGRP_DECnet_RULE
686607ca46eSDavid Howells 	RTNLGRP_NOP4,
687607ca46eSDavid Howells 	RTNLGRP_IPV6_PREFIX,
688607ca46eSDavid Howells #define RTNLGRP_IPV6_PREFIX	RTNLGRP_IPV6_PREFIX
689607ca46eSDavid Howells 	RTNLGRP_IPV6_RULE,
690607ca46eSDavid Howells #define RTNLGRP_IPV6_RULE	RTNLGRP_IPV6_RULE
691607ca46eSDavid Howells 	RTNLGRP_ND_USEROPT,
692607ca46eSDavid Howells #define RTNLGRP_ND_USEROPT	RTNLGRP_ND_USEROPT
693607ca46eSDavid Howells 	RTNLGRP_PHONET_IFADDR,
694607ca46eSDavid Howells #define RTNLGRP_PHONET_IFADDR	RTNLGRP_PHONET_IFADDR
695607ca46eSDavid Howells 	RTNLGRP_PHONET_ROUTE,
696607ca46eSDavid Howells #define RTNLGRP_PHONET_ROUTE	RTNLGRP_PHONET_ROUTE
697607ca46eSDavid Howells 	RTNLGRP_DCB,
698607ca46eSDavid Howells #define RTNLGRP_DCB		RTNLGRP_DCB
699edc9e748SNicolas Dichtel 	RTNLGRP_IPV4_NETCONF,
700edc9e748SNicolas Dichtel #define RTNLGRP_IPV4_NETCONF	RTNLGRP_IPV4_NETCONF
701f3a1bfb1SNicolas Dichtel 	RTNLGRP_IPV6_NETCONF,
702f3a1bfb1SNicolas Dichtel #define RTNLGRP_IPV6_NETCONF	RTNLGRP_IPV6_NETCONF
70337a393bcSCong Wang 	RTNLGRP_MDB,
70437a393bcSCong Wang #define RTNLGRP_MDB		RTNLGRP_MDB
7058de147dcSEric W. Biederman 	RTNLGRP_MPLS_ROUTE,
7068de147dcSEric W. Biederman #define RTNLGRP_MPLS_ROUTE	RTNLGRP_MPLS_ROUTE
7079a963454SNicolas Dichtel 	RTNLGRP_NSID,
7089a963454SNicolas Dichtel #define RTNLGRP_NSID		RTNLGRP_NSID
70924045a03SDavid Ahern 	RTNLGRP_MPLS_NETCONF,
71024045a03SDavid Ahern #define RTNLGRP_MPLS_NETCONF	RTNLGRP_MPLS_NETCONF
7115f729eaaSJulien Gomes 	RTNLGRP_IPV4_MROUTE_R,
7125f729eaaSJulien Gomes #define RTNLGRP_IPV4_MROUTE_R	RTNLGRP_IPV4_MROUTE_R
7135f729eaaSJulien Gomes 	RTNLGRP_IPV6_MROUTE_R,
7145f729eaaSJulien Gomes #define RTNLGRP_IPV6_MROUTE_R	RTNLGRP_IPV6_MROUTE_R
71565ee00a9SDavid Ahern 	RTNLGRP_NEXTHOP,
71665ee00a9SDavid Ahern #define RTNLGRP_NEXTHOP		RTNLGRP_NEXTHOP
717607ca46eSDavid Howells 	__RTNLGRP_MAX
718607ca46eSDavid Howells };
719607ca46eSDavid Howells #define RTNLGRP_MAX	(__RTNLGRP_MAX - 1)
720607ca46eSDavid Howells 
721607ca46eSDavid Howells /* TC action piece */
722607ca46eSDavid Howells struct tcamsg {
723607ca46eSDavid Howells 	unsigned char	tca_family;
724607ca46eSDavid Howells 	unsigned char	tca__pad1;
725607ca46eSDavid Howells 	unsigned short	tca__pad2;
726607ca46eSDavid Howells };
72790825b23SJamal Hadi Salim 
72890825b23SJamal Hadi Salim enum {
72990825b23SJamal Hadi Salim 	TCA_ROOT_UNSPEC,
73090825b23SJamal Hadi Salim 	TCA_ROOT_TAB,
73190825b23SJamal Hadi Salim #define TCA_ACT_TAB TCA_ROOT_TAB
73290825b23SJamal Hadi Salim #define TCAA_MAX TCA_ROOT_TAB
73390825b23SJamal Hadi Salim 	TCA_ROOT_FLAGS,
73490825b23SJamal Hadi Salim 	TCA_ROOT_COUNT,
735e62e484dSJamal Hadi Salim 	TCA_ROOT_TIME_DELTA, /* in msecs */
73690825b23SJamal Hadi Salim 	__TCA_ROOT_MAX,
73790825b23SJamal Hadi Salim #define	TCA_ROOT_MAX (__TCA_ROOT_MAX - 1)
73890825b23SJamal Hadi Salim };
73990825b23SJamal Hadi Salim 
740607ca46eSDavid Howells #define TA_RTA(r)  ((struct rtattr*)(((char*)(r)) + NLMSG_ALIGN(sizeof(struct tcamsg))))
741607ca46eSDavid Howells #define TA_PAYLOAD(n) NLMSG_PAYLOAD(n,sizeof(struct tcamsg))
74290825b23SJamal Hadi Salim /* tcamsg flags stored in attribute TCA_ROOT_FLAGS
74390825b23SJamal Hadi Salim  *
74490825b23SJamal Hadi Salim  * TCA_FLAG_LARGE_DUMP_ON user->kernel to request for larger than TCA_ACT_MAX_PRIO
74590825b23SJamal Hadi Salim  * actions in a dump. All dump responses will contain the number of actions
74690825b23SJamal Hadi Salim  * being dumped stored in for user app's consumption in TCA_ROOT_COUNT
74790825b23SJamal Hadi Salim  *
74890825b23SJamal Hadi Salim  */
74990825b23SJamal Hadi Salim #define TCA_FLAG_LARGE_DUMP_ON		(1 << 0)
750607ca46eSDavid Howells 
751607ca46eSDavid Howells /* New extended info filters for IFLA_EXT_MASK */
752607ca46eSDavid Howells #define RTEXT_FILTER_VF		(1 << 0)
7536cbdceebSVlad Yasevich #define RTEXT_FILTER_BRVLAN	(1 << 1)
75435a27ceeSRoopa Prabhu #define RTEXT_FILTER_BRVLAN_COMPRESSED	(1 << 2)
755d5566fd7SSowmini Varadhan #define	RTEXT_FILTER_SKIP_STATS	(1 << 3)
756607ca46eSDavid Howells 
757607ca46eSDavid Howells /* End of information exported to user level */
758607ca46eSDavid Howells 
759607ca46eSDavid Howells 
760607ca46eSDavid Howells 
761607ca46eSDavid Howells #endif /* _UAPI__LINUX_RTNETLINK_H */
762