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 9c32b7655SArnd Bergmann bool 106b237a35SRussell King depends on !MMU 1107e0da78SHyok S. Choi select CPU_32v4T 1207e0da78SHyok S. Choi select CPU_ABRT_LV4T 1307e0da78SHyok S. Choi select CPU_CACHE_V4 14b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 24dc680b98SLinus Walleij bool "Support ARM720T processor" if (ARCH_MULTI_V4T && ARCH_INTEGRATOR) 25260e98edSLennert Buytenhek select CPU_32v4T 261da177e4SLinus Torvalds select CPU_ABRT_LV4T 271da177e4SLinus Torvalds select CPU_CACHE_V4 281da177e4SLinus Torvalds select CPU_CACHE_VIVT 29f9c21a6eSHyok S. Choi select CPU_COPY_V4WT if MMU 30b1b3f49cSRussell King select CPU_CP15_MMU 31b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 42dc680b98SLinus Walleij bool "Support ARM740T processor" if (ARCH_MULTI_V4T && ARCH_INTEGRATOR) 436b237a35SRussell King depends on !MMU 44b731c311SHyok S. Choi select CPU_32v4T 45b731c311SHyok S. Choi select CPU_ABRT_LV4T 4682d9b0d0SWill Deacon select CPU_CACHE_V4 47b731c311SHyok S. Choi select CPU_CP15_MPU 48b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 59c32b7655SArnd Bergmann bool 606b237a35SRussell King depends on !MMU 6143f5f014SHyok S. Choi select CPU_32v4T 620f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 6343f5f014SHyok S. Choi select CPU_CACHE_V4 64b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 74dc680b98SLinus Walleij bool "Support ARM920T processor" if (ARCH_MULTI_V4T && ARCH_INTEGRATOR) 75260e98edSLennert Buytenhek select CPU_32v4T 761da177e4SLinus Torvalds select CPU_ABRT_EV4T 771da177e4SLinus Torvalds select CPU_CACHE_V4WT 781da177e4SLinus Torvalds select CPU_CACHE_VIVT 79f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 80b1b3f49cSRussell King select CPU_CP15_MMU 81b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 92dc680b98SLinus Walleij bool "Support ARM922T processor" if (ARCH_MULTI_V4T && ARCH_INTEGRATOR) 93260e98edSLennert Buytenhek select CPU_32v4T 941da177e4SLinus Torvalds select CPU_ABRT_EV4T 951da177e4SLinus Torvalds select CPU_CACHE_V4WT 961da177e4SLinus Torvalds select CPU_CACHE_VIVT 97f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 98b1b3f49cSRussell King select CPU_CP15_MMU 99b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 1141da177e4SLinus Torvalds select CPU_CACHE_V4WT 1151da177e4SLinus Torvalds select CPU_CACHE_VIVT 116f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 117b1b3f49cSRussell King select CPU_CP15_MMU 118b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 130dc680b98SLinus Walleij bool "Support ARM926T processor" if (!ARCH_MULTIPLATFORM || ARCH_MULTI_V5) && (ARCH_INTEGRATOR || MACH_REALVIEW_EB) 1311da177e4SLinus Torvalds select CPU_32v5 1321da177e4SLinus Torvalds select CPU_ABRT_EV5TJ 1331da177e4SLinus Torvalds select CPU_CACHE_VIVT 134f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 135b1b3f49cSRussell King select CPU_CP15_MMU 136b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 15128853ac8SPaulius Zaleckas select CPU_CACHE_FA 152b1b3f49cSRussell King select CPU_CACHE_VIVT 15328853ac8SPaulius Zaleckas select CPU_COPY_FA if MMU 154b1b3f49cSRussell King select CPU_CP15_MMU 155b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 166dc680b98SLinus Walleij bool "Support ARM940T processor" if (ARCH_MULTI_V4T && ARCH_INTEGRATOR) 1676b237a35SRussell King depends on !MMU 168d60674ebSHyok S. Choi select CPU_32v4T 1690f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 170d60674ebSHyok S. Choi select CPU_CACHE_VIVT 171d60674ebSHyok S. Choi select CPU_CP15_MPU 172b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 184dc680b98SLinus Walleij bool "Support ARM946E-S processor" if (ARCH_MULTI_V5 && ARCH_INTEGRATOR) 1856b237a35SRussell King depends on !MMU 186f37f46ebSHyok S. Choi select CPU_32v5 1870f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 188f37f46ebSHyok S. Choi select CPU_CACHE_VIVT 189f37f46ebSHyok S. Choi select CPU_CP15_MPU 190b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 201dc680b98SLinus Walleij bool "Support ARM1020T (rev 0) processor" if (ARCH_MULTI_V5 && ARCH_INTEGRATOR) 2021da177e4SLinus Torvalds select CPU_32v5 2031da177e4SLinus Torvalds select CPU_ABRT_EV4T 2041da177e4SLinus Torvalds select CPU_CACHE_V4WT 2051da177e4SLinus Torvalds select CPU_CACHE_VIVT 206f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 207b1b3f49cSRussell King select CPU_CP15_MMU 208b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 219dc680b98SLinus Walleij bool "Support ARM1020E processor" if (ARCH_MULTI_V5 && ARCH_INTEGRATOR) 220b1b3f49cSRussell King depends on n 2211da177e4SLinus Torvalds select CPU_32v5 2221da177e4SLinus Torvalds select CPU_ABRT_EV4T 2231da177e4SLinus Torvalds select CPU_CACHE_V4WT 2241da177e4SLinus Torvalds select CPU_CACHE_VIVT 225f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 226b1b3f49cSRussell King select CPU_CP15_MMU 227b1b3f49cSRussell King select CPU_PABRT_LEGACY 228f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2291da177e4SLinus Torvalds 2301da177e4SLinus Torvalds# ARM1022E 2311da177e4SLinus Torvaldsconfig CPU_ARM1022 232dc680b98SLinus Walleij bool "Support ARM1022E processor" if (ARCH_MULTI_V5 && ARCH_INTEGRATOR) 2331da177e4SLinus Torvalds select CPU_32v5 2341da177e4SLinus Torvalds select CPU_ABRT_EV4T 2351da177e4SLinus Torvalds select CPU_CACHE_VIVT 236f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU # can probably do better 237b1b3f49cSRussell King select CPU_CP15_MMU 238b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 250dc680b98SLinus Walleij bool "Support ARM1026EJ-S processor" if (ARCH_MULTI_V5 && ARCH_INTEGRATOR) 2511da177e4SLinus Torvalds select CPU_32v5 2521da177e4SLinus Torvalds select CPU_ABRT_EV5T # But need Jazelle, but EV5TJ ignores bit 10 2531da177e4SLinus Torvalds select CPU_CACHE_VIVT 254f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU # can probably do better 255b1b3f49cSRussell King select CPU_CP15_MMU 256b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 267fa04e209SArnd Bergmann bool 2681da177e4SLinus Torvalds select CPU_32v3 if ARCH_RPC 2691da177e4SLinus Torvalds select CPU_32v4 if !ARCH_RPC 2701da177e4SLinus Torvalds select CPU_ABRT_EV4 2711da177e4SLinus Torvalds select CPU_CACHE_V4WB 2721da177e4SLinus Torvalds select CPU_CACHE_VIVT 273f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 274b1b3f49cSRussell King select CPU_CP15_MMU 275b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 2911da177e4SLinus Torvalds select CPU_CACHE_V4WB 2921da177e4SLinus Torvalds select CPU_CACHE_VIVT 293fefdaa06SHyok S. Choi select CPU_CP15_MMU 294b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 3021da177e4SLinus Torvalds select CPU_CACHE_VIVT 303fefdaa06SHyok S. Choi select CPU_CP15_MMU 304b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 31223bdf86aSLennert Buytenhek select CPU_CACHE_VIVT 313fefdaa06SHyok S. Choi select CPU_CP15_MMU 314b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 32349cbe786SEric Miao select CPU_CACHE_VIVT 32449cbe786SEric Miao select CPU_COPY_V4WB if MMU 325b1b3f49cSRussell King select CPU_CP15_MMU 326b1b3f49cSRussell King select CPU_PABRT_LEGACY 327b1b3f49cSRussell King select CPU_TLB_V4WBI 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 334e50d6409SAssaf Hoffman select CPU_CACHE_VIVT 3350ed15071SLennert Buytenhek select CPU_COPY_FEROCEON if MMU 336b1b3f49cSRussell King select CPU_CP15_MMU 337b1b3f49cSRussell King select CPU_PABRT_LEGACY 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 ARM_THUMBEE 353b1b3f49cSRussell King select CPU_V7 354a4553358SHaojian Zhuang 355de490193SGregory CLEMENTconfig CPU_PJ4B 356de490193SGregory CLEMENT bool 357de490193SGregory CLEMENT select CPU_V7 358de490193SGregory CLEMENT 3591da177e4SLinus Torvalds# ARMv6 3601da177e4SLinus Torvaldsconfig CPU_V6 361dc680b98SLinus Walleij bool "Support ARM V6 processor" if (!ARCH_MULTIPLATFORM || ARCH_MULTI_V6) && (ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX) 3621da177e4SLinus Torvalds select CPU_32v6 3631da177e4SLinus Torvalds select CPU_ABRT_EV6 3641da177e4SLinus Torvalds select CPU_CACHE_V6 3651da177e4SLinus Torvalds select CPU_CACHE_VIPT 366b1b3f49cSRussell King select CPU_COPY_V6 if MMU 367fefdaa06SHyok S. Choi select CPU_CP15_MMU 3687b4c965aSCatalin Marinas select CPU_HAS_ASID if MMU 369b1b3f49cSRussell King select CPU_PABRT_V6 370f9c21a6eSHyok S. Choi select CPU_TLB_V6 if MMU 3711da177e4SLinus Torvalds 3724a5f79e7SRussell King# ARMv6k 373e399b1a4SRussell Kingconfig CPU_V6K 374dc680b98SLinus Walleij bool "Support ARM V6K processor" if (!ARCH_MULTIPLATFORM || ARCH_MULTI_V6) && (ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX) 375e399b1a4SRussell King select CPU_32v6 37660799c6dSRussell King select CPU_32v6K 377e399b1a4SRussell King select CPU_ABRT_EV6 378e399b1a4SRussell King select CPU_CACHE_V6 379e399b1a4SRussell King select CPU_CACHE_VIPT 380b1b3f49cSRussell King select CPU_COPY_V6 if MMU 381e399b1a4SRussell King select CPU_CP15_MMU 382e399b1a4SRussell King select CPU_HAS_ASID if MMU 383b1b3f49cSRussell King select CPU_PABRT_V6 384e399b1a4SRussell King select CPU_TLB_V6 if MMU 3854a5f79e7SRussell King 38623688e99SCatalin Marinas# ARMv7 38723688e99SCatalin Marinasconfig CPU_V7 388dc680b98SLinus Walleij bool "Support ARM V7 processor" if (!ARCH_MULTIPLATFORM || ARCH_MULTI_V7) && (ARCH_INTEGRATOR || MACH_REALVIEW_EB || MACH_REALVIEW_PBX) 38915490ef8SRussell King select CPU_32v6K 39023688e99SCatalin Marinas select CPU_32v7 39123688e99SCatalin Marinas select CPU_ABRT_EV7 39223688e99SCatalin Marinas select CPU_CACHE_V7 39323688e99SCatalin Marinas select CPU_CACHE_VIPT 394b1b3f49cSRussell King select CPU_COPY_V6 if MMU 39566567618SJonathan Austin select CPU_CP15_MMU if MMU 39666567618SJonathan Austin select CPU_CP15_MPU if !MMU 3972eb8c82bSCatalin Marinas select CPU_HAS_ASID if MMU 398b1b3f49cSRussell King select CPU_PABRT_V7 3992ccdd1e7SCatalin Marinas select CPU_TLB_V7 if MMU 40023688e99SCatalin Marinas 4014477ca45SUwe Kleine-König# ARMv7M 4024477ca45SUwe Kleine-Königconfig CPU_V7M 4034477ca45SUwe Kleine-König bool 4044477ca45SUwe Kleine-König select CPU_32v7M 4054477ca45SUwe Kleine-König select CPU_ABRT_NOMMU 4064477ca45SUwe Kleine-König select CPU_CACHE_NOP 4074477ca45SUwe Kleine-König select CPU_PABRT_LEGACY 4084477ca45SUwe Kleine-König select CPU_THUMBONLY 4094477ca45SUwe Kleine-König 410bc7dea00SUwe Kleine-Königconfig CPU_THUMBONLY 411bc7dea00SUwe Kleine-König bool 412bc7dea00SUwe Kleine-König # There are no CPUs available with MMU that don't implement an ARM ISA: 413bc7dea00SUwe Kleine-König depends on !MMU 414bc7dea00SUwe Kleine-König help 415bc7dea00SUwe Kleine-König Select this if your CPU doesn't support the 32 bit ARM instructions. 416bc7dea00SUwe Kleine-König 4171da177e4SLinus Torvalds# Figure out what processor architecture version we should be using. 4181da177e4SLinus Torvalds# This defines the compiler instruction set which depends on the machine type. 4191da177e4SLinus Torvaldsconfig CPU_32v3 4201da177e4SLinus Torvalds bool 4218762df4dSRussell King select CPU_USE_DOMAINS if MMU 422b1b3f49cSRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 423f6f91b0dSRussell King select NEED_KUSER_HELPERS 42451aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 4251da177e4SLinus Torvalds 4261da177e4SLinus Torvaldsconfig CPU_32v4 4271da177e4SLinus Torvalds bool 4288762df4dSRussell King select CPU_USE_DOMAINS if MMU 429b1b3f49cSRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 430f6f91b0dSRussell King select NEED_KUSER_HELPERS 43151aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 4321da177e4SLinus Torvalds 433260e98edSLennert Buytenhekconfig CPU_32v4T 434260e98edSLennert Buytenhek bool 4358762df4dSRussell King select CPU_USE_DOMAINS if MMU 436b1b3f49cSRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 437f6f91b0dSRussell King select NEED_KUSER_HELPERS 43851aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 439260e98edSLennert Buytenhek 4401da177e4SLinus Torvaldsconfig CPU_32v5 4411da177e4SLinus Torvalds bool 4428762df4dSRussell King select CPU_USE_DOMAINS if MMU 443b1b3f49cSRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 444f6f91b0dSRussell King select NEED_KUSER_HELPERS 44551aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 4461da177e4SLinus Torvalds 4471da177e4SLinus Torvaldsconfig CPU_32v6 4481da177e4SLinus Torvalds bool 449b1b3f49cSRussell King select TLS_REG_EMUL if !CPU_32v6K && !MMU 4501da177e4SLinus Torvalds 451e399b1a4SRussell Kingconfig CPU_32v6K 45260799c6dSRussell King bool 4531da177e4SLinus Torvalds 45423688e99SCatalin Marinasconfig CPU_32v7 45523688e99SCatalin Marinas bool 45623688e99SCatalin Marinas 4574477ca45SUwe Kleine-Königconfig CPU_32v7M 4584477ca45SUwe Kleine-König bool 4594477ca45SUwe Kleine-König 4601da177e4SLinus Torvalds# The abort model 4610f45d7f3SHyok S. Choiconfig CPU_ABRT_NOMMU 4620f45d7f3SHyok S. Choi bool 4630f45d7f3SHyok S. Choi 4641da177e4SLinus Torvaldsconfig CPU_ABRT_EV4 4651da177e4SLinus Torvalds bool 4661da177e4SLinus Torvalds 4671da177e4SLinus Torvaldsconfig CPU_ABRT_EV4T 4681da177e4SLinus Torvalds bool 4691da177e4SLinus Torvalds 4701da177e4SLinus Torvaldsconfig CPU_ABRT_LV4T 4711da177e4SLinus Torvalds bool 4721da177e4SLinus Torvalds 4731da177e4SLinus Torvaldsconfig CPU_ABRT_EV5T 4741da177e4SLinus Torvalds bool 4751da177e4SLinus Torvalds 4761da177e4SLinus Torvaldsconfig CPU_ABRT_EV5TJ 4771da177e4SLinus Torvalds bool 4781da177e4SLinus Torvalds 4791da177e4SLinus Torvaldsconfig CPU_ABRT_EV6 4801da177e4SLinus Torvalds bool 4811da177e4SLinus Torvalds 48223688e99SCatalin Marinasconfig CPU_ABRT_EV7 48323688e99SCatalin Marinas bool 48423688e99SCatalin Marinas 4854fb28474SKirill A. Shutemovconfig CPU_PABRT_LEGACY 48648d7927bSPaul Brook bool 48748d7927bSPaul Brook 4884fb28474SKirill A. Shutemovconfig CPU_PABRT_V6 4894fb28474SKirill A. Shutemov bool 4904fb28474SKirill A. Shutemov 4914fb28474SKirill A. Shutemovconfig CPU_PABRT_V7 49248d7927bSPaul Brook bool 49348d7927bSPaul Brook 4941da177e4SLinus Torvalds# The cache model 4951da177e4SLinus Torvaldsconfig CPU_CACHE_V4 4961da177e4SLinus Torvalds bool 4971da177e4SLinus Torvalds 4981da177e4SLinus Torvaldsconfig CPU_CACHE_V4WT 4991da177e4SLinus Torvalds bool 5001da177e4SLinus Torvalds 5011da177e4SLinus Torvaldsconfig CPU_CACHE_V4WB 5021da177e4SLinus Torvalds bool 5031da177e4SLinus Torvalds 5041da177e4SLinus Torvaldsconfig CPU_CACHE_V6 5051da177e4SLinus Torvalds bool 5061da177e4SLinus Torvalds 50723688e99SCatalin Marinasconfig CPU_CACHE_V7 50823688e99SCatalin Marinas bool 50923688e99SCatalin Marinas 5104477ca45SUwe Kleine-Königconfig CPU_CACHE_NOP 5114477ca45SUwe Kleine-König bool 5124477ca45SUwe Kleine-König 5131da177e4SLinus Torvaldsconfig CPU_CACHE_VIVT 5141da177e4SLinus Torvalds bool 5151da177e4SLinus Torvalds 5161da177e4SLinus Torvaldsconfig CPU_CACHE_VIPT 5171da177e4SLinus Torvalds bool 5181da177e4SLinus Torvalds 51928853ac8SPaulius Zaleckasconfig CPU_CACHE_FA 52028853ac8SPaulius Zaleckas bool 52128853ac8SPaulius Zaleckas 522f9c21a6eSHyok S. Choiif MMU 5231da177e4SLinus Torvalds# The copy-page model 5241da177e4SLinus Torvaldsconfig CPU_COPY_V4WT 5251da177e4SLinus Torvalds bool 5261da177e4SLinus Torvalds 5271da177e4SLinus Torvaldsconfig CPU_COPY_V4WB 5281da177e4SLinus Torvalds bool 5291da177e4SLinus Torvalds 5300ed15071SLennert Buytenhekconfig CPU_COPY_FEROCEON 5310ed15071SLennert Buytenhek bool 5320ed15071SLennert Buytenhek 53328853ac8SPaulius Zaleckasconfig CPU_COPY_FA 53428853ac8SPaulius Zaleckas bool 53528853ac8SPaulius Zaleckas 5361da177e4SLinus Torvaldsconfig CPU_COPY_V6 5371da177e4SLinus Torvalds bool 5381da177e4SLinus Torvalds 5391da177e4SLinus Torvalds# This selects the TLB model 5401da177e4SLinus Torvaldsconfig CPU_TLB_V4WT 5411da177e4SLinus Torvalds bool 5421da177e4SLinus Torvalds help 5431da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writethrough cache. 5441da177e4SLinus Torvalds 5451da177e4SLinus Torvaldsconfig CPU_TLB_V4WB 5461da177e4SLinus Torvalds bool 5471da177e4SLinus Torvalds help 5481da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writeback cache. 5491da177e4SLinus Torvalds 5501da177e4SLinus Torvaldsconfig CPU_TLB_V4WBI 5511da177e4SLinus Torvalds bool 5521da177e4SLinus Torvalds help 5531da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writeback cache and invalidate 5541da177e4SLinus Torvalds instruction cache entry. 5551da177e4SLinus Torvalds 55699c6dc11SLennert Buytenhekconfig CPU_TLB_FEROCEON 55799c6dc11SLennert Buytenhek bool 55899c6dc11SLennert Buytenhek help 55999c6dc11SLennert Buytenhek Feroceon TLB (v4wbi with non-outer-cachable page table walks). 56099c6dc11SLennert Buytenhek 56128853ac8SPaulius Zaleckasconfig CPU_TLB_FA 56228853ac8SPaulius Zaleckas bool 56328853ac8SPaulius Zaleckas help 56428853ac8SPaulius Zaleckas Faraday ARM FA526 architecture, unified TLB with writeback cache 56528853ac8SPaulius Zaleckas and invalidate instruction cache entry. Branch target buffer is 56628853ac8SPaulius Zaleckas also supported. 56728853ac8SPaulius Zaleckas 5681da177e4SLinus Torvaldsconfig CPU_TLB_V6 5691da177e4SLinus Torvalds bool 5701da177e4SLinus Torvalds 5712ccdd1e7SCatalin Marinasconfig CPU_TLB_V7 5722ccdd1e7SCatalin Marinas bool 5732ccdd1e7SCatalin Marinas 574e220ba60SDave Estesconfig VERIFY_PERMISSION_FAULT 575e220ba60SDave Estes bool 576f9c21a6eSHyok S. Choiendif 577f9c21a6eSHyok S. Choi 578516793c6SRussell Kingconfig CPU_HAS_ASID 579516793c6SRussell King bool 580516793c6SRussell King help 581516793c6SRussell King This indicates whether the CPU has the ASID register; used to 582516793c6SRussell King tag TLB and possibly cache entries. 583516793c6SRussell King 584fefdaa06SHyok S. Choiconfig CPU_CP15 585fefdaa06SHyok S. Choi bool 586fefdaa06SHyok S. Choi help 587fefdaa06SHyok S. Choi Processor has the CP15 register. 588fefdaa06SHyok S. Choi 589fefdaa06SHyok S. Choiconfig CPU_CP15_MMU 590fefdaa06SHyok S. Choi bool 591fefdaa06SHyok S. Choi select CPU_CP15 592fefdaa06SHyok S. Choi help 593fefdaa06SHyok S. Choi Processor has the CP15 register, which has MMU related registers. 594fefdaa06SHyok S. Choi 595fefdaa06SHyok S. Choiconfig CPU_CP15_MPU 596fefdaa06SHyok S. Choi bool 597fefdaa06SHyok S. Choi select CPU_CP15 598fefdaa06SHyok S. Choi help 599fefdaa06SHyok S. Choi Processor has the CP15 register, which has MPU related registers. 600fefdaa06SHyok S. Choi 601247055aaSCatalin Marinasconfig CPU_USE_DOMAINS 602247055aaSCatalin Marinas bool 603247055aaSCatalin Marinas help 604247055aaSCatalin Marinas This option enables or disables the use of domain switching 605247055aaSCatalin Marinas via the set_fs() function. 606247055aaSCatalin Marinas 6076b1814cdSMaxime Coquelin stm32config CPU_V7M_NUM_IRQ 6086b1814cdSMaxime Coquelin stm32 int "Number of external interrupts connected to the NVIC" 6096b1814cdSMaxime Coquelin stm32 depends on CPU_V7M 6106b1814cdSMaxime Coquelin stm32 default 90 if ARCH_STM32 6116b1814cdSMaxime Coquelin stm32 default 38 if ARCH_EFM32 61245b0fa09SStefan Agner default 112 if SOC_VF610 6136b1814cdSMaxime Coquelin stm32 default 240 6146b1814cdSMaxime Coquelin stm32 help 6156b1814cdSMaxime Coquelin stm32 This option indicates the number of interrupts connected to the NVIC. 6166b1814cdSMaxime Coquelin stm32 The value can be larger than the real number of interrupts supported 6176b1814cdSMaxime Coquelin stm32 by the system, but must not be lower. 6186b1814cdSMaxime Coquelin stm32 The default value is 240, corresponding to the maximum number of 6196b1814cdSMaxime Coquelin stm32 interrupts supported by the NVIC on Cortex-M family. 6206b1814cdSMaxime Coquelin stm32 6216b1814cdSMaxime Coquelin stm32 If unsure, keep default value. 6226b1814cdSMaxime Coquelin stm32 62323bdf86aSLennert Buytenhek# 62423bdf86aSLennert Buytenhek# CPU supports 36-bit I/O 62523bdf86aSLennert Buytenhek# 62623bdf86aSLennert Buytenhekconfig IO_36 62723bdf86aSLennert Buytenhek bool 62823bdf86aSLennert Buytenhek 6291da177e4SLinus Torvaldscomment "Processor Features" 6301da177e4SLinus Torvalds 631497b7e94SCatalin Marinasconfig ARM_LPAE 632497b7e94SCatalin Marinas bool "Support for the Large Physical Address Extension" 63308a183f0SCatalin Marinas depends on MMU && CPU_32v7 && !CPU_32v6 && !CPU_32v5 && \ 63408a183f0SCatalin Marinas !CPU_32v4 && !CPU_32v3 635497b7e94SCatalin Marinas help 636497b7e94SCatalin Marinas Say Y if you have an ARMv7 processor supporting the LPAE page 637497b7e94SCatalin Marinas table format and you would like to access memory beyond the 638497b7e94SCatalin Marinas 4GB limit. The resulting kernel image will not run on 639497b7e94SCatalin Marinas processors without the LPA extension. 640497b7e94SCatalin Marinas 641497b7e94SCatalin Marinas If unsure, say N. 642497b7e94SCatalin Marinas 643d8dc7fbdSRussell Kingconfig ARM_PV_FIXUP 644d8dc7fbdSRussell King def_bool y 645d8dc7fbdSRussell King depends on ARM_LPAE && ARM_PATCH_PHYS_VIRT && ARCH_KEYSTONE 646d8dc7fbdSRussell King 647497b7e94SCatalin Marinasconfig ARCH_PHYS_ADDR_T_64BIT 648497b7e94SCatalin Marinas def_bool ARM_LPAE 649497b7e94SCatalin Marinas 650497b7e94SCatalin Marinasconfig ARCH_DMA_ADDR_T_64BIT 651497b7e94SCatalin Marinas bool 652497b7e94SCatalin Marinas 6531da177e4SLinus Torvaldsconfig ARM_THUMB 654bc7dea00SUwe Kleine-König bool "Support Thumb user binaries" if !CPU_THUMBONLY 6554477ca45SUwe Kleine-König depends on CPU_ARM720T || CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || \ 6564477ca45SUwe Kleine-König CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || \ 6574477ca45SUwe Kleine-König CPU_ARM1020 || CPU_ARM1020E || CPU_ARM1022 || CPU_ARM1026 || \ 6584477ca45SUwe Kleine-König CPU_XSCALE || CPU_XSC3 || CPU_MOHAWK || CPU_V6 || CPU_V6K || \ 6594477ca45SUwe Kleine-König CPU_V7 || CPU_FEROCEON || CPU_V7M 6601da177e4SLinus Torvalds default y 6611da177e4SLinus Torvalds help 6621da177e4SLinus Torvalds Say Y if you want to include kernel support for running user space 6631da177e4SLinus Torvalds Thumb binaries. 6641da177e4SLinus Torvalds 6651da177e4SLinus Torvalds The Thumb instruction set is a compressed form of the standard ARM 6661da177e4SLinus Torvalds instruction set resulting in smaller binaries at the expense of 6671da177e4SLinus Torvalds slightly less efficient code. 6681da177e4SLinus Torvalds 6691da177e4SLinus Torvalds If you don't know what this all is, saying Y is a safe choice. 6701da177e4SLinus Torvalds 671d7f864beSCatalin Marinasconfig ARM_THUMBEE 672d7f864beSCatalin Marinas bool "Enable ThumbEE CPU extension" 673d7f864beSCatalin Marinas depends on CPU_V7 674d7f864beSCatalin Marinas help 675d7f864beSCatalin Marinas Say Y here if you have a CPU with the ThumbEE extension and code to 676d7f864beSCatalin Marinas make use of it. Say N for code that can run on CPUs without ThumbEE. 677d7f864beSCatalin Marinas 6785b6728d4SDave Martinconfig ARM_VIRT_EXT 679651134b0SWill Deacon bool 680651134b0SWill Deacon depends on MMU 681651134b0SWill Deacon default y if CPU_V7 6825b6728d4SDave Martin help 6835b6728d4SDave Martin Enable the kernel to make use of the ARM Virtualization 6845b6728d4SDave Martin Extensions to install hypervisors without run-time firmware 6855b6728d4SDave Martin assistance. 6865b6728d4SDave Martin 6875b6728d4SDave Martin A compliant bootloader is required in order to make maximum 6885b6728d4SDave Martin use of this feature. Refer to Documentation/arm/Booting for 6895b6728d4SDave Martin details. 6905b6728d4SDave Martin 69164d2dc38SLeif Lindholmconfig SWP_EMULATE 692a11dd731SRussell King bool "Emulate SWP/SWPB instructions" if !SMP 693b6ccb980SWill Deacon depends on CPU_V7 69464d2dc38SLeif Lindholm default y if SMP 695b1b3f49cSRussell King select HAVE_PROC_CPU if PROC_FS 69664d2dc38SLeif Lindholm help 69764d2dc38SLeif Lindholm ARMv6 architecture deprecates use of the SWP/SWPB instructions. 69864d2dc38SLeif Lindholm ARMv7 multiprocessing extensions introduce the ability to disable 69964d2dc38SLeif Lindholm these instructions, triggering an undefined instruction exception 70064d2dc38SLeif Lindholm when executed. Say Y here to enable software emulation of these 70164d2dc38SLeif Lindholm instructions for userspace (not kernel) using LDREX/STREX. 70264d2dc38SLeif Lindholm Also creates /proc/cpu/swp_emulation for statistics. 70364d2dc38SLeif Lindholm 70464d2dc38SLeif Lindholm In some older versions of glibc [<=2.8] SWP is used during futex 70564d2dc38SLeif Lindholm trylock() operations with the assumption that the code will not 70664d2dc38SLeif Lindholm be preempted. This invalid assumption may be more likely to fail 70764d2dc38SLeif Lindholm with SWP emulation enabled, leading to deadlock of the user 70864d2dc38SLeif Lindholm application. 70964d2dc38SLeif Lindholm 71064d2dc38SLeif Lindholm NOTE: when accessing uncached shared regions, LDREX/STREX rely 71164d2dc38SLeif Lindholm on an external transaction monitoring block called a global 71264d2dc38SLeif Lindholm monitor to maintain update atomicity. If your system does not 71364d2dc38SLeif Lindholm implement a global monitor, this option can cause programs that 71464d2dc38SLeif Lindholm perform SWP operations to uncached memory to deadlock. 71564d2dc38SLeif Lindholm 71664d2dc38SLeif Lindholm If unsure, say Y. 71764d2dc38SLeif Lindholm 7181da177e4SLinus Torvaldsconfig CPU_BIG_ENDIAN 7191da177e4SLinus Torvalds bool "Build big-endian kernel" 7201da177e4SLinus Torvalds depends on ARCH_SUPPORTS_BIG_ENDIAN 7211da177e4SLinus Torvalds help 7221da177e4SLinus Torvalds Say Y if you plan on running a kernel in big-endian mode. 7231da177e4SLinus Torvalds Note that your board must be properly built and your board 7241da177e4SLinus Torvalds port must properly enable any big-endian related features 7251da177e4SLinus Torvalds of your chipset/board/processor. 7261da177e4SLinus Torvalds 72726584853SCatalin Marinasconfig CPU_ENDIAN_BE8 72826584853SCatalin Marinas bool 72926584853SCatalin Marinas depends on CPU_BIG_ENDIAN 730e399b1a4SRussell King default CPU_V6 || CPU_V6K || CPU_V7 73126584853SCatalin Marinas help 73226584853SCatalin Marinas Support for the BE-8 (big-endian) mode on ARMv6 and ARMv7 processors. 73326584853SCatalin Marinas 73426584853SCatalin Marinasconfig CPU_ENDIAN_BE32 73526584853SCatalin Marinas bool 73626584853SCatalin Marinas depends on CPU_BIG_ENDIAN 73726584853SCatalin Marinas default !CPU_ENDIAN_BE8 73826584853SCatalin Marinas help 73926584853SCatalin Marinas Support for the BE-32 (big-endian) mode on pre-ARMv6 processors. 74026584853SCatalin Marinas 7416afd6faeSHyok S. Choiconfig CPU_HIGH_VECTOR 7426340aa61SRobert P. J. Day depends on !MMU && CPU_CP15 && !CPU_ARM740T 7436afd6faeSHyok S. Choi bool "Select the High exception vector" 7446afd6faeSHyok S. Choi help 7456afd6faeSHyok S. Choi Say Y here to select high exception vector(0xFFFF0000~). 7469b7333a9SWill Deacon The exception vector can vary depending on the platform 7476afd6faeSHyok S. Choi design in nommu mode. If your platform needs to select 7486afd6faeSHyok S. Choi high exception vector, say Y. 7496afd6faeSHyok S. Choi Otherwise or if you are unsure, say N, and the low exception 7506afd6faeSHyok S. Choi vector (0x00000000~) will be used. 7516afd6faeSHyok S. Choi 7521da177e4SLinus Torvaldsconfig CPU_ICACHE_DISABLE 753f12d0d7cSHyok S. Choi bool "Disable I-Cache (I-bit)" 754357c9c1fSRussell King depends on CPU_CP15 && !(CPU_ARM720T || CPU_ARM740T || CPU_XSCALE || CPU_XSC3) 7551da177e4SLinus Torvalds help 7561da177e4SLinus Torvalds Say Y here to disable the processor instruction cache. Unless 7571da177e4SLinus Torvalds you have a reason not to or are unsure, say N. 7581da177e4SLinus Torvalds 7591da177e4SLinus Torvaldsconfig CPU_DCACHE_DISABLE 760f12d0d7cSHyok S. Choi bool "Disable D-Cache (C-bit)" 761e1e2f6e4SFlorian Fainelli depends on CPU_CP15 && !SMP 7621da177e4SLinus Torvalds help 7631da177e4SLinus Torvalds Say Y here to disable the processor data cache. Unless 7641da177e4SLinus Torvalds you have a reason not to or are unsure, say N. 7651da177e4SLinus Torvalds 766f37f46ebSHyok S. Choiconfig CPU_DCACHE_SIZE 767f37f46ebSHyok S. Choi hex 768f37f46ebSHyok S. Choi depends on CPU_ARM740T || CPU_ARM946E 769f37f46ebSHyok S. Choi default 0x00001000 if CPU_ARM740T 770f37f46ebSHyok S. Choi default 0x00002000 # default size for ARM946E-S 771f37f46ebSHyok S. Choi help 772f37f46ebSHyok S. Choi Some cores are synthesizable to have various sized cache. For 773f37f46ebSHyok S. Choi ARM946E-S case, it can vary from 0KB to 1MB. 774f37f46ebSHyok S. Choi To support such cache operations, it is efficient to know the size 775f37f46ebSHyok S. Choi before compile time. 776f37f46ebSHyok S. Choi If your SoC is configured to have a different size, define the value 777f37f46ebSHyok S. Choi here with proper conditions. 778f37f46ebSHyok S. Choi 7791da177e4SLinus Torvaldsconfig CPU_DCACHE_WRITETHROUGH 7801da177e4SLinus Torvalds bool "Force write through D-cache" 78128853ac8SPaulius Zaleckas depends on (CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_FA526) && !CPU_DCACHE_DISABLE 7821da177e4SLinus Torvalds default y if CPU_ARM925T 7831da177e4SLinus Torvalds help 7841da177e4SLinus Torvalds Say Y here to use the data cache in writethrough mode. Unless you 7851da177e4SLinus Torvalds specifically require this or are unsure, say N. 7861da177e4SLinus Torvalds 7871da177e4SLinus Torvaldsconfig CPU_CACHE_ROUND_ROBIN 7881da177e4SLinus Torvalds bool "Round robin I and D cache replacement algorithm" 789f37f46ebSHyok S. Choi depends on (CPU_ARM926T || CPU_ARM946E || CPU_ARM1020) && (!CPU_ICACHE_DISABLE || !CPU_DCACHE_DISABLE) 7901da177e4SLinus Torvalds help 7911da177e4SLinus Torvalds Say Y here to use the predictable round-robin cache replacement 7921da177e4SLinus Torvalds policy. Unless you specifically require this or are unsure, say N. 7931da177e4SLinus Torvalds 7941da177e4SLinus Torvaldsconfig CPU_BPREDICT_DISABLE 7951da177e4SLinus Torvalds bool "Disable branch prediction" 796e399b1a4SRussell King depends on CPU_ARM1020 || CPU_V6 || CPU_V6K || CPU_MOHAWK || CPU_XSC3 || CPU_V7 || CPU_FA526 7971da177e4SLinus Torvalds help 7981da177e4SLinus Torvalds Say Y here to disable branch prediction. If unsure, say N. 7992d2669b6SNicolas Pitre 8004b0e07a5SNicolas Pitreconfig TLS_REG_EMUL 8014b0e07a5SNicolas Pitre bool 802f6f91b0dSRussell King select NEED_KUSER_HELPERS 8034b0e07a5SNicolas Pitre help 80470489c88SNicolas Pitre An SMP system using a pre-ARMv6 processor (there are apparently 80570489c88SNicolas Pitre a few prototypes like that in existence) and therefore access to 80670489c88SNicolas Pitre that required register must be emulated. 8074b0e07a5SNicolas Pitre 808dcef1f63SNicolas Pitreconfig NEEDS_SYSCALL_FOR_CMPXCHG 809dcef1f63SNicolas Pitre bool 810f6f91b0dSRussell King select NEED_KUSER_HELPERS 811dcef1f63SNicolas Pitre help 812dcef1f63SNicolas Pitre SMP on a pre-ARMv6 processor? Well OK then. 813dcef1f63SNicolas Pitre Forget about fast user space cmpxchg support. 814dcef1f63SNicolas Pitre It is just not possible. 815dcef1f63SNicolas Pitre 816f6f91b0dSRussell Kingconfig NEED_KUSER_HELPERS 817f6f91b0dSRussell King bool 818f6f91b0dSRussell King 819f6f91b0dSRussell Kingconfig KUSER_HELPERS 820f6f91b0dSRussell King bool "Enable kuser helpers in vector page" if !NEED_KUSER_HELPERS 82108b964ffSNathan Lynch depends on MMU 822f6f91b0dSRussell King default y 823f6f91b0dSRussell King help 824f6f91b0dSRussell King Warning: disabling this option may break user programs. 825f6f91b0dSRussell King 826f6f91b0dSRussell King Provide kuser helpers in the vector page. The kernel provides 827f6f91b0dSRussell King helper code to userspace in read only form at a fixed location 828f6f91b0dSRussell King in the high vector page to allow userspace to be independent of 829f6f91b0dSRussell King the CPU type fitted to the system. This permits binaries to be 830f6f91b0dSRussell King run on ARMv4 through to ARMv7 without modification. 831f6f91b0dSRussell King 832ac124504SNicolas Pitre See Documentation/arm/kernel_user_helpers.txt for details. 833ac124504SNicolas Pitre 834f6f91b0dSRussell King However, the fixed address nature of these helpers can be used 835f6f91b0dSRussell King by ROP (return orientated programming) authors when creating 836f6f91b0dSRussell King exploits. 837f6f91b0dSRussell King 838f6f91b0dSRussell King If all of the binaries and libraries which run on your platform 839f6f91b0dSRussell King are built specifically for your platform, and make no use of 840ac124504SNicolas Pitre these helpers, then you can turn this option off to hinder 841ac124504SNicolas Pitre such exploits. However, in that case, if a binary or library 842ac124504SNicolas Pitre relying on those helpers is run, it will receive a SIGILL signal, 843ac124504SNicolas Pitre which will terminate the program. 844f6f91b0dSRussell King 845f6f91b0dSRussell King Say N here only if you are absolutely certain that you do not 846f6f91b0dSRussell King need these helpers; otherwise, the safe option is to say Y. 847f6f91b0dSRussell King 848e5b61debSNathan Lynchconfig VDSO 849e5b61debSNathan Lynch bool "Enable VDSO for acceleration of some system calls" 8505d38000bSNathan Lynch depends on AEABI && MMU && CPU_V7 851e5b61debSNathan Lynch default y if ARM_ARCH_TIMER 852e5b61debSNathan Lynch select GENERIC_TIME_VSYSCALL 853e5b61debSNathan Lynch help 854e5b61debSNathan Lynch Place in the process address space an ELF shared object 855e5b61debSNathan Lynch providing fast implementations of gettimeofday and 856e5b61debSNathan Lynch clock_gettime. Systems that implement the ARM architected 857e5b61debSNathan Lynch timer will receive maximum benefit. 858e5b61debSNathan Lynch 859e5b61debSNathan Lynch You must have glibc 2.22 or later for programs to seamlessly 860e5b61debSNathan Lynch take advantage of this. 861e5b61debSNathan Lynch 862ad642d9fSCatalin Marinasconfig DMA_CACHE_RWFO 863ad642d9fSCatalin Marinas bool "Enable read/write for ownership DMA cache maintenance" 8643bc28c8eSRussell King depends on CPU_V6K && SMP 865ad642d9fSCatalin Marinas default y 866ad642d9fSCatalin Marinas help 867ad642d9fSCatalin Marinas The Snoop Control Unit on ARM11MPCore does not detect the 868ad642d9fSCatalin Marinas cache maintenance operations and the dma_{map,unmap}_area() 869ad642d9fSCatalin Marinas functions may leave stale cache entries on other CPUs. By 870ad642d9fSCatalin Marinas enabling this option, Read or Write For Ownership in the ARMv6 871ad642d9fSCatalin Marinas DMA cache maintenance functions is performed. These LDR/STR 872ad642d9fSCatalin Marinas instructions change the cache line state to shared or modified 873ad642d9fSCatalin Marinas so that the cache operation has the desired effect. 874ad642d9fSCatalin Marinas 875ad642d9fSCatalin Marinas Note that the workaround is only valid on processors that do 876ad642d9fSCatalin Marinas not perform speculative loads into the D-cache. For such 877ad642d9fSCatalin Marinas processors, if cache maintenance operations are not broadcast 878ad642d9fSCatalin Marinas in hardware, other workarounds are needed (e.g. cache 879ad642d9fSCatalin Marinas maintenance broadcasting in software via FIQ). 880ad642d9fSCatalin Marinas 881953233dcSCatalin Marinasconfig OUTER_CACHE 882953233dcSCatalin Marinas bool 883382266adSCatalin Marinas 884319f551aSCatalin Marinasconfig OUTER_CACHE_SYNC 885319f551aSCatalin Marinas bool 886*f8130906SRussell King select ARM_HEAVY_MB 887319f551aSCatalin Marinas help 888319f551aSCatalin Marinas The outer cache has a outer_cache_fns.sync function pointer 889319f551aSCatalin Marinas that can be used to drain the write buffer of the outer cache. 890319f551aSCatalin Marinas 89199c6dc11SLennert Buytenhekconfig CACHE_FEROCEON_L2 89299c6dc11SLennert Buytenhek bool "Enable the Feroceon L2 cache controller" 893ba364fc7SAndrew Lunn depends on ARCH_MV78XX0 || ARCH_MVEBU 89499c6dc11SLennert Buytenhek default y 895382266adSCatalin Marinas select OUTER_CACHE 89699c6dc11SLennert Buytenhek help 89799c6dc11SLennert Buytenhek This option enables the Feroceon L2 cache controller. 89899c6dc11SLennert Buytenhek 8994360bb41SRonen Shitritconfig CACHE_FEROCEON_L2_WRITETHROUGH 9004360bb41SRonen Shitrit bool "Force Feroceon L2 cache write through" 9014360bb41SRonen Shitrit depends on CACHE_FEROCEON_L2 9024360bb41SRonen Shitrit help 9034360bb41SRonen Shitrit Say Y here to use the Feroceon L2 cache in writethrough mode. 9044360bb41SRonen Shitrit Unless you specifically require this, say N for writeback mode. 9054360bb41SRonen Shitrit 906ce5ea9f3SDave Martinconfig MIGHT_HAVE_CACHE_L2X0 907ce5ea9f3SDave Martin bool 908ce5ea9f3SDave Martin help 909ce5ea9f3SDave Martin This option should be selected by machines which have a L2x0 910ce5ea9f3SDave Martin or PL310 cache controller, but where its use is optional. 911ce5ea9f3SDave Martin 912ce5ea9f3SDave Martin The only effect of this option is to make CACHE_L2X0 and 913ce5ea9f3SDave Martin related options available to the user for configuration. 914ce5ea9f3SDave Martin 915ce5ea9f3SDave Martin Boards or SoCs which always require the cache controller 916ce5ea9f3SDave Martin support to be present should select CACHE_L2X0 directly 917ce5ea9f3SDave Martin instead of this option, thus preventing the user from 918ce5ea9f3SDave Martin inadvertently configuring a broken kernel. 919ce5ea9f3SDave Martin 9201da177e4SLinus Torvaldsconfig CACHE_L2X0 921ce5ea9f3SDave Martin bool "Enable the L2x0 outer cache controller" if MIGHT_HAVE_CACHE_L2X0 922ce5ea9f3SDave Martin default MIGHT_HAVE_CACHE_L2X0 9231da177e4SLinus Torvalds select OUTER_CACHE 92423107c54SCatalin Marinas select OUTER_CACHE_SYNC 925ba927951SCatalin Marinas help 926ba927951SCatalin Marinas This option enables the L2x0 PrimeCell. 927905a09d5SEric Miao 928a641f3a6SRussell Kingif CACHE_L2X0 929a641f3a6SRussell King 930c0fe18baSRussell Kingconfig PL310_ERRATA_588369 931c0fe18baSRussell King bool "PL310 errata: Clean & Invalidate maintenance operations do not invalidate clean lines" 932c0fe18baSRussell King help 933c0fe18baSRussell King The PL310 L2 cache controller implements three types of Clean & 934c0fe18baSRussell King Invalidate maintenance operations: by Physical Address 935c0fe18baSRussell King (offset 0x7F0), by Index/Way (0x7F8) and by Way (0x7FC). 936c0fe18baSRussell King They are architecturally defined to behave as the execution of a 937c0fe18baSRussell King clean operation followed immediately by an invalidate operation, 938c0fe18baSRussell King both performing to the same memory location. This functionality 93980d3cb91SShawn Guo is not correctly implemented in PL310 prior to r2p0 (fixed in r2p0) 94080d3cb91SShawn Guo as clean lines are not invalidated as a result of these operations. 941c0fe18baSRussell King 942c0fe18baSRussell Kingconfig PL310_ERRATA_727915 943c0fe18baSRussell King bool "PL310 errata: Background Clean & Invalidate by Way operation can cause data corruption" 944c0fe18baSRussell King help 945c0fe18baSRussell King PL310 implements the Clean & Invalidate by Way L2 cache maintenance 946c0fe18baSRussell King operation (offset 0x7FC). This operation runs in background so that 947c0fe18baSRussell King PL310 can handle normal accesses while it is in progress. Under very 948c0fe18baSRussell King rare circumstances, due to this erratum, write data can be lost when 949c0fe18baSRussell King PL310 treats a cacheable write transaction during a Clean & 95080d3cb91SShawn Guo Invalidate by Way operation. Revisions prior to r3p1 are affected by 95180d3cb91SShawn Guo this errata (fixed in r3p1). 952c0fe18baSRussell King 953c0fe18baSRussell Kingconfig PL310_ERRATA_753970 954c0fe18baSRussell King bool "PL310 errata: cache sync operation may be faulty" 955c0fe18baSRussell King help 956c0fe18baSRussell King This option enables the workaround for the 753970 PL310 (r3p0) erratum. 957c0fe18baSRussell King 958c0fe18baSRussell King Under some condition the effect of cache sync operation on 959c0fe18baSRussell King the store buffer still remains when the operation completes. 960c0fe18baSRussell King This means that the store buffer is always asked to drain and 961c0fe18baSRussell King this prevents it from merging any further writes. The workaround 962c0fe18baSRussell King is to replace the normal offset of cache sync operation (0x730) 963c0fe18baSRussell King by another offset targeting an unmapped PL310 register 0x740. 964c0fe18baSRussell King This has the same effect as the cache sync operation: store buffer 965c0fe18baSRussell King drain and waiting for all buffers empty. 966c0fe18baSRussell King 967c0fe18baSRussell Kingconfig PL310_ERRATA_769419 968c0fe18baSRussell King bool "PL310 errata: no automatic Store Buffer drain" 969c0fe18baSRussell King help 970c0fe18baSRussell King On revisions of the PL310 prior to r3p2, the Store Buffer does 971c0fe18baSRussell King not automatically drain. This can cause normal, non-cacheable 972c0fe18baSRussell King writes to be retained when the memory system is idle, leading 973c0fe18baSRussell King to suboptimal I/O performance for drivers using coherent DMA. 974c0fe18baSRussell King This option adds a write barrier to the cpu_idle loop so that, 975c0fe18baSRussell King on systems with an outer cache, the store buffer is drained 976c0fe18baSRussell King explicitly. 977c0fe18baSRussell King 978a641f3a6SRussell Kingendif 979a641f3a6SRussell King 980573a652fSLennert Buytenhekconfig CACHE_TAUROS2 981573a652fSLennert Buytenhek bool "Enable the Tauros2 L2 cache controller" 9823f408fa0SHaojian Zhuang depends on (ARCH_DOVE || ARCH_MMP || CPU_PJ4) 983573a652fSLennert Buytenhek default y 984573a652fSLennert Buytenhek select OUTER_CACHE 985573a652fSLennert Buytenhek help 986573a652fSLennert Buytenhek This option enables the Tauros2 L2 cache controller (as 987573a652fSLennert Buytenhek found on PJ1/PJ4). 988573a652fSLennert Buytenhek 989905a09d5SEric Miaoconfig CACHE_XSC3L2 990905a09d5SEric Miao bool "Enable the L2 cache on XScale3" 991905a09d5SEric Miao depends on CPU_XSC3 992905a09d5SEric Miao default y 993905a09d5SEric Miao select OUTER_CACHE 994905a09d5SEric Miao help 995905a09d5SEric Miao This option enables the L2 cache on XScale3. 996910a17e5SKirill A. Shutemov 9975637a126SRussell Kingconfig ARM_L1_CACHE_SHIFT_6 9985637a126SRussell King bool 999a092f2b1SWill Deacon default y if CPU_V7 10005637a126SRussell King help 10015637a126SRussell King Setting ARM L1 cache line size to 64 Bytes. 10025637a126SRussell King 1003910a17e5SKirill A. Shutemovconfig ARM_L1_CACHE_SHIFT 1004910a17e5SKirill A. Shutemov int 1005d6d502faSKukjin Kim default 6 if ARM_L1_CACHE_SHIFT_6 1006910a17e5SKirill A. Shutemov default 5 100747ab0deeSRussell King 100847ab0deeSRussell Kingconfig ARM_DMA_MEM_BUFFERABLE 1009e399b1a4SRussell King bool "Use non-cacheable memory for DMA" if (CPU_V6 || CPU_V6K) && !CPU_V7 101042c4dafeSCatalin Marinas depends on !(MACH_REALVIEW_PB1176 || REALVIEW_EB_ARM11MP || \ 101142c4dafeSCatalin Marinas MACH_REALVIEW_PB11MP) 1012e399b1a4SRussell King default y if CPU_V6 || CPU_V6K || CPU_V7 101347ab0deeSRussell King help 101447ab0deeSRussell King Historically, the kernel has used strongly ordered mappings to 101547ab0deeSRussell King provide DMA coherent memory. With the advent of ARMv7, mapping 101647ab0deeSRussell King memory with differing types results in unpredictable behaviour, 101747ab0deeSRussell King so on these CPUs, this option is forced on. 101847ab0deeSRussell King 101947ab0deeSRussell King Multiple mappings with differing attributes is also unpredictable 102047ab0deeSRussell King on ARMv6 CPUs, but since they do not have aggressive speculative 102147ab0deeSRussell King prefetch, no harm appears to occur. 102247ab0deeSRussell King 102347ab0deeSRussell King However, drivers may be missing the necessary barriers for ARMv6, 102447ab0deeSRussell King and therefore turning this on may result in unpredictable driver 102547ab0deeSRussell King behaviour. Therefore, we offer this as an option. 102647ab0deeSRussell King 102747ab0deeSRussell King You are recommended say 'Y' here and debug any affected drivers. 1028ac1d426eSRussell King 1029e7c5650fSCatalin Marinasconfig ARCH_HAS_BARRIERS 1030e7c5650fSCatalin Marinas bool 1031e7c5650fSCatalin Marinas help 1032e7c5650fSCatalin Marinas This option allows the use of custom mandatory barriers 1033e7c5650fSCatalin Marinas included via the mach/barriers.h file. 1034d10d2d48SBen Dooks 1035*f8130906SRussell Kingconfig ARM_HEAVY_MB 1036*f8130906SRussell King bool 1037*f8130906SRussell King 1038d10d2d48SBen Dooksconfig ARCH_SUPPORTS_BIG_ENDIAN 1039d10d2d48SBen Dooks bool 1040d10d2d48SBen Dooks help 1041d10d2d48SBen Dooks This option specifies the architecture can support big endian 1042d10d2d48SBen Dooks operation. 10431e6b4811SKees Cook 10441e6b4811SKees Cookconfig ARM_KERNMEM_PERMS 10451e6b4811SKees Cook bool "Restrict kernel memory permissions" 1046fba28905SArnd Bergmann depends on MMU 10471e6b4811SKees Cook help 10481e6b4811SKees Cook If this is set, kernel memory other than kernel text (and rodata) 10491e6b4811SKees Cook will be made non-executable. The tradeoff is that each region is 10501e6b4811SKees Cook padded to section-size (1MiB) boundaries (because their permissions 10511e6b4811SKees Cook are different and splitting the 1M pages into 4K ones causes TLB 10521e6b4811SKees Cook performance problems), wasting memory. 105380d6b0c2SKees Cook 105480d6b0c2SKees Cookconfig DEBUG_RODATA 105580d6b0c2SKees Cook bool "Make kernel text and rodata read-only" 105680d6b0c2SKees Cook depends on ARM_KERNMEM_PERMS 105780d6b0c2SKees Cook default y 105880d6b0c2SKees Cook help 105980d6b0c2SKees Cook If this is set, kernel text and rodata will be made read-only. This 106080d6b0c2SKees Cook is to help catch accidental or malicious attempts to change the 106180d6b0c2SKees Cook kernel's executable code. Additionally splits rodata from kernel 106280d6b0c2SKees Cook text so it can be made explicitly non-executable. This creates 106380d6b0c2SKees Cook another section-size padded region, so it can waste more memory 106480d6b0c2SKees Cook space while gaining the read-only protections. 1065