mirror of https://gitee.com/openkylin/linux.git
mm/vma: make vma_is_accessible() available for general use
Lets move vma_is_accessible() helper to include/linux/mm.h which makes it available for general use. While here, this replaces all remaining open encodings for VMA access check with vma_is_accessible(). Signed-off-by: Anshuman Khandual <anshuman.khandual@arm.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Acked-by: Geert Uytterhoeven <geert@linux-m68k.org> Acked-by: Guo Ren <guoren@kernel.org> Acked-by: Vlastimil Babka <vbabka@suse.cz> Cc: Guo Ren <guoren@kernel.org> Cc: Geert Uytterhoeven <geert@linux-m68k.org> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Paul Burton <paulburton@kernel.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Yoshinori Sato <ysato@users.sourceforge.jp> Cc: Rich Felker <dalias@libc.org> Cc: Dave Hansen <dave.hansen@linux.intel.com> Cc: Andy Lutomirski <luto@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Ingo Molnar <mingo@redhat.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Mel Gorman <mgorman@suse.de> Cc: Alexander Viro <viro@zeniv.linux.org.uk> Cc: "Aneesh Kumar K.V" <aneesh.kumar@linux.ibm.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Nick Piggin <npiggin@gmail.com> Cc: Paul Mackerras <paulus@ozlabs.org> Cc: Will Deacon <will@kernel.org> Link: http://lkml.kernel.org/r/1582520593-30704-3-git-send-email-anshuman.khandual@arm.com Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
7e96fb5710
commit
3122e80efc
|
@ -141,7 +141,7 @@ asmlinkage void do_page_fault(struct pt_regs *regs, unsigned long write,
|
||||||
if (!(vma->vm_flags & VM_WRITE))
|
if (!(vma->vm_flags & VM_WRITE))
|
||||||
goto bad_area;
|
goto bad_area;
|
||||||
} else {
|
} else {
|
||||||
if (!(vma->vm_flags & (VM_READ | VM_WRITE | VM_EXEC)))
|
if (!vma_is_accessible(vma))
|
||||||
goto bad_area;
|
goto bad_area;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -125,7 +125,7 @@ int do_page_fault(struct pt_regs *regs, unsigned long address,
|
||||||
case 1: /* read, present */
|
case 1: /* read, present */
|
||||||
goto acc_err;
|
goto acc_err;
|
||||||
case 0: /* read, not present */
|
case 0: /* read, not present */
|
||||||
if (!(vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE)))
|
if (!vma_is_accessible(vma))
|
||||||
goto acc_err;
|
goto acc_err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -142,7 +142,7 @@ static void __kprobes __do_page_fault(struct pt_regs *regs, unsigned long write,
|
||||||
goto bad_area;
|
goto bad_area;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (!(vma->vm_flags & (VM_READ | VM_WRITE | VM_EXEC)))
|
if (!vma_is_accessible(vma))
|
||||||
goto bad_area;
|
goto bad_area;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -314,7 +314,7 @@ static bool access_error(bool is_write, bool is_exec,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlikely(!(vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE))))
|
if (unlikely(!vma_is_accessible(vma)))
|
||||||
return true;
|
return true;
|
||||||
/*
|
/*
|
||||||
* We should ideally do the vma pkey access check here. But in the
|
* We should ideally do the vma pkey access check here. But in the
|
||||||
|
|
|
@ -355,7 +355,7 @@ static inline int access_error(int error_code, struct vm_area_struct *vma)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
/* read, not present: */
|
/* read, not present: */
|
||||||
if (unlikely(!(vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE))))
|
if (unlikely(!vma_is_accessible(vma)))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -1222,7 +1222,7 @@ access_error(unsigned long error_code, struct vm_area_struct *vma)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
/* read, not present: */
|
/* read, not present: */
|
||||||
if (unlikely(!(vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE))))
|
if (unlikely(!vma_is_accessible(vma)))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -629,6 +629,12 @@ static inline bool vma_is_foreign(struct vm_area_struct *vma)
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline bool vma_is_accessible(struct vm_area_struct *vma)
|
||||||
|
{
|
||||||
|
return vma->vm_flags & (VM_READ | VM_WRITE | VM_EXEC);
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_SHMEM
|
#ifdef CONFIG_SHMEM
|
||||||
/*
|
/*
|
||||||
* The vma_is_shmem is not inline because it is used only by slow
|
* The vma_is_shmem is not inline because it is used only by slow
|
||||||
|
|
|
@ -2799,7 +2799,7 @@ static void task_numa_work(struct callback_head *work)
|
||||||
* Skip inaccessible VMAs to avoid any confusion between
|
* Skip inaccessible VMAs to avoid any confusion between
|
||||||
* PROT_NONE and NUMA hinting ptes
|
* PROT_NONE and NUMA hinting ptes
|
||||||
*/
|
*/
|
||||||
if (!(vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE)))
|
if (!vma_is_accessible(vma))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
|
2
mm/gup.c
2
mm/gup.c
|
@ -1416,7 +1416,7 @@ long populate_vma_page_range(struct vm_area_struct *vma,
|
||||||
* We want mlock to succeed for regions that have any permissions
|
* We want mlock to succeed for regions that have any permissions
|
||||||
* other than PROT_NONE.
|
* other than PROT_NONE.
|
||||||
*/
|
*/
|
||||||
if (vma->vm_flags & (VM_READ | VM_WRITE | VM_EXEC))
|
if (vma_is_accessible(vma))
|
||||||
gup_flags |= FOLL_FORCE;
|
gup_flags |= FOLL_FORCE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -3964,11 +3964,6 @@ static inline vm_fault_t wp_huge_pmd(struct vm_fault *vmf, pmd_t orig_pmd)
|
||||||
return VM_FAULT_FALLBACK;
|
return VM_FAULT_FALLBACK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline bool vma_is_accessible(struct vm_area_struct *vma)
|
|
||||||
{
|
|
||||||
return vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE);
|
|
||||||
}
|
|
||||||
|
|
||||||
static vm_fault_t create_huge_pud(struct vm_fault *vmf)
|
static vm_fault_t create_huge_pud(struct vm_fault *vmf)
|
||||||
{
|
{
|
||||||
#if defined(CONFIG_TRANSPARENT_HUGEPAGE) && \
|
#if defined(CONFIG_TRANSPARENT_HUGEPAGE) && \
|
||||||
|
|
|
@ -678,8 +678,7 @@ static int queue_pages_test_walk(unsigned long start, unsigned long end,
|
||||||
|
|
||||||
if (flags & MPOL_MF_LAZY) {
|
if (flags & MPOL_MF_LAZY) {
|
||||||
/* Similar to task_numa_work, skip inaccessible VMAs */
|
/* Similar to task_numa_work, skip inaccessible VMAs */
|
||||||
if (!is_vm_hugetlb_page(vma) &&
|
if (!is_vm_hugetlb_page(vma) && vma_is_accessible(vma) &&
|
||||||
(vma->vm_flags & (VM_READ | VM_EXEC | VM_WRITE)) &&
|
|
||||||
!(vma->vm_flags & VM_MIXEDMAP))
|
!(vma->vm_flags & VM_MIXEDMAP))
|
||||||
change_prot_numa(vma, start, endvma);
|
change_prot_numa(vma, start, endvma);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
|
@ -2358,8 +2358,7 @@ int expand_upwards(struct vm_area_struct *vma, unsigned long address)
|
||||||
gap_addr = TASK_SIZE;
|
gap_addr = TASK_SIZE;
|
||||||
|
|
||||||
next = vma->vm_next;
|
next = vma->vm_next;
|
||||||
if (next && next->vm_start < gap_addr &&
|
if (next && next->vm_start < gap_addr && vma_is_accessible(next)) {
|
||||||
(next->vm_flags & (VM_WRITE|VM_READ|VM_EXEC))) {
|
|
||||||
if (!(next->vm_flags & VM_GROWSUP))
|
if (!(next->vm_flags & VM_GROWSUP))
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
/* Check that both stack segments have the same anon_vma? */
|
/* Check that both stack segments have the same anon_vma? */
|
||||||
|
@ -2440,7 +2439,7 @@ int expand_downwards(struct vm_area_struct *vma,
|
||||||
prev = vma->vm_prev;
|
prev = vma->vm_prev;
|
||||||
/* Check that both stack segments have the same anon_vma? */
|
/* Check that both stack segments have the same anon_vma? */
|
||||||
if (prev && !(prev->vm_flags & VM_GROWSDOWN) &&
|
if (prev && !(prev->vm_flags & VM_GROWSDOWN) &&
|
||||||
(prev->vm_flags & (VM_WRITE|VM_READ|VM_EXEC))) {
|
vma_is_accessible(prev)) {
|
||||||
if (address - prev->vm_end < stack_guard_gap)
|
if (address - prev->vm_end < stack_guard_gap)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue