27 items
NAME ↑ SIZE MODIFIED PERMS ACTIONS
.. / Parent Directory
hfi — dir
2026-06-09 20:11 · rwxr-xr-x
2026-06-09 20:11 rwxr-xr-x
bnxt_re-abi.h — 5.55 KB
2026-05-19 19:43 · rw-r--r--
5.55 KB 2026-05-19 19:43 rw-r--r--
cxgb4-abi.h — 3.05 KB
2026-05-19 19:43 · rw-r--r--
3.05 KB 2026-05-19 19:43 rw-r--r--
efa-abi.h — 3.57 KB
2026-05-19 19:43 · rw-r--r--
3.57 KB 2026-05-19 19:43 rw-r--r--
hns-abi.h — 2.62 KB
2026-05-19 19:43 · rw-r--r--
2.62 KB 2026-05-19 19:43 rw-r--r--
ib_user_ioctl_cmds.h — 9.67 KB
2026-05-19 19:43 · rw-r--r--
9.67 KB 2026-05-19 19:43 rw-r--r--
ib_user_ioctl_verbs.h — 7.77 KB
2026-05-19 19:43 · rw-r--r--
7.77 KB 2026-05-19 19:43 rw-r--r--
ib_user_mad.h — 8.33 KB
2026-05-19 19:43 · rw-r--r--
8.33 KB 2026-05-19 19:43 rw-r--r--
ib_user_sa.h — 2.25 KB
2026-05-19 19:43 · rw-r--r--
2.25 KB 2026-05-19 19:43 rw-r--r--
ib_user_verbs.h — 28.29 KB
2026-05-19 19:43 · rw-r--r--
28.29 KB 2026-05-19 19:43 rw-r--r--
irdma-abi.h — 2.32 KB
2026-05-19 19:43 · rw-r--r--
2.32 KB 2026-05-19 19:43 rw-r--r--
mana-abi.h — 1.48 KB
2026-05-19 19:43 · rw-r--r--
1.48 KB 2026-05-19 19:43 rw-r--r--
mlx4-abi.h — 5 KB
2026-05-19 19:43 · rw-r--r--
5 KB 2026-05-19 19:43 rw-r--r--
mlx5-abi.h — 13.73 KB
2026-05-19 19:43 · rw-r--r--
13.73 KB 2026-05-19 19:43 rw-r--r--
mlx5_user_ioctl_cmds.h — 10.94 KB
2026-05-19 19:43 · rw-r--r--
10.94 KB 2026-05-19 19:43 rw-r--r--
mlx5_user_ioctl_verbs.h — 3.73 KB
2026-05-19 19:43 · rw-r--r--
3.73 KB 2026-05-19 19:43 rw-r--r--
mthca-abi.h — 2.98 KB
2026-05-19 19:43 · rw-r--r--
2.98 KB 2026-05-19 19:43 rw-r--r--
ocrdma-abi.h — 4.02 KB
2026-05-19 19:43 · rw-r--r--
4.02 KB 2026-05-19 19:43 rw-r--r--
qedr-abi.h — 4.21 KB
2026-05-19 19:43 · rw-r--r--
4.21 KB 2026-05-19 19:43 rw-r--r--
rdma_netlink.h — 15.7 KB
2026-05-19 19:43 · rw-r--r--
15.7 KB 2026-05-19 19:43 rw-r--r--
rdma_user_cm.h — 6.96 KB
2026-05-19 19:43 · rw-r--r--
6.96 KB 2026-05-19 19:43 rw-r--r--
rdma_user_ioctl.h — 3.66 KB
2026-05-19 19:43 · rw-r--r--
3.66 KB 2026-05-19 19:43 rw-r--r--
rdma_user_ioctl_cmds.h — 2.56 KB
2026-05-19 19:43 · rw-r--r--
2.56 KB 2026-05-19 19:43 rw-r--r--
rdma_user_rxe.h — 4.86 KB
2026-05-19 19:43 · rw-r--r--
4.86 KB 2026-05-19 19:43 rw-r--r--
rvt-abi.h — 1.73 KB
2026-05-19 19:43 · rw-r--r--
1.73 KB 2026-05-19 19:43 rw-r--r--
siw-abi.h — 3.35 KB
2026-05-19 19:43 · rw-r--r--
3.35 KB 2026-05-19 19:43 rw-r--r--
vmw_pvrdma-abi.h — 7.82 KB
2026-05-19 19:43 · rw-r--r--
7.82 KB 2026-05-19 19:43 rw-r--r--
ONLINE
rdma
27 items
11:20:49
TERMINAL FM
Edit
Preview
Download
Rename
Copy
Chmod
Delete
/* SPDX-License-Identifier: (GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause */ /* Authors: Bernard Metzler */ /* Copyright (c) 2008-2019, IBM Corporation */ #ifndef _SIW_USER_H #define _SIW_USER_H #include #define SIW_NODE_DESC_COMMON "Software iWARP stack" #define SIW_ABI_VERSION 1 #define SIW_MAX_SGE 6 #define SIW_UOBJ_MAX_KEY 0x08FFFF #define SIW_INVAL_UOBJ_KEY (SIW_UOBJ_MAX_KEY + 1) struct siw_uresp_create_cq { __u32 cq_id; __u32 num_cqe; __aligned_u64 cq_key; }; struct siw_uresp_create_qp { __u32 qp_id; __u32 num_sqe; __u32 num_rqe; __u32 pad; __aligned_u64 sq_key; __aligned_u64 rq_key; }; struct siw_ureq_reg_mr { __u8 stag_key; __u8 reserved[3]; __u32 pad; }; struct siw_uresp_reg_mr { __u32 stag; __u32 pad; }; struct siw_uresp_create_srq { __u32 num_rqe; __u32 pad; __aligned_u64 srq_key; }; struct siw_uresp_alloc_ctx { __u32 dev_id; __u32 pad; }; enum siw_opcode { SIW_OP_WRITE, SIW_OP_READ, SIW_OP_READ_LOCAL_INV, SIW_OP_SEND, SIW_OP_SEND_WITH_IMM, SIW_OP_SEND_REMOTE_INV, /* Unsupported */ SIW_OP_FETCH_AND_ADD, SIW_OP_COMP_AND_SWAP, SIW_OP_RECEIVE, /* provider internal SQE */ SIW_OP_READ_RESPONSE, /* * below opcodes valid for * in-kernel clients only */ SIW_OP_INVAL_STAG, SIW_OP_REG_MR, SIW_NUM_OPCODES }; /* Keep it same as ibv_sge to allow for memcpy */ struct siw_sge { __aligned_u64 laddr; __u32 length; __u32 lkey; }; /* * Inline data are kept within the work request itself occupying * the space of sge[1] .. sge[n]. Therefore, __inline__ data cannot be * supported if SIW_MAX_SGE is below 2 elements. */ #define SIW_MAX_INLINE (sizeof(struct siw_sge) * (SIW_MAX_SGE - 1)) #if SIW_MAX_SGE < 2 #error "SIW_MAX_SGE must be at least 2" #endif enum siw_wqe_flags { SIW_WQE_VALID = 1, SIW_WQE_INLINE = (1 << 1), SIW_WQE_SIGNALLED = (1 << 2), SIW_WQE_SOLICITED = (1 << 3), SIW_WQE_READ_FENCE = (1 << 4), SIW_WQE_REM_INVAL = (1 << 5), SIW_WQE_COMPLETED = (1 << 6) }; /* Send Queue Element */ struct siw_sqe { __aligned_u64 id; __u16 flags; __u8 num_sge; /* Contains enum siw_opcode values */ __u8 opcode; __u32 rkey; union { __aligned_u64 raddr; __aligned_u64 base_mr; }; union { struct siw_sge sge[SIW_MAX_SGE]; __aligned_u64 access; }; }; /* Receive Queue Element */ struct siw_rqe { __aligned_u64 id; __u16 flags; __u8 num_sge; /* * only used by kernel driver, * ignored if set by user */ __u8 opcode; __u32 unused; struct siw_sge sge[SIW_MAX_SGE]; }; enum siw_notify_flags { SIW_NOTIFY_NOT = (0), SIW_NOTIFY_SOLICITED = (1 << 0), SIW_NOTIFY_NEXT_COMPLETION = (1 << 1), SIW_NOTIFY_MISSED_EVENTS = (1 << 2), SIW_NOTIFY_ALL = SIW_NOTIFY_SOLICITED | SIW_NOTIFY_NEXT_COMPLETION | SIW_NOTIFY_MISSED_EVENTS }; enum siw_wc_status { SIW_WC_SUCCESS, SIW_WC_LOC_LEN_ERR, SIW_WC_LOC_PROT_ERR, SIW_WC_LOC_QP_OP_ERR, SIW_WC_WR_FLUSH_ERR, SIW_WC_BAD_RESP_ERR, SIW_WC_LOC_ACCESS_ERR, SIW_WC_REM_ACCESS_ERR, SIW_WC_REM_INV_REQ_ERR, SIW_WC_GENERAL_ERR, SIW_NUM_WC_STATUS }; struct siw_cqe { __aligned_u64 id; __u8 flags; __u8 opcode; __u16 status; __u32 bytes; union { __aligned_u64 imm_data; __u32 inval_stag; }; /* QP number or QP pointer */ union { struct ib_qp *base_qp; __aligned_u64 qp_id; }; }; /* * Shared structure between user and kernel * to control CQ arming. */ struct siw_cq_ctrl { __u32 flags; __u32 pad; }; #endif