RDMA/rxe: Fix rxe_cq_post
authorBob Pearson <rpearsonhpe@gmail.com>
Mon, 12 Jun 2023 15:50:33 +0000 (10:50 -0500)
committerJason Gunthorpe <jgg@nvidia.com>
Wed, 14 Jun 2023 17:12:43 +0000 (14:12 -0300)
commit0c7e314a6352664e12ec465f576cf039e95f8369
tree28257ed5f3ab9a30e2c949c66960150790032ba6
parent699826f4e30ab76a62c238c86fbef7e826639c8d
RDMA/rxe: Fix rxe_cq_post

A recent patch replaced a tasklet execution of cq->comp_handler by a
direct call. While this made sense it let changes to cq->notify state be
unprotected and assumed that the cq completion machinery and the ulp done
callbacks were reentrant. The result is that in some cases completion
events can be lost. This patch moves the cq->comp_handler call inside of
the spinlock in rxe_cq_post which solves both issues. This is compatible
with the matching code in the request notify verb.

Fixes: 78b26a335310 ("RDMA/rxe: Remove tasklet call from rxe_cq.c")
Link: https://lore.kernel.org/r/20230612155032.17036-1-rpearsonhpe@gmail.com
Signed-off-by: Bob Pearson <rpearsonhpe@gmail.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
drivers/infiniband/sw/rxe/rxe_cq.c