1 /* SPDX-License-Identifier: (GPL-2.0 WITH Linux-syscall-note) or BSD-3-Clause */
2 
3 /* Authors: Bernard Metzler <bmt@zurich.ibm.com> */
4 /* Copyright (c) 2008-2019, IBM Corporation */
5 
6 #ifndef _SIW_USER_H
7 #define _SIW_USER_H
8 
9 #include <linux/types.h>
10 
11 #define SIW_NODE_DESC_COMMON "Software iWARP stack"
12 #define SIW_ABI_VERSION 1
13 #define SIW_MAX_SGE 6
14 #define SIW_UOBJ_MAX_KEY 0x08FFFF
15 #define SIW_INVAL_UOBJ_KEY (SIW_UOBJ_MAX_KEY + 1)
16 
17 struct siw_uresp_create_cq {
18 	__u32 cq_id;
19 	__u32 num_cqe;
20 	__aligned_u64 cq_key;
21 };
22 
23 struct siw_uresp_create_qp {
24 	__u32 qp_id;
25 	__u32 num_sqe;
26 	__u32 num_rqe;
27 	__u32 pad;
28 	__aligned_u64 sq_key;
29 	__aligned_u64 rq_key;
30 };
31 
32 struct siw_ureq_reg_mr {
33 	__u8 stag_key;
34 	__u8 reserved[3];
35 	__u32 pad;
36 };
37 
38 struct siw_uresp_reg_mr {
39 	__u32 stag;
40 	__u32 pad;
41 };
42 
43 struct siw_uresp_create_srq {
44 	__u32 num_rqe;
45 	__u32 pad;
46 	__aligned_u64 srq_key;
47 };
48 
49 struct siw_uresp_alloc_ctx {
50 	__u32 dev_id;
51 	__u32 pad;
52 };
53 
54 enum siw_opcode {
55 	SIW_OP_WRITE,
56 	SIW_OP_READ,
57 	SIW_OP_READ_LOCAL_INV,
58 	SIW_OP_SEND,
59 	SIW_OP_SEND_WITH_IMM,
60 	SIW_OP_SEND_REMOTE_INV,
61 
62 	/* Unsupported */
63 	SIW_OP_FETCH_AND_ADD,
64 	SIW_OP_COMP_AND_SWAP,
65 
66 	SIW_OP_RECEIVE,
67 	/* provider internal SQE */
68 	SIW_OP_READ_RESPONSE,
69 	/*
70 	 * below opcodes valid for
71 	 * in-kernel clients only
72 	 */
73 	SIW_OP_INVAL_STAG,
74 	SIW_OP_REG_MR,
75 	SIW_NUM_OPCODES
76 };
77 
78 /* Keep it same as ibv_sge to allow for memcpy */
79 struct siw_sge {
80 	__aligned_u64 laddr;
81 	__u32 length;
82 	__u32 lkey;
83 };
84 
85 /*
86  * Inline data are kept within the work request itself occupying
87  * the space of sge[1] .. sge[n]. Therefore, inline data cannot be
88  * supported if SIW_MAX_SGE is below 2 elements.
89  */
90 #define SIW_MAX_INLINE (sizeof(struct siw_sge) * (SIW_MAX_SGE - 1))
91 
92 #if SIW_MAX_SGE < 2
93 #error "SIW_MAX_SGE must be at least 2"
94 #endif
95 
96 enum siw_wqe_flags {
97 	SIW_WQE_VALID = 1,
98 	SIW_WQE_INLINE = (1 << 1),
99 	SIW_WQE_SIGNALLED = (1 << 2),
100 	SIW_WQE_SOLICITED = (1 << 3),
101 	SIW_WQE_READ_FENCE = (1 << 4),
102 	SIW_WQE_REM_INVAL = (1 << 5),
103 	SIW_WQE_COMPLETED = (1 << 6)
104 };
105 
106 /* Send Queue Element */
107 struct siw_sqe {
108 	__aligned_u64 id;
109 	__u16 flags;
110 	__u8 num_sge;
111 	/* Contains enum siw_opcode values */
112 	__u8 opcode;
113 	__u32 rkey;
114 	union {
115 		__aligned_u64 raddr;
116 		__aligned_u64 base_mr;
117 	};
118 	union {
119 		struct siw_sge sge[SIW_MAX_SGE];
120 		__aligned_u64 access;
121 	};
122 };
123 
124 /* Receive Queue Element */
125 struct siw_rqe {
126 	__aligned_u64 id;
127 	__u16 flags;
128 	__u8 num_sge;
129 	/*
130 	 * only used by kernel driver,
131 	 * ignored if set by user
132 	 */
133 	__u8 opcode;
134 	__u32 unused;
135 	struct siw_sge sge[SIW_MAX_SGE];
136 };
137 
138 enum siw_notify_flags {
139 	SIW_NOTIFY_NOT = (0),
140 	SIW_NOTIFY_SOLICITED = (1 << 0),
141 	SIW_NOTIFY_NEXT_COMPLETION = (1 << 1),
142 	SIW_NOTIFY_MISSED_EVENTS = (1 << 2),
143 	SIW_NOTIFY_ALL = SIW_NOTIFY_SOLICITED | SIW_NOTIFY_NEXT_COMPLETION |
144 			 SIW_NOTIFY_MISSED_EVENTS
145 };
146 
147 enum siw_wc_status {
148 	SIW_WC_SUCCESS,
149 	SIW_WC_LOC_LEN_ERR,
150 	SIW_WC_LOC_PROT_ERR,
151 	SIW_WC_LOC_QP_OP_ERR,
152 	SIW_WC_WR_FLUSH_ERR,
153 	SIW_WC_BAD_RESP_ERR,
154 	SIW_WC_LOC_ACCESS_ERR,
155 	SIW_WC_REM_ACCESS_ERR,
156 	SIW_WC_REM_INV_REQ_ERR,
157 	SIW_WC_GENERAL_ERR,
158 	SIW_NUM_WC_STATUS
159 };
160 
161 struct siw_cqe {
162 	__aligned_u64 id;
163 	__u8 flags;
164 	__u8 opcode;
165 	__u16 status;
166 	__u32 bytes;
167 	union {
168 		__aligned_u64 imm_data;
169 		__u32 inval_stag;
170 	};
171 	/* QP number or QP pointer */
172 	union {
173 		struct ib_qp *base_qp;
174 		__aligned_u64 qp_id;
175 	};
176 };
177 
178 /*
179  * Shared structure between user and kernel
180  * to control CQ arming.
181  */
182 struct siw_cq_ctrl {
183 	__u32 flags;
184 	__u32 pad;
185 };
186 #endif
187