xref: /linux-6.15/include/uapi/linux/devlink.h (revision 2d8dc5bb)
1e2be04c7SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
2bfcd3a46SJiri Pirko /*
3bfcd3a46SJiri Pirko  * include/uapi/linux/devlink.h - Network physical device Netlink interface
4bfcd3a46SJiri Pirko  * Copyright (c) 2016 Mellanox Technologies. All rights reserved.
5bfcd3a46SJiri Pirko  * Copyright (c) 2016 Jiri Pirko <[email protected]>
6bfcd3a46SJiri Pirko  *
7bfcd3a46SJiri Pirko  * This program is free software; you can redistribute it and/or modify
8bfcd3a46SJiri Pirko  * it under the terms of the GNU General Public License as published by
9bfcd3a46SJiri Pirko  * the Free Software Foundation; either version 2 of the License, or
10bfcd3a46SJiri Pirko  * (at your option) any later version.
11bfcd3a46SJiri Pirko  */
12bfcd3a46SJiri Pirko 
13bfcd3a46SJiri Pirko #ifndef _UAPI_LINUX_DEVLINK_H_
14bfcd3a46SJiri Pirko #define _UAPI_LINUX_DEVLINK_H_
15bfcd3a46SJiri Pirko 
16bfcd3a46SJiri Pirko #define DEVLINK_GENL_NAME "devlink"
17bfcd3a46SJiri Pirko #define DEVLINK_GENL_VERSION 0x1
18bfcd3a46SJiri Pirko #define DEVLINK_GENL_MCGRP_CONFIG_NAME "config"
19bfcd3a46SJiri Pirko 
20bfcd3a46SJiri Pirko enum devlink_command {
21bfcd3a46SJiri Pirko 	/* don't change the order or add anything between, this is ABI! */
22bfcd3a46SJiri Pirko 	DEVLINK_CMD_UNSPEC,
23bfcd3a46SJiri Pirko 
24bfcd3a46SJiri Pirko 	DEVLINK_CMD_GET,		/* can dump */
25bfcd3a46SJiri Pirko 	DEVLINK_CMD_SET,
26bfcd3a46SJiri Pirko 	DEVLINK_CMD_NEW,
27bfcd3a46SJiri Pirko 	DEVLINK_CMD_DEL,
28bfcd3a46SJiri Pirko 
29bfcd3a46SJiri Pirko 	DEVLINK_CMD_PORT_GET,		/* can dump */
30bfcd3a46SJiri Pirko 	DEVLINK_CMD_PORT_SET,
31bfcd3a46SJiri Pirko 	DEVLINK_CMD_PORT_NEW,
32bfcd3a46SJiri Pirko 	DEVLINK_CMD_PORT_DEL,
33bfcd3a46SJiri Pirko 
34bfcd3a46SJiri Pirko 	DEVLINK_CMD_PORT_SPLIT,
35bfcd3a46SJiri Pirko 	DEVLINK_CMD_PORT_UNSPLIT,
36bfcd3a46SJiri Pirko 
37bf797471SJiri Pirko 	DEVLINK_CMD_SB_GET,		/* can dump */
38bf797471SJiri Pirko 	DEVLINK_CMD_SB_SET,
39bf797471SJiri Pirko 	DEVLINK_CMD_SB_NEW,
40bf797471SJiri Pirko 	DEVLINK_CMD_SB_DEL,
41bf797471SJiri Pirko 
42bf797471SJiri Pirko 	DEVLINK_CMD_SB_POOL_GET,	/* can dump */
43bf797471SJiri Pirko 	DEVLINK_CMD_SB_POOL_SET,
44bf797471SJiri Pirko 	DEVLINK_CMD_SB_POOL_NEW,
45bf797471SJiri Pirko 	DEVLINK_CMD_SB_POOL_DEL,
46bf797471SJiri Pirko 
47bf797471SJiri Pirko 	DEVLINK_CMD_SB_PORT_POOL_GET,	/* can dump */
48bf797471SJiri Pirko 	DEVLINK_CMD_SB_PORT_POOL_SET,
49bf797471SJiri Pirko 	DEVLINK_CMD_SB_PORT_POOL_NEW,
50bf797471SJiri Pirko 	DEVLINK_CMD_SB_PORT_POOL_DEL,
51bf797471SJiri Pirko 
52bf797471SJiri Pirko 	DEVLINK_CMD_SB_TC_POOL_BIND_GET,	/* can dump */
53bf797471SJiri Pirko 	DEVLINK_CMD_SB_TC_POOL_BIND_SET,
54bf797471SJiri Pirko 	DEVLINK_CMD_SB_TC_POOL_BIND_NEW,
55bf797471SJiri Pirko 	DEVLINK_CMD_SB_TC_POOL_BIND_DEL,
56bf797471SJiri Pirko 
57df38dafdSJiri Pirko 	/* Shared buffer occupancy monitoring commands */
58df38dafdSJiri Pirko 	DEVLINK_CMD_SB_OCC_SNAPSHOT,
59df38dafdSJiri Pirko 	DEVLINK_CMD_SB_OCC_MAX_CLEAR,
60df38dafdSJiri Pirko 
61adf200f3SJiri Pirko 	DEVLINK_CMD_ESWITCH_GET,
62adf200f3SJiri Pirko #define DEVLINK_CMD_ESWITCH_MODE_GET /* obsolete, never use this! */ \
63adf200f3SJiri Pirko 	DEVLINK_CMD_ESWITCH_GET
64adf200f3SJiri Pirko 
65adf200f3SJiri Pirko 	DEVLINK_CMD_ESWITCH_SET,
66adf200f3SJiri Pirko #define DEVLINK_CMD_ESWITCH_MODE_SET /* obsolete, never use this! */ \
67adf200f3SJiri Pirko 	DEVLINK_CMD_ESWITCH_SET
68adf200f3SJiri Pirko 
691555d204SArkadi Sharshevsky 	DEVLINK_CMD_DPIPE_TABLE_GET,
701555d204SArkadi Sharshevsky 	DEVLINK_CMD_DPIPE_ENTRIES_GET,
711555d204SArkadi Sharshevsky 	DEVLINK_CMD_DPIPE_HEADERS_GET,
721555d204SArkadi Sharshevsky 	DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET,
73d9f9b9a4SArkadi Sharshevsky 	DEVLINK_CMD_RESOURCE_SET,
74d9f9b9a4SArkadi Sharshevsky 	DEVLINK_CMD_RESOURCE_DUMP,
75bfcd3a46SJiri Pirko 
76*2d8dc5bbSArkadi Sharshevsky 	/* Hot driver reload, makes configuration changes take place. The
77*2d8dc5bbSArkadi Sharshevsky 	 * devlink instance is not released during the process.
78*2d8dc5bbSArkadi Sharshevsky 	 */
79*2d8dc5bbSArkadi Sharshevsky 	DEVLINK_CMD_RELOAD,
80*2d8dc5bbSArkadi Sharshevsky 
811555d204SArkadi Sharshevsky 	/* add new commands above here */
82bfcd3a46SJiri Pirko 	__DEVLINK_CMD_MAX,
83bfcd3a46SJiri Pirko 	DEVLINK_CMD_MAX = __DEVLINK_CMD_MAX - 1
84bfcd3a46SJiri Pirko };
85bfcd3a46SJiri Pirko 
86bfcd3a46SJiri Pirko enum devlink_port_type {
87bfcd3a46SJiri Pirko 	DEVLINK_PORT_TYPE_NOTSET,
88bfcd3a46SJiri Pirko 	DEVLINK_PORT_TYPE_AUTO,
89bfcd3a46SJiri Pirko 	DEVLINK_PORT_TYPE_ETH,
90bfcd3a46SJiri Pirko 	DEVLINK_PORT_TYPE_IB,
91bfcd3a46SJiri Pirko };
92bfcd3a46SJiri Pirko 
93bf797471SJiri Pirko enum devlink_sb_pool_type {
94bf797471SJiri Pirko 	DEVLINK_SB_POOL_TYPE_INGRESS,
95bf797471SJiri Pirko 	DEVLINK_SB_POOL_TYPE_EGRESS,
96bf797471SJiri Pirko };
97bf797471SJiri Pirko 
98bf797471SJiri Pirko /* static threshold - limiting the maximum number of bytes.
99bf797471SJiri Pirko  * dynamic threshold - limiting the maximum number of bytes
100bf797471SJiri Pirko  *   based on the currently available free space in the shared buffer pool.
101bf797471SJiri Pirko  *   In this mode, the maximum quota is calculated based
102bf797471SJiri Pirko  *   on the following formula:
103bf797471SJiri Pirko  *     max_quota = alpha / (1 + alpha) * Free_Buffer
104bf797471SJiri Pirko  *   While Free_Buffer is the amount of none-occupied buffer associated to
105bf797471SJiri Pirko  *   the relevant pool.
106bf797471SJiri Pirko  *   The value range which can be passed is 0-20 and serves
107bf797471SJiri Pirko  *   for computation of alpha by following formula:
108bf797471SJiri Pirko  *     alpha = 2 ^ (passed_value - 10)
109bf797471SJiri Pirko  */
110bf797471SJiri Pirko 
111bf797471SJiri Pirko enum devlink_sb_threshold_type {
112bf797471SJiri Pirko 	DEVLINK_SB_THRESHOLD_TYPE_STATIC,
113bf797471SJiri Pirko 	DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC,
114bf797471SJiri Pirko };
115bf797471SJiri Pirko 
116bf797471SJiri Pirko #define DEVLINK_SB_THRESHOLD_TO_ALPHA_MAX 20
117bf797471SJiri Pirko 
11808f4b591SOr Gerlitz enum devlink_eswitch_mode {
11908f4b591SOr Gerlitz 	DEVLINK_ESWITCH_MODE_LEGACY,
12008f4b591SOr Gerlitz 	DEVLINK_ESWITCH_MODE_SWITCHDEV,
12108f4b591SOr Gerlitz };
12208f4b591SOr Gerlitz 
12359bfde01SRoi Dayan enum devlink_eswitch_inline_mode {
12459bfde01SRoi Dayan 	DEVLINK_ESWITCH_INLINE_MODE_NONE,
12559bfde01SRoi Dayan 	DEVLINK_ESWITCH_INLINE_MODE_LINK,
12659bfde01SRoi Dayan 	DEVLINK_ESWITCH_INLINE_MODE_NETWORK,
12759bfde01SRoi Dayan 	DEVLINK_ESWITCH_INLINE_MODE_TRANSPORT,
12859bfde01SRoi Dayan };
12959bfde01SRoi Dayan 
130f43e9b06SRoi Dayan enum devlink_eswitch_encap_mode {
131f43e9b06SRoi Dayan 	DEVLINK_ESWITCH_ENCAP_MODE_NONE,
132f43e9b06SRoi Dayan 	DEVLINK_ESWITCH_ENCAP_MODE_BASIC,
133f43e9b06SRoi Dayan };
134f43e9b06SRoi Dayan 
135bfcd3a46SJiri Pirko enum devlink_attr {
136bfcd3a46SJiri Pirko 	/* don't change the order or add anything between, this is ABI! */
137bfcd3a46SJiri Pirko 	DEVLINK_ATTR_UNSPEC,
138bfcd3a46SJiri Pirko 
139bfcd3a46SJiri Pirko 	/* bus name + dev name together are a handle for devlink entity */
140bfcd3a46SJiri Pirko 	DEVLINK_ATTR_BUS_NAME,			/* string */
141bfcd3a46SJiri Pirko 	DEVLINK_ATTR_DEV_NAME,			/* string */
142bfcd3a46SJiri Pirko 
143bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_INDEX,		/* u32 */
144bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_TYPE,			/* u16 */
145bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_DESIRED_TYPE,		/* u16 */
146bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_NETDEV_IFINDEX,	/* u32 */
147bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_NETDEV_NAME,		/* string */
148bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_IBDEV_NAME,		/* string */
149bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_SPLIT_COUNT,		/* u32 */
150bfcd3a46SJiri Pirko 	DEVLINK_ATTR_PORT_SPLIT_GROUP,		/* u32 */
151bf797471SJiri Pirko 	DEVLINK_ATTR_SB_INDEX,			/* u32 */
152bf797471SJiri Pirko 	DEVLINK_ATTR_SB_SIZE,			/* u32 */
153bf797471SJiri Pirko 	DEVLINK_ATTR_SB_INGRESS_POOL_COUNT,	/* u16 */
154bf797471SJiri Pirko 	DEVLINK_ATTR_SB_EGRESS_POOL_COUNT,	/* u16 */
155bf797471SJiri Pirko 	DEVLINK_ATTR_SB_INGRESS_TC_COUNT,	/* u16 */
156bf797471SJiri Pirko 	DEVLINK_ATTR_SB_EGRESS_TC_COUNT,	/* u16 */
157bf797471SJiri Pirko 	DEVLINK_ATTR_SB_POOL_INDEX,		/* u16 */
158bf797471SJiri Pirko 	DEVLINK_ATTR_SB_POOL_TYPE,		/* u8 */
159bf797471SJiri Pirko 	DEVLINK_ATTR_SB_POOL_SIZE,		/* u32 */
160bf797471SJiri Pirko 	DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE,	/* u8 */
161bf797471SJiri Pirko 	DEVLINK_ATTR_SB_THRESHOLD,		/* u32 */
162bf797471SJiri Pirko 	DEVLINK_ATTR_SB_TC_INDEX,		/* u16 */
163df38dafdSJiri Pirko 	DEVLINK_ATTR_SB_OCC_CUR,		/* u32 */
164df38dafdSJiri Pirko 	DEVLINK_ATTR_SB_OCC_MAX,		/* u32 */
16508f4b591SOr Gerlitz 	DEVLINK_ATTR_ESWITCH_MODE,		/* u16 */
16659bfde01SRoi Dayan 	DEVLINK_ATTR_ESWITCH_INLINE_MODE,	/* u8 */
167bfcd3a46SJiri Pirko 
1681555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLES,		/* nested */
1691555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLE,		/* nested */
1701555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLE_NAME,		/* string */
1711555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLE_SIZE,		/* u64 */
1721555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLE_MATCHES,	/* nested */
1731555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLE_ACTIONS,	/* nested */
1741555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED,	/* u8 */
1751555d204SArkadi Sharshevsky 
1761555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ENTRIES,		/* nested */
1771555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ENTRY,		/* nested */
1781555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ENTRY_INDEX,		/* u64 */
1791555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ENTRY_MATCH_VALUES,	/* nested */
1801555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ENTRY_ACTION_VALUES,	/* nested */
1811555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ENTRY_COUNTER,	/* u64 */
1821555d204SArkadi Sharshevsky 
1831555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_MATCH,		/* nested */
1841555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_MATCH_VALUE,		/* nested */
1851555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_MATCH_TYPE,		/* u32 */
1861555d204SArkadi Sharshevsky 
1871555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ACTION,		/* nested */
1881555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ACTION_VALUE,	/* nested */
1891555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_ACTION_TYPE,		/* u32 */
1901555d204SArkadi Sharshevsky 
1911555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_VALUE,
1921555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_VALUE_MASK,
1931555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_VALUE_MAPPING,	/* u32 */
1941555d204SArkadi Sharshevsky 
1951555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADERS,		/* nested */
1961555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADER,		/* nested */
1971555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADER_NAME,		/* string */
1981555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADER_ID,		/* u32 */
1991555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADER_FIELDS,	/* nested */
2001555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADER_GLOBAL,	/* u8 */
2011555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_HEADER_INDEX,	/* u32 */
2021555d204SArkadi Sharshevsky 
2031555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_FIELD,		/* nested */
2041555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_FIELD_NAME,		/* string */
2051555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_FIELD_ID,		/* u32 */
2061555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_FIELD_BITWIDTH,	/* u32 */
2071555d204SArkadi Sharshevsky 	DEVLINK_ATTR_DPIPE_FIELD_MAPPING_TYPE,	/* u32 */
2081555d204SArkadi Sharshevsky 
2091555d204SArkadi Sharshevsky 	DEVLINK_ATTR_PAD,
2101555d204SArkadi Sharshevsky 
211f43e9b06SRoi Dayan 	DEVLINK_ATTR_ESWITCH_ENCAP_MODE,	/* u8 */
212d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_LIST,		/* nested */
213d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE,			/* nested */
214d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_NAME,		/* string */
215d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_ID,		/* u64 */
216d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_SIZE,		/* u64 */
217d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_SIZE_NEW,		/* u64 */
218d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_SIZE_VALID,	/* u8 */
219d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_SIZE_MIN,		/* u64 */
220d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_SIZE_MAX,		/* u64 */
221d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_SIZE_GRAN,        /* u64 */
222d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_UNIT,		/* u8 */
223d9f9b9a4SArkadi Sharshevsky 	DEVLINK_ATTR_RESOURCE_OCC,		/* u64 */
224f43e9b06SRoi Dayan 
225bfcd3a46SJiri Pirko 	/* add new attributes above here, update the policy in devlink.c */
226bfcd3a46SJiri Pirko 
227bfcd3a46SJiri Pirko 	__DEVLINK_ATTR_MAX,
228bfcd3a46SJiri Pirko 	DEVLINK_ATTR_MAX = __DEVLINK_ATTR_MAX - 1
229bfcd3a46SJiri Pirko };
230bfcd3a46SJiri Pirko 
2311555d204SArkadi Sharshevsky /* Mapping between internal resource described by the field and system
2321555d204SArkadi Sharshevsky  * structure
2331555d204SArkadi Sharshevsky  */
2341555d204SArkadi Sharshevsky enum devlink_dpipe_field_mapping_type {
2351555d204SArkadi Sharshevsky 	DEVLINK_DPIPE_FIELD_MAPPING_TYPE_NONE,
2361555d204SArkadi Sharshevsky 	DEVLINK_DPIPE_FIELD_MAPPING_TYPE_IFINDEX,
2371555d204SArkadi Sharshevsky };
2381555d204SArkadi Sharshevsky 
2391555d204SArkadi Sharshevsky /* Match type - specify the type of the match */
2401555d204SArkadi Sharshevsky enum devlink_dpipe_match_type {
2411555d204SArkadi Sharshevsky 	DEVLINK_DPIPE_MATCH_TYPE_FIELD_EXACT,
2421555d204SArkadi Sharshevsky };
2431555d204SArkadi Sharshevsky 
2441555d204SArkadi Sharshevsky /* Action type - specify the action type */
2451555d204SArkadi Sharshevsky enum devlink_dpipe_action_type {
2461555d204SArkadi Sharshevsky 	DEVLINK_DPIPE_ACTION_TYPE_FIELD_MODIFY,
2471555d204SArkadi Sharshevsky };
2481555d204SArkadi Sharshevsky 
24911770091SArkadi Sharshevsky enum devlink_dpipe_field_ethernet_id {
25011770091SArkadi Sharshevsky 	DEVLINK_DPIPE_FIELD_ETHERNET_DST_MAC,
25111770091SArkadi Sharshevsky };
25211770091SArkadi Sharshevsky 
2533fb886ecSArkadi Sharshevsky enum devlink_dpipe_field_ipv4_id {
2543fb886ecSArkadi Sharshevsky 	DEVLINK_DPIPE_FIELD_IPV4_DST_IP,
2553fb886ecSArkadi Sharshevsky };
2563fb886ecSArkadi Sharshevsky 
2571797f5b3SArkadi Sharshevsky enum devlink_dpipe_field_ipv6_id {
2581797f5b3SArkadi Sharshevsky 	DEVLINK_DPIPE_FIELD_IPV6_DST_IP,
2591797f5b3SArkadi Sharshevsky };
2601797f5b3SArkadi Sharshevsky 
26111770091SArkadi Sharshevsky enum devlink_dpipe_header_id {
26211770091SArkadi Sharshevsky 	DEVLINK_DPIPE_HEADER_ETHERNET,
2633fb886ecSArkadi Sharshevsky 	DEVLINK_DPIPE_HEADER_IPV4,
2641797f5b3SArkadi Sharshevsky 	DEVLINK_DPIPE_HEADER_IPV6,
26511770091SArkadi Sharshevsky };
26611770091SArkadi Sharshevsky 
267d9f9b9a4SArkadi Sharshevsky enum devlink_resource_unit {
268d9f9b9a4SArkadi Sharshevsky 	DEVLINK_RESOURCE_UNIT_ENTRY,
269d9f9b9a4SArkadi Sharshevsky };
270d9f9b9a4SArkadi Sharshevsky 
271bfcd3a46SJiri Pirko #endif /* _UAPI_LINUX_DEVLINK_H_ */
272