2017-11-01 22:08:43 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
2012-11-21 23:47:40 +08:00
|
|
|
#ifndef _UAPI_RDMA_NETLINK_H
|
|
|
|
#define _UAPI_RDMA_NETLINK_H
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
|
|
|
enum {
|
2019-01-16 15:55:41 +08:00
|
|
|
RDMA_NL_IWCM = 2,
|
2016-02-26 23:18:00 +08:00
|
|
|
RDMA_NL_RSVD,
|
2015-08-14 20:52:06 +08:00
|
|
|
RDMA_NL_LS, /* RDMA Local Services */
|
2017-06-20 12:55:53 +08:00
|
|
|
RDMA_NL_NLDEV, /* RDMA device interface */
|
2014-03-27 06:07:35 +08:00
|
|
|
RDMA_NL_NUM_CLIENTS
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
2019-01-16 15:55:41 +08:00
|
|
|
RDMA_NL_GROUP_IWPM = 2,
|
2015-08-14 20:52:06 +08:00
|
|
|
RDMA_NL_GROUP_LS,
|
2014-03-27 06:07:35 +08:00
|
|
|
RDMA_NL_NUM_GROUPS
|
2012-11-21 23:47:40 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#define RDMA_NL_GET_CLIENT(type) ((type & (((1 << 6) - 1) << 10)) >> 10)
|
|
|
|
#define RDMA_NL_GET_OP(type) (type & ((1 << 10) - 1))
|
|
|
|
#define RDMA_NL_GET_TYPE(client, op) ((client << 10) + op)
|
|
|
|
|
2019-01-30 05:33:16 +08:00
|
|
|
/* The minimum version that the iwpm kernel supports */
|
|
|
|
#define IWPM_UABI_VERSION_MIN 3
|
|
|
|
|
|
|
|
/* The latest version that the iwpm kernel supports */
|
|
|
|
#define IWPM_UABI_VERSION 4
|
|
|
|
|
|
|
|
/* iwarp port mapper message flags */
|
|
|
|
enum {
|
|
|
|
|
|
|
|
/* Do not map the port for this IWPM request */
|
|
|
|
IWPM_FLAGS_NO_PORT_MAP = (1 << 0),
|
|
|
|
};
|
|
|
|
|
2014-03-27 06:07:35 +08:00
|
|
|
/* iwarp port mapper op-codes */
|
|
|
|
enum {
|
|
|
|
RDMA_NL_IWPM_REG_PID = 0,
|
|
|
|
RDMA_NL_IWPM_ADD_MAPPING,
|
|
|
|
RDMA_NL_IWPM_QUERY_MAPPING,
|
|
|
|
RDMA_NL_IWPM_REMOVE_MAPPING,
|
2015-04-22 04:28:10 +08:00
|
|
|
RDMA_NL_IWPM_REMOTE_INFO,
|
2014-03-27 06:07:35 +08:00
|
|
|
RDMA_NL_IWPM_HANDLE_ERR,
|
|
|
|
RDMA_NL_IWPM_MAPINFO,
|
|
|
|
RDMA_NL_IWPM_MAPINFO_NUM,
|
2019-01-30 05:33:16 +08:00
|
|
|
RDMA_NL_IWPM_HELLO,
|
2014-03-27 06:07:35 +08:00
|
|
|
RDMA_NL_IWPM_NUM_OPS
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_REG_PID_UNSPEC = 0,
|
|
|
|
IWPM_NLA_REG_PID_SEQ,
|
|
|
|
IWPM_NLA_REG_IF_NAME,
|
|
|
|
IWPM_NLA_REG_IBDEV_NAME,
|
|
|
|
IWPM_NLA_REG_ULIB_NAME,
|
|
|
|
IWPM_NLA_REG_PID_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_RREG_PID_UNSPEC = 0,
|
|
|
|
IWPM_NLA_RREG_PID_SEQ,
|
|
|
|
IWPM_NLA_RREG_IBDEV_NAME,
|
|
|
|
IWPM_NLA_RREG_ULIB_NAME,
|
|
|
|
IWPM_NLA_RREG_ULIB_VER,
|
|
|
|
IWPM_NLA_RREG_PID_ERR,
|
|
|
|
IWPM_NLA_RREG_PID_MAX
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_MANAGE_MAPPING_UNSPEC = 0,
|
|
|
|
IWPM_NLA_MANAGE_MAPPING_SEQ,
|
|
|
|
IWPM_NLA_MANAGE_ADDR,
|
2019-01-30 05:33:16 +08:00
|
|
|
IWPM_NLA_MANAGE_FLAGS,
|
2019-01-30 05:33:11 +08:00
|
|
|
IWPM_NLA_MANAGE_MAPPING_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_RMANAGE_MAPPING_UNSPEC = 0,
|
|
|
|
IWPM_NLA_RMANAGE_MAPPING_SEQ,
|
|
|
|
IWPM_NLA_RMANAGE_ADDR,
|
|
|
|
IWPM_NLA_RMANAGE_MAPPED_LOC_ADDR,
|
|
|
|
/* The following maintains bisectability of rdma-core */
|
|
|
|
IWPM_NLA_MANAGE_MAPPED_LOC_ADDR = IWPM_NLA_RMANAGE_MAPPED_LOC_ADDR,
|
2014-03-27 06:07:35 +08:00
|
|
|
IWPM_NLA_RMANAGE_MAPPING_ERR,
|
|
|
|
IWPM_NLA_RMANAGE_MAPPING_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
#define IWPM_NLA_MAPINFO_SEND_MAX 3
|
2019-01-30 05:33:16 +08:00
|
|
|
#define IWPM_NLA_REMOVE_MAPPING_MAX 3
|
2014-03-27 06:07:35 +08:00
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_QUERY_MAPPING_UNSPEC = 0,
|
|
|
|
IWPM_NLA_QUERY_MAPPING_SEQ,
|
|
|
|
IWPM_NLA_QUERY_LOCAL_ADDR,
|
|
|
|
IWPM_NLA_QUERY_REMOTE_ADDR,
|
2019-01-30 05:33:16 +08:00
|
|
|
IWPM_NLA_QUERY_FLAGS,
|
2019-01-30 05:33:11 +08:00
|
|
|
IWPM_NLA_QUERY_MAPPING_MAX,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_RQUERY_MAPPING_UNSPEC = 0,
|
|
|
|
IWPM_NLA_RQUERY_MAPPING_SEQ,
|
|
|
|
IWPM_NLA_RQUERY_LOCAL_ADDR,
|
|
|
|
IWPM_NLA_RQUERY_REMOTE_ADDR,
|
2014-03-27 06:07:35 +08:00
|
|
|
IWPM_NLA_RQUERY_MAPPED_LOC_ADDR,
|
|
|
|
IWPM_NLA_RQUERY_MAPPED_REM_ADDR,
|
|
|
|
IWPM_NLA_RQUERY_MAPPING_ERR,
|
|
|
|
IWPM_NLA_RQUERY_MAPPING_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_MAPINFO_REQ_UNSPEC = 0,
|
|
|
|
IWPM_NLA_MAPINFO_ULIB_NAME,
|
|
|
|
IWPM_NLA_MAPINFO_ULIB_VER,
|
|
|
|
IWPM_NLA_MAPINFO_REQ_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_MAPINFO_UNSPEC = 0,
|
|
|
|
IWPM_NLA_MAPINFO_LOCAL_ADDR,
|
|
|
|
IWPM_NLA_MAPINFO_MAPPED_ADDR,
|
2019-01-30 05:33:16 +08:00
|
|
|
IWPM_NLA_MAPINFO_FLAGS,
|
2014-03-27 06:07:35 +08:00
|
|
|
IWPM_NLA_MAPINFO_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_MAPINFO_NUM_UNSPEC = 0,
|
|
|
|
IWPM_NLA_MAPINFO_SEQ,
|
|
|
|
IWPM_NLA_MAPINFO_SEND_NUM,
|
|
|
|
IWPM_NLA_MAPINFO_ACK_NUM,
|
|
|
|
IWPM_NLA_MAPINFO_NUM_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
IWPM_NLA_ERR_UNSPEC = 0,
|
|
|
|
IWPM_NLA_ERR_SEQ,
|
|
|
|
IWPM_NLA_ERR_CODE,
|
|
|
|
IWPM_NLA_ERR_MAX
|
|
|
|
};
|
|
|
|
|
2019-01-30 05:33:16 +08:00
|
|
|
enum {
|
|
|
|
IWPM_NLA_HELLO_UNSPEC = 0,
|
|
|
|
IWPM_NLA_HELLO_ABI_VERSION,
|
|
|
|
IWPM_NLA_HELLO_MAX
|
|
|
|
};
|
|
|
|
|
2019-06-14 08:38:17 +08:00
|
|
|
/* For RDMA_NLDEV_ATTR_DEV_NODE_TYPE */
|
|
|
|
enum {
|
|
|
|
/* IB values map to NodeInfo:NodeType. */
|
|
|
|
RDMA_NODE_IB_CA = 1,
|
|
|
|
RDMA_NODE_IB_SWITCH,
|
|
|
|
RDMA_NODE_IB_ROUTER,
|
|
|
|
RDMA_NODE_RNIC,
|
|
|
|
RDMA_NODE_USNIC,
|
|
|
|
RDMA_NODE_USNIC_UDP,
|
|
|
|
RDMA_NODE_UNSPECIFIED,
|
|
|
|
};
|
|
|
|
|
2015-08-14 20:52:06 +08:00
|
|
|
/*
|
|
|
|
* Local service operations:
|
|
|
|
* RESOLVE - The client requests the local service to resolve a path.
|
|
|
|
* SET_TIMEOUT - The local service requests the client to set the timeout.
|
2016-05-19 22:12:34 +08:00
|
|
|
* IP_RESOLVE - The client requests the local service to resolve an IP to GID.
|
2015-08-14 20:52:06 +08:00
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
RDMA_NL_LS_OP_RESOLVE = 0,
|
|
|
|
RDMA_NL_LS_OP_SET_TIMEOUT,
|
2016-05-19 22:12:34 +08:00
|
|
|
RDMA_NL_LS_OP_IP_RESOLVE,
|
2015-08-14 20:52:06 +08:00
|
|
|
RDMA_NL_LS_NUM_OPS
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Local service netlink message flags */
|
|
|
|
#define RDMA_NL_LS_F_ERR 0x0100 /* Failed response */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Local service resolve operation family header.
|
|
|
|
* The layout for the resolve operation:
|
|
|
|
* nlmsg header
|
|
|
|
* family header
|
|
|
|
* attributes
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Local service path use:
|
|
|
|
* Specify how the path(s) will be used.
|
|
|
|
* ALL - For connected CM operation (6 pathrecords)
|
|
|
|
* UNIDIRECTIONAL - For unidirectional UD (1 pathrecord)
|
|
|
|
* GMP - For miscellaneous GMP like operation (at least 1 reversible
|
|
|
|
* pathrecord)
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
LS_RESOLVE_PATH_USE_ALL = 0,
|
|
|
|
LS_RESOLVE_PATH_USE_UNIDIRECTIONAL,
|
|
|
|
LS_RESOLVE_PATH_USE_GMP,
|
|
|
|
LS_RESOLVE_PATH_USE_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
#define LS_DEVICE_NAME_MAX 64
|
|
|
|
|
|
|
|
struct rdma_ls_resolve_header {
|
|
|
|
__u8 device_name[LS_DEVICE_NAME_MAX];
|
|
|
|
__u8 port_num;
|
|
|
|
__u8 path_use;
|
|
|
|
};
|
|
|
|
|
2016-05-19 22:12:34 +08:00
|
|
|
struct rdma_ls_ip_resolve_header {
|
|
|
|
__u32 ifindex;
|
|
|
|
};
|
|
|
|
|
2015-08-14 20:52:06 +08:00
|
|
|
/* Local service attribute type */
|
|
|
|
#define RDMA_NLA_F_MANDATORY (1 << 13)
|
|
|
|
#define RDMA_NLA_TYPE_MASK (~(NLA_F_NESTED | NLA_F_NET_BYTEORDER | \
|
|
|
|
RDMA_NLA_F_MANDATORY))
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Local service attributes:
|
|
|
|
* Attr Name Size Byte order
|
|
|
|
* -----------------------------------------------------
|
|
|
|
* PATH_RECORD struct ib_path_rec_data
|
|
|
|
* TIMEOUT u32 cpu
|
|
|
|
* SERVICE_ID u64 cpu
|
|
|
|
* DGID u8[16] BE
|
|
|
|
* SGID u8[16] BE
|
|
|
|
* TCLASS u8
|
|
|
|
* PKEY u16 cpu
|
|
|
|
* QOS_CLASS u16 cpu
|
2016-05-19 22:12:34 +08:00
|
|
|
* IPV4 u32 BE
|
|
|
|
* IPV6 u8[16] BE
|
2015-08-14 20:52:06 +08:00
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
LS_NLA_TYPE_UNSPEC = 0,
|
|
|
|
LS_NLA_TYPE_PATH_RECORD,
|
|
|
|
LS_NLA_TYPE_TIMEOUT,
|
|
|
|
LS_NLA_TYPE_SERVICE_ID,
|
|
|
|
LS_NLA_TYPE_DGID,
|
|
|
|
LS_NLA_TYPE_SGID,
|
|
|
|
LS_NLA_TYPE_TCLASS,
|
|
|
|
LS_NLA_TYPE_PKEY,
|
|
|
|
LS_NLA_TYPE_QOS_CLASS,
|
2016-05-19 22:12:34 +08:00
|
|
|
LS_NLA_TYPE_IPV4,
|
|
|
|
LS_NLA_TYPE_IPV6,
|
2015-08-14 20:52:06 +08:00
|
|
|
LS_NLA_TYPE_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Local service DGID/SGID attribute: big endian */
|
|
|
|
struct rdma_nla_ls_gid {
|
|
|
|
__u8 gid[16];
|
|
|
|
};
|
2012-11-21 23:47:40 +08:00
|
|
|
|
2017-06-20 12:55:53 +08:00
|
|
|
enum rdma_nldev_command {
|
|
|
|
RDMA_NLDEV_CMD_UNSPEC,
|
|
|
|
|
|
|
|
RDMA_NLDEV_CMD_GET, /* can dump */
|
2018-10-10 14:19:12 +08:00
|
|
|
RDMA_NLDEV_CMD_SET,
|
2017-06-20 12:55:53 +08:00
|
|
|
|
2019-02-16 03:03:53 +08:00
|
|
|
RDMA_NLDEV_CMD_NEWLINK,
|
2017-06-20 12:55:53 +08:00
|
|
|
|
2019-02-16 03:03:53 +08:00
|
|
|
RDMA_NLDEV_CMD_DELLINK,
|
|
|
|
|
|
|
|
RDMA_NLDEV_CMD_PORT_GET, /* can dump */
|
2018-01-30 23:07:16 +08:00
|
|
|
|
2019-05-13 13:26:57 +08:00
|
|
|
RDMA_NLDEV_CMD_SYS_GET,
|
2019-02-26 20:01:49 +08:00
|
|
|
RDMA_NLDEV_CMD_SYS_SET,
|
|
|
|
|
|
|
|
/* 8 is free to use */
|
2018-01-30 23:07:16 +08:00
|
|
|
|
|
|
|
RDMA_NLDEV_CMD_RES_GET = 9, /* can dump */
|
2018-01-28 17:17:24 +08:00
|
|
|
|
2018-01-28 17:17:25 +08:00
|
|
|
RDMA_NLDEV_CMD_RES_QP_GET, /* can dump */
|
|
|
|
|
2018-03-02 05:57:44 +08:00
|
|
|
RDMA_NLDEV_CMD_RES_CM_ID_GET, /* can dump */
|
|
|
|
|
2018-03-02 05:57:51 +08:00
|
|
|
RDMA_NLDEV_CMD_RES_CQ_GET, /* can dump */
|
|
|
|
|
2018-03-02 05:58:13 +08:00
|
|
|
RDMA_NLDEV_CMD_RES_MR_GET, /* can dump */
|
|
|
|
|
2018-03-02 05:58:28 +08:00
|
|
|
RDMA_NLDEV_CMD_RES_PD_GET, /* can dump */
|
|
|
|
|
2019-06-14 08:38:18 +08:00
|
|
|
RDMA_NLDEV_CMD_GET_CHARDEV,
|
|
|
|
|
2019-07-02 18:02:39 +08:00
|
|
|
RDMA_NLDEV_CMD_STAT_SET,
|
|
|
|
|
2017-06-20 12:55:53 +08:00
|
|
|
RDMA_NLDEV_NUM_OPS
|
|
|
|
};
|
|
|
|
|
RDMA/nldev: add driver-specific resource tracking
Each driver can register a "fill entry" function with the restrack core.
This function will be called when filling out a resource, allowing the
driver to add driver-specific details. The details consist of a
nltable of nested attributes, that are in the form of <key, [print-type],
value> tuples. Both key and value attributes are mandatory. The key
nlattr must be a string, and the value nlattr can be one of the driver
attributes that are generic, but typed, allowing the attributes to be
validated. Currently the driver nlattr types include string, s32,
u32, s64, and u64. The print-type nlattr allows a driver to specify
an alternative display format for user tools displaying the attribute.
For example, a u32 attribute will default to "%u", but a print-type
attribute can be included for it to be displayed in hex. This allows
the user tool to print the number in the format desired by the driver
driver.
More attrs can be defined as they become needed by drivers.
Signed-off-by: Steve Wise <swise@opengridcomputing.com>
Reviewed-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
2018-05-03 23:41:30 +08:00
|
|
|
enum rdma_nldev_print_type {
|
|
|
|
RDMA_NLDEV_PRINT_TYPE_UNSPEC,
|
|
|
|
RDMA_NLDEV_PRINT_TYPE_HEX,
|
|
|
|
};
|
|
|
|
|
2017-06-20 12:55:53 +08:00
|
|
|
enum rdma_nldev_attr {
|
|
|
|
/* don't change the order or add anything between, this is ABI! */
|
|
|
|
RDMA_NLDEV_ATTR_UNSPEC,
|
|
|
|
|
2018-05-03 23:40:49 +08:00
|
|
|
/* Pad attribute for 64b alignment */
|
|
|
|
RDMA_NLDEV_ATTR_PAD = RDMA_NLDEV_ATTR_UNSPEC,
|
|
|
|
|
2017-06-20 12:55:53 +08:00
|
|
|
/* Identifier for ib_device */
|
|
|
|
RDMA_NLDEV_ATTR_DEV_INDEX, /* u32 */
|
|
|
|
|
|
|
|
RDMA_NLDEV_ATTR_DEV_NAME, /* string */
|
|
|
|
/*
|
|
|
|
* Device index together with port index are identifiers
|
|
|
|
* for port/link properties.
|
|
|
|
*
|
|
|
|
* For RDMA_NLDEV_CMD_GET commamnd, port index will return number
|
|
|
|
* of available ports in ib_device, while for port specific operations,
|
|
|
|
* it will be real port index as it appears in sysfs. Port index follows
|
|
|
|
* sysfs notation and starts from 1 for the first port.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_PORT_INDEX, /* u32 */
|
|
|
|
|
2017-06-20 19:47:08 +08:00
|
|
|
/*
|
|
|
|
* Device and port capabilities
|
2018-12-09 17:58:05 +08:00
|
|
|
*
|
|
|
|
* When used for port info, first 32-bits are CapabilityMask followed by
|
|
|
|
* 16-bit CapabilityMask2.
|
2017-06-20 19:47:08 +08:00
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_CAP_FLAGS, /* u64 */
|
|
|
|
|
2017-06-27 21:58:59 +08:00
|
|
|
/*
|
|
|
|
* FW version
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_FW_VERSION, /* string */
|
2017-06-28 19:01:37 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Node GUID (in host byte order) associated with the RDMA device.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_NODE_GUID, /* u64 */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* System image GUID (in host byte order) associated with
|
|
|
|
* this RDMA device and other devices which are part of a
|
|
|
|
* single system.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_SYS_IMAGE_GUID, /* u64 */
|
|
|
|
|
2017-06-28 20:05:14 +08:00
|
|
|
/*
|
|
|
|
* Subnet prefix (in host byte order)
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_SUBNET_PREFIX, /* u64 */
|
|
|
|
|
2017-06-28 20:38:36 +08:00
|
|
|
/*
|
|
|
|
* Local Identifier (LID),
|
|
|
|
* According to IB specification, It is 16-bit address assigned
|
|
|
|
* by the Subnet Manager. Extended to be 32-bit for OmniPath users.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_LID, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_SM_LID, /* u32 */
|
|
|
|
|
2017-06-28 20:49:30 +08:00
|
|
|
/*
|
|
|
|
* LID mask control (LMC)
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_LMC, /* u8 */
|
|
|
|
|
2017-06-29 18:12:45 +08:00
|
|
|
RDMA_NLDEV_ATTR_PORT_STATE, /* u8 */
|
|
|
|
RDMA_NLDEV_ATTR_PORT_PHYS_STATE, /* u8 */
|
|
|
|
|
2017-06-29 21:01:29 +08:00
|
|
|
RDMA_NLDEV_ATTR_DEV_NODE_TYPE, /* u8 */
|
|
|
|
|
2018-01-28 17:17:24 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_SUMMARY, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_SUMMARY_ENTRY, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_SUMMARY_ENTRY_NAME, /* string */
|
|
|
|
RDMA_NLDEV_ATTR_RES_SUMMARY_ENTRY_CURR, /* u64 */
|
|
|
|
|
2018-01-28 17:17:25 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_QP, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_QP_ENTRY, /* nested table */
|
|
|
|
/*
|
|
|
|
* Local QPN
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_LQPN, /* u32 */
|
|
|
|
/*
|
|
|
|
* Remote QPN,
|
|
|
|
* Applicable for RC and UC only IBTA 11.2.5.3 QUERY QUEUE PAIR
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_RQPN, /* u32 */
|
|
|
|
/*
|
|
|
|
* Receive Queue PSN,
|
|
|
|
* Applicable for RC and UC only 11.2.5.3 QUERY QUEUE PAIR
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_RQ_PSN, /* u32 */
|
|
|
|
/*
|
|
|
|
* Send Queue PSN
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_SQ_PSN, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_PATH_MIG_STATE, /* u8 */
|
|
|
|
/*
|
|
|
|
* QP types as visible to RDMA/core, the reserved QPT
|
|
|
|
* are not exported through this interface.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_TYPE, /* u8 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_STATE, /* u8 */
|
|
|
|
/*
|
|
|
|
* Process ID which created object,
|
|
|
|
* in case of kernel origin, PID won't exist.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_PID, /* u32 */
|
|
|
|
/*
|
|
|
|
* The name of process created following resource.
|
|
|
|
* It will exist only for kernel objects.
|
|
|
|
* For user created objects, the user is supposed
|
|
|
|
* to read /proc/PID/comm file.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_KERN_NAME, /* string */
|
|
|
|
|
2018-03-02 05:57:44 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_CM_ID, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_CM_ID_ENTRY, /* nested table */
|
|
|
|
/*
|
|
|
|
* rdma_cm_id port space.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_PS, /* u32 */
|
|
|
|
/*
|
|
|
|
* Source and destination socket addresses
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_SRC_ADDR, /* __kernel_sockaddr_storage */
|
|
|
|
RDMA_NLDEV_ATTR_RES_DST_ADDR, /* __kernel_sockaddr_storage */
|
|
|
|
|
2018-03-02 05:57:51 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_CQ, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_CQ_ENTRY, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_CQE, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_USECNT, /* u64 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_POLL_CTX, /* u8 */
|
|
|
|
|
2018-03-02 05:58:13 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_MR, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_MR_ENTRY, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_RKEY, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_LKEY, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_IOVA, /* u64 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_MRLEN, /* u64 */
|
|
|
|
|
2018-03-02 05:58:28 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_PD, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_PD_ENTRY, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_RES_LOCAL_DMA_LKEY, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_UNSAFE_GLOBAL_RKEY, /* u32 */
|
2018-05-16 03:54:46 +08:00
|
|
|
/*
|
|
|
|
* Provides logical name and index of netdevice which is
|
|
|
|
* connected to physical port. This information is relevant
|
|
|
|
* for RoCE and iWARP.
|
|
|
|
*
|
|
|
|
* The netdevices which are associated with containers are
|
|
|
|
* supposed to be exported together with GID table once it
|
|
|
|
* will be exposed through the netlink. Because the
|
|
|
|
* associated netdevices are properties of GIDs.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_NDEV_INDEX, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_NDEV_NAME, /* string */
|
RDMA/nldev: add driver-specific resource tracking
Each driver can register a "fill entry" function with the restrack core.
This function will be called when filling out a resource, allowing the
driver to add driver-specific details. The details consist of a
nltable of nested attributes, that are in the form of <key, [print-type],
value> tuples. Both key and value attributes are mandatory. The key
nlattr must be a string, and the value nlattr can be one of the driver
attributes that are generic, but typed, allowing the attributes to be
validated. Currently the driver nlattr types include string, s32,
u32, s64, and u64. The print-type nlattr allows a driver to specify
an alternative display format for user tools displaying the attribute.
For example, a u32 attribute will default to "%u", but a print-type
attribute can be included for it to be displayed in hex. This allows
the user tool to print the number in the format desired by the driver
driver.
More attrs can be defined as they become needed by drivers.
Signed-off-by: Steve Wise <swise@opengridcomputing.com>
Reviewed-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Doug Ledford <dledford@redhat.com>
2018-05-03 23:41:30 +08:00
|
|
|
/*
|
|
|
|
* driver-specific attributes.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_ENTRY, /* nested table */
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_STRING, /* string */
|
|
|
|
/*
|
|
|
|
* u8 values from enum rdma_nldev_print_type
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_PRINT_TYPE, /* u8 */
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_S32, /* s32 */
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_U32, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_S64, /* s64 */
|
|
|
|
RDMA_NLDEV_ATTR_DRIVER_U64, /* u64 */
|
2018-03-02 05:58:28 +08:00
|
|
|
|
2019-02-19 04:25:49 +08:00
|
|
|
/*
|
|
|
|
* Indexes to get/set secific entry,
|
|
|
|
* for QP use RDMA_NLDEV_ATTR_RES_LQPN
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_RES_PDN, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_CQN, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_MRN, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_RES_CM_IDN, /* u32 */
|
2019-02-19 04:25:50 +08:00
|
|
|
RDMA_NLDEV_ATTR_RES_CTXN, /* u32 */
|
2019-02-16 03:03:53 +08:00
|
|
|
/*
|
|
|
|
* Identifies the rdma driver. eg: "rxe" or "siw"
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_LINK_TYPE, /* string */
|
2019-02-19 04:25:49 +08:00
|
|
|
|
2019-02-26 20:01:48 +08:00
|
|
|
/*
|
|
|
|
* net namespace mode for rdma subsystem:
|
|
|
|
* either shared or exclusive among multiple net namespaces.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_SYS_ATTR_NETNS_MODE, /* u8 */
|
2019-04-03 02:50:34 +08:00
|
|
|
/*
|
|
|
|
* Device protocol, e.g. ib, iw, usnic, roce and opa
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_DEV_PROTOCOL, /* string */
|
|
|
|
|
2019-04-15 18:22:51 +08:00
|
|
|
/*
|
|
|
|
* File descriptor handle of the net namespace object
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_NET_NS_FD, /* u32 */
|
2019-07-02 18:02:39 +08:00
|
|
|
/*
|
|
|
|
* Counter-specific attributes.
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_STAT_MODE, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_STAT_RES, /* u32 */
|
|
|
|
RDMA_NLDEV_ATTR_STAT_AUTO_MODE_MASK, /* u32 */
|
2019-04-15 18:22:51 +08:00
|
|
|
|
2019-06-14 08:38:18 +08:00
|
|
|
/*
|
|
|
|
* Information about a chardev.
|
|
|
|
* CHARDEV_TYPE is the name of the chardev ABI (ie uverbs, umad, etc)
|
|
|
|
* CHARDEV_ABI signals the ABI revision (historical)
|
|
|
|
* CHARDEV_NAME is the kernel name for the /dev/ file (no directory)
|
|
|
|
* CHARDEV is the 64 bit dev_t for the inode
|
|
|
|
*/
|
|
|
|
RDMA_NLDEV_ATTR_CHARDEV_TYPE, /* string */
|
|
|
|
RDMA_NLDEV_ATTR_CHARDEV_NAME, /* string */
|
|
|
|
RDMA_NLDEV_ATTR_CHARDEV_ABI, /* u64 */
|
|
|
|
RDMA_NLDEV_ATTR_CHARDEV, /* u64 */
|
2019-06-14 08:38:19 +08:00
|
|
|
RDMA_NLDEV_ATTR_UVERBS_DRIVER_ID, /* u64 */
|
2019-06-14 08:38:18 +08:00
|
|
|
|
2018-03-28 01:40:49 +08:00
|
|
|
/*
|
2018-05-16 03:54:46 +08:00
|
|
|
* Always the end
|
2018-03-28 01:40:49 +08:00
|
|
|
*/
|
2017-06-20 12:55:53 +08:00
|
|
|
RDMA_NLDEV_ATTR_MAX
|
|
|
|
};
|
2019-07-02 18:02:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Supported counter bind modes. All modes are mutual-exclusive.
|
|
|
|
*/
|
|
|
|
enum rdma_nl_counter_mode {
|
|
|
|
RDMA_COUNTER_MODE_NONE,
|
|
|
|
|
|
|
|
/*
|
|
|
|
* A qp is bound with a counter automatically during initialization
|
|
|
|
* based on the auto mode (e.g., qp type, ...)
|
|
|
|
*/
|
|
|
|
RDMA_COUNTER_MODE_AUTO,
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Always the end
|
|
|
|
*/
|
|
|
|
RDMA_COUNTER_MODE_MAX,
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Supported criteria in counter auto mode.
|
|
|
|
* Currently only "qp type" is supported
|
|
|
|
*/
|
|
|
|
enum rdma_nl_counter_mask {
|
|
|
|
RDMA_COUNTER_MASK_QP_TYPE = 1,
|
|
|
|
};
|
2012-11-21 23:47:40 +08:00
|
|
|
#endif /* _UAPI_RDMA_NETLINK_H */
|