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

TOMOYO Linux Cross Reference
Linux/arch/csky/abiv2/inc/abi/ckmmu.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ 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 
  3 #ifndef __ASM_CSKY_CKMMUV2_H
  4 #define __ASM_CSKY_CKMMUV2_H
  5 
  6 #include <abi/reg_ops.h>
  7 #include <asm/barrier.h>
  8 
  9 static inline int read_mmu_index(void)
 10 {
 11         return mfcr("cr<0, 15>");
 12 }
 13 
 14 static inline void write_mmu_index(int value)
 15 {
 16         mtcr("cr<0, 15>", value);
 17 }
 18 
 19 static inline int read_mmu_entrylo0(void)
 20 {
 21         return mfcr("cr<2, 15>");
 22 }
 23 
 24 static inline int read_mmu_entrylo1(void)
 25 {
 26         return mfcr("cr<3, 15>");
 27 }
 28 
 29 static inline void write_mmu_pagemask(int value)
 30 {
 31         mtcr("cr<6, 15>", value);
 32 }
 33 
 34 static inline int read_mmu_entryhi(void)
 35 {
 36         return mfcr("cr<4, 15>");
 37 }
 38 
 39 static inline void write_mmu_entryhi(int value)
 40 {
 41         mtcr("cr<4, 15>", value);
 42 }
 43 
 44 static inline unsigned long read_mmu_msa0(void)
 45 {
 46         return mfcr("cr<30, 15>");
 47 }
 48 
 49 static inline void write_mmu_msa0(unsigned long value)
 50 {
 51         mtcr("cr<30, 15>", value);
 52 }
 53 
 54 static inline unsigned long read_mmu_msa1(void)
 55 {
 56         return mfcr("cr<31, 15>");
 57 }
 58 
 59 static inline void write_mmu_msa1(unsigned long value)
 60 {
 61         mtcr("cr<31, 15>", value);
 62 }
 63 
 64 /*
 65  * TLB operations.
 66  */
 67 static inline void tlb_probe(void)
 68 {
 69         mtcr("cr<8, 15>", 0x80000000);
 70 }
 71 
 72 static inline void tlb_read(void)
 73 {
 74         mtcr("cr<8, 15>", 0x40000000);
 75 }
 76 
 77 static inline void tlb_invalid_all(void)
 78 {
 79 #ifdef CONFIG_CPU_HAS_TLBI
 80         sync_is();
 81         asm volatile(
 82                 "tlbi.alls      \n"
 83                 "sync.i         \n"
 84                 :
 85                 :
 86                 : "memory");
 87 #else
 88         mtcr("cr<8, 15>", 0x04000000);
 89 #endif
 90 }
 91 
 92 static inline void local_tlb_invalid_all(void)
 93 {
 94 #ifdef CONFIG_CPU_HAS_TLBI
 95         sync_is();
 96         asm volatile(
 97                 "tlbi.all       \n"
 98                 "sync.i         \n"
 99                 :
100                 :
101                 : "memory");
102 #else
103         tlb_invalid_all();
104 #endif
105 }
106 
107 static inline void tlb_invalid_indexed(void)
108 {
109         mtcr("cr<8, 15>", 0x02000000);
110 }
111 
112 #define NOP32 ".long 0x4820c400\n"
113 
114 static inline void setup_pgd(pgd_t *pgd, int asid)
115 {
116 #ifdef CONFIG_CPU_HAS_TLBI
117         sync_is();
118 #else
119         mb();
120 #endif
121         asm volatile(
122 #ifdef CONFIG_CPU_HAS_TLBI
123                 "mtcr %1, cr<28, 15>    \n"
124 #endif
125                 "mtcr %1, cr<29, 15>    \n"
126                 "mtcr %0, cr< 4, 15>    \n"
127                 ".rept 64               \n"
128                 NOP32
129                 ".endr                  \n"
130                 :
131                 :"r"(asid), "r"(__pa(pgd) | BIT(0))
132                 :"memory");
133 }
134 
135 static inline pgd_t *get_pgd(void)
136 {
137         return __va(mfcr("cr<29, 15>") & ~BIT(0));
138 }
139 #endif /* __ASM_CSKY_CKMMUV2_H */
140 

~ [ 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