Skip to content

Commit

Permalink
Add support for SRD unsolicited write w/ imm. receive
Browse files Browse the repository at this point in the history
Add a new --unsolicited_write flag, available when using SRD with
supporting rdma-core version in write with immediate tests. When used,
receive WRs will not be posted.

Reviewed-by: Daniel Kranzdorf <[email protected]>
Reviewed-by: Yonatan Nachum <[email protected]>
Signed-off-by: Michael Margolin <[email protected]>
  • Loading branch information
mrgolin committed Aug 28, 2024
1 parent 279d92e commit ad2a685
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 10 deletions.
5 changes: 5 additions & 0 deletions configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -393,6 +393,11 @@ if [test $HAVE_IBV_WR_API = yes]; then
if [test $HAVE_RDMA_WRITE_SRD = yes]; then
AC_DEFINE([HAVE_SRD_WITH_RDMA_WRITE], [1], [Have SRD with RDMA write support])
fi
AC_TRY_LINK([#include <infiniband/efadv.h>],
[int x = EFADV_DEVICE_ATTR_CAPS_UNSOLICITED_WRITE_RECV;], [HAVE_UNSOLICITED_WRITE_RECV_SRD=yes], [HAVE_UNSOLICITED_WRITE_RECV_SRD=no])
if [test $HAVE_UNSOLICITED_WRITE_RECV_SRD = yes]; then
AC_DEFINE([HAVE_SRD_WITH_UNSOLICITED_WRITE_RECV], [1], [Have SRD with unsolicited RDMA write with imm. support])
fi
else
AC_CHECK_LIB([efa], [efadv_create_driver_qp], [HAVE_SRD=yes], [HAVE_SRD=no])
fi
Expand Down
33 changes: 32 additions & 1 deletion src/perftest_parameters.c
Original file line number Diff line number Diff line change
Expand Up @@ -645,7 +645,12 @@ static void usage(const char *argv0, VerbType verb, TestType tst, int connection

if ((tst == LAT || tst == BW) && verb == WRITE) {
printf(" --write_with_imm ");
printf(" use write-with-immediate verb instead of write\n");
printf(" Use write-with-immediate verb instead of write\n");

#ifdef HAVE_SRD_WITH_UNSOLICITED_WRITE_RECV
printf(" --unsolicited_write ");
printf(" Use unsolicited receive for write-with-immediate\n");
#endif
}

putchar('\n');
Expand Down Expand Up @@ -883,6 +888,7 @@ static void init_perftest_params(struct perftest_parameters *user_param)
user_param->source_ip = NULL;
user_param->has_source_ip = 0;
user_param->use_write_with_imm = 0;
user_param->use_unsolicited_write = 0;
user_param->congest_type = OFF;
user_param->no_lock = OFF;
}
Expand Down Expand Up @@ -1617,6 +1623,19 @@ static void force_dependecies(struct perftest_parameters *user_param)
user_param->cq_mod = 1;
}

if (user_param->use_unsolicited_write) {
if (user_param->connection_type != SRD) {
printf(RESULT_LINE);
fprintf(stderr, " Unsolicited write receive is supported only for SRD\n");
exit(1);
}
if (user_param->verb != WRITE_IMM) {
printf(RESULT_LINE);
fprintf(stderr, " Unsolicited write receive can only be used with write-with-immediate\n");
exit(1);
}
}

if ((user_param->use_srq && (user_param->tst == LAT || user_param->machine == SERVER || user_param->duplex == ON)) || user_param->use_xrc)
user_param->srq_exists = 1;

Expand Down Expand Up @@ -2323,6 +2342,9 @@ int parser(struct perftest_parameters *user_param,char *argv[], int argc)
static int recv_post_list_flag = 0;
static int payload_flag = 0;
static int use_write_with_imm_flag = 0;
#ifdef HAVE_SRD_WITH_UNSOLICITED_WRITE_RECV
static int unsolicited_write_flag = 0;
#endif
#ifdef HAVE_DCS
static int log_dci_streams_flag = 0;
static int log_active_dci_streams_flag = 0;
Expand Down Expand Up @@ -2506,6 +2528,9 @@ int parser(struct perftest_parameters *user_param,char *argv[], int argc)
#endif
{.name = "bind_source_ip", .has_arg = 1, .flag = &source_ip_flag, .val = 1},
{.name = "write_with_imm", .has_arg = 0, .flag = &use_write_with_imm_flag, .val = 1 },
#ifdef HAVE_SRD_WITH_UNSOLICITED_WRITE_RECV
{.name = "unsolicited_write", .has_arg = 0, .flag = &unsolicited_write_flag, .val = 1 },
#endif
{0}
};
if (!duplicates_checker) {
Expand Down Expand Up @@ -3146,6 +3171,12 @@ int parser(struct perftest_parameters *user_param,char *argv[], int argc)
user_param->verb = WRITE_IMM;
use_write_with_imm_flag = 0;
}
#ifdef HAVE_SRD_WITH_UNSOLICITED_WRITE_RECV
if (unsolicited_write_flag) {
user_param->use_unsolicited_write = 1;
unsolicited_write_flag = 0;
}
#endif
break;
default:
fprintf(stderr," Invalid Command or flag.\n");
Expand Down
1 change: 1 addition & 0 deletions src/perftest_parameters.h
Original file line number Diff line number Diff line change
Expand Up @@ -639,6 +639,7 @@ struct perftest_parameters {
int has_source_ip;
int ah_allocated;
int use_write_with_imm;
int use_unsolicited_write;
};

