summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorRalph Campbell <rcampbell@nvidia.com>2019-11-04 23:21:40 +0100
committerJason Gunthorpe <jgg@mellanox.com>2019-11-24 00:56:45 +0100
commitd28c2c9a487708b9db519ce7fedc10333032c76b (patch)
tree651d078ef9d500fb46c53f66577f1bac8f9dcee7 /include
parentxen/gntdev: use mmu_interval_notifier_insert (diff)
downloadlinux-d28c2c9a487708b9db519ce7fedc10333032c76b.tar.xz
linux-d28c2c9a487708b9db519ce7fedc10333032c76b.zip
mm/hmm: make full use of walk_page_range()
hmm_range_fault() calls find_vma() and walk_page_range() in a loop. This is unnecessary duplication since walk_page_range() calls find_vma() in a loop already. Simplify hmm_range_fault() by defining a walk_test() callback function to filter unhandled vmas. This also fixes a bug where hmm_range_fault() was not checking start >= vma->vm_start before checking vma->vm_flags so hmm_range_fault() could return an error based on the wrong vma for the requested range. It also fixes a bug when the vma has no read access and the caller did not request a fault, there shouldn't be any error return code. Link: https://lore.kernel.org/r/20191104222141.5173-2-rcampbell@nvidia.com Signed-off-by: Ralph Campbell <rcampbell@nvidia.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Jason Gunthorpe <jgg@mellanox.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Diffstat (limited to 'include')
0 files changed, 0 insertions, 0 deletions