rdma_backend.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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 "rdma_rm_defs.h"
  19. #include "rdma_backend_defs.h"
  20. /* Add definition for QP0 and QP1 as there is no userspace enums for them */
  21. enum ibv_special_qp_type {
  22. IBV_QPT_SMI = 0,
  23. IBV_QPT_GSI = 1,
  24. };
  25. static inline union ibv_gid *rdma_backend_gid(RdmaBackendDev *dev)
  26. {
  27. return &dev->gid;
  28. }
  29. static inline uint32_t rdma_backend_qpn(const RdmaBackendQP *qp)
  30. {
  31. return qp->ibqp ? qp->ibqp->qp_num : 0;
  32. }
  33. static inline uint32_t rdma_backend_mr_lkey(const RdmaBackendMR *mr)
  34. {
  35. return mr->ibmr ? mr->ibmr->lkey : 0;
  36. }
  37. static inline uint32_t rdma_backend_mr_rkey(const RdmaBackendMR *mr)
  38. {
  39. return mr->ibmr ? mr->ibmr->rkey : 0;
  40. }
  41. int rdma_backend_init(RdmaBackendDev *backend_dev,
  42. RdmaDeviceResources *rdma_dev_res,
  43. const char *backend_device_name, uint8_t port_num,
  44. uint8_t backend_gid_idx, struct ibv_device_attr *dev_attr,
  45. Error **errp);
  46. void rdma_backend_fini(RdmaBackendDev *backend_dev);
  47. void rdma_backend_register_comp_handler(void (*handler)(int status,
  48. unsigned int vendor_err, void *ctx));
  49. void rdma_backend_unregister_comp_handler(void);
  50. int rdma_backend_query_port(RdmaBackendDev *backend_dev,
  51. struct ibv_port_attr *port_attr);
  52. int rdma_backend_create_pd(RdmaBackendDev *backend_dev, RdmaBackendPD *pd);
  53. void rdma_backend_destroy_pd(RdmaBackendPD *pd);
  54. int rdma_backend_create_mr(RdmaBackendMR *mr, RdmaBackendPD *pd, void *addr,
  55. size_t length, int access);
  56. void rdma_backend_destroy_mr(RdmaBackendMR *mr);
  57. int rdma_backend_create_cq(RdmaBackendDev *backend_dev, RdmaBackendCQ *cq,
  58. int cqe);
  59. void rdma_backend_destroy_cq(RdmaBackendCQ *cq);
  60. void rdma_backend_poll_cq(RdmaDeviceResources *rdma_dev_res, RdmaBackendCQ *cq);
  61. int rdma_backend_create_qp(RdmaBackendQP *qp, uint8_t qp_type,
  62. RdmaBackendPD *pd, RdmaBackendCQ *scq,
  63. RdmaBackendCQ *rcq, uint32_t max_send_wr,
  64. uint32_t max_recv_wr, uint32_t max_send_sge,
  65. uint32_t max_recv_sge);
  66. int rdma_backend_qp_state_init(RdmaBackendDev *backend_dev, RdmaBackendQP *qp,
  67. uint8_t qp_type, uint32_t qkey);
  68. int rdma_backend_qp_state_rtr(RdmaBackendDev *backend_dev, RdmaBackendQP *qp,
  69. uint8_t qp_type, union ibv_gid *dgid,
  70. uint32_t dqpn, uint32_t rq_psn, uint32_t qkey,
  71. bool use_qkey);
  72. int rdma_backend_qp_state_rts(RdmaBackendQP *qp, uint8_t qp_type,
  73. uint32_t sq_psn, uint32_t qkey, bool use_qkey);
  74. int rdma_backend_query_qp(RdmaBackendQP *qp, struct ibv_qp_attr *attr,
  75. int attr_mask, struct ibv_qp_init_attr *init_attr);
  76. void rdma_backend_destroy_qp(RdmaBackendQP *qp);
  77. void rdma_backend_post_send(RdmaBackendDev *backend_dev,
  78. RdmaBackendQP *qp, uint8_t qp_type,
  79. struct ibv_sge *sge, uint32_t num_sge,
  80. union ibv_gid *dgid, uint32_t dqpn, uint32_t dqkey,
  81. void *ctx);
  82. void rdma_backend_post_recv(RdmaBackendDev *backend_dev,
  83. RdmaDeviceResources *rdma_dev_res,
  84. RdmaBackendQP *qp, uint8_t qp_type,
  85. struct ibv_sge *sge, uint32_t num_sge, void *ctx);
  86. #endif