projects
/
platform
/
kernel
/
linux-rpi.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
034e285
)
RDMA/rxe: Implement atomic write completion
author
Xiao Yang
<yangx.jy@fujitsu.com>
Thu, 1 Dec 2022 14:39:27 +0000
(14:39 +0000)
committer
Jason Gunthorpe
<jgg@nvidia.com>
Thu, 1 Dec 2022 23:51:10 +0000
(19:51 -0400)
Generate an atomic write completion when the atomic write request
has been finished.
Link:
https://lore.kernel.org/r/1669905568-62-3-git-send-email-yangx.jy@fujitsu.com
Signed-off-by: Xiao Yang <yangx.jy@fujitsu.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
drivers/infiniband/sw/rxe/rxe_comp.c
patch
|
blob
|
history
diff --git
a/drivers/infiniband/sw/rxe/rxe_comp.c
b/drivers/infiniband/sw/rxe/rxe_comp.c
index
4dca4f8
..
1c52532
100644
(file)
--- a/
drivers/infiniband/sw/rxe/rxe_comp.c
+++ b/
drivers/infiniband/sw/rxe/rxe_comp.c
@@
-104,6
+104,7
@@
static enum ib_wc_opcode wr_to_wc_opcode(enum ib_wr_opcode opcode)
case IB_WR_LOCAL_INV: return IB_WC_LOCAL_INV;
case IB_WR_REG_MR: return IB_WC_REG_MR;
case IB_WR_BIND_MW: return IB_WC_BIND_MW;
+ case IB_WR_ATOMIC_WRITE: return IB_WC_ATOMIC_WRITE;
default:
return 0xff;
@@
-269,6
+270,9
@@
static inline enum comp_state check_ack(struct rxe_qp *qp,
if ((syn & AETH_TYPE_MASK) != AETH_ACK)
return COMPST_ERROR;
+ if (wqe->wr.opcode == IB_WR_ATOMIC_WRITE)
+ return COMPST_WRITE_SEND;
+
fallthrough;
/* (IB_OPCODE_RC_RDMA_READ_RESPONSE_MIDDLE doesn't have an AETH)
*/