Path: blob/master/include/uapi/rdma/mlx5_user_ioctl_cmds.h
26288 views
/*1* Copyright (c) 2018, Mellanox Technologies inc. All rights reserved.2*3* This software is available to you under a choice of one of two4* licenses. You may choose to be licensed under the terms of the GNU5* General Public License (GPL) Version 2, available from the file6* COPYING in the main directory of this source tree, or the7* OpenIB.org BSD license below:8*9* Redistribution and use in source and binary forms, with or10* without modification, are permitted provided that the following11* conditions are met:12*13* - Redistributions of source code must retain the above14* copyright notice, this list of conditions and the following15* disclaimer.16*17* - Redistributions in binary form must reproduce the above18* copyright notice, this list of conditions and the following19* disclaimer in the documentation and/or other materials20* provided with the distribution.21*22* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,23* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF24* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND25* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS26* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN27* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN28* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE29* SOFTWARE.30*/3132#ifndef MLX5_USER_IOCTL_CMDS_H33#define MLX5_USER_IOCTL_CMDS_H3435#include <linux/types.h>36#include <rdma/ib_user_ioctl_cmds.h>3738enum mlx5_ib_create_flow_action_attrs {39/* This attribute belong to the driver namespace */40MLX5_IB_ATTR_CREATE_FLOW_ACTION_FLAGS = (1U << UVERBS_ID_NS_SHIFT),41};4243enum mlx5_ib_dm_methods {44MLX5_IB_METHOD_DM_MAP_OP_ADDR = (1U << UVERBS_ID_NS_SHIFT),45MLX5_IB_METHOD_DM_QUERY,46};4748enum mlx5_ib_dm_map_op_addr_attrs {49MLX5_IB_ATTR_DM_MAP_OP_ADDR_REQ_HANDLE = (1U << UVERBS_ID_NS_SHIFT),50MLX5_IB_ATTR_DM_MAP_OP_ADDR_REQ_OP,51MLX5_IB_ATTR_DM_MAP_OP_ADDR_RESP_START_OFFSET,52MLX5_IB_ATTR_DM_MAP_OP_ADDR_RESP_PAGE_INDEX,53};5455enum mlx5_ib_query_dm_attrs {56MLX5_IB_ATTR_QUERY_DM_REQ_HANDLE = (1U << UVERBS_ID_NS_SHIFT),57MLX5_IB_ATTR_QUERY_DM_RESP_START_OFFSET,58MLX5_IB_ATTR_QUERY_DM_RESP_PAGE_INDEX,59MLX5_IB_ATTR_QUERY_DM_RESP_LENGTH,60};6162enum mlx5_ib_alloc_dm_attrs {63MLX5_IB_ATTR_ALLOC_DM_RESP_START_OFFSET = (1U << UVERBS_ID_NS_SHIFT),64MLX5_IB_ATTR_ALLOC_DM_RESP_PAGE_INDEX,65MLX5_IB_ATTR_ALLOC_DM_REQ_TYPE,66};6768enum mlx5_ib_devx_methods {69MLX5_IB_METHOD_DEVX_OTHER = (1U << UVERBS_ID_NS_SHIFT),70MLX5_IB_METHOD_DEVX_QUERY_UAR,71MLX5_IB_METHOD_DEVX_QUERY_EQN,72MLX5_IB_METHOD_DEVX_SUBSCRIBE_EVENT,73};7475enum mlx5_ib_devx_other_attrs {76MLX5_IB_ATTR_DEVX_OTHER_CMD_IN = (1U << UVERBS_ID_NS_SHIFT),77MLX5_IB_ATTR_DEVX_OTHER_CMD_OUT,78};7980enum mlx5_ib_devx_obj_create_attrs {81MLX5_IB_ATTR_DEVX_OBJ_CREATE_HANDLE = (1U << UVERBS_ID_NS_SHIFT),82MLX5_IB_ATTR_DEVX_OBJ_CREATE_CMD_IN,83MLX5_IB_ATTR_DEVX_OBJ_CREATE_CMD_OUT,84};8586enum mlx5_ib_devx_query_uar_attrs {87MLX5_IB_ATTR_DEVX_QUERY_UAR_USER_IDX = (1U << UVERBS_ID_NS_SHIFT),88MLX5_IB_ATTR_DEVX_QUERY_UAR_DEV_IDX,89};9091enum mlx5_ib_devx_obj_destroy_attrs {92MLX5_IB_ATTR_DEVX_OBJ_DESTROY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),93};9495enum mlx5_ib_devx_obj_modify_attrs {96MLX5_IB_ATTR_DEVX_OBJ_MODIFY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),97MLX5_IB_ATTR_DEVX_OBJ_MODIFY_CMD_IN,98MLX5_IB_ATTR_DEVX_OBJ_MODIFY_CMD_OUT,99};100101enum mlx5_ib_devx_obj_query_attrs {102MLX5_IB_ATTR_DEVX_OBJ_QUERY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),103MLX5_IB_ATTR_DEVX_OBJ_QUERY_CMD_IN,104MLX5_IB_ATTR_DEVX_OBJ_QUERY_CMD_OUT,105};106107enum mlx5_ib_devx_obj_query_async_attrs {108MLX5_IB_ATTR_DEVX_OBJ_QUERY_ASYNC_HANDLE = (1U << UVERBS_ID_NS_SHIFT),109MLX5_IB_ATTR_DEVX_OBJ_QUERY_ASYNC_CMD_IN,110MLX5_IB_ATTR_DEVX_OBJ_QUERY_ASYNC_FD,111MLX5_IB_ATTR_DEVX_OBJ_QUERY_ASYNC_WR_ID,112MLX5_IB_ATTR_DEVX_OBJ_QUERY_ASYNC_OUT_LEN,113};114115enum mlx5_ib_devx_subscribe_event_attrs {116MLX5_IB_ATTR_DEVX_SUBSCRIBE_EVENT_FD_HANDLE = (1U << UVERBS_ID_NS_SHIFT),117MLX5_IB_ATTR_DEVX_SUBSCRIBE_EVENT_OBJ_HANDLE,118MLX5_IB_ATTR_DEVX_SUBSCRIBE_EVENT_TYPE_NUM_LIST,119MLX5_IB_ATTR_DEVX_SUBSCRIBE_EVENT_FD_NUM,120MLX5_IB_ATTR_DEVX_SUBSCRIBE_EVENT_COOKIE,121};122123enum mlx5_ib_devx_query_eqn_attrs {124MLX5_IB_ATTR_DEVX_QUERY_EQN_USER_VEC = (1U << UVERBS_ID_NS_SHIFT),125MLX5_IB_ATTR_DEVX_QUERY_EQN_DEV_EQN,126};127128enum mlx5_ib_devx_obj_methods {129MLX5_IB_METHOD_DEVX_OBJ_CREATE = (1U << UVERBS_ID_NS_SHIFT),130MLX5_IB_METHOD_DEVX_OBJ_DESTROY,131MLX5_IB_METHOD_DEVX_OBJ_MODIFY,132MLX5_IB_METHOD_DEVX_OBJ_QUERY,133MLX5_IB_METHOD_DEVX_OBJ_ASYNC_QUERY,134};135136enum mlx5_ib_var_alloc_attrs {137MLX5_IB_ATTR_VAR_OBJ_ALLOC_HANDLE = (1U << UVERBS_ID_NS_SHIFT),138MLX5_IB_ATTR_VAR_OBJ_ALLOC_MMAP_OFFSET,139MLX5_IB_ATTR_VAR_OBJ_ALLOC_MMAP_LENGTH,140MLX5_IB_ATTR_VAR_OBJ_ALLOC_PAGE_ID,141};142143enum mlx5_ib_var_obj_destroy_attrs {144MLX5_IB_ATTR_VAR_OBJ_DESTROY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),145};146147enum mlx5_ib_var_obj_methods {148MLX5_IB_METHOD_VAR_OBJ_ALLOC = (1U << UVERBS_ID_NS_SHIFT),149MLX5_IB_METHOD_VAR_OBJ_DESTROY,150};151152enum mlx5_ib_uar_alloc_attrs {153MLX5_IB_ATTR_UAR_OBJ_ALLOC_HANDLE = (1U << UVERBS_ID_NS_SHIFT),154MLX5_IB_ATTR_UAR_OBJ_ALLOC_TYPE,155MLX5_IB_ATTR_UAR_OBJ_ALLOC_MMAP_OFFSET,156MLX5_IB_ATTR_UAR_OBJ_ALLOC_MMAP_LENGTH,157MLX5_IB_ATTR_UAR_OBJ_ALLOC_PAGE_ID,158};159160enum mlx5_ib_uar_obj_destroy_attrs {161MLX5_IB_ATTR_UAR_OBJ_DESTROY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),162};163164enum mlx5_ib_uar_obj_methods {165MLX5_IB_METHOD_UAR_OBJ_ALLOC = (1U << UVERBS_ID_NS_SHIFT),166MLX5_IB_METHOD_UAR_OBJ_DESTROY,167};168169enum mlx5_ib_devx_umem_reg_attrs {170MLX5_IB_ATTR_DEVX_UMEM_REG_HANDLE = (1U << UVERBS_ID_NS_SHIFT),171MLX5_IB_ATTR_DEVX_UMEM_REG_ADDR,172MLX5_IB_ATTR_DEVX_UMEM_REG_LEN,173MLX5_IB_ATTR_DEVX_UMEM_REG_ACCESS,174MLX5_IB_ATTR_DEVX_UMEM_REG_OUT_ID,175MLX5_IB_ATTR_DEVX_UMEM_REG_PGSZ_BITMAP,176MLX5_IB_ATTR_DEVX_UMEM_REG_DMABUF_FD,177};178179enum mlx5_ib_devx_umem_dereg_attrs {180MLX5_IB_ATTR_DEVX_UMEM_DEREG_HANDLE = (1U << UVERBS_ID_NS_SHIFT),181};182183enum mlx5_ib_pp_obj_methods {184MLX5_IB_METHOD_PP_OBJ_ALLOC = (1U << UVERBS_ID_NS_SHIFT),185MLX5_IB_METHOD_PP_OBJ_DESTROY,186};187188enum mlx5_ib_pp_alloc_attrs {189MLX5_IB_ATTR_PP_OBJ_ALLOC_HANDLE = (1U << UVERBS_ID_NS_SHIFT),190MLX5_IB_ATTR_PP_OBJ_ALLOC_CTX,191MLX5_IB_ATTR_PP_OBJ_ALLOC_FLAGS,192MLX5_IB_ATTR_PP_OBJ_ALLOC_INDEX,193};194195enum mlx5_ib_pp_obj_destroy_attrs {196MLX5_IB_ATTR_PP_OBJ_DESTROY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),197};198199enum mlx5_ib_devx_umem_methods {200MLX5_IB_METHOD_DEVX_UMEM_REG = (1U << UVERBS_ID_NS_SHIFT),201MLX5_IB_METHOD_DEVX_UMEM_DEREG,202};203204enum mlx5_ib_devx_async_cmd_fd_alloc_attrs {205MLX5_IB_ATTR_DEVX_ASYNC_CMD_FD_ALLOC_HANDLE = (1U << UVERBS_ID_NS_SHIFT),206};207208enum mlx5_ib_devx_async_event_fd_alloc_attrs {209MLX5_IB_ATTR_DEVX_ASYNC_EVENT_FD_ALLOC_HANDLE = (1U << UVERBS_ID_NS_SHIFT),210MLX5_IB_ATTR_DEVX_ASYNC_EVENT_FD_ALLOC_FLAGS,211};212213enum mlx5_ib_devx_async_cmd_fd_methods {214MLX5_IB_METHOD_DEVX_ASYNC_CMD_FD_ALLOC = (1U << UVERBS_ID_NS_SHIFT),215};216217enum mlx5_ib_devx_async_event_fd_methods {218MLX5_IB_METHOD_DEVX_ASYNC_EVENT_FD_ALLOC = (1U << UVERBS_ID_NS_SHIFT),219};220221enum mlx5_ib_objects {222MLX5_IB_OBJECT_DEVX = (1U << UVERBS_ID_NS_SHIFT),223MLX5_IB_OBJECT_DEVX_OBJ,224MLX5_IB_OBJECT_DEVX_UMEM,225MLX5_IB_OBJECT_FLOW_MATCHER,226MLX5_IB_OBJECT_DEVX_ASYNC_CMD_FD,227MLX5_IB_OBJECT_DEVX_ASYNC_EVENT_FD,228MLX5_IB_OBJECT_VAR,229MLX5_IB_OBJECT_PP,230MLX5_IB_OBJECT_UAR,231MLX5_IB_OBJECT_STEERING_ANCHOR,232};233234enum mlx5_ib_flow_matcher_create_attrs {235MLX5_IB_ATTR_FLOW_MATCHER_CREATE_HANDLE = (1U << UVERBS_ID_NS_SHIFT),236MLX5_IB_ATTR_FLOW_MATCHER_MATCH_MASK,237MLX5_IB_ATTR_FLOW_MATCHER_FLOW_TYPE,238MLX5_IB_ATTR_FLOW_MATCHER_MATCH_CRITERIA,239MLX5_IB_ATTR_FLOW_MATCHER_FLOW_FLAGS,240MLX5_IB_ATTR_FLOW_MATCHER_FT_TYPE,241MLX5_IB_ATTR_FLOW_MATCHER_IB_PORT,242};243244enum mlx5_ib_flow_matcher_destroy_attrs {245MLX5_IB_ATTR_FLOW_MATCHER_DESTROY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),246};247248enum mlx5_ib_flow_matcher_methods {249MLX5_IB_METHOD_FLOW_MATCHER_CREATE = (1U << UVERBS_ID_NS_SHIFT),250MLX5_IB_METHOD_FLOW_MATCHER_DESTROY,251};252253enum mlx5_ib_flow_steering_anchor_create_attrs {254MLX5_IB_ATTR_STEERING_ANCHOR_CREATE_HANDLE = (1U << UVERBS_ID_NS_SHIFT),255MLX5_IB_ATTR_STEERING_ANCHOR_FT_TYPE,256MLX5_IB_ATTR_STEERING_ANCHOR_PRIORITY,257MLX5_IB_ATTR_STEERING_ANCHOR_FT_ID,258};259260enum mlx5_ib_flow_steering_anchor_destroy_attrs {261MLX5_IB_ATTR_STEERING_ANCHOR_DESTROY_HANDLE = (1U << UVERBS_ID_NS_SHIFT),262};263264enum mlx5_ib_steering_anchor_methods {265MLX5_IB_METHOD_STEERING_ANCHOR_CREATE = (1U << UVERBS_ID_NS_SHIFT),266MLX5_IB_METHOD_STEERING_ANCHOR_DESTROY,267};268269enum mlx5_ib_device_query_context_attrs {270MLX5_IB_ATTR_QUERY_CONTEXT_RESP_UCTX = (1U << UVERBS_ID_NS_SHIFT),271};272273enum mlx5_ib_create_cq_attrs {274MLX5_IB_ATTR_CREATE_CQ_UAR_INDEX = UVERBS_ID_DRIVER_NS_WITH_UHW,275};276277enum mlx5_ib_reg_dmabuf_mr_attrs {278MLX5_IB_ATTR_REG_DMABUF_MR_ACCESS_FLAGS = (1U << UVERBS_ID_NS_SHIFT),279};280281#define MLX5_IB_DW_MATCH_PARAM 0xA0282283struct mlx5_ib_match_params {284__u32 match_params[MLX5_IB_DW_MATCH_PARAM];285};286287enum mlx5_ib_flow_type {288MLX5_IB_FLOW_TYPE_NORMAL,289MLX5_IB_FLOW_TYPE_SNIFFER,290MLX5_IB_FLOW_TYPE_ALL_DEFAULT,291MLX5_IB_FLOW_TYPE_MC_DEFAULT,292};293294enum mlx5_ib_create_flow_flags {295MLX5_IB_ATTR_CREATE_FLOW_FLAGS_DEFAULT_MISS = 1 << 0,296MLX5_IB_ATTR_CREATE_FLOW_FLAGS_DROP = 1 << 1,297};298299enum mlx5_ib_create_flow_attrs {300MLX5_IB_ATTR_CREATE_FLOW_HANDLE = (1U << UVERBS_ID_NS_SHIFT),301MLX5_IB_ATTR_CREATE_FLOW_MATCH_VALUE,302MLX5_IB_ATTR_CREATE_FLOW_DEST_QP,303MLX5_IB_ATTR_CREATE_FLOW_DEST_DEVX,304MLX5_IB_ATTR_CREATE_FLOW_MATCHER,305MLX5_IB_ATTR_CREATE_FLOW_ARR_FLOW_ACTIONS,306MLX5_IB_ATTR_CREATE_FLOW_TAG,307MLX5_IB_ATTR_CREATE_FLOW_ARR_COUNTERS_DEVX,308MLX5_IB_ATTR_CREATE_FLOW_ARR_COUNTERS_DEVX_OFFSET,309MLX5_IB_ATTR_CREATE_FLOW_FLAGS,310};311312enum mlx5_ib_destroy_flow_attrs {313MLX5_IB_ATTR_DESTROY_FLOW_HANDLE = (1U << UVERBS_ID_NS_SHIFT),314};315316enum mlx5_ib_flow_methods {317MLX5_IB_METHOD_CREATE_FLOW = (1U << UVERBS_ID_NS_SHIFT),318MLX5_IB_METHOD_DESTROY_FLOW,319};320321enum mlx5_ib_flow_action_methods {322MLX5_IB_METHOD_FLOW_ACTION_CREATE_MODIFY_HEADER = (1U << UVERBS_ID_NS_SHIFT),323MLX5_IB_METHOD_FLOW_ACTION_CREATE_PACKET_REFORMAT,324};325326enum mlx5_ib_create_flow_action_create_modify_header_attrs {327MLX5_IB_ATTR_CREATE_MODIFY_HEADER_HANDLE = (1U << UVERBS_ID_NS_SHIFT),328MLX5_IB_ATTR_CREATE_MODIFY_HEADER_ACTIONS_PRM,329MLX5_IB_ATTR_CREATE_MODIFY_HEADER_FT_TYPE,330};331332enum mlx5_ib_create_flow_action_create_packet_reformat_attrs {333MLX5_IB_ATTR_CREATE_PACKET_REFORMAT_HANDLE = (1U << UVERBS_ID_NS_SHIFT),334MLX5_IB_ATTR_CREATE_PACKET_REFORMAT_TYPE,335MLX5_IB_ATTR_CREATE_PACKET_REFORMAT_FT_TYPE,336MLX5_IB_ATTR_CREATE_PACKET_REFORMAT_DATA_BUF,337};338339enum mlx5_ib_query_pd_attrs {340MLX5_IB_ATTR_QUERY_PD_HANDLE = (1U << UVERBS_ID_NS_SHIFT),341MLX5_IB_ATTR_QUERY_PD_RESP_PDN,342};343344enum mlx5_ib_pd_methods {345MLX5_IB_METHOD_PD_QUERY = (1U << UVERBS_ID_NS_SHIFT),346347};348349enum mlx5_ib_device_methods {350MLX5_IB_METHOD_QUERY_PORT = (1U << UVERBS_ID_NS_SHIFT),351MLX5_IB_METHOD_GET_DATA_DIRECT_SYSFS_PATH,352};353354enum mlx5_ib_query_port_attrs {355MLX5_IB_ATTR_QUERY_PORT_PORT_NUM = (1U << UVERBS_ID_NS_SHIFT),356MLX5_IB_ATTR_QUERY_PORT,357};358359enum mlx5_ib_get_data_direct_sysfs_path_attrs {360MLX5_IB_ATTR_GET_DATA_DIRECT_SYSFS_PATH = (1U << UVERBS_ID_NS_SHIFT),361};362363#endif364365366