[openib-general] [PATCH v3 2/6] libibverbs source files changes.
Krishna Kumar
krkumar2 at in.ibm.com
Thu Aug 3 00:10:53 PDT 2006
Source files in libibverbs defining the new API.
Signed-off-by: Krishna Kumar <krkumar2 at in.ibm.com>
diff -ruNp ORG/libibverbs/src/cmd.c NEW/libibverbs/src/cmd.c
--- ORG/libibverbs/src/cmd.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/cmd.c 2006-08-03 17:29:24.000000000 -0700
@@ -45,16 +45,16 @@
#include <alloca.h>
#include <string.h>
-#include "ibverbs.h"
+#include "rdmaverbs.h"
-static int ibv_cmd_get_context_v2(struct ibv_context *context,
- struct ibv_get_context *new_cmd,
+static int rdmav_cmd_get_context_v2(struct rdmav_context *context,
+ struct rdmav_get_context *new_cmd,
size_t new_cmd_size,
- struct ibv_get_context_resp *resp,
+ struct rdmav_get_context_resp *resp,
size_t resp_size)
{
- struct ibv_abi_compat_v2 *t;
- struct ibv_get_context_v2 *cmd;
+ struct rdmav_abi_compat_v2 *t;
+ struct rdmav_get_context_v2 *cmd;
size_t cmd_size;
uint32_t cq_fd;
@@ -65,9 +65,10 @@ static int ibv_cmd_get_context_v2(struct
cmd_size = sizeof *cmd + new_cmd_size - sizeof *new_cmd;
cmd = alloca(cmd_size);
- memcpy(cmd->driver_data, new_cmd->driver_data, new_cmd_size - sizeof *new_cmd);
+ memcpy(cmd->driver_data, new_cmd->driver_data,
+ new_cmd_size - sizeof *new_cmd);
- IBV_INIT_CMD_RESP(cmd, cmd_size, GET_CONTEXT, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, GET_CONTEXT, resp, resp_size);
cmd->cq_fd_tab = (uintptr_t) &cq_fd;
if (write(context->cmd_fd, cmd, cmd_size) != cmd_size)
@@ -81,14 +82,16 @@ static int ibv_cmd_get_context_v2(struct
return 0;
}
-int ibv_cmd_get_context(struct ibv_context *context, struct ibv_get_context *cmd,
- size_t cmd_size, struct ibv_get_context_resp *resp,
+int rdmav_cmd_get_context(struct rdmav_context *context,
+ struct rdmav_get_context *cmd,
+ size_t cmd_size, struct rdmav_get_context_resp *resp,
size_t resp_size)
{
if (abi_ver <= 2)
- return ibv_cmd_get_context_v2(context, cmd, cmd_size, resp, resp_size);
+ return rdmav_cmd_get_context_v2(context, cmd, cmd_size, resp,
+ resp_size);
- IBV_INIT_CMD_RESP(cmd, cmd_size, GET_CONTEXT, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, GET_CONTEXT, resp, resp_size);
if (write(context->cmd_fd, cmd, cmd_size) != cmd_size)
return errno;
@@ -99,14 +102,14 @@ int ibv_cmd_get_context(struct ibv_conte
return 0;
}
-int ibv_cmd_query_device(struct ibv_context *context,
- struct ibv_device_attr *device_attr,
+int rdmav_cmd_query_device(struct rdmav_context *context,
+ struct rdmav_device_attr *device_attr,
uint64_t *raw_fw_ver,
- struct ibv_query_device *cmd, size_t cmd_size)
+ struct rdmav_query_device *cmd, size_t cmd_size)
{
- struct ibv_query_device_resp resp;
+ struct rdmav_query_device_resp resp;
- IBV_INIT_CMD_RESP(cmd, cmd_size, QUERY_DEVICE, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, QUERY_DEVICE, &resp, sizeof resp);
if (write(context->cmd_fd, cmd, cmd_size) != cmd_size)
return errno;
@@ -156,13 +159,13 @@ int ibv_cmd_query_device(struct ibv_cont
return 0;
}
-int ibv_cmd_query_port(struct ibv_context *context, uint8_t port_num,
- struct ibv_port_attr *port_attr,
- struct ibv_query_port *cmd, size_t cmd_size)
+int rdmav_cmd_query_port(struct rdmav_context *context, uint8_t port_num,
+ struct rdmav_port_attr *port_attr,
+ struct rdmav_query_port *cmd, size_t cmd_size)
{
- struct ibv_query_port_resp resp;
+ struct rdmav_query_port_resp resp;
- IBV_INIT_CMD_RESP(cmd, cmd_size, QUERY_PORT, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, QUERY_PORT, &resp, sizeof resp);
cmd->port_num = port_num;
if (write(context->cmd_fd, cmd, cmd_size) != cmd_size)
@@ -191,11 +194,11 @@ int ibv_cmd_query_port(struct ibv_contex
return 0;
}
-int ibv_cmd_alloc_pd(struct ibv_context *context, struct ibv_pd *pd,
- struct ibv_alloc_pd *cmd, size_t cmd_size,
- struct ibv_alloc_pd_resp *resp, size_t resp_size)
+int rdmav_cmd_alloc_pd(struct rdmav_context *context, struct rdmav_pd *pd,
+ struct rdmav_alloc_pd *cmd, size_t cmd_size,
+ struct rdmav_alloc_pd_resp *resp, size_t resp_size)
{
- IBV_INIT_CMD_RESP(cmd, cmd_size, ALLOC_PD, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, ALLOC_PD, resp, resp_size);
if (write(context->cmd_fd, cmd, cmd_size) != cmd_size)
return errno;
@@ -205,11 +208,11 @@ int ibv_cmd_alloc_pd(struct ibv_context
return 0;
}
-int ibv_cmd_dealloc_pd(struct ibv_pd *pd)
+int rdmav_cmd_dealloc_pd(struct rdmav_pd *pd)
{
- struct ibv_dealloc_pd cmd;
+ struct rdmav_dealloc_pd cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DEALLOC_PD);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DEALLOC_PD);
cmd.pd_handle = pd->handle;
if (write(pd->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -218,14 +221,14 @@ int ibv_cmd_dealloc_pd(struct ibv_pd *pd
return 0;
}
-int ibv_cmd_reg_mr(struct ibv_pd *pd, void *addr, size_t length,
- uint64_t hca_va, enum ibv_access_flags access,
- struct ibv_mr *mr, struct ibv_reg_mr *cmd,
+int rdmav_cmd_reg_mr(struct rdmav_pd *pd, void *addr, size_t length,
+ uint64_t hca_va, enum rdmav_access_flags access,
+ struct rdmav_mr *mr, struct rdmav_reg_mr *cmd,
size_t cmd_size)
{
- struct ibv_reg_mr_resp resp;
+ struct rdmav_reg_mr_resp resp;
- IBV_INIT_CMD_RESP(cmd, cmd_size, REG_MR, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, REG_MR, &resp, sizeof resp);
cmd->start = (uintptr_t) addr;
cmd->length = length;
@@ -243,11 +246,11 @@ int ibv_cmd_reg_mr(struct ibv_pd *pd, vo
return 0;
}
-int ibv_cmd_dereg_mr(struct ibv_mr *mr)
+int rdmav_cmd_dereg_mr(struct rdmav_mr *mr)
{
- struct ibv_dereg_mr cmd;
+ struct rdmav_dereg_mr cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DEREG_MR);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DEREG_MR);
cmd.mr_handle = mr->handle;
if (write(mr->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -256,19 +259,22 @@ int ibv_cmd_dereg_mr(struct ibv_mr *mr)
return 0;
}
-static int ibv_cmd_create_cq_v2(struct ibv_context *context, int cqe,
- struct ibv_cq *cq,
- struct ibv_create_cq *new_cmd, size_t new_cmd_size,
- struct ibv_create_cq_resp *resp, size_t resp_size)
+static int rdmav_cmd_create_cq_v2(struct rdmav_context *context, int cqe,
+ struct rdmav_cq *cq,
+ struct rdmav_create_cq *new_cmd,
+ size_t new_cmd_size,
+ struct rdmav_create_cq_resp *resp,
+ size_t resp_size)
{
- struct ibv_create_cq_v2 *cmd;
+ struct rdmav_create_cq_v2 *cmd;
size_t cmd_size;
cmd_size = sizeof *cmd + new_cmd_size - sizeof *new_cmd;
cmd = alloca(cmd_size);
- memcpy(cmd->driver_data, new_cmd->driver_data, new_cmd_size - sizeof *new_cmd);
+ memcpy(cmd->driver_data, new_cmd->driver_data,
+ new_cmd_size - sizeof *new_cmd);
- IBV_INIT_CMD_RESP(cmd, cmd_size, CREATE_CQ, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, CREATE_CQ, resp, resp_size);
cmd->user_handle = (uintptr_t) cq;
cmd->cqe = cqe;
cmd->event_handler = 0;
@@ -282,17 +288,17 @@ static int ibv_cmd_create_cq_v2(struct i
return 0;
}
-int ibv_cmd_create_cq(struct ibv_context *context, int cqe,
- struct ibv_comp_channel *channel,
- int comp_vector, struct ibv_cq *cq,
- struct ibv_create_cq *cmd, size_t cmd_size,
- struct ibv_create_cq_resp *resp, size_t resp_size)
+int rdmav_cmd_create_cq(struct rdmav_context *context, int cqe,
+ struct rdmav_comp_channel *channel,
+ int comp_vector, struct rdmav_cq *cq,
+ struct rdmav_create_cq *cmd, size_t cmd_size,
+ struct rdmav_create_cq_resp *resp, size_t resp_size)
{
if (abi_ver <= 2)
- return ibv_cmd_create_cq_v2(context, cqe, cq,
+ return rdmav_cmd_create_cq_v2(context, cqe, cq,
cmd, cmd_size, resp, resp_size);
- IBV_INIT_CMD_RESP(cmd, cmd_size, CREATE_CQ, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, CREATE_CQ, resp, resp_size);
cmd->user_handle = (uintptr_t) cq;
cmd->cqe = cqe;
cmd->comp_vector = comp_vector;
@@ -308,20 +314,20 @@ int ibv_cmd_create_cq(struct ibv_context
return 0;
}
-int ibv_cmd_poll_cq(struct ibv_cq *ibcq, int ne, struct ibv_wc *wc)
+int rdmav_cmd_poll_cq(struct rdmav_cq *ibcq, int ne, struct rdmav_wc *wc)
{
- struct ibv_poll_cq cmd;
- struct ibv_poll_cq_resp *resp;
+ struct rdmav_poll_cq cmd;
+ struct rdmav_poll_cq_resp *resp;
int i;
int rsize;
int ret;
- rsize = sizeof *resp + ne * sizeof(struct ibv_kern_wc);
+ rsize = sizeof *resp + ne * sizeof(struct rdmav_kern_wc);
resp = malloc(rsize);
if (!resp)
return -1;
- IBV_INIT_CMD_RESP(&cmd, sizeof cmd, POLL_CQ, resp, rsize);
+ RDMAV_INIT_CMD_RESP(&cmd, sizeof cmd, POLL_CQ, resp, rsize);
cmd.cq_handle = ibcq->handle;
cmd.ne = ne;
@@ -353,11 +359,11 @@ out:
return ret;
}
-int ibv_cmd_req_notify_cq(struct ibv_cq *ibcq, int solicited_only)
+int rdmav_cmd_req_notify_cq(struct rdmav_cq *ibcq, int solicited_only)
{
- struct ibv_req_notify_cq cmd;
+ struct rdmav_req_notify_cq cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, REQ_NOTIFY_CQ);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, REQ_NOTIFY_CQ);
cmd.cq_handle = ibcq->handle;
cmd.solicited = !!solicited_only;
@@ -367,12 +373,12 @@ int ibv_cmd_req_notify_cq(struct ibv_cq
return 0;
}
-int ibv_cmd_resize_cq(struct ibv_cq *cq, int cqe,
- struct ibv_resize_cq *cmd, size_t cmd_size)
+int rdmav_cmd_resize_cq(struct rdmav_cq *cq, int cqe,
+ struct rdmav_resize_cq *cmd, size_t cmd_size)
{
- struct ibv_resize_cq_resp resp;
+ struct rdmav_resize_cq_resp resp;
- IBV_INIT_CMD_RESP(cmd, cmd_size, RESIZE_CQ, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, RESIZE_CQ, &resp, sizeof resp);
cmd->cq_handle = cq->handle;
cmd->cqe = cqe;
@@ -384,11 +390,11 @@ int ibv_cmd_resize_cq(struct ibv_cq *cq,
return 0;
}
-static int ibv_cmd_destroy_cq_v1(struct ibv_cq *cq)
+static int rdmav_cmd_destroy_cq_v1(struct rdmav_cq *cq)
{
- struct ibv_destroy_cq_v1 cmd;
+ struct rdmav_destroy_cq_v1 cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DESTROY_CQ);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DESTROY_CQ);
cmd.cq_handle = cq->handle;
if (write(cq->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -397,15 +403,15 @@ static int ibv_cmd_destroy_cq_v1(struct
return 0;
}
-int ibv_cmd_destroy_cq(struct ibv_cq *cq)
+int rdmav_cmd_destroy_cq(struct rdmav_cq *cq)
{
- struct ibv_destroy_cq cmd;
- struct ibv_destroy_cq_resp resp;
+ struct rdmav_destroy_cq cmd;
+ struct rdmav_destroy_cq_resp resp;
if (abi_ver == 1)
- return ibv_cmd_destroy_cq_v1(cq);
+ return rdmav_cmd_destroy_cq_v1(cq);
- IBV_INIT_CMD_RESP(&cmd, sizeof cmd, DESTROY_CQ, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(&cmd, sizeof cmd, DESTROY_CQ, &resp, sizeof resp);
cmd.cq_handle = cq->handle;
if (write(cq->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -420,12 +426,12 @@ int ibv_cmd_destroy_cq(struct ibv_cq *cq
return 0;
}
-int ibv_cmd_create_srq(struct ibv_pd *pd,
- struct ibv_srq *srq, struct ibv_srq_init_attr *attr,
- struct ibv_create_srq *cmd, size_t cmd_size,
- struct ibv_create_srq_resp *resp, size_t resp_size)
+int rdmav_cmd_create_srq(struct rdmav_pd *pd,
+ struct rdmav_srq *srq, struct rdmav_srq_init_attr *attr,
+ struct rdmav_create_srq *cmd, size_t cmd_size,
+ struct rdmav_create_srq_resp *resp, size_t resp_size)
{
- IBV_INIT_CMD_RESP(cmd, cmd_size, CREATE_SRQ, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, CREATE_SRQ, resp, resp_size);
cmd->user_handle = (uintptr_t) srq;
cmd->pd_handle = pd->handle;
cmd->max_wr = attr->attr.max_wr;
@@ -441,8 +447,8 @@ int ibv_cmd_create_srq(struct ibv_pd *pd
attr->attr.max_wr = resp->max_wr;
attr->attr.max_sge = resp->max_sge;
} else {
- struct ibv_create_srq_resp_v5 *resp_v5 =
- (struct ibv_create_srq_resp_v5 *) resp;
+ struct rdmav_create_srq_resp_v5 *resp_v5 =
+ (struct rdmav_create_srq_resp_v5 *) resp;
memmove((void *) resp + sizeof *resp,
(void *) resp_v5 + sizeof *resp_v5,
@@ -452,20 +458,21 @@ int ibv_cmd_create_srq(struct ibv_pd *pd
return 0;
}
-static int ibv_cmd_modify_srq_v3(struct ibv_srq *srq,
- struct ibv_srq_attr *srq_attr,
- enum ibv_srq_attr_mask srq_attr_mask,
- struct ibv_modify_srq *new_cmd,
+static int rdmav_cmd_modify_srq_v3(struct rdmav_srq *srq,
+ struct rdmav_srq_attr *srq_attr,
+ enum rdmav_srq_attr_mask srq_attr_mask,
+ struct rdmav_modify_srq *new_cmd,
size_t new_cmd_size)
{
- struct ibv_modify_srq_v3 *cmd;
+ struct rdmav_modify_srq_v3 *cmd;
size_t cmd_size;
cmd_size = sizeof *cmd + new_cmd_size - sizeof *new_cmd;
cmd = alloca(cmd_size);
- memcpy(cmd->driver_data, new_cmd->driver_data, new_cmd_size - sizeof *new_cmd);
+ memcpy(cmd->driver_data, new_cmd->driver_data,
+ new_cmd_size - sizeof *new_cmd);
- IBV_INIT_CMD(cmd, cmd_size, MODIFY_SRQ);
+ RDMAV_INIT_CMD(cmd, cmd_size, MODIFY_SRQ);
cmd->srq_handle = srq->handle;
cmd->attr_mask = srq_attr_mask;
@@ -480,16 +487,16 @@ static int ibv_cmd_modify_srq_v3(struct
return 0;
}
-int ibv_cmd_modify_srq(struct ibv_srq *srq,
- struct ibv_srq_attr *srq_attr,
- enum ibv_srq_attr_mask srq_attr_mask,
- struct ibv_modify_srq *cmd, size_t cmd_size)
+int rdmav_cmd_modify_srq(struct rdmav_srq *srq,
+ struct rdmav_srq_attr *srq_attr,
+ enum rdmav_srq_attr_mask srq_attr_mask,
+ struct rdmav_modify_srq *cmd, size_t cmd_size)
{
if (abi_ver == 3)
- return ibv_cmd_modify_srq_v3(srq, srq_attr, srq_attr_mask,
+ return rdmav_cmd_modify_srq_v3(srq, srq_attr, srq_attr_mask,
cmd, cmd_size);
- IBV_INIT_CMD(cmd, cmd_size, MODIFY_SRQ);
+ RDMAV_INIT_CMD(cmd, cmd_size, MODIFY_SRQ);
cmd->srq_handle = srq->handle;
cmd->attr_mask = srq_attr_mask;
@@ -502,12 +509,12 @@ int ibv_cmd_modify_srq(struct ibv_srq *s
return 0;
}
-int ibv_cmd_query_srq(struct ibv_srq *srq, struct ibv_srq_attr *srq_attr,
- struct ibv_query_srq *cmd, size_t cmd_size)
+int rdmav_cmd_query_srq(struct rdmav_srq *srq, struct rdmav_srq_attr *srq_attr,
+ struct rdmav_query_srq *cmd, size_t cmd_size)
{
- struct ibv_query_srq_resp resp;
+ struct rdmav_query_srq_resp resp;
- IBV_INIT_CMD_RESP(cmd, cmd_size, QUERY_SRQ, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, QUERY_SRQ, &resp, sizeof resp);
cmd->srq_handle = srq->handle;
if (write(srq->context->cmd_fd, cmd, cmd_size) != cmd_size)
@@ -520,11 +527,11 @@ int ibv_cmd_query_srq(struct ibv_srq *sr
return 0;
}
-static int ibv_cmd_destroy_srq_v1(struct ibv_srq *srq)
+static int rdmav_cmd_destroy_srq_v1(struct rdmav_srq *srq)
{
- struct ibv_destroy_srq_v1 cmd;
+ struct rdmav_destroy_srq_v1 cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DESTROY_SRQ);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DESTROY_SRQ);
cmd.srq_handle = srq->handle;
if (write(srq->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -533,15 +540,15 @@ static int ibv_cmd_destroy_srq_v1(struct
return 0;
}
-int ibv_cmd_destroy_srq(struct ibv_srq *srq)
+int rdmav_cmd_destroy_srq(struct rdmav_srq *srq)
{
- struct ibv_destroy_srq cmd;
- struct ibv_destroy_srq_resp resp;
+ struct rdmav_destroy_srq cmd;
+ struct rdmav_destroy_srq_resp resp;
if (abi_ver == 1)
- return ibv_cmd_destroy_srq_v1(srq);
+ return rdmav_cmd_destroy_srq_v1(srq);
- IBV_INIT_CMD_RESP(&cmd, sizeof cmd, DESTROY_SRQ, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(&cmd, sizeof cmd, DESTROY_SRQ, &resp, sizeof resp);
cmd.srq_handle = srq->handle;
if (write(srq->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -555,12 +562,12 @@ int ibv_cmd_destroy_srq(struct ibv_srq *
return 0;
}
-int ibv_cmd_create_qp(struct ibv_pd *pd,
- struct ibv_qp *qp, struct ibv_qp_init_attr *attr,
- struct ibv_create_qp *cmd, size_t cmd_size,
- struct ibv_create_qp_resp *resp, size_t resp_size)
+int rdmav_cmd_create_qp(struct rdmav_pd *pd,
+ struct rdmav_qp *qp, struct rdmav_qp_init_attr *attr,
+ struct rdmav_create_qp *cmd, size_t cmd_size,
+ struct rdmav_create_qp_resp *resp, size_t resp_size)
{
- IBV_INIT_CMD_RESP(cmd, cmd_size, CREATE_QP, resp, resp_size);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, CREATE_QP, resp, resp_size);
cmd->user_handle = (uintptr_t) qp;
cmd->pd_handle = pd->handle;
@@ -591,15 +598,15 @@ int ibv_cmd_create_qp(struct ibv_pd *pd,
}
if (abi_ver == 4) {
- struct ibv_create_qp_resp_v4 *resp_v4 =
- (struct ibv_create_qp_resp_v4 *) resp;
+ struct rdmav_create_qp_resp_v4 *resp_v4 =
+ (struct rdmav_create_qp_resp_v4 *) resp;
memmove((void *) resp + sizeof *resp,
(void *) resp_v4 + sizeof *resp_v4,
resp_size - sizeof *resp);
} else if (abi_ver <= 3) {
- struct ibv_create_qp_resp_v3 *resp_v3 =
- (struct ibv_create_qp_resp_v3 *) resp;
+ struct rdmav_create_qp_resp_v3 *resp_v3 =
+ (struct rdmav_create_qp_resp_v3 *) resp;
memmove((void *) resp + sizeof *resp,
(void *) resp_v3 + sizeof *resp_v3,
@@ -609,14 +616,14 @@ int ibv_cmd_create_qp(struct ibv_pd *pd,
return 0;
}
-int ibv_cmd_query_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr,
- enum ibv_qp_attr_mask attr_mask,
- struct ibv_qp_init_attr *init_attr,
- struct ibv_query_qp *cmd, size_t cmd_size)
+int rdmav_cmd_query_qp(struct rdmav_qp *qp, struct rdmav_qp_attr *attr,
+ enum rdmav_qp_attr_mask attr_mask,
+ struct rdmav_qp_init_attr *init_attr,
+ struct rdmav_query_qp *cmd, size_t cmd_size)
{
- struct ibv_query_qp_resp resp;
+ struct rdmav_query_qp_resp resp;
- IBV_INIT_CMD_RESP(cmd, cmd_size, QUERY_QP, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, QUERY_QP, &resp, sizeof resp);
cmd->qp_handle = qp->handle;
cmd->attr_mask = attr_mask;
@@ -689,11 +696,11 @@ int ibv_cmd_query_qp(struct ibv_qp *qp,
return 0;
}
-int ibv_cmd_modify_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr,
- enum ibv_qp_attr_mask attr_mask,
- struct ibv_modify_qp *cmd, size_t cmd_size)
+int rdmav_cmd_modify_qp(struct rdmav_qp *qp, struct rdmav_qp_attr *attr,
+ enum rdmav_qp_attr_mask attr_mask,
+ struct rdmav_modify_qp *cmd, size_t cmd_size)
{
- IBV_INIT_CMD(cmd, cmd_size, MODIFY_QP);
+ RDMAV_INIT_CMD(cmd, cmd_size, MODIFY_QP);
cmd->qp_handle = qp->handle;
cmd->attr_mask = attr_mask;
@@ -749,11 +756,11 @@ int ibv_cmd_modify_qp(struct ibv_qp *qp,
return 0;
}
-static int ibv_cmd_destroy_qp_v1(struct ibv_qp *qp)
+static int rdmav_cmd_destroy_qp_v1(struct rdmav_qp *qp)
{
- struct ibv_destroy_qp_v1 cmd;
+ struct rdmav_destroy_qp_v1 cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DESTROY_QP);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DESTROY_QP);
cmd.qp_handle = qp->handle;
if (write(qp->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -762,14 +769,14 @@ static int ibv_cmd_destroy_qp_v1(struct
return 0;
}
-int ibv_cmd_post_send(struct ibv_qp *ibqp, struct ibv_send_wr *wr,
- struct ibv_send_wr **bad_wr)
+int rdmav_cmd_post_send(struct rdmav_qp *ibqp, struct rdmav_send_wr *wr,
+ struct rdmav_send_wr **bad_wr)
{
- struct ibv_post_send *cmd;
- struct ibv_post_send_resp resp;
- struct ibv_send_wr *i;
- struct ibv_kern_send_wr *n, *tmp;
- struct ibv_sge *s;
+ struct rdmav_post_send *cmd;
+ struct rdmav_post_send_resp resp;
+ struct rdmav_send_wr *i;
+ struct rdmav_kern_send_wr *n, *tmp;
+ struct rdmav_sge *s;
unsigned wr_count = 0;
unsigned sge_count = 0;
int cmd_size;
@@ -783,14 +790,14 @@ int ibv_cmd_post_send(struct ibv_qp *ibq
cmd_size = sizeof *cmd + wr_count * sizeof *n + sge_count * sizeof *s;
cmd = alloca(cmd_size);
- IBV_INIT_CMD_RESP(cmd, cmd_size, POST_SEND, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, POST_SEND, &resp, sizeof resp);
cmd->qp_handle = ibqp->handle;
cmd->wr_count = wr_count;
cmd->sge_count = sge_count;
cmd->wqe_size = sizeof *n;
- n = (struct ibv_kern_send_wr *) ((void *) cmd + sizeof *cmd);
- s = (struct ibv_sge *) (n + wr_count);
+ n = (struct rdmav_kern_send_wr *) ((void *) cmd + sizeof *cmd);
+ s = (struct rdmav_sge *) (n + wr_count);
tmp = n;
for (i = wr; i; i = i->next) {
@@ -799,21 +806,21 @@ int ibv_cmd_post_send(struct ibv_qp *ibq
tmp->opcode = i->opcode;
tmp->send_flags = i->send_flags;
tmp->imm_data = i->imm_data;
- if (ibqp->qp_type == IBV_QPT_UD) {
+ if (ibqp->qp_type == RDMAV_QPT_UD) {
tmp->wr.ud.ah = i->wr.ud.ah->handle;
tmp->wr.ud.remote_qpn = i->wr.ud.remote_qpn;
tmp->wr.ud.remote_qkey = i->wr.ud.remote_qkey;
} else {
switch(i->opcode) {
- case IBV_WR_RDMA_WRITE:
- case IBV_WR_RDMA_WRITE_WITH_IMM:
- case IBV_WR_RDMA_READ:
+ case RDMAV_WR_RDMA_WRITE:
+ case RDMAV_WR_RDMA_WRITE_WITH_IMM:
+ case RDMAV_WR_RDMA_READ:
tmp->wr.rdma.remote_addr =
i->wr.rdma.remote_addr;
tmp->wr.rdma.rkey = i->wr.rdma.rkey;
break;
- case IBV_WR_ATOMIC_CMP_AND_SWP:
- case IBV_WR_ATOMIC_FETCH_AND_ADD:
+ case RDMAV_WR_ATOMIC_CMP_AND_SWP:
+ case RDMAV_WR_ATOMIC_FETCH_AND_ADD:
tmp->wr.atomic.remote_addr =
i->wr.atomic.remote_addr;
tmp->wr.atomic.compare_add =
@@ -849,14 +856,14 @@ int ibv_cmd_post_send(struct ibv_qp *ibq
return ret;
}
-int ibv_cmd_post_recv(struct ibv_qp *ibqp, struct ibv_recv_wr *wr,
- struct ibv_recv_wr **bad_wr)
+int rdmav_cmd_post_recv(struct rdmav_qp *ibqp, struct rdmav_recv_wr *wr,
+ struct rdmav_recv_wr **bad_wr)
{
- struct ibv_post_recv *cmd;
- struct ibv_post_recv_resp resp;
- struct ibv_recv_wr *i;
- struct ibv_kern_recv_wr *n, *tmp;
- struct ibv_sge *s;
+ struct rdmav_post_recv *cmd;
+ struct rdmav_post_recv_resp resp;
+ struct rdmav_recv_wr *i;
+ struct rdmav_kern_recv_wr *n, *tmp;
+ struct rdmav_sge *s;
unsigned wr_count = 0;
unsigned sge_count = 0;
int cmd_size;
@@ -870,14 +877,14 @@ int ibv_cmd_post_recv(struct ibv_qp *ibq
cmd_size = sizeof *cmd + wr_count * sizeof *n + sge_count * sizeof *s;
cmd = alloca(cmd_size);
- IBV_INIT_CMD_RESP(cmd, cmd_size, POST_RECV, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, POST_RECV, &resp, sizeof resp);
cmd->qp_handle = ibqp->handle;
cmd->wr_count = wr_count;
cmd->sge_count = sge_count;
cmd->wqe_size = sizeof *n;
- n = (struct ibv_kern_recv_wr *) ((void *) cmd + sizeof *cmd);
- s = (struct ibv_sge *) (n + wr_count);
+ n = (struct rdmav_kern_recv_wr *) ((void *) cmd + sizeof *cmd);
+ s = (struct rdmav_sge *) (n + wr_count);
tmp = n;
for (i = wr; i; i = i->next) {
@@ -907,14 +914,14 @@ int ibv_cmd_post_recv(struct ibv_qp *ibq
return ret;
}
-int ibv_cmd_post_srq_recv(struct ibv_srq *srq, struct ibv_recv_wr *wr,
- struct ibv_recv_wr **bad_wr)
+int rdmav_cmd_post_srq_recv(struct rdmav_srq *srq, struct rdmav_recv_wr *wr,
+ struct rdmav_recv_wr **bad_wr)
{
- struct ibv_post_srq_recv *cmd;
- struct ibv_post_srq_recv_resp resp;
- struct ibv_recv_wr *i;
- struct ibv_kern_recv_wr *n, *tmp;
- struct ibv_sge *s;
+ struct rdmav_post_srq_recv *cmd;
+ struct rdmav_post_srq_recv_resp resp;
+ struct rdmav_recv_wr *i;
+ struct rdmav_kern_recv_wr *n, *tmp;
+ struct rdmav_sge *s;
unsigned wr_count = 0;
unsigned sge_count = 0;
int cmd_size;
@@ -928,14 +935,14 @@ int ibv_cmd_post_srq_recv(struct ibv_srq
cmd_size = sizeof *cmd + wr_count * sizeof *n + sge_count * sizeof *s;
cmd = alloca(cmd_size);
- IBV_INIT_CMD_RESP(cmd, cmd_size, POST_SRQ_RECV, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(cmd, cmd_size, POST_SRQ_RECV, &resp, sizeof resp);
cmd->srq_handle = srq->handle;
cmd->wr_count = wr_count;
cmd->sge_count = sge_count;
cmd->wqe_size = sizeof *n;
- n = (struct ibv_kern_recv_wr *) ((void *) cmd + sizeof *cmd);
- s = (struct ibv_sge *) (n + wr_count);
+ n = (struct rdmav_kern_recv_wr *) ((void *) cmd + sizeof *cmd);
+ s = (struct rdmav_sge *) (n + wr_count);
tmp = n;
for (i = wr; i; i = i->next) {
@@ -965,13 +972,13 @@ int ibv_cmd_post_srq_recv(struct ibv_srq
return ret;
}
-int ibv_cmd_create_ah(struct ibv_pd *pd, struct ibv_ah *ah,
- struct ibv_ah_attr *attr)
+int rdmav_cmd_create_ah(struct rdmav_pd *pd, struct rdmav_ah *ah,
+ struct rdmav_ah_attr *attr)
{
- struct ibv_create_ah cmd;
- struct ibv_create_ah_resp resp;
+ struct rdmav_create_ah cmd;
+ struct rdmav_create_ah_resp resp;
- IBV_INIT_CMD_RESP(&cmd, sizeof cmd, CREATE_AH, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(&cmd, sizeof cmd, CREATE_AH, &resp, sizeof resp);
cmd.user_handle = (uintptr_t) ah;
cmd.pd_handle = pd->handle;
cmd.attr.dlid = attr->dlid;
@@ -994,11 +1001,11 @@ int ibv_cmd_create_ah(struct ibv_pd *pd,
return 0;
}
-int ibv_cmd_destroy_ah(struct ibv_ah *ah)
+int rdmav_cmd_destroy_ah(struct rdmav_ah *ah)
{
- struct ibv_destroy_ah cmd;
+ struct rdmav_destroy_ah cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DESTROY_AH);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DESTROY_AH);
cmd.ah_handle = ah->handle;
if (write(ah->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -1007,15 +1014,15 @@ int ibv_cmd_destroy_ah(struct ibv_ah *ah
return 0;
}
-int ibv_cmd_destroy_qp(struct ibv_qp *qp)
+int rdmav_cmd_destroy_qp(struct rdmav_qp *qp)
{
- struct ibv_destroy_qp cmd;
- struct ibv_destroy_qp_resp resp;
+ struct rdmav_destroy_qp cmd;
+ struct rdmav_destroy_qp_resp resp;
if (abi_ver == 1)
- return ibv_cmd_destroy_qp_v1(qp);
+ return rdmav_cmd_destroy_qp_v1(qp);
- IBV_INIT_CMD_RESP(&cmd, sizeof cmd, DESTROY_QP, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(&cmd, sizeof cmd, DESTROY_QP, &resp, sizeof resp);
cmd.qp_handle = qp->handle;
if (write(qp->context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd)
@@ -1029,11 +1036,11 @@ int ibv_cmd_destroy_qp(struct ibv_qp *qp
return 0;
}
-int ibv_cmd_attach_mcast(struct ibv_qp *qp, union ibv_gid *gid, uint16_t lid)
+int rdmav_cmd_attach_mcast(struct rdmav_qp *qp, union rdmav_gid *gid, uint16_t lid)
{
- struct ibv_attach_mcast cmd;
+ struct rdmav_attach_mcast cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, ATTACH_MCAST);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, ATTACH_MCAST);
memcpy(cmd.gid, gid->raw, sizeof cmd.gid);
cmd.qp_handle = qp->handle;
cmd.mlid = lid;
@@ -1044,11 +1051,11 @@ int ibv_cmd_attach_mcast(struct ibv_qp *
return 0;
}
-int ibv_cmd_detach_mcast(struct ibv_qp *qp, union ibv_gid *gid, uint16_t lid)
+int rdmav_cmd_detach_mcast(struct rdmav_qp *qp, union rdmav_gid *gid, uint16_t lid)
{
- struct ibv_detach_mcast cmd;
+ struct rdmav_detach_mcast cmd;
- IBV_INIT_CMD(&cmd, sizeof cmd, DETACH_MCAST);
+ RDMAV_INIT_CMD(&cmd, sizeof cmd, DETACH_MCAST);
memcpy(cmd.gid, gid->raw, sizeof cmd.gid);
cmd.qp_handle = qp->handle;
cmd.mlid = lid;
diff -ruNp ORG/libibverbs/src/device.c NEW/libibverbs/src/device.c
--- ORG/libibverbs/src/device.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/device.c 2006-08-02 23:57:31.000000000 -0700
@@ -48,23 +48,23 @@
#include <infiniband/arch.h>
-#include "ibverbs.h"
+#include "rdmaverbs.h"
static pthread_mutex_t device_list_lock = PTHREAD_MUTEX_INITIALIZER;
static int num_devices;
-static struct ibv_device **device_list;
+static struct rdmav_device **device_list;
-struct ibv_device **ibv_get_device_list(int *num)
+struct rdmav_device **rdmav_get_device_list(int *num)
{
- struct ibv_device **l;
+ struct rdmav_device **l;
int i;
pthread_mutex_lock(&device_list_lock);
if (!num_devices)
- num_devices = ibverbs_init(&device_list);
+ num_devices = rdmaverbs_init(&device_list);
- l = calloc(num_devices + 1, sizeof (struct ibv_device *));
+ l = calloc(num_devices + 1, sizeof (struct rdmav_device *));
for (i = 0; i < num_devices; ++i)
l[i] = device_list[i];
@@ -76,24 +76,30 @@ struct ibv_device **ibv_get_device_list(
return l;
}
-void ibv_free_device_list(struct ibv_device **list)
+/* XXX - to be removed when all apps are converted to new API */
+struct rdmav_device **ibv_get_device_list(int *num)
+{
+ return rdmav_get_device_list(num);
+}
+
+void rdmav_free_device_list(struct rdmav_device **list)
{
free(list);
}
-const char *ibv_get_device_name(struct ibv_device *device)
+const char *rdmav_get_device_name(struct rdmav_device *device)
{
return device->name;
}
-uint64_t ibv_get_device_guid(struct ibv_device *device)
+uint64_t rdmav_get_device_guid(struct rdmav_device *device)
{
char attr[24];
uint64_t guid = 0;
uint16_t parts[4];
int i;
- if (ibv_read_sysfs_file(device->ibdev_path, "node_guid",
+ if (rdmav_read_sysfs_file(device->ibdev_path, "node_guid",
attr, sizeof attr) < 0)
return 0;
@@ -107,11 +113,11 @@ uint64_t ibv_get_device_guid(struct ibv_
return htonll(guid);
}
-struct ibv_context *ibv_open_device(struct ibv_device *device)
+struct rdmav_context *rdmav_open_device(struct rdmav_device *device)
{
char *devpath;
int cmd_fd;
- struct ibv_context *context;
+ struct rdmav_context *context;
asprintf(&devpath, "/dev/infiniband/%s", device->dev_name);
@@ -140,14 +146,14 @@ err:
return NULL;
}
-int ibv_close_device(struct ibv_context *context)
+int rdmav_close_device(struct rdmav_context *context)
{
int async_fd = context->async_fd;
int cmd_fd = context->cmd_fd;
int cq_fd = -1;
if (abi_ver <= 2) {
- struct ibv_abi_compat_v2 *t = context->abi_compat;
+ struct rdmav_abi_compat_v2 *t = context->abi_compat;
cq_fd = t->channel.fd;
free(context->abi_compat);
}
@@ -162,10 +168,10 @@ int ibv_close_device(struct ibv_context
return 0;
}
-int ibv_get_async_event(struct ibv_context *context,
- struct ibv_async_event *event)
+int rdmav_get_async_event(struct rdmav_context *context,
+ struct rdmav_async_event *event)
{
- struct ibv_kern_async_event ev;
+ struct rdmav_kern_async_event ev;
if (read(context->async_fd, &ev, sizeof ev) != sizeof ev)
return -1;
@@ -173,23 +179,23 @@ int ibv_get_async_event(struct ibv_conte
event->event_type = ev.event_type;
switch (event->event_type) {
- case IBV_EVENT_CQ_ERR:
+ case RDMAV_EVENT_CQ_ERR:
event->element.cq = (void *) (uintptr_t) ev.element;
break;
- case IBV_EVENT_QP_FATAL:
- case IBV_EVENT_QP_REQ_ERR:
- case IBV_EVENT_QP_ACCESS_ERR:
- case IBV_EVENT_COMM_EST:
- case IBV_EVENT_SQ_DRAINED:
- case IBV_EVENT_PATH_MIG:
- case IBV_EVENT_PATH_MIG_ERR:
- case IBV_EVENT_QP_LAST_WQE_REACHED:
+ case RDMAV_EVENT_QP_FATAL:
+ case RDMAV_EVENT_QP_REQ_ERR:
+ case RDMAV_EVENT_QP_ACCESS_ERR:
+ case RDMAV_EVENT_COMM_EST:
+ case RDMAV_EVENT_SQ_DRAINED:
+ case RDMAV_EVENT_PATH_MIG:
+ case RDMAV_EVENT_PATH_MIG_ERR:
+ case RDMAV_EVENT_QP_LAST_WQE_REACHED:
event->element.qp = (void *) (uintptr_t) ev.element;
break;
- case IBV_EVENT_SRQ_ERR:
- case IBV_EVENT_SRQ_LIMIT_REACHED:
+ case RDMAV_EVENT_SRQ_ERR:
+ case RDMAV_EVENT_SRQ_LIMIT_REACHED:
event->element.srq = (void *) (uintptr_t) ev.element;
break;
@@ -201,12 +207,12 @@ int ibv_get_async_event(struct ibv_conte
return 0;
}
-void ibv_ack_async_event(struct ibv_async_event *event)
+void rdmav_ack_async_event(struct rdmav_async_event *event)
{
switch (event->event_type) {
- case IBV_EVENT_CQ_ERR:
+ case RDMAV_EVENT_CQ_ERR:
{
- struct ibv_cq *cq = event->element.cq;
+ struct rdmav_cq *cq = event->element.cq;
pthread_mutex_lock(&cq->mutex);
++cq->async_events_completed;
@@ -216,16 +222,16 @@ void ibv_ack_async_event(struct ibv_asyn
return;
}
- case IBV_EVENT_QP_FATAL:
- case IBV_EVENT_QP_REQ_ERR:
- case IBV_EVENT_QP_ACCESS_ERR:
- case IBV_EVENT_COMM_EST:
- case IBV_EVENT_SQ_DRAINED:
- case IBV_EVENT_PATH_MIG:
- case IBV_EVENT_PATH_MIG_ERR:
- case IBV_EVENT_QP_LAST_WQE_REACHED:
+ case RDMAV_EVENT_QP_FATAL:
+ case RDMAV_EVENT_QP_REQ_ERR:
+ case RDMAV_EVENT_QP_ACCESS_ERR:
+ case RDMAV_EVENT_COMM_EST:
+ case RDMAV_EVENT_SQ_DRAINED:
+ case RDMAV_EVENT_PATH_MIG:
+ case RDMAV_EVENT_PATH_MIG_ERR:
+ case RDMAV_EVENT_QP_LAST_WQE_REACHED:
{
- struct ibv_qp *qp = event->element.qp;
+ struct rdmav_qp *qp = event->element.qp;
pthread_mutex_lock(&qp->mutex);
++qp->events_completed;
@@ -235,10 +241,10 @@ void ibv_ack_async_event(struct ibv_asyn
return;
}
- case IBV_EVENT_SRQ_ERR:
- case IBV_EVENT_SRQ_LIMIT_REACHED:
+ case RDMAV_EVENT_SRQ_ERR:
+ case RDMAV_EVENT_SRQ_LIMIT_REACHED:
{
- struct ibv_srq *srq = event->element.srq;
+ struct rdmav_srq *srq = event->element.srq;
pthread_mutex_lock(&srq->mutex);
++srq->events_completed;
diff -ruNp ORG/libibverbs/src/ibverbs.h NEW/libibverbs/src/ibverbs.h
--- ORG/libibverbs/src/ibverbs.h 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/ibverbs.h 1969-12-31 16:00:00.000000000 -0800
@@ -1,88 +0,0 @@
-/*
- * Copyright (c) 2004, 2005 Topspin Communications. All rights reserved.
- *
- * This software is available to you under a choice of one of two
- * licenses. You may choose to be licensed under the terms of the GNU
- * General Public License (GPL) Version 2, available from the file
- * COPYING in the main directory of this source tree, or the
- * OpenIB.org BSD license below:
- *
- * Redistribution and use in source and binary forms, with or
- * without modification, are permitted provided that the following
- * conditions are met:
- *
- * - Redistributions of source code must retain the above
- * copyright notice, this list of conditions and the following
- * disclaimer.
- *
- * - Redistributions in binary form must reproduce the above
- * copyright notice, this list of conditions and the following
- * disclaimer in the documentation and/or other materials
- * provided with the distribution.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
- * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
- * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
- * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- * $Id: ibverbs.h 4466 2005-12-14 20:44:36Z roland $
- */
-
-#ifndef IB_VERBS_H
-#define IB_VERBS_H
-
-#include <pthread.h>
-
-#include <infiniband/driver.h>
-
-#define HIDDEN __attribute__((visibility ("hidden")))
-
-#define INIT __attribute__((constructor))
-#define FINI __attribute__((destructor))
-
-#define PFX "libibverbs: "
-
-struct ibv_driver {
- ibv_driver_init_func init_func;
- struct ibv_driver *next;
-};
-
-struct ibv_abi_compat_v2 {
- struct ibv_comp_channel channel;
- pthread_mutex_t in_use;
-};
-
-extern HIDDEN int abi_ver;
-
-extern HIDDEN int ibverbs_init(struct ibv_device ***list);
-
-extern HIDDEN int ibv_init_mem_map(void);
-extern HIDDEN int ibv_lock_range(void *base, size_t size);
-extern HIDDEN int ibv_unlock_range(void *base, size_t size);
-
-#define IBV_INIT_CMD(cmd, size, opcode) \
- do { \
- if (abi_ver > 2) \
- (cmd)->command = IB_USER_VERBS_CMD_##opcode; \
- else \
- (cmd)->command = IB_USER_VERBS_CMD_##opcode##_V2; \
- (cmd)->in_words = (size) / 4; \
- (cmd)->out_words = 0; \
- } while (0)
-
-#define IBV_INIT_CMD_RESP(cmd, size, opcode, out, outsize) \
- do { \
- if (abi_ver > 2) \
- (cmd)->command = IB_USER_VERBS_CMD_##opcode; \
- else \
- (cmd)->command = IB_USER_VERBS_CMD_##opcode##_V2; \
- (cmd)->in_words = (size) / 4; \
- (cmd)->out_words = (outsize) / 4; \
- (cmd)->response = (uintptr_t) (out); \
- } while (0)
-
-#endif /* IB_VERBS_H */
diff -ruNp ORG/libibverbs/src/init.c NEW/libibverbs/src/init.c
--- ORG/libibverbs/src/init.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/init.c 2006-08-02 18:24:49.000000000 -0700
@@ -46,24 +46,28 @@
#include <sys/types.h>
#include <dirent.h>
-#include "ibverbs.h"
+#include "rdmaverbs.h"
#ifndef OPENIB_DRIVER_PATH_ENV
# define OPENIB_DRIVER_PATH_ENV "OPENIB_DRIVER_PATH"
#endif
+#ifndef LIBRDMAVERBS_DRIVER_PATH_ENV
+# define LIBRDMAVERBS_DRIVER_PATH_ENV "LIBRDMAVERBS_DRIVER_PATH"
+#endif
+
HIDDEN int abi_ver;
static char default_path[] = DRIVER_PATH;
static const char *user_path;
-static struct ibv_driver *driver_list;
+static struct rdmav_driver *driver_list;
static void load_driver(char *so_path)
{
void *dlhandle;
- ibv_driver_init_func init_func;
- struct ibv_driver *driver;
+ rdmav_driver_init_func init_func;
+ struct rdmav_driver *driver;
dlhandle = dlopen(so_path, RTLD_NOW);
if (!dlhandle) {
@@ -81,7 +85,8 @@ static void load_driver(char *so_path)
driver = malloc(sizeof *driver);
if (!driver) {
- fprintf(stderr, PFX "Fatal: couldn't allocate driver for %s\n", so_path);
+ fprintf(stderr, PFX "Fatal: couldn't allocate driver for %s\n",
+ so_path);
dlclose(dlhandle);
return;
}
@@ -122,23 +127,25 @@ static void find_drivers(char *dir)
globfree(&so_glob);
}
-static struct ibv_device *init_drivers(const char *class_path,
+static struct rdmav_device *init_drivers(const char *class_path,
const char *dev_name)
{
- struct ibv_driver *driver;
- struct ibv_device *dev;
+ struct rdmav_driver *driver;
+ struct rdmav_device *dev;
int abi_ver = 0;
- char sys_path[IBV_SYSFS_PATH_MAX];
- char ibdev_name[IBV_SYSFS_NAME_MAX];
+ char sys_path[RDMAV_SYSFS_PATH_MAX];
+ char ibdev_name[RDMAV_SYSFS_NAME_MAX];
char value[8];
snprintf(sys_path, sizeof sys_path, "%s/%s",
class_path, dev_name);
- if (ibv_read_sysfs_file(sys_path, "abi_version", value, sizeof value) > 0)
+ if (rdmav_read_sysfs_file(sys_path, "abi_version", value,
+ sizeof value) > 0)
abi_ver = strtol(value, NULL, 10);
- if (ibv_read_sysfs_file(sys_path, "ibdev", ibdev_name, sizeof ibdev_name) < 0) {
+ if (rdmav_read_sysfs_file(sys_path, "ibdev", ibdev_name,
+ sizeof ibdev_name) < 0) {
fprintf(stderr, PFX "Warning: no ibdev class attr for %s\n",
sys_path);
return NULL;
@@ -151,8 +158,9 @@ static struct ibv_device *init_drivers(c
dev->driver = driver;
strcpy(dev->dev_path, sys_path);
- snprintf(dev->ibdev_path, IBV_SYSFS_PATH_MAX, "%s/class/infiniband/%s",
- ibv_get_sysfs_path(), ibdev_name);
+ snprintf(dev->ibdev_path, RDMAV_SYSFS_PATH_MAX,
+ "%s/class/infiniband/%s",
+ rdmav_get_sysfs_path(), ibdev_name);
strcpy(dev->dev_name, dev_name);
strcpy(dev->name, ibdev_name);
@@ -172,7 +180,7 @@ static int check_abi_version(const char
{
char value[8];
- if (ibv_read_sysfs_file(path, "class/infiniband_verbs/abi_version",
+ if (rdmav_read_sysfs_file(path, "class/infiniband_verbs/abi_version",
value, sizeof value) < 0) {
fprintf(stderr, PFX "Fatal: couldn't read uverbs ABI version.\n");
return -1;
@@ -180,32 +188,32 @@ static int check_abi_version(const char
abi_ver = strtol(value, NULL, 10);
- if (abi_ver < IB_USER_VERBS_MIN_ABI_VERSION ||
- abi_ver > IB_USER_VERBS_MAX_ABI_VERSION) {
+ if (abi_ver < RDMAV_USER_VERBS_MIN_ABI_VERSION ||
+ abi_ver > RDMAV_USER_VERBS_MAX_ABI_VERSION) {
fprintf(stderr, PFX "Fatal: kernel ABI version %d "
"doesn't match library version %d.\n",
- abi_ver, IB_USER_VERBS_MAX_ABI_VERSION);
+ abi_ver, RDMAV_USER_VERBS_MAX_ABI_VERSION);
return -1;
}
return 0;
}
-HIDDEN int ibverbs_init(struct ibv_device ***list)
+HIDDEN int rdmaverbs_init(struct rdmav_device ***list)
{
const char *sysfs_path;
char *wr_path, *dir;
- char class_path[IBV_SYSFS_PATH_MAX];
+ char class_path[RDMAV_SYSFS_PATH_MAX];
DIR *class_dir;
struct dirent *dent;
- struct ibv_device *device;
- struct ibv_device **new_list;
+ struct rdmav_device *device;
+ struct rdmav_device **new_list;
int num_devices = 0;
int list_size = 0;
*list = NULL;
- if (ibv_init_mem_map())
+ if (rdmav_init_mem_map())
return 0;
find_drivers(default_path);
@@ -215,12 +223,22 @@ HIDDEN int ibverbs_init(struct ibv_devic
* environment if we're not running SUID.
*/
if (getuid() == geteuid()) {
- user_path = getenv(OPENIB_DRIVER_PATH_ENV);
+ const char *user_path_extra;
+
+ user_path = getenv(LIBRDMAVERBS_DRIVER_PATH_ENV);
if (user_path) {
wr_path = strdupa(user_path);
while ((dir = strsep(&wr_path, ";:")))
find_drivers(dir);
}
+
+ /* for backwards compatibility */
+ user_path_extra = getenv(OPENIB_DRIVER_PATH_ENV);
+ if (user_path_extra) {
+ wr_path = strdupa(user_path_extra);
+ while ((dir = strsep(&wr_path, ";:")))
+ find_drivers(dir);
+ }
}
/*
@@ -230,7 +248,7 @@ HIDDEN int ibverbs_init(struct ibv_devic
*/
load_driver(NULL);
- sysfs_path = ibv_get_sysfs_path();
+ sysfs_path = rdmav_get_sysfs_path();
if (!sysfs_path) {
fprintf(stderr, PFX "Fatal: couldn't find sysfs mount.\n");
return 0;
@@ -258,7 +276,7 @@ HIDDEN int ibverbs_init(struct ibv_devic
if (list_size <= num_devices) {
list_size = list_size ? list_size * 2 : 1;
- new_list = realloc(*list, list_size * sizeof (struct ibv_device *));
+ new_list = realloc(*list, list_size * sizeof (struct rdmav_device *));
if (!new_list)
goto out;
*list = new_list;
diff -ruNp ORG/libibverbs/src/libibverbs.map NEW/libibverbs/src/libibverbs.map
--- ORG/libibverbs/src/libibverbs.map 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/libibverbs.map 1969-12-31 16:00:00.000000000 -0800
@@ -1,79 +0,0 @@
-IBVERBS_1.0 {
- global:
- ibv_get_device_list;
- ibv_free_device_list;
- ibv_get_device_name;
- ibv_get_device_guid;
- ibv_open_device;
- ibv_close_device;
- ibv_get_async_event;
- ibv_ack_async_event;
- ibv_query_device;
- ibv_query_port;
- ibv_query_gid;
- ibv_query_pkey;
- ibv_alloc_pd;
- ibv_dealloc_pd;
- ibv_reg_mr;
- ibv_dereg_mr;
- ibv_create_comp_channel;
- ibv_destroy_comp_channel;
- ibv_create_cq;
- ibv_resize_cq;
- ibv_destroy_cq;
- ibv_get_cq_event;
- ibv_ack_cq_events;
- ibv_create_srq;
- ibv_modify_srq;
- ibv_query_srq;
- ibv_destroy_srq;
- ibv_create_qp;
- ibv_query_qp;
- ibv_modify_qp;
- ibv_destroy_qp;
- ibv_create_ah;
- ibv_init_ah_from_wc;
- ibv_create_ah_from_wc;
- ibv_destroy_ah;
- ibv_attach_mcast;
- ibv_detach_mcast;
- ibv_cmd_get_context;
- ibv_cmd_query_device;
- ibv_cmd_query_port;
- ibv_cmd_query_gid;
- ibv_cmd_query_pkey;
- ibv_cmd_alloc_pd;
- ibv_cmd_dealloc_pd;
- ibv_cmd_reg_mr;
- ibv_cmd_dereg_mr;
- ibv_cmd_create_cq;
- ibv_cmd_poll_cq;
- ibv_cmd_req_notify_cq;
- ibv_cmd_resize_cq;
- ibv_cmd_destroy_cq;
- ibv_cmd_create_srq;
- ibv_cmd_modify_srq;
- ibv_cmd_query_srq;
- ibv_cmd_destroy_srq;
- ibv_cmd_create_qp;
- ibv_cmd_query_qp;
- ibv_cmd_modify_qp;
- ibv_cmd_destroy_qp;
- ibv_cmd_post_send;
- ibv_cmd_post_recv;
- ibv_cmd_post_srq_recv;
- ibv_cmd_create_ah;
- ibv_cmd_destroy_ah;
- ibv_cmd_attach_mcast;
- ibv_cmd_detach_mcast;
- ibv_copy_qp_attr_from_kern;
- ibv_copy_ah_attr_from_kern;
- ibv_copy_path_rec_from_kern;
- ibv_copy_path_rec_to_kern;
- ibv_rate_to_mult;
- mult_to_ibv_rate;
- ibv_get_sysfs_path;
- ibv_read_sysfs_file;
-
- local: *;
-};
diff -ruNp ORG/libibverbs/src/librdmaverbs.map NEW/libibverbs/src/librdmaverbs.map
--- ORG/libibverbs/src/librdmaverbs.map 1969-12-31 16:00:00.000000000 -0800
+++ NEW/libibverbs/src/librdmaverbs.map 2006-08-02 23:50:50.000000000 -0700
@@ -0,0 +1,80 @@
+RDMAVERBS_1.0 {
+ global:
+ ibv_get_device_list;
+ rdmav_get_device_list;
+ rdmav_free_device_list;
+ rdmav_get_device_name;
+ rdmav_get_device_guid;
+ rdmav_open_device;
+ rdmav_close_device;
+ rdmav_get_async_event;
+ rdmav_ack_async_event;
+ rdmav_query_device;
+ rdmav_query_port;
+ rdmav_query_gid;
+ rdmav_query_pkey;
+ rdmav_alloc_pd;
+ rdmav_dealloc_pd;
+ rdmav_reg_mr;
+ rdmav_dereg_mr;
+ rdmav_create_comp_channel;
+ rdmav_destroy_comp_channel;
+ rdmav_create_cq;
+ rdmav_resize_cq;
+ rdmav_destroy_cq;
+ rdmav_get_cq_event;
+ rdmav_ack_cq_events;
+ rdmav_create_srq;
+ rdmav_modify_srq;
+ rdmav_query_srq;
+ rdmav_destroy_srq;
+ rdmav_create_qp;
+ rdmav_query_qp;
+ rdmav_modify_qp;
+ rdmav_destroy_qp;
+ rdmav_create_ah;
+ rdmav_init_ah_from_wc;
+ rdmav_create_ah_from_wc;
+ rdmav_destroy_ah;
+ rdmav_attach_mcast;
+ rdmav_detach_mcast;
+ rdmav_cmd_get_context;
+ rdmav_cmd_query_device;
+ rdmav_cmd_query_port;
+ rdmav_cmd_query_gid;
+ rdmav_cmd_query_pkey;
+ rdmav_cmd_alloc_pd;
+ rdmav_cmd_dealloc_pd;
+ rdmav_cmd_reg_mr;
+ rdmav_cmd_dereg_mr;
+ rdmav_cmd_create_cq;
+ rdmav_cmd_poll_cq;
+ rdmav_cmd_req_notify_cq;
+ rdmav_cmd_resize_cq;
+ rdmav_cmd_destroy_cq;
+ rdmav_cmd_create_srq;
+ rdmav_cmd_modify_srq;
+ rdmav_cmd_query_srq;
+ rdmav_cmd_destroy_srq;
+ rdmav_cmd_create_qp;
+ rdmav_cmd_query_qp;
+ rdmav_cmd_modify_qp;
+ rdmav_cmd_destroy_qp;
+ rdmav_cmd_post_send;
+ rdmav_cmd_post_recv;
+ rdmav_cmd_post_srq_recv;
+ rdmav_cmd_create_ah;
+ rdmav_cmd_destroy_ah;
+ rdmav_cmd_attach_mcast;
+ rdmav_cmd_detach_mcast;
+ rdmav_copy_qp_attr_from_kern;
+ rdmav_copy_ah_attr_from_kern;
+ rdmav_copy_path_rec_from_kern;
+ rdmav_copy_path_rec_to_kern;
+ rdmav_rate_to_mult;
+ mult_to_rdmav_rate;
+ rdmav_get_sysfs_path;
+ rdmav_read_sysfs_file;
+
+ local: *;
+};
diff -ruNp ORG/libibverbs/src/marshall.c NEW/libibverbs/src/marshall.c
--- ORG/libibverbs/src/marshall.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/marshall.c 2006-08-02 18:24:49.000000000 -0700
@@ -38,8 +38,8 @@
#include <infiniband/marshall.h>
-void ibv_copy_ah_attr_from_kern(struct ibv_ah_attr *dst,
- struct ibv_kern_ah_attr *src)
+void rdmav_copy_ah_attr_from_kern(struct rdmav_ah_attr *dst,
+ struct rdmav_kern_ah_attr *src)
{
memcpy(dst->grh.dgid.raw, src->grh.dgid, sizeof dst->grh.dgid);
dst->grh.flow_label = src->grh.flow_label;
@@ -55,8 +55,8 @@ void ibv_copy_ah_attr_from_kern(struct i
dst->port_num = src->port_num;
}
-void ibv_copy_qp_attr_from_kern(struct ibv_qp_attr *dst,
- struct ibv_kern_qp_attr *src)
+void rdmav_copy_qp_attr_from_kern(struct rdmav_qp_attr *dst,
+ struct rdmav_kern_qp_attr *src)
{
dst->cur_qp_state = src->cur_qp_state;
dst->path_mtu = src->path_mtu;
@@ -73,8 +73,8 @@ void ibv_copy_qp_attr_from_kern(struct i
dst->cap.max_recv_sge = src->max_recv_sge;
dst->cap.max_inline_data = src->max_inline_data;
- ibv_copy_ah_attr_from_kern(&dst->ah_attr, &src->ah_attr);
- ibv_copy_ah_attr_from_kern(&dst->alt_ah_attr, &src->alt_ah_attr);
+ rdmav_copy_ah_attr_from_kern(&dst->ah_attr, &src->ah_attr);
+ rdmav_copy_ah_attr_from_kern(&dst->alt_ah_attr, &src->alt_ah_attr);
dst->pkey_index = src->pkey_index;
dst->alt_pkey_index = src->alt_pkey_index;
@@ -91,8 +91,8 @@ void ibv_copy_qp_attr_from_kern(struct i
dst->alt_timeout = src->alt_timeout;
}
-void ibv_copy_path_rec_from_kern(struct ibv_sa_path_rec *dst,
- struct ibv_kern_path_rec *src)
+void rdmav_copy_path_rec_from_kern(struct rdmav_sa_path_rec *dst,
+ struct rdmav_kern_path_rec *src)
{
memcpy(dst->dgid.raw, src->dgid, sizeof dst->dgid);
memcpy(dst->sgid.raw, src->sgid, sizeof dst->sgid);
@@ -116,8 +116,8 @@ void ibv_copy_path_rec_from_kern(struct
dst->packet_life_time_selector = src->packet_life_time_selector;
}
-void ibv_copy_path_rec_to_kern(struct ibv_kern_path_rec *dst,
- struct ibv_sa_path_rec *src)
+void rdmav_copy_path_rec_to_kern(struct rdmav_kern_path_rec *dst,
+ struct rdmav_sa_path_rec *src)
{
memcpy(dst->dgid, src->dgid.raw, sizeof src->dgid);
memcpy(dst->sgid, src->sgid.raw, sizeof src->sgid);
diff -ruNp ORG/libibverbs/src/memory.c NEW/libibverbs/src/memory.c
--- ORG/libibverbs/src/memory.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/memory.c 2006-08-02 18:24:49.000000000 -0700
@@ -41,7 +41,7 @@
#include <stdlib.h>
#include <stdint.h>
-#include "ibverbs.h"
+#include "rdmaverbs.h"
/*
* We keep a linked list of page ranges that have been locked along with a
@@ -51,21 +51,21 @@
* to avoid the O(n) cost of registering/unregistering memory.
*/
-struct ibv_mem_node {
- struct ibv_mem_node *prev, *next;
+struct rdmav_mem_node {
+ struct rdmav_mem_node *prev, *next;
uintptr_t start, end;
int refcnt;
};
static struct {
- struct ibv_mem_node *first;
+ struct rdmav_mem_node *first;
pthread_mutex_t mutex;
uintptr_t page_size;
} mem_map;
-int ibv_init_mem_map(void)
+int rdmav_init_mem_map(void)
{
- struct ibv_mem_node *node = NULL;
+ struct rdmav_mem_node *node = NULL;
node = malloc(sizeof *node);
if (!node)
@@ -94,9 +94,9 @@ fail:
return -1;
}
-static struct ibv_mem_node *__mm_find_first(uintptr_t start, uintptr_t end)
+static struct rdmav_mem_node *__mm_find_first(uintptr_t start, uintptr_t end)
{
- struct ibv_mem_node *node = mem_map.first;
+ struct rdmav_mem_node *node = mem_map.first;
while (node) {
if ((node->start <= start && node->end >= start) ||
@@ -108,18 +108,18 @@ static struct ibv_mem_node *__mm_find_fi
return node;
}
-static struct ibv_mem_node *__mm_prev(struct ibv_mem_node *node)
+static struct rdmav_mem_node *__mm_prev(struct rdmav_mem_node *node)
{
return node->prev;
}
-static struct ibv_mem_node *__mm_next(struct ibv_mem_node *node)
+static struct rdmav_mem_node *__mm_next(struct rdmav_mem_node *node)
{
return node->next;
}
-static void __mm_add(struct ibv_mem_node *node,
- struct ibv_mem_node *new)
+static void __mm_add(struct rdmav_mem_node *node,
+ struct rdmav_mem_node *new)
{
new->prev = node;
new->next = node->next;
@@ -128,7 +128,7 @@ static void __mm_add(struct ibv_mem_node
new->next->prev = new;
}
-static void __mm_remove(struct ibv_mem_node *node)
+static void __mm_remove(struct rdmav_mem_node *node)
{
/* Never have to remove the first node, so we can use prev */
node->prev->next = node->next;
@@ -136,10 +136,10 @@ static void __mm_remove(struct ibv_mem_n
node->next->prev = node->prev;
}
-int ibv_lock_range(void *base, size_t size)
+int rdmav_lock_range(void *base, size_t size)
{
uintptr_t start, end;
- struct ibv_mem_node *node, *tmp;
+ struct rdmav_mem_node *node, *tmp;
int ret = 0;
if (!size)
@@ -202,10 +202,10 @@ out:
return ret;
}
-int ibv_unlock_range(void *base, size_t size)
+int rdmav_unlock_range(void *base, size_t size)
{
uintptr_t start, end;
- struct ibv_mem_node *node, *tmp;
+ struct rdmav_mem_node *node, *tmp;
int ret = 0;
if (!size)
diff -ruNp ORG/libibverbs/src/rdmaverbs.h NEW/libibverbs/src/rdmaverbs.h
--- ORG/libibverbs/src/rdmaverbs.h 1969-12-31 16:00:00.000000000 -0800
+++ NEW/libibverbs/src/rdmaverbs.h 2006-08-03 17:29:42.000000000 -0700
@@ -0,0 +1,91 @@
+/*
+ * Copyright (c) 2004, 2005 Topspin Communications. All rights reserved.
+ *
+ * This software is available to you under a choice of one of two
+ * licenses. You may choose to be licensed under the terms of the GNU
+ * General Public License (GPL) Version 2, available from the file
+ * COPYING in the main directory of this source tree, or the
+ * OpenIB.org BSD license below:
+ *
+ * Redistribution and use in source and binary forms, with or
+ * without modification, are permitted provided that the following
+ * conditions are met:
+ *
+ * - Redistributions of source code must retain the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer.
+ *
+ * - Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials
+ * provided with the distribution.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
+ * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+ * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
+ * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ *
+ * $Id:
+ */
+
+#ifndef SRC_RDMA_VERBS_H
+#define SRC_RDMA_VERBS_H
+
+#include <pthread.h>
+
+#include <infiniband/driver.h>
+#include <infiniband/deprecate.h>
+
+#define HIDDEN __attribute__((visibility ("hidden")))
+
+#define INIT __attribute__((constructor))
+#define FINI __attribute__((destructor))
+
+#ifndef PFX
+#define PFX "librdmaverbs: "
+#endif
+
+struct rdmav_driver {
+ rdmav_driver_init_func init_func;
+ struct rdmav_driver *next;
+};
+
+struct rdmav_abi_compat_v2 {
+ struct rdmav_comp_channel channel;
+ pthread_mutex_t in_use;
+};
+
+extern HIDDEN int abi_ver;
+
+extern HIDDEN int rdmaverbs_init(struct rdmav_device ***list);
+
+extern HIDDEN int rdmav_init_mem_map(void);
+extern HIDDEN int rdmav_lock_range(void *base, size_t size);
+extern HIDDEN int rdmav_unlock_range(void *base, size_t size);
+
+#define RDMAV_INIT_CMD(cmd, size, opcode) \
+ do { \
+ if (abi_ver > 2) \
+ (cmd)->command = RDMAV_USER_VERBS_CMD_##opcode; \
+ else \
+ (cmd)->command = RDMAV_USER_VERBS_CMD_##opcode##_V2; \
+ (cmd)->in_words = (size) / 4; \
+ (cmd)->out_words = 0; \
+ } while (0)
+
+#define RDMAV_INIT_CMD_RESP(cmd, size, opcode, out, outsize) \
+ do { \
+ if (abi_ver > 2) \
+ (cmd)->command = RDMAV_USER_VERBS_CMD_##opcode; \
+ else \
+ (cmd)->command = RDMAV_USER_VERBS_CMD_##opcode##_V2; \
+ (cmd)->in_words = (size) / 4; \
+ (cmd)->out_words = (outsize) / 4; \
+ (cmd)->response = (uintptr_t) (out); \
+ } while (0)
+
+#endif /* SRC_RDMA_VERBS_H */
diff -ruNp ORG/libibverbs/src/sysfs.c NEW/libibverbs/src/sysfs.c
--- ORG/libibverbs/src/sysfs.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/sysfs.c 2006-08-02 18:24:49.000000000 -0700
@@ -44,11 +44,11 @@
#include <fcntl.h>
#include <string.h>
-#include "ibverbs.h"
+#include "rdmaverbs.h"
static char *sysfs_path;
-const char *ibv_get_sysfs_path(void)
+const char *rdmav_get_sysfs_path(void)
{
char *env = NULL;
@@ -65,7 +65,7 @@ const char *ibv_get_sysfs_path(void)
if (env) {
int len;
- sysfs_path = strndup(env, IBV_SYSFS_PATH_MAX);
+ sysfs_path = strndup(env, RDMAV_SYSFS_PATH_MAX);
len = strlen(sysfs_path);
while (len > 0 && sysfs_path[len - 1] == '/') {
--len;
@@ -77,7 +77,7 @@ const char *ibv_get_sysfs_path(void)
return sysfs_path;
}
-int ibv_read_sysfs_file(const char *dir, const char *file,
+int rdmav_read_sysfs_file(const char *dir, const char *file,
char *buf, size_t size)
{
char *path;
diff -ruNp ORG/libibverbs/src/verbs.c NEW/libibverbs/src/verbs.c
--- ORG/libibverbs/src/verbs.c 2006-07-30 21:18:16.000000000 -0700
+++ NEW/libibverbs/src/verbs.c 2006-08-02 18:24:49.000000000 -0700
@@ -44,54 +44,54 @@
#include <errno.h>
#include <string.h>
-#include "ibverbs.h"
+#include "rdmaverbs.h"
-int ibv_rate_to_mult(enum ibv_rate rate)
+int rdmav_rate_to_mult(enum rdmav_rate rate)
{
switch (rate) {
- case IBV_RATE_2_5_GBPS: return 1;
- case IBV_RATE_5_GBPS: return 2;
- case IBV_RATE_10_GBPS: return 4;
- case IBV_RATE_20_GBPS: return 8;
- case IBV_RATE_30_GBPS: return 12;
- case IBV_RATE_40_GBPS: return 16;
- case IBV_RATE_60_GBPS: return 24;
- case IBV_RATE_80_GBPS: return 32;
- case IBV_RATE_120_GBPS: return 48;
+ case RDMAV_RATE_2_5_GBPS: return 1;
+ case RDMAV_RATE_5_GBPS: return 2;
+ case RDMAV_RATE_10_GBPS: return 4;
+ case RDMAV_RATE_20_GBPS: return 8;
+ case RDMAV_RATE_30_GBPS: return 12;
+ case RDMAV_RATE_40_GBPS: return 16;
+ case RDMAV_RATE_60_GBPS: return 24;
+ case RDMAV_RATE_80_GBPS: return 32;
+ case RDMAV_RATE_120_GBPS: return 48;
default: return -1;
}
}
-enum ibv_rate mult_to_ibv_rate(int mult)
+enum rdmav_rate mult_to_rdmav_rate(int mult)
{
switch (mult) {
- case 1: return IBV_RATE_2_5_GBPS;
- case 2: return IBV_RATE_5_GBPS;
- case 4: return IBV_RATE_10_GBPS;
- case 8: return IBV_RATE_20_GBPS;
- case 12: return IBV_RATE_30_GBPS;
- case 16: return IBV_RATE_40_GBPS;
- case 24: return IBV_RATE_60_GBPS;
- case 32: return IBV_RATE_80_GBPS;
- case 48: return IBV_RATE_120_GBPS;
- default: return IBV_RATE_MAX;
+ case 1: return RDMAV_RATE_2_5_GBPS;
+ case 2: return RDMAV_RATE_5_GBPS;
+ case 4: return RDMAV_RATE_10_GBPS;
+ case 8: return RDMAV_RATE_20_GBPS;
+ case 12: return RDMAV_RATE_30_GBPS;
+ case 16: return RDMAV_RATE_40_GBPS;
+ case 24: return RDMAV_RATE_60_GBPS;
+ case 32: return RDMAV_RATE_80_GBPS;
+ case 48: return RDMAV_RATE_120_GBPS;
+ default: return RDMAV_RATE_MAX;
}
}
-int ibv_query_device(struct ibv_context *context,
- struct ibv_device_attr *device_attr)
+int rdmav_query_device(struct rdmav_context *context,
+ struct rdmav_device_attr *device_attr)
{
return context->ops.query_device(context, device_attr);
}
-int ibv_query_port(struct ibv_context *context, uint8_t port_num,
- struct ibv_port_attr *port_attr)
+int rdmav_query_port(struct rdmav_context *context, uint8_t port_num,
+ struct rdmav_port_attr *port_attr)
{
return context->ops.query_port(context, port_num, port_attr);
}
-int ibv_query_gid(struct ibv_context *context, uint8_t port_num,
- int index, union ibv_gid *gid)
+int rdmav_query_gid(struct rdmav_context *context, uint8_t port_num,
+ int index, union rdmav_gid *gid)
{
char name[24];
char attr[41];
@@ -100,7 +100,7 @@ int ibv_query_gid(struct ibv_context *co
snprintf(name, sizeof name, "ports/%d/gids/%d", port_num, index);
- if (ibv_read_sysfs_file(context->device->ibdev_path, name,
+ if (rdmav_read_sysfs_file(context->device->ibdev_path, name,
attr, sizeof attr) < 0)
return -1;
@@ -114,7 +114,7 @@ int ibv_query_gid(struct ibv_context *co
return 0;
}
-int ibv_query_pkey(struct ibv_context *context, uint8_t port_num,
+int rdmav_query_pkey(struct rdmav_context *context, uint8_t port_num,
int index, uint16_t *pkey)
{
char name[24];
@@ -123,7 +123,7 @@ int ibv_query_pkey(struct ibv_context *c
snprintf(name, sizeof name, "ports/%d/pkeys/%d", port_num, index);
- if (ibv_read_sysfs_file(context->device->ibdev_path, name,
+ if (rdmav_read_sysfs_file(context->device->ibdev_path, name,
attr, sizeof attr) < 0)
return -1;
@@ -134,9 +134,9 @@ int ibv_query_pkey(struct ibv_context *c
return 0;
}
-struct ibv_pd *ibv_alloc_pd(struct ibv_context *context)
+struct rdmav_pd *rdmav_alloc_pd(struct rdmav_context *context)
{
- struct ibv_pd *pd;
+ struct rdmav_pd *pd;
pd = context->ops.alloc_pd(context);
if (pd)
@@ -145,15 +145,15 @@ struct ibv_pd *ibv_alloc_pd(struct ibv_c
return pd;
}
-int ibv_dealloc_pd(struct ibv_pd *pd)
+int rdmav_dealloc_pd(struct rdmav_pd *pd)
{
return pd->context->ops.dealloc_pd(pd);
}
-struct ibv_mr *ibv_reg_mr(struct ibv_pd *pd, void *addr,
- size_t length, enum ibv_access_flags access)
+struct rdmav_mr *rdmav_reg_mr(struct rdmav_pd *pd, void *addr,
+ size_t length, enum rdmav_access_flags access)
{
- struct ibv_mr *mr;
+ struct rdmav_mr *mr;
mr = pd->context->ops.reg_mr(pd, addr, length, access);
if (mr) {
@@ -164,14 +164,14 @@ struct ibv_mr *ibv_reg_mr(struct ibv_pd
return mr;
}
-int ibv_dereg_mr(struct ibv_mr *mr)
+int rdmav_dereg_mr(struct rdmav_mr *mr)
{
return mr->context->ops.dereg_mr(mr);
}
-static struct ibv_comp_channel *ibv_create_comp_channel_v2(struct ibv_context *context)
+static struct rdmav_comp_channel *rdmav_create_comp_channel_v2(struct rdmav_context *context)
{
- struct ibv_abi_compat_v2 *t = context->abi_compat;
+ struct rdmav_abi_compat_v2 *t = context->abi_compat;
static int warned;
if (!pthread_mutex_trylock(&t->in_use))
@@ -187,20 +187,20 @@ static struct ibv_comp_channel *ibv_crea
return NULL;
}
-struct ibv_comp_channel *ibv_create_comp_channel(struct ibv_context *context)
+struct rdmav_comp_channel *rdmav_create_comp_channel(struct rdmav_context *context)
{
- struct ibv_comp_channel *channel;
- struct ibv_create_comp_channel cmd;
- struct ibv_create_comp_channel_resp resp;
+ struct rdmav_comp_channel *channel;
+ struct rdmav_create_comp_channel cmd;
+ struct rdmav_create_comp_channel_resp resp;
if (abi_ver <= 2)
- return ibv_create_comp_channel_v2(context);
+ return rdmav_create_comp_channel_v2(context);
channel = malloc(sizeof *channel);
if (!channel)
return NULL;
- IBV_INIT_CMD_RESP(&cmd, sizeof cmd, CREATE_COMP_CHANNEL, &resp, sizeof resp);
+ RDMAV_INIT_CMD_RESP(&cmd, sizeof cmd, CREATE_COMP_CHANNEL, &resp, sizeof resp);
if (write(context->cmd_fd, &cmd, sizeof cmd) != sizeof cmd) {
free(channel);
return NULL;
@@ -211,17 +211,17 @@ struct ibv_comp_channel *ibv_create_comp
return channel;
}
-static int ibv_destroy_comp_channel_v2(struct ibv_comp_channel *channel)
+static int rdmav_destroy_comp_channel_v2(struct rdmav_comp_channel *channel)
{
- struct ibv_abi_compat_v2 *t = (struct ibv_abi_compat_v2 *) channel;
+ struct rdmav_abi_compat_v2 *t = (struct rdmav_abi_compat_v2 *) channel;
pthread_mutex_unlock(&t->in_use);
return 0;
}
-int ibv_destroy_comp_channel(struct ibv_comp_channel *channel)
+int rdmav_destroy_comp_channel(struct rdmav_comp_channel *channel)
{
if (abi_ver <= 2)
- return ibv_destroy_comp_channel_v2(channel);
+ return rdmav_destroy_comp_channel_v2(channel);
close(channel->fd);
free(channel);
@@ -229,10 +229,12 @@ int ibv_destroy_comp_channel(struct ibv_
return 0;
}
-struct ibv_cq *ibv_create_cq(struct ibv_context *context, int cqe, void *cq_context,
- struct ibv_comp_channel *channel, int comp_vector)
+struct rdmav_cq *rdmav_create_cq(struct rdmav_context *context, int cqe,
+ void *cq_context,
+ struct rdmav_comp_channel *channel,
+ int comp_vector)
{
- struct ibv_cq *cq = context->ops.create_cq(context, cqe, channel,
+ struct rdmav_cq *cq = context->ops.create_cq(context, cqe, channel,
comp_vector);
if (cq) {
@@ -247,7 +249,7 @@ struct ibv_cq *ibv_create_cq(struct ibv_
return cq;
}
-int ibv_resize_cq(struct ibv_cq *cq, int cqe)
+int rdmav_resize_cq(struct rdmav_cq *cq, int cqe)
{
if (!cq->context->ops.resize_cq)
return ENOSYS;
@@ -255,21 +257,20 @@ int ibv_resize_cq(struct ibv_cq *cq, int
return cq->context->ops.resize_cq(cq, cqe);
}
-int ibv_destroy_cq(struct ibv_cq *cq)
+int rdmav_destroy_cq(struct rdmav_cq *cq)
{
return cq->context->ops.destroy_cq(cq);
}
-
-int ibv_get_cq_event(struct ibv_comp_channel *channel,
- struct ibv_cq **cq, void **cq_context)
+int rdmav_get_cq_event(struct rdmav_comp_channel *channel,
+ struct rdmav_cq **cq, void **cq_context)
{
- struct ibv_comp_event ev;
+ struct rdmav_comp_event ev;
if (read(channel->fd, &ev, sizeof ev) != sizeof ev)
return -1;
- *cq = (struct ibv_cq *) (uintptr_t) ev.cq_handle;
+ *cq = (struct rdmav_cq *) (uintptr_t) ev.cq_handle;
*cq_context = (*cq)->cq_context;
if ((*cq)->context->ops.cq_event)
@@ -278,7 +279,7 @@ int ibv_get_cq_event(struct ibv_comp_cha
return 0;
}
-void ibv_ack_cq_events(struct ibv_cq *cq, unsigned int nevents)
+void rdmav_ack_cq_events(struct rdmav_cq *cq, unsigned int nevents)
{
pthread_mutex_lock(&cq->mutex);
cq->comp_events_completed += nevents;
@@ -286,10 +287,10 @@ void ibv_ack_cq_events(struct ibv_cq *cq
pthread_mutex_unlock(&cq->mutex);
}
-struct ibv_srq *ibv_create_srq(struct ibv_pd *pd,
- struct ibv_srq_init_attr *srq_init_attr)
+struct rdmav_srq *rdmav_create_srq(struct rdmav_pd *pd,
+ struct rdmav_srq_init_attr *srq_init_attr)
{
- struct ibv_srq *srq;
+ struct rdmav_srq *srq;
if (!pd->context->ops.create_srq)
return NULL;
@@ -307,27 +308,27 @@ struct ibv_srq *ibv_create_srq(struct ib
return srq;
}
-int ibv_modify_srq(struct ibv_srq *srq,
- struct ibv_srq_attr *srq_attr,
- enum ibv_srq_attr_mask srq_attr_mask)
+int rdmav_modify_srq(struct rdmav_srq *srq,
+ struct rdmav_srq_attr *srq_attr,
+ enum rdmav_srq_attr_mask srq_attr_mask)
{
return srq->context->ops.modify_srq(srq, srq_attr, srq_attr_mask);
}
-int ibv_query_srq(struct ibv_srq *srq, struct ibv_srq_attr *srq_attr)
+int rdmav_query_srq(struct rdmav_srq *srq, struct rdmav_srq_attr *srq_attr)
{
return srq->context->ops.query_srq(srq, srq_attr);
}
-int ibv_destroy_srq(struct ibv_srq *srq)
+int rdmav_destroy_srq(struct rdmav_srq *srq)
{
return srq->context->ops.destroy_srq(srq);
}
-struct ibv_qp *ibv_create_qp(struct ibv_pd *pd,
- struct ibv_qp_init_attr *qp_init_attr)
+struct rdmav_qp *rdmav_create_qp(struct rdmav_pd *pd,
+ struct rdmav_qp_init_attr *qp_init_attr)
{
- struct ibv_qp *qp = pd->context->ops.create_qp(pd, qp_init_attr);
+ struct rdmav_qp *qp = pd->context->ops.create_qp(pd, qp_init_attr);
if (qp) {
qp->context = pd->context;
@@ -345,9 +346,9 @@ struct ibv_qp *ibv_create_qp(struct ibv_
return qp;
}
-int ibv_query_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr,
- enum ibv_qp_attr_mask attr_mask,
- struct ibv_qp_init_attr *init_attr)
+int rdmav_query_qp(struct rdmav_qp *qp, struct rdmav_qp_attr *attr,
+ enum rdmav_qp_attr_mask attr_mask,
+ struct rdmav_qp_init_attr *init_attr)
{
int ret;
@@ -355,14 +356,14 @@ int ibv_query_qp(struct ibv_qp *qp, stru
if (ret)
return ret;
- if (attr_mask & IBV_QP_STATE)
+ if (attr_mask & RDMAV_QP_STATE)
qp->state = attr->qp_state;
return 0;
}
-int ibv_modify_qp(struct ibv_qp *qp, struct ibv_qp_attr *attr,
- enum ibv_qp_attr_mask attr_mask)
+int rdmav_modify_qp(struct rdmav_qp *qp, struct rdmav_qp_attr *attr,
+ enum rdmav_qp_attr_mask attr_mask)
{
int ret;
@@ -370,20 +371,20 @@ int ibv_modify_qp(struct ibv_qp *qp, str
if (ret)
return ret;
- if (attr_mask & IBV_QP_STATE)
+ if (attr_mask & RDMAV_QP_STATE)
qp->state = attr->qp_state;
return 0;
}
-int ibv_destroy_qp(struct ibv_qp *qp)
+int rdmav_destroy_qp(struct rdmav_qp *qp)
{
return qp->context->ops.destroy_qp(qp);
}
-struct ibv_ah *ibv_create_ah(struct ibv_pd *pd, struct ibv_ah_attr *attr)
+struct rdmav_ah *rdmav_create_ah(struct rdmav_pd *pd, struct rdmav_ah_attr *attr)
{
- struct ibv_ah *ah = pd->context->ops.create_ah(pd, attr);
+ struct rdmav_ah *ah = pd->context->ops.create_ah(pd, attr);
if (ah) {
ah->context = pd->context;
@@ -393,22 +394,22 @@ struct ibv_ah *ibv_create_ah(struct ibv_
return ah;
}
-static int ibv_find_gid_index(struct ibv_context *context, uint8_t port_num,
- union ibv_gid *gid)
+static int rdmav_find_gid_index(struct rdmav_context *context, uint8_t port_num,
+ union rdmav_gid *gid)
{
- union ibv_gid sgid;
+ union rdmav_gid sgid;
int i = 0, ret;
do {
- ret = ibv_query_gid(context, port_num, i++, &sgid);
+ ret = rdmav_query_gid(context, port_num, i++, &sgid);
} while (!ret && memcmp(&sgid, gid, sizeof *gid));
return ret ? ret : i - 1;
}
-int ibv_init_ah_from_wc(struct ibv_context *context, uint8_t port_num,
- struct ibv_wc *wc, struct ibv_grh *grh,
- struct ibv_ah_attr *ah_attr)
+int rdmav_init_ah_from_wc(struct rdmav_context *context, uint8_t port_num,
+ struct rdmav_wc *wc, struct rdmav_grh *grh,
+ struct rdmav_ah_attr *ah_attr)
{
uint32_t flow_class;
int ret;
@@ -419,11 +420,11 @@ int ibv_init_ah_from_wc(struct ibv_conte
ah_attr->src_path_bits = wc->dlid_path_bits;
ah_attr->port_num = port_num;
- if (wc->wc_flags & IBV_WC_GRH) {
+ if (wc->wc_flags & RDMAV_WC_GRH) {
ah_attr->is_global = 1;
ah_attr->grh.dgid = grh->sgid;
- ret = ibv_find_gid_index(context, port_num, &grh->dgid);
+ ret = rdmav_find_gid_index(context, port_num, &grh->dgid);
if (ret < 0)
return ret;
@@ -436,30 +437,30 @@ int ibv_init_ah_from_wc(struct ibv_conte
return 0;
}
-struct ibv_ah *ibv_create_ah_from_wc(struct ibv_pd *pd, struct ibv_wc *wc,
- struct ibv_grh *grh, uint8_t port_num)
+struct rdmav_ah *rdmav_create_ah_from_wc(struct rdmav_pd *pd, struct rdmav_wc *wc,
+ struct rdmav_grh *grh, uint8_t port_num)
{
- struct ibv_ah_attr ah_attr;
+ struct rdmav_ah_attr ah_attr;
int ret;
- ret = ibv_init_ah_from_wc(pd->context, port_num, wc, grh, &ah_attr);
+ ret = rdmav_init_ah_from_wc(pd->context, port_num, wc, grh, &ah_attr);
if (ret)
return NULL;
- return ibv_create_ah(pd, &ah_attr);
+ return rdmav_create_ah(pd, &ah_attr);
}
-int ibv_destroy_ah(struct ibv_ah *ah)
+int rdmav_destroy_ah(struct rdmav_ah *ah)
{
return ah->context->ops.destroy_ah(ah);
}
-int ibv_attach_mcast(struct ibv_qp *qp, union ibv_gid *gid, uint16_t lid)
+int rdmav_attach_mcast(struct rdmav_qp *qp, union rdmav_gid *gid, uint16_t lid)
{
return qp->context->ops.attach_mcast(qp, gid, lid);
}
-int ibv_detach_mcast(struct ibv_qp *qp, union ibv_gid *gid, uint16_t lid)
+int rdmav_detach_mcast(struct rdmav_qp *qp, union rdmav_gid *gid, uint16_t lid)
{
return qp->context->ops.detach_mcast(qp, gid, lid);
}
More information about the general
mailing list