mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-18 19:05:39 +00:00
optee: remove vma linked list walk
Use the VMA iterator instead. Change the calling convention of __check_mem_type() to pass in the mm instead of the first vma in the range. Link: https://lkml.kernel.org/r/20220906194824.2110408-39-Liam.Howlett@oracle.com Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org> Signed-off-by: Liam R. Howlett <Liam.Howlett@Oracle.com> Acked-by: Vlastimil Babka <vbabka@suse.cz> Reviewed-by: Davidlohr Bueso <dave@stgolabs.net> Tested-by: Yu Zhao <yuzhao@google.com> Cc: Catalin Marinas <catalin.marinas@arm.com> Cc: David Hildenbrand <david@redhat.com> Cc: David Howells <dhowells@redhat.com> Cc: SeongJae Park <sj@kernel.org> Cc: Sven Schnelle <svens@linux.ibm.com> Cc: Will Deacon <will@kernel.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
parent
d9fa0e37cd
commit
df724cedcf
@ -492,15 +492,18 @@ static bool is_normal_memory(pgprot_t p)
|
||||
#endif
|
||||
}
|
||||
|
||||
static int __check_mem_type(struct vm_area_struct *vma, unsigned long end)
|
||||
static int __check_mem_type(struct mm_struct *mm, unsigned long start,
|
||||
unsigned long end)
|
||||
{
|
||||
while (vma && is_normal_memory(vma->vm_page_prot)) {
|
||||
if (vma->vm_end >= end)
|
||||
return 0;
|
||||
vma = vma->vm_next;
|
||||
struct vm_area_struct *vma;
|
||||
VMA_ITERATOR(vmi, mm, start);
|
||||
|
||||
for_each_vma_range(vmi, vma, end) {
|
||||
if (!is_normal_memory(vma->vm_page_prot))
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return -EINVAL;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int optee_check_mem_type(unsigned long start, size_t num_pages)
|
||||
@ -516,8 +519,7 @@ int optee_check_mem_type(unsigned long start, size_t num_pages)
|
||||
return 0;
|
||||
|
||||
mmap_read_lock(mm);
|
||||
rc = __check_mem_type(find_vma(mm, start),
|
||||
start + num_pages * PAGE_SIZE);
|
||||
rc = __check_mem_type(mm, start, start + num_pages * PAGE_SIZE);
|
||||
mmap_read_unlock(mm);
|
||||
|
||||
return rc;
|
||||
|
Loading…
x
Reference in New Issue
Block a user