xref: /linux/arch/arm/mm/Kconfig (revision 5b6728d4189d14c19f384d5ec6087276e7c196d8)
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
707e0da78SHyok S. Choi# ARM7TDMI
807e0da78SHyok S. Choiconfig CPU_ARM7TDMI
907e0da78SHyok S. Choi	bool "Support ARM7TDMI processor"
106b237a35SRussell King	depends on !MMU
1107e0da78SHyok S. Choi	select CPU_32v4T
1207e0da78SHyok S. Choi	select CPU_ABRT_LV4T
134fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1407e0da78SHyok S. Choi	select CPU_CACHE_V4
1507e0da78SHyok S. Choi	help
1607e0da78SHyok S. Choi	  A 32-bit RISC microprocessor based on the ARM7 processor core
1707e0da78SHyok S. Choi	  which has no memory control unit and cache.
1807e0da78SHyok S. Choi
1907e0da78SHyok S. Choi	  Say Y if you want support for the ARM7TDMI processor.
2007e0da78SHyok S. Choi	  Otherwise, say N.
2107e0da78SHyok S. Choi
221da177e4SLinus Torvalds# ARM720T
231da177e4SLinus Torvaldsconfig CPU_ARM720T
24c750815eSRussell King	bool "Support ARM720T processor" if ARCH_INTEGRATOR
25260e98edSLennert Buytenhek	select CPU_32v4T
261da177e4SLinus Torvalds	select CPU_ABRT_LV4T
274fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
281da177e4SLinus Torvalds	select CPU_CACHE_V4
291da177e4SLinus Torvalds	select CPU_CACHE_VIVT
30fefdaa06SHyok S. Choi	select CPU_CP15_MMU
31f9c21a6eSHyok S. Choi	select CPU_COPY_V4WT if MMU
32f9c21a6eSHyok S. Choi	select CPU_TLB_V4WT if MMU
331da177e4SLinus Torvalds	help
341da177e4SLinus Torvalds	  A 32-bit RISC processor with 8kByte Cache, Write Buffer and
351da177e4SLinus Torvalds	  MMU built around an ARM7TDMI core.
361da177e4SLinus Torvalds
371da177e4SLinus Torvalds	  Say Y if you want support for the ARM720T processor.
381da177e4SLinus Torvalds	  Otherwise, say N.
391da177e4SLinus Torvalds
40b731c311SHyok S. Choi# ARM740T
41b731c311SHyok S. Choiconfig CPU_ARM740T
42b731c311SHyok S. Choi	bool "Support ARM740T processor" if ARCH_INTEGRATOR
436b237a35SRussell King	depends on !MMU
44b731c311SHyok S. Choi	select CPU_32v4T
45b731c311SHyok S. Choi	select CPU_ABRT_LV4T
464fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
47b731c311SHyok S. Choi	select CPU_CACHE_V3	# although the core is v4t
48b731c311SHyok S. Choi	select CPU_CP15_MPU
49b731c311SHyok S. Choi	help
50b731c311SHyok S. Choi	  A 32-bit RISC processor with 8KB cache or 4KB variants,
51b731c311SHyok S. Choi	  write buffer and MPU(Protection Unit) built around
52b731c311SHyok S. Choi	  an ARM7TDMI core.
53b731c311SHyok S. Choi
54b731c311SHyok S. Choi	  Say Y if you want support for the ARM740T processor.
55b731c311SHyok S. Choi	  Otherwise, say N.
56b731c311SHyok S. Choi
5743f5f014SHyok S. Choi# ARM9TDMI
5843f5f014SHyok S. Choiconfig CPU_ARM9TDMI
5943f5f014SHyok S. Choi	bool "Support ARM9TDMI processor"
606b237a35SRussell King	depends on !MMU
6143f5f014SHyok S. Choi	select CPU_32v4T
620f45d7f3SHyok S. Choi	select CPU_ABRT_NOMMU
634fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
6443f5f014SHyok S. Choi	select CPU_CACHE_V4
6543f5f014SHyok S. Choi	help
6643f5f014SHyok S. Choi	  A 32-bit RISC microprocessor based on the ARM9 processor core
6743f5f014SHyok S. Choi	  which has no memory control unit and cache.
6843f5f014SHyok S. Choi
6943f5f014SHyok S. Choi	  Say Y if you want support for the ARM9TDMI processor.
7043f5f014SHyok S. Choi	  Otherwise, say N.
7143f5f014SHyok S. Choi
721da177e4SLinus Torvalds# ARM920T
731da177e4SLinus Torvaldsconfig CPU_ARM920T
74c750815eSRussell King	bool "Support ARM920T processor" if ARCH_INTEGRATOR
75260e98edSLennert Buytenhek	select CPU_32v4T
761da177e4SLinus Torvalds	select CPU_ABRT_EV4T
774fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
781da177e4SLinus Torvalds	select CPU_CACHE_V4WT
791da177e4SLinus Torvalds	select CPU_CACHE_VIVT
80fefdaa06SHyok S. Choi	select CPU_CP15_MMU
81f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
82f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
831da177e4SLinus Torvalds	help
841da177e4SLinus Torvalds	  The ARM920T is licensed to be produced by numerous vendors,
85c768e676SHartley Sweeten	  and is used in the Cirrus EP93xx and the Samsung S3C2410.
861da177e4SLinus Torvalds
871da177e4SLinus Torvalds	  Say Y if you want support for the ARM920T processor.
881da177e4SLinus Torvalds	  Otherwise, say N.
891da177e4SLinus Torvalds
901da177e4SLinus Torvalds# ARM922T
911da177e4SLinus Torvaldsconfig CPU_ARM922T
921da177e4SLinus Torvalds	bool "Support ARM922T processor" if ARCH_INTEGRATOR
93260e98edSLennert Buytenhek	select CPU_32v4T
941da177e4SLinus Torvalds	select CPU_ABRT_EV4T
954fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
961da177e4SLinus Torvalds	select CPU_CACHE_V4WT
971da177e4SLinus Torvalds	select CPU_CACHE_VIVT
98fefdaa06SHyok S. Choi	select CPU_CP15_MMU
99f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
100f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1011da177e4SLinus Torvalds	help
1021da177e4SLinus Torvalds	  The ARM922T is a version of the ARM920T, but with smaller
1031da177e4SLinus Torvalds	  instruction and data caches. It is used in Altera's
104c53c9cf6SAndrew Victor	  Excalibur XA device family and Micrel's KS8695 Centaur.
1051da177e4SLinus Torvalds
1061da177e4SLinus Torvalds	  Say Y if you want support for the ARM922T processor.
1071da177e4SLinus Torvalds	  Otherwise, say N.
1081da177e4SLinus Torvalds
1091da177e4SLinus Torvalds# ARM925T
1101da177e4SLinus Torvaldsconfig CPU_ARM925T
111b288f75fSTony Lindgren 	bool "Support ARM925T processor" if ARCH_OMAP1
112260e98edSLennert Buytenhek	select CPU_32v4T
1131da177e4SLinus Torvalds	select CPU_ABRT_EV4T
1144fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1151da177e4SLinus Torvalds	select CPU_CACHE_V4WT
1161da177e4SLinus Torvalds	select CPU_CACHE_VIVT
117fefdaa06SHyok S. Choi	select CPU_CP15_MMU
118f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
119f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1201da177e4SLinus Torvalds 	help
1211da177e4SLinus Torvalds 	  The ARM925T is a mix between the ARM920T and ARM926T, but with
1221da177e4SLinus Torvalds	  different instruction and data caches. It is used in TI's OMAP
1231da177e4SLinus Torvalds 	  device family.
1241da177e4SLinus Torvalds
1251da177e4SLinus Torvalds 	  Say Y if you want support for the ARM925T processor.
1261da177e4SLinus Torvalds 	  Otherwise, say N.
1271da177e4SLinus Torvalds
1281da177e4SLinus Torvalds# ARM926T
1291da177e4SLinus Torvaldsconfig CPU_ARM926T
130c750815eSRussell King	bool "Support ARM926T processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB
1311da177e4SLinus Torvalds	select CPU_32v5
1321da177e4SLinus Torvalds	select CPU_ABRT_EV5TJ
1334fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
1341da177e4SLinus Torvalds	select CPU_CACHE_VIVT
135fefdaa06SHyok S. Choi	select CPU_CP15_MMU
136f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
137f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
1381da177e4SLinus Torvalds	help
1391da177e4SLinus Torvalds	  This is a variant of the ARM920.  It has slightly different
1401da177e4SLinus Torvalds	  instruction sequences for cache and TLB operations.  Curiously,
1411da177e4SLinus Torvalds	  there is no documentation on it at the ARM corporate website.
1421da177e4SLinus Torvalds
1431da177e4SLinus Torvalds	  Say Y if you want support for the ARM926T processor.
1441da177e4SLinus Torvalds	  Otherwise, say N.
1451da177e4SLinus Torvalds
14628853ac8SPaulius Zaleckas# FA526
14728853ac8SPaulius Zaleckasconfig CPU_FA526
14828853ac8SPaulius Zaleckas	bool
14928853ac8SPaulius Zaleckas	select CPU_32v4
15028853ac8SPaulius Zaleckas	select CPU_ABRT_EV4
1514fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
15228853ac8SPaulius Zaleckas	select CPU_CACHE_VIVT
15328853ac8SPaulius Zaleckas	select CPU_CP15_MMU
15428853ac8SPaulius Zaleckas	select CPU_CACHE_FA
15528853ac8SPaulius Zaleckas	select CPU_COPY_FA if MMU
15628853ac8SPaulius Zaleckas	select CPU_TLB_FA if MMU
15728853ac8SPaulius Zaleckas	help
15828853ac8SPaulius Zaleckas	  The FA526 is a version of the ARMv4 compatible processor with
15928853ac8SPaulius Zaleckas	  Branch Target Buffer, Unified TLB and cache line size 16.
16028853ac8SPaulius Zaleckas
16128853ac8SPaulius Zaleckas	  Say Y if you want support for the FA526 processor.
16228853ac8SPaulius Zaleckas	  Otherwise, say N.
16328853ac8SPaulius Zaleckas
164d60674ebSHyok S. Choi# ARM940T
165d60674ebSHyok S. Choiconfig CPU_ARM940T
166d60674ebSHyok S. Choi	bool "Support ARM940T processor" if ARCH_INTEGRATOR
1676b237a35SRussell King	depends on !MMU
168d60674ebSHyok S. Choi	select CPU_32v4T
1690f45d7f3SHyok S. Choi	select CPU_ABRT_NOMMU
1704fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
171d60674ebSHyok S. Choi	select CPU_CACHE_VIVT
172d60674ebSHyok S. Choi	select CPU_CP15_MPU
173d60674ebSHyok S. Choi	help
174d60674ebSHyok S. Choi	  ARM940T is a member of the ARM9TDMI family of general-
1753cb2fcccSMatt LaPlante	  purpose microprocessors with MPU and separate 4KB
176d60674ebSHyok S. Choi	  instruction and 4KB data cases, each with a 4-word line
177d60674ebSHyok S. Choi	  length.
178d60674ebSHyok S. Choi
179d60674ebSHyok S. Choi	  Say Y if you want support for the ARM940T processor.
180d60674ebSHyok S. Choi	  Otherwise, say N.
181d60674ebSHyok S. Choi
182f37f46ebSHyok S. Choi# ARM946E-S
183f37f46ebSHyok S. Choiconfig CPU_ARM946E
184f37f46ebSHyok S. Choi	bool "Support ARM946E-S processor" if ARCH_INTEGRATOR
1856b237a35SRussell King	depends on !MMU
186f37f46ebSHyok S. Choi	select CPU_32v5
1870f45d7f3SHyok S. Choi	select CPU_ABRT_NOMMU
1884fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
189f37f46ebSHyok S. Choi	select CPU_CACHE_VIVT
190f37f46ebSHyok S. Choi	select CPU_CP15_MPU
191f37f46ebSHyok S. Choi	help
192f37f46ebSHyok S. Choi	  ARM946E-S is a member of the ARM9E-S family of high-
193f37f46ebSHyok S. Choi	  performance, 32-bit system-on-chip processor solutions.
194f37f46ebSHyok S. Choi	  The TCM and ARMv5TE 32-bit instruction set is supported.
195f37f46ebSHyok S. Choi
196f37f46ebSHyok S. Choi	  Say Y if you want support for the ARM946E-S processor.
197f37f46ebSHyok S. Choi	  Otherwise, say N.
198f37f46ebSHyok S. Choi
1991da177e4SLinus Torvalds# ARM1020 - needs validating
2001da177e4SLinus Torvaldsconfig CPU_ARM1020
201c750815eSRussell King	bool "Support ARM1020T (rev 0) processor" if ARCH_INTEGRATOR
2021da177e4SLinus Torvalds	select CPU_32v5
2031da177e4SLinus Torvalds	select CPU_ABRT_EV4T
2044fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2051da177e4SLinus Torvalds	select CPU_CACHE_V4WT
2061da177e4SLinus Torvalds	select CPU_CACHE_VIVT
207fefdaa06SHyok S. Choi	select CPU_CP15_MMU
208f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
209f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2101da177e4SLinus Torvalds	help
2111da177e4SLinus Torvalds	  The ARM1020 is the 32K cached version of the ARM10 processor,
2121da177e4SLinus Torvalds	  with an addition of a floating-point unit.
2131da177e4SLinus Torvalds
2141da177e4SLinus Torvalds	  Say Y if you want support for the ARM1020 processor.
2151da177e4SLinus Torvalds	  Otherwise, say N.
2161da177e4SLinus Torvalds
2171da177e4SLinus Torvalds# ARM1020E - needs validating
2181da177e4SLinus Torvaldsconfig CPU_ARM1020E
219c750815eSRussell King	bool "Support ARM1020E processor" if ARCH_INTEGRATOR
2201da177e4SLinus Torvalds	select CPU_32v5
2211da177e4SLinus Torvalds	select CPU_ABRT_EV4T
2224fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2231da177e4SLinus Torvalds	select CPU_CACHE_V4WT
2241da177e4SLinus Torvalds	select CPU_CACHE_VIVT
225fefdaa06SHyok S. Choi	select CPU_CP15_MMU
226f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
227f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2281da177e4SLinus Torvalds	depends on n
2291da177e4SLinus Torvalds
2301da177e4SLinus Torvalds# ARM1022E
2311da177e4SLinus Torvaldsconfig CPU_ARM1022
232c750815eSRussell King	bool "Support ARM1022E processor" if ARCH_INTEGRATOR
2331da177e4SLinus Torvalds	select CPU_32v5
2341da177e4SLinus Torvalds	select CPU_ABRT_EV4T
2354fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2361da177e4SLinus Torvalds	select CPU_CACHE_VIVT
237fefdaa06SHyok S. Choi	select CPU_CP15_MMU
238f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU # can probably do better
239f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2401da177e4SLinus Torvalds	help
2411da177e4SLinus Torvalds	  The ARM1022E is an implementation of the ARMv5TE architecture
2421da177e4SLinus Torvalds	  based upon the ARM10 integer core with a 16KiB L1 Harvard cache,
2431da177e4SLinus Torvalds	  embedded trace macrocell, and a floating-point unit.
2441da177e4SLinus Torvalds
2451da177e4SLinus Torvalds	  Say Y if you want support for the ARM1022E processor.
2461da177e4SLinus Torvalds	  Otherwise, say N.
2471da177e4SLinus Torvalds
2481da177e4SLinus Torvalds# ARM1026EJ-S
2491da177e4SLinus Torvaldsconfig CPU_ARM1026
250c750815eSRussell King	bool "Support ARM1026EJ-S processor" if ARCH_INTEGRATOR
2511da177e4SLinus Torvalds	select CPU_32v5
2521da177e4SLinus Torvalds	select CPU_ABRT_EV5T # But need Jazelle, but EV5TJ ignores bit 10
2534fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2541da177e4SLinus Torvalds	select CPU_CACHE_VIVT
255fefdaa06SHyok S. Choi	select CPU_CP15_MMU
256f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU # can probably do better
257f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
2581da177e4SLinus Torvalds	help
2591da177e4SLinus Torvalds	  The ARM1026EJ-S is an implementation of the ARMv5TEJ architecture
2601da177e4SLinus Torvalds	  based upon the ARM10 integer core.
2611da177e4SLinus Torvalds
2621da177e4SLinus Torvalds	  Say Y if you want support for the ARM1026EJ-S processor.
2631da177e4SLinus Torvalds	  Otherwise, say N.
2641da177e4SLinus Torvalds
2651da177e4SLinus Torvalds# SA110
2661da177e4SLinus Torvaldsconfig CPU_SA110
267c750815eSRussell King	bool "Support StrongARM(R) SA-110 processor" if ARCH_RPC
2681da177e4SLinus Torvalds	select CPU_32v3 if ARCH_RPC
2691da177e4SLinus Torvalds	select CPU_32v4 if !ARCH_RPC
2701da177e4SLinus Torvalds	select CPU_ABRT_EV4
2714fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2721da177e4SLinus Torvalds	select CPU_CACHE_V4WB
2731da177e4SLinus Torvalds	select CPU_CACHE_VIVT
274fefdaa06SHyok S. Choi	select CPU_CP15_MMU
275f9c21a6eSHyok S. Choi	select CPU_COPY_V4WB if MMU
276f9c21a6eSHyok S. Choi	select CPU_TLB_V4WB if MMU
2771da177e4SLinus Torvalds	help
2781da177e4SLinus Torvalds	  The Intel StrongARM(R) SA-110 is a 32-bit microprocessor and
2791da177e4SLinus Torvalds	  is available at five speeds ranging from 100 MHz to 233 MHz.
2801da177e4SLinus Torvalds	  More information is available at
2811da177e4SLinus Torvalds	  <http://developer.intel.com/design/strong/sa110.htm>.
2821da177e4SLinus Torvalds
2831da177e4SLinus Torvalds	  Say Y if you want support for the SA-110 processor.
2841da177e4SLinus Torvalds	  Otherwise, say N.
2851da177e4SLinus Torvalds
2861da177e4SLinus Torvalds# SA1100
2871da177e4SLinus Torvaldsconfig CPU_SA1100
2881da177e4SLinus Torvalds	bool
2891da177e4SLinus Torvalds	select CPU_32v4
2901da177e4SLinus Torvalds	select CPU_ABRT_EV4
2914fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
2921da177e4SLinus Torvalds	select CPU_CACHE_V4WB
2931da177e4SLinus Torvalds	select CPU_CACHE_VIVT
294fefdaa06SHyok S. Choi	select CPU_CP15_MMU
295f9c21a6eSHyok S. Choi	select CPU_TLB_V4WB if MMU
2961da177e4SLinus Torvalds
2971da177e4SLinus Torvalds# XScale
2981da177e4SLinus Torvaldsconfig CPU_XSCALE
2991da177e4SLinus Torvalds	bool
3001da177e4SLinus Torvalds	select CPU_32v5
3011da177e4SLinus Torvalds	select CPU_ABRT_EV5T
3024fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
3031da177e4SLinus Torvalds	select CPU_CACHE_VIVT
304fefdaa06SHyok S. Choi	select CPU_CP15_MMU
305f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
3061da177e4SLinus Torvalds
30723bdf86aSLennert Buytenhek# XScale Core Version 3
30823bdf86aSLennert Buytenhekconfig CPU_XSC3
30923bdf86aSLennert Buytenhek	bool
31023bdf86aSLennert Buytenhek	select CPU_32v5
31123bdf86aSLennert Buytenhek	select CPU_ABRT_EV5T
3124fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
31323bdf86aSLennert Buytenhek	select CPU_CACHE_VIVT
314fefdaa06SHyok S. Choi	select CPU_CP15_MMU
315f9c21a6eSHyok S. Choi	select CPU_TLB_V4WBI if MMU
31623bdf86aSLennert Buytenhek	select IO_36
31723bdf86aSLennert Buytenhek
31849cbe786SEric Miao# Marvell PJ1 (Mohawk)
31949cbe786SEric Miaoconfig CPU_MOHAWK
32049cbe786SEric Miao	bool
32149cbe786SEric Miao	select CPU_32v5
32249cbe786SEric Miao	select CPU_ABRT_EV5T
3234fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
32449cbe786SEric Miao	select CPU_CACHE_VIVT
32549cbe786SEric Miao	select CPU_CP15_MMU
32649cbe786SEric Miao	select CPU_TLB_V4WBI if MMU
32749cbe786SEric Miao	select CPU_COPY_V4WB if MMU
32849cbe786SEric Miao
329e50d6409SAssaf Hoffman# Feroceon
330e50d6409SAssaf Hoffmanconfig CPU_FEROCEON
331e50d6409SAssaf Hoffman	bool
332e50d6409SAssaf Hoffman	select CPU_32v5
333e50d6409SAssaf Hoffman	select CPU_ABRT_EV5T
3344fb28474SKirill A. Shutemov	select CPU_PABRT_LEGACY
335e50d6409SAssaf Hoffman	select CPU_CACHE_VIVT
336e50d6409SAssaf Hoffman	select CPU_CP15_MMU
3370ed15071SLennert Buytenhek	select CPU_COPY_FEROCEON if MMU
33899c6dc11SLennert Buytenhek	select CPU_TLB_FEROCEON if MMU
339e50d6409SAssaf Hoffman
340d910a0aaSTzachi Perelsteinconfig CPU_FEROCEON_OLD_ID
341d910a0aaSTzachi Perelstein	bool "Accept early Feroceon cores with an ARM926 ID"
342d910a0aaSTzachi Perelstein	depends on CPU_FEROCEON && !CPU_ARM926T
343d910a0aaSTzachi Perelstein	default y
344d910a0aaSTzachi Perelstein	help
345d910a0aaSTzachi Perelstein	  This enables the usage of some old Feroceon cores
346d910a0aaSTzachi Perelstein	  for which the CPU ID is equal to the ARM926 ID.
347d910a0aaSTzachi Perelstein	  Relevant for Feroceon-1850 and early Feroceon-2850.
348d910a0aaSTzachi Perelstein
349a4553358SHaojian Zhuang# Marvell PJ4
350a4553358SHaojian Zhuangconfig CPU_PJ4
351a4553358SHaojian Zhuang	bool
352a4553358SHaojian Zhuang	select CPU_V7
353a4553358SHaojian Zhuang	select ARM_THUMBEE
354a4553358SHaojian Zhuang
3551da177e4SLinus Torvalds# ARMv6
3561da177e4SLinus Torvaldsconfig CPU_V6
357c786282eSRussell King	bool "Support ARM V6 processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX
3581da177e4SLinus Torvalds	select CPU_32v6
3591da177e4SLinus Torvalds	select CPU_ABRT_EV6
3604fb28474SKirill A. Shutemov	select CPU_PABRT_V6
3611da177e4SLinus Torvalds	select CPU_CACHE_V6
3621da177e4SLinus Torvalds	select CPU_CACHE_VIPT
363fefdaa06SHyok S. Choi	select CPU_CP15_MMU
3647b4c965aSCatalin Marinas	select CPU_HAS_ASID if MMU
365f9c21a6eSHyok S. Choi	select CPU_COPY_V6 if MMU
366f9c21a6eSHyok S. Choi	select CPU_TLB_V6 if MMU
3671da177e4SLinus Torvalds
3684a5f79e7SRussell King# ARMv6k
369e399b1a4SRussell Kingconfig CPU_V6K
370c786282eSRussell King	bool "Support ARM V6K processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX
371e399b1a4SRussell King	select CPU_32v6
37260799c6dSRussell King	select CPU_32v6K
373e399b1a4SRussell King	select CPU_ABRT_EV6
374e399b1a4SRussell King	select CPU_PABRT_V6
375e399b1a4SRussell King	select CPU_CACHE_V6
376e399b1a4SRussell King	select CPU_CACHE_VIPT
377e399b1a4SRussell King	select CPU_CP15_MMU
378e399b1a4SRussell King	select CPU_HAS_ASID if MMU
379e399b1a4SRussell King	select CPU_COPY_V6 if MMU
380e399b1a4SRussell King	select CPU_TLB_V6 if MMU
3814a5f79e7SRussell King
38223688e99SCatalin Marinas# ARMv7
38323688e99SCatalin Marinasconfig CPU_V7
3841b504bbeSColin Tuckley	bool "Support ARM V7 processor" if ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX
38515490ef8SRussell King	select CPU_32v6K
38623688e99SCatalin Marinas	select CPU_32v7
38723688e99SCatalin Marinas	select CPU_ABRT_EV7
3884fb28474SKirill A. Shutemov	select CPU_PABRT_V7
38923688e99SCatalin Marinas	select CPU_CACHE_V7
39023688e99SCatalin Marinas	select CPU_CACHE_VIPT
39123688e99SCatalin Marinas	select CPU_CP15_MMU
3922eb8c82bSCatalin Marinas	select CPU_HAS_ASID if MMU
39323688e99SCatalin Marinas	select CPU_COPY_V6 if MMU
3942ccdd1e7SCatalin Marinas	select CPU_TLB_V7 if MMU
39523688e99SCatalin Marinas
3961da177e4SLinus Torvalds# Figure out what processor architecture version we should be using.
3971da177e4SLinus Torvalds# This defines the compiler instruction set which depends on the machine type.
3981da177e4SLinus Torvaldsconfig CPU_32v3
3991da177e4SLinus Torvalds	bool
40060b6cf68SRussell King	select TLS_REG_EMUL if SMP || !MMU
40148fa14f7SRussell King	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4028762df4dSRussell King	select CPU_USE_DOMAINS if MMU
4031da177e4SLinus Torvalds
4041da177e4SLinus Torvaldsconfig CPU_32v4
4051da177e4SLinus Torvalds	bool
40660b6cf68SRussell King	select TLS_REG_EMUL if SMP || !MMU
40748fa14f7SRussell King	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4088762df4dSRussell King	select CPU_USE_DOMAINS if MMU
4091da177e4SLinus Torvalds
410260e98edSLennert Buytenhekconfig CPU_32v4T
411260e98edSLennert Buytenhek	bool
412260e98edSLennert Buytenhek	select TLS_REG_EMUL if SMP || !MMU
413260e98edSLennert Buytenhek	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4148762df4dSRussell King	select CPU_USE_DOMAINS if MMU
415260e98edSLennert Buytenhek
4161da177e4SLinus Torvaldsconfig CPU_32v5
4171da177e4SLinus Torvalds	bool
41860b6cf68SRussell King	select TLS_REG_EMUL if SMP || !MMU
41948fa14f7SRussell King	select NEEDS_SYSCALL_FOR_CMPXCHG if SMP
4208762df4dSRussell King	select CPU_USE_DOMAINS if MMU
4211da177e4SLinus Torvalds
4221da177e4SLinus Torvaldsconfig CPU_32v6
4231da177e4SLinus Torvalds	bool
424367afaf8SCatalin Marinas	select TLS_REG_EMUL if !CPU_32v6K && !MMU
4258762df4dSRussell King	select CPU_USE_DOMAINS if CPU_V6 && MMU
4261da177e4SLinus Torvalds
427e399b1a4SRussell Kingconfig CPU_32v6K
42860799c6dSRussell King	bool
4291da177e4SLinus Torvalds
43023688e99SCatalin Marinasconfig CPU_32v7
43123688e99SCatalin Marinas	bool
43223688e99SCatalin Marinas
4331da177e4SLinus Torvalds# The abort model
4340f45d7f3SHyok S. Choiconfig CPU_ABRT_NOMMU
4350f45d7f3SHyok S. Choi	bool
4360f45d7f3SHyok S. Choi
4371da177e4SLinus Torvaldsconfig CPU_ABRT_EV4
4381da177e4SLinus Torvalds	bool
4391da177e4SLinus Torvalds
4401da177e4SLinus Torvaldsconfig CPU_ABRT_EV4T
4411da177e4SLinus Torvalds	bool
4421da177e4SLinus Torvalds
4431da177e4SLinus Torvaldsconfig CPU_ABRT_LV4T
4441da177e4SLinus Torvalds	bool
4451da177e4SLinus Torvalds
4461da177e4SLinus Torvaldsconfig CPU_ABRT_EV5T
4471da177e4SLinus Torvalds	bool
4481da177e4SLinus Torvalds
4491da177e4SLinus Torvaldsconfig CPU_ABRT_EV5TJ
4501da177e4SLinus Torvalds	bool
4511da177e4SLinus Torvalds
4521da177e4SLinus Torvaldsconfig CPU_ABRT_EV6
4531da177e4SLinus Torvalds	bool
4541da177e4SLinus Torvalds
45523688e99SCatalin Marinasconfig CPU_ABRT_EV7
45623688e99SCatalin Marinas	bool
45723688e99SCatalin Marinas
4584fb28474SKirill A. Shutemovconfig CPU_PABRT_LEGACY
45948d7927bSPaul Brook	bool
46048d7927bSPaul Brook
4614fb28474SKirill A. Shutemovconfig CPU_PABRT_V6
4624fb28474SKirill A. Shutemov	bool
4634fb28474SKirill A. Shutemov
4644fb28474SKirill A. Shutemovconfig CPU_PABRT_V7
46548d7927bSPaul Brook	bool
46648d7927bSPaul Brook
4671da177e4SLinus Torvalds# The cache model
4681da177e4SLinus Torvaldsconfig CPU_CACHE_V3
4691da177e4SLinus Torvalds	bool
4701da177e4SLinus Torvalds
4711da177e4SLinus Torvaldsconfig CPU_CACHE_V4
4721da177e4SLinus Torvalds	bool
4731da177e4SLinus Torvalds
4741da177e4SLinus Torvaldsconfig CPU_CACHE_V4WT
4751da177e4SLinus Torvalds	bool
4761da177e4SLinus Torvalds
4771da177e4SLinus Torvaldsconfig CPU_CACHE_V4WB
4781da177e4SLinus Torvalds	bool
4791da177e4SLinus Torvalds
4801da177e4SLinus Torvaldsconfig CPU_CACHE_V6
4811da177e4SLinus Torvalds	bool
4821da177e4SLinus Torvalds
48323688e99SCatalin Marinasconfig CPU_CACHE_V7
48423688e99SCatalin Marinas	bool
48523688e99SCatalin Marinas
4861da177e4SLinus Torvaldsconfig CPU_CACHE_VIVT
4871da177e4SLinus Torvalds	bool
4881da177e4SLinus Torvalds
4891da177e4SLinus Torvaldsconfig CPU_CACHE_VIPT
4901da177e4SLinus Torvalds	bool
4911da177e4SLinus Torvalds
49228853ac8SPaulius Zaleckasconfig CPU_CACHE_FA
49328853ac8SPaulius Zaleckas	bool
49428853ac8SPaulius Zaleckas
495f9c21a6eSHyok S. Choiif MMU
4961da177e4SLinus Torvalds# The copy-page model
4971da177e4SLinus Torvaldsconfig CPU_COPY_V4WT
4981da177e4SLinus Torvalds	bool
4991da177e4SLinus Torvalds
5001da177e4SLinus Torvaldsconfig CPU_COPY_V4WB
5011da177e4SLinus Torvalds	bool
5021da177e4SLinus Torvalds
5030ed15071SLennert Buytenhekconfig CPU_COPY_FEROCEON
5040ed15071SLennert Buytenhek	bool
5050ed15071SLennert Buytenhek
50628853ac8SPaulius Zaleckasconfig CPU_COPY_FA
50728853ac8SPaulius Zaleckas	bool
50828853ac8SPaulius Zaleckas
5091da177e4SLinus Torvaldsconfig CPU_COPY_V6
5101da177e4SLinus Torvalds	bool
5111da177e4SLinus Torvalds
5121da177e4SLinus Torvalds# This selects the TLB model
5131da177e4SLinus Torvaldsconfig CPU_TLB_V4WT
5141da177e4SLinus Torvalds	bool
5151da177e4SLinus Torvalds	help
5161da177e4SLinus Torvalds	  ARM Architecture Version 4 TLB with writethrough cache.
5171da177e4SLinus Torvalds
5181da177e4SLinus Torvaldsconfig CPU_TLB_V4WB
5191da177e4SLinus Torvalds	bool
5201da177e4SLinus Torvalds	help
5211da177e4SLinus Torvalds	  ARM Architecture Version 4 TLB with writeback cache.
5221da177e4SLinus Torvalds
5231da177e4SLinus Torvaldsconfig CPU_TLB_V4WBI
5241da177e4SLinus Torvalds	bool
5251da177e4SLinus Torvalds	help
5261da177e4SLinus Torvalds	  ARM Architecture Version 4 TLB with writeback cache and invalidate
5271da177e4SLinus Torvalds	  instruction cache entry.
5281da177e4SLinus Torvalds
52999c6dc11SLennert Buytenhekconfig CPU_TLB_FEROCEON
53099c6dc11SLennert Buytenhek	bool
53199c6dc11SLennert Buytenhek	help
53299c6dc11SLennert Buytenhek	  Feroceon TLB (v4wbi with non-outer-cachable page table walks).
53399c6dc11SLennert Buytenhek
53428853ac8SPaulius Zaleckasconfig CPU_TLB_FA
53528853ac8SPaulius Zaleckas	bool
53628853ac8SPaulius Zaleckas	help
53728853ac8SPaulius Zaleckas	  Faraday ARM FA526 architecture, unified TLB with writeback cache
53828853ac8SPaulius Zaleckas	  and invalidate instruction cache entry. Branch target buffer is
53928853ac8SPaulius Zaleckas	  also supported.
54028853ac8SPaulius Zaleckas
5411da177e4SLinus Torvaldsconfig CPU_TLB_V6
5421da177e4SLinus Torvalds	bool
5431da177e4SLinus Torvalds
5442ccdd1e7SCatalin Marinasconfig CPU_TLB_V7
5452ccdd1e7SCatalin Marinas	bool
5462ccdd1e7SCatalin Marinas
547e220ba60SDave Estesconfig VERIFY_PERMISSION_FAULT
548e220ba60SDave Estes	bool
549f9c21a6eSHyok S. Choiendif
550f9c21a6eSHyok S. Choi
551516793c6SRussell Kingconfig CPU_HAS_ASID
552516793c6SRussell King	bool
553516793c6SRussell King	help
554516793c6SRussell King	  This indicates whether the CPU has the ASID register; used to
555516793c6SRussell King	  tag TLB and possibly cache entries.
556516793c6SRussell King
557fefdaa06SHyok S. Choiconfig CPU_CP15
558fefdaa06SHyok S. Choi	bool
559fefdaa06SHyok S. Choi	help
560fefdaa06SHyok S. Choi	  Processor has the CP15 register.
561fefdaa06SHyok S. Choi
562fefdaa06SHyok S. Choiconfig CPU_CP15_MMU
563fefdaa06SHyok S. Choi	bool
564fefdaa06SHyok S. Choi	select CPU_CP15
565fefdaa06SHyok S. Choi	help
566fefdaa06SHyok S. Choi	  Processor has the CP15 register, which has MMU related registers.
567fefdaa06SHyok S. Choi
568fefdaa06SHyok S. Choiconfig CPU_CP15_MPU
569fefdaa06SHyok S. Choi	bool
570fefdaa06SHyok S. Choi	select CPU_CP15
571fefdaa06SHyok S. Choi	help
572fefdaa06SHyok S. Choi	  Processor has the CP15 register, which has MPU related registers.
573fefdaa06SHyok S. Choi
574247055aaSCatalin Marinasconfig CPU_USE_DOMAINS
575247055aaSCatalin Marinas	bool
576247055aaSCatalin Marinas	help
577247055aaSCatalin Marinas	  This option enables or disables the use of domain switching
578247055aaSCatalin Marinas	  via the set_fs() function.
579247055aaSCatalin Marinas
58023bdf86aSLennert Buytenhek#
58123bdf86aSLennert Buytenhek# CPU supports 36-bit I/O
58223bdf86aSLennert Buytenhek#
58323bdf86aSLennert Buytenhekconfig IO_36
58423bdf86aSLennert Buytenhek	bool
58523bdf86aSLennert Buytenhek
5861da177e4SLinus Torvaldscomment "Processor Features"
5871da177e4SLinus Torvalds
588497b7e94SCatalin Marinasconfig ARM_LPAE
589497b7e94SCatalin Marinas	bool "Support for the Large Physical Address Extension"
59008a183f0SCatalin Marinas	depends on MMU && CPU_32v7 && !CPU_32v6 && !CPU_32v5 && \
59108a183f0SCatalin Marinas		!CPU_32v4 && !CPU_32v3
592497b7e94SCatalin Marinas	help
593497b7e94SCatalin Marinas	  Say Y if you have an ARMv7 processor supporting the LPAE page
594497b7e94SCatalin Marinas	  table format and you would like to access memory beyond the
595497b7e94SCatalin Marinas	  4GB limit. The resulting kernel image will not run on
596497b7e94SCatalin Marinas	  processors without the LPA extension.
597497b7e94SCatalin Marinas
598497b7e94SCatalin Marinas	  If unsure, say N.
599497b7e94SCatalin Marinas
600497b7e94SCatalin Marinasconfig ARCH_PHYS_ADDR_T_64BIT
601497b7e94SCatalin Marinas	def_bool ARM_LPAE
602497b7e94SCatalin Marinas
603497b7e94SCatalin Marinasconfig ARCH_DMA_ADDR_T_64BIT
604497b7e94SCatalin Marinas	bool
605497b7e94SCatalin Marinas
6061da177e4SLinus Torvaldsconfig ARM_THUMB
6071da177e4SLinus Torvalds	bool "Support Thumb user binaries"
608e399b1a4SRussell 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
6091da177e4SLinus Torvalds	default y
6101da177e4SLinus Torvalds	help
6111da177e4SLinus Torvalds	  Say Y if you want to include kernel support for running user space
6121da177e4SLinus Torvalds	  Thumb binaries.
6131da177e4SLinus Torvalds
6141da177e4SLinus Torvalds	  The Thumb instruction set is a compressed form of the standard ARM
6151da177e4SLinus Torvalds	  instruction set resulting in smaller binaries at the expense of
6161da177e4SLinus Torvalds	  slightly less efficient code.
6171da177e4SLinus Torvalds
6181da177e4SLinus Torvalds	  If you don't know what this all is, saying Y is a safe choice.
6191da177e4SLinus Torvalds
620d7f864beSCatalin Marinasconfig ARM_THUMBEE
621d7f864beSCatalin Marinas	bool "Enable ThumbEE CPU extension"
622d7f864beSCatalin Marinas	depends on CPU_V7
623d7f864beSCatalin Marinas	help
624d7f864beSCatalin Marinas	  Say Y here if you have a CPU with the ThumbEE extension and code to
625d7f864beSCatalin Marinas	  make use of it. Say N for code that can run on CPUs without ThumbEE.
626d7f864beSCatalin Marinas
627*5b6728d4SDave Martinconfig ARM_VIRT_EXT
628*5b6728d4SDave Martin	bool "Native support for the ARM Virtualization Extensions"
629*5b6728d4SDave Martin	depends on MMU && CPU_V7
630*5b6728d4SDave Martin	help
631*5b6728d4SDave Martin	  Enable the kernel to make use of the ARM Virtualization
632*5b6728d4SDave Martin	  Extensions to install hypervisors without run-time firmware
633*5b6728d4SDave Martin	  assistance.
634*5b6728d4SDave Martin
635*5b6728d4SDave Martin	  A compliant bootloader is required in order to make maximum
636*5b6728d4SDave Martin	  use of this feature.  Refer to Documentation/arm/Booting for
637*5b6728d4SDave Martin	  details.
638*5b6728d4SDave Martin
639*5b6728d4SDave Martin	  It is safe to enable this option even if the kernel may not be
640*5b6728d4SDave Martin	  booted in HYP mode, may not have support for the
641*5b6728d4SDave Martin	  virtualization extensions, or may be booted with a
642*5b6728d4SDave Martin	  non-compliant bootloader.
643*5b6728d4SDave Martin
64464d2dc38SLeif Lindholmconfig SWP_EMULATE
64564d2dc38SLeif Lindholm	bool "Emulate SWP/SWPB instructions"
646bd1274dcSRussell King	depends on !CPU_USE_DOMAINS && CPU_V7
64764d2dc38SLeif Lindholm	select HAVE_PROC_CPU if PROC_FS
64864d2dc38SLeif Lindholm	default y if SMP
64964d2dc38SLeif Lindholm	help
65064d2dc38SLeif Lindholm	  ARMv6 architecture deprecates use of the SWP/SWPB instructions.
65164d2dc38SLeif Lindholm	  ARMv7 multiprocessing extensions introduce the ability to disable
65264d2dc38SLeif Lindholm	  these instructions, triggering an undefined instruction exception
65364d2dc38SLeif Lindholm	  when executed. Say Y here to enable software emulation of these
65464d2dc38SLeif Lindholm	  instructions for userspace (not kernel) using LDREX/STREX.
65564d2dc38SLeif Lindholm	  Also creates /proc/cpu/swp_emulation for statistics.
65664d2dc38SLeif Lindholm
65764d2dc38SLeif Lindholm	  In some older versions of glibc [<=2.8] SWP is used during futex
65864d2dc38SLeif Lindholm	  trylock() operations with the assumption that the code will not
65964d2dc38SLeif Lindholm	  be preempted. This invalid assumption may be more likely to fail
66064d2dc38SLeif Lindholm	  with SWP emulation enabled, leading to deadlock of the user
66164d2dc38SLeif Lindholm	  application.
66264d2dc38SLeif Lindholm
66364d2dc38SLeif Lindholm	  NOTE: when accessing uncached shared regions, LDREX/STREX rely
66464d2dc38SLeif Lindholm	  on an external transaction monitoring block called a global
66564d2dc38SLeif Lindholm	  monitor to maintain update atomicity. If your system does not
66664d2dc38SLeif Lindholm	  implement a global monitor, this option can cause programs that
66764d2dc38SLeif Lindholm	  perform SWP operations to uncached memory to deadlock.
66864d2dc38SLeif Lindholm
66964d2dc38SLeif Lindholm	  If unsure, say Y.
67064d2dc38SLeif Lindholm
6711da177e4SLinus Torvaldsconfig CPU_BIG_ENDIAN
6721da177e4SLinus Torvalds	bool "Build big-endian kernel"
6731da177e4SLinus Torvalds	depends on ARCH_SUPPORTS_BIG_ENDIAN
6741da177e4SLinus Torvalds	help
6751da177e4SLinus Torvalds	  Say Y if you plan on running a kernel in big-endian mode.
6761da177e4SLinus Torvalds	  Note that your board must be properly built and your board
6771da177e4SLinus Torvalds	  port must properly enable any big-endian related features
6781da177e4SLinus Torvalds	  of your chipset/board/processor.
6791da177e4SLinus Torvalds
68026584853SCatalin Marinasconfig CPU_ENDIAN_BE8
68126584853SCatalin Marinas	bool
68226584853SCatalin Marinas	depends on CPU_BIG_ENDIAN
683e399b1a4SRussell King	default CPU_V6 || CPU_V6K || CPU_V7
68426584853SCatalin Marinas	help
68526584853SCatalin Marinas	  Support for the BE-8 (big-endian) mode on ARMv6 and ARMv7 processors.
68626584853SCatalin Marinas
68726584853SCatalin Marinasconfig CPU_ENDIAN_BE32
68826584853SCatalin Marinas	bool
68926584853SCatalin Marinas	depends on CPU_BIG_ENDIAN
69026584853SCatalin Marinas	default !CPU_ENDIAN_BE8
69126584853SCatalin Marinas	help
69226584853SCatalin Marinas	  Support for the BE-32 (big-endian) mode on pre-ARMv6 processors.
69326584853SCatalin Marinas
6946afd6faeSHyok S. Choiconfig CPU_HIGH_VECTOR
6956340aa61SRobert P. J. Day	depends on !MMU && CPU_CP15 && !CPU_ARM740T
6966afd6faeSHyok S. Choi	bool "Select the High exception vector"
6976afd6faeSHyok S. Choi	help
6986afd6faeSHyok S. Choi	  Say Y here to select high exception vector(0xFFFF0000~).
6999b7333a9SWill Deacon	  The exception vector can vary depending on the platform
7006afd6faeSHyok S. Choi	  design in nommu mode. If your platform needs to select
7016afd6faeSHyok S. Choi	  high exception vector, say Y.
7026afd6faeSHyok S. Choi	  Otherwise or if you are unsure, say N, and the low exception
7036afd6faeSHyok S. Choi	  vector (0x00000000~) will be used.
7046afd6faeSHyok S. Choi
7051da177e4SLinus Torvaldsconfig CPU_ICACHE_DISABLE
706f12d0d7cSHyok S. Choi	bool "Disable I-Cache (I-bit)"
707357c9c1fSRussell King	depends on CPU_CP15 && !(CPU_ARM720T || CPU_ARM740T || CPU_XSCALE || CPU_XSC3)
7081da177e4SLinus Torvalds	help
7091da177e4SLinus Torvalds	  Say Y here to disable the processor instruction cache. Unless
7101da177e4SLinus Torvalds	  you have a reason not to or are unsure, say N.
7111da177e4SLinus Torvalds
7121da177e4SLinus Torvaldsconfig CPU_DCACHE_DISABLE
713f12d0d7cSHyok S. Choi	bool "Disable D-Cache (C-bit)"
714f12d0d7cSHyok S. Choi	depends on CPU_CP15
7151da177e4SLinus Torvalds	help
7161da177e4SLinus Torvalds	  Say Y here to disable the processor data cache. Unless
7171da177e4SLinus Torvalds	  you have a reason not to or are unsure, say N.
7181da177e4SLinus Torvalds
719f37f46ebSHyok S. Choiconfig CPU_DCACHE_SIZE
720f37f46ebSHyok S. Choi	hex
721f37f46ebSHyok S. Choi	depends on CPU_ARM740T || CPU_ARM946E
722f37f46ebSHyok S. Choi	default 0x00001000 if CPU_ARM740T
723f37f46ebSHyok S. Choi	default 0x00002000 # default size for ARM946E-S
724f37f46ebSHyok S. Choi	help
725f37f46ebSHyok S. Choi	  Some cores are synthesizable to have various sized cache. For
726f37f46ebSHyok S. Choi	  ARM946E-S case, it can vary from 0KB to 1MB.
727f37f46ebSHyok S. Choi	  To support such cache operations, it is efficient to know the size
728f37f46ebSHyok S. Choi	  before compile time.
729f37f46ebSHyok S. Choi	  If your SoC is configured to have a different size, define the value
730f37f46ebSHyok S. Choi	  here with proper conditions.
731f37f46ebSHyok S. Choi
7321da177e4SLinus Torvaldsconfig CPU_DCACHE_WRITETHROUGH
7331da177e4SLinus Torvalds	bool "Force write through D-cache"
73428853ac8SPaulius Zaleckas	depends on (CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_FA526) && !CPU_DCACHE_DISABLE
7351da177e4SLinus Torvalds	default y if CPU_ARM925T
7361da177e4SLinus Torvalds	help
7371da177e4SLinus Torvalds	  Say Y here to use the data cache in writethrough mode. Unless you
7381da177e4SLinus Torvalds	  specifically require this or are unsure, say N.
7391da177e4SLinus Torvalds
7401da177e4SLinus Torvaldsconfig CPU_CACHE_ROUND_ROBIN
7411da177e4SLinus Torvalds	bool "Round robin I and D cache replacement algorithm"
742f37f46ebSHyok S. Choi	depends on (CPU_ARM926T || CPU_ARM946E || CPU_ARM1020) && (!CPU_ICACHE_DISABLE || !CPU_DCACHE_DISABLE)
7431da177e4SLinus Torvalds	help
7441da177e4SLinus Torvalds	  Say Y here to use the predictable round-robin cache replacement
7451da177e4SLinus Torvalds	  policy.  Unless you specifically require this or are unsure, say N.
7461da177e4SLinus Torvalds
7471da177e4SLinus Torvaldsconfig CPU_BPREDICT_DISABLE
7481da177e4SLinus Torvalds	bool "Disable branch prediction"
749e399b1a4SRussell King	depends on CPU_ARM1020 || CPU_V6 || CPU_V6K || CPU_MOHAWK || CPU_XSC3 || CPU_V7 || CPU_FA526
7501da177e4SLinus Torvalds	help
7511da177e4SLinus Torvalds	  Say Y here to disable branch prediction.  If unsure, say N.
7522d2669b6SNicolas Pitre
7534b0e07a5SNicolas Pitreconfig TLS_REG_EMUL
7544b0e07a5SNicolas Pitre	bool
7554b0e07a5SNicolas Pitre	help
75670489c88SNicolas Pitre	  An SMP system using a pre-ARMv6 processor (there are apparently
75770489c88SNicolas Pitre	  a few prototypes like that in existence) and therefore access to
75870489c88SNicolas Pitre	  that required register must be emulated.
7594b0e07a5SNicolas Pitre
760dcef1f63SNicolas Pitreconfig NEEDS_SYSCALL_FOR_CMPXCHG
761dcef1f63SNicolas Pitre	bool
762dcef1f63SNicolas Pitre	help
763dcef1f63SNicolas Pitre	  SMP on a pre-ARMv6 processor?  Well OK then.
764dcef1f63SNicolas Pitre	  Forget about fast user space cmpxchg support.
765dcef1f63SNicolas Pitre	  It is just not possible.
766dcef1f63SNicolas Pitre
767ad642d9fSCatalin Marinasconfig DMA_CACHE_RWFO
768ad642d9fSCatalin Marinas	bool "Enable read/write for ownership DMA cache maintenance"
7693bc28c8eSRussell King	depends on CPU_V6K && SMP
770ad642d9fSCatalin Marinas	default y
771ad642d9fSCatalin Marinas	help
772ad642d9fSCatalin Marinas	  The Snoop Control Unit on ARM11MPCore does not detect the
773ad642d9fSCatalin Marinas	  cache maintenance operations and the dma_{map,unmap}_area()
774ad642d9fSCatalin Marinas	  functions may leave stale cache entries on other CPUs. By
775ad642d9fSCatalin Marinas	  enabling this option, Read or Write For Ownership in the ARMv6
776ad642d9fSCatalin Marinas	  DMA cache maintenance functions is performed. These LDR/STR
777ad642d9fSCatalin Marinas	  instructions change the cache line state to shared or modified
778ad642d9fSCatalin Marinas	  so that the cache operation has the desired effect.
779ad642d9fSCatalin Marinas
780ad642d9fSCatalin Marinas	  Note that the workaround is only valid on processors that do
781ad642d9fSCatalin Marinas	  not perform speculative loads into the D-cache. For such
782ad642d9fSCatalin Marinas	  processors, if cache maintenance operations are not broadcast
783ad642d9fSCatalin Marinas	  in hardware, other workarounds are needed (e.g. cache
784ad642d9fSCatalin Marinas	  maintenance broadcasting in software via FIQ).
785ad642d9fSCatalin Marinas
786953233dcSCatalin Marinasconfig OUTER_CACHE
787953233dcSCatalin Marinas	bool
788382266adSCatalin Marinas
789319f551aSCatalin Marinasconfig OUTER_CACHE_SYNC
790319f551aSCatalin Marinas	bool
791319f551aSCatalin Marinas	help
792319f551aSCatalin Marinas	  The outer cache has a outer_cache_fns.sync function pointer
793319f551aSCatalin Marinas	  that can be used to drain the write buffer of the outer cache.
794319f551aSCatalin Marinas
79599c6dc11SLennert Buytenhekconfig CACHE_FEROCEON_L2
79699c6dc11SLennert Buytenhek	bool "Enable the Feroceon L2 cache controller"
797794d15b2SStanislav Samsonov	depends on ARCH_KIRKWOOD || ARCH_MV78XX0
79899c6dc11SLennert Buytenhek	default y
799382266adSCatalin Marinas	select OUTER_CACHE
80099c6dc11SLennert Buytenhek	help
80199c6dc11SLennert Buytenhek	  This option enables the Feroceon L2 cache controller.
80299c6dc11SLennert Buytenhek
8034360bb41SRonen Shitritconfig CACHE_FEROCEON_L2_WRITETHROUGH
8044360bb41SRonen Shitrit	bool "Force Feroceon L2 cache write through"
8054360bb41SRonen Shitrit	depends on CACHE_FEROCEON_L2
8064360bb41SRonen Shitrit	help
8074360bb41SRonen Shitrit	  Say Y here to use the Feroceon L2 cache in writethrough mode.
8084360bb41SRonen Shitrit	  Unless you specifically require this, say N for writeback mode.
8094360bb41SRonen Shitrit
810ce5ea9f3SDave Martinconfig MIGHT_HAVE_CACHE_L2X0
811ce5ea9f3SDave Martin	bool
812ce5ea9f3SDave Martin	help
813ce5ea9f3SDave Martin	  This option should be selected by machines which have a L2x0
814ce5ea9f3SDave Martin	  or PL310 cache controller, but where its use is optional.
815ce5ea9f3SDave Martin
816ce5ea9f3SDave Martin	  The only effect of this option is to make CACHE_L2X0 and
817ce5ea9f3SDave Martin	  related options available to the user for configuration.
818ce5ea9f3SDave Martin
819ce5ea9f3SDave Martin	  Boards or SoCs which always require the cache controller
820ce5ea9f3SDave Martin	  support to be present should select CACHE_L2X0 directly
821ce5ea9f3SDave Martin	  instead of this option, thus preventing the user from
822ce5ea9f3SDave Martin	  inadvertently configuring a broken kernel.
823ce5ea9f3SDave Martin
8241da177e4SLinus Torvaldsconfig CACHE_L2X0
825ce5ea9f3SDave Martin	bool "Enable the L2x0 outer cache controller" if MIGHT_HAVE_CACHE_L2X0
826ce5ea9f3SDave Martin	default MIGHT_HAVE_CACHE_L2X0
8271da177e4SLinus Torvalds	select OUTER_CACHE
82823107c54SCatalin Marinas	select OUTER_CACHE_SYNC
829ba927951SCatalin Marinas	help
830ba927951SCatalin Marinas	  This option enables the L2x0 PrimeCell.
831905a09d5SEric Miao
8329a6655e4SCatalin Marinasconfig CACHE_PL310
8339a6655e4SCatalin Marinas	bool
8349a6655e4SCatalin Marinas	depends on CACHE_L2X0
835e399b1a4SRussell King	default y if CPU_V7 && !(CPU_V6 || CPU_V6K)
8369a6655e4SCatalin Marinas	help
8379a6655e4SCatalin Marinas	  This option enables optimisations for the PL310 cache
8389a6655e4SCatalin Marinas	  controller.
8399a6655e4SCatalin Marinas
840573a652fSLennert Buytenhekconfig CACHE_TAUROS2
841573a652fSLennert Buytenhek	bool "Enable the Tauros2 L2 cache controller"
8423f408fa0SHaojian Zhuang	depends on (ARCH_DOVE || ARCH_MMP || CPU_PJ4)
843573a652fSLennert Buytenhek	default y
844573a652fSLennert Buytenhek	select OUTER_CACHE
845573a652fSLennert Buytenhek	help
846573a652fSLennert Buytenhek	  This option enables the Tauros2 L2 cache controller (as
847573a652fSLennert Buytenhek	  found on PJ1/PJ4).
848573a652fSLennert Buytenhek
849905a09d5SEric Miaoconfig CACHE_XSC3L2
850905a09d5SEric Miao	bool "Enable the L2 cache on XScale3"
851905a09d5SEric Miao	depends on CPU_XSC3
852905a09d5SEric Miao	default y
853905a09d5SEric Miao	select OUTER_CACHE
854905a09d5SEric Miao	help
855905a09d5SEric Miao	  This option enables the L2 cache on XScale3.
856910a17e5SKirill A. Shutemov
8575637a126SRussell Kingconfig ARM_L1_CACHE_SHIFT_6
8585637a126SRussell King	bool
859a092f2b1SWill Deacon	default y if CPU_V7
8605637a126SRussell King	help
8615637a126SRussell King	  Setting ARM L1 cache line size to 64 Bytes.
8625637a126SRussell King
863910a17e5SKirill A. Shutemovconfig ARM_L1_CACHE_SHIFT
864910a17e5SKirill A. Shutemov	int
865d6d502faSKukjin Kim	default 6 if ARM_L1_CACHE_SHIFT_6
866910a17e5SKirill A. Shutemov	default 5
86747ab0deeSRussell King
86847ab0deeSRussell Kingconfig ARM_DMA_MEM_BUFFERABLE
869e399b1a4SRussell King	bool "Use non-cacheable memory for DMA" if (CPU_V6 || CPU_V6K) && !CPU_V7
87042c4dafeSCatalin Marinas	depends on !(MACH_REALVIEW_PB1176 || REALVIEW_EB_ARM11MP || \
87142c4dafeSCatalin Marinas		     MACH_REALVIEW_PB11MP)
872e399b1a4SRussell King	default y if CPU_V6 || CPU_V6K || CPU_V7
87347ab0deeSRussell King	help
87447ab0deeSRussell King	  Historically, the kernel has used strongly ordered mappings to
87547ab0deeSRussell King	  provide DMA coherent memory.  With the advent of ARMv7, mapping
87647ab0deeSRussell King	  memory with differing types results in unpredictable behaviour,
87747ab0deeSRussell King	  so on these CPUs, this option is forced on.
87847ab0deeSRussell King
87947ab0deeSRussell King	  Multiple mappings with differing attributes is also unpredictable
88047ab0deeSRussell King	  on ARMv6 CPUs, but since they do not have aggressive speculative
88147ab0deeSRussell King	  prefetch, no harm appears to occur.
88247ab0deeSRussell King
88347ab0deeSRussell King	  However, drivers may be missing the necessary barriers for ARMv6,
88447ab0deeSRussell King	  and therefore turning this on may result in unpredictable driver
88547ab0deeSRussell King	  behaviour.  Therefore, we offer this as an option.
88647ab0deeSRussell King
88747ab0deeSRussell King	  You are recommended say 'Y' here and debug any affected drivers.
888ac1d426eSRussell King
889e7c5650fSCatalin Marinasconfig ARCH_HAS_BARRIERS
890e7c5650fSCatalin Marinas	bool
891e7c5650fSCatalin Marinas	help
892e7c5650fSCatalin Marinas	  This option allows the use of custom mandatory barriers
893e7c5650fSCatalin Marinas	  included via the mach/barriers.h file.
894