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 2417d44d7dSArnd Bergmann bool 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 32c466bda6SRussell King select CPU_THUMB_CAPABLE 33f9c21a6eSHyok S. Choi select CPU_TLB_V4WT if MMU 341da177e4SLinus Torvalds help 351da177e4SLinus Torvalds A 32-bit RISC processor with 8kByte Cache, Write Buffer and 361da177e4SLinus Torvalds MMU built around an ARM7TDMI core. 371da177e4SLinus Torvalds 381da177e4SLinus Torvalds Say Y if you want support for the ARM720T processor. 391da177e4SLinus Torvalds Otherwise, say N. 401da177e4SLinus Torvalds 41b731c311SHyok S. Choi# ARM740T 42b731c311SHyok S. Choiconfig CPU_ARM740T 4317d44d7dSArnd Bergmann bool 446b237a35SRussell King depends on !MMU 45b731c311SHyok S. Choi select CPU_32v4T 46b731c311SHyok S. Choi select CPU_ABRT_LV4T 4782d9b0d0SWill Deacon select CPU_CACHE_V4 48b731c311SHyok S. Choi select CPU_CP15_MPU 49b1b3f49cSRussell King select CPU_PABRT_LEGACY 50c466bda6SRussell King select CPU_THUMB_CAPABLE 51b731c311SHyok S. Choi help 52b731c311SHyok S. Choi A 32-bit RISC processor with 8KB cache or 4KB variants, 53b731c311SHyok S. Choi write buffer and MPU(Protection Unit) built around 54b731c311SHyok S. Choi an ARM7TDMI core. 55b731c311SHyok S. Choi 56b731c311SHyok S. Choi Say Y if you want support for the ARM740T processor. 57b731c311SHyok S. Choi Otherwise, say N. 58b731c311SHyok S. Choi 5943f5f014SHyok S. Choi# ARM9TDMI 6043f5f014SHyok S. Choiconfig CPU_ARM9TDMI 61c32b7655SArnd Bergmann bool 626b237a35SRussell King depends on !MMU 6343f5f014SHyok S. Choi select CPU_32v4T 640f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 6543f5f014SHyok S. Choi select CPU_CACHE_V4 66b1b3f49cSRussell King select CPU_PABRT_LEGACY 6743f5f014SHyok S. Choi help 6843f5f014SHyok S. Choi A 32-bit RISC microprocessor based on the ARM9 processor core 6943f5f014SHyok S. Choi which has no memory control unit and cache. 7043f5f014SHyok S. Choi 7143f5f014SHyok S. Choi Say Y if you want support for the ARM9TDMI processor. 7243f5f014SHyok S. Choi Otherwise, say N. 7343f5f014SHyok S. Choi 741da177e4SLinus Torvalds# ARM920T 751da177e4SLinus Torvaldsconfig CPU_ARM920T 7617d44d7dSArnd Bergmann bool 77260e98edSLennert Buytenhek select CPU_32v4T 781da177e4SLinus Torvalds select CPU_ABRT_EV4T 791da177e4SLinus Torvalds select CPU_CACHE_V4WT 801da177e4SLinus Torvalds select CPU_CACHE_VIVT 81f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 82b1b3f49cSRussell King select CPU_CP15_MMU 83b1b3f49cSRussell King select CPU_PABRT_LEGACY 84c466bda6SRussell King select CPU_THUMB_CAPABLE 85f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 861da177e4SLinus Torvalds help 871da177e4SLinus Torvalds The ARM920T is licensed to be produced by numerous vendors, 88c768e676SHartley Sweeten and is used in the Cirrus EP93xx and the Samsung S3C2410. 891da177e4SLinus Torvalds 901da177e4SLinus Torvalds Say Y if you want support for the ARM920T processor. 911da177e4SLinus Torvalds Otherwise, say N. 921da177e4SLinus Torvalds 931da177e4SLinus Torvalds# ARM922T 941da177e4SLinus Torvaldsconfig CPU_ARM922T 9517d44d7dSArnd Bergmann bool 96260e98edSLennert Buytenhek select CPU_32v4T 971da177e4SLinus Torvalds select CPU_ABRT_EV4T 981da177e4SLinus Torvalds select CPU_CACHE_V4WT 991da177e4SLinus Torvalds select CPU_CACHE_VIVT 100f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 101b1b3f49cSRussell King select CPU_CP15_MMU 102b1b3f49cSRussell King select CPU_PABRT_LEGACY 103c466bda6SRussell King select CPU_THUMB_CAPABLE 104f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1051da177e4SLinus Torvalds help 1061da177e4SLinus Torvalds The ARM922T is a version of the ARM920T, but with smaller 1071da177e4SLinus Torvalds instruction and data caches. It is used in Altera's 108c53c9cf6SAndrew Victor Excalibur XA device family and Micrel's KS8695 Centaur. 1091da177e4SLinus Torvalds 1101da177e4SLinus Torvalds Say Y if you want support for the ARM922T processor. 1111da177e4SLinus Torvalds Otherwise, say N. 1121da177e4SLinus Torvalds 1131da177e4SLinus Torvalds# ARM925T 1141da177e4SLinus Torvaldsconfig CPU_ARM925T 11517d44d7dSArnd Bergmann bool 116260e98edSLennert Buytenhek select CPU_32v4T 1171da177e4SLinus Torvalds select CPU_ABRT_EV4T 1181da177e4SLinus Torvalds select CPU_CACHE_V4WT 1191da177e4SLinus Torvalds select CPU_CACHE_VIVT 120f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 121b1b3f49cSRussell King select CPU_CP15_MMU 122b1b3f49cSRussell King select CPU_PABRT_LEGACY 123c466bda6SRussell King select CPU_THUMB_CAPABLE 124f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1251da177e4SLinus Torvalds help 1261da177e4SLinus Torvalds The ARM925T is a mix between the ARM920T and ARM926T, but with 1271da177e4SLinus Torvalds different instruction and data caches. It is used in TI's OMAP 1281da177e4SLinus Torvalds device family. 1291da177e4SLinus Torvalds 1301da177e4SLinus Torvalds Say Y if you want support for the ARM925T processor. 1311da177e4SLinus Torvalds Otherwise, say N. 1321da177e4SLinus Torvalds 1331da177e4SLinus Torvalds# ARM926T 1341da177e4SLinus Torvaldsconfig CPU_ARM926T 13517d44d7dSArnd Bergmann bool 1361da177e4SLinus Torvalds select CPU_32v5 1371da177e4SLinus Torvalds select CPU_ABRT_EV5TJ 1381da177e4SLinus Torvalds select CPU_CACHE_VIVT 139f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 140b1b3f49cSRussell King select CPU_CP15_MMU 141b1b3f49cSRussell King select CPU_PABRT_LEGACY 142c466bda6SRussell King select CPU_THUMB_CAPABLE 143f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1441da177e4SLinus Torvalds help 1451da177e4SLinus Torvalds This is a variant of the ARM920. It has slightly different 1461da177e4SLinus Torvalds instruction sequences for cache and TLB operations. Curiously, 1471da177e4SLinus Torvalds there is no documentation on it at the ARM corporate website. 1481da177e4SLinus Torvalds 1491da177e4SLinus Torvalds Say Y if you want support for the ARM926T processor. 1501da177e4SLinus Torvalds Otherwise, say N. 1511da177e4SLinus Torvalds 15228853ac8SPaulius Zaleckas# FA526 15328853ac8SPaulius Zaleckasconfig CPU_FA526 15428853ac8SPaulius Zaleckas bool 15528853ac8SPaulius Zaleckas select CPU_32v4 15628853ac8SPaulius Zaleckas select CPU_ABRT_EV4 15728853ac8SPaulius Zaleckas select CPU_CACHE_FA 158b1b3f49cSRussell King select CPU_CACHE_VIVT 15928853ac8SPaulius Zaleckas select CPU_COPY_FA if MMU 160b1b3f49cSRussell King select CPU_CP15_MMU 161b1b3f49cSRussell King select CPU_PABRT_LEGACY 16228853ac8SPaulius Zaleckas select CPU_TLB_FA if MMU 16328853ac8SPaulius Zaleckas help 16428853ac8SPaulius Zaleckas The FA526 is a version of the ARMv4 compatible processor with 16528853ac8SPaulius Zaleckas Branch Target Buffer, Unified TLB and cache line size 16. 16628853ac8SPaulius Zaleckas 16728853ac8SPaulius Zaleckas Say Y if you want support for the FA526 processor. 16828853ac8SPaulius Zaleckas Otherwise, say N. 16928853ac8SPaulius Zaleckas 170d60674ebSHyok S. Choi# ARM940T 171d60674ebSHyok S. Choiconfig CPU_ARM940T 17217d44d7dSArnd Bergmann bool 1736b237a35SRussell King depends on !MMU 174d60674ebSHyok S. Choi select CPU_32v4T 1750f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 176d60674ebSHyok S. Choi select CPU_CACHE_VIVT 177d60674ebSHyok S. Choi select CPU_CP15_MPU 178b1b3f49cSRussell King select CPU_PABRT_LEGACY 179c466bda6SRussell King select CPU_THUMB_CAPABLE 180d60674ebSHyok S. Choi help 181d60674ebSHyok S. Choi ARM940T is a member of the ARM9TDMI family of general- 1823cb2fcccSMatt LaPlante purpose microprocessors with MPU and separate 4KB 183d60674ebSHyok S. Choi instruction and 4KB data cases, each with a 4-word line 184d60674ebSHyok S. Choi length. 185d60674ebSHyok S. Choi 186d60674ebSHyok S. Choi Say Y if you want support for the ARM940T processor. 187d60674ebSHyok S. Choi Otherwise, say N. 188d60674ebSHyok S. Choi 189f37f46ebSHyok S. Choi# ARM946E-S 190f37f46ebSHyok S. Choiconfig CPU_ARM946E 19117d44d7dSArnd Bergmann bool 1926b237a35SRussell King depends on !MMU 193f37f46ebSHyok S. Choi select CPU_32v5 1940f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 195f37f46ebSHyok S. Choi select CPU_CACHE_VIVT 196f37f46ebSHyok S. Choi select CPU_CP15_MPU 197b1b3f49cSRussell King select CPU_PABRT_LEGACY 198c466bda6SRussell King select CPU_THUMB_CAPABLE 199f37f46ebSHyok S. Choi help 200f37f46ebSHyok S. Choi ARM946E-S is a member of the ARM9E-S family of high- 201f37f46ebSHyok S. Choi performance, 32-bit system-on-chip processor solutions. 202f37f46ebSHyok S. Choi The TCM and ARMv5TE 32-bit instruction set is supported. 203f37f46ebSHyok S. Choi 204f37f46ebSHyok S. Choi Say Y if you want support for the ARM946E-S processor. 205f37f46ebSHyok S. Choi Otherwise, say N. 206f37f46ebSHyok S. Choi 2071da177e4SLinus Torvalds# ARM1020 - needs validating 2081da177e4SLinus Torvaldsconfig CPU_ARM1020 20917d44d7dSArnd Bergmann bool 2101da177e4SLinus Torvalds select CPU_32v5 2111da177e4SLinus Torvalds select CPU_ABRT_EV4T 2121da177e4SLinus Torvalds select CPU_CACHE_V4WT 2131da177e4SLinus Torvalds select CPU_CACHE_VIVT 214f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 215b1b3f49cSRussell King select CPU_CP15_MMU 216b1b3f49cSRussell King select CPU_PABRT_LEGACY 217c466bda6SRussell King select CPU_THUMB_CAPABLE 218f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2191da177e4SLinus Torvalds help 2201da177e4SLinus Torvalds The ARM1020 is the 32K cached version of the ARM10 processor, 2211da177e4SLinus Torvalds with an addition of a floating-point unit. 2221da177e4SLinus Torvalds 2231da177e4SLinus Torvalds Say Y if you want support for the ARM1020 processor. 2241da177e4SLinus Torvalds Otherwise, say N. 2251da177e4SLinus Torvalds 2261da177e4SLinus Torvalds# ARM1020E - needs validating 2271da177e4SLinus Torvaldsconfig CPU_ARM1020E 22817d44d7dSArnd Bergmann bool 229b1b3f49cSRussell King depends on n 2301da177e4SLinus Torvalds select CPU_32v5 2311da177e4SLinus Torvalds select CPU_ABRT_EV4T 2321da177e4SLinus Torvalds select CPU_CACHE_V4WT 2331da177e4SLinus Torvalds select CPU_CACHE_VIVT 234f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 235b1b3f49cSRussell King select CPU_CP15_MMU 236b1b3f49cSRussell King select CPU_PABRT_LEGACY 237c466bda6SRussell King select CPU_THUMB_CAPABLE 238f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2391da177e4SLinus Torvalds 2401da177e4SLinus Torvalds# ARM1022E 2411da177e4SLinus Torvaldsconfig CPU_ARM1022 24217d44d7dSArnd Bergmann bool 2431da177e4SLinus Torvalds select CPU_32v5 2441da177e4SLinus Torvalds select CPU_ABRT_EV4T 2451da177e4SLinus Torvalds select CPU_CACHE_VIVT 246f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU # can probably do better 247b1b3f49cSRussell King select CPU_CP15_MMU 248b1b3f49cSRussell King select CPU_PABRT_LEGACY 249c466bda6SRussell King select CPU_THUMB_CAPABLE 250f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2511da177e4SLinus Torvalds help 2521da177e4SLinus Torvalds The ARM1022E is an implementation of the ARMv5TE architecture 2531da177e4SLinus Torvalds based upon the ARM10 integer core with a 16KiB L1 Harvard cache, 2541da177e4SLinus Torvalds embedded trace macrocell, and a floating-point unit. 2551da177e4SLinus Torvalds 2561da177e4SLinus Torvalds Say Y if you want support for the ARM1022E processor. 2571da177e4SLinus Torvalds Otherwise, say N. 2581da177e4SLinus Torvalds 2591da177e4SLinus Torvalds# ARM1026EJ-S 2601da177e4SLinus Torvaldsconfig CPU_ARM1026 26117d44d7dSArnd Bergmann bool 2621da177e4SLinus Torvalds select CPU_32v5 2631da177e4SLinus Torvalds select CPU_ABRT_EV5T # But need Jazelle, but EV5TJ ignores bit 10 2641da177e4SLinus Torvalds select CPU_CACHE_VIVT 265f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU # can probably do better 266b1b3f49cSRussell King select CPU_CP15_MMU 267b1b3f49cSRussell King select CPU_PABRT_LEGACY 268c466bda6SRussell King select CPU_THUMB_CAPABLE 269f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2701da177e4SLinus Torvalds help 2711da177e4SLinus Torvalds The ARM1026EJ-S is an implementation of the ARMv5TEJ architecture 2721da177e4SLinus Torvalds based upon the ARM10 integer core. 2731da177e4SLinus Torvalds 2741da177e4SLinus Torvalds Say Y if you want support for the ARM1026EJ-S processor. 2751da177e4SLinus Torvalds Otherwise, say N. 2761da177e4SLinus Torvalds 2771da177e4SLinus Torvalds# SA110 2781da177e4SLinus Torvaldsconfig CPU_SA110 279fa04e209SArnd Bergmann bool 2801da177e4SLinus Torvalds select CPU_32v3 if ARCH_RPC 2811da177e4SLinus Torvalds select CPU_32v4 if !ARCH_RPC 2821da177e4SLinus Torvalds select CPU_ABRT_EV4 2831da177e4SLinus Torvalds select CPU_CACHE_V4WB 2841da177e4SLinus Torvalds select CPU_CACHE_VIVT 285f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 286b1b3f49cSRussell King select CPU_CP15_MMU 287b1b3f49cSRussell King select CPU_PABRT_LEGACY 288f9c21a6eSHyok S. Choi select CPU_TLB_V4WB if MMU 2891da177e4SLinus Torvalds help 2901da177e4SLinus Torvalds The Intel StrongARM(R) SA-110 is a 32-bit microprocessor and 2911da177e4SLinus Torvalds is available at five speeds ranging from 100 MHz to 233 MHz. 2921da177e4SLinus Torvalds More information is available at 2931da177e4SLinus Torvalds <http://developer.intel.com/design/strong/sa110.htm>. 2941da177e4SLinus Torvalds 2951da177e4SLinus Torvalds Say Y if you want support for the SA-110 processor. 2961da177e4SLinus Torvalds Otherwise, say N. 2971da177e4SLinus Torvalds 2981da177e4SLinus Torvalds# SA1100 2991da177e4SLinus Torvaldsconfig CPU_SA1100 3001da177e4SLinus Torvalds bool 3011da177e4SLinus Torvalds select CPU_32v4 3021da177e4SLinus Torvalds select CPU_ABRT_EV4 3031da177e4SLinus Torvalds select CPU_CACHE_V4WB 3041da177e4SLinus Torvalds select CPU_CACHE_VIVT 305fefdaa06SHyok S. Choi select CPU_CP15_MMU 306b1b3f49cSRussell King select CPU_PABRT_LEGACY 307f9c21a6eSHyok S. Choi select CPU_TLB_V4WB if MMU 3081da177e4SLinus Torvalds 3091da177e4SLinus Torvalds# XScale 3101da177e4SLinus Torvaldsconfig CPU_XSCALE 3111da177e4SLinus Torvalds bool 3121da177e4SLinus Torvalds select CPU_32v5 3131da177e4SLinus Torvalds select CPU_ABRT_EV5T 3141da177e4SLinus Torvalds select CPU_CACHE_VIVT 315fefdaa06SHyok S. Choi select CPU_CP15_MMU 316b1b3f49cSRussell King select CPU_PABRT_LEGACY 317c466bda6SRussell King select CPU_THUMB_CAPABLE 318f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 3191da177e4SLinus Torvalds 32023bdf86aSLennert Buytenhek# XScale Core Version 3 32123bdf86aSLennert Buytenhekconfig CPU_XSC3 32223bdf86aSLennert Buytenhek bool 32323bdf86aSLennert Buytenhek select CPU_32v5 32423bdf86aSLennert Buytenhek select CPU_ABRT_EV5T 32523bdf86aSLennert Buytenhek select CPU_CACHE_VIVT 326fefdaa06SHyok S. Choi select CPU_CP15_MMU 327b1b3f49cSRussell King select CPU_PABRT_LEGACY 328c466bda6SRussell King select CPU_THUMB_CAPABLE 329f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 33023bdf86aSLennert Buytenhek select IO_36 33123bdf86aSLennert Buytenhek 33249cbe786SEric Miao# Marvell PJ1 (Mohawk) 33349cbe786SEric Miaoconfig CPU_MOHAWK 33449cbe786SEric Miao bool 33549cbe786SEric Miao select CPU_32v5 33649cbe786SEric Miao select CPU_ABRT_EV5T 33749cbe786SEric Miao select CPU_CACHE_VIVT 33849cbe786SEric Miao select CPU_COPY_V4WB if MMU 339b1b3f49cSRussell King select CPU_CP15_MMU 340b1b3f49cSRussell King select CPU_PABRT_LEGACY 341c466bda6SRussell King select CPU_THUMB_CAPABLE 342b1b3f49cSRussell King select CPU_TLB_V4WBI if MMU 34349cbe786SEric Miao 344e50d6409SAssaf Hoffman# Feroceon 345e50d6409SAssaf Hoffmanconfig CPU_FEROCEON 346e50d6409SAssaf Hoffman bool 347e50d6409SAssaf Hoffman select CPU_32v5 348e50d6409SAssaf Hoffman select CPU_ABRT_EV5T 349e50d6409SAssaf Hoffman select CPU_CACHE_VIVT 3500ed15071SLennert Buytenhek select CPU_COPY_FEROCEON if MMU 351b1b3f49cSRussell King select CPU_CP15_MMU 352b1b3f49cSRussell King select CPU_PABRT_LEGACY 353c466bda6SRussell King select CPU_THUMB_CAPABLE 35499c6dc11SLennert Buytenhek select CPU_TLB_FEROCEON if MMU 355e50d6409SAssaf Hoffman 356d910a0aaSTzachi Perelsteinconfig CPU_FEROCEON_OLD_ID 357d910a0aaSTzachi Perelstein bool "Accept early Feroceon cores with an ARM926 ID" 358d910a0aaSTzachi Perelstein depends on CPU_FEROCEON && !CPU_ARM926T 359d910a0aaSTzachi Perelstein default y 360d910a0aaSTzachi Perelstein help 361d910a0aaSTzachi Perelstein This enables the usage of some old Feroceon cores 362d910a0aaSTzachi Perelstein for which the CPU ID is equal to the ARM926 ID. 363d910a0aaSTzachi Perelstein Relevant for Feroceon-1850 and early Feroceon-2850. 364d910a0aaSTzachi Perelstein 365a4553358SHaojian Zhuang# Marvell PJ4 366a4553358SHaojian Zhuangconfig CPU_PJ4 367a4553358SHaojian Zhuang bool 368a4553358SHaojian Zhuang select ARM_THUMBEE 369b1b3f49cSRussell King select CPU_V7 370a4553358SHaojian Zhuang 371de490193SGregory CLEMENTconfig CPU_PJ4B 372de490193SGregory CLEMENT bool 373de490193SGregory CLEMENT select CPU_V7 374de490193SGregory CLEMENT 3751da177e4SLinus Torvalds# ARMv6 3761da177e4SLinus Torvaldsconfig CPU_V6 37717d44d7dSArnd Bergmann bool 3781da177e4SLinus Torvalds select CPU_32v6 3791da177e4SLinus Torvalds select CPU_ABRT_EV6 3801da177e4SLinus Torvalds select CPU_CACHE_V6 3811da177e4SLinus Torvalds select CPU_CACHE_VIPT 382b1b3f49cSRussell King select CPU_COPY_V6 if MMU 383fefdaa06SHyok S. Choi select CPU_CP15_MMU 3847b4c965aSCatalin Marinas select CPU_HAS_ASID if MMU 385b1b3f49cSRussell King select CPU_PABRT_V6 386c466bda6SRussell King select CPU_THUMB_CAPABLE 387f9c21a6eSHyok S. Choi select CPU_TLB_V6 if MMU 3881da177e4SLinus Torvalds 3894a5f79e7SRussell King# ARMv6k 390e399b1a4SRussell Kingconfig CPU_V6K 39117d44d7dSArnd Bergmann bool 392e399b1a4SRussell King select CPU_32v6 39360799c6dSRussell King select CPU_32v6K 394e399b1a4SRussell King select CPU_ABRT_EV6 395e399b1a4SRussell King select CPU_CACHE_V6 396e399b1a4SRussell King select CPU_CACHE_VIPT 397b1b3f49cSRussell King select CPU_COPY_V6 if MMU 398e399b1a4SRussell King select CPU_CP15_MMU 399e399b1a4SRussell King select CPU_HAS_ASID if MMU 400b1b3f49cSRussell King select CPU_PABRT_V6 401c466bda6SRussell King select CPU_THUMB_CAPABLE 402e399b1a4SRussell King select CPU_TLB_V6 if MMU 4034a5f79e7SRussell King 40423688e99SCatalin Marinas# ARMv7 40523688e99SCatalin Marinasconfig CPU_V7 40617d44d7dSArnd Bergmann bool 40715490ef8SRussell King select CPU_32v6K 40823688e99SCatalin Marinas select CPU_32v7 40923688e99SCatalin Marinas select CPU_ABRT_EV7 41023688e99SCatalin Marinas select CPU_CACHE_V7 41123688e99SCatalin Marinas select CPU_CACHE_VIPT 412b1b3f49cSRussell King select CPU_COPY_V6 if MMU 41366567618SJonathan Austin select CPU_CP15_MMU if MMU 41466567618SJonathan Austin select CPU_CP15_MPU if !MMU 4152eb8c82bSCatalin Marinas select CPU_HAS_ASID if MMU 416b1b3f49cSRussell King select CPU_PABRT_V7 417c466bda6SRussell King select CPU_THUMB_CAPABLE 4182ccdd1e7SCatalin Marinas select CPU_TLB_V7 if MMU 41923688e99SCatalin Marinas 4204477ca45SUwe Kleine-König# ARMv7M 4214477ca45SUwe Kleine-Königconfig CPU_V7M 4224477ca45SUwe Kleine-König bool 4234477ca45SUwe Kleine-König select CPU_32v7M 4244477ca45SUwe Kleine-König select CPU_ABRT_NOMMU 425bc0ee9d2SJonathan Austin select CPU_CACHE_V7M 4264477ca45SUwe Kleine-König select CPU_CACHE_NOP 4274477ca45SUwe Kleine-König select CPU_PABRT_LEGACY 4284477ca45SUwe Kleine-König select CPU_THUMBONLY 4294477ca45SUwe Kleine-König 430bc7dea00SUwe Kleine-Königconfig CPU_THUMBONLY 431bc7dea00SUwe Kleine-König bool 432c466bda6SRussell King select CPU_THUMB_CAPABLE 433bc7dea00SUwe Kleine-König # There are no CPUs available with MMU that don't implement an ARM ISA: 434bc7dea00SUwe Kleine-König depends on !MMU 435bc7dea00SUwe Kleine-König help 436bc7dea00SUwe Kleine-König Select this if your CPU doesn't support the 32 bit ARM instructions. 437bc7dea00SUwe Kleine-König 438c466bda6SRussell Kingconfig CPU_THUMB_CAPABLE 439c466bda6SRussell King bool 440c466bda6SRussell King help 441c466bda6SRussell King Select this if your CPU can support Thumb mode. 442c466bda6SRussell King 4431da177e4SLinus Torvalds# Figure out what processor architecture version we should be using. 4441da177e4SLinus Torvalds# This defines the compiler instruction set which depends on the machine type. 4451da177e4SLinus Torvaldsconfig CPU_32v3 4461da177e4SLinus Torvalds bool 4478762df4dSRussell King select CPU_USE_DOMAINS if MMU 448f6f91b0dSRussell King select NEED_KUSER_HELPERS 44951aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 450fff7fb0bSZhaoxiu Zeng select CPU_NO_EFFICIENT_FFS 4511da177e4SLinus Torvalds 4521da177e4SLinus Torvaldsconfig CPU_32v4 4531da177e4SLinus Torvalds bool 4548762df4dSRussell King select CPU_USE_DOMAINS if MMU 455f6f91b0dSRussell King select NEED_KUSER_HELPERS 45651aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 457fff7fb0bSZhaoxiu Zeng select CPU_NO_EFFICIENT_FFS 4581da177e4SLinus Torvalds 459260e98edSLennert Buytenhekconfig CPU_32v4T 460260e98edSLennert Buytenhek bool 4618762df4dSRussell King select CPU_USE_DOMAINS if MMU 462f6f91b0dSRussell King select NEED_KUSER_HELPERS 46351aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 464fff7fb0bSZhaoxiu Zeng select CPU_NO_EFFICIENT_FFS 465260e98edSLennert Buytenhek 4661da177e4SLinus Torvaldsconfig CPU_32v5 4671da177e4SLinus Torvalds bool 4688762df4dSRussell King select CPU_USE_DOMAINS if MMU 469f6f91b0dSRussell King select NEED_KUSER_HELPERS 47051aaf81fSRussell King select TLS_REG_EMUL if SMP || !MMU 4711da177e4SLinus Torvalds 4721da177e4SLinus Torvaldsconfig CPU_32v6 4731da177e4SLinus Torvalds bool 474b1b3f49cSRussell King select TLS_REG_EMUL if !CPU_32v6K && !MMU 4751da177e4SLinus Torvalds 476e399b1a4SRussell Kingconfig CPU_32v6K 47760799c6dSRussell King bool 4781da177e4SLinus Torvalds 47923688e99SCatalin Marinasconfig CPU_32v7 48023688e99SCatalin Marinas bool 48123688e99SCatalin Marinas 4824477ca45SUwe Kleine-Königconfig CPU_32v7M 4834477ca45SUwe Kleine-König bool 4844477ca45SUwe Kleine-König 4851da177e4SLinus Torvalds# The abort model 4860f45d7f3SHyok S. Choiconfig CPU_ABRT_NOMMU 4870f45d7f3SHyok S. Choi bool 4880f45d7f3SHyok S. Choi 4891da177e4SLinus Torvaldsconfig CPU_ABRT_EV4 4901da177e4SLinus Torvalds bool 4911da177e4SLinus Torvalds 4921da177e4SLinus Torvaldsconfig CPU_ABRT_EV4T 4931da177e4SLinus Torvalds bool 4941da177e4SLinus Torvalds 4951da177e4SLinus Torvaldsconfig CPU_ABRT_LV4T 4961da177e4SLinus Torvalds bool 4971da177e4SLinus Torvalds 4981da177e4SLinus Torvaldsconfig CPU_ABRT_EV5T 4991da177e4SLinus Torvalds bool 5001da177e4SLinus Torvalds 5011da177e4SLinus Torvaldsconfig CPU_ABRT_EV5TJ 5021da177e4SLinus Torvalds bool 5031da177e4SLinus Torvalds 5041da177e4SLinus Torvaldsconfig CPU_ABRT_EV6 5051da177e4SLinus Torvalds bool 5061da177e4SLinus Torvalds 50723688e99SCatalin Marinasconfig CPU_ABRT_EV7 50823688e99SCatalin Marinas bool 50923688e99SCatalin Marinas 5104fb28474SKirill A. Shutemovconfig CPU_PABRT_LEGACY 51148d7927bSPaul Brook bool 51248d7927bSPaul Brook 5134fb28474SKirill A. Shutemovconfig CPU_PABRT_V6 5144fb28474SKirill A. Shutemov bool 5154fb28474SKirill A. Shutemov 5164fb28474SKirill A. Shutemovconfig CPU_PABRT_V7 51748d7927bSPaul Brook bool 51848d7927bSPaul Brook 5191da177e4SLinus Torvalds# The cache model 5201da177e4SLinus Torvaldsconfig CPU_CACHE_V4 5211da177e4SLinus Torvalds bool 5221da177e4SLinus Torvalds 5231da177e4SLinus Torvaldsconfig CPU_CACHE_V4WT 5241da177e4SLinus Torvalds bool 5251da177e4SLinus Torvalds 5261da177e4SLinus Torvaldsconfig CPU_CACHE_V4WB 5271da177e4SLinus Torvalds bool 5281da177e4SLinus Torvalds 5291da177e4SLinus Torvaldsconfig CPU_CACHE_V6 5301da177e4SLinus Torvalds bool 5311da177e4SLinus Torvalds 53223688e99SCatalin Marinasconfig CPU_CACHE_V7 53323688e99SCatalin Marinas bool 53423688e99SCatalin Marinas 5354477ca45SUwe Kleine-Königconfig CPU_CACHE_NOP 5364477ca45SUwe Kleine-König bool 5374477ca45SUwe Kleine-König 5381da177e4SLinus Torvaldsconfig CPU_CACHE_VIVT 5391da177e4SLinus Torvalds bool 5401da177e4SLinus Torvalds 5411da177e4SLinus Torvaldsconfig CPU_CACHE_VIPT 5421da177e4SLinus Torvalds bool 5431da177e4SLinus Torvalds 54428853ac8SPaulius Zaleckasconfig CPU_CACHE_FA 54528853ac8SPaulius Zaleckas bool 54628853ac8SPaulius Zaleckas 547bc0ee9d2SJonathan Austinconfig CPU_CACHE_V7M 548bc0ee9d2SJonathan Austin bool 549bc0ee9d2SJonathan Austin 550f9c21a6eSHyok S. Choiif MMU 5511da177e4SLinus Torvalds# The copy-page model 5521da177e4SLinus Torvaldsconfig CPU_COPY_V4WT 5531da177e4SLinus Torvalds bool 5541da177e4SLinus Torvalds 5551da177e4SLinus Torvaldsconfig CPU_COPY_V4WB 5561da177e4SLinus Torvalds bool 5571da177e4SLinus Torvalds 5580ed15071SLennert Buytenhekconfig CPU_COPY_FEROCEON 5590ed15071SLennert Buytenhek bool 5600ed15071SLennert Buytenhek 56128853ac8SPaulius Zaleckasconfig CPU_COPY_FA 56228853ac8SPaulius Zaleckas bool 56328853ac8SPaulius Zaleckas 5641da177e4SLinus Torvaldsconfig CPU_COPY_V6 5651da177e4SLinus Torvalds bool 5661da177e4SLinus Torvalds 5671da177e4SLinus Torvalds# This selects the TLB model 5681da177e4SLinus Torvaldsconfig CPU_TLB_V4WT 5691da177e4SLinus Torvalds bool 5701da177e4SLinus Torvalds help 5711da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writethrough cache. 5721da177e4SLinus Torvalds 5731da177e4SLinus Torvaldsconfig CPU_TLB_V4WB 5741da177e4SLinus Torvalds bool 5751da177e4SLinus Torvalds help 5761da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writeback cache. 5771da177e4SLinus Torvalds 5781da177e4SLinus Torvaldsconfig CPU_TLB_V4WBI 5791da177e4SLinus Torvalds bool 5801da177e4SLinus Torvalds help 5811da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writeback cache and invalidate 5821da177e4SLinus Torvalds instruction cache entry. 5831da177e4SLinus Torvalds 58499c6dc11SLennert Buytenhekconfig CPU_TLB_FEROCEON 58599c6dc11SLennert Buytenhek bool 58699c6dc11SLennert Buytenhek help 58799c6dc11SLennert Buytenhek Feroceon TLB (v4wbi with non-outer-cachable page table walks). 58899c6dc11SLennert Buytenhek 58928853ac8SPaulius Zaleckasconfig CPU_TLB_FA 59028853ac8SPaulius Zaleckas bool 59128853ac8SPaulius Zaleckas help 59228853ac8SPaulius Zaleckas Faraday ARM FA526 architecture, unified TLB with writeback cache 59328853ac8SPaulius Zaleckas and invalidate instruction cache entry. Branch target buffer is 59428853ac8SPaulius Zaleckas also supported. 59528853ac8SPaulius Zaleckas 5961da177e4SLinus Torvaldsconfig CPU_TLB_V6 5971da177e4SLinus Torvalds bool 5981da177e4SLinus Torvalds 5992ccdd1e7SCatalin Marinasconfig CPU_TLB_V7 6002ccdd1e7SCatalin Marinas bool 6012ccdd1e7SCatalin Marinas 602e220ba60SDave Estesconfig VERIFY_PERMISSION_FAULT 603e220ba60SDave Estes bool 604f9c21a6eSHyok S. Choiendif 605f9c21a6eSHyok S. Choi 606516793c6SRussell Kingconfig CPU_HAS_ASID 607516793c6SRussell King bool 608516793c6SRussell King help 609516793c6SRussell King This indicates whether the CPU has the ASID register; used to 610516793c6SRussell King tag TLB and possibly cache entries. 611516793c6SRussell King 612fefdaa06SHyok S. Choiconfig CPU_CP15 613fefdaa06SHyok S. Choi bool 614fefdaa06SHyok S. Choi help 615fefdaa06SHyok S. Choi Processor has the CP15 register. 616fefdaa06SHyok S. Choi 617fefdaa06SHyok S. Choiconfig CPU_CP15_MMU 618fefdaa06SHyok S. Choi bool 619fefdaa06SHyok S. Choi select CPU_CP15 620fefdaa06SHyok S. Choi help 621fefdaa06SHyok S. Choi Processor has the CP15 register, which has MMU related registers. 622fefdaa06SHyok S. Choi 623fefdaa06SHyok S. Choiconfig CPU_CP15_MPU 624fefdaa06SHyok S. Choi bool 625fefdaa06SHyok S. Choi select CPU_CP15 626fefdaa06SHyok S. Choi help 627fefdaa06SHyok S. Choi Processor has the CP15 register, which has MPU related registers. 628fefdaa06SHyok S. Choi 629247055aaSCatalin Marinasconfig CPU_USE_DOMAINS 630247055aaSCatalin Marinas bool 631247055aaSCatalin Marinas help 632247055aaSCatalin Marinas This option enables or disables the use of domain switching 633247055aaSCatalin Marinas via the set_fs() function. 634247055aaSCatalin Marinas 6356b1814cdSMaxime Coquelin stm32config CPU_V7M_NUM_IRQ 6366b1814cdSMaxime Coquelin stm32 int "Number of external interrupts connected to the NVIC" 6376b1814cdSMaxime Coquelin stm32 depends on CPU_V7M 6386b1814cdSMaxime Coquelin stm32 default 90 if ARCH_STM32 6396b1814cdSMaxime Coquelin stm32 default 38 if ARCH_EFM32 64045b0fa09SStefan Agner default 112 if SOC_VF610 6416b1814cdSMaxime Coquelin stm32 default 240 6426b1814cdSMaxime Coquelin stm32 help 6436b1814cdSMaxime Coquelin stm32 This option indicates the number of interrupts connected to the NVIC. 6446b1814cdSMaxime Coquelin stm32 The value can be larger than the real number of interrupts supported 6456b1814cdSMaxime Coquelin stm32 by the system, but must not be lower. 6466b1814cdSMaxime Coquelin stm32 The default value is 240, corresponding to the maximum number of 6476b1814cdSMaxime Coquelin stm32 interrupts supported by the NVIC on Cortex-M family. 6486b1814cdSMaxime Coquelin stm32 6496b1814cdSMaxime Coquelin stm32 If unsure, keep default value. 6506b1814cdSMaxime Coquelin stm32 65123bdf86aSLennert Buytenhek# 65223bdf86aSLennert Buytenhek# CPU supports 36-bit I/O 65323bdf86aSLennert Buytenhek# 65423bdf86aSLennert Buytenhekconfig IO_36 65523bdf86aSLennert Buytenhek bool 65623bdf86aSLennert Buytenhek 6571da177e4SLinus Torvaldscomment "Processor Features" 6581da177e4SLinus Torvalds 659497b7e94SCatalin Marinasconfig ARM_LPAE 660497b7e94SCatalin Marinas bool "Support for the Large Physical Address Extension" 66108a183f0SCatalin Marinas depends on MMU && CPU_32v7 && !CPU_32v6 && !CPU_32v5 && \ 66208a183f0SCatalin Marinas !CPU_32v4 && !CPU_32v3 663497b7e94SCatalin Marinas help 664497b7e94SCatalin Marinas Say Y if you have an ARMv7 processor supporting the LPAE page 665497b7e94SCatalin Marinas table format and you would like to access memory beyond the 666497b7e94SCatalin Marinas 4GB limit. The resulting kernel image will not run on 667497b7e94SCatalin Marinas processors without the LPA extension. 668497b7e94SCatalin Marinas 669497b7e94SCatalin Marinas If unsure, say N. 670497b7e94SCatalin Marinas 671d8dc7fbdSRussell Kingconfig ARM_PV_FIXUP 672d8dc7fbdSRussell King def_bool y 673d8dc7fbdSRussell King depends on ARM_LPAE && ARM_PATCH_PHYS_VIRT && ARCH_KEYSTONE 674d8dc7fbdSRussell King 675497b7e94SCatalin Marinasconfig ARCH_PHYS_ADDR_T_64BIT 676497b7e94SCatalin Marinas def_bool ARM_LPAE 677497b7e94SCatalin Marinas 678497b7e94SCatalin Marinasconfig ARCH_DMA_ADDR_T_64BIT 679497b7e94SCatalin Marinas bool 680497b7e94SCatalin Marinas 6811da177e4SLinus Torvaldsconfig ARM_THUMB 682*1515b186SRussell King bool "Support Thumb user binaries" if !CPU_THUMBONLY && EXPERT 683c466bda6SRussell King depends on CPU_THUMB_CAPABLE 6841da177e4SLinus Torvalds default y 6851da177e4SLinus Torvalds help 6861da177e4SLinus Torvalds Say Y if you want to include kernel support for running user space 6871da177e4SLinus Torvalds Thumb binaries. 6881da177e4SLinus Torvalds 6891da177e4SLinus Torvalds The Thumb instruction set is a compressed form of the standard ARM 6901da177e4SLinus Torvalds instruction set resulting in smaller binaries at the expense of 6911da177e4SLinus Torvalds slightly less efficient code. 6921da177e4SLinus Torvalds 693*1515b186SRussell King If this option is disabled, and you run userspace that switches to 694*1515b186SRussell King Thumb mode, signal handling will not work correctly, resulting in 695*1515b186SRussell King segmentation faults or illegal instruction aborts. 696*1515b186SRussell King 6971da177e4SLinus Torvalds If you don't know what this all is, saying Y is a safe choice. 6981da177e4SLinus Torvalds 699d7f864beSCatalin Marinasconfig ARM_THUMBEE 700d7f864beSCatalin Marinas bool "Enable ThumbEE CPU extension" 701d7f864beSCatalin Marinas depends on CPU_V7 702d7f864beSCatalin Marinas help 703d7f864beSCatalin Marinas Say Y here if you have a CPU with the ThumbEE extension and code to 704d7f864beSCatalin Marinas make use of it. Say N for code that can run on CPUs without ThumbEE. 705d7f864beSCatalin Marinas 7065b6728d4SDave Martinconfig ARM_VIRT_EXT 707651134b0SWill Deacon bool 708651134b0SWill Deacon depends on MMU 709651134b0SWill Deacon default y if CPU_V7 7105b6728d4SDave Martin help 7115b6728d4SDave Martin Enable the kernel to make use of the ARM Virtualization 7125b6728d4SDave Martin Extensions to install hypervisors without run-time firmware 7135b6728d4SDave Martin assistance. 7145b6728d4SDave Martin 7155b6728d4SDave Martin A compliant bootloader is required in order to make maximum 7165b6728d4SDave Martin use of this feature. Refer to Documentation/arm/Booting for 7175b6728d4SDave Martin details. 7185b6728d4SDave Martin 71964d2dc38SLeif Lindholmconfig SWP_EMULATE 720a11dd731SRussell King bool "Emulate SWP/SWPB instructions" if !SMP 721b6ccb980SWill Deacon depends on CPU_V7 72264d2dc38SLeif Lindholm default y if SMP 723b1b3f49cSRussell King select HAVE_PROC_CPU if PROC_FS 72464d2dc38SLeif Lindholm help 72564d2dc38SLeif Lindholm ARMv6 architecture deprecates use of the SWP/SWPB instructions. 72664d2dc38SLeif Lindholm ARMv7 multiprocessing extensions introduce the ability to disable 72764d2dc38SLeif Lindholm these instructions, triggering an undefined instruction exception 72864d2dc38SLeif Lindholm when executed. Say Y here to enable software emulation of these 72964d2dc38SLeif Lindholm instructions for userspace (not kernel) using LDREX/STREX. 73064d2dc38SLeif Lindholm Also creates /proc/cpu/swp_emulation for statistics. 73164d2dc38SLeif Lindholm 73264d2dc38SLeif Lindholm In some older versions of glibc [<=2.8] SWP is used during futex 73364d2dc38SLeif Lindholm trylock() operations with the assumption that the code will not 73464d2dc38SLeif Lindholm be preempted. This invalid assumption may be more likely to fail 73564d2dc38SLeif Lindholm with SWP emulation enabled, leading to deadlock of the user 73664d2dc38SLeif Lindholm application. 73764d2dc38SLeif Lindholm 73864d2dc38SLeif Lindholm NOTE: when accessing uncached shared regions, LDREX/STREX rely 73964d2dc38SLeif Lindholm on an external transaction monitoring block called a global 74064d2dc38SLeif Lindholm monitor to maintain update atomicity. If your system does not 74164d2dc38SLeif Lindholm implement a global monitor, this option can cause programs that 74264d2dc38SLeif Lindholm perform SWP operations to uncached memory to deadlock. 74364d2dc38SLeif Lindholm 74464d2dc38SLeif Lindholm If unsure, say Y. 74564d2dc38SLeif Lindholm 7461da177e4SLinus Torvaldsconfig CPU_BIG_ENDIAN 7471da177e4SLinus Torvalds bool "Build big-endian kernel" 7481da177e4SLinus Torvalds depends on ARCH_SUPPORTS_BIG_ENDIAN 7491da177e4SLinus Torvalds help 7501da177e4SLinus Torvalds Say Y if you plan on running a kernel in big-endian mode. 7511da177e4SLinus Torvalds Note that your board must be properly built and your board 7521da177e4SLinus Torvalds port must properly enable any big-endian related features 7531da177e4SLinus Torvalds of your chipset/board/processor. 7541da177e4SLinus Torvalds 75526584853SCatalin Marinasconfig CPU_ENDIAN_BE8 75626584853SCatalin Marinas bool 75726584853SCatalin Marinas depends on CPU_BIG_ENDIAN 758e399b1a4SRussell King default CPU_V6 || CPU_V6K || CPU_V7 75926584853SCatalin Marinas help 76026584853SCatalin Marinas Support for the BE-8 (big-endian) mode on ARMv6 and ARMv7 processors. 76126584853SCatalin Marinas 76226584853SCatalin Marinasconfig CPU_ENDIAN_BE32 76326584853SCatalin Marinas bool 76426584853SCatalin Marinas depends on CPU_BIG_ENDIAN 76526584853SCatalin Marinas default !CPU_ENDIAN_BE8 76626584853SCatalin Marinas help 76726584853SCatalin Marinas Support for the BE-32 (big-endian) mode on pre-ARMv6 processors. 76826584853SCatalin Marinas 7696afd6faeSHyok S. Choiconfig CPU_HIGH_VECTOR 7706340aa61SRobert P. J. Day depends on !MMU && CPU_CP15 && !CPU_ARM740T 7716afd6faeSHyok S. Choi bool "Select the High exception vector" 7726afd6faeSHyok S. Choi help 7736afd6faeSHyok S. Choi Say Y here to select high exception vector(0xFFFF0000~). 7749b7333a9SWill Deacon The exception vector can vary depending on the platform 7756afd6faeSHyok S. Choi design in nommu mode. If your platform needs to select 7766afd6faeSHyok S. Choi high exception vector, say Y. 7776afd6faeSHyok S. Choi Otherwise or if you are unsure, say N, and the low exception 7786afd6faeSHyok S. Choi vector (0x00000000~) will be used. 7796afd6faeSHyok S. Choi 7801da177e4SLinus Torvaldsconfig CPU_ICACHE_DISABLE 781f12d0d7cSHyok S. Choi bool "Disable I-Cache (I-bit)" 782bc0ee9d2SJonathan Austin depends on (CPU_CP15 && !(CPU_ARM720T || CPU_ARM740T || CPU_XSCALE || CPU_XSC3)) || CPU_V7M 7831da177e4SLinus Torvalds help 7841da177e4SLinus Torvalds Say Y here to disable the processor instruction cache. Unless 7851da177e4SLinus Torvalds you have a reason not to or are unsure, say N. 7861da177e4SLinus Torvalds 7871da177e4SLinus Torvaldsconfig CPU_DCACHE_DISABLE 788f12d0d7cSHyok S. Choi bool "Disable D-Cache (C-bit)" 789bc0ee9d2SJonathan Austin depends on (CPU_CP15 && !SMP) || CPU_V7M 7901da177e4SLinus Torvalds help 7911da177e4SLinus Torvalds Say Y here to disable the processor data cache. Unless 7921da177e4SLinus Torvalds you have a reason not to or are unsure, say N. 7931da177e4SLinus Torvalds 794f37f46ebSHyok S. Choiconfig CPU_DCACHE_SIZE 795f37f46ebSHyok S. Choi hex 796f37f46ebSHyok S. Choi depends on CPU_ARM740T || CPU_ARM946E 797f37f46ebSHyok S. Choi default 0x00001000 if CPU_ARM740T 798f37f46ebSHyok S. Choi default 0x00002000 # default size for ARM946E-S 799f37f46ebSHyok S. Choi help 800f37f46ebSHyok S. Choi Some cores are synthesizable to have various sized cache. For 801f37f46ebSHyok S. Choi ARM946E-S case, it can vary from 0KB to 1MB. 802f37f46ebSHyok S. Choi To support such cache operations, it is efficient to know the size 803f37f46ebSHyok S. Choi before compile time. 804f37f46ebSHyok S. Choi If your SoC is configured to have a different size, define the value 805f37f46ebSHyok S. Choi here with proper conditions. 806f37f46ebSHyok S. Choi 8071da177e4SLinus Torvaldsconfig CPU_DCACHE_WRITETHROUGH 8081da177e4SLinus Torvalds bool "Force write through D-cache" 80928853ac8SPaulius Zaleckas depends on (CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_FA526) && !CPU_DCACHE_DISABLE 8101da177e4SLinus Torvalds default y if CPU_ARM925T 8111da177e4SLinus Torvalds help 8121da177e4SLinus Torvalds Say Y here to use the data cache in writethrough mode. Unless you 8131da177e4SLinus Torvalds specifically require this or are unsure, say N. 8141da177e4SLinus Torvalds 8151da177e4SLinus Torvaldsconfig CPU_CACHE_ROUND_ROBIN 8161da177e4SLinus Torvalds bool "Round robin I and D cache replacement algorithm" 817f37f46ebSHyok S. Choi depends on (CPU_ARM926T || CPU_ARM946E || CPU_ARM1020) && (!CPU_ICACHE_DISABLE || !CPU_DCACHE_DISABLE) 8181da177e4SLinus Torvalds help 8191da177e4SLinus Torvalds Say Y here to use the predictable round-robin cache replacement 8201da177e4SLinus Torvalds policy. Unless you specifically require this or are unsure, say N. 8211da177e4SLinus Torvalds 8221da177e4SLinus Torvaldsconfig CPU_BPREDICT_DISABLE 8231da177e4SLinus Torvalds bool "Disable branch prediction" 824bc0ee9d2SJonathan Austin depends on CPU_ARM1020 || CPU_V6 || CPU_V6K || CPU_MOHAWK || CPU_XSC3 || CPU_V7 || CPU_FA526 || CPU_V7M 8251da177e4SLinus Torvalds help 8261da177e4SLinus Torvalds Say Y here to disable branch prediction. If unsure, say N. 8272d2669b6SNicolas Pitre 8284b0e07a5SNicolas Pitreconfig TLS_REG_EMUL 8294b0e07a5SNicolas Pitre bool 830f6f91b0dSRussell King select NEED_KUSER_HELPERS 8314b0e07a5SNicolas Pitre help 83270489c88SNicolas Pitre An SMP system using a pre-ARMv6 processor (there are apparently 83370489c88SNicolas Pitre a few prototypes like that in existence) and therefore access to 83470489c88SNicolas Pitre that required register must be emulated. 8354b0e07a5SNicolas Pitre 836f6f91b0dSRussell Kingconfig NEED_KUSER_HELPERS 837f6f91b0dSRussell King bool 838f6f91b0dSRussell King 839f6f91b0dSRussell Kingconfig KUSER_HELPERS 840f6f91b0dSRussell King bool "Enable kuser helpers in vector page" if !NEED_KUSER_HELPERS 84108b964ffSNathan Lynch depends on MMU 842f6f91b0dSRussell King default y 843f6f91b0dSRussell King help 844f6f91b0dSRussell King Warning: disabling this option may break user programs. 845f6f91b0dSRussell King 846f6f91b0dSRussell King Provide kuser helpers in the vector page. The kernel provides 847f6f91b0dSRussell King helper code to userspace in read only form at a fixed location 848f6f91b0dSRussell King in the high vector page to allow userspace to be independent of 849f6f91b0dSRussell King the CPU type fitted to the system. This permits binaries to be 850f6f91b0dSRussell King run on ARMv4 through to ARMv7 without modification. 851f6f91b0dSRussell King 852ac124504SNicolas Pitre See Documentation/arm/kernel_user_helpers.txt for details. 853ac124504SNicolas Pitre 854f6f91b0dSRussell King However, the fixed address nature of these helpers can be used 855f6f91b0dSRussell King by ROP (return orientated programming) authors when creating 856f6f91b0dSRussell King exploits. 857f6f91b0dSRussell King 858f6f91b0dSRussell King If all of the binaries and libraries which run on your platform 859f6f91b0dSRussell King are built specifically for your platform, and make no use of 860ac124504SNicolas Pitre these helpers, then you can turn this option off to hinder 861ac124504SNicolas Pitre such exploits. However, in that case, if a binary or library 862ac124504SNicolas Pitre relying on those helpers is run, it will receive a SIGILL signal, 863ac124504SNicolas Pitre which will terminate the program. 864f6f91b0dSRussell King 865f6f91b0dSRussell King Say N here only if you are absolutely certain that you do not 866f6f91b0dSRussell King need these helpers; otherwise, the safe option is to say Y. 867f6f91b0dSRussell King 868e5b61debSNathan Lynchconfig VDSO 869e5b61debSNathan Lynch bool "Enable VDSO for acceleration of some system calls" 8705d38000bSNathan Lynch depends on AEABI && MMU && CPU_V7 871e5b61debSNathan Lynch default y if ARM_ARCH_TIMER 872e5b61debSNathan Lynch select GENERIC_TIME_VSYSCALL 873e5b61debSNathan Lynch help 874e5b61debSNathan Lynch Place in the process address space an ELF shared object 875e5b61debSNathan Lynch providing fast implementations of gettimeofday and 876e5b61debSNathan Lynch clock_gettime. Systems that implement the ARM architected 877e5b61debSNathan Lynch timer will receive maximum benefit. 878e5b61debSNathan Lynch 879e5b61debSNathan Lynch You must have glibc 2.22 or later for programs to seamlessly 880e5b61debSNathan Lynch take advantage of this. 881e5b61debSNathan Lynch 882ad642d9fSCatalin Marinasconfig DMA_CACHE_RWFO 883ad642d9fSCatalin Marinas bool "Enable read/write for ownership DMA cache maintenance" 8843bc28c8eSRussell King depends on CPU_V6K && SMP 885ad642d9fSCatalin Marinas default y 886ad642d9fSCatalin Marinas help 887ad642d9fSCatalin Marinas The Snoop Control Unit on ARM11MPCore does not detect the 888ad642d9fSCatalin Marinas cache maintenance operations and the dma_{map,unmap}_area() 889ad642d9fSCatalin Marinas functions may leave stale cache entries on other CPUs. By 890ad642d9fSCatalin Marinas enabling this option, Read or Write For Ownership in the ARMv6 891ad642d9fSCatalin Marinas DMA cache maintenance functions is performed. These LDR/STR 892ad642d9fSCatalin Marinas instructions change the cache line state to shared or modified 893ad642d9fSCatalin Marinas so that the cache operation has the desired effect. 894ad642d9fSCatalin Marinas 895ad642d9fSCatalin Marinas Note that the workaround is only valid on processors that do 896ad642d9fSCatalin Marinas not perform speculative loads into the D-cache. For such 897ad642d9fSCatalin Marinas processors, if cache maintenance operations are not broadcast 898ad642d9fSCatalin Marinas in hardware, other workarounds are needed (e.g. cache 899ad642d9fSCatalin Marinas maintenance broadcasting in software via FIQ). 900ad642d9fSCatalin Marinas 901953233dcSCatalin Marinasconfig OUTER_CACHE 902953233dcSCatalin Marinas bool 903382266adSCatalin Marinas 904319f551aSCatalin Marinasconfig OUTER_CACHE_SYNC 905319f551aSCatalin Marinas bool 906f8130906SRussell King select ARM_HEAVY_MB 907319f551aSCatalin Marinas help 908319f551aSCatalin Marinas The outer cache has a outer_cache_fns.sync function pointer 909319f551aSCatalin Marinas that can be used to drain the write buffer of the outer cache. 910319f551aSCatalin Marinas 91199c6dc11SLennert Buytenhekconfig CACHE_FEROCEON_L2 91299c6dc11SLennert Buytenhek bool "Enable the Feroceon L2 cache controller" 913ba364fc7SAndrew Lunn depends on ARCH_MV78XX0 || ARCH_MVEBU 91499c6dc11SLennert Buytenhek default y 915382266adSCatalin Marinas select OUTER_CACHE 91699c6dc11SLennert Buytenhek help 91799c6dc11SLennert Buytenhek This option enables the Feroceon L2 cache controller. 91899c6dc11SLennert Buytenhek 9194360bb41SRonen Shitritconfig CACHE_FEROCEON_L2_WRITETHROUGH 9204360bb41SRonen Shitrit bool "Force Feroceon L2 cache write through" 9214360bb41SRonen Shitrit depends on CACHE_FEROCEON_L2 9224360bb41SRonen Shitrit help 9234360bb41SRonen Shitrit Say Y here to use the Feroceon L2 cache in writethrough mode. 9244360bb41SRonen Shitrit Unless you specifically require this, say N for writeback mode. 9254360bb41SRonen Shitrit 926ce5ea9f3SDave Martinconfig MIGHT_HAVE_CACHE_L2X0 927ce5ea9f3SDave Martin bool 928ce5ea9f3SDave Martin help 929ce5ea9f3SDave Martin This option should be selected by machines which have a L2x0 930ce5ea9f3SDave Martin or PL310 cache controller, but where its use is optional. 931ce5ea9f3SDave Martin 932ce5ea9f3SDave Martin The only effect of this option is to make CACHE_L2X0 and 933ce5ea9f3SDave Martin related options available to the user for configuration. 934ce5ea9f3SDave Martin 935ce5ea9f3SDave Martin Boards or SoCs which always require the cache controller 936ce5ea9f3SDave Martin support to be present should select CACHE_L2X0 directly 937ce5ea9f3SDave Martin instead of this option, thus preventing the user from 938ce5ea9f3SDave Martin inadvertently configuring a broken kernel. 939ce5ea9f3SDave Martin 9401da177e4SLinus Torvaldsconfig CACHE_L2X0 941ce5ea9f3SDave Martin bool "Enable the L2x0 outer cache controller" if MIGHT_HAVE_CACHE_L2X0 942ce5ea9f3SDave Martin default MIGHT_HAVE_CACHE_L2X0 9431da177e4SLinus Torvalds select OUTER_CACHE 94423107c54SCatalin Marinas select OUTER_CACHE_SYNC 945ba927951SCatalin Marinas help 946ba927951SCatalin Marinas This option enables the L2x0 PrimeCell. 947905a09d5SEric Miao 948b828f960SMark Rutlandconfig CACHE_L2X0_PMU 949b828f960SMark Rutland bool "L2x0 performance monitor support" if CACHE_L2X0 950b828f960SMark Rutland depends on PERF_EVENTS 951b828f960SMark Rutland help 952b828f960SMark Rutland This option enables support for the performance monitoring features 953b828f960SMark Rutland of the L220 and PL310 outer cache controllers. 954b828f960SMark Rutland 955a641f3a6SRussell Kingif CACHE_L2X0 956a641f3a6SRussell King 957c0fe18baSRussell Kingconfig PL310_ERRATA_588369 958c0fe18baSRussell King bool "PL310 errata: Clean & Invalidate maintenance operations do not invalidate clean lines" 959c0fe18baSRussell King help 960c0fe18baSRussell King The PL310 L2 cache controller implements three types of Clean & 961c0fe18baSRussell King Invalidate maintenance operations: by Physical Address 962c0fe18baSRussell King (offset 0x7F0), by Index/Way (0x7F8) and by Way (0x7FC). 963c0fe18baSRussell King They are architecturally defined to behave as the execution of a 964c0fe18baSRussell King clean operation followed immediately by an invalidate operation, 965c0fe18baSRussell King both performing to the same memory location. This functionality 96680d3cb91SShawn Guo is not correctly implemented in PL310 prior to r2p0 (fixed in r2p0) 96780d3cb91SShawn Guo as clean lines are not invalidated as a result of these operations. 968c0fe18baSRussell King 969c0fe18baSRussell Kingconfig PL310_ERRATA_727915 970c0fe18baSRussell King bool "PL310 errata: Background Clean & Invalidate by Way operation can cause data corruption" 971c0fe18baSRussell King help 972c0fe18baSRussell King PL310 implements the Clean & Invalidate by Way L2 cache maintenance 973c0fe18baSRussell King operation (offset 0x7FC). This operation runs in background so that 974c0fe18baSRussell King PL310 can handle normal accesses while it is in progress. Under very 975c0fe18baSRussell King rare circumstances, due to this erratum, write data can be lost when 976c0fe18baSRussell King PL310 treats a cacheable write transaction during a Clean & 97780d3cb91SShawn Guo Invalidate by Way operation. Revisions prior to r3p1 are affected by 97880d3cb91SShawn Guo this errata (fixed in r3p1). 979c0fe18baSRussell King 980c0fe18baSRussell Kingconfig PL310_ERRATA_753970 981c0fe18baSRussell King bool "PL310 errata: cache sync operation may be faulty" 982c0fe18baSRussell King help 983c0fe18baSRussell King This option enables the workaround for the 753970 PL310 (r3p0) erratum. 984c0fe18baSRussell King 985c0fe18baSRussell King Under some condition the effect of cache sync operation on 986c0fe18baSRussell King the store buffer still remains when the operation completes. 987c0fe18baSRussell King This means that the store buffer is always asked to drain and 988c0fe18baSRussell King this prevents it from merging any further writes. The workaround 989c0fe18baSRussell King is to replace the normal offset of cache sync operation (0x730) 990c0fe18baSRussell King by another offset targeting an unmapped PL310 register 0x740. 991c0fe18baSRussell King This has the same effect as the cache sync operation: store buffer 992c0fe18baSRussell King drain and waiting for all buffers empty. 993c0fe18baSRussell King 994c0fe18baSRussell Kingconfig PL310_ERRATA_769419 995c0fe18baSRussell King bool "PL310 errata: no automatic Store Buffer drain" 996c0fe18baSRussell King help 997c0fe18baSRussell King On revisions of the PL310 prior to r3p2, the Store Buffer does 998c0fe18baSRussell King not automatically drain. This can cause normal, non-cacheable 999c0fe18baSRussell King writes to be retained when the memory system is idle, leading 1000c0fe18baSRussell King to suboptimal I/O performance for drivers using coherent DMA. 1001c0fe18baSRussell King This option adds a write barrier to the cpu_idle loop so that, 1002c0fe18baSRussell King on systems with an outer cache, the store buffer is drained 1003c0fe18baSRussell King explicitly. 1004c0fe18baSRussell King 1005a641f3a6SRussell Kingendif 1006a641f3a6SRussell King 1007573a652fSLennert Buytenhekconfig CACHE_TAUROS2 1008573a652fSLennert Buytenhek bool "Enable the Tauros2 L2 cache controller" 10093f408fa0SHaojian Zhuang depends on (ARCH_DOVE || ARCH_MMP || CPU_PJ4) 1010573a652fSLennert Buytenhek default y 1011573a652fSLennert Buytenhek select OUTER_CACHE 1012573a652fSLennert Buytenhek help 1013573a652fSLennert Buytenhek This option enables the Tauros2 L2 cache controller (as 1014573a652fSLennert Buytenhek found on PJ1/PJ4). 1015573a652fSLennert Buytenhek 1016e7ecbc05SMasahiro Yamadaconfig CACHE_UNIPHIER 1017e7ecbc05SMasahiro Yamada bool "Enable the UniPhier outer cache controller" 1018e7ecbc05SMasahiro Yamada depends on ARCH_UNIPHIER 101901bf9278SMasahiro Yamada select ARM_L1_CACHE_SHIFT_7 1020e7ecbc05SMasahiro Yamada select OUTER_CACHE 1021e7ecbc05SMasahiro Yamada select OUTER_CACHE_SYNC 1022e7ecbc05SMasahiro Yamada help 1023e7ecbc05SMasahiro Yamada This option enables the UniPhier outer cache (system cache) 1024e7ecbc05SMasahiro Yamada controller. 1025e7ecbc05SMasahiro Yamada 1026905a09d5SEric Miaoconfig CACHE_XSC3L2 1027905a09d5SEric Miao bool "Enable the L2 cache on XScale3" 1028905a09d5SEric Miao depends on CPU_XSC3 1029905a09d5SEric Miao default y 1030905a09d5SEric Miao select OUTER_CACHE 1031905a09d5SEric Miao help 1032905a09d5SEric Miao This option enables the L2 cache on XScale3. 1033910a17e5SKirill A. Shutemov 10345637a126SRussell Kingconfig ARM_L1_CACHE_SHIFT_6 10355637a126SRussell King bool 1036a092f2b1SWill Deacon default y if CPU_V7 10375637a126SRussell King help 10385637a126SRussell King Setting ARM L1 cache line size to 64 Bytes. 10395637a126SRussell King 104001bf9278SMasahiro Yamadaconfig ARM_L1_CACHE_SHIFT_7 104101bf9278SMasahiro Yamada bool 104201bf9278SMasahiro Yamada help 104301bf9278SMasahiro Yamada Setting ARM L1 cache line size to 128 Bytes. 104401bf9278SMasahiro Yamada 1045910a17e5SKirill A. Shutemovconfig ARM_L1_CACHE_SHIFT 1046910a17e5SKirill A. Shutemov int 104701bf9278SMasahiro Yamada default 7 if ARM_L1_CACHE_SHIFT_7 1048d6d502faSKukjin Kim default 6 if ARM_L1_CACHE_SHIFT_6 1049910a17e5SKirill A. Shutemov default 5 105047ab0deeSRussell King 105147ab0deeSRussell Kingconfig ARM_DMA_MEM_BUFFERABLE 1052e399b1a4SRussell King bool "Use non-cacheable memory for DMA" if (CPU_V6 || CPU_V6K) && !CPU_V7 1053e399b1a4SRussell King default y if CPU_V6 || CPU_V6K || CPU_V7 105447ab0deeSRussell King help 105547ab0deeSRussell King Historically, the kernel has used strongly ordered mappings to 105647ab0deeSRussell King provide DMA coherent memory. With the advent of ARMv7, mapping 105747ab0deeSRussell King memory with differing types results in unpredictable behaviour, 105847ab0deeSRussell King so on these CPUs, this option is forced on. 105947ab0deeSRussell King 106047ab0deeSRussell King Multiple mappings with differing attributes is also unpredictable 106147ab0deeSRussell King on ARMv6 CPUs, but since they do not have aggressive speculative 106247ab0deeSRussell King prefetch, no harm appears to occur. 106347ab0deeSRussell King 106447ab0deeSRussell King However, drivers may be missing the necessary barriers for ARMv6, 106547ab0deeSRussell King and therefore turning this on may result in unpredictable driver 106647ab0deeSRussell King behaviour. Therefore, we offer this as an option. 106747ab0deeSRussell King 106847ab0deeSRussell King You are recommended say 'Y' here and debug any affected drivers. 1069ac1d426eSRussell King 1070f8130906SRussell Kingconfig ARM_HEAVY_MB 1071f8130906SRussell King bool 1072f8130906SRussell King 1073d10d2d48SBen Dooksconfig ARCH_SUPPORTS_BIG_ENDIAN 1074d10d2d48SBen Dooks bool 1075d10d2d48SBen Dooks help 1076d10d2d48SBen Dooks This option specifies the architecture can support big endian 1077d10d2d48SBen Dooks operation. 10781e6b4811SKees Cook 107925362dc4SKees Cookconfig DEBUG_ALIGN_RODATA 108025362dc4SKees Cook bool "Make rodata strictly non-executable" 10810f5bf6d0SLaura Abbott depends on STRICT_KERNEL_RWX 108280d6b0c2SKees Cook default y 108380d6b0c2SKees Cook help 108425362dc4SKees Cook If this is set, rodata will be made explicitly non-executable. This 108525362dc4SKees Cook provides protection on the rare chance that attackers might find and 108625362dc4SKees Cook use ROP gadgets that exist in the rodata section. This adds an 108725362dc4SKees Cook additional section-aligned split of rodata from kernel text so it 108825362dc4SKees Cook can be made explicitly non-executable. This padding may waste memory 108925362dc4SKees Cook space to gain the additional protection. 1090