1 /* 2 * Copyright (c) 2018, Mellanox Technologies inc. All rights reserved. 3 * Copyright (c) 2020, Intel Corporation. All rights reserved. 4 * 5 * This software is available to you under a choice of one of two 6 * licenses. You may choose to be licensed under the terms of the GNU 7 * General Public License (GPL) Version 2, available from the file 8 * COPYING in the main directory of this source tree, or the 9 * OpenIB.org BSD license below: 10 * 11 * Redistribution and use in source and binary forms, with or 12 * without modification, are permitted provided that the following 13 * conditions are met: 14 * 15 * - Redistributions of source code must retain the above 16 * copyright notice, this list of conditions and the following 17 * disclaimer. 18 * 19 * - Redistributions in binary form must reproduce the above 20 * copyright notice, this list of conditions and the following 21 * disclaimer in the documentation and/or other materials 22 * provided with the distribution. 23 * 24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 25 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 26 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 27 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 28 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 29 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 30 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 31 * SOFTWARE. 32 */ 33 34 #ifndef IB_USER_IOCTL_CMDS_H 35 #define IB_USER_IOCTL_CMDS_H 36 37 #define UVERBS_ID_NS_MASK 0xF000 38 #define UVERBS_ID_NS_SHIFT 12 39 40 enum uverbs_default_objects { 41 UVERBS_OBJECT_DEVICE, /* No instances of DEVICE are allowed */ 42 UVERBS_OBJECT_PD, 43 UVERBS_OBJECT_COMP_CHANNEL, 44 UVERBS_OBJECT_CQ, 45 UVERBS_OBJECT_QP, 46 UVERBS_OBJECT_SRQ, 47 UVERBS_OBJECT_AH, 48 UVERBS_OBJECT_MR, 49 UVERBS_OBJECT_MW, 50 UVERBS_OBJECT_FLOW, 51 UVERBS_OBJECT_XRCD, 52 UVERBS_OBJECT_RWQ_IND_TBL, 53 UVERBS_OBJECT_WQ, 54 UVERBS_OBJECT_FLOW_ACTION, 55 UVERBS_OBJECT_DM, 56 UVERBS_OBJECT_COUNTERS, 57 UVERBS_OBJECT_ASYNC_EVENT, 58 }; 59 60 enum { 61 UVERBS_ID_DRIVER_NS = 1UL << UVERBS_ID_NS_SHIFT, 62 UVERBS_ATTR_UHW_IN = UVERBS_ID_DRIVER_NS, 63 UVERBS_ATTR_UHW_OUT, 64 UVERBS_ID_DRIVER_NS_WITH_UHW, 65 }; 66 67 enum uverbs_methods_device { 68 UVERBS_METHOD_INVOKE_WRITE, 69 UVERBS_METHOD_INFO_HANDLES, 70 UVERBS_METHOD_QUERY_PORT, 71 UVERBS_METHOD_GET_CONTEXT, 72 UVERBS_METHOD_QUERY_CONTEXT, 73 UVERBS_METHOD_QUERY_GID_TABLE, 74 UVERBS_METHOD_QUERY_GID_ENTRY, 75 }; 76 77 enum uverbs_attrs_invoke_write_cmd_attr_ids { 78 UVERBS_ATTR_CORE_IN, 79 UVERBS_ATTR_CORE_OUT, 80 UVERBS_ATTR_WRITE_CMD, 81 }; 82 83 enum uverbs_attrs_query_port_cmd_attr_ids { 84 UVERBS_ATTR_QUERY_PORT_PORT_NUM, 85 UVERBS_ATTR_QUERY_PORT_RESP, 86 }; 87 88 enum uverbs_attrs_get_context_attr_ids { 89 UVERBS_ATTR_GET_CONTEXT_NUM_COMP_VECTORS, 90 UVERBS_ATTR_GET_CONTEXT_CORE_SUPPORT, 91 }; 92 93 enum uverbs_attrs_query_context_attr_ids { 94 UVERBS_ATTR_QUERY_CONTEXT_NUM_COMP_VECTORS, 95 UVERBS_ATTR_QUERY_CONTEXT_CORE_SUPPORT, 96 }; 97 98 enum uverbs_attrs_create_cq_cmd_attr_ids { 99 UVERBS_ATTR_CREATE_CQ_HANDLE, 100 UVERBS_ATTR_CREATE_CQ_CQE, 101 UVERBS_ATTR_CREATE_CQ_USER_HANDLE, 102 UVERBS_ATTR_CREATE_CQ_COMP_CHANNEL, 103 UVERBS_ATTR_CREATE_CQ_COMP_VECTOR, 104 UVERBS_ATTR_CREATE_CQ_FLAGS, 105 UVERBS_ATTR_CREATE_CQ_RESP_CQE, 106 UVERBS_ATTR_CREATE_CQ_EVENT_FD, 107 }; 108 109 enum uverbs_attrs_destroy_cq_cmd_attr_ids { 110 UVERBS_ATTR_DESTROY_CQ_HANDLE, 111 UVERBS_ATTR_DESTROY_CQ_RESP, 112 }; 113 114 enum uverbs_attrs_create_flow_action_esp { 115 UVERBS_ATTR_CREATE_FLOW_ACTION_ESP_HANDLE, 116 UVERBS_ATTR_FLOW_ACTION_ESP_ATTRS, 117 UVERBS_ATTR_FLOW_ACTION_ESP_ESN, 118 UVERBS_ATTR_FLOW_ACTION_ESP_KEYMAT, 119 UVERBS_ATTR_FLOW_ACTION_ESP_REPLAY, 120 UVERBS_ATTR_FLOW_ACTION_ESP_ENCAP, 121 }; 122 123 enum uverbs_attrs_modify_flow_action_esp { 124 UVERBS_ATTR_MODIFY_FLOW_ACTION_ESP_HANDLE = 125 UVERBS_ATTR_CREATE_FLOW_ACTION_ESP_HANDLE, 126 }; 127 128 enum uverbs_attrs_destroy_flow_action_esp { 129 UVERBS_ATTR_DESTROY_FLOW_ACTION_HANDLE, 130 }; 131 132 enum uverbs_attrs_create_qp_cmd_attr_ids { 133 UVERBS_ATTR_CREATE_QP_HANDLE, 134 UVERBS_ATTR_CREATE_QP_XRCD_HANDLE, 135 UVERBS_ATTR_CREATE_QP_PD_HANDLE, 136 UVERBS_ATTR_CREATE_QP_SRQ_HANDLE, 137 UVERBS_ATTR_CREATE_QP_SEND_CQ_HANDLE, 138 UVERBS_ATTR_CREATE_QP_RECV_CQ_HANDLE, 139 UVERBS_ATTR_CREATE_QP_IND_TABLE_HANDLE, 140 UVERBS_ATTR_CREATE_QP_USER_HANDLE, 141 UVERBS_ATTR_CREATE_QP_CAP, 142 UVERBS_ATTR_CREATE_QP_TYPE, 143 UVERBS_ATTR_CREATE_QP_FLAGS, 144 UVERBS_ATTR_CREATE_QP_SOURCE_QPN, 145 UVERBS_ATTR_CREATE_QP_EVENT_FD, 146 UVERBS_ATTR_CREATE_QP_RESP_CAP, 147 UVERBS_ATTR_CREATE_QP_RESP_QP_NUM, 148 }; 149 150 enum uverbs_attrs_destroy_qp_cmd_attr_ids { 151 UVERBS_ATTR_DESTROY_QP_HANDLE, 152 UVERBS_ATTR_DESTROY_QP_RESP, 153 }; 154 155 enum uverbs_methods_qp { 156 UVERBS_METHOD_QP_CREATE, 157 UVERBS_METHOD_QP_DESTROY, 158 }; 159 160 enum uverbs_attrs_create_srq_cmd_attr_ids { 161 UVERBS_ATTR_CREATE_SRQ_HANDLE, 162 UVERBS_ATTR_CREATE_SRQ_PD_HANDLE, 163 UVERBS_ATTR_CREATE_SRQ_XRCD_HANDLE, 164 UVERBS_ATTR_CREATE_SRQ_CQ_HANDLE, 165 UVERBS_ATTR_CREATE_SRQ_USER_HANDLE, 166 UVERBS_ATTR_CREATE_SRQ_MAX_WR, 167 UVERBS_ATTR_CREATE_SRQ_MAX_SGE, 168 UVERBS_ATTR_CREATE_SRQ_LIMIT, 169 UVERBS_ATTR_CREATE_SRQ_MAX_NUM_TAGS, 170 UVERBS_ATTR_CREATE_SRQ_TYPE, 171 UVERBS_ATTR_CREATE_SRQ_EVENT_FD, 172 UVERBS_ATTR_CREATE_SRQ_RESP_MAX_WR, 173 UVERBS_ATTR_CREATE_SRQ_RESP_MAX_SGE, 174 UVERBS_ATTR_CREATE_SRQ_RESP_SRQ_NUM, 175 }; 176 177 enum uverbs_attrs_destroy_srq_cmd_attr_ids { 178 UVERBS_ATTR_DESTROY_SRQ_HANDLE, 179 UVERBS_ATTR_DESTROY_SRQ_RESP, 180 }; 181 182 enum uverbs_methods_srq { 183 UVERBS_METHOD_SRQ_CREATE, 184 UVERBS_METHOD_SRQ_DESTROY, 185 }; 186 187 enum uverbs_methods_cq { 188 UVERBS_METHOD_CQ_CREATE, 189 UVERBS_METHOD_CQ_DESTROY, 190 }; 191 192 enum uverbs_attrs_create_wq_cmd_attr_ids { 193 UVERBS_ATTR_CREATE_WQ_HANDLE, 194 UVERBS_ATTR_CREATE_WQ_PD_HANDLE, 195 UVERBS_ATTR_CREATE_WQ_CQ_HANDLE, 196 UVERBS_ATTR_CREATE_WQ_USER_HANDLE, 197 UVERBS_ATTR_CREATE_WQ_TYPE, 198 UVERBS_ATTR_CREATE_WQ_EVENT_FD, 199 UVERBS_ATTR_CREATE_WQ_MAX_WR, 200 UVERBS_ATTR_CREATE_WQ_MAX_SGE, 201 UVERBS_ATTR_CREATE_WQ_FLAGS, 202 UVERBS_ATTR_CREATE_WQ_RESP_MAX_WR, 203 UVERBS_ATTR_CREATE_WQ_RESP_MAX_SGE, 204 UVERBS_ATTR_CREATE_WQ_RESP_WQ_NUM, 205 }; 206 207 enum uverbs_attrs_destroy_wq_cmd_attr_ids { 208 UVERBS_ATTR_DESTROY_WQ_HANDLE, 209 UVERBS_ATTR_DESTROY_WQ_RESP, 210 }; 211 212 enum uverbs_methods_wq { 213 UVERBS_METHOD_WQ_CREATE, 214 UVERBS_METHOD_WQ_DESTROY, 215 }; 216 217 enum uverbs_methods_actions_flow_action_ops { 218 UVERBS_METHOD_FLOW_ACTION_ESP_CREATE, 219 UVERBS_METHOD_FLOW_ACTION_DESTROY, 220 UVERBS_METHOD_FLOW_ACTION_ESP_MODIFY, 221 }; 222 223 enum uverbs_attrs_alloc_dm_cmd_attr_ids { 224 UVERBS_ATTR_ALLOC_DM_HANDLE, 225 UVERBS_ATTR_ALLOC_DM_LENGTH, 226 UVERBS_ATTR_ALLOC_DM_ALIGNMENT, 227 }; 228 229 enum uverbs_attrs_free_dm_cmd_attr_ids { 230 UVERBS_ATTR_FREE_DM_HANDLE, 231 }; 232 233 enum uverbs_methods_dm { 234 UVERBS_METHOD_DM_ALLOC, 235 UVERBS_METHOD_DM_FREE, 236 }; 237 238 enum uverbs_attrs_reg_dm_mr_cmd_attr_ids { 239 UVERBS_ATTR_REG_DM_MR_HANDLE, 240 UVERBS_ATTR_REG_DM_MR_OFFSET, 241 UVERBS_ATTR_REG_DM_MR_LENGTH, 242 UVERBS_ATTR_REG_DM_MR_PD_HANDLE, 243 UVERBS_ATTR_REG_DM_MR_ACCESS_FLAGS, 244 UVERBS_ATTR_REG_DM_MR_DM_HANDLE, 245 UVERBS_ATTR_REG_DM_MR_RESP_LKEY, 246 UVERBS_ATTR_REG_DM_MR_RESP_RKEY, 247 }; 248 249 enum uverbs_methods_mr { 250 UVERBS_METHOD_DM_MR_REG, 251 UVERBS_METHOD_MR_DESTROY, 252 UVERBS_METHOD_ADVISE_MR, 253 UVERBS_METHOD_QUERY_MR, 254 UVERBS_METHOD_REG_DMABUF_MR, 255 }; 256 257 enum uverbs_attrs_mr_destroy_ids { 258 UVERBS_ATTR_DESTROY_MR_HANDLE, 259 }; 260 261 enum uverbs_attrs_advise_mr_cmd_attr_ids { 262 UVERBS_ATTR_ADVISE_MR_PD_HANDLE, 263 UVERBS_ATTR_ADVISE_MR_ADVICE, 264 UVERBS_ATTR_ADVISE_MR_FLAGS, 265 UVERBS_ATTR_ADVISE_MR_SGE_LIST, 266 }; 267 268 enum uverbs_attrs_query_mr_cmd_attr_ids { 269 UVERBS_ATTR_QUERY_MR_HANDLE, 270 UVERBS_ATTR_QUERY_MR_RESP_LKEY, 271 UVERBS_ATTR_QUERY_MR_RESP_RKEY, 272 UVERBS_ATTR_QUERY_MR_RESP_LENGTH, 273 UVERBS_ATTR_QUERY_MR_RESP_IOVA, 274 }; 275 276 enum uverbs_attrs_reg_dmabuf_mr_cmd_attr_ids { 277 UVERBS_ATTR_REG_DMABUF_MR_HANDLE, 278 UVERBS_ATTR_REG_DMABUF_MR_PD_HANDLE, 279 UVERBS_ATTR_REG_DMABUF_MR_OFFSET, 280 UVERBS_ATTR_REG_DMABUF_MR_LENGTH, 281 UVERBS_ATTR_REG_DMABUF_MR_IOVA, 282 UVERBS_ATTR_REG_DMABUF_MR_FD, 283 UVERBS_ATTR_REG_DMABUF_MR_ACCESS_FLAGS, 284 UVERBS_ATTR_REG_DMABUF_MR_RESP_LKEY, 285 UVERBS_ATTR_REG_DMABUF_MR_RESP_RKEY, 286 }; 287 288 enum uverbs_attrs_create_counters_cmd_attr_ids { 289 UVERBS_ATTR_CREATE_COUNTERS_HANDLE, 290 }; 291 292 enum uverbs_attrs_destroy_counters_cmd_attr_ids { 293 UVERBS_ATTR_DESTROY_COUNTERS_HANDLE, 294 }; 295 296 enum uverbs_attrs_read_counters_cmd_attr_ids { 297 UVERBS_ATTR_READ_COUNTERS_HANDLE, 298 UVERBS_ATTR_READ_COUNTERS_BUFF, 299 UVERBS_ATTR_READ_COUNTERS_FLAGS, 300 }; 301 302 enum uverbs_methods_actions_counters_ops { 303 UVERBS_METHOD_COUNTERS_CREATE, 304 UVERBS_METHOD_COUNTERS_DESTROY, 305 UVERBS_METHOD_COUNTERS_READ, 306 }; 307 308 enum uverbs_attrs_info_handles_id { 309 UVERBS_ATTR_INFO_OBJECT_ID, 310 UVERBS_ATTR_INFO_TOTAL_HANDLES, 311 UVERBS_ATTR_INFO_HANDLES_LIST, 312 }; 313 314 enum uverbs_methods_pd { 315 UVERBS_METHOD_PD_DESTROY, 316 }; 317 318 enum uverbs_attrs_pd_destroy_ids { 319 UVERBS_ATTR_DESTROY_PD_HANDLE, 320 }; 321 322 enum uverbs_methods_mw { 323 UVERBS_METHOD_MW_DESTROY, 324 }; 325 326 enum uverbs_attrs_mw_destroy_ids { 327 UVERBS_ATTR_DESTROY_MW_HANDLE, 328 }; 329 330 enum uverbs_methods_xrcd { 331 UVERBS_METHOD_XRCD_DESTROY, 332 }; 333 334 enum uverbs_attrs_xrcd_destroy_ids { 335 UVERBS_ATTR_DESTROY_XRCD_HANDLE, 336 }; 337 338 enum uverbs_methods_ah { 339 UVERBS_METHOD_AH_DESTROY, 340 }; 341 342 enum uverbs_attrs_ah_destroy_ids { 343 UVERBS_ATTR_DESTROY_AH_HANDLE, 344 }; 345 346 enum uverbs_methods_rwq_ind_tbl { 347 UVERBS_METHOD_RWQ_IND_TBL_DESTROY, 348 }; 349 350 enum uverbs_attrs_rwq_ind_tbl_destroy_ids { 351 UVERBS_ATTR_DESTROY_RWQ_IND_TBL_HANDLE, 352 }; 353 354 enum uverbs_methods_flow { 355 UVERBS_METHOD_FLOW_DESTROY, 356 }; 357 358 enum uverbs_attrs_flow_destroy_ids { 359 UVERBS_ATTR_DESTROY_FLOW_HANDLE, 360 }; 361 362 enum uverbs_method_async_event { 363 UVERBS_METHOD_ASYNC_EVENT_ALLOC, 364 }; 365 366 enum uverbs_attrs_async_event_create { 367 UVERBS_ATTR_ASYNC_EVENT_ALLOC_FD_HANDLE, 368 }; 369 370 enum uverbs_attrs_query_gid_table_cmd_attr_ids { 371 UVERBS_ATTR_QUERY_GID_TABLE_ENTRY_SIZE, 372 UVERBS_ATTR_QUERY_GID_TABLE_FLAGS, 373 UVERBS_ATTR_QUERY_GID_TABLE_RESP_ENTRIES, 374 UVERBS_ATTR_QUERY_GID_TABLE_RESP_NUM_ENTRIES, 375 }; 376 377 enum uverbs_attrs_query_gid_entry_cmd_attr_ids { 378 UVERBS_ATTR_QUERY_GID_ENTRY_PORT, 379 UVERBS_ATTR_QUERY_GID_ENTRY_GID_INDEX, 380 UVERBS_ATTR_QUERY_GID_ENTRY_FLAGS, 381 UVERBS_ATTR_QUERY_GID_ENTRY_RESP_ENTRY, 382 }; 383 384 #endif 385