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