-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathrdma_ctrl.hpp
115 lines (88 loc) · 3.23 KB
/
rdma_ctrl.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#pragma once
#include <memory>
#include "qp.hpp"
namespace rdmaio {
const int MAX_SERVER_SUPPORTED = 16;
typedef RUDQP<default_ud_config,MAX_SERVER_SUPPORTED> UDQP;
typedef RRCQP<default_rc_config> RCQP;
typedef std::function<void (const QPConnArg &)> connection_callback_t;
class RdmaCtrl {
public:
RdmaCtrl(int node_id, int tcp_base_port,
connection_callback_t callback = [](const QPConnArg &) {
// the default callback does nothing
},
std::string ip = "localhost");
~RdmaCtrl();
int current_node_id();
int listening_port();
typedef struct {
int dev_id;
int port_id;
} DevIdx;
/**
* Query devices info on this machine,
* if there is a previous call, return previous results unless clear_dev_info has been called
*/
std::vector<RNicInfo> query_devs();
static std::vector<RNicInfo> query_devs_helper();
// clear the cached infos by RdmaCtrl;
void clear_dev_info();
/**
* Open device handlers.
* RdmaCtrl opens a device for each thread.
* The get_device returns previously opened device of this thread, if it is already opened
*/
RNicHandler *open_thread_local_device(DevIdx idx);
RNicHandler *open_device(DevIdx idx);
RNicHandler *get_device();
/**
* The *callback* is called once a QP connection request is sent to this server
*/
void register_qp_callback(connection_callback_t callback);
void close_device();
void close_device(RNicHandler *);
/**
* Each RDMA NIC has multiple ports, so we use two-dimeson index to locate the target port.
* convert_port_idx provides a way to translate the one-dimeson index to the two-dimeson
*/
DevIdx convert_port_idx(int idx);
/**
* Register memory to a specific RNIC handler
*/
bool register_memory(int id,const char *buf,uint64_t size,RNicHandler *rnic,
int flag = Memory::DEFAULT_PROTECTION_FLAG);
/**
* Get the local registered memory
* undefined if mr_id has been registered
*/
MemoryAttr get_local_mr(int mr_id);
/**
* Return an arbitrary registered MR
* return -1 if no MR is registered to RdmaCtrl
* return the first mr index, if found one
*/
int get_default_mr(MemoryAttr &attr);
/**
* Create and query QPs
* For create, an optional local_attr can be provided to bind to this QP
* A local MR is passed as the default local mr for this QP.
* If local_attr = nullptr, then this QP is unbind to any MR.
*/
RCQP *create_rc_qp(QPIdx idx, RNicHandler *dev,MemoryAttr *local_attr = NULL);
UDQP *create_ud_qp(QPIdx idx, RNicHandler *dev,MemoryAttr *local_attr = NULL);
RCQP *get_rc_qp(QPIdx idx);
UDQP *get_ud_qp(QPIdx idx);
/**
* Some helper functions (example usage of RdmaCtrl)
* Fully link the QP in a symmetric way, for this thread.
* For example, node 0 can connect to node 1, while node 1 connect to node 0.
*/
bool link_symmetric_rcqps(const std::vector<std::string> &cluster,
int l_mrid,int mr_id,int wid,int idx = 0);
private:
class RdmaCtrlImpl;
std::unique_ptr<RdmaCtrlImpl> impl_;
};
} // namespace rdmaio
#include "rdma_ctrl_impl.hpp" // real implemeatation here