11da177e4SLinus Torvaldscomment "Processor Type" 21da177e4SLinus Torvalds 31da177e4SLinus Torvaldsconfig CPU_32 41da177e4SLinus Torvalds bool 51da177e4SLinus Torvalds default y 61da177e4SLinus Torvalds 71da177e4SLinus Torvalds# Select CPU types depending on the architecture selected. This selects 81da177e4SLinus Torvalds# which CPUs we support in the kernel image, and the compiler instruction 91da177e4SLinus Torvalds# optimiser behaviour. 101da177e4SLinus Torvalds 111da177e4SLinus Torvalds# ARM610 121da177e4SLinus Torvaldsconfig CPU_ARM610 131da177e4SLinus Torvalds bool "Support ARM610 processor" 141da177e4SLinus Torvalds depends on ARCH_RPC 151da177e4SLinus Torvalds select CPU_32v3 161da177e4SLinus Torvalds select CPU_CACHE_V3 171da177e4SLinus Torvalds select CPU_CACHE_VIVT 18fefdaa06SHyok S. Choi select CPU_CP15_MMU 19f9c21a6eSHyok S. Choi select CPU_COPY_V3 if MMU 20f9c21a6eSHyok S. Choi select CPU_TLB_V3 if MMU 2148d7927bSPaul Brook select CPU_PABRT_NOIFAR 221da177e4SLinus Torvalds help 231da177e4SLinus Torvalds The ARM610 is the successor to the ARM3 processor 241da177e4SLinus Torvalds and was produced by VLSI Technology Inc. 251da177e4SLinus Torvalds 261da177e4SLinus Torvalds Say Y if you want support for the ARM610 processor. 271da177e4SLinus Torvalds Otherwise, say N. 281da177e4SLinus Torvalds 2907e0da78SHyok S. Choi# ARM7TDMI 3007e0da78SHyok S. Choiconfig CPU_ARM7TDMI 3107e0da78SHyok S. Choi bool "Support ARM7TDMI processor" 326b237a35SRussell King depends on !MMU 3307e0da78SHyok S. Choi select CPU_32v4T 3407e0da78SHyok S. Choi select CPU_ABRT_LV4T 3507e0da78SHyok S. Choi select CPU_CACHE_V4 3607e0da78SHyok S. Choi help 3707e0da78SHyok S. Choi A 32-bit RISC microprocessor based on the ARM7 processor core 3807e0da78SHyok S. Choi which has no memory control unit and cache. 3907e0da78SHyok S. Choi 4007e0da78SHyok S. Choi Say Y if you want support for the ARM7TDMI processor. 4107e0da78SHyok S. Choi Otherwise, say N. 4207e0da78SHyok S. Choi 431da177e4SLinus Torvalds# ARM710 441da177e4SLinus Torvaldsconfig CPU_ARM710 451da177e4SLinus Torvalds bool "Support ARM710 processor" if !ARCH_CLPS7500 && ARCH_RPC 461da177e4SLinus Torvalds default y if ARCH_CLPS7500 471da177e4SLinus Torvalds select CPU_32v3 481da177e4SLinus Torvalds select CPU_CACHE_V3 491da177e4SLinus Torvalds select CPU_CACHE_VIVT 50fefdaa06SHyok S. Choi select CPU_CP15_MMU 51f9c21a6eSHyok S. Choi select CPU_COPY_V3 if MMU 52f9c21a6eSHyok S. Choi select CPU_TLB_V3 if MMU 5348d7927bSPaul Brook select CPU_PABRT_NOIFAR 541da177e4SLinus Torvalds help 551da177e4SLinus Torvalds A 32-bit RISC microprocessor based on the ARM7 processor core 561da177e4SLinus Torvalds designed by Advanced RISC Machines Ltd. The ARM710 is the 571da177e4SLinus Torvalds successor to the ARM610 processor. It was released in 581da177e4SLinus Torvalds July 1994 by VLSI Technology Inc. 591da177e4SLinus Torvalds 601da177e4SLinus Torvalds Say Y if you want support for the ARM710 processor. 611da177e4SLinus Torvalds Otherwise, say N. 621da177e4SLinus Torvalds 631da177e4SLinus Torvalds# ARM720T 641da177e4SLinus Torvaldsconfig CPU_ARM720T 651da177e4SLinus Torvalds bool "Support ARM720T processor" if !ARCH_CLPS711X && !ARCH_L7200 && !ARCH_CDB89712 && ARCH_INTEGRATOR 661da177e4SLinus Torvalds default y if ARCH_CLPS711X || ARCH_L7200 || ARCH_CDB89712 || ARCH_H720X 67260e98edSLennert Buytenhek select CPU_32v4T 681da177e4SLinus Torvalds select CPU_ABRT_LV4T 6948d7927bSPaul Brook select CPU_PABRT_NOIFAR 701da177e4SLinus Torvalds select CPU_CACHE_V4 711da177e4SLinus Torvalds select CPU_CACHE_VIVT 72fefdaa06SHyok S. Choi select CPU_CP15_MMU 73f9c21a6eSHyok S. Choi select CPU_COPY_V4WT if MMU 74f9c21a6eSHyok S. Choi select CPU_TLB_V4WT if MMU 751da177e4SLinus Torvalds help 761da177e4SLinus Torvalds A 32-bit RISC processor with 8kByte Cache, Write Buffer and 771da177e4SLinus Torvalds MMU built around an ARM7TDMI core. 781da177e4SLinus Torvalds 791da177e4SLinus Torvalds Say Y if you want support for the ARM720T processor. 801da177e4SLinus Torvalds Otherwise, say N. 811da177e4SLinus Torvalds 82b731c311SHyok S. Choi# ARM740T 83b731c311SHyok S. Choiconfig CPU_ARM740T 84b731c311SHyok S. Choi bool "Support ARM740T processor" if ARCH_INTEGRATOR 856b237a35SRussell King depends on !MMU 86b731c311SHyok S. Choi select CPU_32v4T 87b731c311SHyok S. Choi select CPU_ABRT_LV4T 88b731c311SHyok S. Choi select CPU_CACHE_V3 # although the core is v4t 89b731c311SHyok S. Choi select CPU_CP15_MPU 90b731c311SHyok S. Choi help 91b731c311SHyok S. Choi A 32-bit RISC processor with 8KB cache or 4KB variants, 92b731c311SHyok S. Choi write buffer and MPU(Protection Unit) built around 93b731c311SHyok S. Choi an ARM7TDMI core. 94b731c311SHyok S. Choi 95b731c311SHyok S. Choi Say Y if you want support for the ARM740T processor. 96b731c311SHyok S. Choi Otherwise, say N. 97b731c311SHyok S. Choi 9843f5f014SHyok S. Choi# ARM9TDMI 9943f5f014SHyok S. Choiconfig CPU_ARM9TDMI 10043f5f014SHyok S. Choi bool "Support ARM9TDMI processor" 1016b237a35SRussell King depends on !MMU 10243f5f014SHyok S. Choi select CPU_32v4T 1030f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 10443f5f014SHyok S. Choi select CPU_CACHE_V4 10543f5f014SHyok S. Choi help 10643f5f014SHyok S. Choi A 32-bit RISC microprocessor based on the ARM9 processor core 10743f5f014SHyok S. Choi which has no memory control unit and cache. 10843f5f014SHyok S. Choi 10943f5f014SHyok S. Choi Say Y if you want support for the ARM9TDMI processor. 11043f5f014SHyok S. Choi Otherwise, say N. 11143f5f014SHyok S. Choi 1121da177e4SLinus Torvalds# ARM920T 1131da177e4SLinus Torvaldsconfig CPU_ARM920T 1143434d9d9SBen Dooks bool "Support ARM920T processor" 1153434d9d9SBen Dooks depends on ARCH_EP93XX || ARCH_INTEGRATOR || CPU_S3C2410 || CPU_S3C2440 || CPU_S3C2442 || ARCH_IMX || ARCH_AAEC2000 || ARCH_AT91RM9200 1163434d9d9SBen Dooks default y if CPU_S3C2410 || CPU_S3C2440 || CPU_S3C2442 || ARCH_AT91RM9200 117260e98edSLennert Buytenhek select CPU_32v4T 1181da177e4SLinus Torvalds select CPU_ABRT_EV4T 11948d7927bSPaul Brook select CPU_PABRT_NOIFAR 1201da177e4SLinus Torvalds select CPU_CACHE_V4WT 1211da177e4SLinus Torvalds select CPU_CACHE_VIVT 122fefdaa06SHyok S. Choi select CPU_CP15_MMU 123f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 124f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1251da177e4SLinus Torvalds help 1261da177e4SLinus Torvalds The ARM920T is licensed to be produced by numerous vendors, 1271da177e4SLinus Torvalds and is used in the Maverick EP9312 and the Samsung S3C2410. 1281da177e4SLinus Torvalds 1291da177e4SLinus Torvalds More information on the Maverick EP9312 at 1301da177e4SLinus Torvalds <http://linuxdevices.com/products/PD2382866068.html>. 1311da177e4SLinus Torvalds 1321da177e4SLinus Torvalds Say Y if you want support for the ARM920T processor. 1331da177e4SLinus Torvalds Otherwise, say N. 1341da177e4SLinus Torvalds 1351da177e4SLinus Torvalds# ARM922T 1361da177e4SLinus Torvaldsconfig CPU_ARM922T 1371da177e4SLinus Torvalds bool "Support ARM922T processor" if ARCH_INTEGRATOR 138c53c9cf6SAndrew Victor depends on ARCH_LH7A40X || ARCH_INTEGRATOR || ARCH_KS8695 139c53c9cf6SAndrew Victor default y if ARCH_LH7A40X || ARCH_KS8695 140260e98edSLennert Buytenhek select CPU_32v4T 1411da177e4SLinus Torvalds select CPU_ABRT_EV4T 14248d7927bSPaul Brook select CPU_PABRT_NOIFAR 1431da177e4SLinus Torvalds select CPU_CACHE_V4WT 1441da177e4SLinus Torvalds select CPU_CACHE_VIVT 145fefdaa06SHyok S. Choi select CPU_CP15_MMU 146f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 147f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1481da177e4SLinus Torvalds help 1491da177e4SLinus Torvalds The ARM922T is a version of the ARM920T, but with smaller 1501da177e4SLinus Torvalds instruction and data caches. It is used in Altera's 151c53c9cf6SAndrew Victor Excalibur XA device family and Micrel's KS8695 Centaur. 1521da177e4SLinus Torvalds 1531da177e4SLinus Torvalds Say Y if you want support for the ARM922T processor. 1541da177e4SLinus Torvalds Otherwise, say N. 1551da177e4SLinus Torvalds 1561da177e4SLinus Torvalds# ARM925T 1571da177e4SLinus Torvaldsconfig CPU_ARM925T 158b288f75fSTony Lindgren bool "Support ARM925T processor" if ARCH_OMAP1 1593179a019STony Lindgren depends on ARCH_OMAP15XX 1603179a019STony Lindgren default y if ARCH_OMAP15XX 161260e98edSLennert Buytenhek select CPU_32v4T 1621da177e4SLinus Torvalds select CPU_ABRT_EV4T 16348d7927bSPaul Brook select CPU_PABRT_NOIFAR 1641da177e4SLinus Torvalds select CPU_CACHE_V4WT 1651da177e4SLinus Torvalds select CPU_CACHE_VIVT 166fefdaa06SHyok S. Choi select CPU_CP15_MMU 167f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 168f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1691da177e4SLinus Torvalds help 1701da177e4SLinus Torvalds The ARM925T is a mix between the ARM920T and ARM926T, but with 1711da177e4SLinus Torvalds different instruction and data caches. It is used in TI's OMAP 1721da177e4SLinus Torvalds device family. 1731da177e4SLinus Torvalds 1741da177e4SLinus Torvalds Say Y if you want support for the ARM925T processor. 1751da177e4SLinus Torvalds Otherwise, say N. 1761da177e4SLinus Torvalds 1771da177e4SLinus Torvalds# ARM926T 1781da177e4SLinus Torvaldsconfig CPU_ARM926T 1798ad68bbfSCatalin Marinas bool "Support ARM926T processor" 1802b3b3516SAndrew Victor depends on ARCH_INTEGRATOR || ARCH_VERSATILE_PB || MACH_VERSATILE_AB || ARCH_OMAP730 || ARCH_OMAP16XX || MACH_REALVIEW_EB || ARCH_PNX4008 || ARCH_NETX || CPU_S3C2412 || ARCH_AT91SAM9260 || ARCH_AT91SAM9261 || ARCH_AT91SAM9263 || ARCH_AT91SAM9RL || ARCH_AT91CAP9 || ARCH_NS9XXX || ARCH_DAVINCI 1812b3b3516SAndrew Victor default y if ARCH_VERSATILE_PB || MACH_VERSATILE_AB || ARCH_OMAP730 || ARCH_OMAP16XX || ARCH_PNX4008 || ARCH_NETX || CPU_S3C2412 || ARCH_AT91SAM9260 || ARCH_AT91SAM9261 || ARCH_AT91SAM9263 || ARCH_AT91SAM9RL || ARCH_AT91CAP9 || ARCH_NS9XXX || ARCH_DAVINCI 1821da177e4SLinus Torvalds select CPU_32v5 1831da177e4SLinus Torvalds select CPU_ABRT_EV5TJ 18448d7927bSPaul Brook select CPU_PABRT_NOIFAR 1851da177e4SLinus Torvalds select CPU_CACHE_VIVT 186fefdaa06SHyok S. Choi select CPU_CP15_MMU 187f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 188f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 1891da177e4SLinus Torvalds help 1901da177e4SLinus Torvalds This is a variant of the ARM920. It has slightly different 1911da177e4SLinus Torvalds instruction sequences for cache and TLB operations. Curiously, 1921da177e4SLinus Torvalds there is no documentation on it at the ARM corporate website. 1931da177e4SLinus Torvalds 1941da177e4SLinus Torvalds Say Y if you want support for the ARM926T processor. 1951da177e4SLinus Torvalds Otherwise, say N. 1961da177e4SLinus Torvalds 197d60674ebSHyok S. Choi# ARM940T 198d60674ebSHyok S. Choiconfig CPU_ARM940T 199d60674ebSHyok S. Choi bool "Support ARM940T processor" if ARCH_INTEGRATOR 2006b237a35SRussell King depends on !MMU 201d60674ebSHyok S. Choi select CPU_32v4T 2020f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 203d60674ebSHyok S. Choi select CPU_CACHE_VIVT 204d60674ebSHyok S. Choi select CPU_CP15_MPU 205d60674ebSHyok S. Choi help 206d60674ebSHyok S. Choi ARM940T is a member of the ARM9TDMI family of general- 2073cb2fcccSMatt LaPlante purpose microprocessors with MPU and separate 4KB 208d60674ebSHyok S. Choi instruction and 4KB data cases, each with a 4-word line 209d60674ebSHyok S. Choi length. 210d60674ebSHyok S. Choi 211d60674ebSHyok S. Choi Say Y if you want support for the ARM940T processor. 212d60674ebSHyok S. Choi Otherwise, say N. 213d60674ebSHyok S. Choi 214f37f46ebSHyok S. Choi# ARM946E-S 215f37f46ebSHyok S. Choiconfig CPU_ARM946E 216f37f46ebSHyok S. Choi bool "Support ARM946E-S processor" if ARCH_INTEGRATOR 2176b237a35SRussell King depends on !MMU 218f37f46ebSHyok S. Choi select CPU_32v5 2190f45d7f3SHyok S. Choi select CPU_ABRT_NOMMU 220f37f46ebSHyok S. Choi select CPU_CACHE_VIVT 221f37f46ebSHyok S. Choi select CPU_CP15_MPU 222f37f46ebSHyok S. Choi help 223f37f46ebSHyok S. Choi ARM946E-S is a member of the ARM9E-S family of high- 224f37f46ebSHyok S. Choi performance, 32-bit system-on-chip processor solutions. 225f37f46ebSHyok S. Choi The TCM and ARMv5TE 32-bit instruction set is supported. 226f37f46ebSHyok S. Choi 227f37f46ebSHyok S. Choi Say Y if you want support for the ARM946E-S processor. 228f37f46ebSHyok S. Choi Otherwise, say N. 229f37f46ebSHyok S. Choi 2301da177e4SLinus Torvalds# ARM1020 - needs validating 2311da177e4SLinus Torvaldsconfig CPU_ARM1020 2321da177e4SLinus Torvalds bool "Support ARM1020T (rev 0) processor" 2331da177e4SLinus Torvalds depends on ARCH_INTEGRATOR 2341da177e4SLinus Torvalds select CPU_32v5 2351da177e4SLinus Torvalds select CPU_ABRT_EV4T 23648d7927bSPaul Brook select CPU_PABRT_NOIFAR 2371da177e4SLinus Torvalds select CPU_CACHE_V4WT 2381da177e4SLinus Torvalds select CPU_CACHE_VIVT 239fefdaa06SHyok S. Choi select CPU_CP15_MMU 240f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 241f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2421da177e4SLinus Torvalds help 2431da177e4SLinus Torvalds The ARM1020 is the 32K cached version of the ARM10 processor, 2441da177e4SLinus Torvalds with an addition of a floating-point unit. 2451da177e4SLinus Torvalds 2461da177e4SLinus Torvalds Say Y if you want support for the ARM1020 processor. 2471da177e4SLinus Torvalds Otherwise, say N. 2481da177e4SLinus Torvalds 2491da177e4SLinus Torvalds# ARM1020E - needs validating 2501da177e4SLinus Torvaldsconfig CPU_ARM1020E 2511da177e4SLinus Torvalds bool "Support ARM1020E processor" 2521da177e4SLinus Torvalds depends on ARCH_INTEGRATOR 2531da177e4SLinus Torvalds select CPU_32v5 2541da177e4SLinus Torvalds select CPU_ABRT_EV4T 25548d7927bSPaul Brook select CPU_PABRT_NOIFAR 2561da177e4SLinus Torvalds select CPU_CACHE_V4WT 2571da177e4SLinus Torvalds select CPU_CACHE_VIVT 258fefdaa06SHyok S. Choi select CPU_CP15_MMU 259f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 260f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2611da177e4SLinus Torvalds depends on n 2621da177e4SLinus Torvalds 2631da177e4SLinus Torvalds# ARM1022E 2641da177e4SLinus Torvaldsconfig CPU_ARM1022 2651da177e4SLinus Torvalds bool "Support ARM1022E processor" 2661da177e4SLinus Torvalds depends on ARCH_INTEGRATOR 2671da177e4SLinus Torvalds select CPU_32v5 2681da177e4SLinus Torvalds select CPU_ABRT_EV4T 26948d7927bSPaul Brook select CPU_PABRT_NOIFAR 2701da177e4SLinus Torvalds select CPU_CACHE_VIVT 271fefdaa06SHyok S. Choi select CPU_CP15_MMU 272f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU # can probably do better 273f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2741da177e4SLinus Torvalds help 2751da177e4SLinus Torvalds The ARM1022E is an implementation of the ARMv5TE architecture 2761da177e4SLinus Torvalds based upon the ARM10 integer core with a 16KiB L1 Harvard cache, 2771da177e4SLinus Torvalds embedded trace macrocell, and a floating-point unit. 2781da177e4SLinus Torvalds 2791da177e4SLinus Torvalds Say Y if you want support for the ARM1022E processor. 2801da177e4SLinus Torvalds Otherwise, say N. 2811da177e4SLinus Torvalds 2821da177e4SLinus Torvalds# ARM1026EJ-S 2831da177e4SLinus Torvaldsconfig CPU_ARM1026 2841da177e4SLinus Torvalds bool "Support ARM1026EJ-S processor" 2851da177e4SLinus Torvalds depends on ARCH_INTEGRATOR 2861da177e4SLinus Torvalds select CPU_32v5 2871da177e4SLinus Torvalds select CPU_ABRT_EV5T # But need Jazelle, but EV5TJ ignores bit 10 28848d7927bSPaul Brook select CPU_PABRT_NOIFAR 2891da177e4SLinus Torvalds select CPU_CACHE_VIVT 290fefdaa06SHyok S. Choi select CPU_CP15_MMU 291f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU # can probably do better 292f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 2931da177e4SLinus Torvalds help 2941da177e4SLinus Torvalds The ARM1026EJ-S is an implementation of the ARMv5TEJ architecture 2951da177e4SLinus Torvalds based upon the ARM10 integer core. 2961da177e4SLinus Torvalds 2971da177e4SLinus Torvalds Say Y if you want support for the ARM1026EJ-S processor. 2981da177e4SLinus Torvalds Otherwise, say N. 2991da177e4SLinus Torvalds 3001da177e4SLinus Torvalds# SA110 3011da177e4SLinus Torvaldsconfig CPU_SA110 3021da177e4SLinus Torvalds bool "Support StrongARM(R) SA-110 processor" if !ARCH_EBSA110 && !FOOTBRIDGE && !ARCH_TBOX && !ARCH_SHARK && !ARCH_NEXUSPCI && ARCH_RPC 3031da177e4SLinus Torvalds default y if ARCH_EBSA110 || FOOTBRIDGE || ARCH_TBOX || ARCH_SHARK || ARCH_NEXUSPCI 3041da177e4SLinus Torvalds select CPU_32v3 if ARCH_RPC 3051da177e4SLinus Torvalds select CPU_32v4 if !ARCH_RPC 3061da177e4SLinus Torvalds select CPU_ABRT_EV4 30748d7927bSPaul Brook select CPU_PABRT_NOIFAR 3081da177e4SLinus Torvalds select CPU_CACHE_V4WB 3091da177e4SLinus Torvalds select CPU_CACHE_VIVT 310fefdaa06SHyok S. Choi select CPU_CP15_MMU 311f9c21a6eSHyok S. Choi select CPU_COPY_V4WB if MMU 312f9c21a6eSHyok S. Choi select CPU_TLB_V4WB if MMU 3131da177e4SLinus Torvalds help 3141da177e4SLinus Torvalds The Intel StrongARM(R) SA-110 is a 32-bit microprocessor and 3151da177e4SLinus Torvalds is available at five speeds ranging from 100 MHz to 233 MHz. 3161da177e4SLinus Torvalds More information is available at 3171da177e4SLinus Torvalds <http://developer.intel.com/design/strong/sa110.htm>. 3181da177e4SLinus Torvalds 3191da177e4SLinus Torvalds Say Y if you want support for the SA-110 processor. 3201da177e4SLinus Torvalds Otherwise, say N. 3211da177e4SLinus Torvalds 3221da177e4SLinus Torvalds# SA1100 3231da177e4SLinus Torvaldsconfig CPU_SA1100 3241da177e4SLinus Torvalds bool 3251da177e4SLinus Torvalds depends on ARCH_SA1100 3261da177e4SLinus Torvalds default y 3271da177e4SLinus Torvalds select CPU_32v4 3281da177e4SLinus Torvalds select CPU_ABRT_EV4 32948d7927bSPaul Brook select CPU_PABRT_NOIFAR 3301da177e4SLinus Torvalds select CPU_CACHE_V4WB 3311da177e4SLinus Torvalds select CPU_CACHE_VIVT 332fefdaa06SHyok S. Choi select CPU_CP15_MMU 333f9c21a6eSHyok S. Choi select CPU_TLB_V4WB if MMU 3341da177e4SLinus Torvalds 3351da177e4SLinus Torvalds# XScale 3361da177e4SLinus Torvaldsconfig CPU_XSCALE 3371da177e4SLinus Torvalds bool 338fa0b6251SRussell King depends on ARCH_IOP32X || ARCH_IOP33X || PXA25x || PXA27x || ARCH_IXP4XX || ARCH_IXP2000 3391da177e4SLinus Torvalds default y 3401da177e4SLinus Torvalds select CPU_32v5 3411da177e4SLinus Torvalds select CPU_ABRT_EV5T 34248d7927bSPaul Brook select CPU_PABRT_NOIFAR 3431da177e4SLinus Torvalds select CPU_CACHE_VIVT 344fefdaa06SHyok S. Choi select CPU_CP15_MMU 345f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 3461da177e4SLinus Torvalds 34723bdf86aSLennert Buytenhek# XScale Core Version 3 34823bdf86aSLennert Buytenhekconfig CPU_XSC3 34923bdf86aSLennert Buytenhek bool 3502c8086a5Seric miao depends on ARCH_IXP23XX || ARCH_IOP13XX || PXA3xx 35123bdf86aSLennert Buytenhek default y 35223bdf86aSLennert Buytenhek select CPU_32v5 35323bdf86aSLennert Buytenhek select CPU_ABRT_EV5T 35423bdf86aSLennert Buytenhek select CPU_CACHE_VIVT 355fefdaa06SHyok S. Choi select CPU_CP15_MMU 356f9c21a6eSHyok S. Choi select CPU_TLB_V4WBI if MMU 35723bdf86aSLennert Buytenhek select IO_36 35823bdf86aSLennert Buytenhek 359e50d6409SAssaf Hoffman# Feroceon 360e50d6409SAssaf Hoffmanconfig CPU_FEROCEON 361e50d6409SAssaf Hoffman bool 362e50d6409SAssaf Hoffman depends on ARCH_ORION 363e50d6409SAssaf Hoffman default y 364e50d6409SAssaf Hoffman select CPU_32v5 365e50d6409SAssaf Hoffman select CPU_ABRT_EV5T 36648d7927bSPaul Brook select CPU_PABRT_NOIFAR 367e50d6409SAssaf Hoffman select CPU_CACHE_VIVT 368e50d6409SAssaf Hoffman select CPU_CP15_MMU 369e50d6409SAssaf Hoffman select CPU_COPY_V4WB if MMU 370e50d6409SAssaf Hoffman select CPU_TLB_V4WBI if MMU 371e50d6409SAssaf Hoffman 372d910a0aaSTzachi Perelsteinconfig CPU_FEROCEON_OLD_ID 373d910a0aaSTzachi Perelstein bool "Accept early Feroceon cores with an ARM926 ID" 374d910a0aaSTzachi Perelstein depends on CPU_FEROCEON && !CPU_ARM926T 375d910a0aaSTzachi Perelstein default y 376d910a0aaSTzachi Perelstein help 377d910a0aaSTzachi Perelstein This enables the usage of some old Feroceon cores 378d910a0aaSTzachi Perelstein for which the CPU ID is equal to the ARM926 ID. 379d910a0aaSTzachi Perelstein Relevant for Feroceon-1850 and early Feroceon-2850. 380d910a0aaSTzachi Perelstein 3811da177e4SLinus Torvalds# ARMv6 3821da177e4SLinus Torvaldsconfig CPU_V6 3831da177e4SLinus Torvalds bool "Support ARM V6 processor" 384bc02c58bSBahadir Balban depends on ARCH_INTEGRATOR || MACH_REALVIEW_EB || ARCH_OMAP2 || ARCH_MX3 || ARCH_MSM7X00A || MACH_REALVIEW_PB11MP || MACH_REALVIEW_PB1176 38552c543f9SQuinn Jensen default y if ARCH_MX3 3863042102aSBrian Swetland default y if ARCH_MSM7X00A 3871da177e4SLinus Torvalds select CPU_32v6 3881da177e4SLinus Torvalds select CPU_ABRT_EV6 38948d7927bSPaul Brook select CPU_PABRT_NOIFAR 3901da177e4SLinus Torvalds select CPU_CACHE_V6 3911da177e4SLinus Torvalds select CPU_CACHE_VIPT 392fefdaa06SHyok S. Choi select CPU_CP15_MMU 3937b4c965aSCatalin Marinas select CPU_HAS_ASID if MMU 394f9c21a6eSHyok S. Choi select CPU_COPY_V6 if MMU 395f9c21a6eSHyok S. Choi select CPU_TLB_V6 if MMU 3961da177e4SLinus Torvalds 3974a5f79e7SRussell King# ARMv6k 3984a5f79e7SRussell Kingconfig CPU_32v6K 3994a5f79e7SRussell King bool "Support ARM V6K processor extensions" if !SMP 4004a5f79e7SRussell King depends on CPU_V6 40152c543f9SQuinn Jensen default y if SMP && !ARCH_MX3 4024a5f79e7SRussell King help 4034a5f79e7SRussell King Say Y here if your ARMv6 processor supports the 'K' extension. 4044a5f79e7SRussell King This enables the kernel to use some instructions not present 4054a5f79e7SRussell King on previous processors, and as such a kernel build with this 4064a5f79e7SRussell King enabled will not boot on processors with do not support these 4074a5f79e7SRussell King instructions. 4084a5f79e7SRussell King 40923688e99SCatalin Marinas# ARMv7 41023688e99SCatalin Marinasconfig CPU_V7 41123688e99SCatalin Marinas bool "Support ARM V7 processor" 41241267e20SCatalin Marinas depends on ARCH_INTEGRATOR || MACH_REALVIEW_EB 41323688e99SCatalin Marinas select CPU_32v6K 41423688e99SCatalin Marinas select CPU_32v7 41523688e99SCatalin Marinas select CPU_ABRT_EV7 41648d7927bSPaul Brook select CPU_PABRT_IFAR 41723688e99SCatalin Marinas select CPU_CACHE_V7 41823688e99SCatalin Marinas select CPU_CACHE_VIPT 41923688e99SCatalin Marinas select CPU_CP15_MMU 4202eb8c82bSCatalin Marinas select CPU_HAS_ASID if MMU 42123688e99SCatalin Marinas select CPU_COPY_V6 if MMU 4222ccdd1e7SCatalin Marinas select CPU_TLB_V7 if MMU 42323688e99SCatalin Marinas 4241da177e4SLinus Torvalds# Figure out what processor architecture version we should be using. 4251da177e4SLinus Torvalds# This defines the compiler instruction set which depends on the machine type. 4261da177e4SLinus Torvaldsconfig CPU_32v3 4271da177e4SLinus Torvalds bool 42860b6cf68SRussell King select TLS_REG_EMUL if SMP || !MMU 42948fa14f7SRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 4301da177e4SLinus Torvalds 4311da177e4SLinus Torvaldsconfig CPU_32v4 4321da177e4SLinus Torvalds bool 43360b6cf68SRussell King select TLS_REG_EMUL if SMP || !MMU 43448fa14f7SRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 4351da177e4SLinus Torvalds 436260e98edSLennert Buytenhekconfig CPU_32v4T 437260e98edSLennert Buytenhek bool 438260e98edSLennert Buytenhek select TLS_REG_EMUL if SMP || !MMU 439260e98edSLennert Buytenhek select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 440260e98edSLennert Buytenhek 4411da177e4SLinus Torvaldsconfig CPU_32v5 4421da177e4SLinus Torvalds bool 44360b6cf68SRussell King select TLS_REG_EMUL if SMP || !MMU 44448fa14f7SRussell King select NEEDS_SYSCALL_FOR_CMPXCHG if SMP 4451da177e4SLinus Torvalds 4461da177e4SLinus Torvaldsconfig CPU_32v6 4471da177e4SLinus Torvalds bool 448367afaf8SCatalin Marinas select TLS_REG_EMUL if !CPU_32v6K && !MMU 4491da177e4SLinus Torvalds 45023688e99SCatalin Marinasconfig CPU_32v7 45123688e99SCatalin Marinas bool 45223688e99SCatalin Marinas 4531da177e4SLinus Torvalds# The abort model 4540f45d7f3SHyok S. Choiconfig CPU_ABRT_NOMMU 4550f45d7f3SHyok S. Choi bool 4560f45d7f3SHyok S. Choi 4571da177e4SLinus Torvaldsconfig CPU_ABRT_EV4 4581da177e4SLinus Torvalds bool 4591da177e4SLinus Torvalds 4601da177e4SLinus Torvaldsconfig CPU_ABRT_EV4T 4611da177e4SLinus Torvalds bool 4621da177e4SLinus Torvalds 4631da177e4SLinus Torvaldsconfig CPU_ABRT_LV4T 4641da177e4SLinus Torvalds bool 4651da177e4SLinus Torvalds 4661da177e4SLinus Torvaldsconfig CPU_ABRT_EV5T 4671da177e4SLinus Torvalds bool 4681da177e4SLinus Torvalds 4691da177e4SLinus Torvaldsconfig CPU_ABRT_EV5TJ 4701da177e4SLinus Torvalds bool 4711da177e4SLinus Torvalds 4721da177e4SLinus Torvaldsconfig CPU_ABRT_EV6 4731da177e4SLinus Torvalds bool 4741da177e4SLinus Torvalds 47523688e99SCatalin Marinasconfig CPU_ABRT_EV7 47623688e99SCatalin Marinas bool 47723688e99SCatalin Marinas 47848d7927bSPaul Brookconfig CPU_PABRT_IFAR 47948d7927bSPaul Brook bool 48048d7927bSPaul Brook 48148d7927bSPaul Brookconfig CPU_PABRT_NOIFAR 48248d7927bSPaul Brook bool 48348d7927bSPaul Brook 4841da177e4SLinus Torvalds# The cache model 4851da177e4SLinus Torvaldsconfig CPU_CACHE_V3 4861da177e4SLinus Torvalds bool 4871da177e4SLinus Torvalds 4881da177e4SLinus Torvaldsconfig CPU_CACHE_V4 4891da177e4SLinus Torvalds bool 4901da177e4SLinus Torvalds 4911da177e4SLinus Torvaldsconfig CPU_CACHE_V4WT 4921da177e4SLinus Torvalds bool 4931da177e4SLinus Torvalds 4941da177e4SLinus Torvaldsconfig CPU_CACHE_V4WB 4951da177e4SLinus Torvalds bool 4961da177e4SLinus Torvalds 4971da177e4SLinus Torvaldsconfig CPU_CACHE_V6 4981da177e4SLinus Torvalds bool 4991da177e4SLinus Torvalds 50023688e99SCatalin Marinasconfig CPU_CACHE_V7 50123688e99SCatalin Marinas bool 50223688e99SCatalin Marinas 5031da177e4SLinus Torvaldsconfig CPU_CACHE_VIVT 5041da177e4SLinus Torvalds bool 5051da177e4SLinus Torvalds 5061da177e4SLinus Torvaldsconfig CPU_CACHE_VIPT 5071da177e4SLinus Torvalds bool 5081da177e4SLinus Torvalds 509f9c21a6eSHyok S. Choiif MMU 5101da177e4SLinus Torvalds# The copy-page model 5111da177e4SLinus Torvaldsconfig CPU_COPY_V3 5121da177e4SLinus Torvalds bool 5131da177e4SLinus Torvalds 5141da177e4SLinus Torvaldsconfig CPU_COPY_V4WT 5151da177e4SLinus Torvalds bool 5161da177e4SLinus Torvalds 5171da177e4SLinus Torvaldsconfig CPU_COPY_V4WB 5181da177e4SLinus Torvalds bool 5191da177e4SLinus Torvalds 5201da177e4SLinus Torvaldsconfig CPU_COPY_V6 5211da177e4SLinus Torvalds bool 5221da177e4SLinus Torvalds 5231da177e4SLinus Torvalds# This selects the TLB model 5241da177e4SLinus Torvaldsconfig CPU_TLB_V3 5251da177e4SLinus Torvalds bool 5261da177e4SLinus Torvalds help 5271da177e4SLinus Torvalds ARM Architecture Version 3 TLB. 5281da177e4SLinus Torvalds 5291da177e4SLinus Torvaldsconfig CPU_TLB_V4WT 5301da177e4SLinus Torvalds bool 5311da177e4SLinus Torvalds help 5321da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writethrough cache. 5331da177e4SLinus Torvalds 5341da177e4SLinus Torvaldsconfig CPU_TLB_V4WB 5351da177e4SLinus Torvalds bool 5361da177e4SLinus Torvalds help 5371da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writeback cache. 5381da177e4SLinus Torvalds 5391da177e4SLinus Torvaldsconfig CPU_TLB_V4WBI 5401da177e4SLinus Torvalds bool 5411da177e4SLinus Torvalds help 5421da177e4SLinus Torvalds ARM Architecture Version 4 TLB with writeback cache and invalidate 5431da177e4SLinus Torvalds instruction cache entry. 5441da177e4SLinus Torvalds 5451da177e4SLinus Torvaldsconfig CPU_TLB_V6 5461da177e4SLinus Torvalds bool 5471da177e4SLinus Torvalds 5482ccdd1e7SCatalin Marinasconfig CPU_TLB_V7 5492ccdd1e7SCatalin Marinas bool 5502ccdd1e7SCatalin Marinas 551f9c21a6eSHyok S. Choiendif 552f9c21a6eSHyok S. Choi 553516793c6SRussell Kingconfig CPU_HAS_ASID 554516793c6SRussell King bool 555516793c6SRussell King help 556516793c6SRussell King This indicates whether the CPU has the ASID register; used to 557516793c6SRussell King tag TLB and possibly cache entries. 558516793c6SRussell King 559fefdaa06SHyok S. Choiconfig CPU_CP15 560fefdaa06SHyok S. Choi bool 561fefdaa06SHyok S. Choi help 562fefdaa06SHyok S. Choi Processor has the CP15 register. 563fefdaa06SHyok S. Choi 564fefdaa06SHyok S. Choiconfig CPU_CP15_MMU 565fefdaa06SHyok S. Choi bool 566fefdaa06SHyok S. Choi select CPU_CP15 567fefdaa06SHyok S. Choi help 568fefdaa06SHyok S. Choi Processor has the CP15 register, which has MMU related registers. 569fefdaa06SHyok S. Choi 570fefdaa06SHyok S. Choiconfig CPU_CP15_MPU 571fefdaa06SHyok S. Choi bool 572fefdaa06SHyok S. Choi select CPU_CP15 573fefdaa06SHyok S. Choi help 574fefdaa06SHyok S. Choi Processor has the CP15 register, which has MPU related registers. 575fefdaa06SHyok S. Choi 57623bdf86aSLennert Buytenhek# 57723bdf86aSLennert Buytenhek# CPU supports 36-bit I/O 57823bdf86aSLennert Buytenhek# 57923bdf86aSLennert Buytenhekconfig IO_36 58023bdf86aSLennert Buytenhek bool 58123bdf86aSLennert Buytenhek 5821da177e4SLinus Torvaldscomment "Processor Features" 5831da177e4SLinus Torvalds 5841da177e4SLinus Torvaldsconfig ARM_THUMB 5851da177e4SLinus Torvalds bool "Support Thumb user binaries" 586e50d6409SAssaf Hoffman depends on CPU_ARM720T || CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_ARM1020E || CPU_ARM1022 || CPU_ARM1026 || CPU_XSCALE || CPU_XSC3 || CPU_V6 || CPU_V7 || CPU_FEROCEON 5871da177e4SLinus Torvalds default y 5881da177e4SLinus Torvalds help 5891da177e4SLinus Torvalds Say Y if you want to include kernel support for running user space 5901da177e4SLinus Torvalds Thumb binaries. 5911da177e4SLinus Torvalds 5921da177e4SLinus Torvalds The Thumb instruction set is a compressed form of the standard ARM 5931da177e4SLinus Torvalds instruction set resulting in smaller binaries at the expense of 5941da177e4SLinus Torvalds slightly less efficient code. 5951da177e4SLinus Torvalds 5961da177e4SLinus Torvalds If you don't know what this all is, saying Y is a safe choice. 5971da177e4SLinus Torvalds 598d7f864beSCatalin Marinasconfig ARM_THUMBEE 599d7f864beSCatalin Marinas bool "Enable ThumbEE CPU extension" 600d7f864beSCatalin Marinas depends on CPU_V7 601d7f864beSCatalin Marinas help 602d7f864beSCatalin Marinas Say Y here if you have a CPU with the ThumbEE extension and code to 603d7f864beSCatalin Marinas make use of it. Say N for code that can run on CPUs without ThumbEE. 604d7f864beSCatalin Marinas 6051da177e4SLinus Torvaldsconfig CPU_BIG_ENDIAN 6061da177e4SLinus Torvalds bool "Build big-endian kernel" 6071da177e4SLinus Torvalds depends on ARCH_SUPPORTS_BIG_ENDIAN 6081da177e4SLinus Torvalds help 6091da177e4SLinus Torvalds Say Y if you plan on running a kernel in big-endian mode. 6101da177e4SLinus Torvalds Note that your board must be properly built and your board 6111da177e4SLinus Torvalds port must properly enable any big-endian related features 6121da177e4SLinus Torvalds of your chipset/board/processor. 6131da177e4SLinus Torvalds 6146afd6faeSHyok S. Choiconfig CPU_HIGH_VECTOR 6156340aa61SRobert P. J. Day depends on !MMU && CPU_CP15 && !CPU_ARM740T 6166afd6faeSHyok S. Choi bool "Select the High exception vector" 6176afd6faeSHyok S. Choi default n 6186afd6faeSHyok S. Choi help 6196afd6faeSHyok S. Choi Say Y here to select high exception vector(0xFFFF0000~). 6206afd6faeSHyok S. Choi The exception vector can be vary depending on the platform 6216afd6faeSHyok S. Choi design in nommu mode. If your platform needs to select 6226afd6faeSHyok S. Choi high exception vector, say Y. 6236afd6faeSHyok S. Choi Otherwise or if you are unsure, say N, and the low exception 6246afd6faeSHyok S. Choi vector (0x00000000~) will be used. 6256afd6faeSHyok S. Choi 6261da177e4SLinus Torvaldsconfig CPU_ICACHE_DISABLE 627f12d0d7cSHyok S. Choi bool "Disable I-Cache (I-bit)" 628f12d0d7cSHyok S. Choi depends on CPU_CP15 && !(CPU_ARM610 || CPU_ARM710 || CPU_ARM720T || CPU_ARM740T || CPU_XSCALE || CPU_XSC3) 6291da177e4SLinus Torvalds help 6301da177e4SLinus Torvalds Say Y here to disable the processor instruction cache. Unless 6311da177e4SLinus Torvalds you have a reason not to or are unsure, say N. 6321da177e4SLinus Torvalds 6331da177e4SLinus Torvaldsconfig CPU_DCACHE_DISABLE 634f12d0d7cSHyok S. Choi bool "Disable D-Cache (C-bit)" 635f12d0d7cSHyok S. Choi depends on CPU_CP15 6361da177e4SLinus Torvalds help 6371da177e4SLinus Torvalds Say Y here to disable the processor data cache. Unless 6381da177e4SLinus Torvalds you have a reason not to or are unsure, say N. 6391da177e4SLinus Torvalds 640f37f46ebSHyok S. Choiconfig CPU_DCACHE_SIZE 641f37f46ebSHyok S. Choi hex 642f37f46ebSHyok S. Choi depends on CPU_ARM740T || CPU_ARM946E 643f37f46ebSHyok S. Choi default 0x00001000 if CPU_ARM740T 644f37f46ebSHyok S. Choi default 0x00002000 # default size for ARM946E-S 645f37f46ebSHyok S. Choi help 646f37f46ebSHyok S. Choi Some cores are synthesizable to have various sized cache. For 647f37f46ebSHyok S. Choi ARM946E-S case, it can vary from 0KB to 1MB. 648f37f46ebSHyok S. Choi To support such cache operations, it is efficient to know the size 649f37f46ebSHyok S. Choi before compile time. 650f37f46ebSHyok S. Choi If your SoC is configured to have a different size, define the value 651f37f46ebSHyok S. Choi here with proper conditions. 652f37f46ebSHyok S. Choi 6531da177e4SLinus Torvaldsconfig CPU_DCACHE_WRITETHROUGH 6541da177e4SLinus Torvalds bool "Force write through D-cache" 655e50d6409SAssaf Hoffman depends on (CPU_ARM740T || CPU_ARM920T || CPU_ARM922T || CPU_ARM925T || CPU_ARM926T || CPU_ARM940T || CPU_ARM946E || CPU_ARM1020 || CPU_FEROCEON) && !CPU_DCACHE_DISABLE 6561da177e4SLinus Torvalds default y if CPU_ARM925T 6571da177e4SLinus Torvalds help 6581da177e4SLinus Torvalds Say Y here to use the data cache in writethrough mode. Unless you 6591da177e4SLinus Torvalds specifically require this or are unsure, say N. 6601da177e4SLinus Torvalds 6611da177e4SLinus Torvaldsconfig CPU_CACHE_ROUND_ROBIN 6621da177e4SLinus Torvalds bool "Round robin I and D cache replacement algorithm" 663f37f46ebSHyok S. Choi depends on (CPU_ARM926T || CPU_ARM946E || CPU_ARM1020) && (!CPU_ICACHE_DISABLE || !CPU_DCACHE_DISABLE) 6641da177e4SLinus Torvalds help 6651da177e4SLinus Torvalds Say Y here to use the predictable round-robin cache replacement 6661da177e4SLinus Torvalds policy. Unless you specifically require this or are unsure, say N. 6671da177e4SLinus Torvalds 6681da177e4SLinus Torvaldsconfig CPU_BPREDICT_DISABLE 6691da177e4SLinus Torvalds bool "Disable branch prediction" 67023688e99SCatalin Marinas depends on CPU_ARM1020 || CPU_V6 || CPU_XSC3 || CPU_V7 6711da177e4SLinus Torvalds help 6721da177e4SLinus Torvalds Say Y here to disable branch prediction. If unsure, say N. 6732d2669b6SNicolas Pitre 6744b0e07a5SNicolas Pitreconfig TLS_REG_EMUL 6754b0e07a5SNicolas Pitre bool 6764b0e07a5SNicolas Pitre help 67770489c88SNicolas Pitre An SMP system using a pre-ARMv6 processor (there are apparently 67870489c88SNicolas Pitre a few prototypes like that in existence) and therefore access to 67970489c88SNicolas Pitre that required register must be emulated. 6804b0e07a5SNicolas Pitre 6812d2669b6SNicolas Pitreconfig HAS_TLS_REG 6822d2669b6SNicolas Pitre bool 68370489c88SNicolas Pitre depends on !TLS_REG_EMUL 68470489c88SNicolas Pitre default y if SMP || CPU_32v7 6852d2669b6SNicolas Pitre help 6862d2669b6SNicolas Pitre This selects support for the CP15 thread register. 68770489c88SNicolas Pitre It is defined to be available on some ARMv6 processors (including 68870489c88SNicolas Pitre all SMP capable ARMv6's) or later processors. User space may 68970489c88SNicolas Pitre assume directly accessing that register and always obtain the 69070489c88SNicolas Pitre expected value only on ARMv7 and above. 6912d2669b6SNicolas Pitre 692dcef1f63SNicolas Pitreconfig NEEDS_SYSCALL_FOR_CMPXCHG 693dcef1f63SNicolas Pitre bool 694dcef1f63SNicolas Pitre help 695dcef1f63SNicolas Pitre SMP on a pre-ARMv6 processor? Well OK then. 696dcef1f63SNicolas Pitre Forget about fast user space cmpxchg support. 697dcef1f63SNicolas Pitre It is just not possible. 698dcef1f63SNicolas Pitre 699953233dcSCatalin Marinasconfig OUTER_CACHE 700953233dcSCatalin Marinas bool 701953233dcSCatalin Marinas default n 702382266adSCatalin Marinas 703382266adSCatalin Marinasconfig CACHE_L2X0 704*ba927951SCatalin Marinas bool "Enable the L2x0 outer cache controller" 705*ba927951SCatalin Marinas depends on REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || MACH_REALVIEW_PB1176 706*ba927951SCatalin Marinas default y 707382266adSCatalin Marinas select OUTER_CACHE 708*ba927951SCatalin Marinas help 709*ba927951SCatalin Marinas This option enables the L2x0 PrimeCell. 710