xref: /OK3568_Linux_fs/kernel/include/uapi/linux/if_link.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2*4882a593Smuzhiyun #ifndef _UAPI_LINUX_IF_LINK_H
3*4882a593Smuzhiyun #define _UAPI_LINUX_IF_LINK_H
4*4882a593Smuzhiyun 
5*4882a593Smuzhiyun #include <linux/types.h>
6*4882a593Smuzhiyun #include <linux/netlink.h>
7*4882a593Smuzhiyun 
8*4882a593Smuzhiyun /* This struct should be in sync with struct rtnl_link_stats64 */
9*4882a593Smuzhiyun struct rtnl_link_stats {
10*4882a593Smuzhiyun 	__u32	rx_packets;
11*4882a593Smuzhiyun 	__u32	tx_packets;
12*4882a593Smuzhiyun 	__u32	rx_bytes;
13*4882a593Smuzhiyun 	__u32	tx_bytes;
14*4882a593Smuzhiyun 	__u32	rx_errors;
15*4882a593Smuzhiyun 	__u32	tx_errors;
16*4882a593Smuzhiyun 	__u32	rx_dropped;
17*4882a593Smuzhiyun 	__u32	tx_dropped;
18*4882a593Smuzhiyun 	__u32	multicast;
19*4882a593Smuzhiyun 	__u32	collisions;
20*4882a593Smuzhiyun 	/* detailed rx_errors: */
21*4882a593Smuzhiyun 	__u32	rx_length_errors;
22*4882a593Smuzhiyun 	__u32	rx_over_errors;
23*4882a593Smuzhiyun 	__u32	rx_crc_errors;
24*4882a593Smuzhiyun 	__u32	rx_frame_errors;
25*4882a593Smuzhiyun 	__u32	rx_fifo_errors;
26*4882a593Smuzhiyun 	__u32	rx_missed_errors;
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun 	/* detailed tx_errors */
29*4882a593Smuzhiyun 	__u32	tx_aborted_errors;
30*4882a593Smuzhiyun 	__u32	tx_carrier_errors;
31*4882a593Smuzhiyun 	__u32	tx_fifo_errors;
32*4882a593Smuzhiyun 	__u32	tx_heartbeat_errors;
33*4882a593Smuzhiyun 	__u32	tx_window_errors;
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun 	/* for cslip etc */
36*4882a593Smuzhiyun 	__u32	rx_compressed;
37*4882a593Smuzhiyun 	__u32	tx_compressed;
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun 	__u32	rx_nohandler;
40*4882a593Smuzhiyun };
41*4882a593Smuzhiyun 
42*4882a593Smuzhiyun /**
43*4882a593Smuzhiyun  * struct rtnl_link_stats64 - The main device statistics structure.
44*4882a593Smuzhiyun  *
45*4882a593Smuzhiyun  * @rx_packets: Number of good packets received by the interface.
46*4882a593Smuzhiyun  *   For hardware interfaces counts all good packets received from the device
47*4882a593Smuzhiyun  *   by the host, including packets which host had to drop at various stages
48*4882a593Smuzhiyun  *   of processing (even in the driver).
49*4882a593Smuzhiyun  *
50*4882a593Smuzhiyun  * @tx_packets: Number of packets successfully transmitted.
51*4882a593Smuzhiyun  *   For hardware interfaces counts packets which host was able to successfully
52*4882a593Smuzhiyun  *   hand over to the device, which does not necessarily mean that packets
53*4882a593Smuzhiyun  *   had been successfully transmitted out of the device, only that device
54*4882a593Smuzhiyun  *   acknowledged it copied them out of host memory.
55*4882a593Smuzhiyun  *
56*4882a593Smuzhiyun  * @rx_bytes: Number of good received bytes, corresponding to @rx_packets.
57*4882a593Smuzhiyun  *
58*4882a593Smuzhiyun  *   For IEEE 802.3 devices should count the length of Ethernet Frames
59*4882a593Smuzhiyun  *   excluding the FCS.
60*4882a593Smuzhiyun  *
61*4882a593Smuzhiyun  * @tx_bytes: Number of good transmitted bytes, corresponding to @tx_packets.
62*4882a593Smuzhiyun  *
63*4882a593Smuzhiyun  *   For IEEE 802.3 devices should count the length of Ethernet Frames
64*4882a593Smuzhiyun  *   excluding the FCS.
65*4882a593Smuzhiyun  *
66*4882a593Smuzhiyun  * @rx_errors: Total number of bad packets received on this network device.
67*4882a593Smuzhiyun  *   This counter must include events counted by @rx_length_errors,
68*4882a593Smuzhiyun  *   @rx_crc_errors, @rx_frame_errors and other errors not otherwise
69*4882a593Smuzhiyun  *   counted.
70*4882a593Smuzhiyun  *
71*4882a593Smuzhiyun  * @tx_errors: Total number of transmit problems.
72*4882a593Smuzhiyun  *   This counter must include events counter by @tx_aborted_errors,
73*4882a593Smuzhiyun  *   @tx_carrier_errors, @tx_fifo_errors, @tx_heartbeat_errors,
74*4882a593Smuzhiyun  *   @tx_window_errors and other errors not otherwise counted.
75*4882a593Smuzhiyun  *
76*4882a593Smuzhiyun  * @rx_dropped: Number of packets received but not processed,
77*4882a593Smuzhiyun  *   e.g. due to lack of resources or unsupported protocol.
78*4882a593Smuzhiyun  *   For hardware interfaces this counter should not include packets
79*4882a593Smuzhiyun  *   dropped by the device which are counted separately in
80*4882a593Smuzhiyun  *   @rx_missed_errors (since procfs folds those two counters together).
81*4882a593Smuzhiyun  *
82*4882a593Smuzhiyun  * @tx_dropped: Number of packets dropped on their way to transmission,
83*4882a593Smuzhiyun  *   e.g. due to lack of resources.
84*4882a593Smuzhiyun  *
85*4882a593Smuzhiyun  * @multicast: Multicast packets received.
86*4882a593Smuzhiyun  *   For hardware interfaces this statistic is commonly calculated
87*4882a593Smuzhiyun  *   at the device level (unlike @rx_packets) and therefore may include
88*4882a593Smuzhiyun  *   packets which did not reach the host.
89*4882a593Smuzhiyun  *
90*4882a593Smuzhiyun  *   For IEEE 802.3 devices this counter may be equivalent to:
91*4882a593Smuzhiyun  *
92*4882a593Smuzhiyun  *    - 30.3.1.1.21 aMulticastFramesReceivedOK
93*4882a593Smuzhiyun  *
94*4882a593Smuzhiyun  * @collisions: Number of collisions during packet transmissions.
95*4882a593Smuzhiyun  *
96*4882a593Smuzhiyun  * @rx_length_errors: Number of packets dropped due to invalid length.
97*4882a593Smuzhiyun  *   Part of aggregate "frame" errors in `/proc/net/dev`.
98*4882a593Smuzhiyun  *
99*4882a593Smuzhiyun  *   For IEEE 802.3 devices this counter should be equivalent to a sum
100*4882a593Smuzhiyun  *   of the following attributes:
101*4882a593Smuzhiyun  *
102*4882a593Smuzhiyun  *    - 30.3.1.1.23 aInRangeLengthErrors
103*4882a593Smuzhiyun  *    - 30.3.1.1.24 aOutOfRangeLengthField
104*4882a593Smuzhiyun  *    - 30.3.1.1.25 aFrameTooLongErrors
105*4882a593Smuzhiyun  *
106*4882a593Smuzhiyun  * @rx_over_errors: Receiver FIFO overflow event counter.
107*4882a593Smuzhiyun  *
108*4882a593Smuzhiyun  *   Historically the count of overflow events. Such events may be
109*4882a593Smuzhiyun  *   reported in the receive descriptors or via interrupts, and may
110*4882a593Smuzhiyun  *   not correspond one-to-one with dropped packets.
111*4882a593Smuzhiyun  *
112*4882a593Smuzhiyun  *   The recommended interpretation for high speed interfaces is -
113*4882a593Smuzhiyun  *   number of packets dropped because they did not fit into buffers
114*4882a593Smuzhiyun  *   provided by the host, e.g. packets larger than MTU or next buffer
115*4882a593Smuzhiyun  *   in the ring was not available for a scatter transfer.
116*4882a593Smuzhiyun  *
117*4882a593Smuzhiyun  *   Part of aggregate "frame" errors in `/proc/net/dev`.
118*4882a593Smuzhiyun  *
119*4882a593Smuzhiyun  *   This statistics was historically used interchangeably with
120*4882a593Smuzhiyun  *   @rx_fifo_errors.
121*4882a593Smuzhiyun  *
122*4882a593Smuzhiyun  *   This statistic corresponds to hardware events and is not commonly used
123*4882a593Smuzhiyun  *   on software devices.
124*4882a593Smuzhiyun  *
125*4882a593Smuzhiyun  * @rx_crc_errors: Number of packets received with a CRC error.
126*4882a593Smuzhiyun  *   Part of aggregate "frame" errors in `/proc/net/dev`.
127*4882a593Smuzhiyun  *
128*4882a593Smuzhiyun  *   For IEEE 802.3 devices this counter must be equivalent to:
129*4882a593Smuzhiyun  *
130*4882a593Smuzhiyun  *    - 30.3.1.1.6 aFrameCheckSequenceErrors
131*4882a593Smuzhiyun  *
132*4882a593Smuzhiyun  * @rx_frame_errors: Receiver frame alignment errors.
133*4882a593Smuzhiyun  *   Part of aggregate "frame" errors in `/proc/net/dev`.
134*4882a593Smuzhiyun  *
135*4882a593Smuzhiyun  *   For IEEE 802.3 devices this counter should be equivalent to:
136*4882a593Smuzhiyun  *
137*4882a593Smuzhiyun  *    - 30.3.1.1.7 aAlignmentErrors
138*4882a593Smuzhiyun  *
139*4882a593Smuzhiyun  * @rx_fifo_errors: Receiver FIFO error counter.
140*4882a593Smuzhiyun  *
141*4882a593Smuzhiyun  *   Historically the count of overflow events. Those events may be
142*4882a593Smuzhiyun  *   reported in the receive descriptors or via interrupts, and may
143*4882a593Smuzhiyun  *   not correspond one-to-one with dropped packets.
144*4882a593Smuzhiyun  *
145*4882a593Smuzhiyun  *   This statistics was used interchangeably with @rx_over_errors.
146*4882a593Smuzhiyun  *   Not recommended for use in drivers for high speed interfaces.
147*4882a593Smuzhiyun  *
148*4882a593Smuzhiyun  *   This statistic is used on software devices, e.g. to count software
149*4882a593Smuzhiyun  *   packet queue overflow (can) or sequencing errors (GRE).
150*4882a593Smuzhiyun  *
151*4882a593Smuzhiyun  * @rx_missed_errors: Count of packets missed by the host.
152*4882a593Smuzhiyun  *   Folded into the "drop" counter in `/proc/net/dev`.
153*4882a593Smuzhiyun  *
154*4882a593Smuzhiyun  *   Counts number of packets dropped by the device due to lack
155*4882a593Smuzhiyun  *   of buffer space. This usually indicates that the host interface
156*4882a593Smuzhiyun  *   is slower than the network interface, or host is not keeping up
157*4882a593Smuzhiyun  *   with the receive packet rate.
158*4882a593Smuzhiyun  *
159*4882a593Smuzhiyun  *   This statistic corresponds to hardware events and is not used
160*4882a593Smuzhiyun  *   on software devices.
161*4882a593Smuzhiyun  *
162*4882a593Smuzhiyun  * @tx_aborted_errors:
163*4882a593Smuzhiyun  *   Part of aggregate "carrier" errors in `/proc/net/dev`.
164*4882a593Smuzhiyun  *   For IEEE 802.3 devices capable of half-duplex operation this counter
165*4882a593Smuzhiyun  *   must be equivalent to:
166*4882a593Smuzhiyun  *
167*4882a593Smuzhiyun  *    - 30.3.1.1.11 aFramesAbortedDueToXSColls
168*4882a593Smuzhiyun  *
169*4882a593Smuzhiyun  *   High speed interfaces may use this counter as a general device
170*4882a593Smuzhiyun  *   discard counter.
171*4882a593Smuzhiyun  *
172*4882a593Smuzhiyun  * @tx_carrier_errors: Number of frame transmission errors due to loss
173*4882a593Smuzhiyun  *   of carrier during transmission.
174*4882a593Smuzhiyun  *   Part of aggregate "carrier" errors in `/proc/net/dev`.
175*4882a593Smuzhiyun  *
176*4882a593Smuzhiyun  *   For IEEE 802.3 devices this counter must be equivalent to:
177*4882a593Smuzhiyun  *
178*4882a593Smuzhiyun  *    - 30.3.1.1.13 aCarrierSenseErrors
179*4882a593Smuzhiyun  *
180*4882a593Smuzhiyun  * @tx_fifo_errors: Number of frame transmission errors due to device
181*4882a593Smuzhiyun  *   FIFO underrun / underflow. This condition occurs when the device
182*4882a593Smuzhiyun  *   begins transmission of a frame but is unable to deliver the
183*4882a593Smuzhiyun  *   entire frame to the transmitter in time for transmission.
184*4882a593Smuzhiyun  *   Part of aggregate "carrier" errors in `/proc/net/dev`.
185*4882a593Smuzhiyun  *
186*4882a593Smuzhiyun  * @tx_heartbeat_errors: Number of Heartbeat / SQE Test errors for
187*4882a593Smuzhiyun  *   old half-duplex Ethernet.
188*4882a593Smuzhiyun  *   Part of aggregate "carrier" errors in `/proc/net/dev`.
189*4882a593Smuzhiyun  *
190*4882a593Smuzhiyun  *   For IEEE 802.3 devices possibly equivalent to:
191*4882a593Smuzhiyun  *
192*4882a593Smuzhiyun  *    - 30.3.2.1.4 aSQETestErrors
193*4882a593Smuzhiyun  *
194*4882a593Smuzhiyun  * @tx_window_errors: Number of frame transmission errors due
195*4882a593Smuzhiyun  *   to late collisions (for Ethernet - after the first 64B of transmission).
196*4882a593Smuzhiyun  *   Part of aggregate "carrier" errors in `/proc/net/dev`.
197*4882a593Smuzhiyun  *
198*4882a593Smuzhiyun  *   For IEEE 802.3 devices this counter must be equivalent to:
199*4882a593Smuzhiyun  *
200*4882a593Smuzhiyun  *    - 30.3.1.1.10 aLateCollisions
201*4882a593Smuzhiyun  *
202*4882a593Smuzhiyun  * @rx_compressed: Number of correctly received compressed packets.
203*4882a593Smuzhiyun  *   This counters is only meaningful for interfaces which support
204*4882a593Smuzhiyun  *   packet compression (e.g. CSLIP, PPP).
205*4882a593Smuzhiyun  *
206*4882a593Smuzhiyun  * @tx_compressed: Number of transmitted compressed packets.
207*4882a593Smuzhiyun  *   This counters is only meaningful for interfaces which support
208*4882a593Smuzhiyun  *   packet compression (e.g. CSLIP, PPP).
209*4882a593Smuzhiyun  *
210*4882a593Smuzhiyun  * @rx_nohandler: Number of packets received on the interface
211*4882a593Smuzhiyun  *   but dropped by the networking stack because the device is
212*4882a593Smuzhiyun  *   not designated to receive packets (e.g. backup link in a bond).
213*4882a593Smuzhiyun  */
214*4882a593Smuzhiyun struct rtnl_link_stats64 {
215*4882a593Smuzhiyun 	__u64	rx_packets;
216*4882a593Smuzhiyun 	__u64	tx_packets;
217*4882a593Smuzhiyun 	__u64	rx_bytes;
218*4882a593Smuzhiyun 	__u64	tx_bytes;
219*4882a593Smuzhiyun 	__u64	rx_errors;
220*4882a593Smuzhiyun 	__u64	tx_errors;
221*4882a593Smuzhiyun 	__u64	rx_dropped;
222*4882a593Smuzhiyun 	__u64	tx_dropped;
223*4882a593Smuzhiyun 	__u64	multicast;
224*4882a593Smuzhiyun 	__u64	collisions;
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun 	/* detailed rx_errors: */
227*4882a593Smuzhiyun 	__u64	rx_length_errors;
228*4882a593Smuzhiyun 	__u64	rx_over_errors;
229*4882a593Smuzhiyun 	__u64	rx_crc_errors;
230*4882a593Smuzhiyun 	__u64	rx_frame_errors;
231*4882a593Smuzhiyun 	__u64	rx_fifo_errors;
232*4882a593Smuzhiyun 	__u64	rx_missed_errors;
233*4882a593Smuzhiyun 
234*4882a593Smuzhiyun 	/* detailed tx_errors */
235*4882a593Smuzhiyun 	__u64	tx_aborted_errors;
236*4882a593Smuzhiyun 	__u64	tx_carrier_errors;
237*4882a593Smuzhiyun 	__u64	tx_fifo_errors;
238*4882a593Smuzhiyun 	__u64	tx_heartbeat_errors;
239*4882a593Smuzhiyun 	__u64	tx_window_errors;
240*4882a593Smuzhiyun 
241*4882a593Smuzhiyun 	/* for cslip etc */
242*4882a593Smuzhiyun 	__u64	rx_compressed;
243*4882a593Smuzhiyun 	__u64	tx_compressed;
244*4882a593Smuzhiyun 	__u64	rx_nohandler;
245*4882a593Smuzhiyun };
246*4882a593Smuzhiyun 
247*4882a593Smuzhiyun /* The struct should be in sync with struct ifmap */
248*4882a593Smuzhiyun struct rtnl_link_ifmap {
249*4882a593Smuzhiyun 	__u64	mem_start;
250*4882a593Smuzhiyun 	__u64	mem_end;
251*4882a593Smuzhiyun 	__u64	base_addr;
252*4882a593Smuzhiyun 	__u16	irq;
253*4882a593Smuzhiyun 	__u8	dma;
254*4882a593Smuzhiyun 	__u8	port;
255*4882a593Smuzhiyun };
256*4882a593Smuzhiyun 
257*4882a593Smuzhiyun /*
258*4882a593Smuzhiyun  * IFLA_AF_SPEC
259*4882a593Smuzhiyun  *   Contains nested attributes for address family specific attributes.
260*4882a593Smuzhiyun  *   Each address family may create a attribute with the address family
261*4882a593Smuzhiyun  *   number as type and create its own attribute structure in it.
262*4882a593Smuzhiyun  *
263*4882a593Smuzhiyun  *   Example:
264*4882a593Smuzhiyun  *   [IFLA_AF_SPEC] = {
265*4882a593Smuzhiyun  *       [AF_INET] = {
266*4882a593Smuzhiyun  *           [IFLA_INET_CONF] = ...,
267*4882a593Smuzhiyun  *       },
268*4882a593Smuzhiyun  *       [AF_INET6] = {
269*4882a593Smuzhiyun  *           [IFLA_INET6_FLAGS] = ...,
270*4882a593Smuzhiyun  *           [IFLA_INET6_CONF] = ...,
271*4882a593Smuzhiyun  *       }
272*4882a593Smuzhiyun  *   }
273*4882a593Smuzhiyun  */
274*4882a593Smuzhiyun 
275*4882a593Smuzhiyun enum {
276*4882a593Smuzhiyun 	IFLA_UNSPEC,
277*4882a593Smuzhiyun 	IFLA_ADDRESS,
278*4882a593Smuzhiyun 	IFLA_BROADCAST,
279*4882a593Smuzhiyun 	IFLA_IFNAME,
280*4882a593Smuzhiyun 	IFLA_MTU,
281*4882a593Smuzhiyun 	IFLA_LINK,
282*4882a593Smuzhiyun 	IFLA_QDISC,
283*4882a593Smuzhiyun 	IFLA_STATS,
284*4882a593Smuzhiyun 	IFLA_COST,
285*4882a593Smuzhiyun #define IFLA_COST IFLA_COST
286*4882a593Smuzhiyun 	IFLA_PRIORITY,
287*4882a593Smuzhiyun #define IFLA_PRIORITY IFLA_PRIORITY
288*4882a593Smuzhiyun 	IFLA_MASTER,
289*4882a593Smuzhiyun #define IFLA_MASTER IFLA_MASTER
290*4882a593Smuzhiyun 	IFLA_WIRELESS,		/* Wireless Extension event - see wireless.h */
291*4882a593Smuzhiyun #define IFLA_WIRELESS IFLA_WIRELESS
292*4882a593Smuzhiyun 	IFLA_PROTINFO,		/* Protocol specific information for a link */
293*4882a593Smuzhiyun #define IFLA_PROTINFO IFLA_PROTINFO
294*4882a593Smuzhiyun 	IFLA_TXQLEN,
295*4882a593Smuzhiyun #define IFLA_TXQLEN IFLA_TXQLEN
296*4882a593Smuzhiyun 	IFLA_MAP,
297*4882a593Smuzhiyun #define IFLA_MAP IFLA_MAP
298*4882a593Smuzhiyun 	IFLA_WEIGHT,
299*4882a593Smuzhiyun #define IFLA_WEIGHT IFLA_WEIGHT
300*4882a593Smuzhiyun 	IFLA_OPERSTATE,
301*4882a593Smuzhiyun 	IFLA_LINKMODE,
302*4882a593Smuzhiyun 	IFLA_LINKINFO,
303*4882a593Smuzhiyun #define IFLA_LINKINFO IFLA_LINKINFO
304*4882a593Smuzhiyun 	IFLA_NET_NS_PID,
305*4882a593Smuzhiyun 	IFLA_IFALIAS,
306*4882a593Smuzhiyun 	IFLA_NUM_VF,		/* Number of VFs if device is SR-IOV PF */
307*4882a593Smuzhiyun 	IFLA_VFINFO_LIST,
308*4882a593Smuzhiyun 	IFLA_STATS64,
309*4882a593Smuzhiyun 	IFLA_VF_PORTS,
310*4882a593Smuzhiyun 	IFLA_PORT_SELF,
311*4882a593Smuzhiyun 	IFLA_AF_SPEC,
312*4882a593Smuzhiyun 	IFLA_GROUP,		/* Group the device belongs to */
313*4882a593Smuzhiyun 	IFLA_NET_NS_FD,
314*4882a593Smuzhiyun 	IFLA_EXT_MASK,		/* Extended info mask, VFs, etc */
315*4882a593Smuzhiyun 	IFLA_PROMISCUITY,	/* Promiscuity count: > 0 means acts PROMISC */
316*4882a593Smuzhiyun #define IFLA_PROMISCUITY IFLA_PROMISCUITY
317*4882a593Smuzhiyun 	IFLA_NUM_TX_QUEUES,
318*4882a593Smuzhiyun 	IFLA_NUM_RX_QUEUES,
319*4882a593Smuzhiyun 	IFLA_CARRIER,
320*4882a593Smuzhiyun 	IFLA_PHYS_PORT_ID,
321*4882a593Smuzhiyun 	IFLA_CARRIER_CHANGES,
322*4882a593Smuzhiyun 	IFLA_PHYS_SWITCH_ID,
323*4882a593Smuzhiyun 	IFLA_LINK_NETNSID,
324*4882a593Smuzhiyun 	IFLA_PHYS_PORT_NAME,
325*4882a593Smuzhiyun 	IFLA_PROTO_DOWN,
326*4882a593Smuzhiyun 	IFLA_GSO_MAX_SEGS,
327*4882a593Smuzhiyun 	IFLA_GSO_MAX_SIZE,
328*4882a593Smuzhiyun 	IFLA_PAD,
329*4882a593Smuzhiyun 	IFLA_XDP,
330*4882a593Smuzhiyun 	IFLA_EVENT,
331*4882a593Smuzhiyun 	IFLA_NEW_NETNSID,
332*4882a593Smuzhiyun 	IFLA_IF_NETNSID,
333*4882a593Smuzhiyun 	IFLA_TARGET_NETNSID = IFLA_IF_NETNSID, /* new alias */
334*4882a593Smuzhiyun 	IFLA_CARRIER_UP_COUNT,
335*4882a593Smuzhiyun 	IFLA_CARRIER_DOWN_COUNT,
336*4882a593Smuzhiyun 	IFLA_NEW_IFINDEX,
337*4882a593Smuzhiyun 	IFLA_MIN_MTU,
338*4882a593Smuzhiyun 	IFLA_MAX_MTU,
339*4882a593Smuzhiyun 	IFLA_PROP_LIST,
340*4882a593Smuzhiyun 	IFLA_ALT_IFNAME, /* Alternative ifname */
341*4882a593Smuzhiyun 	IFLA_PERM_ADDRESS,
342*4882a593Smuzhiyun 	IFLA_PROTO_DOWN_REASON,
343*4882a593Smuzhiyun 	__IFLA_MAX
344*4882a593Smuzhiyun };
345*4882a593Smuzhiyun 
346*4882a593Smuzhiyun 
347*4882a593Smuzhiyun #define IFLA_MAX (__IFLA_MAX - 1)
348*4882a593Smuzhiyun 
349*4882a593Smuzhiyun enum {
350*4882a593Smuzhiyun 	IFLA_PROTO_DOWN_REASON_UNSPEC,
351*4882a593Smuzhiyun 	IFLA_PROTO_DOWN_REASON_MASK,	/* u32, mask for reason bits */
352*4882a593Smuzhiyun 	IFLA_PROTO_DOWN_REASON_VALUE,   /* u32, reason bit value */
353*4882a593Smuzhiyun 
354*4882a593Smuzhiyun 	__IFLA_PROTO_DOWN_REASON_CNT,
355*4882a593Smuzhiyun 	IFLA_PROTO_DOWN_REASON_MAX = __IFLA_PROTO_DOWN_REASON_CNT - 1
356*4882a593Smuzhiyun };
357*4882a593Smuzhiyun 
358*4882a593Smuzhiyun /* backwards compatibility for userspace */
359*4882a593Smuzhiyun #ifndef __KERNEL__
360*4882a593Smuzhiyun #define IFLA_RTA(r)  ((struct rtattr*)(((char*)(r)) + NLMSG_ALIGN(sizeof(struct ifinfomsg))))
361*4882a593Smuzhiyun #define IFLA_PAYLOAD(n) NLMSG_PAYLOAD(n,sizeof(struct ifinfomsg))
362*4882a593Smuzhiyun #endif
363*4882a593Smuzhiyun 
364*4882a593Smuzhiyun enum {
365*4882a593Smuzhiyun 	IFLA_INET_UNSPEC,
366*4882a593Smuzhiyun 	IFLA_INET_CONF,
367*4882a593Smuzhiyun 	__IFLA_INET_MAX,
368*4882a593Smuzhiyun };
369*4882a593Smuzhiyun 
370*4882a593Smuzhiyun #define IFLA_INET_MAX (__IFLA_INET_MAX - 1)
371*4882a593Smuzhiyun 
372*4882a593Smuzhiyun /* ifi_flags.
373*4882a593Smuzhiyun 
374*4882a593Smuzhiyun    IFF_* flags.
375*4882a593Smuzhiyun 
376*4882a593Smuzhiyun    The only change is:
377*4882a593Smuzhiyun    IFF_LOOPBACK, IFF_BROADCAST and IFF_POINTOPOINT are
378*4882a593Smuzhiyun    more not changeable by user. They describe link media
379*4882a593Smuzhiyun    characteristics and set by device driver.
380*4882a593Smuzhiyun 
381*4882a593Smuzhiyun    Comments:
382*4882a593Smuzhiyun    - Combination IFF_BROADCAST|IFF_POINTOPOINT is invalid
383*4882a593Smuzhiyun    - If neither of these three flags are set;
384*4882a593Smuzhiyun      the interface is NBMA.
385*4882a593Smuzhiyun 
386*4882a593Smuzhiyun    - IFF_MULTICAST does not mean anything special:
387*4882a593Smuzhiyun    multicasts can be used on all not-NBMA links.
388*4882a593Smuzhiyun    IFF_MULTICAST means that this media uses special encapsulation
389*4882a593Smuzhiyun    for multicast frames. Apparently, all IFF_POINTOPOINT and
390*4882a593Smuzhiyun    IFF_BROADCAST devices are able to use multicasts too.
391*4882a593Smuzhiyun  */
392*4882a593Smuzhiyun 
393*4882a593Smuzhiyun /* IFLA_LINK.
394*4882a593Smuzhiyun    For usual devices it is equal ifi_index.
395*4882a593Smuzhiyun    If it is a "virtual interface" (f.e. tunnel), ifi_link
396*4882a593Smuzhiyun    can point to real physical interface (f.e. for bandwidth calculations),
397*4882a593Smuzhiyun    or maybe 0, what means, that real media is unknown (usual
398*4882a593Smuzhiyun    for IPIP tunnels, when route to endpoint is allowed to change)
399*4882a593Smuzhiyun  */
400*4882a593Smuzhiyun 
401*4882a593Smuzhiyun /* Subtype attributes for IFLA_PROTINFO */
402*4882a593Smuzhiyun enum {
403*4882a593Smuzhiyun 	IFLA_INET6_UNSPEC,
404*4882a593Smuzhiyun 	IFLA_INET6_FLAGS,	/* link flags			*/
405*4882a593Smuzhiyun 	IFLA_INET6_CONF,	/* sysctl parameters		*/
406*4882a593Smuzhiyun 	IFLA_INET6_STATS,	/* statistics			*/
407*4882a593Smuzhiyun 	IFLA_INET6_MCAST,	/* MC things. What of them?	*/
408*4882a593Smuzhiyun 	IFLA_INET6_CACHEINFO,	/* time values and max reasm size */
409*4882a593Smuzhiyun 	IFLA_INET6_ICMP6STATS,	/* statistics (icmpv6)		*/
410*4882a593Smuzhiyun 	IFLA_INET6_TOKEN,	/* device token			*/
411*4882a593Smuzhiyun 	IFLA_INET6_ADDR_GEN_MODE, /* implicit address generator mode */
412*4882a593Smuzhiyun 	__IFLA_INET6_MAX
413*4882a593Smuzhiyun };
414*4882a593Smuzhiyun 
415*4882a593Smuzhiyun #define IFLA_INET6_MAX	(__IFLA_INET6_MAX - 1)
416*4882a593Smuzhiyun 
417*4882a593Smuzhiyun enum in6_addr_gen_mode {
418*4882a593Smuzhiyun 	IN6_ADDR_GEN_MODE_EUI64,
419*4882a593Smuzhiyun 	IN6_ADDR_GEN_MODE_NONE,
420*4882a593Smuzhiyun 	IN6_ADDR_GEN_MODE_STABLE_PRIVACY,
421*4882a593Smuzhiyun 	IN6_ADDR_GEN_MODE_RANDOM,
422*4882a593Smuzhiyun };
423*4882a593Smuzhiyun 
424*4882a593Smuzhiyun /* Bridge section */
425*4882a593Smuzhiyun 
426*4882a593Smuzhiyun enum {
427*4882a593Smuzhiyun 	IFLA_BR_UNSPEC,
428*4882a593Smuzhiyun 	IFLA_BR_FORWARD_DELAY,
429*4882a593Smuzhiyun 	IFLA_BR_HELLO_TIME,
430*4882a593Smuzhiyun 	IFLA_BR_MAX_AGE,
431*4882a593Smuzhiyun 	IFLA_BR_AGEING_TIME,
432*4882a593Smuzhiyun 	IFLA_BR_STP_STATE,
433*4882a593Smuzhiyun 	IFLA_BR_PRIORITY,
434*4882a593Smuzhiyun 	IFLA_BR_VLAN_FILTERING,
435*4882a593Smuzhiyun 	IFLA_BR_VLAN_PROTOCOL,
436*4882a593Smuzhiyun 	IFLA_BR_GROUP_FWD_MASK,
437*4882a593Smuzhiyun 	IFLA_BR_ROOT_ID,
438*4882a593Smuzhiyun 	IFLA_BR_BRIDGE_ID,
439*4882a593Smuzhiyun 	IFLA_BR_ROOT_PORT,
440*4882a593Smuzhiyun 	IFLA_BR_ROOT_PATH_COST,
441*4882a593Smuzhiyun 	IFLA_BR_TOPOLOGY_CHANGE,
442*4882a593Smuzhiyun 	IFLA_BR_TOPOLOGY_CHANGE_DETECTED,
443*4882a593Smuzhiyun 	IFLA_BR_HELLO_TIMER,
444*4882a593Smuzhiyun 	IFLA_BR_TCN_TIMER,
445*4882a593Smuzhiyun 	IFLA_BR_TOPOLOGY_CHANGE_TIMER,
446*4882a593Smuzhiyun 	IFLA_BR_GC_TIMER,
447*4882a593Smuzhiyun 	IFLA_BR_GROUP_ADDR,
448*4882a593Smuzhiyun 	IFLA_BR_FDB_FLUSH,
449*4882a593Smuzhiyun 	IFLA_BR_MCAST_ROUTER,
450*4882a593Smuzhiyun 	IFLA_BR_MCAST_SNOOPING,
451*4882a593Smuzhiyun 	IFLA_BR_MCAST_QUERY_USE_IFADDR,
452*4882a593Smuzhiyun 	IFLA_BR_MCAST_QUERIER,
453*4882a593Smuzhiyun 	IFLA_BR_MCAST_HASH_ELASTICITY,
454*4882a593Smuzhiyun 	IFLA_BR_MCAST_HASH_MAX,
455*4882a593Smuzhiyun 	IFLA_BR_MCAST_LAST_MEMBER_CNT,
456*4882a593Smuzhiyun 	IFLA_BR_MCAST_STARTUP_QUERY_CNT,
457*4882a593Smuzhiyun 	IFLA_BR_MCAST_LAST_MEMBER_INTVL,
458*4882a593Smuzhiyun 	IFLA_BR_MCAST_MEMBERSHIP_INTVL,
459*4882a593Smuzhiyun 	IFLA_BR_MCAST_QUERIER_INTVL,
460*4882a593Smuzhiyun 	IFLA_BR_MCAST_QUERY_INTVL,
461*4882a593Smuzhiyun 	IFLA_BR_MCAST_QUERY_RESPONSE_INTVL,
462*4882a593Smuzhiyun 	IFLA_BR_MCAST_STARTUP_QUERY_INTVL,
463*4882a593Smuzhiyun 	IFLA_BR_NF_CALL_IPTABLES,
464*4882a593Smuzhiyun 	IFLA_BR_NF_CALL_IP6TABLES,
465*4882a593Smuzhiyun 	IFLA_BR_NF_CALL_ARPTABLES,
466*4882a593Smuzhiyun 	IFLA_BR_VLAN_DEFAULT_PVID,
467*4882a593Smuzhiyun 	IFLA_BR_PAD,
468*4882a593Smuzhiyun 	IFLA_BR_VLAN_STATS_ENABLED,
469*4882a593Smuzhiyun 	IFLA_BR_MCAST_STATS_ENABLED,
470*4882a593Smuzhiyun 	IFLA_BR_MCAST_IGMP_VERSION,
471*4882a593Smuzhiyun 	IFLA_BR_MCAST_MLD_VERSION,
472*4882a593Smuzhiyun 	IFLA_BR_VLAN_STATS_PER_PORT,
473*4882a593Smuzhiyun 	IFLA_BR_MULTI_BOOLOPT,
474*4882a593Smuzhiyun 	__IFLA_BR_MAX,
475*4882a593Smuzhiyun };
476*4882a593Smuzhiyun 
477*4882a593Smuzhiyun #define IFLA_BR_MAX	(__IFLA_BR_MAX - 1)
478*4882a593Smuzhiyun 
479*4882a593Smuzhiyun struct ifla_bridge_id {
480*4882a593Smuzhiyun 	__u8	prio[2];
481*4882a593Smuzhiyun 	__u8	addr[6]; /* ETH_ALEN */
482*4882a593Smuzhiyun };
483*4882a593Smuzhiyun 
484*4882a593Smuzhiyun enum {
485*4882a593Smuzhiyun 	BRIDGE_MODE_UNSPEC,
486*4882a593Smuzhiyun 	BRIDGE_MODE_HAIRPIN,
487*4882a593Smuzhiyun };
488*4882a593Smuzhiyun 
489*4882a593Smuzhiyun enum {
490*4882a593Smuzhiyun 	IFLA_BRPORT_UNSPEC,
491*4882a593Smuzhiyun 	IFLA_BRPORT_STATE,	/* Spanning tree state     */
492*4882a593Smuzhiyun 	IFLA_BRPORT_PRIORITY,	/* "             priority  */
493*4882a593Smuzhiyun 	IFLA_BRPORT_COST,	/* "             cost      */
494*4882a593Smuzhiyun 	IFLA_BRPORT_MODE,	/* mode (hairpin)          */
495*4882a593Smuzhiyun 	IFLA_BRPORT_GUARD,	/* bpdu guard              */
496*4882a593Smuzhiyun 	IFLA_BRPORT_PROTECT,	/* root port protection    */
497*4882a593Smuzhiyun 	IFLA_BRPORT_FAST_LEAVE,	/* multicast fast leave    */
498*4882a593Smuzhiyun 	IFLA_BRPORT_LEARNING,	/* mac learning */
499*4882a593Smuzhiyun 	IFLA_BRPORT_UNICAST_FLOOD, /* flood unicast traffic */
500*4882a593Smuzhiyun 	IFLA_BRPORT_PROXYARP,	/* proxy ARP */
501*4882a593Smuzhiyun 	IFLA_BRPORT_LEARNING_SYNC, /* mac learning sync from device */
502*4882a593Smuzhiyun 	IFLA_BRPORT_PROXYARP_WIFI, /* proxy ARP for Wi-Fi */
503*4882a593Smuzhiyun 	IFLA_BRPORT_ROOT_ID,	/* designated root */
504*4882a593Smuzhiyun 	IFLA_BRPORT_BRIDGE_ID,	/* designated bridge */
505*4882a593Smuzhiyun 	IFLA_BRPORT_DESIGNATED_PORT,
506*4882a593Smuzhiyun 	IFLA_BRPORT_DESIGNATED_COST,
507*4882a593Smuzhiyun 	IFLA_BRPORT_ID,
508*4882a593Smuzhiyun 	IFLA_BRPORT_NO,
509*4882a593Smuzhiyun 	IFLA_BRPORT_TOPOLOGY_CHANGE_ACK,
510*4882a593Smuzhiyun 	IFLA_BRPORT_CONFIG_PENDING,
511*4882a593Smuzhiyun 	IFLA_BRPORT_MESSAGE_AGE_TIMER,
512*4882a593Smuzhiyun 	IFLA_BRPORT_FORWARD_DELAY_TIMER,
513*4882a593Smuzhiyun 	IFLA_BRPORT_HOLD_TIMER,
514*4882a593Smuzhiyun 	IFLA_BRPORT_FLUSH,
515*4882a593Smuzhiyun 	IFLA_BRPORT_MULTICAST_ROUTER,
516*4882a593Smuzhiyun 	IFLA_BRPORT_PAD,
517*4882a593Smuzhiyun 	IFLA_BRPORT_MCAST_FLOOD,
518*4882a593Smuzhiyun 	IFLA_BRPORT_MCAST_TO_UCAST,
519*4882a593Smuzhiyun 	IFLA_BRPORT_VLAN_TUNNEL,
520*4882a593Smuzhiyun 	IFLA_BRPORT_BCAST_FLOOD,
521*4882a593Smuzhiyun 	IFLA_BRPORT_GROUP_FWD_MASK,
522*4882a593Smuzhiyun 	IFLA_BRPORT_NEIGH_SUPPRESS,
523*4882a593Smuzhiyun 	IFLA_BRPORT_ISOLATED,
524*4882a593Smuzhiyun 	IFLA_BRPORT_BACKUP_PORT,
525*4882a593Smuzhiyun 	IFLA_BRPORT_MRP_RING_OPEN,
526*4882a593Smuzhiyun 	IFLA_BRPORT_MRP_IN_OPEN,
527*4882a593Smuzhiyun 	__IFLA_BRPORT_MAX
528*4882a593Smuzhiyun };
529*4882a593Smuzhiyun #define IFLA_BRPORT_MAX (__IFLA_BRPORT_MAX - 1)
530*4882a593Smuzhiyun 
531*4882a593Smuzhiyun struct ifla_cacheinfo {
532*4882a593Smuzhiyun 	__u32	max_reasm_len;
533*4882a593Smuzhiyun 	__u32	tstamp;		/* ipv6InterfaceTable updated timestamp */
534*4882a593Smuzhiyun 	__u32	reachable_time;
535*4882a593Smuzhiyun 	__u32	retrans_time;
536*4882a593Smuzhiyun };
537*4882a593Smuzhiyun 
538*4882a593Smuzhiyun enum {
539*4882a593Smuzhiyun 	IFLA_INFO_UNSPEC,
540*4882a593Smuzhiyun 	IFLA_INFO_KIND,
541*4882a593Smuzhiyun 	IFLA_INFO_DATA,
542*4882a593Smuzhiyun 	IFLA_INFO_XSTATS,
543*4882a593Smuzhiyun 	IFLA_INFO_SLAVE_KIND,
544*4882a593Smuzhiyun 	IFLA_INFO_SLAVE_DATA,
545*4882a593Smuzhiyun 	__IFLA_INFO_MAX,
546*4882a593Smuzhiyun };
547*4882a593Smuzhiyun 
548*4882a593Smuzhiyun #define IFLA_INFO_MAX	(__IFLA_INFO_MAX - 1)
549*4882a593Smuzhiyun 
550*4882a593Smuzhiyun /* VLAN section */
551*4882a593Smuzhiyun 
552*4882a593Smuzhiyun enum {
553*4882a593Smuzhiyun 	IFLA_VLAN_UNSPEC,
554*4882a593Smuzhiyun 	IFLA_VLAN_ID,
555*4882a593Smuzhiyun 	IFLA_VLAN_FLAGS,
556*4882a593Smuzhiyun 	IFLA_VLAN_EGRESS_QOS,
557*4882a593Smuzhiyun 	IFLA_VLAN_INGRESS_QOS,
558*4882a593Smuzhiyun 	IFLA_VLAN_PROTOCOL,
559*4882a593Smuzhiyun 	__IFLA_VLAN_MAX,
560*4882a593Smuzhiyun };
561*4882a593Smuzhiyun 
562*4882a593Smuzhiyun #define IFLA_VLAN_MAX	(__IFLA_VLAN_MAX - 1)
563*4882a593Smuzhiyun 
564*4882a593Smuzhiyun struct ifla_vlan_flags {
565*4882a593Smuzhiyun 	__u32	flags;
566*4882a593Smuzhiyun 	__u32	mask;
567*4882a593Smuzhiyun };
568*4882a593Smuzhiyun 
569*4882a593Smuzhiyun enum {
570*4882a593Smuzhiyun 	IFLA_VLAN_QOS_UNSPEC,
571*4882a593Smuzhiyun 	IFLA_VLAN_QOS_MAPPING,
572*4882a593Smuzhiyun 	__IFLA_VLAN_QOS_MAX
573*4882a593Smuzhiyun };
574*4882a593Smuzhiyun 
575*4882a593Smuzhiyun #define IFLA_VLAN_QOS_MAX	(__IFLA_VLAN_QOS_MAX - 1)
576*4882a593Smuzhiyun 
577*4882a593Smuzhiyun struct ifla_vlan_qos_mapping {
578*4882a593Smuzhiyun 	__u32 from;
579*4882a593Smuzhiyun 	__u32 to;
580*4882a593Smuzhiyun };
581*4882a593Smuzhiyun 
582*4882a593Smuzhiyun /* MACVLAN section */
583*4882a593Smuzhiyun enum {
584*4882a593Smuzhiyun 	IFLA_MACVLAN_UNSPEC,
585*4882a593Smuzhiyun 	IFLA_MACVLAN_MODE,
586*4882a593Smuzhiyun 	IFLA_MACVLAN_FLAGS,
587*4882a593Smuzhiyun 	IFLA_MACVLAN_MACADDR_MODE,
588*4882a593Smuzhiyun 	IFLA_MACVLAN_MACADDR,
589*4882a593Smuzhiyun 	IFLA_MACVLAN_MACADDR_DATA,
590*4882a593Smuzhiyun 	IFLA_MACVLAN_MACADDR_COUNT,
591*4882a593Smuzhiyun 	__IFLA_MACVLAN_MAX,
592*4882a593Smuzhiyun };
593*4882a593Smuzhiyun 
594*4882a593Smuzhiyun #define IFLA_MACVLAN_MAX (__IFLA_MACVLAN_MAX - 1)
595*4882a593Smuzhiyun 
596*4882a593Smuzhiyun enum macvlan_mode {
597*4882a593Smuzhiyun 	MACVLAN_MODE_PRIVATE = 1, /* don't talk to other macvlans */
598*4882a593Smuzhiyun 	MACVLAN_MODE_VEPA    = 2, /* talk to other ports through ext bridge */
599*4882a593Smuzhiyun 	MACVLAN_MODE_BRIDGE  = 4, /* talk to bridge ports directly */
600*4882a593Smuzhiyun 	MACVLAN_MODE_PASSTHRU = 8,/* take over the underlying device */
601*4882a593Smuzhiyun 	MACVLAN_MODE_SOURCE  = 16,/* use source MAC address list to assign */
602*4882a593Smuzhiyun };
603*4882a593Smuzhiyun 
604*4882a593Smuzhiyun enum macvlan_macaddr_mode {
605*4882a593Smuzhiyun 	MACVLAN_MACADDR_ADD,
606*4882a593Smuzhiyun 	MACVLAN_MACADDR_DEL,
607*4882a593Smuzhiyun 	MACVLAN_MACADDR_FLUSH,
608*4882a593Smuzhiyun 	MACVLAN_MACADDR_SET,
609*4882a593Smuzhiyun };
610*4882a593Smuzhiyun 
611*4882a593Smuzhiyun #define MACVLAN_FLAG_NOPROMISC	1
612*4882a593Smuzhiyun 
613*4882a593Smuzhiyun /* VRF section */
614*4882a593Smuzhiyun enum {
615*4882a593Smuzhiyun 	IFLA_VRF_UNSPEC,
616*4882a593Smuzhiyun 	IFLA_VRF_TABLE,
617*4882a593Smuzhiyun 	__IFLA_VRF_MAX
618*4882a593Smuzhiyun };
619*4882a593Smuzhiyun 
620*4882a593Smuzhiyun #define IFLA_VRF_MAX (__IFLA_VRF_MAX - 1)
621*4882a593Smuzhiyun 
622*4882a593Smuzhiyun enum {
623*4882a593Smuzhiyun 	IFLA_VRF_PORT_UNSPEC,
624*4882a593Smuzhiyun 	IFLA_VRF_PORT_TABLE,
625*4882a593Smuzhiyun 	__IFLA_VRF_PORT_MAX
626*4882a593Smuzhiyun };
627*4882a593Smuzhiyun 
628*4882a593Smuzhiyun #define IFLA_VRF_PORT_MAX (__IFLA_VRF_PORT_MAX - 1)
629*4882a593Smuzhiyun 
630*4882a593Smuzhiyun /* MACSEC section */
631*4882a593Smuzhiyun enum {
632*4882a593Smuzhiyun 	IFLA_MACSEC_UNSPEC,
633*4882a593Smuzhiyun 	IFLA_MACSEC_SCI,
634*4882a593Smuzhiyun 	IFLA_MACSEC_PORT,
635*4882a593Smuzhiyun 	IFLA_MACSEC_ICV_LEN,
636*4882a593Smuzhiyun 	IFLA_MACSEC_CIPHER_SUITE,
637*4882a593Smuzhiyun 	IFLA_MACSEC_WINDOW,
638*4882a593Smuzhiyun 	IFLA_MACSEC_ENCODING_SA,
639*4882a593Smuzhiyun 	IFLA_MACSEC_ENCRYPT,
640*4882a593Smuzhiyun 	IFLA_MACSEC_PROTECT,
641*4882a593Smuzhiyun 	IFLA_MACSEC_INC_SCI,
642*4882a593Smuzhiyun 	IFLA_MACSEC_ES,
643*4882a593Smuzhiyun 	IFLA_MACSEC_SCB,
644*4882a593Smuzhiyun 	IFLA_MACSEC_REPLAY_PROTECT,
645*4882a593Smuzhiyun 	IFLA_MACSEC_VALIDATION,
646*4882a593Smuzhiyun 	IFLA_MACSEC_PAD,
647*4882a593Smuzhiyun 	IFLA_MACSEC_OFFLOAD,
648*4882a593Smuzhiyun 	__IFLA_MACSEC_MAX,
649*4882a593Smuzhiyun };
650*4882a593Smuzhiyun 
651*4882a593Smuzhiyun #define IFLA_MACSEC_MAX (__IFLA_MACSEC_MAX - 1)
652*4882a593Smuzhiyun 
653*4882a593Smuzhiyun /* XFRM section */
654*4882a593Smuzhiyun enum {
655*4882a593Smuzhiyun 	IFLA_XFRM_UNSPEC,
656*4882a593Smuzhiyun 	IFLA_XFRM_LINK,
657*4882a593Smuzhiyun 	IFLA_XFRM_IF_ID,
658*4882a593Smuzhiyun 	__IFLA_XFRM_MAX
659*4882a593Smuzhiyun };
660*4882a593Smuzhiyun 
661*4882a593Smuzhiyun #define IFLA_XFRM_MAX (__IFLA_XFRM_MAX - 1)
662*4882a593Smuzhiyun 
663*4882a593Smuzhiyun enum macsec_validation_type {
664*4882a593Smuzhiyun 	MACSEC_VALIDATE_DISABLED = 0,
665*4882a593Smuzhiyun 	MACSEC_VALIDATE_CHECK = 1,
666*4882a593Smuzhiyun 	MACSEC_VALIDATE_STRICT = 2,
667*4882a593Smuzhiyun 	__MACSEC_VALIDATE_END,
668*4882a593Smuzhiyun 	MACSEC_VALIDATE_MAX = __MACSEC_VALIDATE_END - 1,
669*4882a593Smuzhiyun };
670*4882a593Smuzhiyun 
671*4882a593Smuzhiyun enum macsec_offload {
672*4882a593Smuzhiyun 	MACSEC_OFFLOAD_OFF = 0,
673*4882a593Smuzhiyun 	MACSEC_OFFLOAD_PHY = 1,
674*4882a593Smuzhiyun 	MACSEC_OFFLOAD_MAC = 2,
675*4882a593Smuzhiyun 	__MACSEC_OFFLOAD_END,
676*4882a593Smuzhiyun 	MACSEC_OFFLOAD_MAX = __MACSEC_OFFLOAD_END - 1,
677*4882a593Smuzhiyun };
678*4882a593Smuzhiyun 
679*4882a593Smuzhiyun /* IPVLAN section */
680*4882a593Smuzhiyun enum {
681*4882a593Smuzhiyun 	IFLA_IPVLAN_UNSPEC,
682*4882a593Smuzhiyun 	IFLA_IPVLAN_MODE,
683*4882a593Smuzhiyun 	IFLA_IPVLAN_FLAGS,
684*4882a593Smuzhiyun 	__IFLA_IPVLAN_MAX
685*4882a593Smuzhiyun };
686*4882a593Smuzhiyun 
687*4882a593Smuzhiyun #define IFLA_IPVLAN_MAX (__IFLA_IPVLAN_MAX - 1)
688*4882a593Smuzhiyun 
689*4882a593Smuzhiyun enum ipvlan_mode {
690*4882a593Smuzhiyun 	IPVLAN_MODE_L2 = 0,
691*4882a593Smuzhiyun 	IPVLAN_MODE_L3,
692*4882a593Smuzhiyun 	IPVLAN_MODE_L3S,
693*4882a593Smuzhiyun 	IPVLAN_MODE_MAX
694*4882a593Smuzhiyun };
695*4882a593Smuzhiyun 
696*4882a593Smuzhiyun #define IPVLAN_F_PRIVATE	0x01
697*4882a593Smuzhiyun #define IPVLAN_F_VEPA		0x02
698*4882a593Smuzhiyun 
699*4882a593Smuzhiyun /* VXLAN section */
700*4882a593Smuzhiyun enum {
701*4882a593Smuzhiyun 	IFLA_VXLAN_UNSPEC,
702*4882a593Smuzhiyun 	IFLA_VXLAN_ID,
703*4882a593Smuzhiyun 	IFLA_VXLAN_GROUP,	/* group or remote address */
704*4882a593Smuzhiyun 	IFLA_VXLAN_LINK,
705*4882a593Smuzhiyun 	IFLA_VXLAN_LOCAL,
706*4882a593Smuzhiyun 	IFLA_VXLAN_TTL,
707*4882a593Smuzhiyun 	IFLA_VXLAN_TOS,
708*4882a593Smuzhiyun 	IFLA_VXLAN_LEARNING,
709*4882a593Smuzhiyun 	IFLA_VXLAN_AGEING,
710*4882a593Smuzhiyun 	IFLA_VXLAN_LIMIT,
711*4882a593Smuzhiyun 	IFLA_VXLAN_PORT_RANGE,	/* source port */
712*4882a593Smuzhiyun 	IFLA_VXLAN_PROXY,
713*4882a593Smuzhiyun 	IFLA_VXLAN_RSC,
714*4882a593Smuzhiyun 	IFLA_VXLAN_L2MISS,
715*4882a593Smuzhiyun 	IFLA_VXLAN_L3MISS,
716*4882a593Smuzhiyun 	IFLA_VXLAN_PORT,	/* destination port */
717*4882a593Smuzhiyun 	IFLA_VXLAN_GROUP6,
718*4882a593Smuzhiyun 	IFLA_VXLAN_LOCAL6,
719*4882a593Smuzhiyun 	IFLA_VXLAN_UDP_CSUM,
720*4882a593Smuzhiyun 	IFLA_VXLAN_UDP_ZERO_CSUM6_TX,
721*4882a593Smuzhiyun 	IFLA_VXLAN_UDP_ZERO_CSUM6_RX,
722*4882a593Smuzhiyun 	IFLA_VXLAN_REMCSUM_TX,
723*4882a593Smuzhiyun 	IFLA_VXLAN_REMCSUM_RX,
724*4882a593Smuzhiyun 	IFLA_VXLAN_GBP,
725*4882a593Smuzhiyun 	IFLA_VXLAN_REMCSUM_NOPARTIAL,
726*4882a593Smuzhiyun 	IFLA_VXLAN_COLLECT_METADATA,
727*4882a593Smuzhiyun 	IFLA_VXLAN_LABEL,
728*4882a593Smuzhiyun 	IFLA_VXLAN_GPE,
729*4882a593Smuzhiyun 	IFLA_VXLAN_TTL_INHERIT,
730*4882a593Smuzhiyun 	IFLA_VXLAN_DF,
731*4882a593Smuzhiyun 	__IFLA_VXLAN_MAX
732*4882a593Smuzhiyun };
733*4882a593Smuzhiyun #define IFLA_VXLAN_MAX	(__IFLA_VXLAN_MAX - 1)
734*4882a593Smuzhiyun 
735*4882a593Smuzhiyun struct ifla_vxlan_port_range {
736*4882a593Smuzhiyun 	__be16	low;
737*4882a593Smuzhiyun 	__be16	high;
738*4882a593Smuzhiyun };
739*4882a593Smuzhiyun 
740*4882a593Smuzhiyun enum ifla_vxlan_df {
741*4882a593Smuzhiyun 	VXLAN_DF_UNSET = 0,
742*4882a593Smuzhiyun 	VXLAN_DF_SET,
743*4882a593Smuzhiyun 	VXLAN_DF_INHERIT,
744*4882a593Smuzhiyun 	__VXLAN_DF_END,
745*4882a593Smuzhiyun 	VXLAN_DF_MAX = __VXLAN_DF_END - 1,
746*4882a593Smuzhiyun };
747*4882a593Smuzhiyun 
748*4882a593Smuzhiyun /* GENEVE section */
749*4882a593Smuzhiyun enum {
750*4882a593Smuzhiyun 	IFLA_GENEVE_UNSPEC,
751*4882a593Smuzhiyun 	IFLA_GENEVE_ID,
752*4882a593Smuzhiyun 	IFLA_GENEVE_REMOTE,
753*4882a593Smuzhiyun 	IFLA_GENEVE_TTL,
754*4882a593Smuzhiyun 	IFLA_GENEVE_TOS,
755*4882a593Smuzhiyun 	IFLA_GENEVE_PORT,	/* destination port */
756*4882a593Smuzhiyun 	IFLA_GENEVE_COLLECT_METADATA,
757*4882a593Smuzhiyun 	IFLA_GENEVE_REMOTE6,
758*4882a593Smuzhiyun 	IFLA_GENEVE_UDP_CSUM,
759*4882a593Smuzhiyun 	IFLA_GENEVE_UDP_ZERO_CSUM6_TX,
760*4882a593Smuzhiyun 	IFLA_GENEVE_UDP_ZERO_CSUM6_RX,
761*4882a593Smuzhiyun 	IFLA_GENEVE_LABEL,
762*4882a593Smuzhiyun 	IFLA_GENEVE_TTL_INHERIT,
763*4882a593Smuzhiyun 	IFLA_GENEVE_DF,
764*4882a593Smuzhiyun 	__IFLA_GENEVE_MAX
765*4882a593Smuzhiyun };
766*4882a593Smuzhiyun #define IFLA_GENEVE_MAX	(__IFLA_GENEVE_MAX - 1)
767*4882a593Smuzhiyun 
768*4882a593Smuzhiyun enum ifla_geneve_df {
769*4882a593Smuzhiyun 	GENEVE_DF_UNSET = 0,
770*4882a593Smuzhiyun 	GENEVE_DF_SET,
771*4882a593Smuzhiyun 	GENEVE_DF_INHERIT,
772*4882a593Smuzhiyun 	__GENEVE_DF_END,
773*4882a593Smuzhiyun 	GENEVE_DF_MAX = __GENEVE_DF_END - 1,
774*4882a593Smuzhiyun };
775*4882a593Smuzhiyun 
776*4882a593Smuzhiyun /* Bareudp section  */
777*4882a593Smuzhiyun enum {
778*4882a593Smuzhiyun 	IFLA_BAREUDP_UNSPEC,
779*4882a593Smuzhiyun 	IFLA_BAREUDP_PORT,
780*4882a593Smuzhiyun 	IFLA_BAREUDP_ETHERTYPE,
781*4882a593Smuzhiyun 	IFLA_BAREUDP_SRCPORT_MIN,
782*4882a593Smuzhiyun 	IFLA_BAREUDP_MULTIPROTO_MODE,
783*4882a593Smuzhiyun 	__IFLA_BAREUDP_MAX
784*4882a593Smuzhiyun };
785*4882a593Smuzhiyun 
786*4882a593Smuzhiyun #define IFLA_BAREUDP_MAX (__IFLA_BAREUDP_MAX - 1)
787*4882a593Smuzhiyun 
788*4882a593Smuzhiyun /* PPP section */
789*4882a593Smuzhiyun enum {
790*4882a593Smuzhiyun 	IFLA_PPP_UNSPEC,
791*4882a593Smuzhiyun 	IFLA_PPP_DEV_FD,
792*4882a593Smuzhiyun 	__IFLA_PPP_MAX
793*4882a593Smuzhiyun };
794*4882a593Smuzhiyun #define IFLA_PPP_MAX (__IFLA_PPP_MAX - 1)
795*4882a593Smuzhiyun 
796*4882a593Smuzhiyun /* GTP section */
797*4882a593Smuzhiyun 
798*4882a593Smuzhiyun enum ifla_gtp_role {
799*4882a593Smuzhiyun 	GTP_ROLE_GGSN = 0,
800*4882a593Smuzhiyun 	GTP_ROLE_SGSN,
801*4882a593Smuzhiyun };
802*4882a593Smuzhiyun 
803*4882a593Smuzhiyun enum {
804*4882a593Smuzhiyun 	IFLA_GTP_UNSPEC,
805*4882a593Smuzhiyun 	IFLA_GTP_FD0,
806*4882a593Smuzhiyun 	IFLA_GTP_FD1,
807*4882a593Smuzhiyun 	IFLA_GTP_PDP_HASHSIZE,
808*4882a593Smuzhiyun 	IFLA_GTP_ROLE,
809*4882a593Smuzhiyun 	__IFLA_GTP_MAX,
810*4882a593Smuzhiyun };
811*4882a593Smuzhiyun #define IFLA_GTP_MAX (__IFLA_GTP_MAX - 1)
812*4882a593Smuzhiyun 
813*4882a593Smuzhiyun /* Bonding section */
814*4882a593Smuzhiyun 
815*4882a593Smuzhiyun enum {
816*4882a593Smuzhiyun 	IFLA_BOND_UNSPEC,
817*4882a593Smuzhiyun 	IFLA_BOND_MODE,
818*4882a593Smuzhiyun 	IFLA_BOND_ACTIVE_SLAVE,
819*4882a593Smuzhiyun 	IFLA_BOND_MIIMON,
820*4882a593Smuzhiyun 	IFLA_BOND_UPDELAY,
821*4882a593Smuzhiyun 	IFLA_BOND_DOWNDELAY,
822*4882a593Smuzhiyun 	IFLA_BOND_USE_CARRIER,
823*4882a593Smuzhiyun 	IFLA_BOND_ARP_INTERVAL,
824*4882a593Smuzhiyun 	IFLA_BOND_ARP_IP_TARGET,
825*4882a593Smuzhiyun 	IFLA_BOND_ARP_VALIDATE,
826*4882a593Smuzhiyun 	IFLA_BOND_ARP_ALL_TARGETS,
827*4882a593Smuzhiyun 	IFLA_BOND_PRIMARY,
828*4882a593Smuzhiyun 	IFLA_BOND_PRIMARY_RESELECT,
829*4882a593Smuzhiyun 	IFLA_BOND_FAIL_OVER_MAC,
830*4882a593Smuzhiyun 	IFLA_BOND_XMIT_HASH_POLICY,
831*4882a593Smuzhiyun 	IFLA_BOND_RESEND_IGMP,
832*4882a593Smuzhiyun 	IFLA_BOND_NUM_PEER_NOTIF,
833*4882a593Smuzhiyun 	IFLA_BOND_ALL_SLAVES_ACTIVE,
834*4882a593Smuzhiyun 	IFLA_BOND_MIN_LINKS,
835*4882a593Smuzhiyun 	IFLA_BOND_LP_INTERVAL,
836*4882a593Smuzhiyun 	IFLA_BOND_PACKETS_PER_SLAVE,
837*4882a593Smuzhiyun 	IFLA_BOND_AD_LACP_RATE,
838*4882a593Smuzhiyun 	IFLA_BOND_AD_SELECT,
839*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO,
840*4882a593Smuzhiyun 	IFLA_BOND_AD_ACTOR_SYS_PRIO,
841*4882a593Smuzhiyun 	IFLA_BOND_AD_USER_PORT_KEY,
842*4882a593Smuzhiyun 	IFLA_BOND_AD_ACTOR_SYSTEM,
843*4882a593Smuzhiyun 	IFLA_BOND_TLB_DYNAMIC_LB,
844*4882a593Smuzhiyun 	IFLA_BOND_PEER_NOTIF_DELAY,
845*4882a593Smuzhiyun 	__IFLA_BOND_MAX,
846*4882a593Smuzhiyun };
847*4882a593Smuzhiyun 
848*4882a593Smuzhiyun #define IFLA_BOND_MAX	(__IFLA_BOND_MAX - 1)
849*4882a593Smuzhiyun 
850*4882a593Smuzhiyun enum {
851*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO_UNSPEC,
852*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO_AGGREGATOR,
853*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO_NUM_PORTS,
854*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO_ACTOR_KEY,
855*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO_PARTNER_KEY,
856*4882a593Smuzhiyun 	IFLA_BOND_AD_INFO_PARTNER_MAC,
857*4882a593Smuzhiyun 	__IFLA_BOND_AD_INFO_MAX,
858*4882a593Smuzhiyun };
859*4882a593Smuzhiyun 
860*4882a593Smuzhiyun #define IFLA_BOND_AD_INFO_MAX	(__IFLA_BOND_AD_INFO_MAX - 1)
861*4882a593Smuzhiyun 
862*4882a593Smuzhiyun enum {
863*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_UNSPEC,
864*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_STATE,
865*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_MII_STATUS,
866*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_LINK_FAILURE_COUNT,
867*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_PERM_HWADDR,
868*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_QUEUE_ID,
869*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_AD_AGGREGATOR_ID,
870*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_AD_ACTOR_OPER_PORT_STATE,
871*4882a593Smuzhiyun 	IFLA_BOND_SLAVE_AD_PARTNER_OPER_PORT_STATE,
872*4882a593Smuzhiyun 	__IFLA_BOND_SLAVE_MAX,
873*4882a593Smuzhiyun };
874*4882a593Smuzhiyun 
875*4882a593Smuzhiyun #define IFLA_BOND_SLAVE_MAX	(__IFLA_BOND_SLAVE_MAX - 1)
876*4882a593Smuzhiyun 
877*4882a593Smuzhiyun /* SR-IOV virtual function management section */
878*4882a593Smuzhiyun 
879*4882a593Smuzhiyun enum {
880*4882a593Smuzhiyun 	IFLA_VF_INFO_UNSPEC,
881*4882a593Smuzhiyun 	IFLA_VF_INFO,
882*4882a593Smuzhiyun 	__IFLA_VF_INFO_MAX,
883*4882a593Smuzhiyun };
884*4882a593Smuzhiyun 
885*4882a593Smuzhiyun #define IFLA_VF_INFO_MAX (__IFLA_VF_INFO_MAX - 1)
886*4882a593Smuzhiyun 
887*4882a593Smuzhiyun enum {
888*4882a593Smuzhiyun 	IFLA_VF_UNSPEC,
889*4882a593Smuzhiyun 	IFLA_VF_MAC,		/* Hardware queue specific attributes */
890*4882a593Smuzhiyun 	IFLA_VF_VLAN,		/* VLAN ID and QoS */
891*4882a593Smuzhiyun 	IFLA_VF_TX_RATE,	/* Max TX Bandwidth Allocation */
892*4882a593Smuzhiyun 	IFLA_VF_SPOOFCHK,	/* Spoof Checking on/off switch */
893*4882a593Smuzhiyun 	IFLA_VF_LINK_STATE,	/* link state enable/disable/auto switch */
894*4882a593Smuzhiyun 	IFLA_VF_RATE,		/* Min and Max TX Bandwidth Allocation */
895*4882a593Smuzhiyun 	IFLA_VF_RSS_QUERY_EN,	/* RSS Redirection Table and Hash Key query
896*4882a593Smuzhiyun 				 * on/off switch
897*4882a593Smuzhiyun 				 */
898*4882a593Smuzhiyun 	IFLA_VF_STATS,		/* network device statistics */
899*4882a593Smuzhiyun 	IFLA_VF_TRUST,		/* Trust VF */
900*4882a593Smuzhiyun 	IFLA_VF_IB_NODE_GUID,	/* VF Infiniband node GUID */
901*4882a593Smuzhiyun 	IFLA_VF_IB_PORT_GUID,	/* VF Infiniband port GUID */
902*4882a593Smuzhiyun 	IFLA_VF_VLAN_LIST,	/* nested list of vlans, option for QinQ */
903*4882a593Smuzhiyun 	IFLA_VF_BROADCAST,	/* VF broadcast */
904*4882a593Smuzhiyun 	__IFLA_VF_MAX,
905*4882a593Smuzhiyun };
906*4882a593Smuzhiyun 
907*4882a593Smuzhiyun #define IFLA_VF_MAX (__IFLA_VF_MAX - 1)
908*4882a593Smuzhiyun 
909*4882a593Smuzhiyun struct ifla_vf_mac {
910*4882a593Smuzhiyun 	__u32 vf;
911*4882a593Smuzhiyun 	__u8 mac[32]; /* MAX_ADDR_LEN */
912*4882a593Smuzhiyun };
913*4882a593Smuzhiyun 
914*4882a593Smuzhiyun struct ifla_vf_broadcast {
915*4882a593Smuzhiyun 	__u8 broadcast[32];
916*4882a593Smuzhiyun };
917*4882a593Smuzhiyun 
918*4882a593Smuzhiyun struct ifla_vf_vlan {
919*4882a593Smuzhiyun 	__u32 vf;
920*4882a593Smuzhiyun 	__u32 vlan; /* 0 - 4095, 0 disables VLAN filter */
921*4882a593Smuzhiyun 	__u32 qos;
922*4882a593Smuzhiyun };
923*4882a593Smuzhiyun 
924*4882a593Smuzhiyun enum {
925*4882a593Smuzhiyun 	IFLA_VF_VLAN_INFO_UNSPEC,
926*4882a593Smuzhiyun 	IFLA_VF_VLAN_INFO,	/* VLAN ID, QoS and VLAN protocol */
927*4882a593Smuzhiyun 	__IFLA_VF_VLAN_INFO_MAX,
928*4882a593Smuzhiyun };
929*4882a593Smuzhiyun 
930*4882a593Smuzhiyun #define IFLA_VF_VLAN_INFO_MAX (__IFLA_VF_VLAN_INFO_MAX - 1)
931*4882a593Smuzhiyun #define MAX_VLAN_LIST_LEN 1
932*4882a593Smuzhiyun 
933*4882a593Smuzhiyun struct ifla_vf_vlan_info {
934*4882a593Smuzhiyun 	__u32 vf;
935*4882a593Smuzhiyun 	__u32 vlan; /* 0 - 4095, 0 disables VLAN filter */
936*4882a593Smuzhiyun 	__u32 qos;
937*4882a593Smuzhiyun 	__be16 vlan_proto; /* VLAN protocol either 802.1Q or 802.1ad */
938*4882a593Smuzhiyun };
939*4882a593Smuzhiyun 
940*4882a593Smuzhiyun struct ifla_vf_tx_rate {
941*4882a593Smuzhiyun 	__u32 vf;
942*4882a593Smuzhiyun 	__u32 rate; /* Max TX bandwidth in Mbps, 0 disables throttling */
943*4882a593Smuzhiyun };
944*4882a593Smuzhiyun 
945*4882a593Smuzhiyun struct ifla_vf_rate {
946*4882a593Smuzhiyun 	__u32 vf;
947*4882a593Smuzhiyun 	__u32 min_tx_rate; /* Min Bandwidth in Mbps */
948*4882a593Smuzhiyun 	__u32 max_tx_rate; /* Max Bandwidth in Mbps */
949*4882a593Smuzhiyun };
950*4882a593Smuzhiyun 
951*4882a593Smuzhiyun struct ifla_vf_spoofchk {
952*4882a593Smuzhiyun 	__u32 vf;
953*4882a593Smuzhiyun 	__u32 setting;
954*4882a593Smuzhiyun };
955*4882a593Smuzhiyun 
956*4882a593Smuzhiyun struct ifla_vf_guid {
957*4882a593Smuzhiyun 	__u32 vf;
958*4882a593Smuzhiyun 	__u64 guid;
959*4882a593Smuzhiyun };
960*4882a593Smuzhiyun 
961*4882a593Smuzhiyun enum {
962*4882a593Smuzhiyun 	IFLA_VF_LINK_STATE_AUTO,	/* link state of the uplink */
963*4882a593Smuzhiyun 	IFLA_VF_LINK_STATE_ENABLE,	/* link always up */
964*4882a593Smuzhiyun 	IFLA_VF_LINK_STATE_DISABLE,	/* link always down */
965*4882a593Smuzhiyun 	__IFLA_VF_LINK_STATE_MAX,
966*4882a593Smuzhiyun };
967*4882a593Smuzhiyun 
968*4882a593Smuzhiyun struct ifla_vf_link_state {
969*4882a593Smuzhiyun 	__u32 vf;
970*4882a593Smuzhiyun 	__u32 link_state;
971*4882a593Smuzhiyun };
972*4882a593Smuzhiyun 
973*4882a593Smuzhiyun struct ifla_vf_rss_query_en {
974*4882a593Smuzhiyun 	__u32 vf;
975*4882a593Smuzhiyun 	__u32 setting;
976*4882a593Smuzhiyun };
977*4882a593Smuzhiyun 
978*4882a593Smuzhiyun enum {
979*4882a593Smuzhiyun 	IFLA_VF_STATS_RX_PACKETS,
980*4882a593Smuzhiyun 	IFLA_VF_STATS_TX_PACKETS,
981*4882a593Smuzhiyun 	IFLA_VF_STATS_RX_BYTES,
982*4882a593Smuzhiyun 	IFLA_VF_STATS_TX_BYTES,
983*4882a593Smuzhiyun 	IFLA_VF_STATS_BROADCAST,
984*4882a593Smuzhiyun 	IFLA_VF_STATS_MULTICAST,
985*4882a593Smuzhiyun 	IFLA_VF_STATS_PAD,
986*4882a593Smuzhiyun 	IFLA_VF_STATS_RX_DROPPED,
987*4882a593Smuzhiyun 	IFLA_VF_STATS_TX_DROPPED,
988*4882a593Smuzhiyun 	__IFLA_VF_STATS_MAX,
989*4882a593Smuzhiyun };
990*4882a593Smuzhiyun 
991*4882a593Smuzhiyun #define IFLA_VF_STATS_MAX (__IFLA_VF_STATS_MAX - 1)
992*4882a593Smuzhiyun 
993*4882a593Smuzhiyun struct ifla_vf_trust {
994*4882a593Smuzhiyun 	__u32 vf;
995*4882a593Smuzhiyun 	__u32 setting;
996*4882a593Smuzhiyun };
997*4882a593Smuzhiyun 
998*4882a593Smuzhiyun /* VF ports management section
999*4882a593Smuzhiyun  *
1000*4882a593Smuzhiyun  *	Nested layout of set/get msg is:
1001*4882a593Smuzhiyun  *
1002*4882a593Smuzhiyun  *		[IFLA_NUM_VF]
1003*4882a593Smuzhiyun  *		[IFLA_VF_PORTS]
1004*4882a593Smuzhiyun  *			[IFLA_VF_PORT]
1005*4882a593Smuzhiyun  *				[IFLA_PORT_*], ...
1006*4882a593Smuzhiyun  *			[IFLA_VF_PORT]
1007*4882a593Smuzhiyun  *				[IFLA_PORT_*], ...
1008*4882a593Smuzhiyun  *			...
1009*4882a593Smuzhiyun  *		[IFLA_PORT_SELF]
1010*4882a593Smuzhiyun  *			[IFLA_PORT_*], ...
1011*4882a593Smuzhiyun  */
1012*4882a593Smuzhiyun 
1013*4882a593Smuzhiyun enum {
1014*4882a593Smuzhiyun 	IFLA_VF_PORT_UNSPEC,
1015*4882a593Smuzhiyun 	IFLA_VF_PORT,			/* nest */
1016*4882a593Smuzhiyun 	__IFLA_VF_PORT_MAX,
1017*4882a593Smuzhiyun };
1018*4882a593Smuzhiyun 
1019*4882a593Smuzhiyun #define IFLA_VF_PORT_MAX (__IFLA_VF_PORT_MAX - 1)
1020*4882a593Smuzhiyun 
1021*4882a593Smuzhiyun enum {
1022*4882a593Smuzhiyun 	IFLA_PORT_UNSPEC,
1023*4882a593Smuzhiyun 	IFLA_PORT_VF,			/* __u32 */
1024*4882a593Smuzhiyun 	IFLA_PORT_PROFILE,		/* string */
1025*4882a593Smuzhiyun 	IFLA_PORT_VSI_TYPE,		/* 802.1Qbg (pre-)standard VDP */
1026*4882a593Smuzhiyun 	IFLA_PORT_INSTANCE_UUID,	/* binary UUID */
1027*4882a593Smuzhiyun 	IFLA_PORT_HOST_UUID,		/* binary UUID */
1028*4882a593Smuzhiyun 	IFLA_PORT_REQUEST,		/* __u8 */
1029*4882a593Smuzhiyun 	IFLA_PORT_RESPONSE,		/* __u16, output only */
1030*4882a593Smuzhiyun 	__IFLA_PORT_MAX,
1031*4882a593Smuzhiyun };
1032*4882a593Smuzhiyun 
1033*4882a593Smuzhiyun #define IFLA_PORT_MAX (__IFLA_PORT_MAX - 1)
1034*4882a593Smuzhiyun 
1035*4882a593Smuzhiyun #define PORT_PROFILE_MAX	40
1036*4882a593Smuzhiyun #define PORT_UUID_MAX		16
1037*4882a593Smuzhiyun #define PORT_SELF_VF		-1
1038*4882a593Smuzhiyun 
1039*4882a593Smuzhiyun enum {
1040*4882a593Smuzhiyun 	PORT_REQUEST_PREASSOCIATE = 0,
1041*4882a593Smuzhiyun 	PORT_REQUEST_PREASSOCIATE_RR,
1042*4882a593Smuzhiyun 	PORT_REQUEST_ASSOCIATE,
1043*4882a593Smuzhiyun 	PORT_REQUEST_DISASSOCIATE,
1044*4882a593Smuzhiyun };
1045*4882a593Smuzhiyun 
1046*4882a593Smuzhiyun enum {
1047*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_SUCCESS = 0,
1048*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_INVALID_FORMAT,
1049*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_INSUFFICIENT_RESOURCES,
1050*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_UNUSED_VTID,
1051*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_VTID_VIOLATION,
1052*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_VTID_VERSION_VIOALTION,
1053*4882a593Smuzhiyun 	PORT_VDP_RESPONSE_OUT_OF_SYNC,
1054*4882a593Smuzhiyun 	/* 0x08-0xFF reserved for future VDP use */
1055*4882a593Smuzhiyun 	PORT_PROFILE_RESPONSE_SUCCESS = 0x100,
1056*4882a593Smuzhiyun 	PORT_PROFILE_RESPONSE_INPROGRESS,
1057*4882a593Smuzhiyun 	PORT_PROFILE_RESPONSE_INVALID,
1058*4882a593Smuzhiyun 	PORT_PROFILE_RESPONSE_BADSTATE,
1059*4882a593Smuzhiyun 	PORT_PROFILE_RESPONSE_INSUFFICIENT_RESOURCES,
1060*4882a593Smuzhiyun 	PORT_PROFILE_RESPONSE_ERROR,
1061*4882a593Smuzhiyun };
1062*4882a593Smuzhiyun 
1063*4882a593Smuzhiyun struct ifla_port_vsi {
1064*4882a593Smuzhiyun 	__u8 vsi_mgr_id;
1065*4882a593Smuzhiyun 	__u8 vsi_type_id[3];
1066*4882a593Smuzhiyun 	__u8 vsi_type_version;
1067*4882a593Smuzhiyun 	__u8 pad[3];
1068*4882a593Smuzhiyun };
1069*4882a593Smuzhiyun 
1070*4882a593Smuzhiyun 
1071*4882a593Smuzhiyun /* IPoIB section */
1072*4882a593Smuzhiyun 
1073*4882a593Smuzhiyun enum {
1074*4882a593Smuzhiyun 	IFLA_IPOIB_UNSPEC,
1075*4882a593Smuzhiyun 	IFLA_IPOIB_PKEY,
1076*4882a593Smuzhiyun 	IFLA_IPOIB_MODE,
1077*4882a593Smuzhiyun 	IFLA_IPOIB_UMCAST,
1078*4882a593Smuzhiyun 	__IFLA_IPOIB_MAX
1079*4882a593Smuzhiyun };
1080*4882a593Smuzhiyun 
1081*4882a593Smuzhiyun enum {
1082*4882a593Smuzhiyun 	IPOIB_MODE_DATAGRAM  = 0, /* using unreliable datagram QPs */
1083*4882a593Smuzhiyun 	IPOIB_MODE_CONNECTED = 1, /* using connected QPs */
1084*4882a593Smuzhiyun };
1085*4882a593Smuzhiyun 
1086*4882a593Smuzhiyun #define IFLA_IPOIB_MAX (__IFLA_IPOIB_MAX - 1)
1087*4882a593Smuzhiyun 
1088*4882a593Smuzhiyun 
1089*4882a593Smuzhiyun /* HSR/PRP section, both uses same interface */
1090*4882a593Smuzhiyun 
1091*4882a593Smuzhiyun /* Different redundancy protocols for hsr device */
1092*4882a593Smuzhiyun enum {
1093*4882a593Smuzhiyun 	HSR_PROTOCOL_HSR,
1094*4882a593Smuzhiyun 	HSR_PROTOCOL_PRP,
1095*4882a593Smuzhiyun 	HSR_PROTOCOL_MAX,
1096*4882a593Smuzhiyun };
1097*4882a593Smuzhiyun 
1098*4882a593Smuzhiyun enum {
1099*4882a593Smuzhiyun 	IFLA_HSR_UNSPEC,
1100*4882a593Smuzhiyun 	IFLA_HSR_SLAVE1,
1101*4882a593Smuzhiyun 	IFLA_HSR_SLAVE2,
1102*4882a593Smuzhiyun 	IFLA_HSR_MULTICAST_SPEC,	/* Last byte of supervision addr */
1103*4882a593Smuzhiyun 	IFLA_HSR_SUPERVISION_ADDR,	/* Supervision frame multicast addr */
1104*4882a593Smuzhiyun 	IFLA_HSR_SEQ_NR,
1105*4882a593Smuzhiyun 	IFLA_HSR_VERSION,		/* HSR version */
1106*4882a593Smuzhiyun 	IFLA_HSR_PROTOCOL,		/* Indicate different protocol than
1107*4882a593Smuzhiyun 					 * HSR. For example PRP.
1108*4882a593Smuzhiyun 					 */
1109*4882a593Smuzhiyun 	__IFLA_HSR_MAX,
1110*4882a593Smuzhiyun };
1111*4882a593Smuzhiyun 
1112*4882a593Smuzhiyun #define IFLA_HSR_MAX (__IFLA_HSR_MAX - 1)
1113*4882a593Smuzhiyun 
1114*4882a593Smuzhiyun /* STATS section */
1115*4882a593Smuzhiyun 
1116*4882a593Smuzhiyun struct if_stats_msg {
1117*4882a593Smuzhiyun 	__u8  family;
1118*4882a593Smuzhiyun 	__u8  pad1;
1119*4882a593Smuzhiyun 	__u16 pad2;
1120*4882a593Smuzhiyun 	__u32 ifindex;
1121*4882a593Smuzhiyun 	__u32 filter_mask;
1122*4882a593Smuzhiyun };
1123*4882a593Smuzhiyun 
1124*4882a593Smuzhiyun /* A stats attribute can be netdev specific or a global stat.
1125*4882a593Smuzhiyun  * For netdev stats, lets use the prefix IFLA_STATS_LINK_*
1126*4882a593Smuzhiyun  */
1127*4882a593Smuzhiyun enum {
1128*4882a593Smuzhiyun 	IFLA_STATS_UNSPEC, /* also used as 64bit pad attribute */
1129*4882a593Smuzhiyun 	IFLA_STATS_LINK_64,
1130*4882a593Smuzhiyun 	IFLA_STATS_LINK_XSTATS,
1131*4882a593Smuzhiyun 	IFLA_STATS_LINK_XSTATS_SLAVE,
1132*4882a593Smuzhiyun 	IFLA_STATS_LINK_OFFLOAD_XSTATS,
1133*4882a593Smuzhiyun 	IFLA_STATS_AF_SPEC,
1134*4882a593Smuzhiyun 	__IFLA_STATS_MAX,
1135*4882a593Smuzhiyun };
1136*4882a593Smuzhiyun 
1137*4882a593Smuzhiyun #define IFLA_STATS_MAX (__IFLA_STATS_MAX - 1)
1138*4882a593Smuzhiyun 
1139*4882a593Smuzhiyun #define IFLA_STATS_FILTER_BIT(ATTR)	(1 << (ATTR - 1))
1140*4882a593Smuzhiyun 
1141*4882a593Smuzhiyun /* These are embedded into IFLA_STATS_LINK_XSTATS:
1142*4882a593Smuzhiyun  * [IFLA_STATS_LINK_XSTATS]
1143*4882a593Smuzhiyun  * -> [LINK_XSTATS_TYPE_xxx]
1144*4882a593Smuzhiyun  *    -> [rtnl link type specific attributes]
1145*4882a593Smuzhiyun  */
1146*4882a593Smuzhiyun enum {
1147*4882a593Smuzhiyun 	LINK_XSTATS_TYPE_UNSPEC,
1148*4882a593Smuzhiyun 	LINK_XSTATS_TYPE_BRIDGE,
1149*4882a593Smuzhiyun 	LINK_XSTATS_TYPE_BOND,
1150*4882a593Smuzhiyun 	__LINK_XSTATS_TYPE_MAX
1151*4882a593Smuzhiyun };
1152*4882a593Smuzhiyun #define LINK_XSTATS_TYPE_MAX (__LINK_XSTATS_TYPE_MAX - 1)
1153*4882a593Smuzhiyun 
1154*4882a593Smuzhiyun /* These are stats embedded into IFLA_STATS_LINK_OFFLOAD_XSTATS */
1155*4882a593Smuzhiyun enum {
1156*4882a593Smuzhiyun 	IFLA_OFFLOAD_XSTATS_UNSPEC,
1157*4882a593Smuzhiyun 	IFLA_OFFLOAD_XSTATS_CPU_HIT, /* struct rtnl_link_stats64 */
1158*4882a593Smuzhiyun 	__IFLA_OFFLOAD_XSTATS_MAX
1159*4882a593Smuzhiyun };
1160*4882a593Smuzhiyun #define IFLA_OFFLOAD_XSTATS_MAX (__IFLA_OFFLOAD_XSTATS_MAX - 1)
1161*4882a593Smuzhiyun 
1162*4882a593Smuzhiyun /* XDP section */
1163*4882a593Smuzhiyun 
1164*4882a593Smuzhiyun #define XDP_FLAGS_UPDATE_IF_NOEXIST	(1U << 0)
1165*4882a593Smuzhiyun #define XDP_FLAGS_SKB_MODE		(1U << 1)
1166*4882a593Smuzhiyun #define XDP_FLAGS_DRV_MODE		(1U << 2)
1167*4882a593Smuzhiyun #define XDP_FLAGS_HW_MODE		(1U << 3)
1168*4882a593Smuzhiyun #define XDP_FLAGS_REPLACE		(1U << 4)
1169*4882a593Smuzhiyun #define XDP_FLAGS_MODES			(XDP_FLAGS_SKB_MODE | \
1170*4882a593Smuzhiyun 					 XDP_FLAGS_DRV_MODE | \
1171*4882a593Smuzhiyun 					 XDP_FLAGS_HW_MODE)
1172*4882a593Smuzhiyun #define XDP_FLAGS_MASK			(XDP_FLAGS_UPDATE_IF_NOEXIST | \
1173*4882a593Smuzhiyun 					 XDP_FLAGS_MODES | XDP_FLAGS_REPLACE)
1174*4882a593Smuzhiyun 
1175*4882a593Smuzhiyun /* These are stored into IFLA_XDP_ATTACHED on dump. */
1176*4882a593Smuzhiyun enum {
1177*4882a593Smuzhiyun 	XDP_ATTACHED_NONE = 0,
1178*4882a593Smuzhiyun 	XDP_ATTACHED_DRV,
1179*4882a593Smuzhiyun 	XDP_ATTACHED_SKB,
1180*4882a593Smuzhiyun 	XDP_ATTACHED_HW,
1181*4882a593Smuzhiyun 	XDP_ATTACHED_MULTI,
1182*4882a593Smuzhiyun };
1183*4882a593Smuzhiyun 
1184*4882a593Smuzhiyun enum {
1185*4882a593Smuzhiyun 	IFLA_XDP_UNSPEC,
1186*4882a593Smuzhiyun 	IFLA_XDP_FD,
1187*4882a593Smuzhiyun 	IFLA_XDP_ATTACHED,
1188*4882a593Smuzhiyun 	IFLA_XDP_FLAGS,
1189*4882a593Smuzhiyun 	IFLA_XDP_PROG_ID,
1190*4882a593Smuzhiyun 	IFLA_XDP_DRV_PROG_ID,
1191*4882a593Smuzhiyun 	IFLA_XDP_SKB_PROG_ID,
1192*4882a593Smuzhiyun 	IFLA_XDP_HW_PROG_ID,
1193*4882a593Smuzhiyun 	IFLA_XDP_EXPECTED_FD,
1194*4882a593Smuzhiyun 	__IFLA_XDP_MAX,
1195*4882a593Smuzhiyun };
1196*4882a593Smuzhiyun 
1197*4882a593Smuzhiyun #define IFLA_XDP_MAX (__IFLA_XDP_MAX - 1)
1198*4882a593Smuzhiyun 
1199*4882a593Smuzhiyun enum {
1200*4882a593Smuzhiyun 	IFLA_EVENT_NONE,
1201*4882a593Smuzhiyun 	IFLA_EVENT_REBOOT,		/* internal reset / reboot */
1202*4882a593Smuzhiyun 	IFLA_EVENT_FEATURES,		/* change in offload features */
1203*4882a593Smuzhiyun 	IFLA_EVENT_BONDING_FAILOVER,	/* change in active slave */
1204*4882a593Smuzhiyun 	IFLA_EVENT_NOTIFY_PEERS,	/* re-sent grat. arp/ndisc */
1205*4882a593Smuzhiyun 	IFLA_EVENT_IGMP_RESEND,		/* re-sent IGMP JOIN */
1206*4882a593Smuzhiyun 	IFLA_EVENT_BONDING_OPTIONS,	/* change in bonding options */
1207*4882a593Smuzhiyun };
1208*4882a593Smuzhiyun 
1209*4882a593Smuzhiyun /* tun section */
1210*4882a593Smuzhiyun 
1211*4882a593Smuzhiyun enum {
1212*4882a593Smuzhiyun 	IFLA_TUN_UNSPEC,
1213*4882a593Smuzhiyun 	IFLA_TUN_OWNER,
1214*4882a593Smuzhiyun 	IFLA_TUN_GROUP,
1215*4882a593Smuzhiyun 	IFLA_TUN_TYPE,
1216*4882a593Smuzhiyun 	IFLA_TUN_PI,
1217*4882a593Smuzhiyun 	IFLA_TUN_VNET_HDR,
1218*4882a593Smuzhiyun 	IFLA_TUN_PERSIST,
1219*4882a593Smuzhiyun 	IFLA_TUN_MULTI_QUEUE,
1220*4882a593Smuzhiyun 	IFLA_TUN_NUM_QUEUES,
1221*4882a593Smuzhiyun 	IFLA_TUN_NUM_DISABLED_QUEUES,
1222*4882a593Smuzhiyun 	__IFLA_TUN_MAX,
1223*4882a593Smuzhiyun };
1224*4882a593Smuzhiyun 
1225*4882a593Smuzhiyun #define IFLA_TUN_MAX (__IFLA_TUN_MAX - 1)
1226*4882a593Smuzhiyun 
1227*4882a593Smuzhiyun /* rmnet section */
1228*4882a593Smuzhiyun 
1229*4882a593Smuzhiyun #define RMNET_FLAGS_INGRESS_DEAGGREGATION         (1U << 0)
1230*4882a593Smuzhiyun #define RMNET_FLAGS_INGRESS_MAP_COMMANDS          (1U << 1)
1231*4882a593Smuzhiyun #define RMNET_FLAGS_INGRESS_MAP_CKSUMV4           (1U << 2)
1232*4882a593Smuzhiyun #define RMNET_FLAGS_EGRESS_MAP_CKSUMV4            (1U << 3)
1233*4882a593Smuzhiyun 
1234*4882a593Smuzhiyun enum {
1235*4882a593Smuzhiyun 	IFLA_RMNET_UNSPEC,
1236*4882a593Smuzhiyun 	IFLA_RMNET_MUX_ID,
1237*4882a593Smuzhiyun 	IFLA_RMNET_FLAGS,
1238*4882a593Smuzhiyun 	__IFLA_RMNET_MAX,
1239*4882a593Smuzhiyun };
1240*4882a593Smuzhiyun 
1241*4882a593Smuzhiyun #define IFLA_RMNET_MAX	(__IFLA_RMNET_MAX - 1)
1242*4882a593Smuzhiyun 
1243*4882a593Smuzhiyun struct ifla_rmnet_flags {
1244*4882a593Smuzhiyun 	__u32	flags;
1245*4882a593Smuzhiyun 	__u32	mask;
1246*4882a593Smuzhiyun };
1247*4882a593Smuzhiyun 
1248*4882a593Smuzhiyun #endif /* _UAPI_LINUX_IF_LINK_H */
1249