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

TOMOYO Linux Cross Reference
Linux/arch/arm/mm/Kconfig

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.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/arm/mm/Kconfig (Version linux-6.12-rc7) and /arch/sparc64/mm/Kconfig (Version linux-5.16.20)


  1 # SPDX-License-Identifier: GPL-2.0                
  2 comment "Processor Type"                          
  3                                                   
  4 # Select CPU types depending on the architectu    
  5 # which CPUs we support in the kernel image, a    
  6 # optimiser behaviour.                            
  7                                                   
  8 # ARM7TDMI                                        
  9 config CPU_ARM7TDMI                               
 10         bool                                      
 11         depends on !MMU                           
 12         select CPU_32v4T                          
 13         select CPU_ABRT_LV4T                      
 14         select CPU_CACHE_V4                       
 15         select CPU_PABRT_LEGACY                   
 16         help                                      
 17           A 32-bit RISC microprocessor based o    
 18           which has no memory control unit and    
 19                                                   
 20           Say Y if you want support for the AR    
 21           Otherwise, say N.                       
 22                                                   
 23 # ARM720T                                         
 24 config CPU_ARM720T                                
 25         bool                                      
 26         select CPU_32v4T                          
 27         select CPU_ABRT_LV4T                      
 28         select CPU_CACHE_V4                       
 29         select CPU_CACHE_VIVT                     
 30         select CPU_COPY_V4WT if MMU               
 31         select CPU_CP15_MMU                       
 32         select CPU_PABRT_LEGACY                   
 33         select CPU_THUMB_CAPABLE                  
 34         select CPU_TLB_V4WT if MMU                
 35         help                                      
 36           A 32-bit RISC processor with 8kByte     
 37           MMU built around an ARM7TDMI core.      
 38                                                   
 39           Say Y if you want support for the AR    
 40           Otherwise, say N.                       
 41                                                   
 42 # ARM740T                                         
 43 config CPU_ARM740T                                
 44         bool                                      
 45         depends on !MMU                           
 46         select CPU_32v4T                          
 47         select CPU_ABRT_LV4T                      
 48         select CPU_CACHE_V4                       
 49         select CPU_CP15_MPU                       
 50         select CPU_PABRT_LEGACY                   
 51         select CPU_THUMB_CAPABLE                  
 52         help                                      
 53           A 32-bit RISC processor with 8KB cac    
 54           write buffer and MPU(Protection Unit    
 55           an ARM7TDMI core.                       
 56                                                   
 57           Say Y if you want support for the AR    
 58           Otherwise, say N.                       
 59                                                   
 60 # ARM9TDMI                                        
 61 config CPU_ARM9TDMI                               
 62         bool                                      
 63         depends on !MMU                           
 64         select CPU_32v4T                          
 65         select CPU_ABRT_NOMMU                     
 66         select CPU_CACHE_V4                       
 67         select CPU_PABRT_LEGACY                   
 68         help                                      
 69           A 32-bit RISC microprocessor based o    
 70           which has no memory control unit and    
 71                                                   
 72           Say Y if you want support for the AR    
 73           Otherwise, say N.                       
 74                                                   
 75 # ARM920T                                         
 76 config CPU_ARM920T                                
 77         bool                                      
 78         select CPU_32v4T                          
 79         select CPU_ABRT_EV4T                      
 80         select CPU_CACHE_V4WT                     
 81         select CPU_CACHE_VIVT                     
 82         select CPU_COPY_V4WB if MMU               
 83         select CPU_CP15_MMU                       
 84         select CPU_PABRT_LEGACY                   
 85         select CPU_THUMB_CAPABLE                  
 86         select CPU_TLB_V4WBI if MMU               
 87         help                                      
 88           The ARM920T is licensed to be produc    
 89           and is used in the Cirrus EP93xx and    
 90                                                   
 91           Say Y if you want support for the AR    
 92           Otherwise, say N.                       
 93                                                   
 94 # ARM922T                                         
 95 config CPU_ARM922T                                
 96         bool                                      
 97         select CPU_32v4T                          
 98         select CPU_ABRT_EV4T                      
 99         select CPU_CACHE_V4WT                     
100         select CPU_CACHE_VIVT                     
101         select CPU_COPY_V4WB if MMU               
102         select CPU_CP15_MMU                       
103         select CPU_PABRT_LEGACY                   
104         select CPU_THUMB_CAPABLE                  
105         select CPU_TLB_V4WBI if MMU               
106         help                                      
107           The ARM922T is a version of the ARM9    
108           instruction and data caches. It is u    
109           Excalibur XA device family and the A    
110                                                   
111           Say Y if you want support for the AR    
112           Otherwise, say N.                       
113                                                   
114 # ARM925T                                         
115 config CPU_ARM925T                                
116         bool                                      
117         select CPU_32v4T                          
118         select CPU_ABRT_EV4T                      
119         select CPU_CACHE_V4WT                     
120         select CPU_CACHE_VIVT                     
121         select CPU_COPY_V4WB if MMU               
122         select CPU_CP15_MMU                       
123         select CPU_PABRT_LEGACY                   
124         select CPU_THUMB_CAPABLE                  
125         select CPU_TLB_V4WBI if MMU               
126         help                                      
127           The ARM925T is a mix between the ARM    
128           different instruction and data cache    
129           device family.                          
130                                                   
131           Say Y if you want support for the AR    
132           Otherwise, say N.                       
133                                                   
134 # ARM926T                                         
135 config CPU_ARM926T                                
136         bool                                      
137         select CPU_32v5                           
138         select CPU_ABRT_EV5TJ                     
139         select CPU_CACHE_VIVT                     
140         select CPU_COPY_V4WB if MMU               
141         select CPU_CP15_MMU                       
142         select CPU_PABRT_LEGACY                   
143         select CPU_THUMB_CAPABLE                  
144         select CPU_TLB_V4WBI if MMU               
145         help                                      
146           This is a variant of the ARM920.  It    
147           instruction sequences for cache and     
148           there is no documentation on it at t    
149                                                   
150           Say Y if you want support for the AR    
151           Otherwise, say N.                       
152                                                   
153 # FA526                                           
154 config CPU_FA526                                  
155         bool                                      
156         select CPU_32v4                           
157         select CPU_ABRT_EV4                       
158         select CPU_CACHE_FA                       
159         select CPU_CACHE_VIVT                     
160         select CPU_COPY_FA if MMU                 
161         select CPU_CP15_MMU                       
162         select CPU_PABRT_LEGACY                   
163         select CPU_TLB_FA if MMU                  
164         help                                      
165           The FA526 is a version of the ARMv4     
166           Branch Target Buffer, Unified TLB an    
167                                                   
168           Say Y if you want support for the FA    
169           Otherwise, say N.                       
170                                                   
171 # ARM940T                                         
172 config CPU_ARM940T                                
173         bool                                      
174         depends on !MMU                           
175         select CPU_32v4T                          
176         select CPU_ABRT_NOMMU                     
177         select CPU_CACHE_VIVT                     
178         select CPU_CP15_MPU                       
179         select CPU_PABRT_LEGACY                   
180         select CPU_THUMB_CAPABLE                  
181         help                                      
182           ARM940T is a member of the ARM9TDMI     
183           purpose microprocessors with MPU and    
184           instruction and 4KB data cases, each    
185           length.                                 
186                                                   
187           Say Y if you want support for the AR    
188           Otherwise, say N.                       
189                                                   
190 # ARM946E-S                                       
191 config CPU_ARM946E                                
192         bool                                      
193         depends on !MMU                           
194         select CPU_32v5                           
195         select CPU_ABRT_NOMMU                     
196         select CPU_CACHE_VIVT                     
197         select CPU_CP15_MPU                       
198         select CPU_PABRT_LEGACY                   
199         select CPU_THUMB_CAPABLE                  
200         help                                      
201           ARM946E-S is a member of the ARM9E-S    
202           performance, 32-bit system-on-chip p    
203           The TCM and ARMv5TE 32-bit instructi    
204                                                   
205           Say Y if you want support for the AR    
206           Otherwise, say N.                       
207                                                   
208 # ARM1020 - needs validating                      
209 config CPU_ARM1020                                
210         bool                                      
211         select CPU_32v5                           
212         select CPU_ABRT_EV4T                      
213         select CPU_CACHE_V4WT                     
214         select CPU_CACHE_VIVT                     
215         select CPU_COPY_V4WB if MMU               
216         select CPU_CP15_MMU                       
217         select CPU_PABRT_LEGACY                   
218         select CPU_THUMB_CAPABLE                  
219         select CPU_TLB_V4WBI if MMU               
220         help                                      
221           The ARM1020 is the 32K cached versio    
222           with an addition of a floating-point    
223                                                   
224           Say Y if you want support for the AR    
225           Otherwise, say N.                       
226                                                   
227 # ARM1020E - needs validating                     
228 config CPU_ARM1020E                               
229         bool                                      
230         depends on n                              
231         select CPU_32v5                           
232         select CPU_ABRT_EV4T                      
233         select CPU_CACHE_V4WT                     
234         select CPU_CACHE_VIVT                     
235         select CPU_COPY_V4WB if MMU               
236         select CPU_CP15_MMU                       
237         select CPU_PABRT_LEGACY                   
238         select CPU_THUMB_CAPABLE                  
239         select CPU_TLB_V4WBI if MMU               
240                                                   
241 # ARM1022E                                        
242 config CPU_ARM1022                                
243         bool                                      
244         select CPU_32v5                           
245         select CPU_ABRT_EV4T                      
246         select CPU_CACHE_VIVT                     
247         select CPU_COPY_V4WB if MMU # can prob    
248         select CPU_CP15_MMU                       
249         select CPU_PABRT_LEGACY                   
250         select CPU_THUMB_CAPABLE                  
251         select CPU_TLB_V4WBI if MMU               
252         help                                      
253           The ARM1022E is an implementation of    
254           based upon the ARM10 integer core wi    
255           embedded trace macrocell, and a floa    
256                                                   
257           Say Y if you want support for the AR    
258           Otherwise, say N.                       
259                                                   
260 # ARM1026EJ-S                                     
261 config CPU_ARM1026                                
262         bool                                      
263         select CPU_32v5                           
264         select CPU_ABRT_EV5T # But need Jazell    
265         select CPU_CACHE_VIVT                     
266         select CPU_COPY_V4WB if MMU # can prob    
267         select CPU_CP15_MMU                       
268         select CPU_PABRT_LEGACY                   
269         select CPU_THUMB_CAPABLE                  
270         select CPU_TLB_V4WBI if MMU               
271         help                                      
272           The ARM1026EJ-S is an implementation    
273           based upon the ARM10 integer core.      
274                                                   
275           Say Y if you want support for the AR    
276           Otherwise, say N.                       
277                                                   
278 # SA110                                           
279 config CPU_SA110                                  
280         bool                                      
281         select CPU_32v3 if ARCH_RPC               
282         select CPU_32v4 if !ARCH_RPC              
283         select CPU_ABRT_EV4                       
284         select CPU_CACHE_V4WB                     
285         select CPU_CACHE_VIVT                     
286         select CPU_COPY_V4WB if MMU               
287         select CPU_CP15_MMU                       
288         select CPU_PABRT_LEGACY                   
289         select CPU_TLB_V4WB if MMU                
290         help                                      
291           The Intel StrongARM(R) SA-110 is a 3    
292           is available at five speeds ranging     
293           More information is available at        
294           <http://developer.intel.com/design/s    
295                                                   
296           Say Y if you want support for the SA    
297           Otherwise, say N.                       
298                                                   
299 # SA1100                                          
300 config CPU_SA1100                                 
301         bool                                      
302         select CPU_32v4                           
303         select CPU_ABRT_EV4                       
304         select CPU_CACHE_V4WB                     
305         select CPU_CACHE_VIVT                     
306         select CPU_CP15_MMU                       
307         select CPU_PABRT_LEGACY                   
308         select CPU_TLB_V4WB if MMU                
309                                                   
310 # XScale                                          
311 config CPU_XSCALE                                 
312         bool                                      
313         select CPU_32v5                           
314         select CPU_ABRT_EV5T                      
315         select CPU_CACHE_VIVT                     
316         select CPU_CP15_MMU                       
317         select CPU_PABRT_LEGACY                   
318         select CPU_THUMB_CAPABLE                  
319         select CPU_TLB_V4WBI if MMU               
320                                                   
321 # XScale Core Version 3                           
322 config CPU_XSC3                                   
323         bool                                      
324         select CPU_32v5                           
325         select CPU_ABRT_EV5T                      
326         select CPU_CACHE_VIVT                     
327         select CPU_CP15_MMU                       
328         select CPU_PABRT_LEGACY                   
329         select CPU_THUMB_CAPABLE                  
330         select CPU_TLB_V4WBI if MMU               
331         select IO_36                              
332                                                   
333 # Marvell PJ1 (Mohawk)                            
334 config CPU_MOHAWK                                 
335         bool                                      
336         select CPU_32v5                           
337         select CPU_ABRT_EV5T                      
338         select CPU_CACHE_VIVT                     
339         select CPU_COPY_V4WB if MMU               
340         select CPU_CP15_MMU                       
341         select CPU_PABRT_LEGACY                   
342         select CPU_THUMB_CAPABLE                  
343         select CPU_TLB_V4WBI if MMU               
344                                                   
345 # Feroceon                                        
346 config CPU_FEROCEON                               
347         bool                                      
348         select CPU_32v5                           
349         select CPU_ABRT_EV5T                      
350         select CPU_CACHE_VIVT                     
351         select CPU_COPY_FEROCEON if MMU           
352         select CPU_CP15_MMU                       
353         select CPU_PABRT_LEGACY                   
354         select CPU_THUMB_CAPABLE                  
355         select CPU_TLB_FEROCEON if MMU            
356                                                   
357 config CPU_FEROCEON_OLD_ID                        
358         bool "Accept early Feroceon cores with    
359         depends on CPU_FEROCEON && !CPU_ARM926    
360         default y                                 
361         help                                      
362           This enables the usage of some old F    
363           for which the CPU ID is equal to the    
364           Relevant for Feroceon-1850 and early    
365                                                   
366 # Marvell PJ4                                     
367 config CPU_PJ4                                    
368         bool                                      
369         select ARM_THUMBEE                        
370         select CPU_V7                             
371                                                   
372 config CPU_PJ4B                                   
373         bool                                      
374         select CPU_V7                             
375                                                   
376 # ARMv6                                           
377 config CPU_V6                                     
378         bool                                      
379         select CPU_32v6                           
380         select CPU_ABRT_EV6                       
381         select CPU_CACHE_V6                       
382         select CPU_CACHE_VIPT                     
383         select CPU_COPY_V6 if MMU                 
384         select CPU_CP15_MMU                       
385         select CPU_HAS_ASID if MMU                
386         select CPU_PABRT_V6                       
387         select CPU_THUMB_CAPABLE                  
388         select CPU_TLB_V6 if MMU                  
389         select SMP_ON_UP if SMP                   
390                                                   
391 # ARMv6k                                          
392 config CPU_V6K                                    
393         bool                                      
394         select CPU_32v6                           
395         select CPU_32v6K                          
396         select CPU_ABRT_EV6                       
397         select CPU_CACHE_V6                       
398         select CPU_CACHE_VIPT                     
399         select CPU_COPY_V6 if MMU                 
400         select CPU_CP15_MMU                       
401         select CPU_HAS_ASID if MMU                
402         select CPU_PABRT_V6                       
403         select CPU_THUMB_CAPABLE                  
404         select CPU_TLB_V6 if MMU                  
405                                                   
406 # ARMv7 and ARMv8 architectures                   
407 config CPU_V7                                     
408         bool                                      
409         select CPU_32v6K                          
410         select CPU_32v7                           
411         select CPU_ABRT_EV7                       
412         select CPU_CACHE_V7                       
413         select CPU_CACHE_VIPT                     
414         select CPU_COPY_V6 if MMU                 
415         select CPU_CP15_MMU if MMU                
416         select CPU_CP15_MPU if !MMU               
417         select CPU_HAS_ASID if MMU                
418         select CPU_PABRT_V7                       
419         select CPU_SPECTRE if MMU                 
420         select CPU_THUMB_CAPABLE                  
421         select CPU_TLB_V7 if MMU                  
422                                                   
423 # ARMv7M                                          
424 config CPU_V7M                                    
425         bool                                      
426         select CPU_32v7M                          
427         select CPU_ABRT_NOMMU                     
428         select CPU_CACHE_V7M                      
429         select CPU_CACHE_NOP                      
430         select CPU_PABRT_LEGACY                   
431         select CPU_THUMBONLY                      
432                                                   
433 config CPU_THUMBONLY                              
434         bool                                      
435         select CPU_THUMB_CAPABLE                  
436         # There are no CPUs available with MMU    
437         depends on !MMU                           
438         help                                      
439           Select this if your CPU doesn't supp    
440                                                   
441 config CPU_THUMB_CAPABLE                          
442         bool                                      
443         help                                      
444           Select this if your CPU can support     
445                                                   
446 # Figure out what processor architecture versi    
447 # This defines the compiler instruction set wh    
448 config CPU_32v3                                   
449         bool                                      
450         select CPU_USE_DOMAINS if MMU             
451         select NEED_KUSER_HELPERS                 
452         select TLS_REG_EMUL if SMP || !MMU        
453         select CPU_NO_EFFICIENT_FFS               
454                                                   
455 config CPU_32v4                                   
456         bool                                      
457         select CPU_USE_DOMAINS if MMU             
458         select NEED_KUSER_HELPERS                 
459         select TLS_REG_EMUL if SMP || !MMU        
460         select CPU_NO_EFFICIENT_FFS               
461                                                   
462 config CPU_32v4T                                  
463         bool                                      
464         select CPU_USE_DOMAINS if MMU             
465         select NEED_KUSER_HELPERS                 
466         select TLS_REG_EMUL if SMP || !MMU        
467         select CPU_NO_EFFICIENT_FFS               
468                                                   
469 config CPU_32v5                                   
470         bool                                      
471         select CPU_USE_DOMAINS if MMU             
472         select NEED_KUSER_HELPERS                 
473         select TLS_REG_EMUL if SMP || !MMU        
474                                                   
475 config CPU_32v6                                   
476         bool                                      
477         select TLS_REG_EMUL if !CPU_32v6K && !    
478                                                   
479 config CPU_32v6K                                  
480         bool                                      
481                                                   
482 config CPU_32v7                                   
483         bool                                      
484                                                   
485 config CPU_32v7M                                  
486         bool                                      
487                                                   
488 # The abort model                                 
489 config CPU_ABRT_NOMMU                             
490         bool                                      
491                                                   
492 config CPU_ABRT_EV4                               
493         bool                                      
494                                                   
495 config CPU_ABRT_EV4T                              
496         bool                                      
497                                                   
498 config CPU_ABRT_LV4T                              
499         bool                                      
500                                                   
501 config CPU_ABRT_EV5T                              
502         bool                                      
503                                                   
504 config CPU_ABRT_EV5TJ                             
505         bool                                      
506                                                   
507 config CPU_ABRT_EV6                               
508         bool                                      
509                                                   
510 config CPU_ABRT_EV7                               
511         bool                                      
512                                                   
513 config CPU_PABRT_LEGACY                           
514         bool                                      
515                                                   
516 config CPU_PABRT_V6                               
517         bool                                      
518                                                   
519 config CPU_PABRT_V7                               
520         bool                                      
521                                                   
522 # The cache model                                 
523 config CPU_CACHE_V4                               
524         bool                                      
525                                                   
526 config CPU_CACHE_V4WT                             
527         bool                                      
528                                                   
529 config CPU_CACHE_V4WB                             
530         bool                                      
531                                                   
532 config CPU_CACHE_V6                               
533         bool                                      
534                                                   
535 config CPU_CACHE_V7                               
536         bool                                      
537                                                   
538 config CPU_CACHE_NOP                              
539         bool                                      
540                                                   
541 config CPU_CACHE_VIVT                             
542         bool                                      
543                                                   
544 config CPU_CACHE_VIPT                             
545         bool                                      
546                                                   
547 config CPU_CACHE_FA                               
548         bool                                      
549                                                   
550 config CPU_CACHE_V7M                              
551         bool                                      
552                                                   
553 if MMU                                            
554 # The copy-page model                             
555 config CPU_COPY_V4WT                              
556         bool                                      
557                                                   
558 config CPU_COPY_V4WB                              
559         bool                                      
560                                                   
561 config CPU_COPY_FEROCEON                          
562         bool                                      
563                                                   
564 config CPU_COPY_FA                                
565         bool                                      
566                                                   
567 config CPU_COPY_V6                                
568         bool                                      
569                                                   
570 # This selects the TLB model                      
571 config CPU_TLB_V4WT                               
572         bool                                      
573         help                                      
574           ARM Architecture Version 4 TLB with     
575                                                   
576 config CPU_TLB_V4WB                               
577         bool                                      
578         help                                      
579           ARM Architecture Version 4 TLB with     
580                                                   
581 config CPU_TLB_V4WBI                              
582         bool                                      
583         help                                      
584           ARM Architecture Version 4 TLB with     
585           instruction cache entry.                
586                                                   
587 config CPU_TLB_FEROCEON                           
588         bool                                      
589         help                                      
590           Feroceon TLB (v4wbi with non-outer-c    
591                                                   
592 config CPU_TLB_FA                                 
593         bool                                      
594         help                                      
595           Faraday ARM FA526 architecture, unif    
596           and invalidate instruction cache ent    
597           also supported.                         
598                                                   
599 config CPU_TLB_V6                                 
600         bool                                      
601                                                   
602 config CPU_TLB_V7                                 
603         bool                                      
604                                                   
605 endif                                             
606                                                   
607 config CPU_HAS_ASID                               
608         bool                                      
609         help                                      
610           This indicates whether the CPU has t    
611           tag TLB and possibly cache entries.     
612                                                   
613 config CPU_CP15                                   
614         bool                                      
615         help                                      
616           Processor has the CP15 register.        
617                                                   
618 config CPU_CP15_MMU                               
619         bool                                      
620         select CPU_CP15                           
621         help                                      
622           Processor has the CP15 register, whi    
623                                                   
624 config CPU_CP15_MPU                               
625         bool                                      
626         select CPU_CP15                           
627         help                                      
628           Processor has the CP15 register, whi    
629                                                   
630 config CPU_USE_DOMAINS                            
631         bool                                      
632         help                                      
633           This option enables or disables the     
634           using the DACR (domain access contro    
635           domains from each other. In Linux we    
636           and IO. The domains are used to prot    
637           and to handle IO-space as a special     
638           manager or client roles to running c    
639                                                   
640 config CPU_V7M_NUM_IRQ                            
641         int "Number of external interrupts con    
642         depends on CPU_V7M                        
643         default 90 if ARCH_STM32                  
644         default 112 if SOC_VF610                  
645         default 240                               
646         help                                      
647           This option indicates the number of     
648           The value can be larger than the rea    
649           by the system, but must not be lower    
650           The default value is 240, correspond    
651           interrupts supported by the NVIC on     
652                                                   
653           If unsure, keep default value.          
654                                                   
655 #                                                 
656 # CPU supports 36-bit I/O                         
657 #                                                 
658 config IO_36                                      
659         bool                                      
660                                                   
661 comment "Processor Features"                      
662                                                   
663 config ARM_LPAE                                   
664         bool "Support for the Large Physical A    
665         depends on MMU && CPU_32v7 && !CPU_32v    
666                 !CPU_32v4 && !CPU_32v3            
667         select PHYS_ADDR_T_64BIT                  
668         select SWIOTLB                            
669         help                                      
670           Say Y if you have an ARMv7 processor    
671           table format and you would like to a    
672           4GB limit. The resulting kernel imag    
673           processors without the LPA extension    
674                                                   
675           If unsure, say N.                       
676                                                   
677 config ARM_PV_FIXUP                               
678         def_bool y                                
679         depends on ARM_LPAE && ARM_PATCH_PHYS_    
680                                                   
681 config ARM_THUMB                                  
682         bool "Support Thumb user binaries" if     
683         depends on CPU_THUMB_CAPABLE && !CPU_3    
684         default y                                 
685         help                                      
686           Say Y if you want to include kernel     
687           Thumb binaries.                         
688                                                   
689           The Thumb instruction set is a compr    
690           instruction set resulting in smaller    
691           slightly less efficient code.           
692                                                   
693           If this option is disabled, and you     
694           Thumb mode, signal handling will not    
695           segmentation faults or illegal instr    
696                                                   
697           If you don't know what this all is,     
698                                                   
699 config ARM_THUMBEE                                
700         bool "Enable ThumbEE CPU extension"       
701         depends on CPU_V7                         
702         help                                      
703           Say Y here if you have a CPU with th    
704           make use of it. Say N for code that     
705                                                   
706 config ARM_VIRT_EXT                               
707         bool                                      
708         default y if CPU_V7                       
709         help                                      
710           Enable the kernel to make use of the    
711           Extensions to install hypervisors wi    
712           assistance.                             
713                                                   
714           A compliant bootloader is required i    
715           use of this feature.  Refer to Docum    
716           details.                                
717                                                   
718 config SWP_EMULATE                                
719         bool "Emulate SWP/SWPB instructions" i    
720         depends on CPU_V7                         
721         default y if SMP                          
722         select HAVE_PROC_CPU if PROC_FS           
723         help                                      
724           ARMv6 architecture deprecates use of    
725           ARMv7 multiprocessing extensions int    
726           these instructions, triggering an un    
727           when executed. Say Y here to enable     
728           instructions for userspace (not kern    
729           Also creates /proc/cpu/swp_emulation    
730                                                   
731           In some older versions of glibc [<=2    
732           trylock() operations with the assump    
733           be preempted. This invalid assumptio    
734           with SWP emulation enabled, leading     
735           application.                            
736                                                   
737           NOTE: when accessing uncached shared    
738           on an external transaction monitorin    
739           monitor to maintain update atomicity    
740           implement a global monitor, this opt    
741           perform SWP operations to uncached m    
742                                                   
743           If unsure, say Y.                       
744                                                   
745 choice                                            
746         prompt "CPU Endianness"                   
747         default CPU_LITTLE_ENDIAN                 
748                                                   
749 config CPU_LITTLE_ENDIAN                          
750         bool "Built little-endian kernel"         
751         help                                      
752           Say Y if you plan on running a kerne    
753           This is the default and is used in p    
754           space builds.                           
755                                                   
756 config CPU_BIG_ENDIAN                             
757         bool "Build big-endian kernel"            
758         depends on !LD_IS_LLD                     
759         help                                      
760           Say Y if you plan on running a kerne    
761           This works on many machines using AR    
762           but requires big-endian user space.     
763                                                   
764           The only ARMv5 platform with big-end    
765           Intel IXP4xx.                           
766                                                   
767 endchoice                                         
768                                                   
769 config CPU_ENDIAN_BE8                             
770         bool                                      
771         depends on CPU_BIG_ENDIAN                 
772         default CPU_V6 || CPU_V6K || CPU_V7 ||    
773         help                                      
774           Support for the BE-8 (big-endian) mo    
775                                                   
776 config CPU_ENDIAN_BE32                            
777         bool                                      
778         depends on CPU_BIG_ENDIAN                 
779         default !CPU_ENDIAN_BE8                   
780         help                                      
781           Support for the BE-32 (big-endian) m    
782                                                   
783 config CPU_HIGH_VECTOR                            
784         depends on !MMU && CPU_CP15 && !CPU_AR    
785         bool "Select the High exception vector    
786         help                                      
787           Say Y here to select high exception     
788           The exception vector can vary depend    
789           design in nommu mode. If your platfo    
790           high exception vector, say Y.           
791           Otherwise or if you are unsure, say     
792           vector (0x00000000~) will be used.      
793                                                   
794 config CPU_ICACHE_DISABLE                         
795         bool "Disable I-Cache (I-bit)"            
796         depends on (CPU_CP15 && !(CPU_ARM720T     
797         help                                      
798           Say Y here to disable the processor     
799           you have a reason not to or are unsu    
800                                                   
801 config CPU_ICACHE_MISMATCH_WORKAROUND             
802         bool "Workaround for I-Cache line size    
803         depends on SMP && CPU_V7                  
804         help                                      
805           Some big.LITTLE systems have I-Cache    
806           LITTLE and big cores.  Say Y here to    
807           proper I-Cache support on such syste    
808                                                   
809 config CPU_DCACHE_DISABLE                         
810         bool "Disable D-Cache (C-bit)"            
811         depends on (CPU_CP15 && !SMP) || CPU_V    
812         help                                      
813           Say Y here to disable the processor     
814           you have a reason not to or are unsu    
815                                                   
816 config CPU_DCACHE_SIZE                            
817         hex                                       
818         depends on CPU_ARM740T || CPU_ARM946E     
819         default 0x00001000 if CPU_ARM740T         
820         default 0x00002000 # default size for     
821         help                                      
822           Some cores are synthesizable to have    
823           ARM946E-S case, it can vary from 0KB    
824           To support such cache operations, it    
825           before compile time.                    
826           If your SoC is configured to have a     
827           here with proper conditions.            
828                                                   
829 config CPU_DCACHE_WRITETHROUGH                    
830         bool "Force write through D-cache"        
831         depends on (CPU_ARM740T || CPU_ARM920T    
832         default y if CPU_ARM925T                  
833         help                                      
834           Say Y here to use the data cache in     
835           specifically require this or are uns    
836                                                   
837 config CPU_CACHE_ROUND_ROBIN                      
838         bool "Round robin I and D cache replac    
839         depends on (CPU_ARM926T || CPU_ARM946E    
840         help                                      
841           Say Y here to use the predictable ro    
842           policy.  Unless you specifically req    
843                                                   
844 config CPU_BPREDICT_DISABLE                       
845         bool "Disable branch prediction"          
846         depends on CPU_ARM1020 || CPU_V6 || CP    
847         help                                      
848           Say Y here to disable branch predict    
849                                                   
850 config CPU_SPECTRE                                
851         bool                                      
852         select GENERIC_CPU_VULNERABILITIES        
853                                                   
854 config HARDEN_BRANCH_PREDICTOR                    
855         bool "Harden the branch predictor agai    
856         depends on CPU_SPECTRE                    
857         default y                                 
858         help                                      
859            Speculation attacks against some hi    
860            on being able to manipulate the bra    
861            context by executing aliasing branc    
862            Such attacks can be partially mitig    
863            internal branch predictor state and    
864            logic in some situations.              
865                                                   
866            This config option will take CPU-sp    
867            the branch predictor against aliasi    
868            specific instruction sequences or c    
869            the system firmware.                   
870                                                   
871            If unsure, say Y.                      
872                                                   
873 config HARDEN_BRANCH_HISTORY                      
874         bool "Harden Spectre style attacks aga    
875         depends on CPU_SPECTRE                    
876         default y                                 
877         help                                      
878           Speculation attacks against some hig    
879           make use of branch history to influe    
880           taking an exception, a sequence of b    
881           history, or branch history is invali    
882                                                   
883 config TLS_REG_EMUL                               
884         bool                                      
885         select NEED_KUSER_HELPERS                 
886         help                                      
887           An SMP system using a pre-ARMv6 proc    
888           a few prototypes like that in existe    
889           that required register must be emula    
890                                                   
891 config NEED_KUSER_HELPERS                         
892         bool                                      
893                                                   
894 config KUSER_HELPERS                              
895         bool "Enable kuser helpers in vector p    
896         depends on MMU                            
897         default y                                 
898         help                                      
899           Warning: disabling this option may b    
900                                                   
901           Provide kuser helpers in the vector     
902           helper code to userspace in read onl    
903           in the high vector page to allow use    
904           the CPU type fitted to the system.      
905           run on ARMv4 through to ARMv7 withou    
906                                                   
907           See Documentation/arch/arm/kernel_us    
908                                                   
909           However, the fixed address nature of    
910           by ROP (return orientated programmin    
911           exploits.                               
912                                                   
913           If all of the binaries and libraries    
914           are built specifically for your plat    
915           these helpers, then you can turn thi    
916           such exploits. However, in that case    
917           relying on those helpers is run, it     
918           which will terminate the program.       
919                                                   
920           Say N here only if you are absolutel    
921           need these helpers; otherwise, the s    
922                                                   
923 config VDSO                                       
924         bool "Enable VDSO for acceleration of     
925         depends on AEABI && MMU && CPU_V7         
926         default y if ARM_ARCH_TIMER               
927         select HAVE_GENERIC_VDSO                  
928         select GENERIC_TIME_VSYSCALL              
929         select GENERIC_VDSO_32                    
930         select GENERIC_GETTIMEOFDAY               
931         help                                      
932           Place in the process address space a    
933           providing fast implementations of ge    
934           clock_gettime.  Systems that impleme    
935           timer will receive maximum benefit.     
936                                                   
937           You must have glibc 2.22 or later fo    
938           take advantage of this.                 
939                                                   
940                                                   
941 config OUTER_CACHE                                
942         bool                                      
943                                                   
944 config OUTER_CACHE_SYNC                           
945         bool                                      
946         select ARM_HEAVY_MB                       
947         help                                      
948           The outer cache has a outer_cache_fn    
949           that can be used to drain the write     
950                                                   
951 config CACHE_B15_RAC                              
952         bool "Enable the Broadcom Brahma-B15 r    
953         depends on ARCH_BRCMSTB                   
954         default y                                 
955         help                                      
956           This option enables the Broadcom Bra    
957           controller. If disabled, the read-ah    
958                                                   
959 config CACHE_FEROCEON_L2                          
960         bool "Enable the Feroceon L2 cache con    
961         depends on ARCH_MV78XX0 || ARCH_MVEBU     
962         default y                                 
963         select OUTER_CACHE                        
964         help                                      
965           This option enables the Feroceon L2     
966                                                   
967 config CACHE_FEROCEON_L2_WRITETHROUGH             
968         bool "Force Feroceon L2 cache write th    
969         depends on CACHE_FEROCEON_L2              
970         help                                      
971           Say Y here to use the Feroceon L2 ca    
972           Unless you specifically require this    
973                                                   
974 config MIGHT_HAVE_CACHE_L2X0                      
975         bool                                      
976         help                                      
977           This option should be selected by ma    
978           or PL310 cache controller, but where    
979                                                   
980           The only effect of this option is to    
981           related options available to the use    
982                                                   
983           Boards or SoCs which always require     
984           support to be present should select     
985           instead of this option, thus prevent    
986           inadvertently configuring a broken k    
987                                                   
988 config CACHE_L2X0                                 
989         bool "Enable the L2x0 outer cache cont    
990         default MIGHT_HAVE_CACHE_L2X0             
991         select OUTER_CACHE                        
992         select OUTER_CACHE_SYNC                   
993         help                                      
994           This option enables the L2x0 PrimeCe    
995                                                   
996 config CACHE_L2X0_PMU                             
997         bool "L2x0 performance monitor support    
998         depends on PERF_EVENTS                    
999         help                                      
1000           This option enables support for the    
1001           of the L220 and PL310 outer cache c    
1002                                                  
1003 if CACHE_L2X0                                    
1004                                                  
1005 config PL310_ERRATA_588369                       
1006         bool "PL310 errata: Clean & Invalidat    
1007         help                                     
1008            The PL310 L2 cache controller impl    
1009            Invalidate maintenance operations:    
1010            (offset 0x7F0), by Index/Way (0x7F    
1011            They are architecturally defined t    
1012            clean operation followed immediate    
1013            both performing to the same memory    
1014            is not correctly implemented in PL    
1015            as clean lines are not invalidated    
1016                                                  
1017 config PL310_ERRATA_727915                       
1018         bool "PL310 errata: Background Clean     
1019         help                                     
1020           PL310 implements the Clean & Invali    
1021           operation (offset 0x7FC). This oper    
1022           PL310 can handle normal accesses wh    
1023           rare circumstances, due to this err    
1024           PL310 treats a cacheable write tran    
1025           Invalidate by Way operation.  Revis    
1026           this errata (fixed in r3p1).           
1027                                                  
1028 config PL310_ERRATA_753970                       
1029         bool "PL310 errata: cache sync operat    
1030         help                                     
1031           This option enables the workaround     
1032                                                  
1033           Under some condition the effect of     
1034           the store buffer still remains when    
1035           This means that the store buffer is    
1036           this prevents it from merging any f    
1037           is to replace the normal offset of     
1038           by another offset targeting an unma    
1039           This has the same effect as the cac    
1040           drain and waiting for all buffers e    
1041                                                  
1042 config PL310_ERRATA_769419                       
1043         bool "PL310 errata: no automatic Stor    
1044         help                                     
1045           On revisions of the PL310 prior to     
1046           not automatically drain. This can c    
1047           writes to be retained when the memo    
1048           to suboptimal I/O performance for d    
1049           This option adds a write barrier to    
1050           on systems with an outer cache, the    
1051           explicitly.                            
1052                                                  
1053 endif                                            
1054                                                  
1055 config CACHE_TAUROS2                             
1056         bool "Enable the Tauros2 L2 cache con    
1057         depends on (CPU_MOHAWK || CPU_PJ4)       
1058         default y                                
1059         select OUTER_CACHE                       
1060         help                                     
1061           This option enables the Tauros2 L2     
1062           found on PJ1/PJ4).                     
1063                                                  
1064 config CACHE_UNIPHIER                            
1065         bool "Enable the UniPhier outer cache    
1066         depends on ARCH_UNIPHIER                 
1067         select ARM_L1_CACHE_SHIFT_7              
1068         select OUTER_CACHE                       
1069         select OUTER_CACHE_SYNC                  
1070         help                                     
1071           This option enables the UniPhier ou    
1072           controller.                            
1073                                                  
1074 config CACHE_XSC3L2                              
1075         bool "Enable the L2 cache on XScale3"    
1076         depends on CPU_XSC3                      
1077         default y                                
1078         select OUTER_CACHE                       
1079         help                                     
1080           This option enables the L2 cache on    
1081                                                  
1082 config ARM_L1_CACHE_SHIFT_6                      
1083         bool                                     
1084         default y if CPU_V7                      
1085         help                                     
1086           Setting ARM L1 cache line size to 6    
1087                                                  
1088 config ARM_L1_CACHE_SHIFT_7                      
1089         bool                                     
1090         help                                     
1091           Setting ARM L1 cache line size to 1    
1092                                                  
1093 config ARM_L1_CACHE_SHIFT                        
1094         int                                      
1095         default 7 if ARM_L1_CACHE_SHIFT_7        
1096         default 6 if ARM_L1_CACHE_SHIFT_6        
1097         default 5                                
1098                                                  
1099 config ARM_DMA_MEM_BUFFERABLE                    
1100         bool "Use non-cacheable memory for DM    
1101         default y if CPU_V6 || CPU_V6K || CPU    
1102         help                                     
1103           Historically, the kernel has used s    
1104           provide DMA coherent memory.  With     
1105           memory with differing types results    
1106           so on these CPUs, this option is fo    
1107                                                  
1108           Multiple mappings with differing at    
1109           on ARMv6 CPUs, but since they do no    
1110           prefetch, no harm appears to occur.    
1111                                                  
1112           However, drivers may be missing the    
1113           and therefore turning this on may r    
1114           behaviour.  Therefore, we offer thi    
1115                                                  
1116           On some of the beefier ARMv7-M mach    
1117           buffers) you likely want this enabl    
1118           didn't need it until now also won't    
1119                                                  
1120           You are recommended say 'Y' here an    
1121                                                  
1122 config ARM_HEAVY_MB                              
1123         bool                                     
1124                                                  
1125 config DEBUG_ALIGN_RODATA                        
1126         bool "Make rodata strictly non-execut    
1127         depends on STRICT_KERNEL_RWX             
1128         default y                                
1129         help                                     
1130           If this is set, rodata will be made    
1131           provides protection on the rare cha    
1132           use ROP gadgets that exist in the r    
1133           additional section-aligned split of    
1134           can be made explicitly non-executab    
1135           space to gain the additional protec    
                                                      

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