Commit 8537f2de authored by Jack Wang's avatar Jack Wang Committed by Jason Gunthorpe

RDMA/rtrs-srv: Fix missing wr_cqe

We had a few places wr_cqe is not set, which could lead to NULL pointer
deref or GPF in error case.

Fixes: 9cb83748 ("RDMA/rtrs: server: main functionality")
Link: https://lore.kernel.org/r/20201217141915.56989-14-jinpu.wang@cloud.ionos.comSigned-off-by: default avatarJack Wang <jinpu.wang@cloud.ionos.com>
Reviewed-by: default avatarMd Haris Iqbal <haris.iqbal@cloud.ionos.com>
Signed-off-by: default avatarGuoqing Jiang <guoqing.jiang@cloud.ionos.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@nvidia.com>
parent 7a8732a6
...@@ -267,6 +267,7 @@ static int rdma_write_sg(struct rtrs_srv_op *id) ...@@ -267,6 +267,7 @@ static int rdma_write_sg(struct rtrs_srv_op *id)
WARN_ON_ONCE(rkey != wr->rkey); WARN_ON_ONCE(rkey != wr->rkey);
wr->wr.opcode = IB_WR_RDMA_WRITE; wr->wr.opcode = IB_WR_RDMA_WRITE;
wr->wr.wr_cqe = &io_comp_cqe;
wr->wr.ex.imm_data = 0; wr->wr.ex.imm_data = 0;
wr->wr.send_flags = 0; wr->wr.send_flags = 0;
...@@ -294,6 +295,7 @@ static int rdma_write_sg(struct rtrs_srv_op *id) ...@@ -294,6 +295,7 @@ static int rdma_write_sg(struct rtrs_srv_op *id)
inv_wr.sg_list = NULL; inv_wr.sg_list = NULL;
inv_wr.num_sge = 0; inv_wr.num_sge = 0;
inv_wr.opcode = IB_WR_SEND_WITH_INV; inv_wr.opcode = IB_WR_SEND_WITH_INV;
inv_wr.wr_cqe = &io_comp_cqe;
inv_wr.send_flags = 0; inv_wr.send_flags = 0;
inv_wr.ex.invalidate_rkey = rkey; inv_wr.ex.invalidate_rkey = rkey;
} }
...@@ -304,6 +306,7 @@ static int rdma_write_sg(struct rtrs_srv_op *id) ...@@ -304,6 +306,7 @@ static int rdma_write_sg(struct rtrs_srv_op *id)
srv_mr = &sess->mrs[id->msg_id]; srv_mr = &sess->mrs[id->msg_id];
rwr.wr.opcode = IB_WR_REG_MR; rwr.wr.opcode = IB_WR_REG_MR;
rwr.wr.wr_cqe = &local_reg_cqe;
rwr.wr.num_sge = 0; rwr.wr.num_sge = 0;
rwr.mr = srv_mr->mr; rwr.mr = srv_mr->mr;
rwr.wr.send_flags = 0; rwr.wr.send_flags = 0;
...@@ -379,6 +382,7 @@ static int send_io_resp_imm(struct rtrs_srv_con *con, struct rtrs_srv_op *id, ...@@ -379,6 +382,7 @@ static int send_io_resp_imm(struct rtrs_srv_con *con, struct rtrs_srv_op *id,
if (need_inval) { if (need_inval) {
if (likely(sg_cnt)) { if (likely(sg_cnt)) {
inv_wr.wr_cqe = &io_comp_cqe;
inv_wr.sg_list = NULL; inv_wr.sg_list = NULL;
inv_wr.num_sge = 0; inv_wr.num_sge = 0;
inv_wr.opcode = IB_WR_SEND_WITH_INV; inv_wr.opcode = IB_WR_SEND_WITH_INV;
...@@ -421,6 +425,7 @@ static int send_io_resp_imm(struct rtrs_srv_con *con, struct rtrs_srv_op *id, ...@@ -421,6 +425,7 @@ static int send_io_resp_imm(struct rtrs_srv_con *con, struct rtrs_srv_op *id,
srv_mr = &sess->mrs[id->msg_id]; srv_mr = &sess->mrs[id->msg_id];
rwr.wr.next = &imm_wr; rwr.wr.next = &imm_wr;
rwr.wr.opcode = IB_WR_REG_MR; rwr.wr.opcode = IB_WR_REG_MR;
rwr.wr.wr_cqe = &local_reg_cqe;
rwr.wr.num_sge = 0; rwr.wr.num_sge = 0;
rwr.wr.send_flags = 0; rwr.wr.send_flags = 0;
rwr.mr = srv_mr->mr; rwr.mr = srv_mr->mr;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment