xref: /linux-6.15/include/uapi/linux/if_link.h (revision fee6d4c7)
1 #ifndef _UAPI_LINUX_IF_LINK_H
2 #define _UAPI_LINUX_IF_LINK_H
3 
4 #include <linux/types.h>
5 #include <linux/netlink.h>
6 
7 /* This struct should be in sync with struct rtnl_link_stats64 */
8 struct rtnl_link_stats {
9 	__u32	rx_packets;		/* total packets received	*/
10 	__u32	tx_packets;		/* total packets transmitted	*/
11 	__u32	rx_bytes;		/* total bytes received 	*/
12 	__u32	tx_bytes;		/* total bytes transmitted	*/
13 	__u32	rx_errors;		/* bad packets received		*/
14 	__u32	tx_errors;		/* packet transmit problems	*/
15 	__u32	rx_dropped;		/* no space in linux buffers	*/
16 	__u32	tx_dropped;		/* no space available in linux	*/
17 	__u32	multicast;		/* multicast packets received	*/
18 	__u32	collisions;
19 
20 	/* detailed rx_errors: */
21 	__u32	rx_length_errors;
22 	__u32	rx_over_errors;		/* receiver ring buff overflow	*/
23 	__u32	rx_crc_errors;		/* recved pkt with crc error	*/
24 	__u32	rx_frame_errors;	/* recv'd frame alignment error */
25 	__u32	rx_fifo_errors;		/* recv'r fifo overrun		*/
26 	__u32	rx_missed_errors;	/* receiver missed packet	*/
27 
28 	/* detailed tx_errors */
29 	__u32	tx_aborted_errors;
30 	__u32	tx_carrier_errors;
31 	__u32	tx_fifo_errors;
32 	__u32	tx_heartbeat_errors;
33 	__u32	tx_window_errors;
34 
35 	/* for cslip etc */
36 	__u32	rx_compressed;
37 	__u32	tx_compressed;
38 };
39 
40 /* The main device statistics structure */
41 struct rtnl_link_stats64 {
42 	__u64	rx_packets;		/* total packets received	*/
43 	__u64	tx_packets;		/* total packets transmitted	*/
44 	__u64	rx_bytes;		/* total bytes received 	*/
45 	__u64	tx_bytes;		/* total bytes transmitted	*/
46 	__u64	rx_errors;		/* bad packets received		*/
47 	__u64	tx_errors;		/* packet transmit problems	*/
48 	__u64	rx_dropped;		/* no space in linux buffers	*/
49 	__u64	tx_dropped;		/* no space available in linux	*/
50 	__u64	multicast;		/* multicast packets received	*/
51 	__u64	collisions;
52 
53 	/* detailed rx_errors: */
54 	__u64	rx_length_errors;
55 	__u64	rx_over_errors;		/* receiver ring buff overflow	*/
56 	__u64	rx_crc_errors;		/* recved pkt with crc error	*/
57 	__u64	rx_frame_errors;	/* recv'd frame alignment error */
58 	__u64	rx_fifo_errors;		/* recv'r fifo overrun		*/
59 	__u64	rx_missed_errors;	/* receiver missed packet	*/
60 
61 	/* detailed tx_errors */
62 	__u64	tx_aborted_errors;
63 	__u64	tx_carrier_errors;
64 	__u64	tx_fifo_errors;
65 	__u64	tx_heartbeat_errors;
66 	__u64	tx_window_errors;
67 
68 	/* for cslip etc */
69 	__u64	rx_compressed;
70 	__u64	tx_compressed;
71 };
72 
73 /* The struct should be in sync with struct ifmap */
74 struct rtnl_link_ifmap {
75 	__u64	mem_start;
76 	__u64	mem_end;
77 	__u64	base_addr;
78 	__u16	irq;
79 	__u8	dma;
80 	__u8	port;
81 };
82 
83 /*
84  * IFLA_AF_SPEC
85  *   Contains nested attributes for address family specific attributes.
86  *   Each address family may create a attribute with the address family
87  *   number as type and create its own attribute structure in it.
88  *
89  *   Example:
90  *   [IFLA_AF_SPEC] = {
91  *       [AF_INET] = {
92  *           [IFLA_INET_CONF] = ...,
93  *       },
94  *       [AF_INET6] = {
95  *           [IFLA_INET6_FLAGS] = ...,
96  *           [IFLA_INET6_CONF] = ...,
97  *       }
98  *   }
99  */
100 
101 enum {
102 	IFLA_UNSPEC,
103 	IFLA_ADDRESS,
104 	IFLA_BROADCAST,
105 	IFLA_IFNAME,
106 	IFLA_MTU,
107 	IFLA_LINK,
108 	IFLA_QDISC,
109 	IFLA_STATS,
110 	IFLA_COST,
111 #define IFLA_COST IFLA_COST
112 	IFLA_PRIORITY,
113 #define IFLA_PRIORITY IFLA_PRIORITY
114 	IFLA_MASTER,
115 #define IFLA_MASTER IFLA_MASTER
116 	IFLA_WIRELESS,		/* Wireless Extension event - see wireless.h */
117 #define IFLA_WIRELESS IFLA_WIRELESS
118 	IFLA_PROTINFO,		/* Protocol specific information for a link */
119 #define IFLA_PROTINFO IFLA_PROTINFO
120 	IFLA_TXQLEN,
121 #define IFLA_TXQLEN IFLA_TXQLEN
122 	IFLA_MAP,
123 #define IFLA_MAP IFLA_MAP
124 	IFLA_WEIGHT,
125 #define IFLA_WEIGHT IFLA_WEIGHT
126 	IFLA_OPERSTATE,
127 	IFLA_LINKMODE,
128 	IFLA_LINKINFO,
129 #define IFLA_LINKINFO IFLA_LINKINFO
130 	IFLA_NET_NS_PID,
131 	IFLA_IFALIAS,
132 	IFLA_NUM_VF,		/* Number of VFs if device is SR-IOV PF */
133 	IFLA_VFINFO_LIST,
134 	IFLA_STATS64,
135 	IFLA_VF_PORTS,
136 	IFLA_PORT_SELF,
137 	IFLA_AF_SPEC,
138 	IFLA_GROUP,		/* Group the device belongs to */
139 	IFLA_NET_NS_FD,
140 	IFLA_EXT_MASK,		/* Extended info mask, VFs, etc */
141 	IFLA_PROMISCUITY,	/* Promiscuity count: > 0 means acts PROMISC */
142 #define IFLA_PROMISCUITY IFLA_PROMISCUITY
143 	IFLA_NUM_TX_QUEUES,
144 	IFLA_NUM_RX_QUEUES,
145 	IFLA_CARRIER,
146 	IFLA_PHYS_PORT_ID,
147 	IFLA_CARRIER_CHANGES,
148 	IFLA_PHYS_SWITCH_ID,
149 	IFLA_LINK_NETNSID,
150 	IFLA_PHYS_PORT_NAME,
151 	IFLA_PROTO_DOWN,
152 	__IFLA_MAX
153 };
154 
155 
156 #define IFLA_MAX (__IFLA_MAX - 1)
157 
158 /* backwards compatibility for userspace */
159 #ifndef __KERNEL__
160 #define IFLA_RTA(r)  ((struct rtattr*)(((char*)(r)) + NLMSG_ALIGN(sizeof(struct ifinfomsg))))
161 #define IFLA_PAYLOAD(n) NLMSG_PAYLOAD(n,sizeof(struct ifinfomsg))
162 #endif
163 
164 enum {
165 	IFLA_INET_UNSPEC,
166 	IFLA_INET_CONF,
167 	__IFLA_INET_MAX,
168 };
169 
170 #define IFLA_INET_MAX (__IFLA_INET_MAX - 1)
171 
172 /* ifi_flags.
173 
174    IFF_* flags.
175 
176    The only change is:
177    IFF_LOOPBACK, IFF_BROADCAST and IFF_POINTOPOINT are
178    more not changeable by user. They describe link media
179    characteristics and set by device driver.
180 
181    Comments:
182    - Combination IFF_BROADCAST|IFF_POINTOPOINT is invalid
183    - If neither of these three flags are set;
184      the interface is NBMA.
185 
186    - IFF_MULTICAST does not mean anything special:
187    multicasts can be used on all not-NBMA links.
188    IFF_MULTICAST means that this media uses special encapsulation
189    for multicast frames. Apparently, all IFF_POINTOPOINT and
190    IFF_BROADCAST devices are able to use multicasts too.
191  */
192 
193 /* IFLA_LINK.
194    For usual devices it is equal ifi_index.
195    If it is a "virtual interface" (f.e. tunnel), ifi_link
196    can point to real physical interface (f.e. for bandwidth calculations),
197    or maybe 0, what means, that real media is unknown (usual
198    for IPIP tunnels, when route to endpoint is allowed to change)
199  */
200 
201 /* Subtype attributes for IFLA_PROTINFO */
202 enum {
203 	IFLA_INET6_UNSPEC,
204 	IFLA_INET6_FLAGS,	/* link flags			*/
205 	IFLA_INET6_CONF,	/* sysctl parameters		*/
206 	IFLA_INET6_STATS,	/* statistics			*/
207 	IFLA_INET6_MCAST,	/* MC things. What of them?	*/
208 	IFLA_INET6_CACHEINFO,	/* time values and max reasm size */
209 	IFLA_INET6_ICMP6STATS,	/* statistics (icmpv6)		*/
210 	IFLA_INET6_TOKEN,	/* device token			*/
211 	IFLA_INET6_ADDR_GEN_MODE, /* implicit address generator mode */
212 	__IFLA_INET6_MAX
213 };
214 
215 #define IFLA_INET6_MAX	(__IFLA_INET6_MAX - 1)
216 
217 enum in6_addr_gen_mode {
218 	IN6_ADDR_GEN_MODE_EUI64,
219 	IN6_ADDR_GEN_MODE_NONE,
220 	IN6_ADDR_GEN_MODE_STABLE_PRIVACY,
221 };
222 
223 /* Bridge section */
224 
225 enum {
226 	IFLA_BR_UNSPEC,
227 	IFLA_BR_FORWARD_DELAY,
228 	IFLA_BR_HELLO_TIME,
229 	IFLA_BR_MAX_AGE,
230 	IFLA_BR_AGEING_TIME,
231 	IFLA_BR_STP_STATE,
232 	IFLA_BR_PRIORITY,
233 	IFLA_BR_VLAN_FILTERING,
234 	IFLA_BR_VLAN_PROTOCOL,
235 	IFLA_BR_GROUP_FWD_MASK,
236 	IFLA_BR_ROOT_ID,
237 	IFLA_BR_BRIDGE_ID,
238 	IFLA_BR_ROOT_PORT,
239 	IFLA_BR_ROOT_PATH_COST,
240 	IFLA_BR_TOPOLOGY_CHANGE,
241 	IFLA_BR_TOPOLOGY_CHANGE_DETECTED,
242 	IFLA_BR_HELLO_TIMER,
243 	IFLA_BR_TCN_TIMER,
244 	IFLA_BR_TOPOLOGY_CHANGE_TIMER,
245 	IFLA_BR_GC_TIMER,
246 	IFLA_BR_GROUP_ADDR,
247 	IFLA_BR_FDB_FLUSH,
248 	IFLA_BR_MCAST_ROUTER,
249 	IFLA_BR_MCAST_SNOOPING,
250 	IFLA_BR_MCAST_QUERY_USE_IFADDR,
251 	IFLA_BR_MCAST_QUERIER,
252 	IFLA_BR_MCAST_HASH_ELASTICITY,
253 	IFLA_BR_MCAST_HASH_MAX,
254 	IFLA_BR_MCAST_LAST_MEMBER_CNT,
255 	IFLA_BR_MCAST_STARTUP_QUERY_CNT,
256 	IFLA_BR_MCAST_LAST_MEMBER_INTVL,
257 	IFLA_BR_MCAST_MEMBERSHIP_INTVL,
258 	IFLA_BR_MCAST_QUERIER_INTVL,
259 	IFLA_BR_MCAST_QUERY_INTVL,
260 	IFLA_BR_MCAST_QUERY_RESPONSE_INTVL,
261 	IFLA_BR_MCAST_STARTUP_QUERY_INTVL,
262 	IFLA_BR_NF_CALL_IPTABLES,
263 	IFLA_BR_NF_CALL_IP6TABLES,
264 	IFLA_BR_NF_CALL_ARPTABLES,
265 	IFLA_BR_VLAN_DEFAULT_PVID,
266 	__IFLA_BR_MAX,
267 };
268 
269 #define IFLA_BR_MAX	(__IFLA_BR_MAX - 1)
270 
271 struct ifla_bridge_id {
272 	__u8	prio[2];
273 	__u8	addr[6]; /* ETH_ALEN */
274 };
275 
276 enum {
277 	BRIDGE_MODE_UNSPEC,
278 	BRIDGE_MODE_HAIRPIN,
279 };
280 
281 enum {
282 	IFLA_BRPORT_UNSPEC,
283 	IFLA_BRPORT_STATE,	/* Spanning tree state     */
284 	IFLA_BRPORT_PRIORITY,	/* "             priority  */
285 	IFLA_BRPORT_COST,	/* "             cost      */
286 	IFLA_BRPORT_MODE,	/* mode (hairpin)          */
287 	IFLA_BRPORT_GUARD,	/* bpdu guard              */
288 	IFLA_BRPORT_PROTECT,	/* root port protection    */
289 	IFLA_BRPORT_FAST_LEAVE,	/* multicast fast leave    */
290 	IFLA_BRPORT_LEARNING,	/* mac learning */
291 	IFLA_BRPORT_UNICAST_FLOOD, /* flood unicast traffic */
292 	IFLA_BRPORT_PROXYARP,	/* proxy ARP */
293 	IFLA_BRPORT_LEARNING_SYNC, /* mac learning sync from device */
294 	IFLA_BRPORT_PROXYARP_WIFI, /* proxy ARP for Wi-Fi */
295 	__IFLA_BRPORT_MAX
296 };
297 #define IFLA_BRPORT_MAX (__IFLA_BRPORT_MAX - 1)
298 
299 struct ifla_cacheinfo {
300 	__u32	max_reasm_len;
301 	__u32	tstamp;		/* ipv6InterfaceTable updated timestamp */
302 	__u32	reachable_time;
303 	__u32	retrans_time;
304 };
305 
306 enum {
307 	IFLA_INFO_UNSPEC,
308 	IFLA_INFO_KIND,
309 	IFLA_INFO_DATA,
310 	IFLA_INFO_XSTATS,
311 	IFLA_INFO_SLAVE_KIND,
312 	IFLA_INFO_SLAVE_DATA,
313 	__IFLA_INFO_MAX,
314 };
315 
316 #define IFLA_INFO_MAX	(__IFLA_INFO_MAX - 1)
317 
318 /* VLAN section */
319 
320 enum {
321 	IFLA_VLAN_UNSPEC,
322 	IFLA_VLAN_ID,
323 	IFLA_VLAN_FLAGS,
324 	IFLA_VLAN_EGRESS_QOS,
325 	IFLA_VLAN_INGRESS_QOS,
326 	IFLA_VLAN_PROTOCOL,
327 	__IFLA_VLAN_MAX,
328 };
329 
330 #define IFLA_VLAN_MAX	(__IFLA_VLAN_MAX - 1)
331 
332 struct ifla_vlan_flags {
333 	__u32	flags;
334 	__u32	mask;
335 };
336 
337 enum {
338 	IFLA_VLAN_QOS_UNSPEC,
339 	IFLA_VLAN_QOS_MAPPING,
340 	__IFLA_VLAN_QOS_MAX
341 };
342 
343 #define IFLA_VLAN_QOS_MAX	(__IFLA_VLAN_QOS_MAX - 1)
344 
345 struct ifla_vlan_qos_mapping {
346 	__u32 from;
347 	__u32 to;
348 };
349 
350 /* MACVLAN section */
351 enum {
352 	IFLA_MACVLAN_UNSPEC,
353 	IFLA_MACVLAN_MODE,
354 	IFLA_MACVLAN_FLAGS,
355 	IFLA_MACVLAN_MACADDR_MODE,
356 	IFLA_MACVLAN_MACADDR,
357 	IFLA_MACVLAN_MACADDR_DATA,
358 	IFLA_MACVLAN_MACADDR_COUNT,
359 	__IFLA_MACVLAN_MAX,
360 };
361 
362 #define IFLA_MACVLAN_MAX (__IFLA_MACVLAN_MAX - 1)
363 
364 enum macvlan_mode {
365 	MACVLAN_MODE_PRIVATE = 1, /* don't talk to other macvlans */
366 	MACVLAN_MODE_VEPA    = 2, /* talk to other ports through ext bridge */
367 	MACVLAN_MODE_BRIDGE  = 4, /* talk to bridge ports directly */
368 	MACVLAN_MODE_PASSTHRU = 8,/* take over the underlying device */
369 	MACVLAN_MODE_SOURCE  = 16,/* use source MAC address list to assign */
370 };
371 
372 enum macvlan_macaddr_mode {
373 	MACVLAN_MACADDR_ADD,
374 	MACVLAN_MACADDR_DEL,
375 	MACVLAN_MACADDR_FLUSH,
376 	MACVLAN_MACADDR_SET,
377 };
378 
379 #define MACVLAN_FLAG_NOPROMISC	1
380 
381 /* VRF section */
382 enum {
383 	IFLA_VRF_UNSPEC,
384 	IFLA_VRF_TABLE,
385 	__IFLA_VRF_MAX
386 };
387 
388 #define IFLA_VRF_MAX (__IFLA_VRF_MAX - 1)
389 
390 /* IPVLAN section */
391 enum {
392 	IFLA_IPVLAN_UNSPEC,
393 	IFLA_IPVLAN_MODE,
394 	__IFLA_IPVLAN_MAX
395 };
396 
397 #define IFLA_IPVLAN_MAX (__IFLA_IPVLAN_MAX - 1)
398 
399 enum ipvlan_mode {
400 	IPVLAN_MODE_L2 = 0,
401 	IPVLAN_MODE_L3,
402 	IPVLAN_MODE_MAX
403 };
404 
405 /* VXLAN section */
406 enum {
407 	IFLA_VXLAN_UNSPEC,
408 	IFLA_VXLAN_ID,
409 	IFLA_VXLAN_GROUP,	/* group or remote address */
410 	IFLA_VXLAN_LINK,
411 	IFLA_VXLAN_LOCAL,
412 	IFLA_VXLAN_TTL,
413 	IFLA_VXLAN_TOS,
414 	IFLA_VXLAN_LEARNING,
415 	IFLA_VXLAN_AGEING,
416 	IFLA_VXLAN_LIMIT,
417 	IFLA_VXLAN_PORT_RANGE,	/* source port */
418 	IFLA_VXLAN_PROXY,
419 	IFLA_VXLAN_RSC,
420 	IFLA_VXLAN_L2MISS,
421 	IFLA_VXLAN_L3MISS,
422 	IFLA_VXLAN_PORT,	/* destination port */
423 	IFLA_VXLAN_GROUP6,
424 	IFLA_VXLAN_LOCAL6,
425 	IFLA_VXLAN_UDP_CSUM,
426 	IFLA_VXLAN_UDP_ZERO_CSUM6_TX,
427 	IFLA_VXLAN_UDP_ZERO_CSUM6_RX,
428 	IFLA_VXLAN_REMCSUM_TX,
429 	IFLA_VXLAN_REMCSUM_RX,
430 	IFLA_VXLAN_GBP,
431 	IFLA_VXLAN_REMCSUM_NOPARTIAL,
432 	IFLA_VXLAN_COLLECT_METADATA,
433 	__IFLA_VXLAN_MAX
434 };
435 #define IFLA_VXLAN_MAX	(__IFLA_VXLAN_MAX - 1)
436 
437 struct ifla_vxlan_port_range {
438 	__be16	low;
439 	__be16	high;
440 };
441 
442 /* GENEVE section */
443 enum {
444 	IFLA_GENEVE_UNSPEC,
445 	IFLA_GENEVE_ID,
446 	IFLA_GENEVE_REMOTE,
447 	IFLA_GENEVE_TTL,
448 	IFLA_GENEVE_TOS,
449 	IFLA_GENEVE_PORT,	/* destination port */
450 	IFLA_GENEVE_COLLECT_METADATA,
451 	__IFLA_GENEVE_MAX
452 };
453 #define IFLA_GENEVE_MAX	(__IFLA_GENEVE_MAX - 1)
454 
455 /* Bonding section */
456 
457 enum {
458 	IFLA_BOND_UNSPEC,
459 	IFLA_BOND_MODE,
460 	IFLA_BOND_ACTIVE_SLAVE,
461 	IFLA_BOND_MIIMON,
462 	IFLA_BOND_UPDELAY,
463 	IFLA_BOND_DOWNDELAY,
464 	IFLA_BOND_USE_CARRIER,
465 	IFLA_BOND_ARP_INTERVAL,
466 	IFLA_BOND_ARP_IP_TARGET,
467 	IFLA_BOND_ARP_VALIDATE,
468 	IFLA_BOND_ARP_ALL_TARGETS,
469 	IFLA_BOND_PRIMARY,
470 	IFLA_BOND_PRIMARY_RESELECT,
471 	IFLA_BOND_FAIL_OVER_MAC,
472 	IFLA_BOND_XMIT_HASH_POLICY,
473 	IFLA_BOND_RESEND_IGMP,
474 	IFLA_BOND_NUM_PEER_NOTIF,
475 	IFLA_BOND_ALL_SLAVES_ACTIVE,
476 	IFLA_BOND_MIN_LINKS,
477 	IFLA_BOND_LP_INTERVAL,
478 	IFLA_BOND_PACKETS_PER_SLAVE,
479 	IFLA_BOND_AD_LACP_RATE,
480 	IFLA_BOND_AD_SELECT,
481 	IFLA_BOND_AD_INFO,
482 	IFLA_BOND_AD_ACTOR_SYS_PRIO,
483 	IFLA_BOND_AD_USER_PORT_KEY,
484 	IFLA_BOND_AD_ACTOR_SYSTEM,
485 	IFLA_BOND_TLB_DYNAMIC_LB,
486 	__IFLA_BOND_MAX,
487 };
488 
489 #define IFLA_BOND_MAX	(__IFLA_BOND_MAX - 1)
490 
491 enum {
492 	IFLA_BOND_AD_INFO_UNSPEC,
493 	IFLA_BOND_AD_INFO_AGGREGATOR,
494 	IFLA_BOND_AD_INFO_NUM_PORTS,
495 	IFLA_BOND_AD_INFO_ACTOR_KEY,
496 	IFLA_BOND_AD_INFO_PARTNER_KEY,
497 	IFLA_BOND_AD_INFO_PARTNER_MAC,
498 	__IFLA_BOND_AD_INFO_MAX,
499 };
500 
501 #define IFLA_BOND_AD_INFO_MAX	(__IFLA_BOND_AD_INFO_MAX - 1)
502 
503 enum {
504 	IFLA_BOND_SLAVE_UNSPEC,
505 	IFLA_BOND_SLAVE_STATE,
506 	IFLA_BOND_SLAVE_MII_STATUS,
507 	IFLA_BOND_SLAVE_LINK_FAILURE_COUNT,
508 	IFLA_BOND_SLAVE_PERM_HWADDR,
509 	IFLA_BOND_SLAVE_QUEUE_ID,
510 	IFLA_BOND_SLAVE_AD_AGGREGATOR_ID,
511 	IFLA_BOND_SLAVE_AD_ACTOR_OPER_PORT_STATE,
512 	IFLA_BOND_SLAVE_AD_PARTNER_OPER_PORT_STATE,
513 	__IFLA_BOND_SLAVE_MAX,
514 };
515 
516 #define IFLA_BOND_SLAVE_MAX	(__IFLA_BOND_SLAVE_MAX - 1)
517 
518 /* SR-IOV virtual function management section */
519 
520 enum {
521 	IFLA_VF_INFO_UNSPEC,
522 	IFLA_VF_INFO,
523 	__IFLA_VF_INFO_MAX,
524 };
525 
526 #define IFLA_VF_INFO_MAX (__IFLA_VF_INFO_MAX - 1)
527 
528 enum {
529 	IFLA_VF_UNSPEC,
530 	IFLA_VF_MAC,		/* Hardware queue specific attributes */
531 	IFLA_VF_VLAN,
532 	IFLA_VF_TX_RATE,	/* Max TX Bandwidth Allocation */
533 	IFLA_VF_SPOOFCHK,	/* Spoof Checking on/off switch */
534 	IFLA_VF_LINK_STATE,	/* link state enable/disable/auto switch */
535 	IFLA_VF_RATE,		/* Min and Max TX Bandwidth Allocation */
536 	IFLA_VF_RSS_QUERY_EN,	/* RSS Redirection Table and Hash Key query
537 				 * on/off switch
538 				 */
539 	IFLA_VF_STATS,		/* network device statistics */
540 	__IFLA_VF_MAX,
541 };
542 
543 #define IFLA_VF_MAX (__IFLA_VF_MAX - 1)
544 
545 struct ifla_vf_mac {
546 	__u32 vf;
547 	__u8 mac[32]; /* MAX_ADDR_LEN */
548 };
549 
550 struct ifla_vf_vlan {
551 	__u32 vf;
552 	__u32 vlan; /* 0 - 4095, 0 disables VLAN filter */
553 	__u32 qos;
554 };
555 
556 struct ifla_vf_tx_rate {
557 	__u32 vf;
558 	__u32 rate; /* Max TX bandwidth in Mbps, 0 disables throttling */
559 };
560 
561 struct ifla_vf_rate {
562 	__u32 vf;
563 	__u32 min_tx_rate; /* Min Bandwidth in Mbps */
564 	__u32 max_tx_rate; /* Max Bandwidth in Mbps */
565 };
566 
567 struct ifla_vf_spoofchk {
568 	__u32 vf;
569 	__u32 setting;
570 };
571 
572 enum {
573 	IFLA_VF_LINK_STATE_AUTO,	/* link state of the uplink */
574 	IFLA_VF_LINK_STATE_ENABLE,	/* link always up */
575 	IFLA_VF_LINK_STATE_DISABLE,	/* link always down */
576 	__IFLA_VF_LINK_STATE_MAX,
577 };
578 
579 struct ifla_vf_link_state {
580 	__u32 vf;
581 	__u32 link_state;
582 };
583 
584 struct ifla_vf_rss_query_en {
585 	__u32 vf;
586 	__u32 setting;
587 };
588 
589 enum {
590 	IFLA_VF_STATS_RX_PACKETS,
591 	IFLA_VF_STATS_TX_PACKETS,
592 	IFLA_VF_STATS_RX_BYTES,
593 	IFLA_VF_STATS_TX_BYTES,
594 	IFLA_VF_STATS_BROADCAST,
595 	IFLA_VF_STATS_MULTICAST,
596 	__IFLA_VF_STATS_MAX,
597 };
598 
599 #define IFLA_VF_STATS_MAX (__IFLA_VF_STATS_MAX - 1)
600 
601 /* VF ports management section
602  *
603  *	Nested layout of set/get msg is:
604  *
605  *		[IFLA_NUM_VF]
606  *		[IFLA_VF_PORTS]
607  *			[IFLA_VF_PORT]
608  *				[IFLA_PORT_*], ...
609  *			[IFLA_VF_PORT]
610  *				[IFLA_PORT_*], ...
611  *			...
612  *		[IFLA_PORT_SELF]
613  *			[IFLA_PORT_*], ...
614  */
615 
616 enum {
617 	IFLA_VF_PORT_UNSPEC,
618 	IFLA_VF_PORT,			/* nest */
619 	__IFLA_VF_PORT_MAX,
620 };
621 
622 #define IFLA_VF_PORT_MAX (__IFLA_VF_PORT_MAX - 1)
623 
624 enum {
625 	IFLA_PORT_UNSPEC,
626 	IFLA_PORT_VF,			/* __u32 */
627 	IFLA_PORT_PROFILE,		/* string */
628 	IFLA_PORT_VSI_TYPE,		/* 802.1Qbg (pre-)standard VDP */
629 	IFLA_PORT_INSTANCE_UUID,	/* binary UUID */
630 	IFLA_PORT_HOST_UUID,		/* binary UUID */
631 	IFLA_PORT_REQUEST,		/* __u8 */
632 	IFLA_PORT_RESPONSE,		/* __u16, output only */
633 	__IFLA_PORT_MAX,
634 };
635 
636 #define IFLA_PORT_MAX (__IFLA_PORT_MAX - 1)
637 
638 #define PORT_PROFILE_MAX	40
639 #define PORT_UUID_MAX		16
640 #define PORT_SELF_VF		-1
641 
642 enum {
643 	PORT_REQUEST_PREASSOCIATE = 0,
644 	PORT_REQUEST_PREASSOCIATE_RR,
645 	PORT_REQUEST_ASSOCIATE,
646 	PORT_REQUEST_DISASSOCIATE,
647 };
648 
649 enum {
650 	PORT_VDP_RESPONSE_SUCCESS = 0,
651 	PORT_VDP_RESPONSE_INVALID_FORMAT,
652 	PORT_VDP_RESPONSE_INSUFFICIENT_RESOURCES,
653 	PORT_VDP_RESPONSE_UNUSED_VTID,
654 	PORT_VDP_RESPONSE_VTID_VIOLATION,
655 	PORT_VDP_RESPONSE_VTID_VERSION_VIOALTION,
656 	PORT_VDP_RESPONSE_OUT_OF_SYNC,
657 	/* 0x08-0xFF reserved for future VDP use */
658 	PORT_PROFILE_RESPONSE_SUCCESS = 0x100,
659 	PORT_PROFILE_RESPONSE_INPROGRESS,
660 	PORT_PROFILE_RESPONSE_INVALID,
661 	PORT_PROFILE_RESPONSE_BADSTATE,
662 	PORT_PROFILE_RESPONSE_INSUFFICIENT_RESOURCES,
663 	PORT_PROFILE_RESPONSE_ERROR,
664 };
665 
666 struct ifla_port_vsi {
667 	__u8 vsi_mgr_id;
668 	__u8 vsi_type_id[3];
669 	__u8 vsi_type_version;
670 	__u8 pad[3];
671 };
672 
673 
674 /* IPoIB section */
675 
676 enum {
677 	IFLA_IPOIB_UNSPEC,
678 	IFLA_IPOIB_PKEY,
679 	IFLA_IPOIB_MODE,
680 	IFLA_IPOIB_UMCAST,
681 	__IFLA_IPOIB_MAX
682 };
683 
684 enum {
685 	IPOIB_MODE_DATAGRAM  = 0, /* using unreliable datagram QPs */
686 	IPOIB_MODE_CONNECTED = 1, /* using connected QPs */
687 };
688 
689 #define IFLA_IPOIB_MAX (__IFLA_IPOIB_MAX - 1)
690 
691 
692 /* HSR section */
693 
694 enum {
695 	IFLA_HSR_UNSPEC,
696 	IFLA_HSR_SLAVE1,
697 	IFLA_HSR_SLAVE2,
698 	IFLA_HSR_MULTICAST_SPEC,	/* Last byte of supervision addr */
699 	IFLA_HSR_SUPERVISION_ADDR,	/* Supervision frame multicast addr */
700 	IFLA_HSR_SEQ_NR,
701 	__IFLA_HSR_MAX,
702 };
703 
704 #define IFLA_HSR_MAX (__IFLA_HSR_MAX - 1)
705 
706 #endif /* _UAPI_LINUX_IF_LINK_H */
707