1
2
3
4
5
6 #ifndef EFA_ABI_USER_H
7 #define EFA_ABI_USER_H
8
9 #include <linux/types.h>
10
11
12
13
14
15 #define EFA_UVERBS_ABI_VERSION 1
16
17
18
19
20
21
22
23 enum efa_ibv_user_cmds_supp_udata {
24 EFA_USER_CMDS_SUPP_UDATA_QUERY_DEVICE = 1 << 0,
25 EFA_USER_CMDS_SUPP_UDATA_CREATE_AH = 1 << 1,
26 };
27
28 struct efa_ibv_alloc_ucontext_resp {
29 __u32 comp_mask;
30 __u32 cmds_supp_udata_mask;
31 __u16 sub_cqs_per_cq;
32 __u16 inline_buf_size;
33 __u32 max_llq_size;
34 };
35
36 struct efa_ibv_alloc_pd_resp {
37 __u32 comp_mask;
38 __u16 pdn;
39 __u8 reserved_30[2];
40 };
41
42 struct efa_ibv_create_cq {
43 __u32 comp_mask;
44 __u32 cq_entry_size;
45 __u16 num_sub_cqs;
46 __u8 reserved_50[6];
47 };
48
49 struct efa_ibv_create_cq_resp {
50 __u32 comp_mask;
51 __u8 reserved_20[4];
52 __aligned_u64 q_mmap_key;
53 __aligned_u64 q_mmap_size;
54 __u16 cq_idx;
55 __u8 reserved_d0[6];
56 };
57
58 enum {
59 EFA_QP_DRIVER_TYPE_SRD = 0,
60 };
61
62 struct efa_ibv_create_qp {
63 __u32 comp_mask;
64 __u32 rq_ring_size;
65 __u32 sq_ring_size;
66 __u32 driver_qp_type;
67 };
68
69 struct efa_ibv_create_qp_resp {
70 __u32 comp_mask;
71
72 __u32 rq_db_offset;
73
74 __u32 sq_db_offset;
75
76 __u32 llq_desc_offset;
77 __aligned_u64 rq_mmap_key;
78 __aligned_u64 rq_mmap_size;
79 __aligned_u64 rq_db_mmap_key;
80 __aligned_u64 sq_db_mmap_key;
81 __aligned_u64 llq_desc_mmap_key;
82 __u16 send_sub_cq_idx;
83 __u16 recv_sub_cq_idx;
84 __u8 reserved_1e0[4];
85 };
86
87 struct efa_ibv_create_ah_resp {
88 __u32 comp_mask;
89 __u16 efa_address_handle;
90 __u8 reserved_30[2];
91 };
92
93 struct efa_ibv_ex_query_device_resp {
94 __u32 comp_mask;
95 __u32 max_sq_wr;
96 __u32 max_rq_wr;
97 __u16 max_sq_sge;
98 __u16 max_rq_sge;
99 };
100
101 #endif