[openib-general] userspace CM API for per device handling

Sean Hefty
Wed Sep 14 14:32:55 PDT 2005


Roland Dreier wrote:
>>ibv_get_async_event(int fd, struct ibv_async_event *event);
>>ibv_get_cq_event(int fd, struct ibv_cq **cq, void **cq_context);
> 
> This seems like mostly pain with little gain to me.  A consumer doing
> a poll or something with multiple file descriptors still needs some
> mapping to some per-fd context so that it knows which fds are CQ event
> fds, which ones are async event fds, and which ones are neither.  So
> it's pretty easy to go back to a verbs context.

I'm not sold on this change either.  Right now I'm just trying to find a decent 
API for the CM, and the one you mentioned works just as well.

As for mapping fd's to context, I think this depends on how the user groups 
multiple file descriptors together and their threading model.  A user could poll 
only fd's associated with CQs; although, I don't think that the current 
implementation of DAPL does this.

> If we wanted to be more symmetrical, we could have a CM API like
> 
>     struct ib_cm_context *ib_cm_get_context(struct ibv_context *dev_context);
>     int ib_cm_get_event(struct ib_cm_context *context, struct ib_cm_event **event);

This API still gives the benefits that I was looking for, so I will go with 
something like this for now.  Thanks.

- Sean



More information about the openib-general mailing list