| /* SPDX-License-Identifier: GPL-2.0 */ |
| #ifndef _SPARC64_TLBFLUSH_H |
| #define _SPARC64_TLBFLUSH_H |
| |
| #include <asm/mmu_context.h> |
| |
| /* TSB flush operations. */ |
| |
| #define TLB_BATCH_NR 192 |
| |
| struct tlb_batch { |
| unsigned int hugepage_shift; |
| struct mm_struct *mm; |
| unsigned long tlb_nr; |
| unsigned long active; |
| unsigned long vaddrs[TLB_BATCH_NR]; |
| }; |
| |
| void flush_tsb_kernel_range(unsigned long start, unsigned long end); |
| void flush_tsb_user(struct tlb_batch *tb); |
| void flush_tsb_user_page(struct mm_struct *mm, unsigned long vaddr, |
| unsigned int hugepage_shift); |
| |
| /* TLB flush operations. */ |
| |
| static inline void flush_tlb_mm(struct mm_struct *mm) |
| { |
| } |
| |
| static inline void flush_tlb_page(struct vm_area_struct *vma, |
| unsigned long vmaddr) |
| { |
| } |
| |
| static inline void flush_tlb_range(struct vm_area_struct *vma, |
| unsigned long start, unsigned long end) |
| { |
| } |
| |
| void flush_tlb_kernel_range(unsigned long start, unsigned long end); |
| |
| #define __HAVE_ARCH_ENTER_LAZY_MMU_MODE |
| |
| void flush_tlb_pending(void); |
| void arch_enter_lazy_mmu_mode(void); |
| void arch_leave_lazy_mmu_mode(void); |
| #define arch_flush_lazy_mmu_mode() do {} while (0) |
| |
| /* Local cpu only. */ |
| void __flush_tlb_all(void); |
| void __flush_tlb_page(unsigned long context, unsigned long vaddr); |
| void __flush_tlb_kernel_range(unsigned long start, unsigned long end); |
| |
| #ifndef CONFIG_SMP |
| |
| static inline void global_flush_tlb_page(struct mm_struct *mm, unsigned long vaddr) |
| { |
| __flush_tlb_page(CTX_HWBITS(mm->context), vaddr); |
| } |
| |
| #else /* CONFIG_SMP */ |
| |
| void smp_flush_tlb_kernel_range(unsigned long start, unsigned long end); |
| void smp_flush_tlb_page(struct mm_struct *mm, unsigned long vaddr); |
| |
| #define global_flush_tlb_page(mm, vaddr) \ |
| smp_flush_tlb_page(mm, vaddr) |
| |
| #endif /* ! CONFIG_SMP */ |
| |
| #endif /* _SPARC64_TLBFLUSH_H */ |