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

TOMOYO Linux Cross Reference
Linux/arch/mips/kernel/mips-mt.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ 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 ] ~

Diff markup

Differences between /arch/mips/kernel/mips-mt.c (Architecture mips) and /arch/alpha/kernel/mips-mt.c (Architecture alpha)


  1 // SPDX-License-Identifier: GPL-2.0                 1 
  2 /*                                                
  3  * General MIPS MT support routines, usable in    
  4  * Copyright (C) 2005 Mips Technologies, Inc      
  5  */                                               
  6                                                   
  7 #include <linux/device.h>                         
  8 #include <linux/kernel.h>                         
  9 #include <linux/sched.h>                          
 10 #include <linux/export.h>                         
 11 #include <linux/interrupt.h>                      
 12 #include <linux/security.h>                       
 13                                                   
 14 #include <asm/cpu.h>                              
 15 #include <asm/processor.h>                        
 16 #include <linux/atomic.h>                         
 17 #include <asm/hardirq.h>                          
 18 #include <asm/mmu_context.h>                      
 19 #include <asm/mipsmtregs.h>                       
 20 #include <asm/r4kcache.h>                         
 21 #include <asm/cacheflush.h>                       
 22 #include <asm/mips_mt.h>                          
 23                                                   
 24 int vpelimit;                                     
 25                                                   
 26 static int __init maxvpes(char *str)              
 27 {                                                 
 28         get_option(&str, &vpelimit);              
 29                                                   
 30         return 1;                                 
 31 }                                                 
 32                                                   
 33 __setup("maxvpes=", maxvpes);                     
 34                                                   
 35 int tclimit;                                      
 36                                                   
 37 static int __init maxtcs(char *str)               
 38 {                                                 
 39         get_option(&str, &tclimit);               
 40                                                   
 41         return 1;                                 
 42 }                                                 
 43                                                   
 44 __setup("maxtcs=", maxtcs);                       
 45                                                   
 46 static int mt_opt_rpsctl = -1;                    
 47 static int mt_opt_nblsu = -1;                     
 48 static int mt_opt_forceconfig7;                   
 49 static int mt_opt_config7 = -1;                   
 50                                                   
 51 static int __init rpsctl_set(char *str)           
 52 {                                                 
 53         get_option(&str, &mt_opt_rpsctl);         
 54         return 1;                                 
 55 }                                                 
 56 __setup("rpsctl=", rpsctl_set);                   
 57                                                   
 58 static int __init nblsu_set(char *str)            
 59 {                                                 
 60         get_option(&str, &mt_opt_nblsu);          
 61         return 1;                                 
 62 }                                                 
 63 __setup("nblsu=", nblsu_set);                     
 64                                                   
 65 static int __init config7_set(char *str)          
 66 {                                                 
 67         get_option(&str, &mt_opt_config7);        
 68         mt_opt_forceconfig7 = 1;                  
 69         return 1;                                 
 70 }                                                 
 71 __setup("config7=", config7_set);                 
 72                                                   
 73 static unsigned int itc_base;                     
 74                                                   
 75 static int __init set_itc_base(char *str)         
 76 {                                                 
 77         get_option(&str, &itc_base);              
 78         return 1;                                 
 79 }                                                 
 80                                                   
 81 __setup("itcbase=", set_itc_base);                
 82                                                   
 83 void mips_mt_set_cpuoptions(void)                 
 84 {                                                 
 85         unsigned int oconfig7 = read_c0_config    
 86         unsigned int nconfig7 = oconfig7;         
 87                                                   
 88         if (mt_opt_rpsctl >= 0) {                 
 89                 printk("34K return prediction     
 90                         mt_opt_rpsctl);           
 91                 if (mt_opt_rpsctl)                
 92                         nconfig7 |= (1 << 2);     
 93                 else                              
 94                         nconfig7 &= ~(1 << 2);    
 95         }                                         
 96         if (mt_opt_nblsu >= 0) {                  
 97                 printk("34K ALU/LSU sync overr    
 98                 if (mt_opt_nblsu)                 
 99                         nconfig7 |= (1 << 5);     
100                 else                              
101                         nconfig7 &= ~(1 << 5);    
102         }                                         
103         if (mt_opt_forceconfig7) {                
104                 printk("CP0.Config7 forced to     
105                 nconfig7 = mt_opt_config7;        
106         }                                         
107         if (oconfig7 != nconfig7) {               
108                 __asm__ __volatile("sync");       
109                 write_c0_config7(nconfig7);       
110                 ehb();                            
111                 printk("Config7: 0x%08x\n", re    
112         }                                         
113                                                   
114         if (itc_base != 0) {                      
115                 /*                                
116                  * Configure ITC mapping.  Thi    
117                  * specific to the 34K core fa    
118                  * a special mode bit ("ITC")     
119                  * register to enable access t    
120                  * registers via cache "tag" o    
121                  */                               
122                 unsigned long ectlval;            
123                 unsigned long itcblkgrn;          
124                                                   
125                 /* ErrCtl register is known as    
126                 ectlval = read_c0_ecc();          
127                 write_c0_ecc(ectlval | (0x1 <<    
128                 ehb();                            
129 #define INDEX_0 (0x80000000)                      
130 #define INDEX_8 (0x80000008)                      
131                 /* Read "cache tag" for Dcache    
132                 cache_op(Index_Load_Tag_D, IND    
133                 ehb();                            
134                 itcblkgrn = read_c0_dtaglo();     
135                 itcblkgrn &= 0xfffe0000;          
136                 /* Set for 128 byte pitch of I    
137                 itcblkgrn |= 0x00000c00;          
138                 /* Stage in Tag register */       
139                 write_c0_dtaglo(itcblkgrn);       
140                 ehb();                            
141                 /* Write out to ITU with CACHE    
142                 cache_op(Index_Store_Tag_D, IN    
143                 /* Now set base address, and t    
144                 write_c0_dtaglo((itc_base & 0x    
145                 ehb();                            
146                 /* Write out to ITU with CACHE    
147                 cache_op(Index_Store_Tag_D, IN    
148                 write_c0_ecc(ectlval);            
149                 ehb();                            
150                 printk("Mapped %ld ITC cells s    
151                         ((itcblkgrn & 0x7fe000    
152         }                                         
153 }                                                 
154                                                   
155 const struct class mt_class = {                   
156         .name = "mt",                             
157 };                                                
158                                                   
159 static int __init mips_mt_init(void)              
160 {                                                 
161         return class_register(&mt_class);         
162 }                                                 
163                                                   
164 subsys_initcall(mips_mt_init);                    
165                                                   

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