aboutsummaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python/libxed.py
diff options
context:
space:
mode:
authorBob Pearson <rpearsonhpe@gmail.com>2023-05-17 16:15:10 -0500
committerJason Gunthorpe <jgg@nvidia.com>2023-06-01 14:27:36 -0300
commitb00683422fd79dd07c9b75efdce1660e5e19150e (patch)
treecc0bfa5ae2a4fe27458d0affdeba25d2614eaeaf /tools/perf/scripts/python/libxed.py
parent9a3763e87379c97a78b7c6c6f40720b1e877174f (diff)
RDMA/rxe: Fix ref count error in check_rkey()
There is a reference count error in error path code and a potential race in check_rkey() in rxe_resp.c. When looking up the rkey for a memory window the reference to the mw from rxe_lookup_mw() is dropped before a reference is taken on the mr referenced by the mw. If the mr is destroyed immediately after the call to rxe_put(mw) the mr pointer is unprotected and may end up pointing at freed memory. The rxe_get(mr) call should take place before the rxe_put(mw) call. All errors in check_rkey() call rxe_put(mw) if mw is not NULL but it was already called after the above. The mw pointer should be set to NULL after the rxe_put(mw) call to prevent this from happening. Fixes: cdd0b85675ae ("RDMA/rxe: Implement memory access through MWs") Link: https://lore.kernel.org/r/20230517211509.1819998-1-rpearsonhpe@gmail.com Signed-off-by: Bob Pearson <rpearsonhpe@gmail.com> Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Diffstat (limited to 'tools/perf/scripts/python/libxed.py')
0 files changed, 0 insertions, 0 deletions