From: Rik van Riel Date: Tue, 9 Oct 2012 13:31:59 +0000 (+0200) Subject: mm: Only flush the TLB when clearing an accessible pte X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=8d1acce4537c4e2f5889ed9ba9b8eddb80d99820;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git mm: Only flush the TLB when clearing an accessible pte If ptep_clear_flush() is called to clear a page table entry that is accessible anyway by the CPU, eg. a _PAGE_PROTNONE page table entry, there is no need to flush the TLB on remote CPUs. Signed-off-by: Rik van Riel Signed-off-by: Peter Zijlstra Cc: Linus Torvalds Cc: Andrew Morton Link: http://lkml.kernel.org/n/tip-vm3rkzevahelwhejx5uwm8ex@git.kernel.org Signed-off-by: Ingo Molnar --- diff --git a/mm/pgtable-generic.c b/mm/pgtable-generic.c index d8397da42fe6..0c8323fe6c8f 100644 --- a/mm/pgtable-generic.c +++ b/mm/pgtable-generic.c @@ -88,7 +88,8 @@ pte_t ptep_clear_flush(struct vm_area_struct *vma, unsigned long address, { pte_t pte; pte = ptep_get_and_clear((vma)->vm_mm, address, ptep); - flush_tlb_page(vma, address); + if (pte_accessible(pte)) + flush_tlb_page(vma, address); return pte; } #endif