]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
um: Skip TLB flushing where not needed
authorAnton Ivanov <anton.ivanov@cambridgegreys.com>
Wed, 5 Dec 2018 12:37:40 +0000 (12:37 +0000)
committerRichard Weinberger <richard@nod.at>
Thu, 27 Dec 2018 21:48:34 +0000 (22:48 +0100)
Skip TLB flushing for all cases where it is not needed, not
just flush_tlb_mm_range

Signed-off-by: Anton Ivanov <anton.ivanov@cambridgegreys.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
arch/um/kernel/tlb.c

index b7f7a60a092807ee9d4a2a8cc88697f88ff8b4e4..9ca902df243a36577951fcb2bd6c0a68274cdfac 100644 (file)
@@ -520,6 +520,13 @@ pte_t *addr_pte(struct task_struct *task, unsigned long addr)
 
 void flush_tlb_all(void)
 {
+       /*
+        * Don't bother flushing if this address space is about to be
+        * destroyed.
+        */
+       if (atomic_read(&current->mm->mm_users) == 0)
+               return;
+
        flush_tlb_mm(current->mm);
 }
 
@@ -541,6 +548,13 @@ void __flush_tlb_one(unsigned long addr)
 static void fix_range(struct mm_struct *mm, unsigned long start_addr,
                      unsigned long end_addr, int force)
 {
+       /*
+        * Don't bother flushing if this address space is about to be
+        * destroyed.
+        */
+       if (atomic_read(&mm->mm_users) == 0)
+               return;
+
        fix_range_common(mm, start_addr, end_addr, force);
 }
 
@@ -556,13 +570,6 @@ EXPORT_SYMBOL(flush_tlb_range);
 void flush_tlb_mm_range(struct mm_struct *mm, unsigned long start,
                        unsigned long end)
 {
-       /*
-        * Don't bother flushing if this address space is about to be
-        * destroyed.
-        */
-       if (atomic_read(&mm->mm_users) == 0)
-               return;
-
        fix_range(mm, start, end, 0);
 }