Skip to content

Commit

Permalink
prov/efa: Use tclass to prioritize the messages from an ep
Browse files Browse the repository at this point in the history
To prioritize the messages from a given endpoint, user can specify `
fi_info->tx_attr->tclass = FI_TC_LOW_LATENCY` in the fi_endpoint()
call to set the service level in rdma-core. All other tclass values
will be ignored.

Signed-off-by: Jessie Yang <[email protected]>
  • Loading branch information
jiaxiyan committed Sep 26, 2024
1 parent 16a4445 commit fc93978
Show file tree
Hide file tree
Showing 5 changed files with 27 additions and 5 deletions.
2 changes: 2 additions & 0 deletions man/fi_efa.7.md
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,8 @@ struct fi_efa_mr_attr {
**query_mr()** returns 0 on success, or the value of errno on failure
(which indicates the failure reason).

# Traffic Class (tclass) in EFA
To prioritize the messages from a given endpoint, user can specify `fi_info->tx_attr->tclass = FI_TC_LOW_LATENCY` in the fi_endpoint() call to set the service level in rdma-core. All other tclass values will be ignored.

# RUNTIME PARAMETERS

Expand Down
9 changes: 9 additions & 0 deletions prov/efa/configure.m4
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,7 @@ AC_DEFUN([FI_EFA_CONFIGURE],[
efadv_support_extended_cq=0
have_efa_dmabuf_mr=0
have_efadv_query_mr=0
have_efadv_sl=0
dnl $have_neuron is defined at top-level configure.ac
AM_CONDITIONAL([HAVE_NEURON], [ test x"$have_neuron" = x1 ])
Expand Down Expand Up @@ -159,6 +160,11 @@ AC_DEFUN([FI_EFA_CONFIGURE],[
[],
[have_efadv_query_mr=0],
[[#include <infiniband/efadv.h>]])
AC_CHECK_MEMBER(struct efadv_qp_init_attr.sl,
[have_efadv_sl=1],
[have_efadv_sl=0],
[[#include <infiniband/efadv.h>]])
])
AC_DEFINE_UNQUOTED([HAVE_RDMA_SIZE],
Expand Down Expand Up @@ -188,6 +194,9 @@ AC_DEFUN([FI_EFA_CONFIGURE],[
AC_DEFINE_UNQUOTED([HAVE_EFADV_QUERY_MR],
[$have_efadv_query_mr],
[Indicates if efadv_query_mr verbs is available])
AC_DEFINE_UNQUOTED([HAVE_EFADV_SL],
[$have_efadv_sl],
[Indicates if efadv_qp_init_attr has sl])
CPPFLAGS=$save_CPPFLAGS
Expand Down
8 changes: 6 additions & 2 deletions prov/efa/src/efa_base_ep.c
Original file line number Diff line number Diff line change
Expand Up @@ -167,7 +167,7 @@ static int efa_base_ep_modify_qp_rst2rts(struct efa_base_ep *base_ep,
* @param init_attr_ex ibv_qp_init_attr_ex
* @return int 0 on success, negative integer on failure
*/
int efa_qp_create(struct efa_qp **qp, struct ibv_qp_init_attr_ex *init_attr_ex)
int efa_qp_create(struct efa_qp **qp, struct ibv_qp_init_attr_ex *init_attr_ex, uint32_t tclass)
{
struct efadv_qp_init_attr efa_attr = { 0 };

Expand All @@ -185,6 +185,10 @@ int efa_qp_create(struct efa_qp **qp, struct ibv_qp_init_attr_ex *init_attr_ex)
efa_attr.flags |= EFADV_QP_FLAGS_UNSOLICITED_WRITE_RECV;
#endif
efa_attr.driver_qp_type = EFADV_QP_DRIVER_TYPE_SRD;
#if HAVE_EFADV_SL
if (tclass == FI_TC_LOW_LATENCY)
efa_attr.sl = SL_8;
#endif
(*qp)->ibv_qp = efadv_create_qp_ex(
init_attr_ex->pd->context, init_attr_ex, &efa_attr,
sizeof(struct efadv_qp_init_attr));
Expand All @@ -206,7 +210,7 @@ int efa_base_ep_create_qp(struct efa_base_ep *base_ep,
{
int ret;

ret = efa_qp_create(&base_ep->qp, init_attr_ex);
ret = efa_qp_create(&base_ep->qp, init_attr_ex, base_ep->info->tx_attr->tclass);
if (ret)
return ret;

Expand Down
9 changes: 8 additions & 1 deletion prov/efa/src/efa_base_ep.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,13 @@
#include "ofi_util.h"
#include "rdm/efa_rdm_protocol.h"

#if HAVE_EFADV_SL
enum efa_qp_service_level {
SL_0 = 0,
SL_8 = 8,
};
#endif

struct efa_qp {
struct ibv_qp *ibv_qp;
struct ibv_qp_ex *ibv_qp_ex;
Expand Down Expand Up @@ -72,7 +79,7 @@ int efa_base_ep_construct(struct efa_base_ep *base_ep,

int efa_base_ep_getname(fid_t fid, void *addr, size_t *addrlen);

int efa_qp_create(struct efa_qp **qp, struct ibv_qp_init_attr_ex *init_attr_ex);
int efa_qp_create(struct efa_qp **qp, struct ibv_qp_init_attr_ex *init_attr_ex, uint32_t tclass);

void efa_qp_destruct(struct efa_qp *qp);

Expand Down
4 changes: 2 additions & 2 deletions prov/efa/src/rdm/efa_rdm_ep_fiops.c
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ int efa_rdm_ep_create_base_ep_ibv_qp(struct efa_rdm_ep *ep)
* without any headers.
*/
if (ep->use_zcpy_rx) {
ret = efa_qp_create(&ep->base_ep.user_recv_qp, &attr_ex);
ret = efa_qp_create(&ep->base_ep.user_recv_qp, &attr_ex, ep->base_ep.info->tx_attr->tclass);
if (ret) {
efa_base_ep_destruct_qp(&ep->base_ep);
return ret;
Expand Down Expand Up @@ -1646,7 +1646,7 @@ int efa_rdm_ep_check_qp_in_order_aligned_128_bytes(struct efa_rdm_ep *ep,
/* Create a dummy qp for query only */
efa_rdm_ep_construct_ibv_qp_init_attr_ex(ep, &attr_ex, ibv_cq_ex, ibv_cq_ex);

ret = efa_qp_create(&qp, &attr_ex);
ret = efa_qp_create(&qp, &attr_ex, FI_TC_UNSPEC);
if (ret)
goto out;

Expand Down

0 comments on commit fc93978

Please sign in to comment.