]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
x86/sgx: use vma_lookup() in sgx_encl_find()
authorLiam Howlett <liam.howlett@oracle.com>
Tue, 29 Jun 2021 02:39:14 +0000 (19:39 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Tue, 29 Jun 2021 17:53:51 +0000 (10:53 -0700)
Use vma_lookup() to find the VMA at a specific address.  As vma_lookup()
will return NULL if the address is not within any VMA, the start address
no longer needs to be validated.

Link: https://lkml.kernel.org/r/20210521174745.2219620-10-Liam.Howlett@Oracle.com
Signed-off-by: Liam R. Howlett <Liam.Howlett@Oracle.com>
Reviewed-by: Laurent Dufour <ldufour@linux.ibm.com>
Acked-by: David Hildenbrand <david@redhat.com>
Acked-by: Davidlohr Bueso <dbueso@suse.de>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
arch/x86/kernel/cpu/sgx/encl.h

index 6e74f85b626451752b0ec8a0b02f64bd77e232c4..fec43ca65065b0caecf5e05dd261c62cf045494e 100644 (file)
@@ -91,8 +91,8 @@ static inline int sgx_encl_find(struct mm_struct *mm, unsigned long addr,
 {
        struct vm_area_struct *result;
 
-       result = find_vma(mm, addr);
-       if (!result || result->vm_ops != &sgx_vm_ops || addr < result->vm_start)
+       result = vma_lookup(mm, addr);
+       if (!result || result->vm_ops != &sgx_vm_ops)
                return -EINVAL;
 
        *vma = result;