本文整理匯總了C++中FI_WARN函數的典型用法代碼示例。如果您正苦於以下問題:C++ FI_WARN函數的具體用法?C++ FI_WARN怎麽用?C++ FI_WARN使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了FI_WARN函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: handle_connreq
static void handle_connreq(struct poll_fd_mgr *poll_mgr,
struct poll_fd_info *poll_info)
{
struct tcpx_conn_handle *handle;
struct tcpx_pep *pep;
struct fi_eq_cm_entry *cm_entry;
struct ofi_ctrl_hdr conn_req;
SOCKET sock;
int ret;
assert(poll_info->fid->fclass == FI_CLASS_PEP);
pep = container_of(poll_info->fid, struct tcpx_pep, util_pep.pep_fid.fid);
sock = accept(pep->sock, NULL, 0);
if (sock < 0) {
FI_WARN(&tcpx_prov, FI_LOG_EP_CTRL, "accept error: %d\n",
ofi_sockerr());
return;
}
ret = rx_cm_data(sock, &conn_req, ofi_ctrl_connreq, poll_info);
if (ret) {
FI_WARN(&tcpx_prov, FI_LOG_EP_CTRL, "cm data recv failed \n");
goto err1;
}
handle = calloc(1, sizeof(*handle));
if (!handle)
goto err1;
cm_entry = calloc(1, sizeof(*cm_entry) + poll_info->cm_data_sz);
if (!cm_entry)
goto err2;
handle->conn_fd = sock;
cm_entry->fid = poll_info->fid;
cm_entry->info = fi_dupinfo(&pep->info);
if (!cm_entry->info)
goto err3;
cm_entry->info->handle = &handle->handle;
memcpy(cm_entry->data, poll_info->cm_data, poll_info->cm_data_sz);
ret = (int) fi_eq_write(&pep->util_pep.eq->eq_fid, FI_CONNREQ, cm_entry,
sizeof(*cm_entry) + poll_info->cm_data_sz, 0);
if (ret < 0) {
FI_WARN(&tcpx_prov, FI_LOG_EP_CTRL, "Error writing to EQ\n");
goto err4;
}
free(cm_entry);
return;
err4:
fi_freeinfo(cm_entry->info);
err3:
free(cm_entry);
err2:
free(handle);
err1:
ofi_close_socket(sock);
}
示例2: rxm_ep_msg_res_close
static int rxm_ep_msg_res_close(struct rxm_ep *rxm_ep)
{
int ret, retv = 0;
ret = fi_close(&rxm_ep->msg_cq->fid);
if (ret) {
FI_WARN(&rxm_prov, FI_LOG_EP_CTRL, "Unable to close msg CQ\n");
retv = ret;
}
ret = fi_close(&rxm_ep->srx_ctx->fid);
if (ret) {
FI_WARN(&rxm_prov, FI_LOG_EP_CTRL, "Unable to close msg shared ctx\n");
retv = ret;
}
ret = fi_close(&rxm_ep->msg_pep->fid);
if (ret) {
FI_WARN(&rxm_prov, FI_LOG_EP_CTRL, "Unable to close msg passive EP\n");
retv = ret;
}
fi_freeinfo(rxm_ep->msg_info);
return retv;
}
示例3: smr_ep_bind
static int smr_ep_bind(struct fid *ep_fid, struct fid *bfid, uint64_t flags)
{
struct smr_ep *ep;
struct util_av *av;
int ret = 0;
ep = container_of(ep_fid, struct smr_ep, util_ep.ep_fid.fid);
switch (bfid->fclass) {
case FI_CLASS_AV:
av = container_of(bfid, struct util_av, av_fid.fid);
ret = ofi_ep_bind_av(&ep->util_ep, av);
if (ret) {
FI_WARN(&smr_prov, FI_LOG_EP_CTRL,
"duplicate AV binding\n");
return -FI_EINVAL;
}
break;
case FI_CLASS_CQ:
ret = smr_ep_bind_cq(ep, container_of(bfid, struct util_cq,
cq_fid.fid), flags);
break;
case FI_CLASS_EQ:
break;
default:
FI_WARN(&smr_prov, FI_LOG_EP_CTRL,
"invalid fid class\n");
ret = -FI_EINVAL;
break;
}
return ret;
}
示例4: ip_av_remove
static int ip_av_remove(struct fid_av *av_fid, fi_addr_t *fi_addr, size_t count,
uint64_t flags)
{
struct util_av *av;
int i, slot, index, ret;
av = container_of(av_fid, struct util_av, av_fid);
if (flags) {
FI_WARN(av->prov, FI_LOG_AV, "invalid flags\n");
return -FI_EINVAL;
}
/*
* It's more efficient to remove addresses from high to low index.
* We assume that addresses are removed in the same order that they were
* added -- i.e. fi_addr passed in here was also passed into insert.
* Thus, we walk through the array backwards.
*/
for (i = count - 1; i >= 0; i--) {
index = (int) fi_addr[i];
slot = ip_av_slot(av, ip_av_get_addr(av, index));
ret = fi_av_remove_addr(av, slot, index);
if (ret) {
FI_WARN(av->prov, FI_LOG_AV,
"removal of fi_addr %d failed\n", index);
}
}
return 0;
}
示例5: calloc
static struct ofi_prov *ofi_create_prov_entry(const char *prov_name)
{
struct ofi_prov *prov = NULL;
prov = calloc(sizeof *prov, 1);
if (!prov) {
FI_WARN(&core_prov, FI_LOG_CORE,
"Not enough memory to allocate provider registry\n");
return NULL;
}
prov->prov_name = strdup(prov_name);
if (!prov->prov_name) {
FI_WARN(&core_prov, FI_LOG_CORE,
"Failed to init pre-registered provider name\n");
free(prov);
return NULL;
}
if (prov_tail)
prov_tail->next = prov;
else
prov_head = prov;
prov_tail = prov;
return prov;
}
示例6: util_verify_av_attr
static int util_verify_av_attr(struct util_domain *domain,
const struct fi_av_attr *attr,
const struct util_av_attr *util_attr)
{
switch (attr->type) {
case FI_AV_MAP:
case FI_AV_TABLE:
if ((domain->av_type != FI_AV_UNSPEC) &&
(attr->type != domain->av_type)) {
FI_INFO(domain->prov, FI_LOG_AV, "Invalid AV type\n");
return -FI_EINVAL;
}
break;
default:
FI_WARN(domain->prov, FI_LOG_AV, "invalid av type\n");
return -FI_EINVAL;
}
if (attr->flags & ~(FI_EVENT | FI_READ | FI_SYMMETRIC)) {
FI_WARN(domain->prov, FI_LOG_AV, "invalid flags\n");
return -FI_EINVAL;
}
if (util_attr->flags & ~(FI_SOURCE)) {
FI_WARN(domain->prov, FI_LOG_AV, "invalid internal flags\n");
return -FI_EINVAL;
}
if (util_attr->addrlen < sizeof(int)) {
FI_WARN(domain->prov, FI_LOG_AV, "unsupported address size\n");
return -FI_ENOSYS;
}
return 0;
}
示例7: rxm_ep_ctrl
static int rxm_ep_ctrl(struct fid *fid, int command, void *arg)
{
struct rxm_ep *rxm_ep;
struct rxm_fabric *rxm_fabric;
int ret;
rxm_ep = container_of(fid, struct rxm_ep, util_ep.ep_fid.fid);
rxm_fabric = container_of(rxm_ep->util_ep.domain->fabric,
struct rxm_fabric, util_fabric);
switch (command) {
case FI_ENABLE:
if (!rxm_ep->util_ep.rx_cq || !rxm_ep->util_ep.tx_cq)
return -FI_ENOCQ;
if (!rxm_ep->util_ep.av)
return -FI_EOPBADSTATE; /* TODO: Add FI_ENOAV */
ret = fi_pep_bind(rxm_ep->msg_pep, &rxm_fabric->msg_eq->fid, 0);
if (ret) {
FI_WARN(&rxm_prov, FI_LOG_EP_CTRL,
"Unable to bind msg PEP to msg EQ\n");
return ret;
}
ret = fi_listen(rxm_ep->msg_pep);
if (ret) {
FI_WARN(&rxm_prov, FI_LOG_EP_CTRL,
"Unable to set msg PEP to listen state\n");
return ret;
}
break;
default:
return -FI_ENOSYS;
}
return 0;
}
示例8: psmx2_string_to_uuid
static void psmx2_string_to_uuid(const char *s, psm2_uuid_t uuid)
{
int n;
if (!s) {
memset(uuid, 0, sizeof(psm2_uuid_t));
return;
}
n = sscanf(s,
"%2hhx%2hhx%2hhx%2hhx-"
"%2hhx%2hhx-%2hhx%2hhx-%2hhx%2hhx-"
"%2hhx%2hhx%2hhx%2hhx%2hhx%2hhx",
&uuid[0], &uuid[1], &uuid[2], &uuid[3],
&uuid[4], &uuid[5], &uuid[6], &uuid[7], &uuid[8], &uuid[9],
&uuid[10], &uuid[11], &uuid[12], &uuid[13], &uuid[14], &uuid[15]);
if (n != 16) {
FI_WARN(&psmx2_prov, FI_LOG_CORE,
"wrong uuid format: %s\n", s);
FI_WARN(&psmx2_prov, FI_LOG_CORE,
"correct uuid format is: "
"xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\n");
}
}
示例9: rxm_ep_recv_common
int rxm_ep_recv_common(struct fid_ep *ep_fid, const struct iovec *iov, void **desc,
size_t count, fi_addr_t src_addr, uint64_t tag, uint64_t ignore,
void *context, uint64_t flags, int op)
{
struct rxm_recv_entry *recv_entry;
struct rxm_ep *rxm_ep;
struct rxm_recv_queue *recv_queue;
dlist_func_t *match;
int ret, i;
rxm_ep = container_of(ep_fid, struct rxm_ep, util_ep.ep_fid.fid);
// TODO pass recv_queue as arg
if (op == ofi_op_msg) {
recv_queue = &rxm_ep->recv_queue;
match = ofi_match_unexp_msg;
} else if (op == ofi_op_tagged) {
recv_queue = &rxm_ep->trecv_queue;
match = ofi_match_unexp_msg_tagged;
} else {
FI_WARN(&rxm_prov, FI_LOG_EP_DATA, "Unknown op!\n");
return -FI_EINVAL;
}
if (freestack_isempty(recv_queue->recv_fs)) {
FI_DBG(&rxm_prov, FI_LOG_CQ, "Exhaused recv_entry freestack\n");
return -FI_EAGAIN;
}
recv_entry = freestack_pop(recv_queue->recv_fs);
for (i = 0; i < count; i++) {
recv_entry->iov[i].iov_base = iov[i].iov_base;
recv_entry->iov[i].iov_len = iov[i].iov_len;
recv_entry->desc[i] = desc[i];
FI_DBG(&rxm_prov, FI_LOG_EP_CTRL, "post recv: %u\n",
iov[i].iov_len);
}
recv_entry->count = count;
recv_entry->addr = (rxm_ep->rxm_info->caps & FI_DIRECTED_RECV) ?
src_addr : FI_ADDR_UNSPEC;
recv_entry->flags = flags;
if (op == ofi_op_tagged) {
recv_entry->tag = tag;
recv_entry->ignore = ignore;
}
if (!dlist_empty(&recv_queue->unexp_msg_list)) {
ret = rxm_check_unexp_msg_list(rxm_ep->util_ep.rx_cq, recv_queue,
recv_entry, match);
if (ret) {
FI_WARN(&rxm_prov, FI_LOG_EP_DATA,
"Unable to check unexp msg list\n");
return ret;
}
}
dlist_insert_tail(&recv_entry->entry, &recv_queue->recv_list);
return 0;
}
示例10: rxm_cq_write_error_trunc
static int rxm_cq_write_error_trunc(struct rxm_rx_buf *rx_buf, size_t done_len)
{
int ret;
if (rx_buf->ep->util_ep.flags & OFI_CNTR_ENABLED)
rxm_cntr_incerr(rx_buf->ep->util_ep.rx_cntr);
FI_WARN(&rxm_prov, FI_LOG_CQ, "Message truncated: "
"recv buf length: %zu message length: %" PRIu64 "\n",
done_len, rx_buf->pkt.hdr.size);
ret = ofi_cq_write_error_trunc(rx_buf->ep->util_ep.rx_cq,
rx_buf->recv_entry->context,
rx_buf->recv_entry->comp_flags |
rxm_cq_get_rx_comp_flags(rx_buf),
rx_buf->pkt.hdr.size,
rx_buf->recv_entry->rxm_iov.iov[0].iov_base,
rx_buf->pkt.hdr.data, rx_buf->pkt.hdr.tag,
rx_buf->pkt.hdr.size - done_len);
if (OFI_UNLIKELY(ret)) {
FI_WARN(&rxm_prov, FI_LOG_CQ,
"Unable to write recv error CQ\n");
return ret;
}
return 0;
}
示例11: psmx_set_epaddr_context
static void psmx_set_epaddr_context(struct psmx_fid_domain *domain,
psm_epid_t epid, psm_epaddr_t epaddr)
{
struct psmx_epaddr_context *context;
context = (void *)psm_epaddr_getctxt(epaddr);
if (context) {
if (context->domain != domain || context->epid != epid) {
FI_WARN(&psmx_prov, FI_LOG_AV,
"domain or epid doesn't match\n");
context = NULL;
}
}
if (context)
return;
context = malloc(sizeof *context);
if (!context) {
FI_WARN(&psmx_prov, FI_LOG_AV,
"cannot allocate context\n");
return;
}
context->domain = domain;
context->epid = epid;
psm_epaddr_setctxt(epaddr, context);
}
示例12: DEFAULT_SYMVER_PRE
int DEFAULT_SYMVER_PRE(fi_getinfo)(uint32_t version, const char *node, const char *service,
uint64_t flags, struct fi_info *hints, struct fi_info **info)
{
struct fi_prov *prov;
struct fi_info *tail, *cur;
int ret;
if (!init)
fi_ini();
if (FI_VERSION_LT(fi_version(), version)) {
FI_WARN(&core_prov, FI_LOG_CORE,
"Requested version is newer than library\n");
return -FI_ENOSYS;
}
if (flags == FI_PROV_ATTR_ONLY) {
return fi_getprovinfo(info);
}
*info = tail = NULL;
for (prov = prov_head; prov; prov = prov->next) {
if (!prov->provider->getinfo)
continue;
if (hints && hints->fabric_attr && hints->fabric_attr->prov_name &&
strcasecmp(prov->provider->name, hints->fabric_attr->prov_name))
continue;
ret = prov->provider->getinfo(version, node, service, flags,
hints, &cur);
if (ret) {
FI_WARN(&core_prov, FI_LOG_CORE,
"fi_getinfo: provider %s returned -%d (%s)\n",
prov->provider->name, -ret, fi_strerror(-ret));
continue;
}
if (!*info)
*info = cur;
else
tail->next = cur;
for (tail = cur; tail->next; tail = tail->next) {
if (tail->fabric_attr->prov_name != NULL)
FI_WARN(&core_prov, FI_LOG_CORE,
"prov_name field is not NULL (%s)\n",
tail->fabric_attr->prov_name);
tail->fabric_attr->prov_name = strdup(prov->provider->name);
tail->fabric_attr->prov_version = prov->provider->version;
}
if (tail->fabric_attr->prov_name != NULL)
FI_WARN(&core_prov, FI_LOG_CORE,
"prov_name field is not NULL (%s)\n",
tail->fabric_attr->prov_name);
tail->fabric_attr->prov_name = strdup(prov->provider->name);
tail->fabric_attr->prov_version = prov->provider->version;
}
return *info ? 0 : -FI_ENODATA;
}
示例13: tcpx_conn_mgr_init
int tcpx_conn_mgr_init(struct tcpx_fabric *tcpx_fabric)
{
int ret;
dlist_init(&tcpx_fabric->poll_mgr.list);
fastlock_init(&tcpx_fabric->poll_mgr.lock);
ret = fd_signal_init(&tcpx_fabric->poll_mgr.signal);
if (ret) {
FI_WARN(&tcpx_prov, FI_LOG_FABRIC,"signal init failed\n");
goto err;
}
tcpx_fabric->poll_mgr.run = 1;
ret = pthread_create(&tcpx_fabric->conn_mgr_thread, 0,
tcpx_conn_mgr_thread, (void *) tcpx_fabric);
if (ret) {
FI_WARN(&tcpx_prov, FI_LOG_FABRIC,
"Failed creating tcpx connection manager thread");
goto err1;
}
return 0;
err1:
fd_signal_free(&tcpx_fabric->poll_mgr.signal);
err:
fastlock_destroy(&tcpx_fabric->poll_mgr.lock);
return ret;
}
示例14: ofi_av_insert_addr
int ofi_av_insert_addr(struct util_av *av, const void *addr, int slot, int *index)
{
int ret = 0;
fastlock_acquire(&av->lock);
if (av->free_list == UTIL_NO_ENTRY) {
FI_WARN(av->prov, FI_LOG_AV, "AV is full\n");
ret = -FI_ENOSPC;
goto out;
}
if (av->flags & FI_SOURCE) {
ret = util_av_hash_insert(&av->hash, slot, av->free_list);
if (ret) {
FI_WARN(av->prov, FI_LOG_AV,
"failed to insert addr into hash table\n");
goto out;
}
}
*index = av->free_list;
av->free_list = *(int *) util_av_get_data(av, av->free_list);
util_av_set_data(av, *index, addr, av->addrlen);
out:
fastlock_release(&av->lock);
return ret;
}
示例15: smr_fetch_result
static int smr_fetch_result(struct smr_ep *ep, struct smr_region *peer_smr,
struct iovec *iov, size_t iov_count,
const struct fi_rma_ioc *rma_ioc, size_t rma_count,
enum fi_datatype datatype, size_t total_len)
{
int ret, i;
struct iovec rma_iov[SMR_IOV_LIMIT];
for (i = 0; i < rma_count; i++) {
rma_iov[i].iov_base = (void *) rma_ioc[i].addr;
rma_iov[i].iov_len = rma_ioc[i].count * ofi_datatype_size(datatype);
}
ret = process_vm_readv(peer_smr->pid, iov, iov_count,
rma_iov, rma_count, 0);
if (ret != total_len) {
if (ret < 0) {
FI_WARN(&smr_prov, FI_LOG_EP_CTRL,
"CMA write error\n");
return -errno;
} else {
FI_WARN(&smr_prov, FI_LOG_EP_CTRL,
"partial read occurred\n");
return -FI_EIO;
}
}
return 0;
}