RDMA基础
基础步骤
应用程序需分别
经历 打 开 设 备 dev_list = ibv_get_device_list(NULL);
创 建 保 护 域 (protection domain, PD)ib_res.pd = ibv_alloc_pd(ib_res.ctx);
用来注册内存和创建qps
申 请 并 注 册 内 存 ib_res.mr = ibv_reg_mr(ib_res.pd, (void *)ib_res.ib_buf,
用于存储message,用户必须保证没有被处理的旧message不能被新到来的数据覆盖
创 建 完 成 队 列 (completion queue,CQ)ib_res.cq = ibv_create_cq(ib_res.ctx, ib_res.dev_attr.max_cqe,
cq用于send/recv语义,用于告诉程序操作已经完成
创 建 收 发 队 列 (queue pair,QP)ib_res.srq = ibv_create_srq(ib_res.pd, &srq_init_attr);
初 始 化 QP 等过程
for (i = 0; i < ib_res.num_qps; i++)
{
ib_res.qp[i] = ibv_create_qp(ib_res.pd, &qp_init_attr);
check(ib_res.qp[i] != NULL, "Failed to create qp[%d]", i);
}