diff options
author | Kuehling, Felix <Felix.Kuehling@amd.com> | 2019-05-10 19:53:24 +0000 |
---|---|---|
committer | Jason Gunthorpe <jgg@mellanox.com> | 2019-06-06 16:31:41 -0300 |
commit | 9b1ae605c8e295836050fa6eaf720131db2fac73 (patch) | |
tree | b2ac18bc0976f6267bce953fc0f826dc104821d0 /mm/hmm.c | |
parent | 789c2af88f24d1db983aae49b5c4561e6e02ff5b (diff) | |
download | lwn-9b1ae605c8e295836050fa6eaf720131db2fac73.tar.gz lwn-9b1ae605c8e295836050fa6eaf720131db2fac73.zip |
mm/hmm: Only set FAULT_FLAG_ALLOW_RETRY for non-blocking
Don't set this flag by default in hmm_vma_do_fault. It is set
conditionally just a few lines below. Setting it unconditionally can lead
to handle_mm_fault doing a non-blocking fault, returning -EBUSY and
unlocking mmap_sem unexpectedly.
Signed-off-by: Felix Kuehling <Felix.Kuehling@amd.com>
Reviewed-by: Jérôme Glisse <jglisse@redhat.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Diffstat (limited to 'mm/hmm.c')
-rw-r--r-- | mm/hmm.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -328,7 +328,7 @@ struct hmm_vma_walk { static int hmm_vma_do_fault(struct mm_walk *walk, unsigned long addr, bool write_fault, uint64_t *pfn) { - unsigned int flags = FAULT_FLAG_ALLOW_RETRY | FAULT_FLAG_REMOTE; + unsigned int flags = FAULT_FLAG_REMOTE; struct hmm_vma_walk *hmm_vma_walk = walk->private; struct hmm_range *range = hmm_vma_walk->range; struct vm_area_struct *vma = walk->vma; |