diff options
| author | Yishai Hadas <yishaih@mellanox.com> | 2018-06-17 06:00:04 -0400 |
|---|---|---|
| committer | Jason Gunthorpe <jgg@mellanox.com> | 2018-06-19 12:53:02 -0400 |
| commit | aeae94579caf77406a8a235ea33fdb67abe9a57e (patch) | |
| tree | 27e16ea1a1840d95801afd339355c759f17c7b2f /include | |
| parent | 7c043e908a74ae0a935037cdd984d0cb89b2b970 (diff) | |
IB/mlx5: Add DEVX support for memory registration
Add support to register a memory with the firmware via the DEVX
interface.
The driver translates a given user address to ib_umem then it will
register the physical addresses with the firmware and get a unique id
for this registration to be used for this virtual address.
Signed-off-by: Yishai Hadas <yishaih@mellanox.com>
Signed-off-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Diffstat (limited to 'include')
| -rw-r--r-- | include/linux/mlx5/mlx5_ifc.h | 1 | ||||
| -rw-r--r-- | include/uapi/rdma/mlx5_user_ioctl_cmds.h | 18 |
2 files changed, 19 insertions, 0 deletions
diff --git a/include/linux/mlx5/mlx5_ifc.h b/include/linux/mlx5/mlx5_ifc.h index ac24ed87c67e..00b539303f5d 100644 --- a/include/linux/mlx5/mlx5_ifc.h +++ b/include/linux/mlx5/mlx5_ifc.h | |||
| @@ -82,6 +82,7 @@ enum { | |||
| 82 | 82 | ||
| 83 | enum { | 83 | enum { |
| 84 | MLX5_OBJ_TYPE_UCTX = 0x0004, | 84 | MLX5_OBJ_TYPE_UCTX = 0x0004, |
| 85 | MLX5_OBJ_TYPE_UMEM = 0x0005, | ||
| 85 | }; | 86 | }; |
| 86 | 87 | ||
| 87 | enum { | 88 | enum { |
diff --git a/include/uapi/rdma/mlx5_user_ioctl_cmds.h b/include/uapi/rdma/mlx5_user_ioctl_cmds.h index 1252695cd94b..dbc549a7bf50 100644 --- a/include/uapi/rdma/mlx5_user_ioctl_cmds.h +++ b/include/uapi/rdma/mlx5_user_ioctl_cmds.h | |||
| @@ -89,9 +89,27 @@ enum mlx5_ib_devx_obj_methods { | |||
| 89 | MLX5_IB_METHOD_DEVX_OBJ_QUERY, | 89 | MLX5_IB_METHOD_DEVX_OBJ_QUERY, |
| 90 | }; | 90 | }; |
| 91 | 91 | ||
| 92 | enum mlx5_ib_devx_umem_reg_attrs { | ||
| 93 | MLX5_IB_ATTR_DEVX_UMEM_REG_HANDLE = (1U << UVERBS_ID_NS_SHIFT), | ||
| 94 | MLX5_IB_ATTR_DEVX_UMEM_REG_ADDR, | ||
| 95 | MLX5_IB_ATTR_DEVX_UMEM_REG_LEN, | ||
| 96 | MLX5_IB_ATTR_DEVX_UMEM_REG_ACCESS, | ||
| 97 | MLX5_IB_ATTR_DEVX_UMEM_REG_OUT_ID, | ||
| 98 | }; | ||
| 99 | |||
| 100 | enum mlx5_ib_devx_umem_dereg_attrs { | ||
| 101 | MLX5_IB_ATTR_DEVX_UMEM_DEREG_HANDLE = (1U << UVERBS_ID_NS_SHIFT), | ||
| 102 | }; | ||
| 103 | |||
| 104 | enum mlx5_ib_devx_umem_methods { | ||
| 105 | MLX5_IB_METHOD_DEVX_UMEM_REG = (1U << UVERBS_ID_NS_SHIFT), | ||
| 106 | MLX5_IB_METHOD_DEVX_UMEM_DEREG, | ||
| 107 | }; | ||
| 108 | |||
| 92 | enum mlx5_ib_devx_objects { | 109 | enum mlx5_ib_devx_objects { |
| 93 | MLX5_IB_OBJECT_DEVX = (1U << UVERBS_ID_NS_SHIFT), | 110 | MLX5_IB_OBJECT_DEVX = (1U << UVERBS_ID_NS_SHIFT), |
| 94 | MLX5_IB_OBJECT_DEVX_OBJ, | 111 | MLX5_IB_OBJECT_DEVX_OBJ, |
| 112 | MLX5_IB_OBJECT_DEVX_UMEM, | ||
| 95 | }; | 113 | }; |
| 96 | 114 | ||
| 97 | #endif | 115 | #endif |
