xref: /linux/arch/arm/mm/Kconfig (revision c786282e6dd18fe2ff43ab44411085dc40e7fbc5)
11da177e4SLinus Torvaldscomment "Processor Type"
21da177e4SLinus Torvalds
31da177e4SLinus Torvalds# Select CPU types depending on the architecture selected.  This selects
41da177e4SLinus Torvalds# which CPUs we support in the kernel image, and the compiler instruction
51da177e4SLinus Torvalds# optimiser behaviour.
61da177e4SLinus Torvalds
71da177e4SLinus Torvalds# ARM610
81da177e4SLinus Torvaldsconfig CPU_ARM610
9c750815eSRussell King	bool "Support ARM610 processor" if ARCH_RPC
101da177e4SLinus Torvalds	select CPU_32v3
111da177e4SLinus Torvalds	select CPU_CACHE_V3
121da177e4SLinus Torvalds	select CPU_CACHE_VIVT
13fefdaa06SHyok S. Choi	select CPU_CP15_MMU
14f9c21a6eSHyok S. Choi	select CPU_COPY_V3 if MMU
15f9c21a6eSHyok S. Choi	select CPU_TLB_V3 if MMU
164fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
171da177e4SLinus Torvalds	help
181da177e4SLinus Torvalds	  The ARM610 is the successor to the ARM3 processor
191da177e4SLinus Torvalds	  and was produced by VLSI Technology Inc.
201da177e4SLinus Torvalds
211da177e4SLinus Torvalds	  Say Y if you want support for the ARM610 processor.
221da177e4SLinus Torvalds	  Otherwise, say N.
231da177e4SLinus Torvalds
2407e0da78SHyok S. Choi# ARM7TDMI
2507e0da78SHyok S. Choiconfig CPU_ARM7TDMI
2607e0da78SHyok S. Choi	bool "Support ARM7TDMI processor"
276b237a35SRussell King	depends on !MMU
2807e0da78SHyok S. Choi	select CPU_32v4T
2907e0da78SHyok S. Choi	select CPU_ABRT_LV4T
304fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
3107e0da78SHyok S. Choi	select CPU_CACHE_V4
3207e0da78SHyok S. Choi	help
3307e0da78SHyok S. Choi	  A 32-bit RISC microprocessor based on the ARM7 processor core
3407e0da78SHyok S. Choi	  which has no memory control unit and cache.
3507e0da78SHyok S. Choi
3607e0da78SHyok S. Choi	  Say Y if you want support for the ARM7TDMI processor.
3707e0da78SHyok S. Choi	  Otherwise, say N.
3807e0da78SHyok S. Choi
391da177e4SLinus Torvalds# ARM710
401da177e4SLinus Torvaldsconfig CPU_ARM710
41c750815eSRussell King	bool "Support ARM710 processor" if ARCH_RPC
421da177e4SLinus Torvalds	select CPU_32v3
431da177e4SLinus Torvalds	select CPU_CACHE_V3
441da177e4SLinus Torvalds	select CPU_CACHE_VIVT
45fefdaa06SHyok S. Choi	select CPU_CP15_MMU
46f9c21a6eSHyok S. Choi	select CPU_COPY_V3 if MMU
47f9c21a6eSHyok S. Choi	select CPU_TLB_V3 if MMU
484fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
491da177e4SLinus Torvalds	help
501da177e4SLinus Torvalds	  A 32-bit RISC microprocessor based on the ARM7 processor core
511da177e4SLinus Torvalds	  designed by Advanced RISC Machines Ltd. The ARM710 is the
521da177e4SLinus Torvalds	  successor to the ARM610 processor. It was released in
531da177e4SLinus Torvalds	  July 1994 by VLSI Technology Inc.
541da177e4SLinus Torvalds
551da177e4SLinus Torvalds	  Say Y if you want support for the ARM710 processor.
561da177e4SLinus Torvalds	  Otherwise, say N.
571da177e4SLinus Torvalds
581da177e4SLinus Torvalds# ARM720T
591da177e4SLinus Torvaldsconfig CPU_ARM720T
60c750815eSRussell King	bool "Support ARM720T processor" if ARCH_INTEGRATOR
61260e98edSLennert Buytenhek	select CPU_32v4T
621da177e4SLinus Torvalds	select CPU_ABRT_LV4T
634fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
641da177e4SLinus Torvalds	select CPU_CACHE_V4
651da177e4SLinus Torvalds	select CPU_CACHE_VIVT
66fefdaa06SHyok S. Choi	select CPU_CP15_MMU
67f9c21a6eSHyok S. Choi	select CPU_COPY_V4WT if MMU
68f9c21a6eSHyok S. Choi	select CPU_TLB_V4WT if MMU
691da177e4SLinus Torvalds	help
701da177e4SLinus Torvalds	  A 32-bit RISC processor with 8kByte Cache, Write Buffer and
711da177e4SLinus Torvalds	  MMU built around an ARM7TDMI core.
721da177e4SLinus Torvalds
731da177e4SLinus Torvalds	  Say Y if you want support for the ARM720T processor.
741da177e4SLinus Torvalds	  Otherwise, say N.
751da177e4SLinus Torvalds
76b731c311SHyok S. Choi# ARM740T
77b731c311SHyok S. Choiconfig CPU_ARM740T
78b731c311SHyok S. Choi	bool "Support ARM740T processor" if ARCH_INTEGRATOR
796b237a35SRussell King	depends on !MMU
80b731c311SHyok S. Choi	select CPU_32v4T
81b731c311SHyok S. Choi	select CPU_ABRT_LV4T
824fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
83b731c311SHyok S. Choi	select CPU_CACHE_V3	# although the core is v4t
84b731c311SHyok S. Choi	select CPU_CP15_MPU
85b731c311SHyok S. Choi	help
86b731c311SHyok S. Choi	  A 32-bit RISC processor with 8KB cache or 4KB variants,
87b731c311SHyok S. Choi	  write buffer and MPU(Protection Unit) built around
88b731c311SHyok S. Choi	  an ARM7TDMI core.
89b731c311SHyok S. Choi
90b731c311SHyok S. Choi	  Say Y if you want support for the ARM740T processor.
91b731c311SHyok S. Choi	  Otherwise, say N.
92b731c311SHyok S. Choi
9343f5f014SHyok S. Choi# ARM9TDMI
9443f5f014SHyok S. Choiconfig CPU_ARM9TDMI
9543f5f014SHyok S. Choi	bool "Support ARM9TDMI processor"
966b237a35SRussell King	depends on !MMU
9743f5f014SHyok S. Choi	select CPU_32v4T
980f45d7f3SHyok S. Choi	select CPU_ABRT_NOMMU
994fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
10043f5f014SHyok S. Choi	select CPU_CACHE_V4
10143f5f014SHyok S. Choi	help
10243f5f014SHyok S. Choi	  A 32-bit RISC microprocessor based on the ARM9 processor core
10343f5f014SHyok S. Choi	  which has no memory control unit and cache.
10443f5f014SHyok S. Choi
10543f5f014SHyok S. Choi	  Say Y if you want support for the ARM9TDMI processor.
10643f5f014SHyok S. Choi	  Otherwise, say N.
10743f5f014SHyok S. Choi
1081da177e4SLinus Torvalds# ARM920T
1091da177e4SLinus Torvaldsconfig CPU_ARM920T
110c750815eSRussell King	bool "Support ARM920T processor" if ARCH_INTEGRATOR
111260e98edSLennert Buytenhek	select CPU_32v4T
1121da177e4SLinus Torvalds	select CPU_ABRT_EV4T
1134fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1141da177e4SLinus Torvalds	select CPU_CACHE_V4WT
1151da177e4SLinus Torvalds	select CPU_CACHE_VIVT
116fefdaa06SHyok S. Choi	select CPU_CP15_MMU
117f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
118f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1191da177e4SLinus Torvalds	help
1201da177e4SLinus Torvalds	  The ARM920T is licensed to be produced by numerous vendors,
121c768e676SHartley Sweeten	  and is used in the Cirrus EP93xx and the Samsung S3C2410.
1221da177e4SLinus Torvalds
1231da177e4SLinus Torvalds	  Say Y if you want support for the ARM920T processor.
1241da177e4SLinus Torvalds	  Otherwise, say N.
1251da177e4SLinus Torvalds
1261da177e4SLinus Torvalds# ARM922T
1271da177e4SLinus Torvaldsconfig CPU_ARM922T
1281da177e4SLinus Torvalds	bool "Support ARM922T processor" if ARCH_INTEGRATOR
129260e98edSLennert Buytenhek	select CPU_32v4T
1301da177e4SLinus Torvalds	select CPU_ABRT_EV4T
1314fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1321da177e4SLinus Torvalds	select CPU_CACHE_V4WT
1331da177e4SLinus Torvalds	select CPU_CACHE_VIVT
134fefdaa06SHyok S. Choi	select CPU_CP15_MMU
135f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
136f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1371da177e4SLinus Torvalds	help
1381da177e4SLinus Torvalds	  The ARM922T is a version of the ARM920T, but with smaller
1391da177e4SLinus Torvalds	  instruction and data caches. It is used in Altera's
140c53c9cf6SAndrew Victor	  Excalibur XA device family and Micrel's KS8695 Centaur.
1411da177e4SLinus Torvalds
1421da177e4SLinus Torvalds	  Say Y if you want support for the ARM922T processor.
1431da177e4SLinus Torvalds	  Otherwise, say N.
1441da177e4SLinus Torvalds
1451da177e4SLinus Torvalds# ARM925T
1461da177e4SLinus Torvaldsconfig CPU_ARM925T
147b288f75fSTony Lindgren 	bool "Support ARM925T processor" if ARCH_OMAP1
148260e98edSLennert Buytenhek	select CPU_32v4T
1491da177e4SLinus Torvalds	select CPU_ABRT_EV4T
1504fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1511da177e4SLinus Torvalds	select CPU_CACHE_V4WT
1521da177e4SLinus Torvalds	select CPU_CACHE_VIVT
153fefdaa06SHyok S. Choi	select CPU_CP15_MMU
154f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
155f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1561da177e4SLinus Torvalds 	help
1571da177e4SLinus Torvalds 	  The ARM925T is a mix between the ARM920T and ARM926T, but with
1581da177e4SLinus Torvalds	  different instruction and data caches. It is used in TI's OMAP
1591da177e4SLinus Torvalds 	  device family.
1601da177e4SLinus Torvalds
1611da177e4SLinus Torvalds 	  Say Y if you want support for the ARM925T processor.
1621da177e4SLinus Torvalds 	  Otherwise, say N.
1631da177e4SLinus Torvalds
1641da177e4SLinus Torvalds# ARM926T
1651da177e4SLinus Torvaldsconfig CPU_ARM926T
166c750815eSRussell King	bool "Support ARM926T processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB
1671da177e4SLinus Torvalds	select CPU_32v5
1681da177e4SLinus Torvalds	select CPU_ABRT_EV5TJ
1694fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1701da177e4SLinus Torvalds	select CPU_CACHE_VIVT
171fefdaa06SHyok S. Choi	select CPU_CP15_MMU
172f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
173f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1741da177e4SLinus Torvalds	help
1751da177e4SLinus Torvalds	  This is a variant of the ARM920.  It has slightly different
1761da177e4SLinus Torvalds	  instruction sequences for cache and TLB operations.  Curiously,
1771da177e4SLinus Torvalds	  there is no documentation on it at the ARM corporate website.
1781da177e4SLinus Torvalds
1791da177e4SLinus Torvalds	  Say Y if you want support for the ARM926T processor.
1801da177e4SLinus Torvalds	  Otherwise, say N.
1811da177e4SLinus Torvalds
18228853ac8SPaulius Zaleckas# FA526
18328853ac8SPaulius Zaleckasconfig CPU_FA526
18428853ac8SPaulius Zaleckas	bool
18528853ac8SPaulius Zaleckas	select CPU_32v4
18628853ac8SPaulius Zaleckas	select CPU_ABRT_EV4
1874fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
18828853ac8SPaulius Zaleckas	select CPU_CACHE_VIVT
18928853ac8SPaulius Zaleckas	select CPU_CP15_MMU
19028853ac8SPaulius Zaleckas	select CPU_CACHE_FA
19128853ac8SPaulius Zaleckas	select CPU_COPY_FA if MMU
19228853ac8SPaulius Zaleckas	select CPU_TLB_FA if MMU
19328853ac8SPaulius Zaleckas	help
19428853ac8SPaulius Zaleckas	  The FA526 is a version of the ARMv4 compatible processor with
19528853ac8SPaulius Zaleckas	  Branch Target Buffer, Unified TLB and cache line size 16.
19628853ac8SPaulius Zaleckas
19728853ac8SPaulius Zaleckas	  Say Y if you want support for the FA526 processor.
19828853ac8SPaulius Zaleckas	  Otherwise, say N.
19928853ac8SPaulius Zaleckas
200d60674ebSHyok S. Choi# ARM940T
201d60674ebSHyok S. Choiconfig CPU_ARM940T
202d60674ebSHyok S. Choi	bool "Support ARM940T processor" if ARCH_INTEGRATOR
2036b237a35SRussell King	depends on !MMU
204d60674ebSHyok S. Choi	select CPU_32v4T
2050f45d7f3SHyok S. Choi	select CPU_ABRT_NOMMU
2064fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
207d60674ebSHyok S. Choi	select CPU_CACHE_VIVT
208d60674ebSHyok S. Choi	select CPU_CP15_MPU
209d60674ebSHyok S. Choi	help
210d60674ebSHyok S. Choi	  ARM940T is a member of the ARM9TDMI family of general-
2113cb2fcccSMatt LaPlante	  purpose microprocessors with MPU and separate 4KB
212d60674ebSHyok S. Choi	  instruction and 4KB data cases, each with a 4-word line
213d60674ebSHyok S. Choi	  length.
214d60674ebSHyok S. Choi
215d60674ebSHyok S. Choi	  Say Y if you want support for the ARM940T processor.
216d60674ebSHyok S. Choi	  Otherwise, say N.
217d60674ebSHyok S. Choi
218f37f46ebSHyok S. Choi# ARM946E-S
219f37f46ebSHyok S. Choiconfig CPU_ARM946E
220f37f46ebSHyok S. Choi	bool "Support ARM946E-S processor" if ARCH_INTEGRATOR
2216b237a35SRussell King	depends on !MMU
222f37f46ebSHyok S. Choi	select CPU_32v5
2230f45d7f3SHyok S. Choi	select CPU_ABRT_NOMMU
2244fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
225f37f46ebSHyok S. Choi	select CPU_CACHE_VIVT
226f37f46ebSHyok S. Choi	select CPU_CP15_MPU
227f37f46ebSHyok S. Choi	help
228f37f46ebSHyok S. Choi	  ARM946E-S is a member of the ARM9E-S family of high-
229f37f46ebSHyok S. Choi	  performance, 32-bit system-on-chip processor solutions.
230f37f46ebSHyok S. Choi	  The TCM and ARMv5TE 32-bit instruction set is supported.
231f37f46ebSHyok S. Choi
232f37f46ebSHyok S. Choi	  Say Y if you want support for the ARM946E-S processor.
233f37f46ebSHyok S. Choi	  Otherwise, say N.
234f37f46ebSHyok S. Choi
2351da177e4SLinus Torvalds# ARM1020 - needs validating
2361da177e4SLinus Torvaldsconfig CPU_ARM1020
237c750815eSRussell King	bool "Support ARM1020T (rev 0) processor" if ARCH_INTEGRATOR
2381da177e4SLinus Torvalds	select CPU_32v5
2391da177e4SLinus Torvalds	select CPU_ABRT_EV4T
2404fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2411da177e4SLinus Torvalds	select CPU_CACHE_V4WT
2421da177e4SLinus Torvalds	select CPU_CACHE_VIVT
243fefdaa06SHyok S. Choi	select CPU_CP15_MMU
244f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
245f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2461da177e4SLinus Torvalds	help
2471da177e4SLinus Torvalds	  The ARM1020 is the 32K cached version of the ARM10 processor,
2481da177e4SLinus Torvalds	  with an addition of a floating-point unit.
2491da177e4SLinus Torvalds
2501da177e4SLinus Torvalds	  Say Y if you want support for the ARM1020 processor.
2511da177e4SLinus Torvalds	  Otherwise, say N.
2521da177e4SLinus Torvalds
2531da177e4SLinus Torvalds# ARM1020E - needs validating
2541da177e4SLinus Torvaldsconfig CPU_ARM1020E
255c750815eSRussell King	bool "Support ARM1020E processor" if ARCH_INTEGRATOR
2561da177e4SLinus Torvalds	select CPU_32v5
2571da177e4SLinus Torvalds	select CPU_ABRT_EV4T
2584fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2591da177e4SLinus Torvalds	select CPU_CACHE_V4WT
2601da177e4SLinus Torvalds	select CPU_CACHE_VIVT
261fefdaa06SHyok S. Choi	select CPU_CP15_MMU
262f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
263f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2641da177e4SLinus Torvalds	depends on n
2651da177e4SLinus Torvalds
2661da177e4SLinus Torvalds# ARM1022E
2671da177e4SLinus Torvaldsconfig CPU_ARM1022
268c750815eSRussell King	bool "Support ARM1022E processor" if ARCH_INTEGRATOR
2691da177e4SLinus Torvalds	select CPU_32v5
2701da177e4SLinus Torvalds	select CPU_ABRT_EV4T
2714fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2721da177e4SLinus Torvalds	select CPU_CACHE_VIVT
273fefdaa06SHyok S. Choi	select CPU_CP15_MMU
274f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU # can probably do better
275f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2761da177e4SLinus Torvalds	help
2771da177e4SLinus Torvalds	  The ARM1022E is an implementation of the ARMv5TE architecture
2781da177e4SLinus Torvalds	  based upon the ARM10 integer core with a 16KiB L1 Harvard cache,
2791da177e4SLinus Torvalds	  embedded trace macrocell, and a floating-point unit.
2801da177e4SLinus Torvalds
2811da177e4SLinus Torvalds	  Say Y if you want support for the ARM1022E processor.
2821da177e4SLinus Torvalds	  Otherwise, say N.
2831da177e4SLinus Torvalds
2841da177e4SLinus Torvalds# ARM1026EJ-S
2851da177e4SLinus Torvaldsconfig CPU_ARM1026
286c750815eSRussell King	bool "Support ARM1026EJ-S processor" if ARCH_INTEGRATOR
2871da177e4SLinus Torvalds	select CPU_32v5
2881da177e4SLinus Torvalds	select CPU_ABRT_EV5T # But need Jazelle, but EV5TJ ignores bit 10
2894fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2901da177e4SLinus Torvalds	select CPU_CACHE_VIVT
291fefdaa06SHyok S. Choi	select CPU_CP15_MMU
292f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU # can probably do better
293f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2941da177e4SLinus Torvalds	help
2951da177e4SLinus Torvalds	  The ARM1026EJ-S is an implementation of the ARMv5TEJ architecture
2961da177e4SLinus Torvalds	  based upon the ARM10 integer core.
2971da177e4SLinus Torvalds
2981da177e4SLinus Torvalds	  Say Y if you want support for the ARM1026EJ-S processor.
2991da177e4SLinus Torvalds	  Otherwise, say N.
3001da177e4SLinus Torvalds
3011da177e4SLinus Torvalds# SA110
3021da177e4SLinus Torvaldsconfig CPU_SA110
303c750815eSRussell King	bool "Support StrongARM(R) SA-110 processor" if ARCH_RPC
3041da177e4SLinus Torvalds	select CPU_32v3 if ARCH_RPC
3051da177e4SLinus Torvalds	select CPU_32v4 if !ARCH_RPC
3061da177e4SLinus Torvalds	select CPU_ABRT_EV4
3074fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
3081da177e4SLinus Torvalds	select CPU_CACHE_V4WB
3091da177e4SLinus Torvalds	select CPU_CACHE_VIVT
310fefdaa06SHyok S. Choi	select CPU_CP15_MMU
311f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
312f9c21a6eSHyok S. Choi	select CPU_TLB_V4WB if MMU
3131da177e4SLinus Torvalds	help
3141da177e4SLinus Torvalds	  The Intel StrongARM(R) SA-110 is a 32-bit microprocessor and
3151da177e4SLinus Torvalds	  is available at five speeds ranging from 100 MHz to 233 MHz.
3161da177e4SLinus Torvalds	  More information is available at
3171da177e4SLinus Torvalds	  <http://developer.intel.com/design/strong/sa110.htm>.
3181da177e4SLinus Torvalds
3191da177e4SLinus Torvalds	  Say Y if you want support for the SA-110 processor.
3201da177e4SLinus Torvalds	  Otherwise, say N.
3211da177e4SLinus Torvalds
3221da177e4SLinus Torvalds# SA1100
3231da177e4SLinus Torvaldsconfig CPU_SA1100
3241da177e4SLinus Torvalds	bool
3251da177e4SLinus Torvalds	select CPU_32v4
3261da177e4SLinus Torvalds	select CPU_ABRT_EV4
3274fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
3281da177e4SLinus Torvalds	select CPU_CACHE_V4WB
3291da177e4SLinus Torvalds	select CPU_CACHE_VIVT
330fefdaa06SHyok S. Choi	select CPU_CP15_MMU
331f9c21a6eSHyok S. Choi	select CPU_TLB_V4WB if MMU
3321da177e4SLinus Torvalds
3331da177e4SLinus Torvalds# XScale
3341da177e4SLinus Torvaldsconfig CPU_XSCALE
3351da177e4SLinus Torvalds	bool
3361da177e4SLinus Torvalds	select CPU_32v5
3371da177e4SLinus Torvalds	select CPU_ABRT_EV5T
3384fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
3391da177e4SLinus Torvalds	select CPU_CACHE_VIVT
340fefdaa06SHyok S. Choi	select CPU_CP15_MMU
341f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
3421da177e4SLinus Torvalds
34323bdf86aSLennert Buytenhek# XScale Core Version 3
34423bdf86aSLennert Buytenhekconfig CPU_XSC3
34523bdf86aSLennert Buytenhek	bool
34623bdf86aSLennert Buytenhek	select CPU_32v5
34723bdf86aSLennert Buytenhek	select CPU_ABRT_EV5T
3484fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
34923bdf86aSLennert Buytenhek	select CPU_CACHE_VIVT
350fefdaa06SHyok S. Choi	select CPU_CP15_MMU
351f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
35223bdf86aSLennert Buytenhek	select IO_36
35323bdf86aSLennert Buytenhek
35449cbe786SEric Miao# Marvell PJ1 (Mohawk)
35549cbe786SEric Miaoconfig CPU_MOHAWK
35649cbe786SEric Miao	bool
35749cbe786SEric Miao	select CPU_32v5
35849cbe786SEric Miao	select CPU_ABRT_EV5T
3594fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
36049cbe786SEric Miao	select CPU_CACHE_VIVT
36149cbe786SEric Miao	select CPU_CP15_MMU
36249cbe786SEric Miao	select CPU_TLB_V4WBI if MMU
36349cbe786SEric Miao	select CPU_COPY_V4WB if MMU
36449cbe786SEric Miao
365e50d6409SAssaf Hoffman# Feroceon
366e50d6409SAssaf Hoffmanconfig CPU_FEROCEON
367e50d6409SAssaf Hoffman	bool
368e50d6409SAssaf Hoffman	select CPU_32v5
369e50d6409SAssaf Hoffman	select CPU_ABRT_EV5T
3704fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
371e50d6409SAssaf Hoffman	select CPU_CACHE_VIVT
372e50d6409SAssaf Hoffman	select CPU_CP15_MMU
3730ed15071SLennert Buytenhek	select CPU_COPY_FEROCEON if MMU
37499c6dc11SLennert Buytenhek	select CPU_TLB_FEROCEON if MMU
375e50d6409SAssaf Hoffman
376d910a0aaSTzachi Perelsteinconfig CPU_FEROCEON_OLD_ID
377d910a0aaSTzachi Perelstein	bool "Accept early Feroceon cores with an ARM926 ID"
378d910a0aaSTzachi Perelstein	depends on CPU_FEROCEON && !CPU_ARM926T
379d910a0aaSTzachi Perelstein	default y
380d910a0aaSTzachi Perelstein	help
381d910a0aaSTzachi Perelstein	  This enables the usage of some old Feroceon cores
382d910a0aaSTzachi Perelstein	  for which the CPU ID is equal to the ARM926 ID.
383d910a0aaSTzachi Perelstein	  Relevant for Feroceon-1850 and early Feroceon-2850.
384d910a0aaSTzachi Perelstein
385a4553358SHaojian Zhuang# Marvell PJ4
386a4553358SHaojian Zhuangconfig CPU_PJ4
387a4553358SHaojian Zhuang	bool
388a4553358SHaojian Zhuang	select CPU_V7
389a4553358SHaojian Zhuang	select ARM_THUMBEE
390a4553358SHaojian Zhuang
3911da177e4SLinus Torvalds# ARMv6
3921da177e4SLinus Torvaldsconfig CPU_V6
393*c786282eSRussell King	bool "Support ARM V6 processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX
3941da177e4SLinus Torvalds	select CPU_32v6
3951da177e4SLinus Torvalds	select CPU_ABRT_EV6
3964fb28474SKirill A. Shutemov	select CPU_PABRT_V6
3971da177e4SLinus Torvalds	select CPU_CACHE_V6
3981da177e4SLinus Torvalds	select CPU_CACHE_VIPT
399fefdaa06SHyok S. Choi	select CPU_CP15_MMU
4007b4c965aSCatalin Marinas	select CPU_HAS_ASID if MMU
401f9c21a6eSHyok S. Choi	select CPU_COPY_V6 if MMU
402f9c21a6eSHyok S. Choi	select CPU_TLB_V6 if MMU
4031da177e4SLinus Torvalds
4044a5f79e7SRussell King# ARMv6k
405e399b1a4SRussell Kingconfig CPU_V6K
406*c786282eSRussell King	bool "Support ARM V6K processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX
407e399b1a4SRussell King	select CPU_32v6
408e399b1a4SRussell King	select CPU_32v6K if !ARCH_OMAP2
409e399b1a4SRussell King	select CPU_ABRT_EV6
410e399b1a4SRussell King	select CPU_PABRT_V6
411e399b1a4SRussell King	select CPU_CACHE_V6
412e399b1a4SRussell King	select CPU_CACHE_VIPT
413e399b1a4SRussell King	select CPU_CP15_MMU
414e399b1a4SRussell King	select CPU_HAS_ASID if MMU
415e399b1a4SRussell King	select CPU_COPY_V6 if MMU
416e399b1a4SRussell King	select CPU_TLB_V6 if MMU
4174a5f79e7SRussell King
41823688e99SCatalin Marinas# ARMv7
41923688e99SCatalin Marinasconfig CPU_V7
4201b504bbeSColin Tuckley	bool "Support ARM V7 processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX
4211a28e3d9STony Lindgren	select CPU_32v6K if !ARCH_OMAP2
42223688e99SCatalin Marinas	select CPU_32v7
42323688e99SCatalin Marinas	select CPU_ABRT_EV7
4244fb28474SKirill A. Shutemov	select CPU_PABRT_V7
42523688e99SCatalin Marinas	select CPU_CACHE_V7
42623688e99SCatalin Marinas	select CPU_CACHE_VIPT
42723688e99SCatalin Marinas	select CPU_CP15_MMU
4282eb8c82bSCatalin Marinas	select CPU_HAS_ASID if MMU
42923688e99SCatalin Marinas	select CPU_COPY_V6 if MMU
4302ccdd1e7SCatalin Marinas	select CPU_TLB_V7 if MMU
43123688e99SCatalin Marinas
4321da177e4SLinus Torvalds# Figure out what processor architecture version we should be using.
4331da177e4SLinus Torvalds# This defines the compiler instruction set which depends on the machine type.
4341da177e4SLinus Torvaldsconfig CPU_32v3
4351da177e4SLinus Torvalds	bool
43660b6cf68SRussell King	select TLS_REG_EMUL if SMP || !MMU
43748fa14f7SRussell King	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4381da177e4SLinus Torvalds
4391da177e4SLinus Torvaldsconfig CPU_32v4
4401da177e4SLinus Torvalds	bool
44160b6cf68SRussell King	select TLS_REG_EMUL if SMP || !MMU
44248fa14f7SRussell King	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4431da177e4SLinus Torvalds
444260e98edSLennert Buytenhekconfig CPU_32v4T
445260e98edSLennert Buytenhek	bool
446260e98edSLennert Buytenhek	select TLS_REG_EMUL if SMP || !MMU
447260e98edSLennert Buytenhek	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
448260e98edSLennert Buytenhek
4491da177e4SLinus Torvaldsconfig CPU_32v5
4501da177e4SLinus Torvalds	bool
45160b6cf68SRussell King	select TLS_REG_EMUL if SMP || !MMU
45248fa14f7SRussell King	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4531da177e4SLinus Torvalds
4541da177e4SLinus Torvaldsconfig CPU_32v6
4551da177e4SLinus Torvalds	bool
456367afaf8SCatalin Marinas	select TLS_REG_EMUL if !CPU_32v6K && !MMU
4571da177e4SLinus Torvalds
458e399b1a4SRussell Kingconfig CPU_32v6K
459e399b1a4SRussell King	bool "Support ARM V6K processor extensions" if !SMP
460e399b1a4SRussell King	depends on CPU_V6 || CPU_V6K || CPU_V7
461e399b1a4SRussell King	default y if SMP && !(ARCH_MX3 || ARCH_OMAP2)
462e399b1a4SRussell King	help
463e399b1a4SRussell King	  Say Y here if your ARMv6 processor supports the 'K' extension.
464e399b1a4SRussell King	  This enables the kernel to use some instructions not present
465e399b1a4SRussell King	  on previous processors, and as such a kernel build with this
466e399b1a4SRussell King	  enabled will not boot on processors with do not support these
467e399b1a4SRussell King	  instructions.
468e399b1a4SRussell King
46923688e99SCatalin Marinasconfig CPU_32v7
47023688e99SCatalin Marinas	bool
47123688e99SCatalin Marinas
4721da177e4SLinus Torvalds# The abort model
4730f45d7f3SHyok S. Choiconfig CPU_ABRT_NOMMU
4740f45d7f3SHyok S. Choi	bool
4750f45d7f3SHyok S. Choi
4761da177e4SLinus Torvaldsconfig CPU_ABRT_EV4
4771da177e4SLinus Torvalds	bool
4781da177e4SLinus Torvalds
4791da177e4SLinus Torvaldsconfig CPU_ABRT_EV4T
4801da177e4SLinus Torvalds	bool
4811da177e4SLinus Torvalds
4821da177e4SLinus Torvaldsconfig CPU_ABRT_LV4T
4831da177e4SLinus Torvalds	bool
4841da177e4SLinus Torvalds
4851da177e4SLinus Torvaldsconfig CPU_ABRT_EV5T
4861da177e4SLinus Torvalds	bool
4871da177e4SLinus Torvalds
4881da177e4SLinus Torvaldsconfig CPU_ABRT_EV5TJ
4891da177e4SLinus Torvalds	bool
4901da177e4SLinus Torvalds
4911da177e4SLinus Torvaldsconfig CPU_ABRT_EV6
4921da177e4SLinus Torvalds	bool
4931da177e4SLinus Torvalds
49423688e99SCatalin Marinasconfig CPU_ABRT_EV7
49523688e99SCatalin Marinas	bool
49623688e99SCatalin Marinas
4974fb28474SKirill A. Shutemovconfig CPU_PABRT_LEGACY
49848d7927bSPaul Brook	bool
49948d7927bSPaul Brook
5004fb28474SKirill A. Shutemovconfig CPU_PABRT_V6
5014fb28474SKirill A. Shutemov	bool
5024fb28474SKirill A. Shutemov
5034fb28474SKirill A. Shutemovconfig CPU_PABRT_V7
50448d7927bSPaul Brook	bool
50548d7927bSPaul Brook
5061da177e4SLinus Torvalds# The cache model
5071da177e4SLinus Torvaldsconfig CPU_CACHE_V3
5081da177e4SLinus Torvalds	bool
5091da177e4SLinus Torvalds
5101da177e4SLinus Torvaldsconfig CPU_CACHE_V4
5111da177e4SLinus Torvalds	bool
5121da177e4SLinus Torvalds
5131da177e4SLinus Torvaldsconfig CPU_CACHE_V4WT
5141da177e4SLinus Torvalds	bool
5151da177e4SLinus Torvalds
5161da177e4SLinus Torvaldsconfig CPU_CACHE_V4WB
5171da177e4SLinus Torvalds	bool
5181da177e4SLinus Torvalds
5191da177e4SLinus Torvaldsconfig CPU_CACHE_V6
5201da177e4SLinus Torvalds	bool
5211da177e4SLinus Torvalds
52223688e99SCatalin Marinasconfig CPU_CACHE_V7
52323688e99SCatalin Marinas	bool
52423688e99SCatalin Marinas
5251da177e4SLinus Torvaldsconfig CPU_CACHE_VIVT
5261da177e4SLinus Torvalds	bool
5271da177e4SLinus Torvalds
5281da177e4SLinus Torvaldsconfig CPU_CACHE_VIPT
5291da177e4SLinus Torvalds	bool
5301da177e4SLinus Torvalds
53128853ac8SPaulius Zaleckasconfig CPU_CACHE_FA
53228853ac8SPaulius Zaleckas	bool
53328853ac8SPaulius Zaleckas
534f9c21a6eSHyok S. Choiif MMU
5351da177e4SLinus Torvalds# The copy-page model
5361da177e4SLinus Torvaldsconfig CPU_COPY_V3
5371da177e4SLinus Torvalds	bool
5381da177e4SLinus Torvalds
5391da177e4SLinus Torvaldsconfig CPU_COPY_V4WT
5401da177e4SLinus Torvalds	bool
5411da177e4SLinus Torvalds
5421da177e4SLinus Torvaldsconfig CPU_COPY_V4WB
5431da177e4SLinus Torvalds	bool
5441da177e4SLinus Torvalds
5450ed15071SLennert Buytenhekconfig CPU_COPY_FEROCEON
5460ed15071SLennert Buytenhek	bool
5470ed15071SLennert Buytenhek
54828853ac8SPaulius Zaleckasconfig CPU_COPY_FA
54928853ac8SPaulius Zaleckas	bool
55028853ac8SPaulius Zaleckas
5511da177e4SLinus Torvaldsconfig CPU_COPY_V6
5521da177e4SLinus Torvalds	bool
5531da177e4SLinus Torvalds
5541da177e4SLinus Torvalds# This selects the TLB model
5551da177e4SLinus Torvaldsconfig CPU_TLB_V3
5561da177e4SLinus Torvalds	bool
5571da177e4SLinus Torvalds	help
5581da177e4SLinus Torvalds	  ARM Architecture Version 3 TLB.
5591da177e4SLinus Torvalds
5601da177e4SLinus Torvaldsconfig CPU_TLB_V4WT
5611da177e4SLinus Torvalds	bool
5621da177e4SLinus Torvalds	help
5631da177e4SLinus Torvalds	  ARM Architecture Version 4 TLB with writethrough cache.
5641da177e4SLinus Torvalds
5651da177e4SLinus Torvaldsconfig CPU_TLB_V4WB
5661da177e4SLinus Torvalds	bool
5671da177e4SLinus Torvalds	help
5681da177e4SLinus Torvalds	  ARM Architecture Version 4 TLB with writeback cache.
5691da177e4SLinus Torvalds
5701da177e4SLinus Torvaldsconfig CPU_TLB_V4WBI
5711da177e4SLinus Torvalds	bool
5721da177e4SLinus Torvalds	help
5731da177e4SLinus Torvalds	  ARM Architecture Version 4 TLB with writeback cache and invalidate
5741da177e4SLinus Torvalds	  instruction cache entry.
5751da177e4SLinus Torvalds
57699c6dc11SLennert Buytenhekconfig CPU_TLB_FEROCEON
57799c6dc11SLennert Buytenhek	bool
57899c6dc11SLennert Buytenhek	help
57999c6dc11SLennert Buytenhek	  Feroceon TLB (v4wbi with non-outer-cachable page table walks).
58099c6dc11SLennert Buytenhek
58128853ac8SPaulius Zaleckasconfig CPU_TLB_FA
58228853ac8SPaulius Zaleckas	bool
58328853ac8SPaulius Zaleckas	help
58428853ac8SPaulius Zaleckas	  Faraday ARM FA526 architecture, unified TLB with writeback cache
58528853ac8SPaulius Zaleckas	  and invalidate instruction cache entry. Branch target buffer is
58628853ac8SPaulius Zaleckas	  also supported.
58728853ac8SPaulius Zaleckas
5881da177e4SLinus Torvaldsconfig CPU_TLB_V6
5891da177e4SLinus Torvalds	bool
5901da177e4SLinus Torvalds
5912ccdd1e7SCatalin Marinasconfig CPU_TLB_V7
5922ccdd1e7SCatalin Marinas	bool
5932ccdd1e7SCatalin Marinas
594e220ba60SDave Estesconfig VERIFY_PERMISSION_FAULT
595e220ba60SDave Estes	bool
596f9c21a6eSHyok S. Choiendif
597f9c21a6eSHyok S. Choi
598516793c6SRussell Kingconfig CPU_HAS_ASID
599516793c6SRussell King	bool
600516793c6SRussell King	help
601516793c6SRussell King	  This indicates whether the CPU has the ASID register; used to
602516793c6SRussell King	  tag TLB and possibly cache entries.
603516793c6SRussell King
604fefdaa06SHyok S. Choiconfig CPU_CP15
605fefdaa06SHyok S. Choi	bool
606fefdaa06SHyok S. Choi	help
607fefdaa06SHyok S. Choi	  Processor has the CP15 register.
608fefdaa06SHyok S. Choi
609fefdaa06SHyok S. Choiconfig CPU_CP15_MMU
610fefdaa06SHyok S. Choi	bool
611fefdaa06SHyok S. Choi	select CPU_CP15
612fefdaa06SHyok S. Choi	help
613fefdaa06SHyok S. Choi	  Processor has the CP15 register, which has MMU related registers.
614fefdaa06SHyok S. Choi
615fefdaa06SHyok S. Choiconfig CPU_CP15_MPU
616fefdaa06SHyok S. Choi	bool
617fefdaa06SHyok S. Choi	select CPU_CP15
618fefdaa06SHyok S. Choi	help
619fefdaa06SHyok S. Choi	  Processor has the CP15 register, which has MPU related registers.
620fefdaa06SHyok S. Choi
621247055aaSCatalin Marinasconfig CPU_USE_DOMAINS
622247055aaSCatalin Marinas	bool
623247055aaSCatalin Marinas	depends on MMU
624247055aaSCatalin Marinas	default y if !CPU_32v6K
625247055aaSCatalin Marinas	help
626247055aaSCatalin Marinas	  This option enables or disables the use of domain switching
627247055aaSCatalin Marinas	  via the set_fs() function.
628247055aaSCatalin Marinas
62923bdf86aSLennert Buytenhek#
63023bdf86aSLennert Buytenhek# CPU supports 36-bit I/O
63123bdf86aSLennert Buytenhek#
63223bdf86aSLennert Buytenhekconfig IO_36
63323bdf86aSLennert Buytenhek	bool
63423bdf86aSLennert Buytenhek
6351da177e4SLinus Torvaldscomment "Processor Features"
6361da177e4SLinus Torvalds
6371da177e4SLinus Torvaldsconfig ARM_THUMB
6381da177e4SLinus Torvalds	bool "Support Thumb user binaries"
639e399b1a4SRussell King	depends on CPU_ARM720T || CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_ARM1020E || CPU_ARM1022 || CPU_ARM1026 || CPU_XSCALE || CPU_XSC3 || CPU_MOHAWK || CPU_V6 || CPU_V6K || CPU_V7 || CPU_FEROCEON
6401da177e4SLinus Torvalds	default y
6411da177e4SLinus Torvalds	help
6421da177e4SLinus Torvalds	  Say Y if you want to include kernel support for running user space
6431da177e4SLinus Torvalds	  Thumb binaries.
6441da177e4SLinus Torvalds
6451da177e4SLinus Torvalds	  The Thumb instruction set is a compressed form of the standard ARM
6461da177e4SLinus Torvalds	  instruction set resulting in smaller binaries at the expense of
6471da177e4SLinus Torvalds	  slightly less efficient code.
6481da177e4SLinus Torvalds
6491da177e4SLinus Torvalds	  If you don't know what this all is, saying Y is a safe choice.
6501da177e4SLinus Torvalds
651d7f864beSCatalin Marinasconfig ARM_THUMBEE
652d7f864beSCatalin Marinas	bool "Enable ThumbEE CPU extension"
653d7f864beSCatalin Marinas	depends on CPU_V7
654d7f864beSCatalin Marinas	help
655d7f864beSCatalin Marinas	  Say Y here if you have a CPU with the ThumbEE extension and code to
656d7f864beSCatalin Marinas	  make use of it. Say N for code that can run on CPUs without ThumbEE.
657d7f864beSCatalin Marinas
65864d2dc38SLeif Lindholmconfig SWP_EMULATE
65964d2dc38SLeif Lindholm	bool "Emulate SWP/SWPB instructions"
660e118a1dfSCatalin Marinas	depends on CPU_V7 && !CPU_V6
66164d2dc38SLeif Lindholm	select HAVE_PROC_CPU if PROC_FS
66264d2dc38SLeif Lindholm	default y if SMP
66364d2dc38SLeif Lindholm	help
66464d2dc38SLeif Lindholm	  ARMv6 architecture deprecates use of the SWP/SWPB instructions.
66564d2dc38SLeif Lindholm	  ARMv7 multiprocessing extensions introduce the ability to disable
66664d2dc38SLeif Lindholm	  these instructions, triggering an undefined instruction exception
66764d2dc38SLeif Lindholm	  when executed. Say Y here to enable software emulation of these
66864d2dc38SLeif Lindholm	  instructions for userspace (not kernel) using LDREX/STREX.
66964d2dc38SLeif Lindholm	  Also creates /proc/cpu/swp_emulation for statistics.
67064d2dc38SLeif Lindholm
67164d2dc38SLeif Lindholm	  In some older versions of glibc [<=2.8] SWP is used during futex
67264d2dc38SLeif Lindholm	  trylock() operations with the assumption that the code will not
67364d2dc38SLeif Lindholm	  be preempted. This invalid assumption may be more likely to fail
67464d2dc38SLeif Lindholm	  with SWP emulation enabled, leading to deadlock of the user
67564d2dc38SLeif Lindholm	  application.
67664d2dc38SLeif Lindholm
67764d2dc38SLeif Lindholm	  NOTE: when accessing uncached shared regions, LDREX/STREX rely
67864d2dc38SLeif Lindholm	  on an external transaction monitoring block called a global
67964d2dc38SLeif Lindholm	  monitor to maintain update atomicity. If your system does not
68064d2dc38SLeif Lindholm	  implement a global monitor, this option can cause programs that
68164d2dc38SLeif Lindholm	  perform SWP operations to uncached memory to deadlock.
68264d2dc38SLeif Lindholm
68364d2dc38SLeif Lindholm	  If unsure, say Y.
68464d2dc38SLeif Lindholm
6851da177e4SLinus Torvaldsconfig CPU_BIG_ENDIAN
6861da177e4SLinus Torvalds	bool "Build big-endian kernel"
6871da177e4SLinus Torvalds	depends on ARCH_SUPPORTS_BIG_ENDIAN
6881da177e4SLinus Torvalds	help
6891da177e4SLinus Torvalds	  Say Y if you plan on running a kernel in big-endian mode.
6901da177e4SLinus Torvalds	  Note that your board must be properly built and your board
6911da177e4SLinus Torvalds	  port must properly enable any big-endian related features
6921da177e4SLinus Torvalds	  of your chipset/board/processor.
6931da177e4SLinus Torvalds
69426584853SCatalin Marinasconfig CPU_ENDIAN_BE8
69526584853SCatalin Marinas	bool
69626584853SCatalin Marinas	depends on CPU_BIG_ENDIAN
697e399b1a4SRussell King	default CPU_V6 || CPU_V6K || CPU_V7
69826584853SCatalin Marinas	help
69926584853SCatalin Marinas	  Support for the BE-8 (big-endian) mode on ARMv6 and ARMv7 processors.
70026584853SCatalin Marinas
70126584853SCatalin Marinasconfig CPU_ENDIAN_BE32
70226584853SCatalin Marinas	bool
70326584853SCatalin Marinas	depends on CPU_BIG_ENDIAN
70426584853SCatalin Marinas	default !CPU_ENDIAN_BE8
70526584853SCatalin Marinas	help
70626584853SCatalin Marinas	  Support for the BE-32 (big-endian) mode on pre-ARMv6 processors.
70726584853SCatalin Marinas
7086afd6faeSHyok S. Choiconfig CPU_HIGH_VECTOR
7096340aa61SRobert P. J. Day	depends on !MMU && CPU_CP15 && !CPU_ARM740T
7106afd6faeSHyok S. Choi	bool "Select the High exception vector"
7116afd6faeSHyok S. Choi	help
7126afd6faeSHyok S. Choi	  Say Y here to select high exception vector(0xFFFF0000~).
7136afd6faeSHyok S. Choi	  The exception vector can be vary depending on the platform
7146afd6faeSHyok S. Choi	  design in nommu mode. If your platform needs to select
7156afd6faeSHyok S. Choi	  high exception vector, say Y.
7166afd6faeSHyok S. Choi	  Otherwise or if you are unsure, say N, and the low exception
7176afd6faeSHyok S. Choi	  vector (0x00000000~) will be used.
7186afd6faeSHyok S. Choi
7191da177e4SLinus Torvaldsconfig CPU_ICACHE_DISABLE
720f12d0d7cSHyok S. Choi	bool "Disable I-Cache (I-bit)"
721f12d0d7cSHyok S. Choi	depends on CPU_CP15 && !(CPU_ARM610 || CPU_ARM710 || CPU_ARM720T || CPU_ARM740T || CPU_XSCALE || CPU_XSC3)
7221da177e4SLinus Torvalds	help
7231da177e4SLinus Torvalds	  Say Y here to disable the processor instruction cache. Unless
7241da177e4SLinus Torvalds	  you have a reason not to or are unsure, say N.
7251da177e4SLinus Torvalds
7261da177e4SLinus Torvaldsconfig CPU_DCACHE_DISABLE
727f12d0d7cSHyok S. Choi	bool "Disable D-Cache (C-bit)"
728f12d0d7cSHyok S. Choi	depends on CPU_CP15
7291da177e4SLinus Torvalds	help
7301da177e4SLinus Torvalds	  Say Y here to disable the processor data cache. Unless
7311da177e4SLinus Torvalds	  you have a reason not to or are unsure, say N.
7321da177e4SLinus Torvalds
733f37f46ebSHyok S. Choiconfig CPU_DCACHE_SIZE
734f37f46ebSHyok S. Choi	hex
735f37f46ebSHyok S. Choi	depends on CPU_ARM740T || CPU_ARM946E
736f37f46ebSHyok S. Choi	default 0x00001000 if CPU_ARM740T
737f37f46ebSHyok S. Choi	default 0x00002000 # default size for ARM946E-S
738f37f46ebSHyok S. Choi	help
739f37f46ebSHyok S. Choi	  Some cores are synthesizable to have various sized cache. For
740f37f46ebSHyok S. Choi	  ARM946E-S case, it can vary from 0KB to 1MB.
741f37f46ebSHyok S. Choi	  To support such cache operations, it is efficient to know the size
742f37f46ebSHyok S. Choi	  before compile time.
743f37f46ebSHyok S. Choi	  If your SoC is configured to have a different size, define the value
744f37f46ebSHyok S. Choi	  here with proper conditions.
745f37f46ebSHyok S. Choi
7461da177e4SLinus Torvaldsconfig CPU_DCACHE_WRITETHROUGH
7471da177e4SLinus Torvalds	bool "Force write through D-cache"
74828853ac8SPaulius Zaleckas	depends on (CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_FA526) && !CPU_DCACHE_DISABLE
7491da177e4SLinus Torvalds	default y if CPU_ARM925T
7501da177e4SLinus Torvalds	help
7511da177e4SLinus Torvalds	  Say Y here to use the data cache in writethrough mode. Unless you
7521da177e4SLinus Torvalds	  specifically require this or are unsure, say N.
7531da177e4SLinus Torvalds
7541da177e4SLinus Torvaldsconfig CPU_CACHE_ROUND_ROBIN
7551da177e4SLinus Torvalds	bool "Round robin I and D cache replacement algorithm"
756f37f46ebSHyok S. Choi	depends on (CPU_ARM926T || CPU_ARM946E || CPU_ARM1020) && (!CPU_ICACHE_DISABLE || !CPU_DCACHE_DISABLE)
7571da177e4SLinus Torvalds	help
7581da177e4SLinus Torvalds	  Say Y here to use the predictable round-robin cache replacement
7591da177e4SLinus Torvalds	  policy.  Unless you specifically require this or are unsure, say N.
7601da177e4SLinus Torvalds
7611da177e4SLinus Torvaldsconfig CPU_BPREDICT_DISABLE
7621da177e4SLinus Torvalds	bool "Disable branch prediction"
763e399b1a4SRussell King	depends on CPU_ARM1020 || CPU_V6 || CPU_V6K || CPU_MOHAWK || CPU_XSC3 || CPU_V7 || CPU_FA526
7641da177e4SLinus Torvalds	help
7651da177e4SLinus Torvalds	  Say Y here to disable branch prediction.  If unsure, say N.
7662d2669b6SNicolas Pitre
7674b0e07a5SNicolas Pitreconfig TLS_REG_EMUL
7684b0e07a5SNicolas Pitre	bool
7694b0e07a5SNicolas Pitre	help
77070489c88SNicolas Pitre	  An SMP system using a pre-ARMv6 processor (there are apparently
77170489c88SNicolas Pitre	  a few prototypes like that in existence) and therefore access to
77270489c88SNicolas Pitre	  that required register must be emulated.
7734b0e07a5SNicolas Pitre
774dcef1f63SNicolas Pitreconfig NEEDS_SYSCALL_FOR_CMPXCHG
775dcef1f63SNicolas Pitre	bool
776dcef1f63SNicolas Pitre	help
777dcef1f63SNicolas Pitre	  SMP on a pre-ARMv6 processor?  Well OK then.
778dcef1f63SNicolas Pitre	  Forget about fast user space cmpxchg support.
779dcef1f63SNicolas Pitre	  It is just not possible.
780dcef1f63SNicolas Pitre
781ad642d9fSCatalin Marinasconfig DMA_CACHE_RWFO
782ad642d9fSCatalin Marinas	bool "Enable read/write for ownership DMA cache maintenance"
783e399b1a4SRussell King	depends on (CPU_V6 || CPU_V6K) && SMP
784ad642d9fSCatalin Marinas	default y
785ad642d9fSCatalin Marinas	help
786ad642d9fSCatalin Marinas	  The Snoop Control Unit on ARM11MPCore does not detect the
787ad642d9fSCatalin Marinas	  cache maintenance operations and the dma_{map,unmap}_area()
788ad642d9fSCatalin Marinas	  functions may leave stale cache entries on other CPUs. By
789ad642d9fSCatalin Marinas	  enabling this option, Read or Write For Ownership in the ARMv6
790ad642d9fSCatalin Marinas	  DMA cache maintenance functions is performed. These LDR/STR
791ad642d9fSCatalin Marinas	  instructions change the cache line state to shared or modified
792ad642d9fSCatalin Marinas	  so that the cache operation has the desired effect.
793ad642d9fSCatalin Marinas
794ad642d9fSCatalin Marinas	  Note that the workaround is only valid on processors that do
795ad642d9fSCatalin Marinas	  not perform speculative loads into the D-cache. For such
796ad642d9fSCatalin Marinas	  processors, if cache maintenance operations are not broadcast
797ad642d9fSCatalin Marinas	  in hardware, other workarounds are needed (e.g. cache
798ad642d9fSCatalin Marinas	  maintenance broadcasting in software via FIQ).
799ad642d9fSCatalin Marinas
800953233dcSCatalin Marinasconfig OUTER_CACHE
801953233dcSCatalin Marinas	bool
802382266adSCatalin Marinas
803319f551aSCatalin Marinasconfig OUTER_CACHE_SYNC
804319f551aSCatalin Marinas	bool
805319f551aSCatalin Marinas	help
806319f551aSCatalin Marinas	  The outer cache has a outer_cache_fns.sync function pointer
807319f551aSCatalin Marinas	  that can be used to drain the write buffer of the outer cache.
808319f551aSCatalin Marinas
80999c6dc11SLennert Buytenhekconfig CACHE_FEROCEON_L2
81099c6dc11SLennert Buytenhek	bool "Enable the Feroceon L2 cache controller"
811794d15b2SStanislav Samsonov	depends on ARCH_KIRKWOOD || ARCH_MV78XX0
81299c6dc11SLennert Buytenhek	default y
813382266adSCatalin Marinas	select OUTER_CACHE
81499c6dc11SLennert Buytenhek	help
81599c6dc11SLennert Buytenhek	  This option enables the Feroceon L2 cache controller.
81699c6dc11SLennert Buytenhek
8174360bb41SRonen Shitritconfig CACHE_FEROCEON_L2_WRITETHROUGH
8184360bb41SRonen Shitrit	bool "Force Feroceon L2 cache write through"
8194360bb41SRonen Shitrit	depends on CACHE_FEROCEON_L2
8204360bb41SRonen Shitrit	help
8214360bb41SRonen Shitrit	  Say Y here to use the Feroceon L2 cache in writethrough mode.
8224360bb41SRonen Shitrit	  Unless you specifically require this, say N for writeback mode.
8234360bb41SRonen Shitrit
8241da177e4SLinus Torvaldsconfig CACHE_L2X0
825ba927951SCatalin Marinas	bool "Enable the L2x0 outer cache controller"
826cb88214dSSascha Hauer	depends on REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || MACH_REALVIEW_PB1176 || \
8278e797a7eSSrinidhi Kasagar		   REALVIEW_EB_A9MP || ARCH_MX35 || ARCH_MX31 || MACH_REALVIEW_PBX || \
8280b019a41SRussell King		   ARCH_NOMADIK || ARCH_OMAP4 || ARCH_S5PV310 || ARCH_TEGRA || \
8296d9598e2SMagnus Damm		   ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || ARCH_SHMOBILE
830ba927951SCatalin Marinas	default y
8311da177e4SLinus Torvalds	select OUTER_CACHE
83223107c54SCatalin Marinas	select OUTER_CACHE_SYNC
833ba927951SCatalin Marinas	help
834ba927951SCatalin Marinas	  This option enables the L2x0 PrimeCell.
835905a09d5SEric Miao
8369a6655e4SCatalin Marinasconfig CACHE_PL310
8379a6655e4SCatalin Marinas	bool
8389a6655e4SCatalin Marinas	depends on CACHE_L2X0
839e399b1a4SRussell King	default y if CPU_V7 && !(CPU_V6 || CPU_V6K)
8409a6655e4SCatalin Marinas	help
8419a6655e4SCatalin Marinas	  This option enables optimisations for the PL310 cache
8429a6655e4SCatalin Marinas	  controller.
8439a6655e4SCatalin Marinas
844573a652fSLennert Buytenhekconfig CACHE_TAUROS2
845573a652fSLennert Buytenhek	bool "Enable the Tauros2 L2 cache controller"
8463f408fa0SHaojian Zhuang	depends on (ARCH_DOVE || ARCH_MMP || CPU_PJ4)
847573a652fSLennert Buytenhek	default y
848573a652fSLennert Buytenhek	select OUTER_CACHE
849573a652fSLennert Buytenhek	help
850573a652fSLennert Buytenhek	  This option enables the Tauros2 L2 cache controller (as
851573a652fSLennert Buytenhek	  found on PJ1/PJ4).
852573a652fSLennert Buytenhek
853905a09d5SEric Miaoconfig CACHE_XSC3L2
854905a09d5SEric Miao	bool "Enable the L2 cache on XScale3"
855905a09d5SEric Miao	depends on CPU_XSC3
856905a09d5SEric Miao	default y
857905a09d5SEric Miao	select OUTER_CACHE
858905a09d5SEric Miao	help
859905a09d5SEric Miao	  This option enables the L2 cache on XScale3.
860910a17e5SKirill A. Shutemov
861910a17e5SKirill A. Shutemovconfig ARM_L1_CACHE_SHIFT
862910a17e5SKirill A. Shutemov	int
863d6d502faSKukjin Kim	default 6 if ARM_L1_CACHE_SHIFT_6
864910a17e5SKirill A. Shutemov	default 5
86547ab0deeSRussell King
86647ab0deeSRussell Kingconfig ARM_DMA_MEM_BUFFERABLE
867e399b1a4SRussell King	bool "Use non-cacheable memory for DMA" if (CPU_V6 || CPU_V6K) && !CPU_V7
86842c4dafeSCatalin Marinas	depends on !(MACH_REALVIEW_PB1176 || REALVIEW_EB_ARM11MP || \
86942c4dafeSCatalin Marinas		     MACH_REALVIEW_PB11MP)
870e399b1a4SRussell King	default y if CPU_V6 || CPU_V6K || CPU_V7
87147ab0deeSRussell King	help
87247ab0deeSRussell King	  Historically, the kernel has used strongly ordered mappings to
87347ab0deeSRussell King	  provide DMA coherent memory.  With the advent of ARMv7, mapping
87447ab0deeSRussell King	  memory with differing types results in unpredictable behaviour,
87547ab0deeSRussell King	  so on these CPUs, this option is forced on.
87647ab0deeSRussell King
87747ab0deeSRussell King	  Multiple mappings with differing attributes is also unpredictable
87847ab0deeSRussell King	  on ARMv6 CPUs, but since they do not have aggressive speculative
87947ab0deeSRussell King	  prefetch, no harm appears to occur.
88047ab0deeSRussell King
88147ab0deeSRussell King	  However, drivers may be missing the necessary barriers for ARMv6,
88247ab0deeSRussell King	  and therefore turning this on may result in unpredictable driver
88347ab0deeSRussell King	  behaviour.  Therefore, we offer this as an option.
88447ab0deeSRussell King
88547ab0deeSRussell King	  You are recommended say 'Y' here and debug any affected drivers.
886ac1d426eSRussell King
887e7c5650fSCatalin Marinasconfig ARCH_HAS_BARRIERS
888e7c5650fSCatalin Marinas	bool
889e7c5650fSCatalin Marinas	help
890e7c5650fSCatalin Marinas	  This option allows the use of custom mandatory barriers
891e7c5650fSCatalin Marinas	  included via the mach/barriers.h file.
892