]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
RDMA/rxe: Prevent access to wr->next ptr afrer wr is posted to send queue
authorMikhail Malygin <m.malygin@yadro.com>
Thu, 16 Jul 2020 19:03:41 +0000 (22:03 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 19 Aug 2020 06:23:54 +0000 (08:23 +0200)
commit6e1ab3bf6ad3e4b88f6ca91ff1d137b98f3dddb8
treea8d63bbab0ae9c9a38295a75d3404bdb804cea4d
parent808124cb5c3801e7cf75d51cdfbec801241c19e5
RDMA/rxe: Prevent access to wr->next ptr afrer wr is posted to send queue

[ Upstream commit 5f0b2a6093a4d9aab093964c65083fe801ef1e58 ]

rxe_post_send_kernel() iterates over linked list of wr's, until the
wr->next ptr is NULL.  However if we've got an interrupt after last wr is
posted, control may be returned to the code after send completion callback
is executed and wr memory is freed.

As a result, wr->next pointer may contain incorrect value leading to
panic. Store the wr->next on the stack before posting it.

Fixes: 8700e3e7c485 ("Soft RoCE driver")
Link: https://lore.kernel.org/r/20200716190340.23453-1-m.malygin@yadro.com
Signed-off-by: Mikhail Malygin <m.malygin@yadro.com>
Signed-off-by: Sergey Kojushev <s.kojushev@yadro.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/infiniband/sw/rxe/rxe_verbs.c