master
  1/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
  2/*
  3 * include/uapi/linux/devlink.h - Network physical device Netlink interface
  4 * Copyright (c) 2016 Mellanox Technologies. All rights reserved.
  5 * Copyright (c) 2016 Jiri Pirko <jiri@mellanox.com>
  6 *
  7 * This program is free software; you can redistribute it and/or modify
  8 * it under the terms of the GNU General Public License as published by
  9 * the Free Software Foundation; either version 2 of the License, or
 10 * (at your option) any later version.
 11 */
 12
 13#ifndef _LINUX_DEVLINK_H_
 14#define _LINUX_DEVLINK_H_
 15
 16#include <linux/const.h>
 17
 18#define DEVLINK_GENL_NAME "devlink"
 19#define DEVLINK_GENL_VERSION 0x1
 20#define DEVLINK_GENL_MCGRP_CONFIG_NAME "config"
 21
 22enum devlink_command {
 23	/* don't change the order or add anything between, this is ABI! */
 24	DEVLINK_CMD_UNSPEC,
 25
 26	DEVLINK_CMD_GET,		/* can dump */
 27	DEVLINK_CMD_SET,
 28	DEVLINK_CMD_NEW,
 29	DEVLINK_CMD_DEL,
 30
 31	DEVLINK_CMD_PORT_GET,		/* can dump */
 32	DEVLINK_CMD_PORT_SET,
 33	DEVLINK_CMD_PORT_NEW,
 34	DEVLINK_CMD_PORT_DEL,
 35
 36	DEVLINK_CMD_PORT_SPLIT,
 37	DEVLINK_CMD_PORT_UNSPLIT,
 38
 39	DEVLINK_CMD_SB_GET,		/* can dump */
 40	DEVLINK_CMD_SB_SET,
 41	DEVLINK_CMD_SB_NEW,
 42	DEVLINK_CMD_SB_DEL,
 43
 44	DEVLINK_CMD_SB_POOL_GET,	/* can dump */
 45	DEVLINK_CMD_SB_POOL_SET,
 46	DEVLINK_CMD_SB_POOL_NEW,
 47	DEVLINK_CMD_SB_POOL_DEL,
 48
 49	DEVLINK_CMD_SB_PORT_POOL_GET,	/* can dump */
 50	DEVLINK_CMD_SB_PORT_POOL_SET,
 51	DEVLINK_CMD_SB_PORT_POOL_NEW,
 52	DEVLINK_CMD_SB_PORT_POOL_DEL,
 53
 54	DEVLINK_CMD_SB_TC_POOL_BIND_GET,	/* can dump */
 55	DEVLINK_CMD_SB_TC_POOL_BIND_SET,
 56	DEVLINK_CMD_SB_TC_POOL_BIND_NEW,
 57	DEVLINK_CMD_SB_TC_POOL_BIND_DEL,
 58
 59	/* Shared buffer occupancy monitoring commands */
 60	DEVLINK_CMD_SB_OCC_SNAPSHOT,
 61	DEVLINK_CMD_SB_OCC_MAX_CLEAR,
 62
 63	DEVLINK_CMD_ESWITCH_GET,
 64#define DEVLINK_CMD_ESWITCH_MODE_GET /* obsolete, never use this! */ \
 65	DEVLINK_CMD_ESWITCH_GET
 66
 67	DEVLINK_CMD_ESWITCH_SET,
 68#define DEVLINK_CMD_ESWITCH_MODE_SET /* obsolete, never use this! */ \
 69	DEVLINK_CMD_ESWITCH_SET
 70
 71	DEVLINK_CMD_DPIPE_TABLE_GET,
 72	DEVLINK_CMD_DPIPE_ENTRIES_GET,
 73	DEVLINK_CMD_DPIPE_HEADERS_GET,
 74	DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET,
 75	DEVLINK_CMD_RESOURCE_SET,
 76	DEVLINK_CMD_RESOURCE_DUMP,
 77
 78	/* Hot driver reload, makes configuration changes take place. The
 79	 * devlink instance is not released during the process.
 80	 */
 81	DEVLINK_CMD_RELOAD,
 82
 83	DEVLINK_CMD_PARAM_GET,		/* can dump */
 84	DEVLINK_CMD_PARAM_SET,
 85	DEVLINK_CMD_PARAM_NEW,
 86	DEVLINK_CMD_PARAM_DEL,
 87
 88	DEVLINK_CMD_REGION_GET,
 89	DEVLINK_CMD_REGION_SET,
 90	DEVLINK_CMD_REGION_NEW,
 91	DEVLINK_CMD_REGION_DEL,
 92	DEVLINK_CMD_REGION_READ,
 93
 94	DEVLINK_CMD_PORT_PARAM_GET,	/* can dump */
 95	DEVLINK_CMD_PORT_PARAM_SET,
 96	DEVLINK_CMD_PORT_PARAM_NEW,
 97	DEVLINK_CMD_PORT_PARAM_DEL,
 98
 99	DEVLINK_CMD_INFO_GET,		/* can dump */
100
101	DEVLINK_CMD_HEALTH_REPORTER_GET,
102	DEVLINK_CMD_HEALTH_REPORTER_SET,
103	DEVLINK_CMD_HEALTH_REPORTER_RECOVER,
104	DEVLINK_CMD_HEALTH_REPORTER_DIAGNOSE,
105	DEVLINK_CMD_HEALTH_REPORTER_DUMP_GET,
106	DEVLINK_CMD_HEALTH_REPORTER_DUMP_CLEAR,
107
108	DEVLINK_CMD_FLASH_UPDATE,
109	DEVLINK_CMD_FLASH_UPDATE_END,		/* notification only */
110	DEVLINK_CMD_FLASH_UPDATE_STATUS,	/* notification only */
111
112	DEVLINK_CMD_TRAP_GET,		/* can dump */
113	DEVLINK_CMD_TRAP_SET,
114	DEVLINK_CMD_TRAP_NEW,
115	DEVLINK_CMD_TRAP_DEL,
116
117	DEVLINK_CMD_TRAP_GROUP_GET,	/* can dump */
118	DEVLINK_CMD_TRAP_GROUP_SET,
119	DEVLINK_CMD_TRAP_GROUP_NEW,
120	DEVLINK_CMD_TRAP_GROUP_DEL,
121
122	DEVLINK_CMD_TRAP_POLICER_GET,	/* can dump */
123	DEVLINK_CMD_TRAP_POLICER_SET,
124	DEVLINK_CMD_TRAP_POLICER_NEW,
125	DEVLINK_CMD_TRAP_POLICER_DEL,
126
127	DEVLINK_CMD_HEALTH_REPORTER_TEST,
128
129	DEVLINK_CMD_RATE_GET,		/* can dump */
130	DEVLINK_CMD_RATE_SET,
131	DEVLINK_CMD_RATE_NEW,
132	DEVLINK_CMD_RATE_DEL,
133
134	DEVLINK_CMD_LINECARD_GET,		/* can dump */
135	DEVLINK_CMD_LINECARD_SET,
136	DEVLINK_CMD_LINECARD_NEW,
137	DEVLINK_CMD_LINECARD_DEL,
138
139	DEVLINK_CMD_SELFTESTS_GET,	/* can dump */
140	DEVLINK_CMD_SELFTESTS_RUN,
141
142	DEVLINK_CMD_NOTIFY_FILTER_SET,
143
144	/* add new commands above here */
145	__DEVLINK_CMD_MAX,
146	DEVLINK_CMD_MAX = __DEVLINK_CMD_MAX - 1
147};
148
149enum devlink_port_type {
150	DEVLINK_PORT_TYPE_NOTSET,
151	DEVLINK_PORT_TYPE_AUTO,
152	DEVLINK_PORT_TYPE_ETH,
153	DEVLINK_PORT_TYPE_IB,
154};
155
156enum devlink_sb_pool_type {
157	DEVLINK_SB_POOL_TYPE_INGRESS,
158	DEVLINK_SB_POOL_TYPE_EGRESS,
159};
160
161/* static threshold - limiting the maximum number of bytes.
162 * dynamic threshold - limiting the maximum number of bytes
163 *   based on the currently available free space in the shared buffer pool.
164 *   In this mode, the maximum quota is calculated based
165 *   on the following formula:
166 *     max_quota = alpha / (1 + alpha) * Free_Buffer
167 *   While Free_Buffer is the amount of none-occupied buffer associated to
168 *   the relevant pool.
169 *   The value range which can be passed is 0-20 and serves
170 *   for computation of alpha by following formula:
171 *     alpha = 2 ^ (passed_value - 10)
172 */
173
174enum devlink_sb_threshold_type {
175	DEVLINK_SB_THRESHOLD_TYPE_STATIC,
176	DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC,
177};
178
179#define DEVLINK_SB_THRESHOLD_TO_ALPHA_MAX 20
180
181enum devlink_eswitch_mode {
182	DEVLINK_ESWITCH_MODE_LEGACY,
183	DEVLINK_ESWITCH_MODE_SWITCHDEV,
184};
185
186enum devlink_eswitch_inline_mode {
187	DEVLINK_ESWITCH_INLINE_MODE_NONE,
188	DEVLINK_ESWITCH_INLINE_MODE_LINK,
189	DEVLINK_ESWITCH_INLINE_MODE_NETWORK,
190	DEVLINK_ESWITCH_INLINE_MODE_TRANSPORT,
191};
192
193enum devlink_eswitch_encap_mode {
194	DEVLINK_ESWITCH_ENCAP_MODE_NONE,
195	DEVLINK_ESWITCH_ENCAP_MODE_BASIC,
196};
197
198enum devlink_port_flavour {
199	DEVLINK_PORT_FLAVOUR_PHYSICAL, /* Any kind of a port physically
200					* facing the user.
201					*/
202	DEVLINK_PORT_FLAVOUR_CPU, /* CPU port */
203	DEVLINK_PORT_FLAVOUR_DSA, /* Distributed switch architecture
204				   * interconnect port.
205				   */
206	DEVLINK_PORT_FLAVOUR_PCI_PF, /* Represents eswitch port for
207				      * the PCI PF. It is an internal
208				      * port that faces the PCI PF.
209				      */
210	DEVLINK_PORT_FLAVOUR_PCI_VF, /* Represents eswitch port
211				      * for the PCI VF. It is an internal
212				      * port that faces the PCI VF.
213				      */
214	DEVLINK_PORT_FLAVOUR_VIRTUAL, /* Any virtual port facing the user. */
215	DEVLINK_PORT_FLAVOUR_UNUSED, /* Port which exists in the switch, but
216				      * is not used in any way.
217				      */
218	DEVLINK_PORT_FLAVOUR_PCI_SF, /* Represents eswitch port
219				      * for the PCI SF. It is an internal
220				      * port that faces the PCI SF.
221				      */
222};
223
224/* IEEE 802.1Qaz standard supported values. */
225
226#define DEVLINK_RATE_TCS_MAX 8
227#define DEVLINK_RATE_TC_INDEX_MAX (DEVLINK_RATE_TCS_MAX - 1)
228
229enum devlink_rate_type {
230	DEVLINK_RATE_TYPE_LEAF,
231	DEVLINK_RATE_TYPE_NODE,
232};
233
234enum devlink_param_cmode {
235	DEVLINK_PARAM_CMODE_RUNTIME,
236	DEVLINK_PARAM_CMODE_DRIVERINIT,
237	DEVLINK_PARAM_CMODE_PERMANENT,
238
239	/* Add new configuration modes above */
240	__DEVLINK_PARAM_CMODE_MAX,
241	DEVLINK_PARAM_CMODE_MAX = __DEVLINK_PARAM_CMODE_MAX - 1
242};
243
244enum devlink_param_fw_load_policy_value {
245	DEVLINK_PARAM_FW_LOAD_POLICY_VALUE_DRIVER,
246	DEVLINK_PARAM_FW_LOAD_POLICY_VALUE_FLASH,
247	DEVLINK_PARAM_FW_LOAD_POLICY_VALUE_DISK,
248	DEVLINK_PARAM_FW_LOAD_POLICY_VALUE_UNKNOWN,
249};
250
251enum devlink_param_reset_dev_on_drv_probe_value {
252	DEVLINK_PARAM_RESET_DEV_ON_DRV_PROBE_VALUE_UNKNOWN,
253	DEVLINK_PARAM_RESET_DEV_ON_DRV_PROBE_VALUE_ALWAYS,
254	DEVLINK_PARAM_RESET_DEV_ON_DRV_PROBE_VALUE_NEVER,
255	DEVLINK_PARAM_RESET_DEV_ON_DRV_PROBE_VALUE_DISK,
256};
257
258enum {
259	DEVLINK_ATTR_STATS_RX_PACKETS,		/* u64 */
260	DEVLINK_ATTR_STATS_RX_BYTES,		/* u64 */
261	DEVLINK_ATTR_STATS_RX_DROPPED,		/* u64 */
262
263	__DEVLINK_ATTR_STATS_MAX,
264	DEVLINK_ATTR_STATS_MAX = __DEVLINK_ATTR_STATS_MAX - 1
265};
266
267/* Specify what sections of a flash component can be overwritten when
268 * performing an update. Overwriting of firmware binary sections is always
269 * implicitly assumed to be allowed.
270 *
271 * Each section must be documented in
272 * Documentation/networking/devlink/devlink-flash.rst
273 *
274 */
275enum devlink_flash_overwrite {
276	DEVLINK_FLASH_OVERWRITE_SETTINGS_BIT,
277	DEVLINK_FLASH_OVERWRITE_IDENTIFIERS_BIT,
278
279	__DEVLINK_FLASH_OVERWRITE_MAX_BIT,
280	DEVLINK_FLASH_OVERWRITE_MAX_BIT = __DEVLINK_FLASH_OVERWRITE_MAX_BIT - 1
281};
282
283#define DEVLINK_FLASH_OVERWRITE_SETTINGS _BITUL(DEVLINK_FLASH_OVERWRITE_SETTINGS_BIT)
284#define DEVLINK_FLASH_OVERWRITE_IDENTIFIERS _BITUL(DEVLINK_FLASH_OVERWRITE_IDENTIFIERS_BIT)
285
286#define DEVLINK_SUPPORTED_FLASH_OVERWRITE_SECTIONS \
287	(_BITUL(__DEVLINK_FLASH_OVERWRITE_MAX_BIT) - 1)
288
289enum devlink_attr_selftest_id {
290	DEVLINK_ATTR_SELFTEST_ID_UNSPEC,
291	DEVLINK_ATTR_SELFTEST_ID_FLASH,	/* flag */
292
293	__DEVLINK_ATTR_SELFTEST_ID_MAX,
294	DEVLINK_ATTR_SELFTEST_ID_MAX = __DEVLINK_ATTR_SELFTEST_ID_MAX - 1
295};
296
297enum devlink_selftest_status {
298	DEVLINK_SELFTEST_STATUS_SKIP,
299	DEVLINK_SELFTEST_STATUS_PASS,
300	DEVLINK_SELFTEST_STATUS_FAIL
301};
302
303enum devlink_attr_selftest_result {
304	DEVLINK_ATTR_SELFTEST_RESULT_UNSPEC,
305	DEVLINK_ATTR_SELFTEST_RESULT,		/* nested */
306	DEVLINK_ATTR_SELFTEST_RESULT_ID,	/* u32, enum devlink_attr_selftest_id */
307	DEVLINK_ATTR_SELFTEST_RESULT_STATUS,	/* u8, enum devlink_selftest_status */
308
309	__DEVLINK_ATTR_SELFTEST_RESULT_MAX,
310	DEVLINK_ATTR_SELFTEST_RESULT_MAX = __DEVLINK_ATTR_SELFTEST_RESULT_MAX - 1
311};
312
313/**
314 * enum devlink_trap_action - Packet trap action.
315 * @DEVLINK_TRAP_ACTION_DROP: Packet is dropped by the device and a copy is not
316 *                            sent to the CPU.
317 * @DEVLINK_TRAP_ACTION_TRAP: The sole copy of the packet is sent to the CPU.
318 * @DEVLINK_TRAP_ACTION_MIRROR: Packet is forwarded by the device and a copy is
319 *                              sent to the CPU.
320 */
321enum devlink_trap_action {
322	DEVLINK_TRAP_ACTION_DROP,
323	DEVLINK_TRAP_ACTION_TRAP,
324	DEVLINK_TRAP_ACTION_MIRROR,
325};
326
327/**
328 * enum devlink_trap_type - Packet trap type.
329 * @DEVLINK_TRAP_TYPE_DROP: Trap reason is a drop. Trapped packets are only
330 *                          processed by devlink and not injected to the
331 *                          kernel's Rx path.
332 * @DEVLINK_TRAP_TYPE_EXCEPTION: Trap reason is an exception. Packet was not
333 *                               forwarded as intended due to an exception
334 *                               (e.g., missing neighbour entry) and trapped to
335 *                               control plane for resolution. Trapped packets
336 *                               are processed by devlink and injected to
337 *                               the kernel's Rx path.
338 * @DEVLINK_TRAP_TYPE_CONTROL: Packet was trapped because it is required for
339 *                             the correct functioning of the control plane.
340 *                             For example, an ARP request packet. Trapped
341 *                             packets are injected to the kernel's Rx path,
342 *                             but not reported to drop monitor.
343 */
344enum devlink_trap_type {
345	DEVLINK_TRAP_TYPE_DROP,
346	DEVLINK_TRAP_TYPE_EXCEPTION,
347	DEVLINK_TRAP_TYPE_CONTROL,
348};
349
350enum {
351	/* Trap can report input port as metadata */
352	DEVLINK_ATTR_TRAP_METADATA_TYPE_IN_PORT,
353	/* Trap can report flow action cookie as metadata */
354	DEVLINK_ATTR_TRAP_METADATA_TYPE_FA_COOKIE,
355};
356
357enum devlink_reload_action {
358	DEVLINK_RELOAD_ACTION_UNSPEC,
359	DEVLINK_RELOAD_ACTION_DRIVER_REINIT,	/* Driver entities re-instantiation */
360	DEVLINK_RELOAD_ACTION_FW_ACTIVATE,	/* FW activate */
361
362	/* Add new reload actions above */
363	__DEVLINK_RELOAD_ACTION_MAX,
364	DEVLINK_RELOAD_ACTION_MAX = __DEVLINK_RELOAD_ACTION_MAX - 1
365};
366
367enum devlink_reload_limit {
368	DEVLINK_RELOAD_LIMIT_UNSPEC,	/* unspecified, no constraints */
369	DEVLINK_RELOAD_LIMIT_NO_RESET,	/* No reset allowed, no down time allowed,
370					 * no link flap and no configuration is lost.
371					 */
372
373	/* Add new reload limit above */
374	__DEVLINK_RELOAD_LIMIT_MAX,
375	DEVLINK_RELOAD_LIMIT_MAX = __DEVLINK_RELOAD_LIMIT_MAX - 1
376};
377
378#define DEVLINK_RELOAD_LIMITS_VALID_MASK (_BITUL(__DEVLINK_RELOAD_LIMIT_MAX) - 1)
379
380enum devlink_linecard_state {
381	DEVLINK_LINECARD_STATE_UNSPEC,
382	DEVLINK_LINECARD_STATE_UNPROVISIONED,
383	DEVLINK_LINECARD_STATE_UNPROVISIONING,
384	DEVLINK_LINECARD_STATE_PROVISIONING,
385	DEVLINK_LINECARD_STATE_PROVISIONING_FAILED,
386	DEVLINK_LINECARD_STATE_PROVISIONED,
387	DEVLINK_LINECARD_STATE_ACTIVE,
388
389	__DEVLINK_LINECARD_STATE_MAX,
390	DEVLINK_LINECARD_STATE_MAX = __DEVLINK_LINECARD_STATE_MAX - 1
391};
392
393/* Variable attribute type. */
394enum devlink_var_attr_type {
395	/* Following values relate to the internal NLA_* values */
396	DEVLINK_VAR_ATTR_TYPE_U8 = 1,
397	DEVLINK_VAR_ATTR_TYPE_U16,
398	DEVLINK_VAR_ATTR_TYPE_U32,
399	DEVLINK_VAR_ATTR_TYPE_U64,
400	DEVLINK_VAR_ATTR_TYPE_STRING,
401	DEVLINK_VAR_ATTR_TYPE_FLAG,
402	DEVLINK_VAR_ATTR_TYPE_NUL_STRING = 10,
403	DEVLINK_VAR_ATTR_TYPE_BINARY,
404	__DEVLINK_VAR_ATTR_TYPE_CUSTOM_BASE = 0x80,
405	/* Any possible custom types, unrelated to NLA_* values go below */
406};
407
408enum devlink_attr {
409	/* don't change the order or add anything between, this is ABI! */
410	DEVLINK_ATTR_UNSPEC,
411
412	/* bus name + dev name together are a handle for devlink entity */
413	DEVLINK_ATTR_BUS_NAME,			/* string */
414	DEVLINK_ATTR_DEV_NAME,			/* string */
415
416	DEVLINK_ATTR_PORT_INDEX,		/* u32 */
417	DEVLINK_ATTR_PORT_TYPE,			/* u16 */
418	DEVLINK_ATTR_PORT_DESIRED_TYPE,		/* u16 */
419	DEVLINK_ATTR_PORT_NETDEV_IFINDEX,	/* u32 */
420	DEVLINK_ATTR_PORT_NETDEV_NAME,		/* string */
421	DEVLINK_ATTR_PORT_IBDEV_NAME,		/* string */
422	DEVLINK_ATTR_PORT_SPLIT_COUNT,		/* u32 */
423	DEVLINK_ATTR_PORT_SPLIT_GROUP,		/* u32 */
424	DEVLINK_ATTR_SB_INDEX,			/* u32 */
425	DEVLINK_ATTR_SB_SIZE,			/* u32 */
426	DEVLINK_ATTR_SB_INGRESS_POOL_COUNT,	/* u16 */
427	DEVLINK_ATTR_SB_EGRESS_POOL_COUNT,	/* u16 */
428	DEVLINK_ATTR_SB_INGRESS_TC_COUNT,	/* u16 */
429	DEVLINK_ATTR_SB_EGRESS_TC_COUNT,	/* u16 */
430	DEVLINK_ATTR_SB_POOL_INDEX,		/* u16 */
431	DEVLINK_ATTR_SB_POOL_TYPE,		/* u8 */
432	DEVLINK_ATTR_SB_POOL_SIZE,		/* u32 */
433	DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE,	/* u8 */
434	DEVLINK_ATTR_SB_THRESHOLD,		/* u32 */
435	DEVLINK_ATTR_SB_TC_INDEX,		/* u16 */
436	DEVLINK_ATTR_SB_OCC_CUR,		/* u32 */
437	DEVLINK_ATTR_SB_OCC_MAX,		/* u32 */
438	DEVLINK_ATTR_ESWITCH_MODE,		/* u16 */
439	DEVLINK_ATTR_ESWITCH_INLINE_MODE,	/* u8 */
440
441	DEVLINK_ATTR_DPIPE_TABLES,		/* nested */
442	DEVLINK_ATTR_DPIPE_TABLE,		/* nested */
443	DEVLINK_ATTR_DPIPE_TABLE_NAME,		/* string */
444	DEVLINK_ATTR_DPIPE_TABLE_SIZE,		/* u64 */
445	DEVLINK_ATTR_DPIPE_TABLE_MATCHES,	/* nested */
446	DEVLINK_ATTR_DPIPE_TABLE_ACTIONS,	/* nested */
447	DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED,	/* u8 */
448
449	DEVLINK_ATTR_DPIPE_ENTRIES,		/* nested */
450	DEVLINK_ATTR_DPIPE_ENTRY,		/* nested */
451	DEVLINK_ATTR_DPIPE_ENTRY_INDEX,		/* u64 */
452	DEVLINK_ATTR_DPIPE_ENTRY_MATCH_VALUES,	/* nested */
453	DEVLINK_ATTR_DPIPE_ENTRY_ACTION_VALUES,	/* nested */
454	DEVLINK_ATTR_DPIPE_ENTRY_COUNTER,	/* u64 */
455
456	DEVLINK_ATTR_DPIPE_MATCH,		/* nested */
457	DEVLINK_ATTR_DPIPE_MATCH_VALUE,		/* nested */
458	DEVLINK_ATTR_DPIPE_MATCH_TYPE,		/* u32 */
459
460	DEVLINK_ATTR_DPIPE_ACTION,		/* nested */
461	DEVLINK_ATTR_DPIPE_ACTION_VALUE,	/* nested */
462	DEVLINK_ATTR_DPIPE_ACTION_TYPE,		/* u32 */
463
464	DEVLINK_ATTR_DPIPE_VALUE,
465	DEVLINK_ATTR_DPIPE_VALUE_MASK,
466	DEVLINK_ATTR_DPIPE_VALUE_MAPPING,	/* u32 */
467
468	DEVLINK_ATTR_DPIPE_HEADERS,		/* nested */
469	DEVLINK_ATTR_DPIPE_HEADER,		/* nested */
470	DEVLINK_ATTR_DPIPE_HEADER_NAME,		/* string */
471	DEVLINK_ATTR_DPIPE_HEADER_ID,		/* u32 */
472	DEVLINK_ATTR_DPIPE_HEADER_FIELDS,	/* nested */
473	DEVLINK_ATTR_DPIPE_HEADER_GLOBAL,	/* u8 */
474	DEVLINK_ATTR_DPIPE_HEADER_INDEX,	/* u32 */
475
476	DEVLINK_ATTR_DPIPE_FIELD,		/* nested */
477	DEVLINK_ATTR_DPIPE_FIELD_NAME,		/* string */
478	DEVLINK_ATTR_DPIPE_FIELD_ID,		/* u32 */
479	DEVLINK_ATTR_DPIPE_FIELD_BITWIDTH,	/* u32 */
480	DEVLINK_ATTR_DPIPE_FIELD_MAPPING_TYPE,	/* u32 */
481
482	DEVLINK_ATTR_PAD,
483
484	DEVLINK_ATTR_ESWITCH_ENCAP_MODE,	/* u8 */
485	DEVLINK_ATTR_RESOURCE_LIST,		/* nested */
486	DEVLINK_ATTR_RESOURCE,			/* nested */
487	DEVLINK_ATTR_RESOURCE_NAME,		/* string */
488	DEVLINK_ATTR_RESOURCE_ID,		/* u64 */
489	DEVLINK_ATTR_RESOURCE_SIZE,		/* u64 */
490	DEVLINK_ATTR_RESOURCE_SIZE_NEW,		/* u64 */
491	DEVLINK_ATTR_RESOURCE_SIZE_VALID,	/* u8 */
492	DEVLINK_ATTR_RESOURCE_SIZE_MIN,		/* u64 */
493	DEVLINK_ATTR_RESOURCE_SIZE_MAX,		/* u64 */
494	DEVLINK_ATTR_RESOURCE_SIZE_GRAN,        /* u64 */
495	DEVLINK_ATTR_RESOURCE_UNIT,		/* u8 */
496	DEVLINK_ATTR_RESOURCE_OCC,		/* u64 */
497	DEVLINK_ATTR_DPIPE_TABLE_RESOURCE_ID,	/* u64 */
498	DEVLINK_ATTR_DPIPE_TABLE_RESOURCE_UNITS,/* u64 */
499
500	DEVLINK_ATTR_PORT_FLAVOUR,		/* u16 */
501	DEVLINK_ATTR_PORT_NUMBER,		/* u32 */
502	DEVLINK_ATTR_PORT_SPLIT_SUBPORT_NUMBER,	/* u32 */
503
504	DEVLINK_ATTR_PARAM,			/* nested */
505	DEVLINK_ATTR_PARAM_NAME,		/* string */
506	DEVLINK_ATTR_PARAM_GENERIC,		/* flag */
507	DEVLINK_ATTR_PARAM_TYPE,		/* u8 */
508	DEVLINK_ATTR_PARAM_VALUES_LIST,		/* nested */
509	DEVLINK_ATTR_PARAM_VALUE,		/* nested */
510	DEVLINK_ATTR_PARAM_VALUE_DATA,		/* dynamic */
511	DEVLINK_ATTR_PARAM_VALUE_CMODE,		/* u8 */
512
513	DEVLINK_ATTR_REGION_NAME,               /* string */
514	DEVLINK_ATTR_REGION_SIZE,               /* u64 */
515	DEVLINK_ATTR_REGION_SNAPSHOTS,          /* nested */
516	DEVLINK_ATTR_REGION_SNAPSHOT,           /* nested */
517	DEVLINK_ATTR_REGION_SNAPSHOT_ID,        /* u32 */
518
519	DEVLINK_ATTR_REGION_CHUNKS,             /* nested */
520	DEVLINK_ATTR_REGION_CHUNK,              /* nested */
521	DEVLINK_ATTR_REGION_CHUNK_DATA,         /* binary */
522	DEVLINK_ATTR_REGION_CHUNK_ADDR,         /* u64 */
523	DEVLINK_ATTR_REGION_CHUNK_LEN,          /* u64 */
524
525	DEVLINK_ATTR_INFO_DRIVER_NAME,		/* string */
526	DEVLINK_ATTR_INFO_SERIAL_NUMBER,	/* string */
527	DEVLINK_ATTR_INFO_VERSION_FIXED,	/* nested */
528	DEVLINK_ATTR_INFO_VERSION_RUNNING,	/* nested */
529	DEVLINK_ATTR_INFO_VERSION_STORED,	/* nested */
530	DEVLINK_ATTR_INFO_VERSION_NAME,		/* string */
531	DEVLINK_ATTR_INFO_VERSION_VALUE,	/* string */
532
533	DEVLINK_ATTR_SB_POOL_CELL_SIZE,		/* u32 */
534
535	DEVLINK_ATTR_FMSG,			/* nested */
536	DEVLINK_ATTR_FMSG_OBJ_NEST_START,	/* flag */
537	DEVLINK_ATTR_FMSG_PAIR_NEST_START,	/* flag */
538	DEVLINK_ATTR_FMSG_ARR_NEST_START,	/* flag */
539	DEVLINK_ATTR_FMSG_NEST_END,		/* flag */
540	DEVLINK_ATTR_FMSG_OBJ_NAME,		/* string */
541	DEVLINK_ATTR_FMSG_OBJ_VALUE_TYPE,	/* u8 */
542	DEVLINK_ATTR_FMSG_OBJ_VALUE_DATA,	/* dynamic */
543
544	DEVLINK_ATTR_HEALTH_REPORTER,			/* nested */
545	DEVLINK_ATTR_HEALTH_REPORTER_NAME,		/* string */
546	DEVLINK_ATTR_HEALTH_REPORTER_STATE,		/* u8 */
547	DEVLINK_ATTR_HEALTH_REPORTER_ERR_COUNT,		/* u64 */
548	DEVLINK_ATTR_HEALTH_REPORTER_RECOVER_COUNT,	/* u64 */
549	DEVLINK_ATTR_HEALTH_REPORTER_DUMP_TS,		/* u64 */
550	DEVLINK_ATTR_HEALTH_REPORTER_GRACEFUL_PERIOD,	/* u64 */
551	DEVLINK_ATTR_HEALTH_REPORTER_AUTO_RECOVER,	/* u8 */
552
553	DEVLINK_ATTR_FLASH_UPDATE_FILE_NAME,	/* string */
554	DEVLINK_ATTR_FLASH_UPDATE_COMPONENT,	/* string */
555	DEVLINK_ATTR_FLASH_UPDATE_STATUS_MSG,	/* string */
556	DEVLINK_ATTR_FLASH_UPDATE_STATUS_DONE,	/* u64 */
557	DEVLINK_ATTR_FLASH_UPDATE_STATUS_TOTAL,	/* u64 */
558
559	DEVLINK_ATTR_PORT_PCI_PF_NUMBER,	/* u16 */
560	DEVLINK_ATTR_PORT_PCI_VF_NUMBER,	/* u16 */
561
562	DEVLINK_ATTR_STATS,				/* nested */
563
564	DEVLINK_ATTR_TRAP_NAME,				/* string */
565	/* enum devlink_trap_action */
566	DEVLINK_ATTR_TRAP_ACTION,			/* u8 */
567	/* enum devlink_trap_type */
568	DEVLINK_ATTR_TRAP_TYPE,				/* u8 */
569	DEVLINK_ATTR_TRAP_GENERIC,			/* flag */
570	DEVLINK_ATTR_TRAP_METADATA,			/* nested */
571	DEVLINK_ATTR_TRAP_GROUP_NAME,			/* string */
572
573	DEVLINK_ATTR_RELOAD_FAILED,			/* u8 0 or 1 */
574
575	DEVLINK_ATTR_HEALTH_REPORTER_DUMP_TS_NS,	/* u64 */
576
577	DEVLINK_ATTR_NETNS_FD,			/* u32 */
578	DEVLINK_ATTR_NETNS_PID,			/* u32 */
579	DEVLINK_ATTR_NETNS_ID,			/* u32 */
580
581	DEVLINK_ATTR_HEALTH_REPORTER_AUTO_DUMP,	/* u8 */
582
583	DEVLINK_ATTR_TRAP_POLICER_ID,			/* u32 */
584	DEVLINK_ATTR_TRAP_POLICER_RATE,			/* u64 */
585	DEVLINK_ATTR_TRAP_POLICER_BURST,		/* u64 */
586
587	DEVLINK_ATTR_PORT_FUNCTION,			/* nested */
588
589	DEVLINK_ATTR_INFO_BOARD_SERIAL_NUMBER,	/* string */
590
591	DEVLINK_ATTR_PORT_LANES,			/* u32 */
592	DEVLINK_ATTR_PORT_SPLITTABLE,			/* u8 */
593
594	DEVLINK_ATTR_PORT_EXTERNAL,		/* u8 */
595	DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,	/* u32 */
596
597	DEVLINK_ATTR_FLASH_UPDATE_STATUS_TIMEOUT,	/* u64 */
598	DEVLINK_ATTR_FLASH_UPDATE_OVERWRITE_MASK,	/* bitfield32 */
599
600	DEVLINK_ATTR_RELOAD_ACTION,		/* u8 */
601	DEVLINK_ATTR_RELOAD_ACTIONS_PERFORMED,	/* bitfield32 */
602	DEVLINK_ATTR_RELOAD_LIMITS,		/* bitfield32 */
603
604	DEVLINK_ATTR_DEV_STATS,			/* nested */
605	DEVLINK_ATTR_RELOAD_STATS,		/* nested */
606	DEVLINK_ATTR_RELOAD_STATS_ENTRY,	/* nested */
607	DEVLINK_ATTR_RELOAD_STATS_LIMIT,	/* u8 */
608	DEVLINK_ATTR_RELOAD_STATS_VALUE,	/* u32 */
609	DEVLINK_ATTR_REMOTE_RELOAD_STATS,	/* nested */
610	DEVLINK_ATTR_RELOAD_ACTION_INFO,        /* nested */
611	DEVLINK_ATTR_RELOAD_ACTION_STATS,       /* nested */
612
613	DEVLINK_ATTR_PORT_PCI_SF_NUMBER,	/* u32 */
614
615	DEVLINK_ATTR_RATE_TYPE,			/* u16 */
616	DEVLINK_ATTR_RATE_TX_SHARE,		/* u64 */
617	DEVLINK_ATTR_RATE_TX_MAX,		/* u64 */
618	DEVLINK_ATTR_RATE_NODE_NAME,		/* string */
619	DEVLINK_ATTR_RATE_PARENT_NODE_NAME,	/* string */
620
621	DEVLINK_ATTR_REGION_MAX_SNAPSHOTS,	/* u32 */
622
623	DEVLINK_ATTR_LINECARD_INDEX,		/* u32 */
624	DEVLINK_ATTR_LINECARD_STATE,		/* u8 */
625	DEVLINK_ATTR_LINECARD_TYPE,		/* string */
626	DEVLINK_ATTR_LINECARD_SUPPORTED_TYPES,	/* nested */
627
628	DEVLINK_ATTR_NESTED_DEVLINK,		/* nested */
629
630	DEVLINK_ATTR_SELFTESTS,			/* nested */
631
632	DEVLINK_ATTR_RATE_TX_PRIORITY,		/* u32 */
633	DEVLINK_ATTR_RATE_TX_WEIGHT,		/* u32 */
634
635	DEVLINK_ATTR_REGION_DIRECT,		/* flag */
636
637	DEVLINK_ATTR_RATE_TC_BWS,		/* nested */
638
639	/* Add new attributes above here, update the spec in
640	 * Documentation/netlink/specs/devlink.yaml and re-generate
641	 * net/devlink/netlink_gen.c.
642	 */
643
644	__DEVLINK_ATTR_MAX,
645	DEVLINK_ATTR_MAX = __DEVLINK_ATTR_MAX - 1
646};
647
648enum devlink_rate_tc_attr {
649	DEVLINK_RATE_TC_ATTR_UNSPEC,
650	DEVLINK_RATE_TC_ATTR_INDEX,		/* u8 */
651	DEVLINK_RATE_TC_ATTR_BW,		/* u32 */
652
653	__DEVLINK_RATE_TC_ATTR_MAX,
654	DEVLINK_RATE_TC_ATTR_MAX = __DEVLINK_RATE_TC_ATTR_MAX - 1
655};
656
657/* Mapping between internal resource described by the field and system
658 * structure
659 */
660enum devlink_dpipe_field_mapping_type {
661	DEVLINK_DPIPE_FIELD_MAPPING_TYPE_NONE,
662	DEVLINK_DPIPE_FIELD_MAPPING_TYPE_IFINDEX,
663};
664
665/* Match type - specify the type of the match */
666enum devlink_dpipe_match_type {
667	DEVLINK_DPIPE_MATCH_TYPE_FIELD_EXACT,
668};
669
670/* Action type - specify the action type */
671enum devlink_dpipe_action_type {
672	DEVLINK_DPIPE_ACTION_TYPE_FIELD_MODIFY,
673};
674
675enum devlink_dpipe_field_ethernet_id {
676	DEVLINK_DPIPE_FIELD_ETHERNET_DST_MAC,
677};
678
679enum devlink_dpipe_field_ipv4_id {
680	DEVLINK_DPIPE_FIELD_IPV4_DST_IP,
681};
682
683enum devlink_dpipe_field_ipv6_id {
684	DEVLINK_DPIPE_FIELD_IPV6_DST_IP,
685};
686
687enum devlink_dpipe_header_id {
688	DEVLINK_DPIPE_HEADER_ETHERNET,
689	DEVLINK_DPIPE_HEADER_IPV4,
690	DEVLINK_DPIPE_HEADER_IPV6,
691};
692
693enum devlink_resource_unit {
694	DEVLINK_RESOURCE_UNIT_ENTRY,
695};
696
697enum devlink_port_fn_attr_cap {
698	DEVLINK_PORT_FN_ATTR_CAP_ROCE_BIT,
699	DEVLINK_PORT_FN_ATTR_CAP_MIGRATABLE_BIT,
700	DEVLINK_PORT_FN_ATTR_CAP_IPSEC_CRYPTO_BIT,
701	DEVLINK_PORT_FN_ATTR_CAP_IPSEC_PACKET_BIT,
702
703	/* Add new caps above */
704	__DEVLINK_PORT_FN_ATTR_CAPS_MAX,
705};
706
707#define DEVLINK_PORT_FN_CAP_ROCE _BITUL(DEVLINK_PORT_FN_ATTR_CAP_ROCE_BIT)
708#define DEVLINK_PORT_FN_CAP_MIGRATABLE \
709	_BITUL(DEVLINK_PORT_FN_ATTR_CAP_MIGRATABLE_BIT)
710#define DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO _BITUL(DEVLINK_PORT_FN_ATTR_CAP_IPSEC_CRYPTO_BIT)
711#define DEVLINK_PORT_FN_CAP_IPSEC_PACKET _BITUL(DEVLINK_PORT_FN_ATTR_CAP_IPSEC_PACKET_BIT)
712
713enum devlink_port_function_attr {
714	DEVLINK_PORT_FUNCTION_ATTR_UNSPEC,
715	DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR,	/* binary */
716	DEVLINK_PORT_FN_ATTR_STATE,	/* u8 */
717	DEVLINK_PORT_FN_ATTR_OPSTATE,	/* u8 */
718	DEVLINK_PORT_FN_ATTR_CAPS,	/* bitfield32 */
719	DEVLINK_PORT_FN_ATTR_DEVLINK,	/* nested */
720	DEVLINK_PORT_FN_ATTR_MAX_IO_EQS,	/* u32 */
721
722	__DEVLINK_PORT_FUNCTION_ATTR_MAX,
723	DEVLINK_PORT_FUNCTION_ATTR_MAX = __DEVLINK_PORT_FUNCTION_ATTR_MAX - 1
724};
725
726enum devlink_port_fn_state {
727	DEVLINK_PORT_FN_STATE_INACTIVE,
728	DEVLINK_PORT_FN_STATE_ACTIVE,
729};
730
731/**
732 * enum devlink_port_fn_opstate - indicates operational state of the function
733 * @DEVLINK_PORT_FN_OPSTATE_ATTACHED: Driver is attached to the function.
734 * For graceful tear down of the function, after inactivation of the
735 * function, user should wait for operational state to turn DETACHED.
736 * @DEVLINK_PORT_FN_OPSTATE_DETACHED: Driver is detached from the function.
737 * It is safe to delete the port.
738 */
739enum devlink_port_fn_opstate {
740	DEVLINK_PORT_FN_OPSTATE_DETACHED,
741	DEVLINK_PORT_FN_OPSTATE_ATTACHED,
742};
743
744#endif /* _LINUX_DEVLINK_H_ */