struct report_options {
Expand Down
13 changes: 9 additions & 4 deletions src/perftest_resources.c
Original file line number Diff line number Diff line change
Expand Up @@ -2431,6 +2431,10 @@ struct ibv_qp* ctx_qp_create(struct pingpong_context *ctx,
#ifdef HAVE_SRD
#ifdef HAVE_IBV_WR_API
efa_attr.driver_qp_type = EFADV_QP_DRIVER_TYPE_SRD;
#ifdef HAVE_SRD_WITH_UNSOLICITED_WRITE_RECV
if (user_param->use_unsolicited_write)
efa_attr.flags |= EFADV_QP_FLAGS_UNSOLICITED_WRITE_RECV;
#endif
qp = efadv_create_qp_ex(ctx->context, &attr_ex,
&efa_attr, sizeof(efa_attr));
#else
Expand Down Expand Up @@ -3797,7 +3801,7 @@ int run_iter_bw_server(struct pingpong_context *ctx, struct perftest_parameters
}
//coverity[uninit_use]
if ((user_param->test_type==DURATION || posted_per_qp[wc_id] + user_param->recv_post_list <= user_param->iters) &&
unused_recv_for_qp[wc_id] >= user_param->recv_post_list) {
unused_recv_for_qp[wc_id] >= user_param->recv_post_list && !user_param->use_unsolicited_write) {
if (user_param->use_srq) {
if (ibv_post_srq_recv(ctx->srq, &ctx->rwr[wc_id * user_param->recv_post_list], &bad_wr_recv)) {
fprintf(stderr, "Couldn't post recv SRQ. QP = %d: counter=%lu\n", wc_id,rcnt);
Expand Down Expand Up @@ -4084,7 +4088,7 @@ int run_iter_bw_infinitely_server(struct pingpong_context *ctx, struct perftest_
}
user_param->iters++;
unused_recv_for_qp[wc[i].wr_id]++;
if (unused_recv_for_qp[wc[i].wr_id] >= user_param->recv_post_list) {
if (unused_recv_for_qp[wc[i].wr_id] >= user_param->recv_post_list && !user_param->use_unsolicited_write) {
if (user_param->use_srq) {
if (ibv_post_srq_recv(ctx->srq, &ctx->rwr[wc[i].wr_id * user_param->recv_post_list],&bad_wr_recv)) {
fprintf(stderr, "Couldn't post recv SRQ. QP = %d:\n",(int)wc[i].wr_id);
Expand Down Expand Up @@ -4338,7 +4342,7 @@ int run_iter_bi(struct pingpong_context *ctx,
}

if ((user_param->test_type==DURATION || posted_per_qp[wc[i].wr_id] + user_param->recv_post_list <= user_param->iters) &&
unused_recv_for_qp[wc[i].wr_id] >= user_param->recv_post_list) {
unused_recv_for_qp[wc[i].wr_id] >= user_param->recv_post_list && !user_param->use_unsolicited_write) {
if (user_param->use_srq) {
if (ibv_post_srq_recv(ctx->srq, &ctx->rwr[wc[i].wr_id * user_param->recv_post_list],&bad_wr_recv)) {
fprintf(stderr, "Couldn't post recv SRQ. QP = %d: counter=%d\n",(int)wc[i].wr_id,(int)totrcnt);
Expand Down Expand Up @@ -4682,7 +4686,8 @@ int run_iter_lat_write_imm(struct pingpong_context *ctx,struct perftest_paramete
* is enough space in the rx_depth,
* post that you received a packet.
*/
if (user_param->test_type == DURATION || (rcnt + size_per_qp <= user_param->iters)) {
if ((user_param->test_type == DURATION || (rcnt + size_per_qp <= user_param->iters)) &&
!user_param->use_unsolicited_write) {
if (user_param->use_srq) {
if (ibv_post_srq_recv(ctx->srq, &ctx->rwr[wc.wr_id], &bad_wr_recv)) {
fprintf(stderr, "Couldn't post recv SRQ. QP = %d: counter=%lu\n",(int)wc.wr_id, rcnt);
Expand Down
3 changes: 2 additions & 1 deletion src/write_bw.c
Original file line number Diff line number Diff line change
Expand Up @@ -301,7 +301,8 @@ int main(int argc, char *argv[])
if (user_param.machine == CLIENT || user_param.duplex)
ctx_set_send_wqes(&ctx,&user_param,rem_dest);

if (user_param.verb == WRITE_IMM && (user_param.machine == SERVER || user_param.duplex)) {
if (user_param.verb == WRITE_IMM && !user_param.use_unsolicited_write &&
(user_param.machine == SERVER || user_param.duplex)) {
if (ctx_set_recv_wqes(&ctx,&user_param)) {
fprintf(stderr," Failed to post receive recv_wqes\n");
goto free_mem;
Expand Down
10 changes: 6 additions & 4 deletions src/write_lat.c
Original file line number Diff line number Diff line change
Expand Up @@ -262,10 +262,12 @@ int main(int argc, char *argv[])
user_param.size = (uint64_t)1 << i;

if (user_param.verb == WRITE_IMM) {
/* Post receive recv_wqes fo current message size */
if (ctx_set_recv_wqes(&ctx,&user_param)) {
fprintf(stderr," Failed to post receive recv_wqes\n");
goto free_mem;
if (!user_param.use_unsolicited_write) {
/* Post receive recv_wqes fo current message size */
if (ctx_set_recv_wqes(&ctx,&user_param)) {
fprintf(stderr," Failed to post receive recv_wqes\n");
goto free_mem;
}
}

/* Sync between the client and server so the client won't send packets
Expand Down

0 comments on commit ad2a685

Please sign in to comment.