Skip to content

Commit

Permalink
[v1.21.x] prov/efa: Remove unconditional assignment of err_entry
Browse files Browse the repository at this point in the history
Currently, efa_rdm_cq_poll_ibv_cq always assigns err_entry
as {0} at the beginning while err_entry is only used in the error path.
This unconditional assignment (88 bytes) caused additonal overhead
in the fast path. This patch fixes it by moving the assignment
of err_entry to the error path only

Signed-off-by: Shi Jin <[email protected]>
(cherry picked from commit 37e557e)
  • Loading branch information
shijin-aws authored and j-xiong committed Mar 29, 2024
1 parent 5cd3460 commit bbe793b
Showing 1 changed file with 6 additions and 4 deletions.
10 changes: 6 additions & 4 deletions prov/efa/src/rdm/efa_rdm_cq.c
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ void efa_rdm_cq_poll_ibv_cq(ssize_t cqe_to_process, struct efa_ibv_cq *ibv_cq)
size_t i = 0;
int prov_errno;
struct efa_rdm_ep *ep = NULL;
struct fi_cq_err_entry err_entry = {0};
struct fi_cq_err_entry err_entry;
struct efa_rdm_cq *efa_rdm_cq;

/* Call ibv_start_poll only once */
Expand Down Expand Up @@ -384,9 +384,11 @@ void efa_rdm_cq_poll_ibv_cq(ssize_t cqe_to_process, struct efa_ibv_cq *ibv_cq)
prov_errno = efa_rdm_cq_get_prov_errno(ibv_cq->ibv_cq_ex);
EFA_WARN(FI_LOG_CQ, "Unexpected error when polling ibv cq, err: %s (%zd) prov_errno: %s (%d)\n", fi_strerror(err), err, efa_strerror(prov_errno), prov_errno);
efa_show_help(prov_errno);
err_entry.err = err;
err_entry.prov_errno = prov_errno;
err_entry.op_context = NULL;
err_entry = (struct fi_cq_err_entry) {
.err = err,
.prov_errno = prov_errno,
.op_context = NULL
};
efa_rdm_cq = container_of(ibv_cq, struct efa_rdm_cq, ibv_cq);
ofi_cq_write_error(&efa_rdm_cq->util_cq, &err_entry);
}
Expand Down

0 comments on commit bbe793b

Please sign in to comment.