blob: d9ac9e0a21811c6cadc62c46f135a67a5a5c7e28 [file] [log] [blame]
Ben Cheng655a7c02013-10-16 16:09:24 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 *** To edit the content of this header, modify the corresponding
11 *** source file (e.g. under external/kernel-headers/original/) then
12 *** run bionic/libc/kernel/tools/update_all.py
13 ***
14 *** Any manual change here will be lost the next time this script will
15 *** be run. You've been warned!
16 ***
17 ****************************************************************************
18 ****************************************************************************/
19#ifndef IB_USER_VERBS_H
20#define IB_USER_VERBS_H
21#include <linux/types.h>
22#define IB_USER_VERBS_ABI_VERSION 6
Christopher Ferris38062f92014-07-09 15:33:25 -070023#define IB_USER_VERBS_CMD_THRESHOLD 50
Christopher Ferrisd842e432019-03-07 10:21:59 -080024enum ib_uverbs_write_cmds {
Tao Baod7db5942015-01-28 10:07:51 -080025 IB_USER_VERBS_CMD_GET_CONTEXT,
26 IB_USER_VERBS_CMD_QUERY_DEVICE,
Tao Baod7db5942015-01-28 10:07:51 -080027 IB_USER_VERBS_CMD_QUERY_PORT,
28 IB_USER_VERBS_CMD_ALLOC_PD,
29 IB_USER_VERBS_CMD_DEALLOC_PD,
30 IB_USER_VERBS_CMD_CREATE_AH,
Tao Baod7db5942015-01-28 10:07:51 -080031 IB_USER_VERBS_CMD_MODIFY_AH,
32 IB_USER_VERBS_CMD_QUERY_AH,
33 IB_USER_VERBS_CMD_DESTROY_AH,
34 IB_USER_VERBS_CMD_REG_MR,
Tao Baod7db5942015-01-28 10:07:51 -080035 IB_USER_VERBS_CMD_REG_SMR,
36 IB_USER_VERBS_CMD_REREG_MR,
37 IB_USER_VERBS_CMD_QUERY_MR,
38 IB_USER_VERBS_CMD_DEREG_MR,
Tao Baod7db5942015-01-28 10:07:51 -080039 IB_USER_VERBS_CMD_ALLOC_MW,
40 IB_USER_VERBS_CMD_BIND_MW,
41 IB_USER_VERBS_CMD_DEALLOC_MW,
42 IB_USER_VERBS_CMD_CREATE_COMP_CHANNEL,
Tao Baod7db5942015-01-28 10:07:51 -080043 IB_USER_VERBS_CMD_CREATE_CQ,
44 IB_USER_VERBS_CMD_RESIZE_CQ,
45 IB_USER_VERBS_CMD_DESTROY_CQ,
46 IB_USER_VERBS_CMD_POLL_CQ,
Tao Baod7db5942015-01-28 10:07:51 -080047 IB_USER_VERBS_CMD_PEEK_CQ,
48 IB_USER_VERBS_CMD_REQ_NOTIFY_CQ,
49 IB_USER_VERBS_CMD_CREATE_QP,
50 IB_USER_VERBS_CMD_QUERY_QP,
Tao Baod7db5942015-01-28 10:07:51 -080051 IB_USER_VERBS_CMD_MODIFY_QP,
52 IB_USER_VERBS_CMD_DESTROY_QP,
53 IB_USER_VERBS_CMD_POST_SEND,
54 IB_USER_VERBS_CMD_POST_RECV,
Tao Baod7db5942015-01-28 10:07:51 -080055 IB_USER_VERBS_CMD_ATTACH_MCAST,
56 IB_USER_VERBS_CMD_DETACH_MCAST,
57 IB_USER_VERBS_CMD_CREATE_SRQ,
58 IB_USER_VERBS_CMD_MODIFY_SRQ,
Tao Baod7db5942015-01-28 10:07:51 -080059 IB_USER_VERBS_CMD_QUERY_SRQ,
60 IB_USER_VERBS_CMD_DESTROY_SRQ,
61 IB_USER_VERBS_CMD_POST_SRQ_RECV,
62 IB_USER_VERBS_CMD_OPEN_XRCD,
Tao Baod7db5942015-01-28 10:07:51 -080063 IB_USER_VERBS_CMD_CLOSE_XRCD,
64 IB_USER_VERBS_CMD_CREATE_XSRQ,
65 IB_USER_VERBS_CMD_OPEN_QP,
Ben Cheng655a7c02013-10-16 16:09:24 -070066};
Christopher Ferris38062f92014-07-09 15:33:25 -070067enum {
Christopher Ferris05d08e92016-02-04 13:16:38 -080068 IB_USER_VERBS_EX_CMD_QUERY_DEVICE = IB_USER_VERBS_CMD_QUERY_DEVICE,
69 IB_USER_VERBS_EX_CMD_CREATE_CQ = IB_USER_VERBS_CMD_CREATE_CQ,
70 IB_USER_VERBS_EX_CMD_CREATE_QP = IB_USER_VERBS_CMD_CREATE_QP,
Christopher Ferris48af7cb2017-02-21 12:35:09 -080071 IB_USER_VERBS_EX_CMD_MODIFY_QP = IB_USER_VERBS_CMD_MODIFY_QP,
Christopher Ferris05d08e92016-02-04 13:16:38 -080072 IB_USER_VERBS_EX_CMD_CREATE_FLOW = IB_USER_VERBS_CMD_THRESHOLD,
73 IB_USER_VERBS_EX_CMD_DESTROY_FLOW,
Christopher Ferris49f525c2016-12-12 14:55:36 -080074 IB_USER_VERBS_EX_CMD_CREATE_WQ,
Christopher Ferris48af7cb2017-02-21 12:35:09 -080075 IB_USER_VERBS_EX_CMD_MODIFY_WQ,
Christopher Ferris49f525c2016-12-12 14:55:36 -080076 IB_USER_VERBS_EX_CMD_DESTROY_WQ,
77 IB_USER_VERBS_EX_CMD_CREATE_RWQ_IND_TBL,
Christopher Ferris934ec942018-01-31 15:29:16 -080078 IB_USER_VERBS_EX_CMD_DESTROY_RWQ_IND_TBL,
79 IB_USER_VERBS_EX_CMD_MODIFY_CQ
Christopher Ferris48af7cb2017-02-21 12:35:09 -080080};
Christopher Ferris49f525c2016-12-12 14:55:36 -080081struct ib_uverbs_async_event_desc {
Christopher Ferris76a1d452018-06-27 14:12:29 -070082 __aligned_u64 element;
Tao Baod7db5942015-01-28 10:07:51 -080083 __u32 event_type;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080084 __u32 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -080085};
Ben Cheng655a7c02013-10-16 16:09:24 -070086struct ib_uverbs_comp_event_desc {
Christopher Ferris76a1d452018-06-27 14:12:29 -070087 __aligned_u64 cq_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080088};
Christopher Ferris934ec942018-01-31 15:29:16 -080089struct ib_uverbs_cq_moderation_caps {
90 __u16 max_cq_moderation_count;
91 __u16 max_cq_moderation_period;
92 __u32 reserved;
93};
Christopher Ferris49f525c2016-12-12 14:55:36 -080094#define IB_USER_VERBS_CMD_COMMAND_MASK 0xff
Christopher Ferris76a1d452018-06-27 14:12:29 -070095#define IB_USER_VERBS_CMD_FLAG_EXTENDED 0x80000000u
Christopher Ferris49f525c2016-12-12 14:55:36 -080096struct ib_uverbs_cmd_hdr {
Tao Baod7db5942015-01-28 10:07:51 -080097 __u32 command;
98 __u16 in_words;
Christopher Ferris48af7cb2017-02-21 12:35:09 -080099 __u16 out_words;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800100};
Christopher Ferris38062f92014-07-09 15:33:25 -0700101struct ib_uverbs_ex_cmd_hdr {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700102 __aligned_u64 response;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800103 __u16 provider_in_words;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800104 __u16 provider_out_words;
Tao Baod7db5942015-01-28 10:07:51 -0800105 __u32 cmd_hdr_reserved;
Christopher Ferris38062f92014-07-09 15:33:25 -0700106};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800107struct ib_uverbs_get_context {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700108 __aligned_u64 response;
109 __aligned_u64 driver_data[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700110};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800111struct ib_uverbs_get_context_resp {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800112 __u32 async_fd;
Tao Baod7db5942015-01-28 10:07:51 -0800113 __u32 num_comp_vectors;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800114 __aligned_u64 driver_data[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700115};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800116struct ib_uverbs_query_device {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700117 __aligned_u64 response;
118 __aligned_u64 driver_data[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700119};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800120struct ib_uverbs_query_device_resp {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700121 __aligned_u64 fw_ver;
Tao Baod7db5942015-01-28 10:07:51 -0800122 __be64 node_guid;
123 __be64 sys_image_guid;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700124 __aligned_u64 max_mr_size;
125 __aligned_u64 page_size_cap;
Tao Baod7db5942015-01-28 10:07:51 -0800126 __u32 vendor_id;
127 __u32 vendor_part_id;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800128 __u32 hw_ver;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800129 __u32 max_qp;
Tao Baod7db5942015-01-28 10:07:51 -0800130 __u32 max_qp_wr;
131 __u32 device_cap_flags;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800132 __u32 max_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800133 __u32 max_sge_rd;
Tao Baod7db5942015-01-28 10:07:51 -0800134 __u32 max_cq;
135 __u32 max_cqe;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800136 __u32 max_mr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800137 __u32 max_pd;
Tao Baod7db5942015-01-28 10:07:51 -0800138 __u32 max_qp_rd_atom;
139 __u32 max_ee_rd_atom;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800140 __u32 max_res_rd_atom;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800141 __u32 max_qp_init_rd_atom;
Tao Baod7db5942015-01-28 10:07:51 -0800142 __u32 max_ee_init_rd_atom;
143 __u32 atomic_cap;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800144 __u32 max_ee;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800145 __u32 max_rdd;
Tao Baod7db5942015-01-28 10:07:51 -0800146 __u32 max_mw;
147 __u32 max_raw_ipv6_qp;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800148 __u32 max_raw_ethy_qp;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800149 __u32 max_mcast_grp;
Tao Baod7db5942015-01-28 10:07:51 -0800150 __u32 max_mcast_qp_attach;
151 __u32 max_total_mcast_qp_attach;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800152 __u32 max_ah;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800153 __u32 max_fmr;
Tao Baod7db5942015-01-28 10:07:51 -0800154 __u32 max_map_per_fmr;
155 __u32 max_srq;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800156 __u32 max_srq_wr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800157 __u32 max_srq_sge;
Tao Baod7db5942015-01-28 10:07:51 -0800158 __u16 max_pkeys;
159 __u8 local_ca_ack_delay;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800160 __u8 phys_port_cnt;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800161 __u8 reserved[4];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800162};
163struct ib_uverbs_ex_query_device {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800164 __u32 comp_mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800165 __u32 reserved;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800166};
167struct ib_uverbs_odp_caps {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700168 __aligned_u64 general_caps;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800169 struct {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800170 __u32 rc_odp_caps;
171 __u32 uc_odp_caps;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800172 __u32 ud_odp_caps;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800173 } per_transport_caps;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800174 __u32 reserved;
175};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800176struct ib_uverbs_rss_caps {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800177 __u32 supported_qpts;
178 __u32 max_rwq_indirection_tables;
179 __u32 max_rwq_indirection_table_size;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800180 __u32 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800181};
Christopher Ferris1308ad32017-11-14 17:32:13 -0800182struct ib_uverbs_tm_caps {
183 __u32 max_rndv_hdr_size;
184 __u32 max_num_tags;
185 __u32 flags;
186 __u32 max_ops;
187 __u32 max_sge;
188 __u32 reserved;
189};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800190struct ib_uverbs_ex_query_device_resp {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800191 struct ib_uverbs_query_device_resp base;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800192 __u32 comp_mask;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800193 __u32 response_length;
194 struct ib_uverbs_odp_caps odp_caps;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700195 __aligned_u64 timestamp_mask;
196 __aligned_u64 hca_core_clock;
197 __aligned_u64 device_cap_flags_ex;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800198 struct ib_uverbs_rss_caps rss_caps;
199 __u32 max_wq_type_rq;
Christopher Ferris525ce912017-07-26 13:12:53 -0700200 __u32 raw_packet_caps;
Christopher Ferris1308ad32017-11-14 17:32:13 -0800201 struct ib_uverbs_tm_caps tm_caps;
Christopher Ferris934ec942018-01-31 15:29:16 -0800202 struct ib_uverbs_cq_moderation_caps cq_moderation_caps;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700203 __aligned_u64 max_dm_size;
Christopher Ferris24f97eb2019-05-20 12:58:13 -0700204 __u32 xrc_odp_caps;
205 __u32 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800206};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800207struct ib_uverbs_query_port {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700208 __aligned_u64 response;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800209 __u8 port_num;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800210 __u8 reserved[7];
Christopher Ferris76a1d452018-06-27 14:12:29 -0700211 __aligned_u64 driver_data[0];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700212};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800213struct ib_uverbs_query_port_resp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800214 __u32 port_cap_flags;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800215 __u32 max_msg_sz;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700216 __u32 bad_pkey_cntr;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800217 __u32 qkey_viol_cntr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800218 __u32 gid_tbl_len;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800219 __u16 pkey_tbl_len;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700220 __u16 lid;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800221 __u16 sm_lid;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800222 __u8 state;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800223 __u8 max_mtu;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700224 __u8 active_mtu;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800225 __u8 lmc;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800226 __u8 max_vl_num;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800227 __u8 sm_sl;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700228 __u8 subnet_timeout;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800229 __u8 init_type_reply;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800230 __u8 active_width;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800231 __u8 active_speed;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700232 __u8 phys_state;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800233 __u8 link_layer;
Christopher Ferris9ce28842018-10-25 12:11:39 -0700234 __u8 flags;
235 __u8 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800236};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700237struct ib_uverbs_alloc_pd {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700238 __aligned_u64 response;
239 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800240};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700241struct ib_uverbs_alloc_pd_resp {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800242 __u32 pd_handle;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800243 __u32 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800244};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800245struct ib_uverbs_dealloc_pd {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700246 __u32 pd_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800247};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800248struct ib_uverbs_open_xrcd {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700249 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700250 __u32 fd;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800251 __u32 oflags;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700252 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800253};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700254struct ib_uverbs_open_xrcd_resp {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800255 __u32 xrcd_handle;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800256 __u32 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800257};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800258struct ib_uverbs_close_xrcd {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700259 __u32 xrcd_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800260};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800261struct ib_uverbs_reg_mr {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700262 __aligned_u64 response;
263 __aligned_u64 start;
264 __aligned_u64 length;
265 __aligned_u64 hca_va;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800266 __u32 pd_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700267 __u32 access_flags;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700268 __aligned_u64 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800269};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800270struct ib_uverbs_reg_mr_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700271 __u32 mr_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800272 __u32 lkey;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800273 __u32 rkey;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800274 __u32 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800275};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700276struct ib_uverbs_rereg_mr {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700277 __aligned_u64 response;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800278 __u32 mr_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800279 __u32 flags;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700280 __aligned_u64 start;
281 __aligned_u64 length;
282 __aligned_u64 hca_va;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800283 __u32 pd_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700284 __u32 access_flags;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800285 __aligned_u64 driver_data[0];
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800286};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800287struct ib_uverbs_rereg_mr_resp {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800288 __u32 lkey;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700289 __u32 rkey;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800290 __aligned_u64 driver_data[0];
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800291};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800292struct ib_uverbs_dereg_mr {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800293 __u32 mr_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700294};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800295struct ib_uverbs_alloc_mw {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700296 __aligned_u64 response;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800297 __u32 pd_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700298 __u8 mw_type;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800299 __u8 reserved[3];
Christopher Ferrisd842e432019-03-07 10:21:59 -0800300 __aligned_u64 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800301};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800302struct ib_uverbs_alloc_mw_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700303 __u32 mw_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800304 __u32 rkey;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800305 __aligned_u64 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800306};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800307struct ib_uverbs_dealloc_mw {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700308 __u32 mw_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800309};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800310struct ib_uverbs_create_comp_channel {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700311 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700312};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800313struct ib_uverbs_create_comp_channel_resp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800314 __u32 fd;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800315};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700316struct ib_uverbs_create_cq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700317 __aligned_u64 response;
318 __aligned_u64 user_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800319 __u32 cqe;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700320 __u32 comp_vector;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800321 __s32 comp_channel;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800322 __u32 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700323 __aligned_u64 driver_data[0];
324};
325enum ib_uverbs_ex_create_cq_flags {
326 IB_UVERBS_CQ_FLAGS_TIMESTAMP_COMPLETION = 1 << 0,
327 IB_UVERBS_CQ_FLAGS_IGNORE_OVERRUN = 1 << 1,
Christopher Ferris106b3a82016-08-24 12:15:38 -0700328};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800329struct ib_uverbs_ex_create_cq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700330 __aligned_u64 user_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800331 __u32 cqe;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700332 __u32 comp_vector;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800333 __s32 comp_channel;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800334 __u32 comp_mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800335 __u32 flags;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700336 __u32 reserved;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800337};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800338struct ib_uverbs_create_cq_resp {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800339 __u32 cq_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700340 __u32 cqe;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800341 __aligned_u64 driver_data[0];
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800342};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800343struct ib_uverbs_ex_create_cq_resp {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800344 struct ib_uverbs_create_cq_resp base;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700345 __u32 comp_mask;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800346 __u32 response_length;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800347};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800348struct ib_uverbs_resize_cq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700349 __aligned_u64 response;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800350 __u32 cq_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800351 __u32 cqe;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700352 __aligned_u64 driver_data[0];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700353};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800354struct ib_uverbs_resize_cq_resp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800355 __u32 cqe;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800356 __u32 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700357 __aligned_u64 driver_data[0];
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800358};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800359struct ib_uverbs_poll_cq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700360 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700361 __u32 cq_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800362 __u32 ne;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800363};
Christopher Ferris32ff3f82020-12-14 13:10:04 -0800364enum ib_uverbs_wc_opcode {
365 IB_UVERBS_WC_SEND = 0,
366 IB_UVERBS_WC_RDMA_WRITE = 1,
367 IB_UVERBS_WC_RDMA_READ = 2,
368 IB_UVERBS_WC_COMP_SWAP = 3,
369 IB_UVERBS_WC_FETCH_ADD = 4,
370 IB_UVERBS_WC_BIND_MW = 5,
371 IB_UVERBS_WC_LOCAL_INV = 6,
372 IB_UVERBS_WC_TSO = 7,
373};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800374struct ib_uverbs_wc {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700375 __aligned_u64 wr_id;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800376 __u32 status;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800377 __u32 opcode;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800378 __u32 vendor_err;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700379 __u32 byte_len;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800380 union {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700381 __be32 imm_data;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800382 __u32 invalidate_rkey;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700383 } ex;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800384 __u32 qp_num;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800385 __u32 src_qp;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800386 __u32 wc_flags;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700387 __u16 pkey_index;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800388 __u16 slid;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800389 __u8 sl;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800390 __u8 dlid_path_bits;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700391 __u8 port_num;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800392 __u8 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800393};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800394struct ib_uverbs_poll_cq_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700395 __u32 count;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800396 __u32 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800397 struct ib_uverbs_wc wc[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800398};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700399struct ib_uverbs_req_notify_cq {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800400 __u32 cq_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800401 __u32 solicited_only;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800402};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700403struct ib_uverbs_destroy_cq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700404 __aligned_u64 response;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800405 __u32 cq_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800406 __u32 reserved;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700407};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800408struct ib_uverbs_destroy_cq_resp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800409 __u32 comp_events_reported;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800410 __u32 async_events_reported;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700411};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800412struct ib_uverbs_global_route {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800413 __u8 dgid[16];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800414 __u32 flow_label;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700415 __u8 sgid_index;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800416 __u8 hop_limit;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800417 __u8 traffic_class;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800418 __u8 reserved;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700419};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800420struct ib_uverbs_ah_attr {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800421 struct ib_uverbs_global_route grh;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800422 __u16 dlid;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700423 __u8 sl;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800424 __u8 src_path_bits;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800425 __u8 static_rate;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800426 __u8 is_global;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700427 __u8 port_num;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800428 __u8 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800429};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800430struct ib_uverbs_qp_attr {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700431 __u32 qp_attr_mask;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800432 __u32 qp_state;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800433 __u32 cur_qp_state;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800434 __u32 path_mtu;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700435 __u32 path_mig_state;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800436 __u32 qkey;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800437 __u32 rq_psn;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800438 __u32 sq_psn;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700439 __u32 dest_qp_num;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800440 __u32 qp_access_flags;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800441 struct ib_uverbs_ah_attr ah_attr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800442 struct ib_uverbs_ah_attr alt_ah_attr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700443 __u32 max_send_wr;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800444 __u32 max_recv_wr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800445 __u32 max_send_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800446 __u32 max_recv_sge;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700447 __u32 max_inline_data;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800448 __u16 pkey_index;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800449 __u16 alt_pkey_index;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800450 __u8 en_sqd_async_notify;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700451 __u8 sq_draining;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800452 __u8 max_rd_atomic;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800453 __u8 max_dest_rd_atomic;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800454 __u8 min_rnr_timer;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700455 __u8 port_num;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800456 __u8 timeout;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800457 __u8 retry_cnt;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800458 __u8 rnr_retry;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700459 __u8 alt_port_num;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800460 __u8 alt_timeout;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800461 __u8 reserved[5];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800462};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700463struct ib_uverbs_create_qp {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700464 __aligned_u64 response;
465 __aligned_u64 user_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800466 __u32 pd_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700467 __u32 send_cq_handle;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800468 __u32 recv_cq_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800469 __u32 srq_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800470 __u32 max_send_wr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700471 __u32 max_recv_wr;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800472 __u32 max_send_sge;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800473 __u32 max_recv_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800474 __u32 max_inline_data;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700475 __u8 sq_sig_all;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800476 __u8 qp_type;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800477 __u8 is_srq;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800478 __u8 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700479 __aligned_u64 driver_data[0];
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800480};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800481enum ib_uverbs_create_qp_mask {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800482 IB_UVERBS_CREATE_QP_MASK_IND_TABLE = 1UL << 0,
483};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800484enum {
485 IB_UVERBS_CREATE_QP_SUP_COMP_MASK = IB_UVERBS_CREATE_QP_MASK_IND_TABLE,
486};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800487struct ib_uverbs_ex_create_qp {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700488 __aligned_u64 user_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800489 __u32 pd_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800490 __u32 send_cq_handle;
Tao Baod7db5942015-01-28 10:07:51 -0800491 __u32 recv_cq_handle;
492 __u32 srq_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800493 __u32 max_send_wr;
Tao Baod7db5942015-01-28 10:07:51 -0800494 __u32 max_recv_wr;
495 __u32 max_send_sge;
496 __u32 max_recv_sge;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800497 __u32 max_inline_data;
Tao Baod7db5942015-01-28 10:07:51 -0800498 __u8 sq_sig_all;
499 __u8 qp_type;
500 __u8 is_srq;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800501 __u8 reserved;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800502 __u32 comp_mask;
503 __u32 create_flags;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800504 __u32 rwq_ind_tbl_handle;
Christopher Ferris1308ad32017-11-14 17:32:13 -0800505 __u32 source_qpn;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800506};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700507struct ib_uverbs_open_qp {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700508 __aligned_u64 response;
509 __aligned_u64 user_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800510 __u32 pd_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700511 __u32 qpn;
Tao Baod7db5942015-01-28 10:07:51 -0800512 __u8 qp_type;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800513 __u8 reserved[7];
Christopher Ferris76a1d452018-06-27 14:12:29 -0700514 __aligned_u64 driver_data[0];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700515};
Ben Cheng655a7c02013-10-16 16:09:24 -0700516struct ib_uverbs_create_qp_resp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800517 __u32 qp_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800518 __u32 qpn;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700519 __u32 max_send_wr;
Tao Baod7db5942015-01-28 10:07:51 -0800520 __u32 max_recv_wr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800521 __u32 max_send_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800522 __u32 max_recv_sge;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700523 __u32 max_inline_data;
Tao Baod7db5942015-01-28 10:07:51 -0800524 __u32 reserved;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800525 __u32 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800526};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800527struct ib_uverbs_ex_create_qp_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700528 struct ib_uverbs_create_qp_resp base;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800529 __u32 comp_mask;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800530 __u32 response_length;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800531};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700532struct ib_uverbs_qp_dest {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800533 __u8 dgid[16];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800534 __u32 flow_label;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800535 __u16 dlid;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700536 __u16 reserved;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800537 __u8 sgid_index;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800538 __u8 hop_limit;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800539 __u8 traffic_class;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700540 __u8 sl;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800541 __u8 src_path_bits;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800542 __u8 static_rate;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800543 __u8 is_global;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700544 __u8 port_num;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800545};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800546struct ib_uverbs_query_qp {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700547 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700548 __u32 qp_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800549 __u32 attr_mask;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700550 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800551};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700552struct ib_uverbs_query_qp_resp {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800553 struct ib_uverbs_qp_dest dest;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800554 struct ib_uverbs_qp_dest alt_dest;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800555 __u32 max_send_wr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700556 __u32 max_recv_wr;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800557 __u32 max_send_sge;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800558 __u32 max_recv_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800559 __u32 max_inline_data;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700560 __u32 qkey;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800561 __u32 rq_psn;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800562 __u32 sq_psn;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800563 __u32 dest_qp_num;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700564 __u32 qp_access_flags;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800565 __u16 pkey_index;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800566 __u16 alt_pkey_index;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800567 __u8 qp_state;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700568 __u8 cur_qp_state;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800569 __u8 path_mtu;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800570 __u8 path_mig_state;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800571 __u8 sq_draining;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700572 __u8 max_rd_atomic;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800573 __u8 max_dest_rd_atomic;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800574 __u8 min_rnr_timer;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800575 __u8 port_num;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700576 __u8 timeout;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800577 __u8 retry_cnt;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800578 __u8 rnr_retry;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800579 __u8 alt_port_num;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700580 __u8 alt_timeout;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800581 __u8 sq_sig_all;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800582 __u8 reserved[5];
Christopher Ferris76a1d452018-06-27 14:12:29 -0700583 __aligned_u64 driver_data[0];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700584};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800585struct ib_uverbs_modify_qp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800586 struct ib_uverbs_qp_dest dest;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800587 struct ib_uverbs_qp_dest alt_dest;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700588 __u32 qp_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800589 __u32 attr_mask;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800590 __u32 qkey;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800591 __u32 rq_psn;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700592 __u32 sq_psn;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800593 __u32 dest_qp_num;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800594 __u32 qp_access_flags;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800595 __u16 pkey_index;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700596 __u16 alt_pkey_index;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800597 __u8 qp_state;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800598 __u8 cur_qp_state;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800599 __u8 path_mtu;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700600 __u8 path_mig_state;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800601 __u8 en_sqd_async_notify;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800602 __u8 max_rd_atomic;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800603 __u8 max_dest_rd_atomic;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700604 __u8 min_rnr_timer;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800605 __u8 port_num;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800606 __u8 timeout;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800607 __u8 retry_cnt;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700608 __u8 rnr_retry;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800609 __u8 alt_port_num;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800610 __u8 alt_timeout;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800611 __u8 reserved[2];
Christopher Ferris76a1d452018-06-27 14:12:29 -0700612 __aligned_u64 driver_data[0];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800613};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800614struct ib_uverbs_ex_modify_qp {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800615 struct ib_uverbs_modify_qp base;
616 __u32 rate_limit;
617 __u32 reserved;
618};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800619struct ib_uverbs_ex_modify_qp_resp {
620 __u32 comp_mask;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800621 __u32 response_length;
622};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700623struct ib_uverbs_destroy_qp {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700624 __aligned_u64 response;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800625 __u32 qp_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800626 __u32 reserved;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700627};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800628struct ib_uverbs_destroy_qp_resp {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800629 __u32 events_reported;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800630};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700631struct ib_uverbs_sge {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700632 __aligned_u64 addr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800633 __u32 length;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800634 __u32 lkey;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700635};
Christopher Ferris86a48372019-01-10 14:14:59 -0800636enum ib_uverbs_wr_opcode {
637 IB_UVERBS_WR_RDMA_WRITE = 0,
638 IB_UVERBS_WR_RDMA_WRITE_WITH_IMM = 1,
639 IB_UVERBS_WR_SEND = 2,
640 IB_UVERBS_WR_SEND_WITH_IMM = 3,
641 IB_UVERBS_WR_RDMA_READ = 4,
642 IB_UVERBS_WR_ATOMIC_CMP_AND_SWP = 5,
643 IB_UVERBS_WR_ATOMIC_FETCH_AND_ADD = 6,
644 IB_UVERBS_WR_LOCAL_INV = 7,
645 IB_UVERBS_WR_BIND_MW = 8,
646 IB_UVERBS_WR_SEND_WITH_INV = 9,
647 IB_UVERBS_WR_TSO = 10,
648 IB_UVERBS_WR_RDMA_READ_WITH_INV = 11,
649 IB_UVERBS_WR_MASKED_ATOMIC_CMP_AND_SWP = 12,
650 IB_UVERBS_WR_MASKED_ATOMIC_FETCH_AND_ADD = 13,
651};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800652struct ib_uverbs_send_wr {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700653 __aligned_u64 wr_id;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800654 __u32 num_sge;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700655 __u32 opcode;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800656 __u32 send_flags;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800657 union {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700658 __be32 imm_data;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700659 __u32 invalidate_rkey;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800660 } ex;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800661 union {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800662 struct {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700663 __aligned_u64 remote_addr;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800664 __u32 rkey;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800665 __u32 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800666 } rdma;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700667 struct {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700668 __aligned_u64 remote_addr;
669 __aligned_u64 compare_add;
670 __aligned_u64 swap;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700671 __u32 rkey;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800672 __u32 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800673 } atomic;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800674 struct {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700675 __u32 ah;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800676 __u32 remote_qpn;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800677 __u32 remote_qkey;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800678 __u32 reserved;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700679 } ud;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800680 } wr;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800681};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800682struct ib_uverbs_post_send {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700683 __aligned_u64 response;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800684 __u32 qp_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800685 __u32 wr_count;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800686 __u32 sge_count;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700687 __u32 wqe_size;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800688 struct ib_uverbs_send_wr send_wr[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800689};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800690struct ib_uverbs_post_send_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700691 __u32 bad_wr;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800692};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800693struct ib_uverbs_recv_wr {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700694 __aligned_u64 wr_id;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700695 __u32 num_sge;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800696 __u32 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800697};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800698struct ib_uverbs_post_recv {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700699 __aligned_u64 response;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800700 __u32 qp_handle;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800701 __u32 wr_count;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800702 __u32 sge_count;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700703 __u32 wqe_size;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800704 struct ib_uverbs_recv_wr recv_wr[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800705};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800706struct ib_uverbs_post_recv_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700707 __u32 bad_wr;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800708};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800709struct ib_uverbs_post_srq_recv {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700710 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700711 __u32 srq_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800712 __u32 wr_count;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800713 __u32 sge_count;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800714 __u32 wqe_size;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700715 struct ib_uverbs_recv_wr recv[0];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800716};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800717struct ib_uverbs_post_srq_recv_resp {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800718 __u32 bad_wr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700719};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800720struct ib_uverbs_create_ah {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700721 __aligned_u64 response;
722 __aligned_u64 user_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700723 __u32 pd_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800724 __u32 reserved;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800725 struct ib_uverbs_ah_attr attr;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800726 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800727};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700728struct ib_uverbs_create_ah_resp {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800729 __u32 ah_handle;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800730 __u32 driver_data[0];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800731};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800732struct ib_uverbs_destroy_ah {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700733 __u32 ah_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800734};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800735struct ib_uverbs_attach_mcast {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800736 __u8 gid[16];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700737 __u32 qp_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800738 __u16 mlid;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800739 __u16 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700740 __aligned_u64 driver_data[0];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700741};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800742struct ib_uverbs_detach_mcast {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800743 __u8 gid[16];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800744 __u32 qp_handle;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700745 __u16 mlid;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800746 __u16 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700747 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800748};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700749struct ib_uverbs_flow_spec_hdr {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800750 __u32 type;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800751 __u16 size;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800752 __u16 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700753 __aligned_u64 flow_spec_data[0];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800754};
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800755struct ib_uverbs_flow_eth_filter {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800756 __u8 dst_mac[6];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700757 __u8 src_mac[6];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800758 __be16 ether_type;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800759 __be16 vlan_tag;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800760};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700761struct ib_uverbs_flow_spec_eth {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800762 union {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800763 struct ib_uverbs_flow_spec_hdr hdr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800764 struct {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700765 __u32 type;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800766 __u16 size;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800767 __u16 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800768 };
Christopher Ferris106b3a82016-08-24 12:15:38 -0700769 };
Christopher Ferris05d08e92016-02-04 13:16:38 -0800770 struct ib_uverbs_flow_eth_filter val;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800771 struct ib_uverbs_flow_eth_filter mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800772};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700773struct ib_uverbs_flow_ipv4_filter {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800774 __be32 src_ip;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800775 __be32 dst_ip;
776 __u8 proto;
777 __u8 tos;
778 __u8 ttl;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800779 __u8 flags;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800780};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700781struct ib_uverbs_flow_spec_ipv4 {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800782 union {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800783 struct ib_uverbs_flow_spec_hdr hdr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800784 struct {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700785 __u32 type;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800786 __u16 size;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800787 __u16 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800788 };
Christopher Ferris106b3a82016-08-24 12:15:38 -0700789 };
Christopher Ferris05d08e92016-02-04 13:16:38 -0800790 struct ib_uverbs_flow_ipv4_filter val;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800791 struct ib_uverbs_flow_ipv4_filter mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800792};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700793struct ib_uverbs_flow_tcp_udp_filter {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800794 __be16 dst_port;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800795 __be16 src_port;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800796};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700797struct ib_uverbs_flow_spec_tcp_udp {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800798 union {
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800799 struct ib_uverbs_flow_spec_hdr hdr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800800 struct {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700801 __u32 type;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800802 __u16 size;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800803 __u16 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800804 };
Christopher Ferris106b3a82016-08-24 12:15:38 -0700805 };
Christopher Ferris05d08e92016-02-04 13:16:38 -0800806 struct ib_uverbs_flow_tcp_udp_filter val;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800807 struct ib_uverbs_flow_tcp_udp_filter mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800808};
809struct ib_uverbs_flow_ipv6_filter {
810 __u8 src_ip[16];
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800811 __u8 dst_ip[16];
812 __be32 flow_label;
813 __u8 next_hdr;
814 __u8 traffic_class;
Christopher Ferris6a9755d2017-01-13 14:09:31 -0800815 __u8 hop_limit;
816 __u8 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800817};
818struct ib_uverbs_flow_spec_ipv6 {
819 union {
820 struct ib_uverbs_flow_spec_hdr hdr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800821 struct {
822 __u32 type;
823 __u16 size;
824 __u16 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800825 };
826 };
827 struct ib_uverbs_flow_ipv6_filter val;
828 struct ib_uverbs_flow_ipv6_filter mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800829};
Christopher Ferris525ce912017-07-26 13:12:53 -0700830struct ib_uverbs_flow_spec_action_tag {
831 union {
832 struct ib_uverbs_flow_spec_hdr hdr;
833 struct {
834 __u32 type;
835 __u16 size;
836 __u16 reserved;
837 };
838 };
839 __u32 tag_id;
840 __u32 reserved1;
841};
842struct ib_uverbs_flow_spec_action_drop {
843 union {
844 struct ib_uverbs_flow_spec_hdr hdr;
845 struct {
846 __u32 type;
847 __u16 size;
848 __u16 reserved;
849 };
850 };
851};
Christopher Ferris76a1d452018-06-27 14:12:29 -0700852struct ib_uverbs_flow_spec_action_handle {
853 union {
854 struct ib_uverbs_flow_spec_hdr hdr;
855 struct {
856 __u32 type;
857 __u16 size;
858 __u16 reserved;
859 };
860 };
861 __u32 handle;
862 __u32 reserved1;
863};
Christopher Ferris9ce28842018-10-25 12:11:39 -0700864struct ib_uverbs_flow_spec_action_count {
865 union {
866 struct ib_uverbs_flow_spec_hdr hdr;
867 struct {
868 __u32 type;
869 __u16 size;
870 __u16 reserved;
871 };
872 };
873 __u32 handle;
874 __u32 reserved1;
875};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800876struct ib_uverbs_flow_tunnel_filter {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800877 __be32 tunnel_id;
878};
879struct ib_uverbs_flow_spec_tunnel {
880 union {
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800881 struct ib_uverbs_flow_spec_hdr hdr;
882 struct {
883 __u32 type;
884 __u16 size;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800885 __u16 reserved;
886 };
887 };
888 struct ib_uverbs_flow_tunnel_filter val;
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800889 struct ib_uverbs_flow_tunnel_filter mask;
890};
Christopher Ferris76a1d452018-06-27 14:12:29 -0700891struct ib_uverbs_flow_spec_esp_filter {
892 __u32 spi;
893 __u32 seq;
894};
895struct ib_uverbs_flow_spec_esp {
896 union {
897 struct ib_uverbs_flow_spec_hdr hdr;
898 struct {
899 __u32 type;
900 __u16 size;
901 __u16 reserved;
902 };
903 };
904 struct ib_uverbs_flow_spec_esp_filter val;
905 struct ib_uverbs_flow_spec_esp_filter mask;
906};
Christopher Ferris9ce28842018-10-25 12:11:39 -0700907struct ib_uverbs_flow_gre_filter {
908 __be16 c_ks_res0_ver;
909 __be16 protocol;
910 __be32 key;
911};
912struct ib_uverbs_flow_spec_gre {
913 union {
914 struct ib_uverbs_flow_spec_hdr hdr;
915 struct {
916 __u32 type;
917 __u16 size;
918 __u16 reserved;
919 };
920 };
921 struct ib_uverbs_flow_gre_filter val;
922 struct ib_uverbs_flow_gre_filter mask;
923};
924struct ib_uverbs_flow_mpls_filter {
925 __be32 label;
926};
927struct ib_uverbs_flow_spec_mpls {
928 union {
929 struct ib_uverbs_flow_spec_hdr hdr;
930 struct {
931 __u32 type;
932 __u16 size;
933 __u16 reserved;
934 };
935 };
936 struct ib_uverbs_flow_mpls_filter val;
937 struct ib_uverbs_flow_mpls_filter mask;
938};
Christopher Ferris48af7cb2017-02-21 12:35:09 -0800939struct ib_uverbs_flow_attr {
Christopher Ferris05d08e92016-02-04 13:16:38 -0800940 __u32 type;
Tao Baod7db5942015-01-28 10:07:51 -0800941 __u16 size;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800942 __u16 priority;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700943 __u8 num_of_specs;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800944 __u8 reserved[2];
Tao Baod7db5942015-01-28 10:07:51 -0800945 __u8 port;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800946 __u32 flags;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700947 struct ib_uverbs_flow_spec_hdr flow_specs[0];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800948};
Christopher Ferris38062f92014-07-09 15:33:25 -0700949struct ib_uverbs_create_flow {
Christopher Ferris49f525c2016-12-12 14:55:36 -0800950 __u32 comp_mask;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700951 __u32 qp_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800952 struct ib_uverbs_flow_attr flow_attr;
Christopher Ferris38062f92014-07-09 15:33:25 -0700953};
954struct ib_uverbs_create_flow_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700955 __u32 comp_mask;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800956 __u32 flow_handle;
Christopher Ferris38062f92014-07-09 15:33:25 -0700957};
958struct ib_uverbs_destroy_flow {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700959 __u32 comp_mask;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800960 __u32 flow_handle;
Ben Cheng655a7c02013-10-16 16:09:24 -0700961};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800962struct ib_uverbs_create_srq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700963 __aligned_u64 response;
964 __aligned_u64 user_handle;
Tao Baod7db5942015-01-28 10:07:51 -0800965 __u32 pd_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800966 __u32 max_wr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700967 __u32 max_sge;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800968 __u32 srq_limit;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700969 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -0800970};
Christopher Ferris106b3a82016-08-24 12:15:38 -0700971struct ib_uverbs_create_xsrq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700972 __aligned_u64 response;
973 __aligned_u64 user_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800974 __u32 srq_type;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700975 __u32 pd_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800976 __u32 max_wr;
Tao Baod7db5942015-01-28 10:07:51 -0800977 __u32 max_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800978 __u32 srq_limit;
Christopher Ferris1308ad32017-11-14 17:32:13 -0800979 __u32 max_num_tags;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800980 __u32 xrcd_handle;
Tao Baod7db5942015-01-28 10:07:51 -0800981 __u32 cq_handle;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700982 __aligned_u64 driver_data[0];
Christopher Ferris106b3a82016-08-24 12:15:38 -0700983};
Christopher Ferris05d08e92016-02-04 13:16:38 -0800984struct ib_uverbs_create_srq_resp {
Tao Baod7db5942015-01-28 10:07:51 -0800985 __u32 srq_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800986 __u32 max_wr;
Christopher Ferris106b3a82016-08-24 12:15:38 -0700987 __u32 max_sge;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800988 __u32 srqn;
Christopher Ferrisd842e432019-03-07 10:21:59 -0800989 __u32 driver_data[0];
Ben Cheng655a7c02013-10-16 16:09:24 -0700990};
Christopher Ferris49f525c2016-12-12 14:55:36 -0800991struct ib_uverbs_modify_srq {
Christopher Ferris106b3a82016-08-24 12:15:38 -0700992 __u32 srq_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -0800993 __u32 attr_mask;
Tao Baod7db5942015-01-28 10:07:51 -0800994 __u32 max_wr;
Christopher Ferris49f525c2016-12-12 14:55:36 -0800995 __u32 srq_limit;
Christopher Ferris76a1d452018-06-27 14:12:29 -0700996 __aligned_u64 driver_data[0];
Christopher Ferris05d08e92016-02-04 13:16:38 -0800997};
Ben Cheng655a7c02013-10-16 16:09:24 -0700998struct ib_uverbs_query_srq {
Christopher Ferris76a1d452018-06-27 14:12:29 -0700999 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -07001000 __u32 srq_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -08001001 __u32 reserved;
Christopher Ferris76a1d452018-06-27 14:12:29 -07001002 __aligned_u64 driver_data[0];
Christopher Ferris49f525c2016-12-12 14:55:36 -08001003};
Christopher Ferris106b3a82016-08-24 12:15:38 -07001004struct ib_uverbs_query_srq_resp {
Christopher Ferris05d08e92016-02-04 13:16:38 -08001005 __u32 max_wr;
Tao Baod7db5942015-01-28 10:07:51 -08001006 __u32 max_sge;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001007 __u32 srq_limit;
Christopher Ferris106b3a82016-08-24 12:15:38 -07001008 __u32 reserved;
Christopher Ferris05d08e92016-02-04 13:16:38 -08001009};
Ben Cheng655a7c02013-10-16 16:09:24 -07001010struct ib_uverbs_destroy_srq {
Christopher Ferris76a1d452018-06-27 14:12:29 -07001011 __aligned_u64 response;
Christopher Ferris106b3a82016-08-24 12:15:38 -07001012 __u32 srq_handle;
Christopher Ferris05d08e92016-02-04 13:16:38 -08001013 __u32 reserved;
Ben Cheng655a7c02013-10-16 16:09:24 -07001014};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001015struct ib_uverbs_destroy_srq_resp {
Christopher Ferris106b3a82016-08-24 12:15:38 -07001016 __u32 events_reported;
Christopher Ferris05d08e92016-02-04 13:16:38 -08001017};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001018struct ib_uverbs_ex_create_wq {
Christopher Ferris49f525c2016-12-12 14:55:36 -08001019 __u32 comp_mask;
1020 __u32 wq_type;
Christopher Ferris76a1d452018-06-27 14:12:29 -07001021 __aligned_u64 user_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001022 __u32 pd_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001023 __u32 cq_handle;
1024 __u32 max_wr;
1025 __u32 max_sge;
Christopher Ferris525ce912017-07-26 13:12:53 -07001026 __u32 create_flags;
1027 __u32 reserved;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001028};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001029struct ib_uverbs_ex_create_wq_resp {
1030 __u32 comp_mask;
1031 __u32 response_length;
1032 __u32 wq_handle;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001033 __u32 max_wr;
1034 __u32 max_sge;
1035 __u32 wqn;
1036};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001037struct ib_uverbs_ex_destroy_wq {
1038 __u32 comp_mask;
1039 __u32 wq_handle;
1040};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001041struct ib_uverbs_ex_destroy_wq_resp {
1042 __u32 comp_mask;
1043 __u32 response_length;
1044 __u32 events_reported;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001045 __u32 reserved;
1046};
1047struct ib_uverbs_ex_modify_wq {
1048 __u32 attr_mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001049 __u32 wq_handle;
1050 __u32 wq_state;
1051 __u32 curr_wq_state;
Christopher Ferris525ce912017-07-26 13:12:53 -07001052 __u32 flags;
1053 __u32 flags_mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001054};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001055#define IB_USER_VERBS_MAX_LOG_IND_TBL_SIZE 0x0d
1056struct ib_uverbs_ex_create_rwq_ind_table {
1057 __u32 comp_mask;
1058 __u32 log_ind_tbl_size;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001059 __u32 wq_handles[0];
1060};
1061struct ib_uverbs_ex_create_rwq_ind_table_resp {
1062 __u32 comp_mask;
Christopher Ferris49f525c2016-12-12 14:55:36 -08001063 __u32 response_length;
1064 __u32 ind_tbl_handle;
1065 __u32 ind_tbl_num;
1066};
Christopher Ferris49f525c2016-12-12 14:55:36 -08001067struct ib_uverbs_ex_destroy_rwq_ind_table {
1068 __u32 comp_mask;
1069 __u32 ind_tbl_handle;
1070};
Christopher Ferris934ec942018-01-31 15:29:16 -08001071struct ib_uverbs_cq_moderation {
1072 __u16 cq_count;
1073 __u16 cq_period;
1074};
1075struct ib_uverbs_ex_modify_cq {
1076 __u32 cq_handle;
1077 __u32 attr_mask;
1078 struct ib_uverbs_cq_moderation attr;
1079 __u32 reserved;
1080};
Christopher Ferris525ce912017-07-26 13:12:53 -07001081#define IB_DEVICE_NAME_MAX 64
Ben Cheng655a7c02013-10-16 16:09:24 -07001082#endif