• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /****************************************************************************
2  ****************************************************************************
3  ***
4  ***   This header was automatically generated from a Linux kernel header
5  ***   of the same name, to make information necessary for userspace to
6  ***   call into the kernel available to libc.  It contains only constants,
7  ***   structures, and macros generated from the original header, and thus,
8  ***   contains no copyrightable information.
9  ***
10  ***   To edit the content of this header, modify the corresponding
11  ***   source file (e.g. under external/kernel-headers/original/) then
12  ***   run bionic/libc/kernel/tools/update_all.py
13  ***
14  ***   Any manual change here will be lost the next time this script will
15  ***   be run. You've been warned!
16  ***
17  ****************************************************************************
18  ****************************************************************************/
19 #ifndef _UAPI__LINUX_RTNETLINK_H
20 #define _UAPI__LINUX_RTNETLINK_H
21 #include <linux/types.h>
22 #include <linux/netlink.h>
23 #include <linux/if_link.h>
24 #include <linux/if_addr.h>
25 #include <linux/neighbour.h>
26 #define RTNL_FAMILY_IPMR 128
27 #define RTNL_FAMILY_IP6MR 129
28 #define RTNL_FAMILY_MAX 129
29 enum {
30   RTM_BASE = 16,
31 #define RTM_BASE RTM_BASE
32   RTM_NEWLINK = 16,
33 #define RTM_NEWLINK RTM_NEWLINK
34   RTM_DELLINK,
35 #define RTM_DELLINK RTM_DELLINK
36   RTM_GETLINK,
37 #define RTM_GETLINK RTM_GETLINK
38   RTM_SETLINK,
39 #define RTM_SETLINK RTM_SETLINK
40   RTM_NEWADDR = 20,
41 #define RTM_NEWADDR RTM_NEWADDR
42   RTM_DELADDR,
43 #define RTM_DELADDR RTM_DELADDR
44   RTM_GETADDR,
45 #define RTM_GETADDR RTM_GETADDR
46   RTM_NEWROUTE = 24,
47 #define RTM_NEWROUTE RTM_NEWROUTE
48   RTM_DELROUTE,
49 #define RTM_DELROUTE RTM_DELROUTE
50   RTM_GETROUTE,
51 #define RTM_GETROUTE RTM_GETROUTE
52   RTM_NEWNEIGH = 28,
53 #define RTM_NEWNEIGH RTM_NEWNEIGH
54   RTM_DELNEIGH,
55 #define RTM_DELNEIGH RTM_DELNEIGH
56   RTM_GETNEIGH,
57 #define RTM_GETNEIGH RTM_GETNEIGH
58   RTM_NEWRULE = 32,
59 #define RTM_NEWRULE RTM_NEWRULE
60   RTM_DELRULE,
61 #define RTM_DELRULE RTM_DELRULE
62   RTM_GETRULE,
63 #define RTM_GETRULE RTM_GETRULE
64   RTM_NEWQDISC = 36,
65 #define RTM_NEWQDISC RTM_NEWQDISC
66   RTM_DELQDISC,
67 #define RTM_DELQDISC RTM_DELQDISC
68   RTM_GETQDISC,
69 #define RTM_GETQDISC RTM_GETQDISC
70   RTM_NEWTCLASS = 40,
71 #define RTM_NEWTCLASS RTM_NEWTCLASS
72   RTM_DELTCLASS,
73 #define RTM_DELTCLASS RTM_DELTCLASS
74   RTM_GETTCLASS,
75 #define RTM_GETTCLASS RTM_GETTCLASS
76   RTM_NEWTFILTER = 44,
77 #define RTM_NEWTFILTER RTM_NEWTFILTER
78   RTM_DELTFILTER,
79 #define RTM_DELTFILTER RTM_DELTFILTER
80   RTM_GETTFILTER,
81 #define RTM_GETTFILTER RTM_GETTFILTER
82   RTM_NEWACTION = 48,
83 #define RTM_NEWACTION RTM_NEWACTION
84   RTM_DELACTION,
85 #define RTM_DELACTION RTM_DELACTION
86   RTM_GETACTION,
87 #define RTM_GETACTION RTM_GETACTION
88   RTM_NEWPREFIX = 52,
89 #define RTM_NEWPREFIX RTM_NEWPREFIX
90   RTM_GETMULTICAST = 58,
91 #define RTM_GETMULTICAST RTM_GETMULTICAST
92   RTM_GETANYCAST = 62,
93 #define RTM_GETANYCAST RTM_GETANYCAST
94   RTM_NEWNEIGHTBL = 64,
95 #define RTM_NEWNEIGHTBL RTM_NEWNEIGHTBL
96   RTM_GETNEIGHTBL = 66,
97 #define RTM_GETNEIGHTBL RTM_GETNEIGHTBL
98   RTM_SETNEIGHTBL,
99 #define RTM_SETNEIGHTBL RTM_SETNEIGHTBL
100   RTM_NEWNDUSEROPT = 68,
101 #define RTM_NEWNDUSEROPT RTM_NEWNDUSEROPT
102   RTM_NEWADDRLABEL = 72,
103 #define RTM_NEWADDRLABEL RTM_NEWADDRLABEL
104   RTM_DELADDRLABEL,
105 #define RTM_DELADDRLABEL RTM_DELADDRLABEL
106   RTM_GETADDRLABEL,
107 #define RTM_GETADDRLABEL RTM_GETADDRLABEL
108   RTM_GETDCB = 78,
109 #define RTM_GETDCB RTM_GETDCB
110   RTM_SETDCB,
111 #define RTM_SETDCB RTM_SETDCB
112   RTM_NEWNETCONF = 80,
113 #define RTM_NEWNETCONF RTM_NEWNETCONF
114   RTM_DELNETCONF,
115 #define RTM_DELNETCONF RTM_DELNETCONF
116   RTM_GETNETCONF = 82,
117 #define RTM_GETNETCONF RTM_GETNETCONF
118   RTM_NEWMDB = 84,
119 #define RTM_NEWMDB RTM_NEWMDB
120   RTM_DELMDB = 85,
121 #define RTM_DELMDB RTM_DELMDB
122   RTM_GETMDB = 86,
123 #define RTM_GETMDB RTM_GETMDB
124   RTM_NEWNSID = 88,
125 #define RTM_NEWNSID RTM_NEWNSID
126   RTM_DELNSID = 89,
127 #define RTM_DELNSID RTM_DELNSID
128   RTM_GETNSID = 90,
129 #define RTM_GETNSID RTM_GETNSID
130   RTM_NEWSTATS = 92,
131 #define RTM_NEWSTATS RTM_NEWSTATS
132   RTM_GETSTATS = 94,
133 #define RTM_GETSTATS RTM_GETSTATS
134   RTM_NEWCACHEREPORT = 96,
135 #define RTM_NEWCACHEREPORT RTM_NEWCACHEREPORT
136   RTM_NEWCHAIN = 100,
137 #define RTM_NEWCHAIN RTM_NEWCHAIN
138   RTM_DELCHAIN,
139 #define RTM_DELCHAIN RTM_DELCHAIN
140   RTM_GETCHAIN,
141 #define RTM_GETCHAIN RTM_GETCHAIN
142   RTM_NEWNEXTHOP = 104,
143 #define RTM_NEWNEXTHOP RTM_NEWNEXTHOP
144   RTM_DELNEXTHOP,
145 #define RTM_DELNEXTHOP RTM_DELNEXTHOP
146   RTM_GETNEXTHOP,
147 #define RTM_GETNEXTHOP RTM_GETNEXTHOP
148   RTM_NEWLINKPROP = 108,
149 #define RTM_NEWLINKPROP RTM_NEWLINKPROP
150   RTM_DELLINKPROP,
151 #define RTM_DELLINKPROP RTM_DELLINKPROP
152   RTM_GETLINKPROP,
153 #define RTM_GETLINKPROP RTM_GETLINKPROP
154   __RTM_MAX,
155 #define RTM_MAX (((__RTM_MAX + 3) & ~3) - 1)
156 };
157 #define RTM_NR_MSGTYPES (RTM_MAX + 1 - RTM_BASE)
158 #define RTM_NR_FAMILIES (RTM_NR_MSGTYPES >> 2)
159 #define RTM_FAM(cmd) (((cmd) - RTM_BASE) >> 2)
160 struct rtattr {
161   unsigned short rta_len;
162   unsigned short rta_type;
163 };
164 #define RTA_ALIGNTO 4U
165 #define RTA_ALIGN(len) (((len) + RTA_ALIGNTO - 1) & ~(RTA_ALIGNTO - 1))
166 #define RTA_OK(rta,len) ((len) >= (int) sizeof(struct rtattr) && (rta)->rta_len >= sizeof(struct rtattr) && (rta)->rta_len <= (len))
167 #define RTA_NEXT(rta,attrlen) ((attrlen) -= RTA_ALIGN((rta)->rta_len), (struct rtattr *) (((char *) (rta)) + RTA_ALIGN((rta)->rta_len)))
168 #define RTA_LENGTH(len) (RTA_ALIGN(sizeof(struct rtattr)) + (len))
169 #define RTA_SPACE(len) RTA_ALIGN(RTA_LENGTH(len))
170 #define RTA_DATA(rta) ((void *) (((char *) (rta)) + RTA_LENGTH(0)))
171 #define RTA_PAYLOAD(rta) ((int) ((rta)->rta_len) - RTA_LENGTH(0))
172 struct rtmsg {
173   unsigned char rtm_family;
174   unsigned char rtm_dst_len;
175   unsigned char rtm_src_len;
176   unsigned char rtm_tos;
177   unsigned char rtm_table;
178   unsigned char rtm_protocol;
179   unsigned char rtm_scope;
180   unsigned char rtm_type;
181   unsigned rtm_flags;
182 };
183 enum {
184   RTN_UNSPEC,
185   RTN_UNICAST,
186   RTN_LOCAL,
187   RTN_BROADCAST,
188   RTN_ANYCAST,
189   RTN_MULTICAST,
190   RTN_BLACKHOLE,
191   RTN_UNREACHABLE,
192   RTN_PROHIBIT,
193   RTN_THROW,
194   RTN_NAT,
195   RTN_XRESOLVE,
196   __RTN_MAX
197 };
198 #define RTN_MAX (__RTN_MAX - 1)
199 #define RTPROT_UNSPEC 0
200 #define RTPROT_REDIRECT 1
201 #define RTPROT_KERNEL 2
202 #define RTPROT_BOOT 3
203 #define RTPROT_STATIC 4
204 #define RTPROT_GATED 8
205 #define RTPROT_RA 9
206 #define RTPROT_MRT 10
207 #define RTPROT_ZEBRA 11
208 #define RTPROT_BIRD 12
209 #define RTPROT_DNROUTED 13
210 #define RTPROT_XORP 14
211 #define RTPROT_NTK 15
212 #define RTPROT_DHCP 16
213 #define RTPROT_MROUTED 17
214 #define RTPROT_BABEL 42
215 #define RTPROT_BGP 186
216 #define RTPROT_ISIS 187
217 #define RTPROT_OSPF 188
218 #define RTPROT_RIP 189
219 #define RTPROT_EIGRP 192
220 enum rt_scope_t {
221   RT_SCOPE_UNIVERSE = 0,
222   RT_SCOPE_SITE = 200,
223   RT_SCOPE_LINK = 253,
224   RT_SCOPE_HOST = 254,
225   RT_SCOPE_NOWHERE = 255
226 };
227 #define RTM_F_NOTIFY 0x100
228 #define RTM_F_CLONED 0x200
229 #define RTM_F_EQUALIZE 0x400
230 #define RTM_F_PREFIX 0x800
231 #define RTM_F_LOOKUP_TABLE 0x1000
232 #define RTM_F_FIB_MATCH 0x2000
233 enum rt_class_t {
234   RT_TABLE_UNSPEC = 0,
235   RT_TABLE_COMPAT = 252,
236   RT_TABLE_DEFAULT = 253,
237   RT_TABLE_MAIN = 254,
238   RT_TABLE_LOCAL = 255,
239   RT_TABLE_MAX = 0xFFFFFFFF
240 };
241 enum rtattr_type_t {
242   RTA_UNSPEC,
243   RTA_DST,
244   RTA_SRC,
245   RTA_IIF,
246   RTA_OIF,
247   RTA_GATEWAY,
248   RTA_PRIORITY,
249   RTA_PREFSRC,
250   RTA_METRICS,
251   RTA_MULTIPATH,
252   RTA_PROTOINFO,
253   RTA_FLOW,
254   RTA_CACHEINFO,
255   RTA_SESSION,
256   RTA_MP_ALGO,
257   RTA_TABLE,
258   RTA_MARK,
259   RTA_MFC_STATS,
260   RTA_VIA,
261   RTA_NEWDST,
262   RTA_PREF,
263   RTA_ENCAP_TYPE,
264   RTA_ENCAP,
265   RTA_EXPIRES,
266   RTA_PAD,
267   RTA_UID,
268   RTA_TTL_PROPAGATE,
269   RTA_IP_PROTO,
270   RTA_SPORT,
271   RTA_DPORT,
272   RTA_NH_ID,
273   __RTA_MAX
274 };
275 #define RTA_MAX (__RTA_MAX - 1)
276 #define RTM_RTA(r) ((struct rtattr *) (((char *) (r)) + NLMSG_ALIGN(sizeof(struct rtmsg))))
277 #define RTM_PAYLOAD(n) NLMSG_PAYLOAD(n, sizeof(struct rtmsg))
278 struct rtnexthop {
279   unsigned short rtnh_len;
280   unsigned char rtnh_flags;
281   unsigned char rtnh_hops;
282   int rtnh_ifindex;
283 };
284 #define RTNH_F_DEAD 1
285 #define RTNH_F_PERVASIVE 2
286 #define RTNH_F_ONLINK 4
287 #define RTNH_F_OFFLOAD 8
288 #define RTNH_F_LINKDOWN 16
289 #define RTNH_F_UNRESOLVED 32
290 #define RTNH_COMPARE_MASK (RTNH_F_DEAD | RTNH_F_LINKDOWN | RTNH_F_OFFLOAD)
291 #define RTNH_ALIGNTO 4
292 #define RTNH_ALIGN(len) (((len) + RTNH_ALIGNTO - 1) & ~(RTNH_ALIGNTO - 1))
293 #define RTNH_OK(rtnh,len) ((rtnh)->rtnh_len >= sizeof(struct rtnexthop) && ((int) (rtnh)->rtnh_len) <= (len))
294 #define RTNH_NEXT(rtnh) ((struct rtnexthop *) (((char *) (rtnh)) + RTNH_ALIGN((rtnh)->rtnh_len)))
295 #define RTNH_LENGTH(len) (RTNH_ALIGN(sizeof(struct rtnexthop)) + (len))
296 #define RTNH_SPACE(len) RTNH_ALIGN(RTNH_LENGTH(len))
297 #define RTNH_DATA(rtnh) ((struct rtattr *) (((char *) (rtnh)) + RTNH_LENGTH(0)))
298 struct rtvia {
299   __kernel_sa_family_t rtvia_family;
300   __u8 rtvia_addr[0];
301 };
302 struct rta_cacheinfo {
303   __u32 rta_clntref;
304   __u32 rta_lastuse;
305   __s32 rta_expires;
306   __u32 rta_error;
307   __u32 rta_used;
308 #define RTNETLINK_HAVE_PEERINFO 1
309   __u32 rta_id;
310   __u32 rta_ts;
311   __u32 rta_tsage;
312 };
313 enum {
314   RTAX_UNSPEC,
315 #define RTAX_UNSPEC RTAX_UNSPEC
316   RTAX_LOCK,
317 #define RTAX_LOCK RTAX_LOCK
318   RTAX_MTU,
319 #define RTAX_MTU RTAX_MTU
320   RTAX_WINDOW,
321 #define RTAX_WINDOW RTAX_WINDOW
322   RTAX_RTT,
323 #define RTAX_RTT RTAX_RTT
324   RTAX_RTTVAR,
325 #define RTAX_RTTVAR RTAX_RTTVAR
326   RTAX_SSTHRESH,
327 #define RTAX_SSTHRESH RTAX_SSTHRESH
328   RTAX_CWND,
329 #define RTAX_CWND RTAX_CWND
330   RTAX_ADVMSS,
331 #define RTAX_ADVMSS RTAX_ADVMSS
332   RTAX_REORDERING,
333 #define RTAX_REORDERING RTAX_REORDERING
334   RTAX_HOPLIMIT,
335 #define RTAX_HOPLIMIT RTAX_HOPLIMIT
336   RTAX_INITCWND,
337 #define RTAX_INITCWND RTAX_INITCWND
338   RTAX_FEATURES,
339 #define RTAX_FEATURES RTAX_FEATURES
340   RTAX_RTO_MIN,
341 #define RTAX_RTO_MIN RTAX_RTO_MIN
342   RTAX_INITRWND,
343 #define RTAX_INITRWND RTAX_INITRWND
344   RTAX_QUICKACK,
345 #define RTAX_QUICKACK RTAX_QUICKACK
346   RTAX_CC_ALGO,
347 #define RTAX_CC_ALGO RTAX_CC_ALGO
348   RTAX_FASTOPEN_NO_COOKIE,
349 #define RTAX_FASTOPEN_NO_COOKIE RTAX_FASTOPEN_NO_COOKIE
350   __RTAX_MAX
351 };
352 #define RTAX_MAX (__RTAX_MAX - 1)
353 #define RTAX_FEATURE_ECN (1 << 0)
354 #define RTAX_FEATURE_SACK (1 << 1)
355 #define RTAX_FEATURE_TIMESTAMP (1 << 2)
356 #define RTAX_FEATURE_ALLFRAG (1 << 3)
357 #define RTAX_FEATURE_MASK (RTAX_FEATURE_ECN | RTAX_FEATURE_SACK | RTAX_FEATURE_TIMESTAMP | RTAX_FEATURE_ALLFRAG)
358 struct rta_session {
359   __u8 proto;
360   __u8 pad1;
361   __u16 pad2;
362   union {
363     struct {
364       __u16 sport;
365       __u16 dport;
366     } ports;
367     struct {
368       __u8 type;
369       __u8 code;
370       __u16 ident;
371     } icmpt;
372     __u32 spi;
373   } u;
374 };
375 struct rta_mfc_stats {
376   __u64 mfcs_packets;
377   __u64 mfcs_bytes;
378   __u64 mfcs_wrong_if;
379 };
380 struct rtgenmsg {
381   unsigned char rtgen_family;
382 };
383 struct ifinfomsg {
384   unsigned char ifi_family;
385   unsigned char __ifi_pad;
386   unsigned short ifi_type;
387   int ifi_index;
388   unsigned ifi_flags;
389   unsigned ifi_change;
390 };
391 struct prefixmsg {
392   unsigned char prefix_family;
393   unsigned char prefix_pad1;
394   unsigned short prefix_pad2;
395   int prefix_ifindex;
396   unsigned char prefix_type;
397   unsigned char prefix_len;
398   unsigned char prefix_flags;
399   unsigned char prefix_pad3;
400 };
401 enum {
402   PREFIX_UNSPEC,
403   PREFIX_ADDRESS,
404   PREFIX_CACHEINFO,
405   __PREFIX_MAX
406 };
407 #define PREFIX_MAX (__PREFIX_MAX - 1)
408 struct prefix_cacheinfo {
409   __u32 preferred_time;
410   __u32 valid_time;
411 };
412 struct tcmsg {
413   unsigned char tcm_family;
414   unsigned char tcm__pad1;
415   unsigned short tcm__pad2;
416   int tcm_ifindex;
417   __u32 tcm_handle;
418   __u32 tcm_parent;
419 #define tcm_block_index tcm_parent
420   __u32 tcm_info;
421 };
422 #define TCM_IFINDEX_MAGIC_BLOCK (0xFFFFFFFFU)
423 enum {
424   TCA_UNSPEC,
425   TCA_KIND,
426   TCA_OPTIONS,
427   TCA_STATS,
428   TCA_XSTATS,
429   TCA_RATE,
430   TCA_FCNT,
431   TCA_STATS2,
432   TCA_STAB,
433   TCA_PAD,
434   TCA_DUMP_INVISIBLE,
435   TCA_CHAIN,
436   TCA_HW_OFFLOAD,
437   TCA_INGRESS_BLOCK,
438   TCA_EGRESS_BLOCK,
439   __TCA_MAX
440 };
441 #define TCA_MAX (__TCA_MAX - 1)
442 #define TCA_RTA(r) ((struct rtattr *) (((char *) (r)) + NLMSG_ALIGN(sizeof(struct tcmsg))))
443 #define TCA_PAYLOAD(n) NLMSG_PAYLOAD(n, sizeof(struct tcmsg))
444 struct nduseroptmsg {
445   unsigned char nduseropt_family;
446   unsigned char nduseropt_pad1;
447   unsigned short nduseropt_opts_len;
448   int nduseropt_ifindex;
449   __u8 nduseropt_icmp_type;
450   __u8 nduseropt_icmp_code;
451   unsigned short nduseropt_pad2;
452   unsigned int nduseropt_pad3;
453 };
454 enum {
455   NDUSEROPT_UNSPEC,
456   NDUSEROPT_SRCADDR,
457   __NDUSEROPT_MAX
458 };
459 #define NDUSEROPT_MAX (__NDUSEROPT_MAX - 1)
460 #define RTMGRP_LINK 1
461 #define RTMGRP_NOTIFY 2
462 #define RTMGRP_NEIGH 4
463 #define RTMGRP_TC 8
464 #define RTMGRP_IPV4_IFADDR 0x10
465 #define RTMGRP_IPV4_MROUTE 0x20
466 #define RTMGRP_IPV4_ROUTE 0x40
467 #define RTMGRP_IPV4_RULE 0x80
468 #define RTMGRP_IPV6_IFADDR 0x100
469 #define RTMGRP_IPV6_MROUTE 0x200
470 #define RTMGRP_IPV6_ROUTE 0x400
471 #define RTMGRP_IPV6_IFINFO 0x800
472 #define RTMGRP_DECnet_IFADDR 0x1000
473 #define RTMGRP_DECnet_ROUTE 0x4000
474 #define RTMGRP_IPV6_PREFIX 0x20000
475 enum rtnetlink_groups {
476   RTNLGRP_NONE,
477 #define RTNLGRP_NONE RTNLGRP_NONE
478   RTNLGRP_LINK,
479 #define RTNLGRP_LINK RTNLGRP_LINK
480   RTNLGRP_NOTIFY,
481 #define RTNLGRP_NOTIFY RTNLGRP_NOTIFY
482   RTNLGRP_NEIGH,
483 #define RTNLGRP_NEIGH RTNLGRP_NEIGH
484   RTNLGRP_TC,
485 #define RTNLGRP_TC RTNLGRP_TC
486   RTNLGRP_IPV4_IFADDR,
487 #define RTNLGRP_IPV4_IFADDR RTNLGRP_IPV4_IFADDR
488   RTNLGRP_IPV4_MROUTE,
489 #define RTNLGRP_IPV4_MROUTE RTNLGRP_IPV4_MROUTE
490   RTNLGRP_IPV4_ROUTE,
491 #define RTNLGRP_IPV4_ROUTE RTNLGRP_IPV4_ROUTE
492   RTNLGRP_IPV4_RULE,
493 #define RTNLGRP_IPV4_RULE RTNLGRP_IPV4_RULE
494   RTNLGRP_IPV6_IFADDR,
495 #define RTNLGRP_IPV6_IFADDR RTNLGRP_IPV6_IFADDR
496   RTNLGRP_IPV6_MROUTE,
497 #define RTNLGRP_IPV6_MROUTE RTNLGRP_IPV6_MROUTE
498   RTNLGRP_IPV6_ROUTE,
499 #define RTNLGRP_IPV6_ROUTE RTNLGRP_IPV6_ROUTE
500   RTNLGRP_IPV6_IFINFO,
501 #define RTNLGRP_IPV6_IFINFO RTNLGRP_IPV6_IFINFO
502   RTNLGRP_DECnet_IFADDR,
503 #define RTNLGRP_DECnet_IFADDR RTNLGRP_DECnet_IFADDR
504   RTNLGRP_NOP2,
505   RTNLGRP_DECnet_ROUTE,
506 #define RTNLGRP_DECnet_ROUTE RTNLGRP_DECnet_ROUTE
507   RTNLGRP_DECnet_RULE,
508 #define RTNLGRP_DECnet_RULE RTNLGRP_DECnet_RULE
509   RTNLGRP_NOP4,
510   RTNLGRP_IPV6_PREFIX,
511 #define RTNLGRP_IPV6_PREFIX RTNLGRP_IPV6_PREFIX
512   RTNLGRP_IPV6_RULE,
513 #define RTNLGRP_IPV6_RULE RTNLGRP_IPV6_RULE
514   RTNLGRP_ND_USEROPT,
515 #define RTNLGRP_ND_USEROPT RTNLGRP_ND_USEROPT
516   RTNLGRP_PHONET_IFADDR,
517 #define RTNLGRP_PHONET_IFADDR RTNLGRP_PHONET_IFADDR
518   RTNLGRP_PHONET_ROUTE,
519 #define RTNLGRP_PHONET_ROUTE RTNLGRP_PHONET_ROUTE
520   RTNLGRP_DCB,
521 #define RTNLGRP_DCB RTNLGRP_DCB
522   RTNLGRP_IPV4_NETCONF,
523 #define RTNLGRP_IPV4_NETCONF RTNLGRP_IPV4_NETCONF
524   RTNLGRP_IPV6_NETCONF,
525 #define RTNLGRP_IPV6_NETCONF RTNLGRP_IPV6_NETCONF
526   RTNLGRP_MDB,
527 #define RTNLGRP_MDB RTNLGRP_MDB
528   RTNLGRP_MPLS_ROUTE,
529 #define RTNLGRP_MPLS_ROUTE RTNLGRP_MPLS_ROUTE
530   RTNLGRP_NSID,
531 #define RTNLGRP_NSID RTNLGRP_NSID
532   RTNLGRP_MPLS_NETCONF,
533 #define RTNLGRP_MPLS_NETCONF RTNLGRP_MPLS_NETCONF
534   RTNLGRP_IPV4_MROUTE_R,
535 #define RTNLGRP_IPV4_MROUTE_R RTNLGRP_IPV4_MROUTE_R
536   RTNLGRP_IPV6_MROUTE_R,
537 #define RTNLGRP_IPV6_MROUTE_R RTNLGRP_IPV6_MROUTE_R
538   RTNLGRP_NEXTHOP,
539 #define RTNLGRP_NEXTHOP RTNLGRP_NEXTHOP
540   __RTNLGRP_MAX
541 };
542 #define RTNLGRP_MAX (__RTNLGRP_MAX - 1)
543 struct tcamsg {
544   unsigned char tca_family;
545   unsigned char tca__pad1;
546   unsigned short tca__pad2;
547 };
548 enum {
549   TCA_ROOT_UNSPEC,
550   TCA_ROOT_TAB,
551 #define TCA_ACT_TAB TCA_ROOT_TAB
552 #define TCAA_MAX TCA_ROOT_TAB
553   TCA_ROOT_FLAGS,
554   TCA_ROOT_COUNT,
555   TCA_ROOT_TIME_DELTA,
556   __TCA_ROOT_MAX,
557 #define TCA_ROOT_MAX (__TCA_ROOT_MAX - 1)
558 };
559 #define TA_RTA(r) ((struct rtattr *) (((char *) (r)) + NLMSG_ALIGN(sizeof(struct tcamsg))))
560 #define TA_PAYLOAD(n) NLMSG_PAYLOAD(n, sizeof(struct tcamsg))
561 #define TCA_FLAG_LARGE_DUMP_ON (1 << 0)
562 #define RTEXT_FILTER_VF (1 << 0)
563 #define RTEXT_FILTER_BRVLAN (1 << 1)
564 #define RTEXT_FILTER_BRVLAN_COMPRESSED (1 << 2)
565 #define RTEXT_FILTER_SKIP_STATS (1 << 3)
566 #endif
567