rdma_backend.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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. #ifndef RDMA_BACKEND_H
  16. #define RDMA_BACKEND_H
  17. #include "qapi/error.h"
  18. #include "chardev/char-fe.h"
  19. #include "rdma_rm_defs.h"
  20. #include "rdma_backend_defs.h"
  21. /* Vendor Errors */
  22. #define VENDOR_ERR_FAIL_BACKEND 0x201
  23. #define VENDOR_ERR_TOO_MANY_SGES 0x202
  24. #define VENDOR_ERR_NOMEM 0x203
  25. #define VENDOR_ERR_QP0 0x204
  26. #define VENDOR_ERR_INV_NUM_SGE 0x205
  27. #define VENDOR_ERR_MAD_SEND 0x206
  28. #define VENDOR_ERR_INVLKEY 0x207
  29. #define VENDOR_ERR_MR_SMALL 0x208
  30. #define VENDOR_ERR_INV_MAD_BUFF 0x209
  31. #define VENDOR_ERR_INV_GID_IDX 0x210
  32. /* Add definition for QP0 and QP1 as there is no userspace enums for them */
  33. enum ibv_special_qp_type {
  34. IBV_QPT_SMI = 0,
  35. IBV_QPT_GSI = 1,
  36. };
  37. static inline uint32_t rdma_backend_qpn(const RdmaBackendQP *qp)
  38. {
  39. return qp->ibqp ? qp->ibqp->qp_num : 1;
  40. }
  41. static inline uint32_t rdma_backend_mr_lkey(const RdmaBackendMR *mr)
  42. {
  43. return mr->ibmr ? mr->ibmr->lkey : 0;
  44. }
  45. static inline uint32_t rdma_backend_mr_rkey(const RdmaBackendMR *mr)
  46. {
  47. return mr->ibmr ? mr->ibmr->rkey : 0;
  48. }
  49. int rdma_backend_init(RdmaBackendDev *backend_dev, PCIDevice *pdev,
  50. RdmaDeviceResources *rdma_dev_res,
  51. const char *backend_device_name, uint8_t port_num,
  52. struct ibv_device_attr *dev_attr,
  53. CharBackend *mad_chr_be);
  54. void rdma_backend_fini(RdmaBackendDev *backend_dev);
  55. int rdma_backend_add_gid(RdmaBackendDev *backend_dev, const char *ifname,
  56. union ibv_gid *gid);
  57. int rdma_backend_del_gid(RdmaBackendDev *backend_dev, const char *ifname,
  58. union ibv_gid *gid);
  59. int rdma_backend_get_gid_index(RdmaBackendDev *backend_dev,
  60. union ibv_gid *gid);
  61. void rdma_backend_start(RdmaBackendDev *backend_dev);
  62. void rdma_backend_stop(RdmaBackendDev *backend_dev);
  63. void rdma_backend_register_comp_handler(void (*handler)(void *ctx,
  64. struct ibv_wc *wc));
  65. void rdma_backend_unregister_comp_handler(void);
  66. int rdma_backend_query_port(RdmaBackendDev *backend_dev,
  67. struct ibv_port_attr *port_attr);
  68. int rdma_backend_create_pd(RdmaBackendDev *backend_dev, RdmaBackendPD *pd);
  69. void rdma_backend_destroy_pd(RdmaBackendPD *pd);
  70. #ifdef LEGACY_RDMA_REG_MR
  71. int rdma_backend_create_mr(RdmaBackendMR *mr, RdmaBackendPD *pd, void *addr,
  72. size_t length, int access);
  73. #else
  74. int rdma_backend_create_mr(RdmaBackendMR *mr, RdmaBackendPD *pd, void *addr,
  75. size_t length, uint64_t guest_start, int access);
  76. #endif
  77. void rdma_backend_destroy_mr(RdmaBackendMR *mr);
  78. int rdma_backend_create_cq(RdmaBackendDev *backend_dev, RdmaBackendCQ *cq,
  79. int cqe);
  80. void rdma_backend_destroy_cq(RdmaBackendCQ *cq);
  81. void rdma_backend_poll_cq(RdmaDeviceResources *rdma_dev_res, RdmaBackendCQ *cq);
  82. int rdma_backend_create_qp(RdmaBackendQP *qp, uint8_t qp_type,
  83. RdmaBackendPD *pd, RdmaBackendCQ *scq,
  84. RdmaBackendCQ *rcq, RdmaBackendSRQ *srq,
  85. uint32_t max_send_wr, uint32_t max_recv_wr,
  86. uint32_t max_send_sge, uint32_t max_recv_sge);
  87. int rdma_backend_qp_state_init(RdmaBackendDev *backend_dev, RdmaBackendQP *qp,
  88. uint8_t qp_type, uint32_t qkey);
  89. int rdma_backend_qp_state_rtr(RdmaBackendDev *backend_dev, RdmaBackendQP *qp,
  90. uint8_t qp_type, uint8_t sgid_idx,
  91. union ibv_gid *dgid, uint32_t dqpn,
  92. uint32_t rq_psn, uint32_t qkey, bool use_qkey);
  93. int rdma_backend_qp_state_rts(RdmaBackendQP *qp, uint8_t qp_type,
  94. uint32_t sq_psn, uint32_t qkey, bool use_qkey);
  95. int rdma_backend_query_qp(RdmaBackendQP *qp, struct ibv_qp_attr *attr,
  96. int attr_mask, struct ibv_qp_init_attr *init_attr);
  97. void rdma_backend_destroy_qp(RdmaBackendQP *qp, RdmaDeviceResources *dev_res);
  98. void rdma_backend_post_send(RdmaBackendDev *backend_dev,
  99. RdmaBackendQP *qp, uint8_t qp_type,
  100. struct ibv_sge *sge, uint32_t num_sge,
  101. uint8_t sgid_idx, union ibv_gid *sgid,
  102. union ibv_gid *dgid, uint32_t dqpn, uint32_t dqkey,
  103. void *ctx);
  104. void rdma_backend_post_recv(RdmaBackendDev *backend_dev,
  105. RdmaBackendQP *qp, uint8_t qp_type,
  106. struct ibv_sge *sge, uint32_t num_sge, void *ctx);
  107. int rdma_backend_create_srq(RdmaBackendSRQ *srq, RdmaBackendPD *pd,
  108. uint32_t max_wr, uint32_t max_sge,
  109. uint32_t srq_limit);
  110. int rdma_backend_query_srq(RdmaBackendSRQ *srq, struct ibv_srq_attr *srq_attr);
  111. int rdma_backend_modify_srq(RdmaBackendSRQ *srq, struct ibv_srq_attr *srq_attr,
  112. int srq_attr_mask);
  113. void rdma_backend_destroy_srq(RdmaBackendSRQ *srq,
  114. RdmaDeviceResources *dev_res);
  115. void rdma_backend_post_srq_recv(RdmaBackendDev *backend_dev,
  116. RdmaBackendSRQ *srq, struct ibv_sge *sge,
  117. uint32_t num_sge, void *ctx);
  118. #endif