]> git.proxmox.com Git - mirror_qemu.git/blame - hw/rdma/rdma_backend.h
Merge remote-tracking branch 'remotes/kraxel/tags/usb-20190607-pull-request' into...
[mirror_qemu.git] / hw / rdma / rdma_backend.h
CommitLineData
ef6d4ccd
YS
1/*
2 * RDMA device: Definitions of Backend Device functions
3 *
4 * Copyright (C) 2018 Oracle
5 * Copyright (C) 2018 Red Hat Inc
6 *
7 * Authors:
8 * Yuval Shaia <yuval.shaia@oracle.com>
9 * Marcel Apfelbaum <marcel@redhat.com>
10 *
11 * This work is licensed under the terms of the GNU GPL, version 2 or later.
12 * See the COPYING file in the top-level directory.
13 *
14 */
15
16#ifndef RDMA_BACKEND_H
17#define RDMA_BACKEND_H
18
0efc9511 19#include "qapi/error.h"
605ec166
YS
20#include "chardev/char-fe.h"
21
ef6d4ccd
YS
22#include "rdma_rm_defs.h"
23#include "rdma_backend_defs.h"
24
ffef4775
YS
25/* Vendor Errors */
26#define VENDOR_ERR_FAIL_BACKEND 0x201
27#define VENDOR_ERR_TOO_MANY_SGES 0x202
28#define VENDOR_ERR_NOMEM 0x203
29#define VENDOR_ERR_QP0 0x204
30#define VENDOR_ERR_INV_NUM_SGE 0x205
31#define VENDOR_ERR_MAD_SEND 0x206
32#define VENDOR_ERR_INVLKEY 0x207
33#define VENDOR_ERR_MR_SMALL 0x208
34#define VENDOR_ERR_INV_MAD_BUFF 0x209
26fd8695 35#define VENDOR_ERR_INV_GID_IDX 0x210
ffef4775 36
ef6d4ccd
YS
37/* Add definition for QP0 and QP1 as there is no userspace enums for them */
38enum ibv_special_qp_type {
39 IBV_QPT_SMI = 0,
40 IBV_QPT_GSI = 1,
41};
42
ef6d4ccd
YS
43static inline uint32_t rdma_backend_qpn(const RdmaBackendQP *qp)
44{
46462cb1 45 return qp->ibqp ? qp->ibqp->qp_num : 1;
ef6d4ccd
YS
46}
47
48static inline uint32_t rdma_backend_mr_lkey(const RdmaBackendMR *mr)
49{
50 return mr->ibmr ? mr->ibmr->lkey : 0;
51}
52
53static inline uint32_t rdma_backend_mr_rkey(const RdmaBackendMR *mr)
54{
55 return mr->ibmr ? mr->ibmr->rkey : 0;
56}
57
430e440c 58int rdma_backend_init(RdmaBackendDev *backend_dev, PCIDevice *pdev,
ef6d4ccd
YS
59 RdmaDeviceResources *rdma_dev_res,
60 const char *backend_device_name, uint8_t port_num,
4d71b38a
YS
61 struct ibv_device_attr *dev_attr,
62 CharBackend *mad_chr_be);
ef6d4ccd 63void rdma_backend_fini(RdmaBackendDev *backend_dev);
2b05705d
YS
64int rdma_backend_add_gid(RdmaBackendDev *backend_dev, const char *ifname,
65 union ibv_gid *gid);
66int rdma_backend_del_gid(RdmaBackendDev *backend_dev, const char *ifname,
67 union ibv_gid *gid);
68int rdma_backend_get_gid_index(RdmaBackendDev *backend_dev,
69 union ibv_gid *gid);
75152227
YS
70void rdma_backend_start(RdmaBackendDev *backend_dev);
71void rdma_backend_stop(RdmaBackendDev *backend_dev);
eaac0100
YS
72void rdma_backend_register_comp_handler(void (*handler)(void *ctx,
73 struct ibv_wc *wc));
ef6d4ccd
YS
74void rdma_backend_unregister_comp_handler(void);
75
76int rdma_backend_query_port(RdmaBackendDev *backend_dev,
77 struct ibv_port_attr *port_attr);
78int rdma_backend_create_pd(RdmaBackendDev *backend_dev, RdmaBackendPD *pd);
79void rdma_backend_destroy_pd(RdmaBackendPD *pd);
80
9bbb8d35 81int rdma_backend_create_mr(RdmaBackendMR *mr, RdmaBackendPD *pd, void *addr,
ef6d4ccd
YS
82 size_t length, int access);
83void rdma_backend_destroy_mr(RdmaBackendMR *mr);
84
85int rdma_backend_create_cq(RdmaBackendDev *backend_dev, RdmaBackendCQ *cq,
86 int cqe);
87void rdma_backend_destroy_cq(RdmaBackendCQ *cq);
88void rdma_backend_poll_cq(RdmaDeviceResources *rdma_dev_res, RdmaBackendCQ *cq);
89
90int rdma_backend_create_qp(RdmaBackendQP *qp, uint8_t qp_type,
91 RdmaBackendPD *pd, RdmaBackendCQ *scq,
8b42cfab
KH
92 RdmaBackendCQ *rcq, RdmaBackendSRQ *srq,
93 uint32_t max_send_wr, uint32_t max_recv_wr,
94 uint32_t max_send_sge, uint32_t max_recv_sge);
ef6d4ccd
YS
95int rdma_backend_qp_state_init(RdmaBackendDev *backend_dev, RdmaBackendQP *qp,
96 uint8_t qp_type, uint32_t qkey);
97int rdma_backend_qp_state_rtr(RdmaBackendDev *backend_dev, RdmaBackendQP *qp,
2b05705d
YS
98 uint8_t qp_type, uint8_t sgid_idx,
99 union ibv_gid *dgid, uint32_t dqpn,
100 uint32_t rq_psn, uint32_t qkey, bool use_qkey);
ef6d4ccd
YS
101int rdma_backend_qp_state_rts(RdmaBackendQP *qp, uint8_t qp_type,
102 uint32_t sq_psn, uint32_t qkey, bool use_qkey);
c99f2174
YS
103int rdma_backend_query_qp(RdmaBackendQP *qp, struct ibv_qp_attr *attr,
104 int attr_mask, struct ibv_qp_init_attr *init_attr);
bf441451 105void rdma_backend_destroy_qp(RdmaBackendQP *qp, RdmaDeviceResources *dev_res);
ef6d4ccd
YS
106
107void rdma_backend_post_send(RdmaBackendDev *backend_dev,
108 RdmaBackendQP *qp, uint8_t qp_type,
109 struct ibv_sge *sge, uint32_t num_sge,
2b05705d 110 uint8_t sgid_idx, union ibv_gid *sgid,
ef6d4ccd
YS
111 union ibv_gid *dgid, uint32_t dqpn, uint32_t dqkey,
112 void *ctx);
113void rdma_backend_post_recv(RdmaBackendDev *backend_dev,
ef6d4ccd
YS
114 RdmaBackendQP *qp, uint8_t qp_type,
115 struct ibv_sge *sge, uint32_t num_sge, void *ctx);
116
e926c9f1
KH
117int rdma_backend_create_srq(RdmaBackendSRQ *srq, RdmaBackendPD *pd,
118 uint32_t max_wr, uint32_t max_sge,
119 uint32_t srq_limit);
120int rdma_backend_query_srq(RdmaBackendSRQ *srq, struct ibv_srq_attr *srq_attr);
121int rdma_backend_modify_srq(RdmaBackendSRQ *srq, struct ibv_srq_attr *srq_attr,
122 int srq_attr_mask);
123void rdma_backend_destroy_srq(RdmaBackendSRQ *srq,
124 RdmaDeviceResources *dev_res);
125void rdma_backend_post_srq_recv(RdmaBackendDev *backend_dev,
126 RdmaBackendSRQ *srq, struct ibv_sge *sge,
127 uint32_t num_sge, void *ctx);
128
ef6d4ccd 129#endif