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