From 200febfcb37bc7da1664a3c267fd67b1ac1bce72 Mon Sep 17 00:00:00 2001 From: Jerome Soumagne Date: Fri, 11 Oct 2024 11:39:49 -0500 Subject: [PATCH] NA OFI: add support for FI_PROTO_CXI_RNR --- src/na/na_ofi.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/src/na/na_ofi.c b/src/na/na_ofi.c index 098ac8b6..e4705801 100644 --- a/src/na/na_ofi.c +++ b/src/na/na_ofi.c @@ -3463,7 +3463,23 @@ na_ofi_getinfo(enum na_ofi_prov_type prov_type, const struct na_ofi_info *info, na_ofi_prov_ep_proto[prov_type] <= FI_PROTO_UNSPEC, cleanup, ret, NA_PROTONOSUPPORT, "Unsupported endpoint protocol (%d)", na_ofi_prov_ep_proto[prov_type]); - hints->ep_attr->protocol = (uint32_t) na_ofi_prov_ep_proto[prov_type]; + +#if FI_VERSION_GE(FI_COMPILE_VERSION, FI_VERSION(1, 21)) + /* The FI_PROTO_CXI_RNR endpoint protocol is an optional protocol that + * targets client/server environments where send-after-send ordering + * is not required and messaging is generally to pre-posted buffers; + * FI_MULTI_RECV is recommended. It utilizes a receiver-not-ready + * implementation where FI_CXI_RNR_MAX_TIMEOUT_US can be tuned to + * control the maximum retry duration.*/ + if (FI_VERSION_GE(fi_version(), FI_VERSION(1, 21)) && + (prov_type == NA_OFI_PROV_CXI)) { + char *env = getenv("NA_OFI_CXI_PROTO_RNR"); + if (env == NULL || atoi(env) != 0) /* Enabled by default */ + hints->ep_attr->protocol = (uint32_t) FI_PROTO_CXI_RNR; + } else +#endif + hints->ep_attr->protocol = + (uint32_t) na_ofi_prov_ep_proto[prov_type]; /* add any additional caps that are particular to this provider */ hints->caps |= na_ofi_prov_extra_caps[prov_type];