|
NAMEibv_get_async_event, ibv_ack_async_event - get or acknowledge asynchronous eventsSYNOPSIS#include <infiniband/verbs.h> int ibv_get_async_event(struct ibv_context *context, struct ibv_async_event *event); void ibv_ack_async_event(struct ibv_async_event *event); DESCRIPTIONibv_get_async_event() waits for the next async event of the RDMA device context context and returns it through the pointer event, which is an ibv_async_event struct, as defined in <infiniband/verbs.h>.struct ibv_async_event { One member of the element union will be valid, depending on the event_type member of the structure. event_type will be one of the following events: QP events:
CQ events:
SRQ events:
Port events:
CA events:
ibv_ack_async_event() acknowledge the async event event. RETURN VALUEibv_get_async_event() returns 0 on success, and -1 on error.ibv_ack_async_event() returns no value. NOTESAll async events that ibv_get_async_event() returns must be acknowledged using ibv_ack_async_event(). To avoid races, destroying an object (CQ, SRQ or QP) will wait for all affiliated events for the object to be acknowledged; this avoids an application retrieving an affiliated event after the corresponding object has already been destroyed.ibv_get_async_event() is a blocking function. If multiple threads call this function simultaneously, then when an async event occurs, only one thread will receive it, and it is not possible to predict which thread will receive it. EXAMPLESThe following code example demonstrates one possible way to work with async events in non-blocking mode. It performs the following steps:1. Set the async events queue work mode to be non-blocked
/* change the blocking mode of the async event queue */ flags = fcntl(ctx->async_fd, F_GETFL); rc = fcntl(ctx->async_fd, F_SETFL, flags | O_NONBLOCK); if (rc < 0) { fprintf(stderr, "Failed to change file descriptor of async event queue\n"); return 1; } /* * poll the queue until it has an event and sleep ms_timeout * milliseconds between any iteration */ my_pollfd.fd = ctx->async_fd; my_pollfd.events = POLLIN; my_pollfd.revents = 0; do { rc = poll(&my_pollfd, 1, ms_timeout); } while (rc == 0); if (rc < 0) { fprintf(stderr, "poll failed\n"); return 1; } /* Get the async event */ if (ibv_get_async_event(ctx, &async_event)) { fprintf(stderr, "Failed to get async_event\n"); return 1; } /* Ack the event */ ibv_ack_async_event(&async_event); SEE ALSOibv_open_device(3)AUTHORS
Visit the GSP FreeBSD Man Page Interface. |