~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/powerpc/include/asm/book3s/64/tlbflush-radix.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 /* SPDX-License-Identifier: GPL-2.0 */
  2 #ifndef _ASM_POWERPC_TLBFLUSH_RADIX_H
  3 #define _ASM_POWERPC_TLBFLUSH_RADIX_H
  4 
  5 #include <asm/hvcall.h>
  6 
  7 #define RIC_FLUSH_TLB 0
  8 #define RIC_FLUSH_PWC 1
  9 #define RIC_FLUSH_ALL 2
 10 
 11 struct vm_area_struct;
 12 struct mm_struct;
 13 struct mmu_gather;
 14 
 15 static inline u64 psize_to_rpti_pgsize(unsigned long psize)
 16 {
 17         if (psize == MMU_PAGE_4K)
 18                 return H_RPTI_PAGE_4K;
 19         if (psize == MMU_PAGE_64K)
 20                 return H_RPTI_PAGE_64K;
 21         if (psize == MMU_PAGE_2M)
 22                 return H_RPTI_PAGE_2M;
 23         if (psize == MMU_PAGE_1G)
 24                 return H_RPTI_PAGE_1G;
 25         return H_RPTI_PAGE_ALL;
 26 }
 27 
 28 static inline int mmu_get_ap(int psize)
 29 {
 30         return mmu_psize_defs[psize].ap;
 31 }
 32 
 33 #ifdef CONFIG_PPC_RADIX_MMU
 34 extern void radix__tlbiel_all(unsigned int action);
 35 extern void radix__flush_tlb_lpid_page(unsigned int lpid,
 36                                         unsigned long addr,
 37                                         unsigned long page_size);
 38 extern void radix__flush_pwc_lpid(unsigned int lpid);
 39 extern void radix__flush_all_lpid(unsigned int lpid);
 40 extern void radix__flush_all_lpid_guest(unsigned int lpid);
 41 #else
 42 static inline void radix__tlbiel_all(unsigned int action) { WARN_ON(1); }
 43 static inline void radix__flush_tlb_lpid_page(unsigned int lpid,
 44                                         unsigned long addr,
 45                                         unsigned long page_size)
 46 {
 47         WARN_ON(1);
 48 }
 49 static inline void radix__flush_pwc_lpid(unsigned int lpid)
 50 {
 51         WARN_ON(1);
 52 }
 53 static inline void radix__flush_all_lpid(unsigned int lpid)
 54 {
 55         WARN_ON(1);
 56 }
 57 static inline void radix__flush_all_lpid_guest(unsigned int lpid)
 58 {
 59         WARN_ON(1);
 60 }
 61 #endif
 62 
 63 extern void radix__flush_hugetlb_tlb_range(struct vm_area_struct *vma,
 64                                            unsigned long start, unsigned long end);
 65 extern void radix__flush_tlb_range_psize(struct mm_struct *mm, unsigned long start,
 66                                          unsigned long end, int psize);
 67 void radix__flush_tlb_pwc_range_psize(struct mm_struct *mm, unsigned long start,
 68                                       unsigned long end, int psize);
 69 extern void radix__flush_pmd_tlb_range(struct vm_area_struct *vma,
 70                                        unsigned long start, unsigned long end);
 71 extern void radix__flush_pud_tlb_range(struct vm_area_struct *vma,
 72                                        unsigned long start, unsigned long end);
 73 extern void radix__flush_tlb_range(struct vm_area_struct *vma, unsigned long start,
 74                             unsigned long end);
 75 extern void radix__flush_tlb_kernel_range(unsigned long start, unsigned long end);
 76 
 77 extern void radix__local_flush_tlb_mm(struct mm_struct *mm);
 78 extern void radix__local_flush_all_mm(struct mm_struct *mm);
 79 extern void radix__local_flush_tlb_page(struct vm_area_struct *vma, unsigned long vmaddr);
 80 extern void radix__local_flush_tlb_page_psize(struct mm_struct *mm, unsigned long vmaddr,
 81                                               int psize);
 82 extern void radix__tlb_flush(struct mmu_gather *tlb);
 83 #ifdef CONFIG_SMP
 84 extern void radix__flush_tlb_mm(struct mm_struct *mm);
 85 extern void radix__flush_all_mm(struct mm_struct *mm);
 86 extern void radix__flush_tlb_page(struct vm_area_struct *vma, unsigned long vmaddr);
 87 extern void radix__flush_tlb_page_psize(struct mm_struct *mm, unsigned long vmaddr,
 88                                         int psize);
 89 #else
 90 #define radix__flush_tlb_mm(mm)         radix__local_flush_tlb_mm(mm)
 91 #define radix__flush_all_mm(mm)         radix__local_flush_all_mm(mm)
 92 #define radix__flush_tlb_page(vma,addr) radix__local_flush_tlb_page(vma,addr)
 93 #define radix__flush_tlb_page_psize(mm,addr,p) radix__local_flush_tlb_page_psize(mm,addr,p)
 94 #endif
 95 extern void radix__flush_tlb_pwc(struct mmu_gather *tlb, unsigned long addr);
 96 extern void radix__flush_tlb_collapsed_pmd(struct mm_struct *mm, unsigned long addr);
 97 extern void radix__flush_tlb_all(void);
 98 
 99 #endif
100 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php