• Home
  • History
  • Annotate
  • 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_NEWVLAN = 112,
155  #define RTM_NEWNVLAN RTM_NEWVLAN
156    RTM_DELVLAN,
157  #define RTM_DELVLAN RTM_DELVLAN
158    RTM_GETVLAN,
159  #define RTM_GETVLAN RTM_GETVLAN
160    __RTM_MAX,
161  #define RTM_MAX (((__RTM_MAX + 3) & ~3) - 1)
162  };
163  #define RTM_NR_MSGTYPES (RTM_MAX + 1 - RTM_BASE)
164  #define RTM_NR_FAMILIES (RTM_NR_MSGTYPES >> 2)
165  #define RTM_FAM(cmd) (((cmd) - RTM_BASE) >> 2)
166  struct rtattr {
167    unsigned short rta_len;
168    unsigned short rta_type;
169  };
170  #define RTA_ALIGNTO 4U
171  #define RTA_ALIGN(len) (((len) + RTA_ALIGNTO - 1) & ~(RTA_ALIGNTO - 1))
172  #define RTA_OK(rta,len) ((len) >= (int) sizeof(struct rtattr) && (rta)->rta_len >= sizeof(struct rtattr) && (rta)->rta_len <= (len))
173  #define RTA_NEXT(rta,attrlen) ((attrlen) -= RTA_ALIGN((rta)->rta_len), (struct rtattr *) (((char *) (rta)) + RTA_ALIGN((rta)->rta_len)))
174  #define RTA_LENGTH(len) (RTA_ALIGN(sizeof(struct rtattr)) + (len))
175  #define RTA_SPACE(len) RTA_ALIGN(RTA_LENGTH(len))
176  #define RTA_DATA(rta) ((void *) (((char *) (rta)) + RTA_LENGTH(0)))
177  #define RTA_PAYLOAD(rta) ((int) ((rta)->rta_len) - RTA_LENGTH(0))
178  struct rtmsg {
179    unsigned char rtm_family;
180    unsigned char rtm_dst_len;
181    unsigned char rtm_src_len;
182    unsigned char rtm_tos;
183    unsigned char rtm_table;
184    unsigned char rtm_protocol;
185    unsigned char rtm_scope;
186    unsigned char rtm_type;
187    unsigned rtm_flags;
188  };
189  enum {
190    RTN_UNSPEC,
191    RTN_UNICAST,
192    RTN_LOCAL,
193    RTN_BROADCAST,
194    RTN_ANYCAST,
195    RTN_MULTICAST,
196    RTN_BLACKHOLE,
197    RTN_UNREACHABLE,
198    RTN_PROHIBIT,
199    RTN_THROW,
200    RTN_NAT,
201    RTN_XRESOLVE,
202    __RTN_MAX
203  };
204  #define RTN_MAX (__RTN_MAX - 1)
205  #define RTPROT_UNSPEC 0
206  #define RTPROT_REDIRECT 1
207  #define RTPROT_KERNEL 2
208  #define RTPROT_BOOT 3
209  #define RTPROT_STATIC 4
210  #define RTPROT_GATED 8
211  #define RTPROT_RA 9
212  #define RTPROT_MRT 10
213  #define RTPROT_ZEBRA 11
214  #define RTPROT_BIRD 12
215  #define RTPROT_DNROUTED 13
216  #define RTPROT_XORP 14
217  #define RTPROT_NTK 15
218  #define RTPROT_DHCP 16
219  #define RTPROT_MROUTED 17
220  #define RTPROT_KEEPALIVED 18
221  #define RTPROT_BABEL 42
222  #define RTPROT_BGP 186
223  #define RTPROT_ISIS 187
224  #define RTPROT_OSPF 188
225  #define RTPROT_RIP 189
226  #define RTPROT_EIGRP 192
227  enum rt_scope_t {
228    RT_SCOPE_UNIVERSE = 0,
229    RT_SCOPE_SITE = 200,
230    RT_SCOPE_LINK = 253,
231    RT_SCOPE_HOST = 254,
232    RT_SCOPE_NOWHERE = 255
233  };
234  #define RTM_F_NOTIFY 0x100
235  #define RTM_F_CLONED 0x200
236  #define RTM_F_EQUALIZE 0x400
237  #define RTM_F_PREFIX 0x800
238  #define RTM_F_LOOKUP_TABLE 0x1000
239  #define RTM_F_FIB_MATCH 0x2000
240  #define RTM_F_OFFLOAD 0x4000
241  #define RTM_F_TRAP 0x8000
242  #define RTM_F_OFFLOAD_FAILED 0x20000000
243  enum rt_class_t {
244    RT_TABLE_UNSPEC = 0,
245    RT_TABLE_COMPAT = 252,
246    RT_TABLE_DEFAULT = 253,
247    RT_TABLE_MAIN = 254,
248    RT_TABLE_LOCAL = 255,
249    RT_TABLE_MAX = 0xFFFFFFFF
250  };
251  enum rtattr_type_t {
252    RTA_UNSPEC,
253    RTA_DST,
254    RTA_SRC,
255    RTA_IIF,
256    RTA_OIF,
257    RTA_GATEWAY,
258    RTA_PRIORITY,
259    RTA_PREFSRC,
260    RTA_METRICS,
261    RTA_MULTIPATH,
262    RTA_PROTOINFO,
263    RTA_FLOW,
264    RTA_CACHEINFO,
265    RTA_SESSION,
266    RTA_MP_ALGO,
267    RTA_TABLE,
268    RTA_MARK,
269    RTA_MFC_STATS,
270    RTA_VIA,
271    RTA_NEWDST,
272    RTA_PREF,
273    RTA_ENCAP_TYPE,
274    RTA_ENCAP,
275    RTA_EXPIRES,
276    RTA_PAD,
277    RTA_UID,
278    RTA_TTL_PROPAGATE,
279    RTA_IP_PROTO,
280    RTA_SPORT,
281    RTA_DPORT,
282    RTA_NH_ID,
283    __RTA_MAX
284  };
285  #define RTA_MAX (__RTA_MAX - 1)
286  #define RTM_RTA(r) ((struct rtattr *) (((char *) (r)) + NLMSG_ALIGN(sizeof(struct rtmsg))))
287  #define RTM_PAYLOAD(n) NLMSG_PAYLOAD(n, sizeof(struct rtmsg))
288  struct rtnexthop {
289    unsigned short rtnh_len;
290    unsigned char rtnh_flags;
291    unsigned char rtnh_hops;
292    int rtnh_ifindex;
293  };
294  #define RTNH_F_DEAD 1
295  #define RTNH_F_PERVASIVE 2
296  #define RTNH_F_ONLINK 4
297  #define RTNH_F_OFFLOAD 8
298  #define RTNH_F_LINKDOWN 16
299  #define RTNH_F_UNRESOLVED 32
300  #define RTNH_F_TRAP 64
301  #define RTNH_COMPARE_MASK (RTNH_F_DEAD | RTNH_F_LINKDOWN | RTNH_F_OFFLOAD | RTNH_F_TRAP)
302  #define RTNH_ALIGNTO 4
303  #define RTNH_ALIGN(len) (((len) + RTNH_ALIGNTO - 1) & ~(RTNH_ALIGNTO - 1))
304  #define RTNH_OK(rtnh,len) ((rtnh)->rtnh_len >= sizeof(struct rtnexthop) && ((int) (rtnh)->rtnh_len) <= (len))
305  #define RTNH_NEXT(rtnh) ((struct rtnexthop *) (((char *) (rtnh)) + RTNH_ALIGN((rtnh)->rtnh_len)))
306  #define RTNH_LENGTH(len) (RTNH_ALIGN(sizeof(struct rtnexthop)) + (len))
307  #define RTNH_SPACE(len) RTNH_ALIGN(RTNH_LENGTH(len))
308  #define RTNH_DATA(rtnh) ((struct rtattr *) (((char *) (rtnh)) + RTNH_LENGTH(0)))
309  struct rtvia {
310    __kernel_sa_family_t rtvia_family;
311    __u8 rtvia_addr[0];
312  };
313  struct rta_cacheinfo {
314    __u32 rta_clntref;
315    __u32 rta_lastuse;
316    __s32 rta_expires;
317    __u32 rta_error;
318    __u32 rta_used;
319  #define RTNETLINK_HAVE_PEERINFO 1
320    __u32 rta_id;
321    __u32 rta_ts;
322    __u32 rta_tsage;
323  };
324  enum {
325    RTAX_UNSPEC,
326  #define RTAX_UNSPEC RTAX_UNSPEC
327    RTAX_LOCK,
328  #define RTAX_LOCK RTAX_LOCK
329    RTAX_MTU,
330  #define RTAX_MTU RTAX_MTU
331    RTAX_WINDOW,
332  #define RTAX_WINDOW RTAX_WINDOW
333    RTAX_RTT,
334  #define RTAX_RTT RTAX_RTT
335    RTAX_RTTVAR,
336  #define RTAX_RTTVAR RTAX_RTTVAR
337    RTAX_SSTHRESH,
338  #define RTAX_SSTHRESH RTAX_SSTHRESH
339    RTAX_CWND,
340  #define RTAX_CWND RTAX_CWND
341    RTAX_ADVMSS,
342  #define RTAX_ADVMSS RTAX_ADVMSS
343    RTAX_REORDERING,
344  #define RTAX_REORDERING RTAX_REORDERING
345    RTAX_HOPLIMIT,
346  #define RTAX_HOPLIMIT RTAX_HOPLIMIT
347    RTAX_INITCWND,
348  #define RTAX_INITCWND RTAX_INITCWND
349    RTAX_FEATURES,
350  #define RTAX_FEATURES RTAX_FEATURES
351    RTAX_RTO_MIN,
352  #define RTAX_RTO_MIN RTAX_RTO_MIN
353    RTAX_INITRWND,
354  #define RTAX_INITRWND RTAX_INITRWND
355    RTAX_QUICKACK,
356  #define RTAX_QUICKACK RTAX_QUICKACK
357    RTAX_CC_ALGO,
358  #define RTAX_CC_ALGO RTAX_CC_ALGO
359    RTAX_FASTOPEN_NO_COOKIE,
360  #define RTAX_FASTOPEN_NO_COOKIE RTAX_FASTOPEN_NO_COOKIE
361    __RTAX_MAX
362  };
363  #define RTAX_MAX (__RTAX_MAX - 1)
364  #define RTAX_FEATURE_ECN (1 << 0)
365  #define RTAX_FEATURE_SACK (1 << 1)
366  #define RTAX_FEATURE_TIMESTAMP (1 << 2)
367  #define RTAX_FEATURE_ALLFRAG (1 << 3)
368  #define RTAX_FEATURE_MASK (RTAX_FEATURE_ECN | RTAX_FEATURE_SACK | RTAX_FEATURE_TIMESTAMP | RTAX_FEATURE_ALLFRAG)
369  struct rta_session {
370    __u8 proto;
371    __u8 pad1;
372    __u16 pad2;
373    union {
374      struct {
375        __u16 sport;
376        __u16 dport;
377      } ports;
378      struct {
379        __u8 type;
380        __u8 code;
381        __u16 ident;
382      } icmpt;
383      __u32 spi;
384    } u;
385  };
386  struct rta_mfc_stats {
387    __u64 mfcs_packets;
388    __u64 mfcs_bytes;
389    __u64 mfcs_wrong_if;
390  };
391  struct rtgenmsg {
392    unsigned char rtgen_family;
393  };
394  struct ifinfomsg {
395    unsigned char ifi_family;
396    unsigned char __ifi_pad;
397    unsigned short ifi_type;
398    int ifi_index;
399    unsigned ifi_flags;
400    unsigned ifi_change;
401  };
402  struct prefixmsg {
403    unsigned char prefix_family;
404    unsigned char prefix_pad1;
405    unsigned short prefix_pad2;
406    int prefix_ifindex;
407    unsigned char prefix_type;
408    unsigned char prefix_len;
409    unsigned char prefix_flags;
410    unsigned char prefix_pad3;
411  };
412  enum {
413    PREFIX_UNSPEC,
414    PREFIX_ADDRESS,
415    PREFIX_CACHEINFO,
416    __PREFIX_MAX
417  };
418  #define PREFIX_MAX (__PREFIX_MAX - 1)
419  struct prefix_cacheinfo {
420    __u32 preferred_time;
421    __u32 valid_time;
422  };
423  struct tcmsg {
424    unsigned char tcm_family;
425    unsigned char tcm__pad1;
426    unsigned short tcm__pad2;
427    int tcm_ifindex;
428    __u32 tcm_handle;
429    __u32 tcm_parent;
430  #define tcm_block_index tcm_parent
431    __u32 tcm_info;
432  };
433  #define TCM_IFINDEX_MAGIC_BLOCK (0xFFFFFFFFU)
434  enum {
435    TCA_UNSPEC,
436    TCA_KIND,
437    TCA_OPTIONS,
438    TCA_STATS,
439    TCA_XSTATS,
440    TCA_RATE,
441    TCA_FCNT,
442    TCA_STATS2,
443    TCA_STAB,
444    TCA_PAD,
445    TCA_DUMP_INVISIBLE,
446    TCA_CHAIN,
447    TCA_HW_OFFLOAD,
448    TCA_INGRESS_BLOCK,
449    TCA_EGRESS_BLOCK,
450    TCA_DUMP_FLAGS,
451    __TCA_MAX
452  };
453  #define TCA_MAX (__TCA_MAX - 1)
454  #define TCA_DUMP_FLAGS_TERSE (1 << 0)
455  #define TCA_RTA(r) ((struct rtattr *) (((char *) (r)) + NLMSG_ALIGN(sizeof(struct tcmsg))))
456  #define TCA_PAYLOAD(n) NLMSG_PAYLOAD(n, sizeof(struct tcmsg))
457  struct nduseroptmsg {
458    unsigned char nduseropt_family;
459    unsigned char nduseropt_pad1;
460    unsigned short nduseropt_opts_len;
461    int nduseropt_ifindex;
462    __u8 nduseropt_icmp_type;
463    __u8 nduseropt_icmp_code;
464    unsigned short nduseropt_pad2;
465    unsigned int nduseropt_pad3;
466  };
467  enum {
468    NDUSEROPT_UNSPEC,
469    NDUSEROPT_SRCADDR,
470    __NDUSEROPT_MAX
471  };
472  #define NDUSEROPT_MAX (__NDUSEROPT_MAX - 1)
473  #define RTMGRP_LINK 1
474  #define RTMGRP_NOTIFY 2
475  #define RTMGRP_NEIGH 4
476  #define RTMGRP_TC 8
477  #define RTMGRP_IPV4_IFADDR 0x10
478  #define RTMGRP_IPV4_MROUTE 0x20
479  #define RTMGRP_IPV4_ROUTE 0x40
480  #define RTMGRP_IPV4_RULE 0x80
481  #define RTMGRP_IPV6_IFADDR 0x100
482  #define RTMGRP_IPV6_MROUTE 0x200
483  #define RTMGRP_IPV6_ROUTE 0x400
484  #define RTMGRP_IPV6_IFINFO 0x800
485  #define RTMGRP_DECnet_IFADDR 0x1000
486  #define RTMGRP_DECnet_ROUTE 0x4000
487  #define RTMGRP_IPV6_PREFIX 0x20000
488  enum rtnetlink_groups {
489    RTNLGRP_NONE,
490  #define RTNLGRP_NONE RTNLGRP_NONE
491    RTNLGRP_LINK,
492  #define RTNLGRP_LINK RTNLGRP_LINK
493    RTNLGRP_NOTIFY,
494  #define RTNLGRP_NOTIFY RTNLGRP_NOTIFY
495    RTNLGRP_NEIGH,
496  #define RTNLGRP_NEIGH RTNLGRP_NEIGH
497    RTNLGRP_TC,
498  #define RTNLGRP_TC RTNLGRP_TC
499    RTNLGRP_IPV4_IFADDR,
500  #define RTNLGRP_IPV4_IFADDR RTNLGRP_IPV4_IFADDR
501    RTNLGRP_IPV4_MROUTE,
502  #define RTNLGRP_IPV4_MROUTE RTNLGRP_IPV4_MROUTE
503    RTNLGRP_IPV4_ROUTE,
504  #define RTNLGRP_IPV4_ROUTE RTNLGRP_IPV4_ROUTE
505    RTNLGRP_IPV4_RULE,
506  #define RTNLGRP_IPV4_RULE RTNLGRP_IPV4_RULE
507    RTNLGRP_IPV6_IFADDR,
508  #define RTNLGRP_IPV6_IFADDR RTNLGRP_IPV6_IFADDR
509    RTNLGRP_IPV6_MROUTE,
510  #define RTNLGRP_IPV6_MROUTE RTNLGRP_IPV6_MROUTE
511    RTNLGRP_IPV6_ROUTE,
512  #define RTNLGRP_IPV6_ROUTE RTNLGRP_IPV6_ROUTE
513    RTNLGRP_IPV6_IFINFO,
514  #define RTNLGRP_IPV6_IFINFO RTNLGRP_IPV6_IFINFO
515    RTNLGRP_DECnet_IFADDR,
516  #define RTNLGRP_DECnet_IFADDR RTNLGRP_DECnet_IFADDR
517    RTNLGRP_NOP2,
518    RTNLGRP_DECnet_ROUTE,
519  #define RTNLGRP_DECnet_ROUTE RTNLGRP_DECnet_ROUTE
520    RTNLGRP_DECnet_RULE,
521  #define RTNLGRP_DECnet_RULE RTNLGRP_DECnet_RULE
522    RTNLGRP_NOP4,
523    RTNLGRP_IPV6_PREFIX,
524  #define RTNLGRP_IPV6_PREFIX RTNLGRP_IPV6_PREFIX
525    RTNLGRP_IPV6_RULE,
526  #define RTNLGRP_IPV6_RULE RTNLGRP_IPV6_RULE
527    RTNLGRP_ND_USEROPT,
528  #define RTNLGRP_ND_USEROPT RTNLGRP_ND_USEROPT
529    RTNLGRP_PHONET_IFADDR,
530  #define RTNLGRP_PHONET_IFADDR RTNLGRP_PHONET_IFADDR
531    RTNLGRP_PHONET_ROUTE,
532  #define RTNLGRP_PHONET_ROUTE RTNLGRP_PHONET_ROUTE
533    RTNLGRP_DCB,
534  #define RTNLGRP_DCB RTNLGRP_DCB
535    RTNLGRP_IPV4_NETCONF,
536  #define RTNLGRP_IPV4_NETCONF RTNLGRP_IPV4_NETCONF
537    RTNLGRP_IPV6_NETCONF,
538  #define RTNLGRP_IPV6_NETCONF RTNLGRP_IPV6_NETCONF
539    RTNLGRP_MDB,
540  #define RTNLGRP_MDB RTNLGRP_MDB
541    RTNLGRP_MPLS_ROUTE,
542  #define RTNLGRP_MPLS_ROUTE RTNLGRP_MPLS_ROUTE
543    RTNLGRP_NSID,
544  #define RTNLGRP_NSID RTNLGRP_NSID
545    RTNLGRP_MPLS_NETCONF,
546  #define RTNLGRP_MPLS_NETCONF RTNLGRP_MPLS_NETCONF
547    RTNLGRP_IPV4_MROUTE_R,
548  #define RTNLGRP_IPV4_MROUTE_R RTNLGRP_IPV4_MROUTE_R
549    RTNLGRP_IPV6_MROUTE_R,
550  #define RTNLGRP_IPV6_MROUTE_R RTNLGRP_IPV6_MROUTE_R
551    RTNLGRP_NEXTHOP,
552  #define RTNLGRP_NEXTHOP RTNLGRP_NEXTHOP
553    RTNLGRP_BRVLAN,
554  #define RTNLGRP_BRVLAN RTNLGRP_BRVLAN
555    __RTNLGRP_MAX
556  };
557  #define RTNLGRP_MAX (__RTNLGRP_MAX - 1)
558  struct tcamsg {
559    unsigned char tca_family;
560    unsigned char tca__pad1;
561    unsigned short tca__pad2;
562  };
563  enum {
564    TCA_ROOT_UNSPEC,
565    TCA_ROOT_TAB,
566  #define TCA_ACT_TAB TCA_ROOT_TAB
567  #define TCAA_MAX TCA_ROOT_TAB
568    TCA_ROOT_FLAGS,
569    TCA_ROOT_COUNT,
570    TCA_ROOT_TIME_DELTA,
571    __TCA_ROOT_MAX,
572  #define TCA_ROOT_MAX (__TCA_ROOT_MAX - 1)
573  };
574  #define TA_RTA(r) ((struct rtattr *) (((char *) (r)) + NLMSG_ALIGN(sizeof(struct tcamsg))))
575  #define TA_PAYLOAD(n) NLMSG_PAYLOAD(n, sizeof(struct tcamsg))
576  #define TCA_FLAG_LARGE_DUMP_ON (1 << 0)
577  #define TCA_ACT_FLAG_LARGE_DUMP_ON TCA_FLAG_LARGE_DUMP_ON
578  #define TCA_ACT_FLAG_TERSE_DUMP (1 << 1)
579  #define RTEXT_FILTER_VF (1 << 0)
580  #define RTEXT_FILTER_BRVLAN (1 << 1)
581  #define RTEXT_FILTER_BRVLAN_COMPRESSED (1 << 2)
582  #define RTEXT_FILTER_SKIP_STATS (1 << 3)
583  #define RTEXT_FILTER_MRP (1 << 4)
584  #define RTEXT_FILTER_CFM_CONFIG (1 << 5)
585  #define RTEXT_FILTER_CFM_STATUS (1 << 6)
586  #endif
587