Skip to content

Commit

Permalink
prov/coll - prepare cq to be used in other providers
Browse files Browse the repository at this point in the history
Signed-off-by: Tomasz Gromadzki <[email protected]>
  • Loading branch information
grom72 committed Nov 28, 2022
1 parent 78ed3d9 commit 6652138
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 3 deletions.
4 changes: 4 additions & 0 deletions include/ofi_coll.h
Original file line number Diff line number Diff line change
Expand Up @@ -162,4 +162,8 @@ struct util_coll_operation {
uint64_t flags;
};

int coll_cq_init(struct fid_domain *domain, struct fi_cq_attr *attr,
struct fid_cq **cq_fid, ofi_cq_progress_func progress,
void *context);

#endif // _OFI_COLL_H_
1 change: 1 addition & 0 deletions prov/coll/src/coll.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@
#include <ofi_hmem.h>
#include <ofi_prov.h>
#include <ofi_atomic.h>
#include <ofi_coll.h>

#define COLL_IOV_LIMIT 4
#define COLL_MR_MODES (OFI_MR_BASIC_MAP | FI_MR_LOCAL)
Expand Down
20 changes: 17 additions & 3 deletions prov/coll/src/coll_cq.c
Original file line number Diff line number Diff line change
Expand Up @@ -68,18 +68,32 @@ static struct fi_ops_cq coll_cq_ops = {

int coll_cq_open(struct fid_domain *domain, struct fi_cq_attr *attr,
struct fid_cq **cq_fid, void *context)
{
return coll_cq_init(domain, attr, cq_fid, &ofi_cq_progress, context);
}

int coll_cq_init(struct fid_domain *domain,
struct fi_cq_attr *attr, struct fid_cq **cq_fid,
ofi_cq_progress_func progress, void *context)
{
struct coll_cq *cq;
struct fi_peer_cq_context *peer_context = context;
int ret;

const struct coll_domain *coll_domain;
const struct fi_provider* provider;

coll_domain = container_of(domain, struct coll_domain, util_domain.domain_fid.fid);
provider = coll_domain->util_domain.fabric->prov;


if (!attr || !(attr->flags & FI_PEER)) {
FI_WARN(&coll_prov, FI_LOG_CORE, "FI_PEER flag required\n");
FI_WARN(provider, FI_LOG_CORE, "FI_PEER flag required\n");
return -EINVAL;
}

if (!peer_context || peer_context->size < sizeof(*peer_context)) {
FI_WARN(&coll_prov, FI_LOG_CORE, "invalid peer CQ context\n");
FI_WARN(provider, FI_LOG_CORE, "invalid peer CQ context\n");
return -EINVAL;
}

Expand All @@ -89,7 +103,7 @@ int coll_cq_open(struct fid_domain *domain, struct fi_cq_attr *attr,

cq->peer_cq = peer_context->cq;

ret = ofi_cq_init(&coll_prov, domain, attr, &cq->util_cq, &ofi_cq_progress,
ret = ofi_cq_init(provider, domain, attr, &cq->util_cq, &ofi_cq_progress,
context);
if (ret)
goto err;
Expand Down

0 comments on commit 6652138

Please sign in to comment.