Path: blob/master/arch/powerpc/include/asm/book3s/64/tlbflush-radix.h
26519 views
/* SPDX-License-Identifier: GPL-2.0 */1#ifndef _ASM_POWERPC_TLBFLUSH_RADIX_H2#define _ASM_POWERPC_TLBFLUSH_RADIX_H34#include <asm/hvcall.h>56#define RIC_FLUSH_TLB 07#define RIC_FLUSH_PWC 18#define RIC_FLUSH_ALL 2910struct vm_area_struct;11struct mm_struct;12struct mmu_gather;1314static inline u64 psize_to_rpti_pgsize(unsigned long psize)15{16if (psize == MMU_PAGE_4K)17return H_RPTI_PAGE_4K;18if (psize == MMU_PAGE_64K)19return H_RPTI_PAGE_64K;20if (psize == MMU_PAGE_2M)21return H_RPTI_PAGE_2M;22if (psize == MMU_PAGE_1G)23return H_RPTI_PAGE_1G;24return H_RPTI_PAGE_ALL;25}2627static inline int mmu_get_ap(int psize)28{29return mmu_psize_defs[psize].ap;30}3132#ifdef CONFIG_PPC_RADIX_MMU33extern void radix__tlbiel_all(unsigned int action);34extern void radix__flush_tlb_lpid_page(unsigned int lpid,35unsigned long addr,36unsigned long page_size);37extern void radix__flush_pwc_lpid(unsigned int lpid);38extern void radix__flush_all_lpid(unsigned int lpid);39extern void radix__flush_all_lpid_guest(unsigned int lpid);40#else41static inline void radix__tlbiel_all(unsigned int action) { WARN_ON(1); }42static inline void radix__flush_tlb_lpid_page(unsigned int lpid,43unsigned long addr,44unsigned long page_size)45{46WARN_ON(1);47}48static inline void radix__flush_pwc_lpid(unsigned int lpid)49{50WARN_ON(1);51}52static inline void radix__flush_all_lpid(unsigned int lpid)53{54WARN_ON(1);55}56static inline void radix__flush_all_lpid_guest(unsigned int lpid)57{58WARN_ON(1);59}60#endif6162extern void radix__flush_hugetlb_tlb_range(struct vm_area_struct *vma,63unsigned long start, unsigned long end);64extern void radix__flush_tlb_range_psize(struct mm_struct *mm, unsigned long start,65unsigned long end, int psize);66void radix__flush_tlb_pwc_range_psize(struct mm_struct *mm, unsigned long start,67unsigned long end, int psize);68extern void radix__flush_pmd_tlb_range(struct vm_area_struct *vma,69unsigned long start, unsigned long end);70extern void radix__flush_pud_tlb_range(struct vm_area_struct *vma,71unsigned long start, unsigned long end);72extern void radix__flush_tlb_range(struct vm_area_struct *vma, unsigned long start,73unsigned long end);74extern void radix__flush_tlb_kernel_range(unsigned long start, unsigned long end);7576extern void radix__local_flush_tlb_mm(struct mm_struct *mm);77extern void radix__local_flush_all_mm(struct mm_struct *mm);78extern void radix__local_flush_tlb_page(struct vm_area_struct *vma, unsigned long vmaddr);79extern void radix__local_flush_tlb_page_psize(struct mm_struct *mm, unsigned long vmaddr,80int psize);81extern void radix__tlb_flush(struct mmu_gather *tlb);82#ifdef CONFIG_SMP83extern void radix__flush_tlb_mm(struct mm_struct *mm);84extern void radix__flush_all_mm(struct mm_struct *mm);85extern void radix__flush_tlb_page(struct vm_area_struct *vma, unsigned long vmaddr);86extern void radix__flush_tlb_page_psize(struct mm_struct *mm, unsigned long vmaddr,87int psize);88#else89#define radix__flush_tlb_mm(mm) radix__local_flush_tlb_mm(mm)90#define radix__flush_all_mm(mm) radix__local_flush_all_mm(mm)91#define radix__flush_tlb_page(vma,addr) radix__local_flush_tlb_page(vma,addr)92#define radix__flush_tlb_page_psize(mm,addr,p) radix__local_flush_tlb_page_psize(mm,addr,p)93#endif94extern void radix__flush_tlb_pwc(struct mmu_gather *tlb, unsigned long addr);95extern void radix__flush_tlb_collapsed_pmd(struct mm_struct *mm, unsigned long addr);96extern void radix__flush_tlb_all(void);9798#endif99100101