mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
1db64e8733
Devlink fmsg is a mechanism to pass descriptors between drivers and devlink, in json-like format. The API allows the driver to add nested attributes such as object, object pair and value array, in addition to attributes such as name and value. Driver can use this API to fill the fmsg context in a format which will be translated by the devlink to the netlink message later. There is no memory allocation in advance (other than the initial list head), and it dynamically allocates messages descriptors and add them to the list on the fly. When it needs to send the data using SKBs to the netlink layer, it fragments the data between different SKBs. In order to do this fragmentation, it uses virtual nests attributes, to avoid actual nesting use which cannot be divided between different SKBs. Signed-off-by: Eran Ben Elisha <eranbe@mellanox.com> Reviewed-by: Moshe Shemesh <moshe@mellanox.com> Acked-by: Jiri Pirko <jiri@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net>
360 lines
11 KiB
C
360 lines
11 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ WITH Linux-syscall-note */
|
|
/*
|
|
* include/uapi/linux/devlink.h - Network physical device Netlink interface
|
|
* Copyright (c) 2016 Mellanox Technologies. All rights reserved.
|
|
* Copyright (c) 2016 Jiri Pirko <jiri@mellanox.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _UAPI_LINUX_DEVLINK_H_
|
|
#define _UAPI_LINUX_DEVLINK_H_
|
|
|
|
#define DEVLINK_GENL_NAME "devlink"
|
|
#define DEVLINK_GENL_VERSION 0x1
|
|
#define DEVLINK_GENL_MCGRP_CONFIG_NAME "config"
|
|
|
|
enum devlink_command {
|
|
/* don't change the order or add anything between, this is ABI! */
|
|
DEVLINK_CMD_UNSPEC,
|
|
|
|
DEVLINK_CMD_GET, /* can dump */
|
|
DEVLINK_CMD_SET,
|
|
DEVLINK_CMD_NEW,
|
|
DEVLINK_CMD_DEL,
|
|
|
|
DEVLINK_CMD_PORT_GET, /* can dump */
|
|
DEVLINK_CMD_PORT_SET,
|
|
DEVLINK_CMD_PORT_NEW,
|
|
DEVLINK_CMD_PORT_DEL,
|
|
|
|
DEVLINK_CMD_PORT_SPLIT,
|
|
DEVLINK_CMD_PORT_UNSPLIT,
|
|
|
|
DEVLINK_CMD_SB_GET, /* can dump */
|
|
DEVLINK_CMD_SB_SET,
|
|
DEVLINK_CMD_SB_NEW,
|
|
DEVLINK_CMD_SB_DEL,
|
|
|
|
DEVLINK_CMD_SB_POOL_GET, /* can dump */
|
|
DEVLINK_CMD_SB_POOL_SET,
|
|
DEVLINK_CMD_SB_POOL_NEW,
|
|
DEVLINK_CMD_SB_POOL_DEL,
|
|
|
|
DEVLINK_CMD_SB_PORT_POOL_GET, /* can dump */
|
|
DEVLINK_CMD_SB_PORT_POOL_SET,
|
|
DEVLINK_CMD_SB_PORT_POOL_NEW,
|
|
DEVLINK_CMD_SB_PORT_POOL_DEL,
|
|
|
|
DEVLINK_CMD_SB_TC_POOL_BIND_GET, /* can dump */
|
|
DEVLINK_CMD_SB_TC_POOL_BIND_SET,
|
|
DEVLINK_CMD_SB_TC_POOL_BIND_NEW,
|
|
DEVLINK_CMD_SB_TC_POOL_BIND_DEL,
|
|
|
|
/* Shared buffer occupancy monitoring commands */
|
|
DEVLINK_CMD_SB_OCC_SNAPSHOT,
|
|
DEVLINK_CMD_SB_OCC_MAX_CLEAR,
|
|
|
|
DEVLINK_CMD_ESWITCH_GET,
|
|
#define DEVLINK_CMD_ESWITCH_MODE_GET /* obsolete, never use this! */ \
|
|
DEVLINK_CMD_ESWITCH_GET
|
|
|
|
DEVLINK_CMD_ESWITCH_SET,
|
|
#define DEVLINK_CMD_ESWITCH_MODE_SET /* obsolete, never use this! */ \
|
|
DEVLINK_CMD_ESWITCH_SET
|
|
|
|
DEVLINK_CMD_DPIPE_TABLE_GET,
|
|
DEVLINK_CMD_DPIPE_ENTRIES_GET,
|
|
DEVLINK_CMD_DPIPE_HEADERS_GET,
|
|
DEVLINK_CMD_DPIPE_TABLE_COUNTERS_SET,
|
|
DEVLINK_CMD_RESOURCE_SET,
|
|
DEVLINK_CMD_RESOURCE_DUMP,
|
|
|
|
/* Hot driver reload, makes configuration changes take place. The
|
|
* devlink instance is not released during the process.
|
|
*/
|
|
DEVLINK_CMD_RELOAD,
|
|
|
|
DEVLINK_CMD_PARAM_GET, /* can dump */
|
|
DEVLINK_CMD_PARAM_SET,
|
|
DEVLINK_CMD_PARAM_NEW,
|
|
DEVLINK_CMD_PARAM_DEL,
|
|
|
|
DEVLINK_CMD_REGION_GET,
|
|
DEVLINK_CMD_REGION_SET,
|
|
DEVLINK_CMD_REGION_NEW,
|
|
DEVLINK_CMD_REGION_DEL,
|
|
DEVLINK_CMD_REGION_READ,
|
|
|
|
DEVLINK_CMD_PORT_PARAM_GET, /* can dump */
|
|
DEVLINK_CMD_PORT_PARAM_SET,
|
|
DEVLINK_CMD_PORT_PARAM_NEW,
|
|
DEVLINK_CMD_PORT_PARAM_DEL,
|
|
|
|
DEVLINK_CMD_INFO_GET, /* can dump */
|
|
|
|
/* add new commands above here */
|
|
__DEVLINK_CMD_MAX,
|
|
DEVLINK_CMD_MAX = __DEVLINK_CMD_MAX - 1
|
|
};
|
|
|
|
enum devlink_port_type {
|
|
DEVLINK_PORT_TYPE_NOTSET,
|
|
DEVLINK_PORT_TYPE_AUTO,
|
|
DEVLINK_PORT_TYPE_ETH,
|
|
DEVLINK_PORT_TYPE_IB,
|
|
};
|
|
|
|
enum devlink_sb_pool_type {
|
|
DEVLINK_SB_POOL_TYPE_INGRESS,
|
|
DEVLINK_SB_POOL_TYPE_EGRESS,
|
|
};
|
|
|
|
/* static threshold - limiting the maximum number of bytes.
|
|
* dynamic threshold - limiting the maximum number of bytes
|
|
* based on the currently available free space in the shared buffer pool.
|
|
* In this mode, the maximum quota is calculated based
|
|
* on the following formula:
|
|
* max_quota = alpha / (1 + alpha) * Free_Buffer
|
|
* While Free_Buffer is the amount of none-occupied buffer associated to
|
|
* the relevant pool.
|
|
* The value range which can be passed is 0-20 and serves
|
|
* for computation of alpha by following formula:
|
|
* alpha = 2 ^ (passed_value - 10)
|
|
*/
|
|
|
|
enum devlink_sb_threshold_type {
|
|
DEVLINK_SB_THRESHOLD_TYPE_STATIC,
|
|
DEVLINK_SB_THRESHOLD_TYPE_DYNAMIC,
|
|
};
|
|
|
|
#define DEVLINK_SB_THRESHOLD_TO_ALPHA_MAX 20
|
|
|
|
enum devlink_eswitch_mode {
|
|
DEVLINK_ESWITCH_MODE_LEGACY,
|
|
DEVLINK_ESWITCH_MODE_SWITCHDEV,
|
|
};
|
|
|
|
enum devlink_eswitch_inline_mode {
|
|
DEVLINK_ESWITCH_INLINE_MODE_NONE,
|
|
DEVLINK_ESWITCH_INLINE_MODE_LINK,
|
|
DEVLINK_ESWITCH_INLINE_MODE_NETWORK,
|
|
DEVLINK_ESWITCH_INLINE_MODE_TRANSPORT,
|
|
};
|
|
|
|
enum devlink_eswitch_encap_mode {
|
|
DEVLINK_ESWITCH_ENCAP_MODE_NONE,
|
|
DEVLINK_ESWITCH_ENCAP_MODE_BASIC,
|
|
};
|
|
|
|
enum devlink_port_flavour {
|
|
DEVLINK_PORT_FLAVOUR_PHYSICAL, /* Any kind of a port physically
|
|
* facing the user.
|
|
*/
|
|
DEVLINK_PORT_FLAVOUR_CPU, /* CPU port */
|
|
DEVLINK_PORT_FLAVOUR_DSA, /* Distributed switch architecture
|
|
* interconnect port.
|
|
*/
|
|
};
|
|
|
|
enum devlink_param_cmode {
|
|
DEVLINK_PARAM_CMODE_RUNTIME,
|
|
DEVLINK_PARAM_CMODE_DRIVERINIT,
|
|
DEVLINK_PARAM_CMODE_PERMANENT,
|
|
|
|
/* Add new configuration modes above */
|
|
__DEVLINK_PARAM_CMODE_MAX,
|
|
DEVLINK_PARAM_CMODE_MAX = __DEVLINK_PARAM_CMODE_MAX - 1
|
|
};
|
|
|
|
enum devlink_param_fw_load_policy_value {
|
|
DEVLINK_PARAM_FW_LOAD_POLICY_VALUE_DRIVER,
|
|
DEVLINK_PARAM_FW_LOAD_POLICY_VALUE_FLASH,
|
|
};
|
|
|
|
enum devlink_attr {
|
|
/* don't change the order or add anything between, this is ABI! */
|
|
DEVLINK_ATTR_UNSPEC,
|
|
|
|
/* bus name + dev name together are a handle for devlink entity */
|
|
DEVLINK_ATTR_BUS_NAME, /* string */
|
|
DEVLINK_ATTR_DEV_NAME, /* string */
|
|
|
|
DEVLINK_ATTR_PORT_INDEX, /* u32 */
|
|
DEVLINK_ATTR_PORT_TYPE, /* u16 */
|
|
DEVLINK_ATTR_PORT_DESIRED_TYPE, /* u16 */
|
|
DEVLINK_ATTR_PORT_NETDEV_IFINDEX, /* u32 */
|
|
DEVLINK_ATTR_PORT_NETDEV_NAME, /* string */
|
|
DEVLINK_ATTR_PORT_IBDEV_NAME, /* string */
|
|
DEVLINK_ATTR_PORT_SPLIT_COUNT, /* u32 */
|
|
DEVLINK_ATTR_PORT_SPLIT_GROUP, /* u32 */
|
|
DEVLINK_ATTR_SB_INDEX, /* u32 */
|
|
DEVLINK_ATTR_SB_SIZE, /* u32 */
|
|
DEVLINK_ATTR_SB_INGRESS_POOL_COUNT, /* u16 */
|
|
DEVLINK_ATTR_SB_EGRESS_POOL_COUNT, /* u16 */
|
|
DEVLINK_ATTR_SB_INGRESS_TC_COUNT, /* u16 */
|
|
DEVLINK_ATTR_SB_EGRESS_TC_COUNT, /* u16 */
|
|
DEVLINK_ATTR_SB_POOL_INDEX, /* u16 */
|
|
DEVLINK_ATTR_SB_POOL_TYPE, /* u8 */
|
|
DEVLINK_ATTR_SB_POOL_SIZE, /* u32 */
|
|
DEVLINK_ATTR_SB_POOL_THRESHOLD_TYPE, /* u8 */
|
|
DEVLINK_ATTR_SB_THRESHOLD, /* u32 */
|
|
DEVLINK_ATTR_SB_TC_INDEX, /* u16 */
|
|
DEVLINK_ATTR_SB_OCC_CUR, /* u32 */
|
|
DEVLINK_ATTR_SB_OCC_MAX, /* u32 */
|
|
DEVLINK_ATTR_ESWITCH_MODE, /* u16 */
|
|
DEVLINK_ATTR_ESWITCH_INLINE_MODE, /* u8 */
|
|
|
|
DEVLINK_ATTR_DPIPE_TABLES, /* nested */
|
|
DEVLINK_ATTR_DPIPE_TABLE, /* nested */
|
|
DEVLINK_ATTR_DPIPE_TABLE_NAME, /* string */
|
|
DEVLINK_ATTR_DPIPE_TABLE_SIZE, /* u64 */
|
|
DEVLINK_ATTR_DPIPE_TABLE_MATCHES, /* nested */
|
|
DEVLINK_ATTR_DPIPE_TABLE_ACTIONS, /* nested */
|
|
DEVLINK_ATTR_DPIPE_TABLE_COUNTERS_ENABLED, /* u8 */
|
|
|
|
DEVLINK_ATTR_DPIPE_ENTRIES, /* nested */
|
|
DEVLINK_ATTR_DPIPE_ENTRY, /* nested */
|
|
DEVLINK_ATTR_DPIPE_ENTRY_INDEX, /* u64 */
|
|
DEVLINK_ATTR_DPIPE_ENTRY_MATCH_VALUES, /* nested */
|
|
DEVLINK_ATTR_DPIPE_ENTRY_ACTION_VALUES, /* nested */
|
|
DEVLINK_ATTR_DPIPE_ENTRY_COUNTER, /* u64 */
|
|
|
|
DEVLINK_ATTR_DPIPE_MATCH, /* nested */
|
|
DEVLINK_ATTR_DPIPE_MATCH_VALUE, /* nested */
|
|
DEVLINK_ATTR_DPIPE_MATCH_TYPE, /* u32 */
|
|
|
|
DEVLINK_ATTR_DPIPE_ACTION, /* nested */
|
|
DEVLINK_ATTR_DPIPE_ACTION_VALUE, /* nested */
|
|
DEVLINK_ATTR_DPIPE_ACTION_TYPE, /* u32 */
|
|
|
|
DEVLINK_ATTR_DPIPE_VALUE,
|
|
DEVLINK_ATTR_DPIPE_VALUE_MASK,
|
|
DEVLINK_ATTR_DPIPE_VALUE_MAPPING, /* u32 */
|
|
|
|
DEVLINK_ATTR_DPIPE_HEADERS, /* nested */
|
|
DEVLINK_ATTR_DPIPE_HEADER, /* nested */
|
|
DEVLINK_ATTR_DPIPE_HEADER_NAME, /* string */
|
|
DEVLINK_ATTR_DPIPE_HEADER_ID, /* u32 */
|
|
DEVLINK_ATTR_DPIPE_HEADER_FIELDS, /* nested */
|
|
DEVLINK_ATTR_DPIPE_HEADER_GLOBAL, /* u8 */
|
|
DEVLINK_ATTR_DPIPE_HEADER_INDEX, /* u32 */
|
|
|
|
DEVLINK_ATTR_DPIPE_FIELD, /* nested */
|
|
DEVLINK_ATTR_DPIPE_FIELD_NAME, /* string */
|
|
DEVLINK_ATTR_DPIPE_FIELD_ID, /* u32 */
|
|
DEVLINK_ATTR_DPIPE_FIELD_BITWIDTH, /* u32 */
|
|
DEVLINK_ATTR_DPIPE_FIELD_MAPPING_TYPE, /* u32 */
|
|
|
|
DEVLINK_ATTR_PAD,
|
|
|
|
DEVLINK_ATTR_ESWITCH_ENCAP_MODE, /* u8 */
|
|
DEVLINK_ATTR_RESOURCE_LIST, /* nested */
|
|
DEVLINK_ATTR_RESOURCE, /* nested */
|
|
DEVLINK_ATTR_RESOURCE_NAME, /* string */
|
|
DEVLINK_ATTR_RESOURCE_ID, /* u64 */
|
|
DEVLINK_ATTR_RESOURCE_SIZE, /* u64 */
|
|
DEVLINK_ATTR_RESOURCE_SIZE_NEW, /* u64 */
|
|
DEVLINK_ATTR_RESOURCE_SIZE_VALID, /* u8 */
|
|
DEVLINK_ATTR_RESOURCE_SIZE_MIN, /* u64 */
|
|
DEVLINK_ATTR_RESOURCE_SIZE_MAX, /* u64 */
|
|
DEVLINK_ATTR_RESOURCE_SIZE_GRAN, /* u64 */
|
|
DEVLINK_ATTR_RESOURCE_UNIT, /* u8 */
|
|
DEVLINK_ATTR_RESOURCE_OCC, /* u64 */
|
|
DEVLINK_ATTR_DPIPE_TABLE_RESOURCE_ID, /* u64 */
|
|
DEVLINK_ATTR_DPIPE_TABLE_RESOURCE_UNITS,/* u64 */
|
|
|
|
DEVLINK_ATTR_PORT_FLAVOUR, /* u16 */
|
|
DEVLINK_ATTR_PORT_NUMBER, /* u32 */
|
|
DEVLINK_ATTR_PORT_SPLIT_SUBPORT_NUMBER, /* u32 */
|
|
|
|
DEVLINK_ATTR_PARAM, /* nested */
|
|
DEVLINK_ATTR_PARAM_NAME, /* string */
|
|
DEVLINK_ATTR_PARAM_GENERIC, /* flag */
|
|
DEVLINK_ATTR_PARAM_TYPE, /* u8 */
|
|
DEVLINK_ATTR_PARAM_VALUES_LIST, /* nested */
|
|
DEVLINK_ATTR_PARAM_VALUE, /* nested */
|
|
DEVLINK_ATTR_PARAM_VALUE_DATA, /* dynamic */
|
|
DEVLINK_ATTR_PARAM_VALUE_CMODE, /* u8 */
|
|
|
|
DEVLINK_ATTR_REGION_NAME, /* string */
|
|
DEVLINK_ATTR_REGION_SIZE, /* u64 */
|
|
DEVLINK_ATTR_REGION_SNAPSHOTS, /* nested */
|
|
DEVLINK_ATTR_REGION_SNAPSHOT, /* nested */
|
|
DEVLINK_ATTR_REGION_SNAPSHOT_ID, /* u32 */
|
|
|
|
DEVLINK_ATTR_REGION_CHUNKS, /* nested */
|
|
DEVLINK_ATTR_REGION_CHUNK, /* nested */
|
|
DEVLINK_ATTR_REGION_CHUNK_DATA, /* binary */
|
|
DEVLINK_ATTR_REGION_CHUNK_ADDR, /* u64 */
|
|
DEVLINK_ATTR_REGION_CHUNK_LEN, /* u64 */
|
|
|
|
DEVLINK_ATTR_INFO_DRIVER_NAME, /* string */
|
|
DEVLINK_ATTR_INFO_SERIAL_NUMBER, /* string */
|
|
DEVLINK_ATTR_INFO_VERSION_FIXED, /* nested */
|
|
DEVLINK_ATTR_INFO_VERSION_RUNNING, /* nested */
|
|
DEVLINK_ATTR_INFO_VERSION_STORED, /* nested */
|
|
DEVLINK_ATTR_INFO_VERSION_NAME, /* string */
|
|
DEVLINK_ATTR_INFO_VERSION_VALUE, /* string */
|
|
|
|
DEVLINK_ATTR_SB_POOL_CELL_SIZE, /* u32 */
|
|
|
|
DEVLINK_ATTR_FMSG, /* nested */
|
|
DEVLINK_ATTR_FMSG_OBJ_NEST_START, /* flag */
|
|
DEVLINK_ATTR_FMSG_PAIR_NEST_START, /* flag */
|
|
DEVLINK_ATTR_FMSG_ARR_NEST_START, /* flag */
|
|
DEVLINK_ATTR_FMSG_NEST_END, /* flag */
|
|
DEVLINK_ATTR_FMSG_OBJ_NAME, /* string */
|
|
DEVLINK_ATTR_FMSG_OBJ_VALUE_TYPE, /* u8 */
|
|
DEVLINK_ATTR_FMSG_OBJ_VALUE_DATA, /* dynamic */
|
|
/* add new attributes above here, update the policy in devlink.c */
|
|
|
|
__DEVLINK_ATTR_MAX,
|
|
DEVLINK_ATTR_MAX = __DEVLINK_ATTR_MAX - 1
|
|
};
|
|
|
|
/* Mapping between internal resource described by the field and system
|
|
* structure
|
|
*/
|
|
enum devlink_dpipe_field_mapping_type {
|
|
DEVLINK_DPIPE_FIELD_MAPPING_TYPE_NONE,
|
|
DEVLINK_DPIPE_FIELD_MAPPING_TYPE_IFINDEX,
|
|
};
|
|
|
|
/* Match type - specify the type of the match */
|
|
enum devlink_dpipe_match_type {
|
|
DEVLINK_DPIPE_MATCH_TYPE_FIELD_EXACT,
|
|
};
|
|
|
|
/* Action type - specify the action type */
|
|
enum devlink_dpipe_action_type {
|
|
DEVLINK_DPIPE_ACTION_TYPE_FIELD_MODIFY,
|
|
};
|
|
|
|
enum devlink_dpipe_field_ethernet_id {
|
|
DEVLINK_DPIPE_FIELD_ETHERNET_DST_MAC,
|
|
};
|
|
|
|
enum devlink_dpipe_field_ipv4_id {
|
|
DEVLINK_DPIPE_FIELD_IPV4_DST_IP,
|
|
};
|
|
|
|
enum devlink_dpipe_field_ipv6_id {
|
|
DEVLINK_DPIPE_FIELD_IPV6_DST_IP,
|
|
};
|
|
|
|
enum devlink_dpipe_header_id {
|
|
DEVLINK_DPIPE_HEADER_ETHERNET,
|
|
DEVLINK_DPIPE_HEADER_IPV4,
|
|
DEVLINK_DPIPE_HEADER_IPV6,
|
|
};
|
|
|
|
enum devlink_resource_unit {
|
|
DEVLINK_RESOURCE_UNIT_ENTRY,
|
|
};
|
|
|
|
#endif /* _UAPI_LINUX_DEVLINK_H_ */
|