RISC-V: Issue a tlb page flush if possible
authorAtish Patra <atish.patra@wdc.com>
Thu, 22 Aug 2019 07:51:51 +0000 (00:51 -0700)
committerPaul Walmsley <paul.walmsley@sifive.com>
Tue, 29 Oct 2019 18:32:18 +0000 (11:32 -0700)
If tlbflush request is for page only, there is no need to do a
complete local tlb shootdown.

Just do a local tlb flush for the given address.

Signed-off-by: Atish Patra <atish.patra@wdc.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Paul Walmsley <paul.walmsley@sifive.com>
arch/riscv/mm/tlbflush.c

index 3531d46..720b443 100644 (file)
@@ -27,7 +27,10 @@ static void __sbi_tlb_flush_range(struct cpumask *cmask, unsigned long start,
 
        if (cpumask_any_but(cmask, cpuid) >= nr_cpu_ids) {
                /* local cpu is the only cpu present in cpumask */
-               local_flush_tlb_all();
+               if (size <= PAGE_SIZE)
+                       local_flush_tlb_page(start);
+               else
+                       local_flush_tlb_all();
        } else {
                riscv_cpuid_to_hartid_mask(cmask, &hmask);
                sbi_remote_sfence_vma(cpumask_bits(&hmask), start, size);