]>
Commit | Line | Data |
---|---|---|
ba777396 RW |
1 | #ifndef _LINUX_IF_LINK_H |
2 | #define _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 | __u32 rx_nohandler; /* dropped, no handler found */ | |
40 | }; | |
41 | ||
42 | /* The main device statistics structure */ | |
43 | struct rtnl_link_stats64 { | |
44 | __u64 rx_packets; /* total packets received */ | |
45 | __u64 tx_packets; /* total packets transmitted */ | |
46 | __u64 rx_bytes; /* total bytes received */ | |
47 | __u64 tx_bytes; /* total bytes transmitted */ | |
48 | __u64 rx_errors; /* bad packets received */ | |
49 | __u64 tx_errors; /* packet transmit problems */ | |
50 | __u64 rx_dropped; /* no space in linux buffers */ | |
51 | __u64 tx_dropped; /* no space available in linux */ | |
52 | __u64 multicast; /* multicast packets received */ | |
53 | __u64 collisions; | |
54 | ||
55 | /* detailed rx_errors: */ | |
56 | __u64 rx_length_errors; | |
57 | __u64 rx_over_errors; /* receiver ring buff overflow */ | |
58 | __u64 rx_crc_errors; /* recved pkt with crc error */ | |
59 | __u64 rx_frame_errors; /* recv'd frame alignment error */ | |
60 | __u64 rx_fifo_errors; /* recv'r fifo overrun */ | |
61 | __u64 rx_missed_errors; /* receiver missed packet */ | |
62 | ||
63 | /* detailed tx_errors */ | |
64 | __u64 tx_aborted_errors; | |
65 | __u64 tx_carrier_errors; | |
66 | __u64 tx_fifo_errors; | |
67 | __u64 tx_heartbeat_errors; | |
68 | __u64 tx_window_errors; | |
69 | ||
70 | /* for cslip etc */ | |
71 | __u64 rx_compressed; | |
72 | __u64 tx_compressed; | |
73 | ||
74 | __u64 rx_nohandler; /* dropped, no handler found */ | |
75 | }; | |
76 | ||
77 | /* The struct should be in sync with struct ifmap */ | |
78 | struct rtnl_link_ifmap { | |
79 | __u64 mem_start; | |
80 | __u64 mem_end; | |
81 | __u64 base_addr; | |
82 | __u16 irq; | |
83 | __u8 dma; | |
84 | __u8 port; | |
85 | }; | |
86 | ||
87 | /* | |
88 | * IFLA_AF_SPEC | |
89 | * Contains nested attributes for address family specific attributes. | |
90 | * Each address family may create a attribute with the address family | |
91 | * number as type and create its own attribute structure in it. | |
92 | * | |
93 | * Example: | |
94 | * [IFLA_AF_SPEC] = { | |
95 | * [AF_INET] = { | |
96 | * [IFLA_INET_CONF] = ..., | |
97 | * }, | |
98 | * [AF_INET6] = { | |
99 | * [IFLA_INET6_FLAGS] = ..., | |
100 | * [IFLA_INET6_CONF] = ..., | |
101 | * } | |
102 | * } | |
103 | */ | |
104 | ||
105 | enum { | |
106 | IFLA_UNSPEC, | |
107 | IFLA_ADDRESS, | |
108 | IFLA_BROADCAST, | |
109 | IFLA_IFNAME, | |
110 | IFLA_MTU, | |
111 | IFLA_LINK, | |
112 | IFLA_QDISC, | |
113 | IFLA_STATS, | |
114 | IFLA_COST, | |
115 | #define IFLA_COST IFLA_COST | |
116 | IFLA_PRIORITY, | |
117 | #define IFLA_PRIORITY IFLA_PRIORITY | |
118 | IFLA_MASTER, | |
119 | #define IFLA_MASTER IFLA_MASTER | |
120 | IFLA_WIRELESS, /* Wireless Extension event - see wireless.h */ | |
121 | #define IFLA_WIRELESS IFLA_WIRELESS | |
122 | IFLA_PROTINFO, /* Protocol specific information for a link */ | |
123 | #define IFLA_PROTINFO IFLA_PROTINFO | |
124 | IFLA_TXQLEN, | |
125 | #define IFLA_TXQLEN IFLA_TXQLEN | |
126 | IFLA_MAP, | |
127 | #define IFLA_MAP IFLA_MAP | |
128 | IFLA_WEIGHT, | |
129 | #define IFLA_WEIGHT IFLA_WEIGHT | |
130 | IFLA_OPERSTATE, | |
131 | IFLA_LINKMODE, | |
132 | IFLA_LINKINFO, | |
133 | #define IFLA_LINKINFO IFLA_LINKINFO | |
134 | IFLA_NET_NS_PID, | |
135 | IFLA_IFALIAS, | |
136 | IFLA_NUM_VF, /* Number of VFs if device is SR-IOV PF */ | |
137 | IFLA_VFINFO_LIST, | |
138 | IFLA_STATS64, | |
139 | IFLA_VF_PORTS, | |
140 | IFLA_PORT_SELF, | |
141 | IFLA_AF_SPEC, | |
142 | IFLA_GROUP, /* Group the device belongs to */ | |
143 | IFLA_NET_NS_FD, | |
144 | IFLA_EXT_MASK, /* Extended info mask, VFs, etc */ | |
145 | IFLA_PROMISCUITY, /* Promiscuity count: > 0 means acts PROMISC */ | |
146 | #define IFLA_PROMISCUITY IFLA_PROMISCUITY | |
147 | IFLA_NUM_TX_QUEUES, | |
148 | IFLA_NUM_RX_QUEUES, | |
149 | IFLA_CARRIER, | |
150 | IFLA_PHYS_PORT_ID, | |
151 | IFLA_CARRIER_CHANGES, | |
152 | IFLA_PHYS_SWITCH_ID, | |
153 | IFLA_LINK_NETNSID, | |
154 | IFLA_PHYS_PORT_NAME, | |
155 | IFLA_PROTO_DOWN, | |
156 | IFLA_GSO_MAX_SEGS, | |
157 | IFLA_GSO_MAX_SIZE, | |
158 | IFLA_PAD, | |
159 | IFLA_XDP, | |
160 | IFLA_EVENT, | |
161 | __IFLA_MAX | |
162 | }; | |
163 | ||
164 | ||
165 | #define IFLA_MAX (__IFLA_MAX - 1) | |
166 | ||
167 | /* backwards compatibility for userspace */ | |
168 | #define IFLA_RTA(r) ((struct rtattr*)(((char*)(r)) + NLMSG_ALIGN(sizeof(struct ifinfomsg)))) | |
169 | #define IFLA_PAYLOAD(n) NLMSG_PAYLOAD(n,sizeof(struct ifinfomsg)) | |
170 | ||
171 | enum { | |
172 | IFLA_INET_UNSPEC, | |
173 | IFLA_INET_CONF, | |
174 | __IFLA_INET_MAX, | |
175 | }; | |
176 | ||
177 | #define IFLA_INET_MAX (__IFLA_INET_MAX - 1) | |
178 | ||
179 | /* ifi_flags. | |
180 | ||
181 | IFF_* flags. | |
182 | ||
183 | The only change is: | |
184 | IFF_LOOPBACK, IFF_BROADCAST and IFF_POINTOPOINT are | |
185 | more not changeable by user. They describe link media | |
186 | characteristics and set by device driver. | |
187 | ||
188 | Comments: | |
189 | - Combination IFF_BROADCAST|IFF_POINTOPOINT is invalid | |
190 | - If neither of these three flags are set; | |
191 | the interface is NBMA. | |
192 | ||
193 | - IFF_MULTICAST does not mean anything special: | |
194 | multicasts can be used on all not-NBMA links. | |
195 | IFF_MULTICAST means that this media uses special encapsulation | |
196 | for multicast frames. Apparently, all IFF_POINTOPOINT and | |
197 | IFF_BROADCAST devices are able to use multicasts too. | |
198 | */ | |
199 | ||
200 | /* IFLA_LINK. | |
201 | For usual devices it is equal ifi_index. | |
202 | If it is a "virtual interface" (f.e. tunnel), ifi_link | |
203 | can point to real physical interface (f.e. for bandwidth calculations), | |
204 | or maybe 0, what means, that real media is unknown (usual | |
205 | for IPIP tunnels, when route to endpoint is allowed to change) | |
206 | */ | |
207 | ||
208 | /* Subtype attributes for IFLA_PROTINFO */ | |
209 | enum { | |
210 | IFLA_INET6_UNSPEC, | |
211 | IFLA_INET6_FLAGS, /* link flags */ | |
212 | IFLA_INET6_CONF, /* sysctl parameters */ | |
213 | IFLA_INET6_STATS, /* statistics */ | |
214 | IFLA_INET6_MCAST, /* MC things. What of them? */ | |
215 | IFLA_INET6_CACHEINFO, /* time values and max reasm size */ | |
216 | IFLA_INET6_ICMP6STATS, /* statistics (icmpv6) */ | |
217 | IFLA_INET6_TOKEN, /* device token */ | |
218 | IFLA_INET6_ADDR_GEN_MODE, /* implicit address generator mode */ | |
219 | __IFLA_INET6_MAX | |
220 | }; | |
221 | ||
222 | #define IFLA_INET6_MAX (__IFLA_INET6_MAX - 1) | |
223 | ||
224 | enum in6_addr_gen_mode { | |
225 | IN6_ADDR_GEN_MODE_EUI64, | |
226 | IN6_ADDR_GEN_MODE_NONE, | |
227 | IN6_ADDR_GEN_MODE_STABLE_PRIVACY, | |
228 | IN6_ADDR_GEN_MODE_RANDOM, | |
229 | }; | |
230 | ||
231 | /* Bridge section */ | |
232 | ||
233 | enum { | |
234 | IFLA_BR_UNSPEC, | |
235 | IFLA_BR_FORWARD_DELAY, | |
236 | IFLA_BR_HELLO_TIME, | |
237 | IFLA_BR_MAX_AGE, | |
238 | IFLA_BR_AGEING_TIME, | |
239 | IFLA_BR_STP_STATE, | |
240 | IFLA_BR_PRIORITY, | |
241 | IFLA_BR_VLAN_FILTERING, | |
242 | IFLA_BR_VLAN_PROTOCOL, | |
243 | IFLA_BR_GROUP_FWD_MASK, | |
244 | IFLA_BR_ROOT_ID, | |
245 | IFLA_BR_BRIDGE_ID, | |
246 | IFLA_BR_ROOT_PORT, | |
247 | IFLA_BR_ROOT_PATH_COST, | |
248 | IFLA_BR_TOPOLOGY_CHANGE, | |
249 | IFLA_BR_TOPOLOGY_CHANGE_DETECTED, | |
250 | IFLA_BR_HELLO_TIMER, | |
251 | IFLA_BR_TCN_TIMER, | |
252 | IFLA_BR_TOPOLOGY_CHANGE_TIMER, | |
253 | IFLA_BR_GC_TIMER, | |
254 | IFLA_BR_GROUP_ADDR, | |
255 | IFLA_BR_FDB_FLUSH, | |
256 | IFLA_BR_MCAST_ROUTER, | |
257 | IFLA_BR_MCAST_SNOOPING, | |
258 | IFLA_BR_MCAST_QUERY_USE_IFADDR, | |
259 | IFLA_BR_MCAST_QUERIER, | |
260 | IFLA_BR_MCAST_HASH_ELASTICITY, | |
261 | IFLA_BR_MCAST_HASH_MAX, | |
262 | IFLA_BR_MCAST_LAST_MEMBER_CNT, | |
263 | IFLA_BR_MCAST_STARTUP_QUERY_CNT, | |
264 | IFLA_BR_MCAST_LAST_MEMBER_INTVL, | |
265 | IFLA_BR_MCAST_MEMBERSHIP_INTVL, | |
266 | IFLA_BR_MCAST_QUERIER_INTVL, | |
267 | IFLA_BR_MCAST_QUERY_INTVL, | |
268 | IFLA_BR_MCAST_QUERY_RESPONSE_INTVL, | |
269 | IFLA_BR_MCAST_STARTUP_QUERY_INTVL, | |
270 | IFLA_BR_NF_CALL_IPTABLES, | |
271 | IFLA_BR_NF_CALL_IP6TABLES, | |
272 | IFLA_BR_NF_CALL_ARPTABLES, | |
273 | IFLA_BR_VLAN_DEFAULT_PVID, | |
274 | IFLA_BR_PAD, | |
275 | IFLA_BR_VLAN_STATS_ENABLED, | |
276 | IFLA_BR_MCAST_STATS_ENABLED, | |
277 | IFLA_BR_MCAST_IGMP_VERSION, | |
278 | IFLA_BR_MCAST_MLD_VERSION, | |
279 | __IFLA_BR_MAX, | |
280 | }; | |
281 | ||
282 | #define IFLA_BR_MAX (__IFLA_BR_MAX - 1) | |
283 | ||
284 | struct ifla_bridge_id { | |
285 | __u8 prio[2]; | |
286 | __u8 addr[6]; /* ETH_ALEN */ | |
287 | }; | |
288 | ||
289 | enum { | |
290 | BRIDGE_MODE_UNSPEC, | |
291 | BRIDGE_MODE_HAIRPIN, | |
292 | }; | |
293 | ||
294 | enum { | |
295 | IFLA_BRPORT_UNSPEC, | |
296 | IFLA_BRPORT_STATE, /* Spanning tree state */ | |
297 | IFLA_BRPORT_PRIORITY, /* " priority */ | |
298 | IFLA_BRPORT_COST, /* " cost */ | |
299 | IFLA_BRPORT_MODE, /* mode (hairpin) */ | |
300 | IFLA_BRPORT_GUARD, /* bpdu guard */ | |
301 | IFLA_BRPORT_PROTECT, /* root port protection */ | |
302 | IFLA_BRPORT_FAST_LEAVE, /* multicast fast leave */ | |
303 | IFLA_BRPORT_LEARNING, /* mac learning */ | |
304 | IFLA_BRPORT_UNICAST_FLOOD, /* flood unicast traffic */ | |
305 | IFLA_BRPORT_PROXYARP, /* proxy ARP */ | |
306 | IFLA_BRPORT_LEARNING_SYNC, /* mac learning sync from device */ | |
307 | IFLA_BRPORT_PROXYARP_WIFI, /* proxy ARP for Wi-Fi */ | |
308 | IFLA_BRPORT_ROOT_ID, /* designated root */ | |
309 | IFLA_BRPORT_BRIDGE_ID, /* designated bridge */ | |
310 | IFLA_BRPORT_DESIGNATED_PORT, | |
311 | IFLA_BRPORT_DESIGNATED_COST, | |
312 | IFLA_BRPORT_ID, | |
313 | IFLA_BRPORT_NO, | |
314 | IFLA_BRPORT_TOPOLOGY_CHANGE_ACK, | |
315 | IFLA_BRPORT_CONFIG_PENDING, | |
316 | IFLA_BRPORT_MESSAGE_AGE_TIMER, | |
317 | IFLA_BRPORT_FORWARD_DELAY_TIMER, | |
318 | IFLA_BRPORT_HOLD_TIMER, | |
319 | IFLA_BRPORT_FLUSH, | |
320 | IFLA_BRPORT_MULTICAST_ROUTER, | |
321 | IFLA_BRPORT_PAD, | |
322 | IFLA_BRPORT_MCAST_FLOOD, | |
323 | IFLA_BRPORT_MCAST_TO_UCAST, | |
324 | IFLA_BRPORT_VLAN_TUNNEL, | |
325 | IFLA_BRPORT_BCAST_FLOOD, | |
326 | __IFLA_BRPORT_MAX | |
327 | }; | |
328 | #define IFLA_BRPORT_MAX (__IFLA_BRPORT_MAX - 1) | |
329 | ||
330 | struct ifla_cacheinfo { | |
331 | __u32 max_reasm_len; | |
332 | __u32 tstamp; /* ipv6InterfaceTable updated timestamp */ | |
333 | __u32 reachable_time; | |
334 | __u32 retrans_time; | |
335 | }; | |
336 | ||
337 | enum { | |
338 | IFLA_INFO_UNSPEC, | |
339 | IFLA_INFO_KIND, | |
340 | IFLA_INFO_DATA, | |
341 | IFLA_INFO_XSTATS, | |
342 | IFLA_INFO_SLAVE_KIND, | |
343 | IFLA_INFO_SLAVE_DATA, | |
344 | __IFLA_INFO_MAX, | |
345 | }; | |
346 | ||
347 | #define IFLA_INFO_MAX (__IFLA_INFO_MAX - 1) | |
348 | ||
349 | /* VLAN section */ | |
350 | ||
351 | enum { | |
352 | IFLA_VLAN_UNSPEC, | |
353 | IFLA_VLAN_ID, | |
354 | IFLA_VLAN_FLAGS, | |
355 | IFLA_VLAN_EGRESS_QOS, | |
356 | IFLA_VLAN_INGRESS_QOS, | |
357 | IFLA_VLAN_PROTOCOL, | |
358 | __IFLA_VLAN_MAX, | |
359 | }; | |
360 | ||
361 | #define IFLA_VLAN_MAX (__IFLA_VLAN_MAX - 1) | |
362 | ||
363 | struct ifla_vlan_flags { | |
364 | __u32 flags; | |
365 | __u32 mask; | |
366 | }; | |
367 | ||
368 | enum { | |
369 | IFLA_VLAN_QOS_UNSPEC, | |
370 | IFLA_VLAN_QOS_MAPPING, | |
371 | __IFLA_VLAN_QOS_MAX | |
372 | }; | |
373 | ||
374 | #define IFLA_VLAN_QOS_MAX (__IFLA_VLAN_QOS_MAX - 1) | |
375 | ||
376 | struct ifla_vlan_qos_mapping { | |
377 | __u32 from; | |
378 | __u32 to; | |
379 | }; | |
380 | ||
381 | /* MACVLAN section */ | |
382 | enum { | |
383 | IFLA_MACVLAN_UNSPEC, | |
384 | IFLA_MACVLAN_MODE, | |
385 | IFLA_MACVLAN_FLAGS, | |
386 | IFLA_MACVLAN_MACADDR_MODE, | |
387 | IFLA_MACVLAN_MACADDR, | |
388 | IFLA_MACVLAN_MACADDR_DATA, | |
389 | IFLA_MACVLAN_MACADDR_COUNT, | |
390 | __IFLA_MACVLAN_MAX, | |
391 | }; | |
392 | ||
393 | #define IFLA_MACVLAN_MAX (__IFLA_MACVLAN_MAX - 1) | |
394 | ||
395 | enum macvlan_mode { | |
396 | MACVLAN_MODE_PRIVATE = 1, /* don't talk to other macvlans */ | |
397 | MACVLAN_MODE_VEPA = 2, /* talk to other ports through ext bridge */ | |
398 | MACVLAN_MODE_BRIDGE = 4, /* talk to bridge ports directly */ | |
399 | MACVLAN_MODE_PASSTHRU = 8,/* take over the underlying device */ | |
400 | MACVLAN_MODE_SOURCE = 16,/* use source MAC address list to assign */ | |
401 | }; | |
402 | ||
403 | enum macvlan_macaddr_mode { | |
404 | MACVLAN_MACADDR_ADD, | |
405 | MACVLAN_MACADDR_DEL, | |
406 | MACVLAN_MACADDR_FLUSH, | |
407 | MACVLAN_MACADDR_SET, | |
408 | }; | |
409 | ||
410 | #define MACVLAN_FLAG_NOPROMISC 1 | |
411 | ||
412 | /* VRF section */ | |
413 | enum { | |
414 | IFLA_VRF_UNSPEC, | |
415 | IFLA_VRF_TABLE, | |
416 | __IFLA_VRF_MAX | |
417 | }; | |
418 | ||
419 | #define IFLA_VRF_MAX (__IFLA_VRF_MAX - 1) | |
420 | ||
421 | enum { | |
422 | IFLA_VRF_PORT_UNSPEC, | |
423 | IFLA_VRF_PORT_TABLE, | |
424 | __IFLA_VRF_PORT_MAX | |
425 | }; | |
426 | ||
427 | #define IFLA_VRF_PORT_MAX (__IFLA_VRF_PORT_MAX - 1) | |
428 | ||
429 | /* MACSEC section */ | |
430 | enum { | |
431 | IFLA_MACSEC_UNSPEC, | |
432 | IFLA_MACSEC_SCI, | |
433 | IFLA_MACSEC_PORT, | |
434 | IFLA_MACSEC_ICV_LEN, | |
435 | IFLA_MACSEC_CIPHER_SUITE, | |
436 | IFLA_MACSEC_WINDOW, | |
437 | IFLA_MACSEC_ENCODING_SA, | |
438 | IFLA_MACSEC_ENCRYPT, | |
439 | IFLA_MACSEC_PROTECT, | |
440 | IFLA_MACSEC_INC_SCI, | |
441 | IFLA_MACSEC_ES, | |
442 | IFLA_MACSEC_SCB, | |
443 | IFLA_MACSEC_REPLAY_PROTECT, | |
444 | IFLA_MACSEC_VALIDATION, | |
445 | IFLA_MACSEC_PAD, | |
446 | __IFLA_MACSEC_MAX, | |
447 | }; | |
448 | ||
449 | #define IFLA_MACSEC_MAX (__IFLA_MACSEC_MAX - 1) | |
450 | ||
451 | enum macsec_validation_type { | |
452 | MACSEC_VALIDATE_DISABLED = 0, | |
453 | MACSEC_VALIDATE_CHECK = 1, | |
454 | MACSEC_VALIDATE_STRICT = 2, | |
455 | __MACSEC_VALIDATE_END, | |
456 | MACSEC_VALIDATE_MAX = __MACSEC_VALIDATE_END - 1, | |
457 | }; | |
458 | ||
459 | /* IPVLAN section */ | |
460 | enum { | |
461 | IFLA_IPVLAN_UNSPEC, | |
462 | IFLA_IPVLAN_MODE, | |
463 | __IFLA_IPVLAN_MAX | |
464 | }; | |
465 | ||
466 | #define IFLA_IPVLAN_MAX (__IFLA_IPVLAN_MAX - 1) | |
467 | ||
468 | enum ipvlan_mode { | |
469 | IPVLAN_MODE_L2 = 0, | |
470 | IPVLAN_MODE_L3, | |
471 | IPVLAN_MODE_L3S, | |
472 | IPVLAN_MODE_MAX | |
473 | }; | |
474 | ||
475 | /* VXLAN section */ | |
476 | enum { | |
477 | IFLA_VXLAN_UNSPEC, | |
478 | IFLA_VXLAN_ID, | |
479 | IFLA_VXLAN_GROUP, /* group or remote address */ | |
480 | IFLA_VXLAN_LINK, | |
481 | IFLA_VXLAN_LOCAL, | |
482 | IFLA_VXLAN_TTL, | |
483 | IFLA_VXLAN_TOS, | |
484 | IFLA_VXLAN_LEARNING, | |
485 | IFLA_VXLAN_AGEING, | |
486 | IFLA_VXLAN_LIMIT, | |
487 | IFLA_VXLAN_PORT_RANGE, /* source port */ | |
488 | IFLA_VXLAN_PROXY, | |
489 | IFLA_VXLAN_RSC, | |
490 | IFLA_VXLAN_L2MISS, | |
491 | IFLA_VXLAN_L3MISS, | |
492 | IFLA_VXLAN_PORT, /* destination port */ | |
493 | IFLA_VXLAN_GROUP6, | |
494 | IFLA_VXLAN_LOCAL6, | |
495 | IFLA_VXLAN_UDP_CSUM, | |
496 | IFLA_VXLAN_UDP_ZERO_CSUM6_TX, | |
497 | IFLA_VXLAN_UDP_ZERO_CSUM6_RX, | |
498 | IFLA_VXLAN_REMCSUM_TX, | |
499 | IFLA_VXLAN_REMCSUM_RX, | |
500 | IFLA_VXLAN_GBP, | |
501 | IFLA_VXLAN_REMCSUM_NOPARTIAL, | |
502 | IFLA_VXLAN_COLLECT_METADATA, | |
503 | IFLA_VXLAN_LABEL, | |
504 | IFLA_VXLAN_GPE, | |
505 | __IFLA_VXLAN_MAX | |
506 | }; | |
507 | #define IFLA_VXLAN_MAX (__IFLA_VXLAN_MAX - 1) | |
508 | ||
509 | struct ifla_vxlan_port_range { | |
510 | __be16 low; | |
511 | __be16 high; | |
512 | }; | |
513 | ||
514 | /* GENEVE section */ | |
515 | enum { | |
516 | IFLA_GENEVE_UNSPEC, | |
517 | IFLA_GENEVE_ID, | |
518 | IFLA_GENEVE_REMOTE, | |
519 | IFLA_GENEVE_TTL, | |
520 | IFLA_GENEVE_TOS, | |
521 | IFLA_GENEVE_PORT, /* destination port */ | |
522 | IFLA_GENEVE_COLLECT_METADATA, | |
523 | IFLA_GENEVE_REMOTE6, | |
524 | IFLA_GENEVE_UDP_CSUM, | |
525 | IFLA_GENEVE_UDP_ZERO_CSUM6_TX, | |
526 | IFLA_GENEVE_UDP_ZERO_CSUM6_RX, | |
527 | IFLA_GENEVE_LABEL, | |
528 | __IFLA_GENEVE_MAX | |
529 | }; | |
530 | #define IFLA_GENEVE_MAX (__IFLA_GENEVE_MAX - 1) | |
531 | ||
532 | /* PPP section */ | |
533 | enum { | |
534 | IFLA_PPP_UNSPEC, | |
535 | IFLA_PPP_DEV_FD, | |
536 | __IFLA_PPP_MAX | |
537 | }; | |
538 | #define IFLA_PPP_MAX (__IFLA_PPP_MAX - 1) | |
539 | ||
540 | /* GTP section */ | |
541 | ||
542 | enum ifla_gtp_role { | |
543 | GTP_ROLE_GGSN = 0, | |
544 | GTP_ROLE_SGSN, | |
545 | }; | |
546 | ||
547 | enum { | |
548 | IFLA_GTP_UNSPEC, | |
549 | IFLA_GTP_FD0, | |
550 | IFLA_GTP_FD1, | |
551 | IFLA_GTP_PDP_HASHSIZE, | |
552 | IFLA_GTP_ROLE, | |
553 | __IFLA_GTP_MAX, | |
554 | }; | |
555 | #define IFLA_GTP_MAX (__IFLA_GTP_MAX - 1) | |
556 | ||
557 | /* Bonding section */ | |
558 | ||
559 | enum { | |
560 | IFLA_BOND_UNSPEC, | |
561 | IFLA_BOND_MODE, | |
562 | IFLA_BOND_ACTIVE_SLAVE, | |
563 | IFLA_BOND_MIIMON, | |
564 | IFLA_BOND_UPDELAY, | |
565 | IFLA_BOND_DOWNDELAY, | |
566 | IFLA_BOND_USE_CARRIER, | |
567 | IFLA_BOND_ARP_INTERVAL, | |
568 | IFLA_BOND_ARP_IP_TARGET, | |
569 | IFLA_BOND_ARP_VALIDATE, | |
570 | IFLA_BOND_ARP_ALL_TARGETS, | |
571 | IFLA_BOND_PRIMARY, | |
572 | IFLA_BOND_PRIMARY_RESELECT, | |
573 | IFLA_BOND_FAIL_OVER_MAC, | |
574 | IFLA_BOND_XMIT_HASH_POLICY, | |
575 | IFLA_BOND_RESEND_IGMP, | |
576 | IFLA_BOND_NUM_PEER_NOTIF, | |
577 | IFLA_BOND_ALL_SLAVES_ACTIVE, | |
578 | IFLA_BOND_MIN_LINKS, | |
579 | IFLA_BOND_LP_INTERVAL, | |
580 | IFLA_BOND_PACKETS_PER_SLAVE, | |
581 | IFLA_BOND_AD_LACP_RATE, | |
582 | IFLA_BOND_AD_SELECT, | |
583 | IFLA_BOND_AD_INFO, | |
584 | IFLA_BOND_AD_ACTOR_SYS_PRIO, | |
585 | IFLA_BOND_AD_USER_PORT_KEY, | |
586 | IFLA_BOND_AD_ACTOR_SYSTEM, | |
587 | IFLA_BOND_TLB_DYNAMIC_LB, | |
588 | __IFLA_BOND_MAX, | |
589 | }; | |
590 | ||
591 | #define IFLA_BOND_MAX (__IFLA_BOND_MAX - 1) | |
592 | ||
593 | enum { | |
594 | IFLA_BOND_AD_INFO_UNSPEC, | |
595 | IFLA_BOND_AD_INFO_AGGREGATOR, | |
596 | IFLA_BOND_AD_INFO_NUM_PORTS, | |
597 | IFLA_BOND_AD_INFO_ACTOR_KEY, | |
598 | IFLA_BOND_AD_INFO_PARTNER_KEY, | |
599 | IFLA_BOND_AD_INFO_PARTNER_MAC, | |
600 | __IFLA_BOND_AD_INFO_MAX, | |
601 | }; | |
602 | ||
603 | #define IFLA_BOND_AD_INFO_MAX (__IFLA_BOND_AD_INFO_MAX - 1) | |
604 | ||
605 | enum { | |
606 | IFLA_BOND_SLAVE_UNSPEC, | |
607 | IFLA_BOND_SLAVE_STATE, | |
608 | IFLA_BOND_SLAVE_MII_STATUS, | |
609 | IFLA_BOND_SLAVE_LINK_FAILURE_COUNT, | |
610 | IFLA_BOND_SLAVE_PERM_HWADDR, | |
611 | IFLA_BOND_SLAVE_QUEUE_ID, | |
612 | IFLA_BOND_SLAVE_AD_AGGREGATOR_ID, | |
613 | IFLA_BOND_SLAVE_AD_ACTOR_OPER_PORT_STATE, | |
614 | IFLA_BOND_SLAVE_AD_PARTNER_OPER_PORT_STATE, | |
615 | __IFLA_BOND_SLAVE_MAX, | |
616 | }; | |
617 | ||
618 | #define IFLA_BOND_SLAVE_MAX (__IFLA_BOND_SLAVE_MAX - 1) | |
619 | ||
620 | /* SR-IOV virtual function management section */ | |
621 | ||
622 | enum { | |
623 | IFLA_VF_INFO_UNSPEC, | |
624 | IFLA_VF_INFO, | |
625 | __IFLA_VF_INFO_MAX, | |
626 | }; | |
627 | ||
628 | #define IFLA_VF_INFO_MAX (__IFLA_VF_INFO_MAX - 1) | |
629 | ||
630 | enum { | |
631 | IFLA_VF_UNSPEC, | |
632 | IFLA_VF_MAC, /* Hardware queue specific attributes */ | |
633 | IFLA_VF_VLAN, /* VLAN ID and QoS */ | |
634 | IFLA_VF_TX_RATE, /* Max TX Bandwidth Allocation */ | |
635 | IFLA_VF_SPOOFCHK, /* Spoof Checking on/off switch */ | |
636 | IFLA_VF_LINK_STATE, /* link state enable/disable/auto switch */ | |
637 | IFLA_VF_RATE, /* Min and Max TX Bandwidth Allocation */ | |
638 | IFLA_VF_RSS_QUERY_EN, /* RSS Redirection Table and Hash Key query | |
639 | * on/off switch | |
640 | */ | |
641 | IFLA_VF_STATS, /* network device statistics */ | |
642 | IFLA_VF_TRUST, /* Trust VF */ | |
643 | IFLA_VF_IB_NODE_GUID, /* VF Infiniband node GUID */ | |
644 | IFLA_VF_IB_PORT_GUID, /* VF Infiniband port GUID */ | |
645 | IFLA_VF_VLAN_LIST, /* nested list of vlans, option for QinQ */ | |
646 | __IFLA_VF_MAX, | |
647 | }; | |
648 | ||
649 | #define IFLA_VF_MAX (__IFLA_VF_MAX - 1) | |
650 | ||
651 | struct ifla_vf_mac { | |
652 | __u32 vf; | |
653 | __u8 mac[32]; /* MAX_ADDR_LEN */ | |
654 | }; | |
655 | ||
656 | struct ifla_vf_vlan { | |
657 | __u32 vf; | |
658 | __u32 vlan; /* 0 - 4095, 0 disables VLAN filter */ | |
659 | __u32 qos; | |
660 | }; | |
661 | ||
662 | enum { | |
663 | IFLA_VF_VLAN_INFO_UNSPEC, | |
664 | IFLA_VF_VLAN_INFO, /* VLAN ID, QoS and VLAN protocol */ | |
665 | __IFLA_VF_VLAN_INFO_MAX, | |
666 | }; | |
667 | ||
668 | #define IFLA_VF_VLAN_INFO_MAX (__IFLA_VF_VLAN_INFO_MAX - 1) | |
669 | #define MAX_VLAN_LIST_LEN 1 | |
670 | ||
671 | struct ifla_vf_vlan_info { | |
672 | __u32 vf; | |
673 | __u32 vlan; /* 0 - 4095, 0 disables VLAN filter */ | |
674 | __u32 qos; | |
675 | __be16 vlan_proto; /* VLAN protocol either 802.1Q or 802.1ad */ | |
676 | }; | |
677 | ||
678 | struct ifla_vf_tx_rate { | |
679 | __u32 vf; | |
680 | __u32 rate; /* Max TX bandwidth in Mbps, 0 disables throttling */ | |
681 | }; | |
682 | ||
683 | struct ifla_vf_rate { | |
684 | __u32 vf; | |
685 | __u32 min_tx_rate; /* Min Bandwidth in Mbps */ | |
686 | __u32 max_tx_rate; /* Max Bandwidth in Mbps */ | |
687 | }; | |
688 | ||
689 | struct ifla_vf_spoofchk { | |
690 | __u32 vf; | |
691 | __u32 setting; | |
692 | }; | |
693 | ||
694 | struct ifla_vf_guid { | |
695 | __u32 vf; | |
696 | __u64 guid; | |
697 | }; | |
698 | ||
699 | enum { | |
700 | IFLA_VF_LINK_STATE_AUTO, /* link state of the uplink */ | |
701 | IFLA_VF_LINK_STATE_ENABLE, /* link always up */ | |
702 | IFLA_VF_LINK_STATE_DISABLE, /* link always down */ | |
703 | __IFLA_VF_LINK_STATE_MAX, | |
704 | }; | |
705 | ||
706 | struct ifla_vf_link_state { | |
707 | __u32 vf; | |
708 | __u32 link_state; | |
709 | }; | |
710 | ||
711 | struct ifla_vf_rss_query_en { | |
712 | __u32 vf; | |
713 | __u32 setting; | |
714 | }; | |
715 | ||
716 | enum { | |
717 | IFLA_VF_STATS_RX_PACKETS, | |
718 | IFLA_VF_STATS_TX_PACKETS, | |
719 | IFLA_VF_STATS_RX_BYTES, | |
720 | IFLA_VF_STATS_TX_BYTES, | |
721 | IFLA_VF_STATS_BROADCAST, | |
722 | IFLA_VF_STATS_MULTICAST, | |
723 | IFLA_VF_STATS_PAD, | |
724 | __IFLA_VF_STATS_MAX, | |
725 | }; | |
726 | ||
727 | #define IFLA_VF_STATS_MAX (__IFLA_VF_STATS_MAX - 1) | |
728 | ||
729 | struct ifla_vf_trust { | |
730 | __u32 vf; | |
731 | __u32 setting; | |
732 | }; | |
733 | ||
734 | /* VF ports management section | |
735 | * | |
736 | * Nested layout of set/get msg is: | |
737 | * | |
738 | * [IFLA_NUM_VF] | |
739 | * [IFLA_VF_PORTS] | |
740 | * [IFLA_VF_PORT] | |
741 | * [IFLA_PORT_*], ... | |
742 | * [IFLA_VF_PORT] | |
743 | * [IFLA_PORT_*], ... | |
744 | * ... | |
745 | * [IFLA_PORT_SELF] | |
746 | * [IFLA_PORT_*], ... | |
747 | */ | |
748 | ||
749 | enum { | |
750 | IFLA_VF_PORT_UNSPEC, | |
751 | IFLA_VF_PORT, /* nest */ | |
752 | __IFLA_VF_PORT_MAX, | |
753 | }; | |
754 | ||
755 | #define IFLA_VF_PORT_MAX (__IFLA_VF_PORT_MAX - 1) | |
756 | ||
757 | enum { | |
758 | IFLA_PORT_UNSPEC, | |
759 | IFLA_PORT_VF, /* __u32 */ | |
760 | IFLA_PORT_PROFILE, /* string */ | |
761 | IFLA_PORT_VSI_TYPE, /* 802.1Qbg (pre-)standard VDP */ | |
762 | IFLA_PORT_INSTANCE_UUID, /* binary UUID */ | |
763 | IFLA_PORT_HOST_UUID, /* binary UUID */ | |
764 | IFLA_PORT_REQUEST, /* __u8 */ | |
765 | IFLA_PORT_RESPONSE, /* __u16, output only */ | |
766 | __IFLA_PORT_MAX, | |
767 | }; | |
768 | ||
769 | #define IFLA_PORT_MAX (__IFLA_PORT_MAX - 1) | |
770 | ||
771 | #define PORT_PROFILE_MAX 40 | |
772 | #define PORT_UUID_MAX 16 | |
773 | #define PORT_SELF_VF -1 | |
774 | ||
775 | enum { | |
776 | PORT_REQUEST_PREASSOCIATE = 0, | |
777 | PORT_REQUEST_PREASSOCIATE_RR, | |
778 | PORT_REQUEST_ASSOCIATE, | |
779 | PORT_REQUEST_DISASSOCIATE, | |
780 | }; | |
781 | ||
782 | enum { | |
783 | PORT_VDP_RESPONSE_SUCCESS = 0, | |
784 | PORT_VDP_RESPONSE_INVALID_FORMAT, | |
785 | PORT_VDP_RESPONSE_INSUFFICIENT_RESOURCES, | |
786 | PORT_VDP_RESPONSE_UNUSED_VTID, | |
787 | PORT_VDP_RESPONSE_VTID_VIOLATION, | |
788 | PORT_VDP_RESPONSE_VTID_VERSION_VIOALTION, | |
789 | PORT_VDP_RESPONSE_OUT_OF_SYNC, | |
790 | /* 0x08-0xFF reserved for future VDP use */ | |
791 | PORT_PROFILE_RESPONSE_SUCCESS = 0x100, | |
792 | PORT_PROFILE_RESPONSE_INPROGRESS, | |
793 | PORT_PROFILE_RESPONSE_INVALID, | |
794 | PORT_PROFILE_RESPONSE_BADSTATE, | |
795 | PORT_PROFILE_RESPONSE_INSUFFICIENT_RESOURCES, | |
796 | PORT_PROFILE_RESPONSE_ERROR, | |
797 | }; | |
798 | ||
799 | struct ifla_port_vsi { | |
800 | __u8 vsi_mgr_id; | |
801 | __u8 vsi_type_id[3]; | |
802 | __u8 vsi_type_version; | |
803 | __u8 pad[3]; | |
804 | }; | |
805 | ||
806 | ||
807 | /* IPoIB section */ | |
808 | ||
809 | enum { | |
810 | IFLA_IPOIB_UNSPEC, | |
811 | IFLA_IPOIB_PKEY, | |
812 | IFLA_IPOIB_MODE, | |
813 | IFLA_IPOIB_UMCAST, | |
814 | __IFLA_IPOIB_MAX | |
815 | }; | |
816 | ||
817 | enum { | |
818 | IPOIB_MODE_DATAGRAM = 0, /* using unreliable datagram QPs */ | |
819 | IPOIB_MODE_CONNECTED = 1, /* using connected QPs */ | |
820 | }; | |
821 | ||
822 | #define IFLA_IPOIB_MAX (__IFLA_IPOIB_MAX - 1) | |
823 | ||
824 | ||
825 | /* HSR section */ | |
826 | ||
827 | enum { | |
828 | IFLA_HSR_UNSPEC, | |
829 | IFLA_HSR_SLAVE1, | |
830 | IFLA_HSR_SLAVE2, | |
831 | IFLA_HSR_MULTICAST_SPEC, /* Last byte of supervision addr */ | |
832 | IFLA_HSR_SUPERVISION_ADDR, /* Supervision frame multicast addr */ | |
833 | IFLA_HSR_SEQ_NR, | |
834 | IFLA_HSR_VERSION, /* HSR version */ | |
835 | __IFLA_HSR_MAX, | |
836 | }; | |
837 | ||
838 | #define IFLA_HSR_MAX (__IFLA_HSR_MAX - 1) | |
839 | ||
840 | /* STATS section */ | |
841 | ||
842 | struct if_stats_msg { | |
843 | __u8 family; | |
844 | __u8 pad1; | |
845 | __u16 pad2; | |
846 | __u32 ifindex; | |
847 | __u32 filter_mask; | |
848 | }; | |
849 | ||
850 | /* A stats attribute can be netdev specific or a global stat. | |
851 | * For netdev stats, lets use the prefix IFLA_STATS_LINK_* | |
852 | */ | |
853 | enum { | |
854 | IFLA_STATS_UNSPEC, /* also used as 64bit pad attribute */ | |
855 | IFLA_STATS_LINK_64, | |
856 | IFLA_STATS_LINK_XSTATS, | |
857 | IFLA_STATS_LINK_XSTATS_SLAVE, | |
858 | IFLA_STATS_LINK_OFFLOAD_XSTATS, | |
859 | IFLA_STATS_AF_SPEC, | |
860 | __IFLA_STATS_MAX, | |
861 | }; | |
862 | ||
863 | #define IFLA_STATS_MAX (__IFLA_STATS_MAX - 1) | |
864 | ||
865 | #define IFLA_STATS_FILTER_BIT(ATTR) (1 << (ATTR - 1)) | |
866 | ||
867 | /* These are embedded into IFLA_STATS_LINK_XSTATS: | |
868 | * [IFLA_STATS_LINK_XSTATS] | |
869 | * -> [LINK_XSTATS_TYPE_xxx] | |
870 | * -> [rtnl link type specific attributes] | |
871 | */ | |
872 | enum { | |
873 | LINK_XSTATS_TYPE_UNSPEC, | |
874 | LINK_XSTATS_TYPE_BRIDGE, | |
875 | __LINK_XSTATS_TYPE_MAX | |
876 | }; | |
877 | #define LINK_XSTATS_TYPE_MAX (__LINK_XSTATS_TYPE_MAX - 1) | |
878 | ||
879 | /* These are stats embedded into IFLA_STATS_LINK_OFFLOAD_XSTATS */ | |
880 | enum { | |
881 | IFLA_OFFLOAD_XSTATS_UNSPEC, | |
882 | IFLA_OFFLOAD_XSTATS_CPU_HIT, /* struct rtnl_link_stats64 */ | |
883 | __IFLA_OFFLOAD_XSTATS_MAX | |
884 | }; | |
885 | #define IFLA_OFFLOAD_XSTATS_MAX (__IFLA_OFFLOAD_XSTATS_MAX - 1) | |
886 | ||
887 | /* XDP section */ | |
888 | ||
889 | #define XDP_FLAGS_UPDATE_IF_NOEXIST (1U << 0) | |
890 | #define XDP_FLAGS_SKB_MODE (1U << 1) | |
891 | #define XDP_FLAGS_DRV_MODE (1U << 2) | |
892 | #define XDP_FLAGS_HW_MODE (1U << 3) | |
893 | #define XDP_FLAGS_MODES (XDP_FLAGS_SKB_MODE | \ | |
894 | XDP_FLAGS_DRV_MODE | \ | |
895 | XDP_FLAGS_HW_MODE) | |
896 | #define XDP_FLAGS_MASK (XDP_FLAGS_UPDATE_IF_NOEXIST | \ | |
897 | XDP_FLAGS_MODES) | |
898 | ||
899 | /* These are stored into IFLA_XDP_ATTACHED on dump. */ | |
900 | enum { | |
901 | XDP_ATTACHED_NONE = 0, | |
902 | XDP_ATTACHED_DRV, | |
903 | XDP_ATTACHED_SKB, | |
904 | XDP_ATTACHED_HW, | |
905 | }; | |
906 | ||
907 | enum { | |
908 | IFLA_XDP_UNSPEC, | |
909 | IFLA_XDP_FD, | |
910 | IFLA_XDP_ATTACHED, | |
911 | IFLA_XDP_FLAGS, | |
912 | IFLA_XDP_PROG_ID, | |
913 | __IFLA_XDP_MAX, | |
914 | }; | |
915 | ||
916 | #define IFLA_XDP_MAX (__IFLA_XDP_MAX - 1) | |
917 | ||
918 | enum { | |
919 | IFLA_EVENT_NONE, | |
920 | IFLA_EVENT_REBOOT, /* internal reset / reboot */ | |
921 | IFLA_EVENT_FEATURES, /* change in offload features */ | |
922 | IFLA_EVENT_BONDING_FAILOVER, /* change in active slave */ | |
923 | IFLA_EVENT_NOTIFY_PEERS, /* re-sent grat. arp/ndisc */ | |
924 | IFLA_EVENT_IGMP_RESEND, /* re-sent IGMP JOIN */ | |
925 | IFLA_EVENT_BONDING_OPTIONS, /* change in bonding options */ | |
926 | }; | |
927 | ||
928 | #endif /* _LINUX_IF_LINK_H */ |