diff options
author | Jason Gunthorpe <jgg@mellanox.com> | 2020-02-27 14:41:18 +0300 |
---|---|---|
committer | Jason Gunthorpe <jgg@mellanox.com> | 2020-03-04 20:56:07 +0300 |
commit | a4e63bce1414df7ab6eb82ca9feb8494ce13e554 (patch) | |
tree | 29db5367405979d5c353761fec56209161a1001a /tools/perf/scripts/python/export-to-sqlite.py | |
parent | e38b55ea0443da35a50a3eb2079ad3612cf763b9 (diff) | |
download | linux-a4e63bce1414df7ab6eb82ca9feb8494ce13e554.tar.xz |
RDMA/odp: Ensure the mm is still alive before creating an implicit child
Registration of a mmu_notifier requires the caller to hold a mmget() on
the mm as registration is not permitted to race with exit_mmap(). There is
a BUG_ON inside the mmu_notifier to guard against this.
Normally creating a umem is done against current which implicitly holds
the mmget(), however an implicit ODP child is created from a pagefault
work queue and is not guaranteed to have a mmget().
Call mmget() around this registration and abort faulting if the MM has
gone to exit_mmap().
Before the patch below the notifier was registered when the implicit ODP
parent was created, so there was no chance to register a notifier outside
of current.
Fixes: c571feca2dc9 ("RDMA/odp: use mmu_notifier_get/put for 'struct ib_ucontext_per_mm'")
Link: https://lore.kernel.org/r/20200227114118.94736-1-leon@kernel.org
Signed-off-by: Leon Romanovsky <leonro@mellanox.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Diffstat (limited to 'tools/perf/scripts/python/export-to-sqlite.py')
0 files changed, 0 insertions, 0 deletions