blob: 36c8b5e125909eec4693c524fea0dfacc459a0b7 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# For a description of the syntax of this configuration file,
3# see Documentation/kbuild/kconfig-language.txt.
4#
5
6mainmenu "Linux Kernel Configuration"
7
8config ARM
9 bool
10 default y
David Woodhousee17c6d52008-06-17 12:19:34 +010011 select HAVE_AOUT
Adrian Bunk2064c942008-04-28 23:44:43 +020012 select HAVE_IDE
Russell King2778f622010-07-09 16:27:52 +010013 select HAVE_MEMBLOCK
Alessandro Zummo12b824f2006-03-27 01:16:35 -080014 select RTC_LIB
Ralf Baechle75e71532007-02-09 17:08:58 +000015 select SYS_SUPPORTS_APM_EMULATION
Will Deacon24b44a62010-01-20 19:05:07 +010016 select GENERIC_ATOMIC64 if (!CPU_32v6K)
Will Deaconfe166142010-04-30 11:37:51 +010017 select HAVE_OPROFILE if (HAVE_PERF_EVENTS)
Jason Wessel5cbad0e2008-02-20 13:33:40 -060018 select HAVE_ARCH_KGDB
Mathieu Desnoyers3f550092008-02-02 15:10:35 -050019 select HAVE_KPROBES if (!XIP_KERNEL)
Ananth N Mavinakayanahalli9edddaa2008-03-04 14:28:37 -080020 select HAVE_KRETPROBES if (HAVE_KPROBES)
Steven Rostedt606576c2008-10-06 19:06:12 -040021 select HAVE_FUNCTION_TRACER if (!XIP_KERNEL)
Dmitry Baryshkov1fe53262008-07-18 13:30:14 +040022 select HAVE_GENERIC_DMA_COHERENT
Albin Tonnerree7db7b42010-01-08 14:42:43 -080023 select HAVE_KERNEL_GZIP
24 select HAVE_KERNEL_LZO
Albin Tonnerre6e8699f2010-04-03 11:40:28 +010025 select HAVE_KERNEL_LZMA
Jamie Iles7ada1892010-02-02 20:24:58 +010026 select HAVE_PERF_EVENTS
27 select PERF_USE_VMALLOC
Linus Torvalds1da177e2005-04-16 15:20:36 -070028 help
29 The ARM series is a line of low-power-consumption RISC chip designs
Martin Michlmayrf6c89652006-02-08 21:09:07 +000030 licensed by ARM Ltd and targeted at embedded applications and
Linus Torvalds1da177e2005-04-16 15:20:36 -070031 handhelds such as the Compaq IPAQ. ARM-based PCs are no longer
Martin Michlmayrf6c89652006-02-08 21:09:07 +000032 manufactured, but legacy ARM-based PC hardware remains popular in
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 Europe. There is an ARM Linux project with a web page at
34 <http://www.arm.linux.org.uk/>.
35
Russell King1a189b92008-04-13 21:41:55 +010036config HAVE_PWM
37 bool
38
Ralf Baechle75e71532007-02-09 17:08:58 +000039config SYS_SUPPORTS_APM_EMULATION
40 bool
41
David Brownell0a938b92007-03-05 00:30:18 -080042config GENERIC_GPIO
43 bool
David Brownell0a938b92007-03-05 00:30:18 -080044
Kevin Hilman746140c2006-09-22 00:16:30 +010045config GENERIC_TIME
46 bool
John Stultz5cfc8ee2010-03-24 00:22:36 +000047 default y
48
49config ARCH_USES_GETTIMEOFFSET
50 bool
51 default n
Kevin Hilman746140c2006-09-22 00:16:30 +010052
Kevin Hilman0567a0c2007-03-13 20:29:24 +010053config GENERIC_CLOCKEVENTS
54 bool
Kevin Hilman0567a0c2007-03-13 20:29:24 +010055
Catalin Marinasa8655e82008-02-04 17:30:57 +010056config GENERIC_CLOCKEVENTS_BROADCAST
57 bool
58 depends on GENERIC_CLOCKEVENTS
59 default y if SMP && !LOCAL_TIMERS
60
Linus Walleijbc581772009-09-15 17:30:37 +010061config HAVE_TCM
62 bool
63 select GENERIC_ALLOCATOR
64
Russell Kinge119bff2010-01-10 17:23:29 +000065config HAVE_PROC_CPU
66 bool
67
Al Viro5ea81762007-02-11 15:41:31 +000068config NO_IOPORT
69 bool
Al Viro5ea81762007-02-11 15:41:31 +000070
Linus Torvalds1da177e2005-04-16 15:20:36 -070071config EISA
72 bool
73 ---help---
74 The Extended Industry Standard Architecture (EISA) bus was
75 developed as an open alternative to the IBM MicroChannel bus.
76
77 The EISA bus provided some of the features of the IBM MicroChannel
78 bus while maintaining backward compatibility with cards made for
79 the older ISA bus. The EISA bus saw limited use between 1988 and
80 1995 when it was made obsolete by the PCI bus.
81
82 Say Y here if you are building a kernel for an EISA-based machine.
83
84 Otherwise, say N.
85
86config SBUS
87 bool
88
89config MCA
90 bool
91 help
92 MicroChannel Architecture is found in some IBM PS/2 machines and
93 laptops. It is a bus system similar to PCI or ISA. See
94 <file:Documentation/mca.txt> (and especially the web page given
95 there) before attempting to build an MCA bus kernel.
96
Thomas Gleixner4a2581a2006-07-01 22:30:09 +010097config GENERIC_HARDIRQS
98 bool
99 default y
100
Russell Kingf16fb1e2007-04-28 09:59:37 +0100101config STACKTRACE_SUPPORT
102 bool
103 default y
104
Nicolas Pitref76e9152008-04-24 01:31:46 -0400105config HAVE_LATENCYTOP_SUPPORT
106 bool
107 depends on !SMP
108 default y
109
Russell Kingf16fb1e2007-04-28 09:59:37 +0100110config LOCKDEP_SUPPORT
111 bool
112 default y
113
Russell King7ad1bcb2006-08-27 12:07:02 +0100114config TRACE_IRQFLAGS_SUPPORT
115 bool
116 default y
117
Thomas Gleixner4a2581a2006-07-01 22:30:09 +0100118config HARDIRQS_SW_RESEND
119 bool
120 default y
121
122config GENERIC_IRQ_PROBE
123 bool
124 default y
125
Nick Piggin95c354f2008-01-30 13:31:20 +0100126config GENERIC_LOCKBREAK
127 bool
128 default y
129 depends on SMP && PREEMPT
130
Linus Torvalds1da177e2005-04-16 15:20:36 -0700131config RWSEM_GENERIC_SPINLOCK
132 bool
133 default y
134
135config RWSEM_XCHGADD_ALGORITHM
136 bool
137
David Howellsf0d1b0b2006-12-08 02:37:49 -0800138config ARCH_HAS_ILOG2_U32
139 bool
David Howellsf0d1b0b2006-12-08 02:37:49 -0800140
141config ARCH_HAS_ILOG2_U64
142 bool
David Howellsf0d1b0b2006-12-08 02:37:49 -0800143
Ben Dooks89c52ed2009-07-30 23:23:24 +0100144config ARCH_HAS_CPUFREQ
145 bool
146 help
147 Internal node to signify that the ARCH has CPUFREQ support
148 and that the relevant menu configurations are displayed for
149 it.
150
Akinobu Mitab89c3b12006-03-26 01:39:19 -0800151config GENERIC_HWEIGHT
152 bool
153 default y
154
Linus Torvalds1da177e2005-04-16 15:20:36 -0700155config GENERIC_CALIBRATE_DELAY
156 bool
157 default y
158
viro@ZenIV.linux.org.uka08b6b72005-09-06 01:48:42 +0100159config ARCH_MAY_HAVE_PC_FDC
160 bool
161
Christoph Lameter5ac6da62007-02-10 01:43:14 -0800162config ZONE_DMA
163 bool
Christoph Lameter5ac6da62007-02-10 01:43:14 -0800164
FUJITA Tomonoriccd7ab72010-03-10 15:23:23 -0800165config NEED_DMA_MAP_STATE
166 def_bool y
167
Linus Torvalds1da177e2005-04-16 15:20:36 -0700168config GENERIC_ISA_DMA
169 bool
170
Linus Torvalds1da177e2005-04-16 15:20:36 -0700171config FIQ
172 bool
173
Al Viro034d2f52005-12-19 16:27:59 -0500174config ARCH_MTD_XIP
175 bool
176
Paulius Zaleckas60a752e2008-06-25 13:33:14 +0100177config GENERIC_HARDIRQS_NO__DO_IRQ
Paulius Zaleckas60a752e2008-06-25 13:33:14 +0100178 def_bool y
179
Kukjin Kimd6d502f2010-02-22 00:02:59 +0100180config ARM_L1_CACHE_SHIFT_6
181 bool
182 help
183 Setting ARM L1 cache line size to 64 Bytes.
184
Hyok S. Choic760fc12006-03-27 15:18:50 +0100185config VECTORS_BASE
186 hex
Hyok S. Choi6afd6fa2006-09-28 21:46:34 +0900187 default 0xffff0000 if MMU || CPU_HIGH_VECTOR
Hyok S. Choic760fc12006-03-27 15:18:50 +0100188 default DRAM_BASE if REMAP_VECTORS_TO_RAM
189 default 0x00000000
190 help
191 The base address of exception vectors.
192
Linus Torvalds1da177e2005-04-16 15:20:36 -0700193source "init/Kconfig"
194
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700195source "kernel/Kconfig.freezer"
196
Linus Torvalds1da177e2005-04-16 15:20:36 -0700197menu "System Type"
198
Hyok S. Choi3c427972009-07-24 12:35:00 +0100199config MMU
200 bool "MMU-based Paged Memory Management Support"
201 default y
202 help
203 Select if you want MMU-based virtualised addressing space
204 support by paged memory management. If unsure, say 'Y'.
205
Russell Kingccf50e22010-03-15 19:03:06 +0000206#
207# The "ARM system type" choice list is ordered alphabetically by option
208# text. Please add new entries in the option alphabetic order.
209#
Linus Torvalds1da177e2005-04-16 15:20:36 -0700210choice
211 prompt "ARM system type"
Catalin Marinas6a0e2432006-03-07 14:42:27 +0000212 default ARCH_VERSATILE
Linus Torvalds1da177e2005-04-16 15:20:36 -0700213
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100214config ARCH_AAEC2000
215 bool "Agilent AAEC-2000 based"
Russell Kingc7508152008-10-26 10:55:14 +0000216 select CPU_ARM920T
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100217 select ARM_AMBA
David Brownell9483a572008-07-23 21:26:48 -0700218 select HAVE_CLK
John Stultz5cfc8ee2010-03-24 00:22:36 +0000219 select ARCH_USES_GETTIMEOFFSET
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100220 help
221 This enables support for systems based on the Agilent AAEC-2000
222
223config ARCH_INTEGRATOR
224 bool "ARM Ltd. Integrator family"
225 select ARM_AMBA
Ben Dooks89c52ed2009-07-30 23:23:24 +0100226 select ARCH_HAS_CPUFREQ
Russell Kingd72fbdf2008-11-08 20:08:08 +0000227 select COMMON_CLKDEV
Russell Kingc5a0adb2010-01-16 20:16:10 +0000228 select ICST
Russell King13edd862010-01-15 21:49:23 +0000229 select GENERIC_CLOCKEVENTS
Russell Kingf4b8b312010-01-14 12:48:06 +0000230 select PLAT_VERSATILE
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100231 help
232 Support for ARM's Integrator platform.
233
234config ARCH_REALVIEW
235 bool "ARM Ltd. RealView family"
236 select ARM_AMBA
Russell Kingcf30fb42008-11-08 20:05:55 +0000237 select COMMON_CLKDEV
Russell Kingc5a0adb2010-01-16 20:16:10 +0000238 select ICST
Catalin Marinasae30cea2008-02-04 17:26:55 +0100239 select GENERIC_CLOCKEVENTS
Russell Kingeb7fffa2009-07-05 22:41:31 +0100240 select ARCH_WANT_OPTIONAL_GPIOLIB
Russell Kingf4b8b312010-01-14 12:48:06 +0000241 select PLAT_VERSATILE
Russell Kinge3887712010-01-14 13:30:16 +0000242 select ARM_TIMER_SP804
Colin Tuckleyb56ba8a2010-02-24 15:23:10 +0100243 select GPIO_PL061 if GPIOLIB
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100244 help
245 This enables support for ARM Ltd RealView boards.
246
247config ARCH_VERSATILE
248 bool "ARM Ltd. Versatile family"
249 select ARM_AMBA
250 select ARM_VIC
Russell King71a06da2008-11-08 20:13:53 +0000251 select COMMON_CLKDEV
Russell Kingc5a0adb2010-01-16 20:16:10 +0000252 select ICST
Kevin Hilman89df1272007-03-08 20:30:38 +0100253 select GENERIC_CLOCKEVENTS
Russell Kingbbeddc42009-07-05 22:43:01 +0100254 select ARCH_WANT_OPTIONAL_GPIOLIB
Russell Kingf4b8b312010-01-14 12:48:06 +0000255 select PLAT_VERSATILE
Russell Kinge3887712010-01-14 13:30:16 +0000256 select ARM_TIMER_SP804
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100257 help
258 This enables support for ARM Ltd Versatile board.
259
Russell Kingceade892010-02-11 21:44:53 +0000260config ARCH_VEXPRESS
261 bool "ARM Ltd. Versatile Express family"
262 select ARCH_WANT_OPTIONAL_GPIOLIB
263 select ARM_AMBA
264 select ARM_TIMER_SP804
265 select COMMON_CLKDEV
266 select GENERIC_CLOCKEVENTS
Russell Kingceade892010-02-11 21:44:53 +0000267 select HAVE_CLK
268 select ICST
269 select PLAT_VERSATILE
270 help
271 This enables support for the ARM Ltd Versatile Express boards.
272
Andrew Victor8fc5ffa2006-06-29 16:06:33 +0100273config ARCH_AT91
274 bool "Atmel AT91"
Ryan Mallonf373e8c2009-02-10 21:02:08 +0100275 select ARCH_REQUIRE_GPIOLIB
David Brownell93686ae2008-07-28 15:46:22 -0700276 select HAVE_CLK
John Stultz5cfc8ee2010-03-24 00:22:36 +0000277 select ARCH_USES_GETTIMEOFFSET
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100278 help
Andrew Victor2b3b3512008-01-24 15:10:39 +0100279 This enables support for systems based on the Atmel AT91RM9200,
280 AT91SAM9 and AT91CAP9 processors.
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100281
Russell Kingccf50e22010-03-15 19:03:06 +0000282config ARCH_BCMRING
283 bool "Broadcom BCMRING"
284 depends on MMU
285 select CPU_V6
286 select ARM_AMBA
287 select COMMON_CLKDEV
Russell Kingccf50e22010-03-15 19:03:06 +0000288 select GENERIC_CLOCKEVENTS
289 select ARCH_WANT_OPTIONAL_GPIOLIB
290 help
291 Support for Broadcom's BCMRing platform.
292
Linus Torvalds1da177e2005-04-16 15:20:36 -0700293config ARCH_CLPS711X
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100294 bool "Cirrus Logic CLPS711x/EP721x-based"
Russell Kingc7508152008-10-26 10:55:14 +0000295 select CPU_ARM720T
John Stultz5cfc8ee2010-03-24 00:22:36 +0000296 select ARCH_USES_GETTIMEOFFSET
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000297 help
298 Support for Cirrus Logic 711x/721x based boards.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700299
Anton Vorontsovd94f9442010-03-25 17:12:41 +0300300config ARCH_CNS3XXX
301 bool "Cavium Networks CNS3XXX family"
302 select CPU_V6
Anton Vorontsovd94f9442010-03-25 17:12:41 +0300303 select GENERIC_CLOCKEVENTS
304 select ARM_GIC
305 help
306 Support for Cavium Networks CNS3XXX platform.
307
Russell King788c9702009-04-26 14:21:59 +0100308config ARCH_GEMINI
309 bool "Cortina Systems Gemini"
310 select CPU_FA526
Russell King788c9702009-04-26 14:21:59 +0100311 select ARCH_REQUIRE_GPIOLIB
John Stultz5cfc8ee2010-03-24 00:22:36 +0000312 select ARCH_USES_GETTIMEOFFSET
Russell King788c9702009-04-26 14:21:59 +0100313 help
314 Support for the Cortina Systems Gemini family SoCs
315
Linus Torvalds1da177e2005-04-16 15:20:36 -0700316config ARCH_EBSA110
317 bool "EBSA-110"
Russell Kingc7508152008-10-26 10:55:14 +0000318 select CPU_SA110
Russell Kingf7e68bb2005-05-05 14:49:01 +0100319 select ISA
Russell Kingc5eb2a22007-03-03 11:54:19 +0000320 select NO_IOPORT
John Stultz5cfc8ee2010-03-24 00:22:36 +0000321 select ARCH_USES_GETTIMEOFFSET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700322 help
323 This is an evaluation board for the StrongARM processor available
Martin Michlmayrf6c89652006-02-08 21:09:07 +0000324 from Digital. It has limited hardware on-board, including an
Linus Torvalds1da177e2005-04-16 15:20:36 -0700325 Ethernet interface, two PCMCIA sockets, two serial ports and a
326 parallel port.
327
Lennert Buytenheke7736d42006-03-20 17:10:13 +0000328config ARCH_EP93XX
329 bool "EP93xx-based"
Russell Kingc7508152008-10-26 10:55:14 +0000330 select CPU_ARM920T
Lennert Buytenheke7736d42006-03-20 17:10:13 +0000331 select ARM_AMBA
332 select ARM_VIC
Russell Kingae696fd2008-11-30 17:11:49 +0000333 select COMMON_CLKDEV
Michael Buesch7444a722008-07-25 01:46:11 -0700334 select ARCH_REQUIRE_GPIOLIB
Mel Gormaneb335752009-05-13 17:34:48 +0100335 select ARCH_HAS_HOLES_MEMORYMODEL
John Stultz5cfc8ee2010-03-24 00:22:36 +0000336 select ARCH_USES_GETTIMEOFFSET
Lennert Buytenheke7736d42006-03-20 17:10:13 +0000337 help
338 This enables support for the Cirrus EP93xx series of CPUs.
339
Linus Torvalds1da177e2005-04-16 15:20:36 -0700340config ARCH_FOOTBRIDGE
341 bool "FootBridge"
Russell Kingc7508152008-10-26 10:55:14 +0000342 select CPU_SA110
Linus Torvalds1da177e2005-04-16 15:20:36 -0700343 select FOOTBRIDGE
John Stultz5cfc8ee2010-03-24 00:22:36 +0000344 select ARCH_USES_GETTIMEOFFSET
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000345 help
346 Support for systems based on the DC21285 companion chip
347 ("FootBridge"), such as the Simtec CATS and the Rebel NetWinder.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700348
Russell King788c9702009-04-26 14:21:59 +0100349config ARCH_MXC
350 bool "Freescale MXC/iMX-based"
Russell King788c9702009-04-26 14:21:59 +0100351 select GENERIC_CLOCKEVENTS
Russell King788c9702009-04-26 14:21:59 +0100352 select ARCH_REQUIRE_GPIOLIB
Uwe Kleine-König03e09cd2010-02-15 17:10:42 +0100353 select COMMON_CLKDEV
Russell King788c9702009-04-26 14:21:59 +0100354 help
355 Support for Freescale MXC/iMX-based family of processors
356
dmitry pervushin7bd0f2f2009-04-27 10:35:04 +0100357config ARCH_STMP3XXX
358 bool "Freescale STMP3xxx"
359 select CPU_ARM926T
dmitry pervushin7bd0f2f2009-04-27 10:35:04 +0100360 select COMMON_CLKDEV
361 select ARCH_REQUIRE_GPIOLIB
dmitry pervushin7bd0f2f2009-04-27 10:35:04 +0100362 select GENERIC_CLOCKEVENTS
dmitry pervushin7bd0f2f2009-04-27 10:35:04 +0100363 select USB_ARCH_HAS_EHCI
364 help
365 Support for systems based on the Freescale 3xxx CPUs.
366
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100367config ARCH_NETX
368 bool "Hilscher NetX based"
Russell Kingc7508152008-10-26 10:55:14 +0000369 select CPU_ARM926T
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100370 select ARM_VIC
Uwe Kleine-König2fcfe6b2008-12-09 21:57:24 +0100371 select GENERIC_CLOCKEVENTS
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000372 help
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100373 This enables support for systems based on the Hilscher NetX Soc
374
375config ARCH_H720X
376 bool "Hynix HMS720x-based"
Russell Kingc7508152008-10-26 10:55:14 +0000377 select CPU_ARM720T
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100378 select ISA_DMA_API
John Stultz5cfc8ee2010-03-24 00:22:36 +0000379 select ARCH_USES_GETTIMEOFFSET
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100380 help
381 This enables support for systems based on the Hynix HMS720x
382
Russell King3b938be2007-05-12 11:25:44 +0100383config ARCH_IOP13XX
384 bool "IOP13xx-based"
385 depends on MMU
Russell Kingc7508152008-10-26 10:55:14 +0000386 select CPU_XSC3
Russell King3b938be2007-05-12 11:25:44 +0100387 select PLAT_IOP
388 select PCI
389 select ARCH_SUPPORTS_MSI
Lennert Buytenhek8d5796d2008-08-25 21:03:32 +0100390 select VMSPLIT_1G
Russell King3b938be2007-05-12 11:25:44 +0100391 help
392 Support for Intel's IOP13XX (XScale) family of processors.
393
Lennert Buytenhek3f7e5812006-09-18 23:10:26 +0100394config ARCH_IOP32X
395 bool "IOP32x-based"
Russell Kinga4f7e762006-06-28 12:52:41 +0100396 depends on MMU
Russell Kingc7508152008-10-26 10:55:14 +0000397 select CPU_XSCALE
Lennert Buytenhek7ae1f7e2006-09-18 23:12:53 +0100398 select PLAT_IOP
Russell Kingf7e68bb2005-05-05 14:49:01 +0100399 select PCI
Russell Kingbb2b1802008-07-26 15:36:03 +0100400 select ARCH_REQUIRE_GPIOLIB
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000401 help
Lennert Buytenhek3f7e5812006-09-18 23:10:26 +0100402 Support for Intel's 80219 and IOP32X (XScale) family of
403 processors.
404
405config ARCH_IOP33X
406 bool "IOP33x-based"
407 depends on MMU
Russell Kingc7508152008-10-26 10:55:14 +0000408 select CPU_XSCALE
Lennert Buytenhek7ae1f7e2006-09-18 23:12:53 +0100409 select PLAT_IOP
Lennert Buytenhek3f7e5812006-09-18 23:10:26 +0100410 select PCI
Russell Kingbb2b1802008-07-26 15:36:03 +0100411 select ARCH_REQUIRE_GPIOLIB
Lennert Buytenhek3f7e5812006-09-18 23:10:26 +0100412 help
413 Support for Intel's IOP33X (XScale) family of processors.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700414
Russell King3b938be2007-05-12 11:25:44 +0100415config ARCH_IXP23XX
416 bool "IXP23XX-based"
Dan Williams588ef762007-02-13 17:12:04 +0100417 depends on MMU
Russell Kingc7508152008-10-26 10:55:14 +0000418 select CPU_XSC3
Russell King3b938be2007-05-12 11:25:44 +0100419 select PCI
John Stultz5cfc8ee2010-03-24 00:22:36 +0000420 select ARCH_USES_GETTIMEOFFSET
Dan Williams285f5fa2006-12-07 02:59:39 +0100421 help
Russell King3b938be2007-05-12 11:25:44 +0100422 Support for Intel's IXP23xx (XScale) family of processors.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700423
424config ARCH_IXP2000
425 bool "IXP2400/2800-based"
Russell Kinga4f7e762006-06-28 12:52:41 +0100426 depends on MMU
Russell Kingc7508152008-10-26 10:55:14 +0000427 select CPU_XSCALE
Russell Kingf7e68bb2005-05-05 14:49:01 +0100428 select PCI
John Stultz5cfc8ee2010-03-24 00:22:36 +0000429 select ARCH_USES_GETTIMEOFFSET
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000430 help
431 Support for Intel's IXP2400/2800 (XScale) family of processors.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700432
Russell King3b938be2007-05-12 11:25:44 +0100433config ARCH_IXP4XX
434 bool "IXP4xx-based"
Russell Kinga4f7e762006-06-28 12:52:41 +0100435 depends on MMU
Russell Kingc7508152008-10-26 10:55:14 +0000436 select CPU_XSCALE
Milan Svoboda8858e9a2007-05-14 07:50:42 +0100437 select GENERIC_GPIO
Russell King3b938be2007-05-12 11:25:44 +0100438 select GENERIC_CLOCKEVENTS
Russell King485bdde2008-10-17 14:00:43 +0100439 select DMABOUNCE if PCI
Lennert Buytenhekc4713072006-03-28 21:18:54 +0100440 help
Russell King3b938be2007-05-12 11:25:44 +0100441 Support for Intel's IXP4XX (XScale) family of processors.
Lennert Buytenhekc4713072006-03-28 21:18:54 +0100442
Linus Torvalds1da177e2005-04-16 15:20:36 -0700443config ARCH_L7200
444 bool "LinkUp-L7200"
Russell Kingc7508152008-10-26 10:55:14 +0000445 select CPU_ARM720T
Linus Torvalds1da177e2005-04-16 15:20:36 -0700446 select FIQ
John Stultz5cfc8ee2010-03-24 00:22:36 +0000447 select ARCH_USES_GETTIMEOFFSET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700448 help
449 Say Y here if you intend to run this kernel on a LinkUp Systems
450 L7200 Software Development Board which uses an ARM720T processor.
451 Information on this board can be obtained at:
452
453 <http://www.linkupsys.com/>
454
455 If you have any questions or comments about the Linux kernel port
456 to this board, send e-mail to <sjhill@cotw.com>.
457
Saeed Bisharaedabd382009-08-06 15:12:43 +0300458config ARCH_DOVE
459 bool "Marvell Dove"
460 select PCI
Saeed Bisharaedabd382009-08-06 15:12:43 +0300461 select ARCH_REQUIRE_GPIOLIB
Saeed Bisharaedabd382009-08-06 15:12:43 +0300462 select GENERIC_CLOCKEVENTS
463 select PLAT_ORION
464 help
465 Support for the Marvell Dove SoC 88AP510
466
Saeed Bishara651c74c2008-06-22 22:45:06 +0200467config ARCH_KIRKWOOD
468 bool "Marvell Kirkwood"
Russell Kingc7508152008-10-26 10:55:14 +0000469 select CPU_FEROCEON
Saeed Bishara651c74c2008-06-22 22:45:06 +0200470 select PCI
Erik Benadaa8865652009-05-28 17:08:55 -0700471 select ARCH_REQUIRE_GPIOLIB
Saeed Bishara651c74c2008-06-22 22:45:06 +0200472 select GENERIC_CLOCKEVENTS
473 select PLAT_ORION
474 help
475 Support for the following Marvell Kirkwood series SoCs:
476 88F6180, 88F6192 and 88F6281.
477
Russell King788c9702009-04-26 14:21:59 +0100478config ARCH_LOKI
479 bool "Marvell Loki (88RC8480)"
480 select CPU_FEROCEON
Russell King788c9702009-04-26 14:21:59 +0100481 select GENERIC_CLOCKEVENTS
482 select PLAT_ORION
483 help
484 Support for the Marvell Loki (88RC8480) SoC.
485
486config ARCH_MV78XX0
487 bool "Marvell MV78xx0"
488 select CPU_FEROCEON
489 select PCI
Erik Benadaa8865652009-05-28 17:08:55 -0700490 select ARCH_REQUIRE_GPIOLIB
Russell King788c9702009-04-26 14:21:59 +0100491 select GENERIC_CLOCKEVENTS
492 select PLAT_ORION
493 help
494 Support for the following Marvell MV78xx0 series SoCs:
495 MV781x0, MV782x0.
496
497config ARCH_ORION5X
498 bool "Marvell Orion"
499 depends on MMU
500 select CPU_FEROCEON
501 select PCI
Erik Benadaa8865652009-05-28 17:08:55 -0700502 select ARCH_REQUIRE_GPIOLIB
Russell King788c9702009-04-26 14:21:59 +0100503 select GENERIC_CLOCKEVENTS
504 select PLAT_ORION
505 help
506 Support for the following Marvell Orion 5x series SoCs:
507 Orion-1 (5181), Orion-VoIP (5181L), Orion-NAS (5182),
508 Orion-2 (5281), Orion-1-90 (6183).
509
510config ARCH_MMP
Haojian Zhuang2f7e8fa2009-12-04 09:41:28 -0500511 bool "Marvell PXA168/910/MMP2"
Russell King788c9702009-04-26 14:21:59 +0100512 depends on MMU
Russell King788c9702009-04-26 14:21:59 +0100513 select ARCH_REQUIRE_GPIOLIB
Russell King788c9702009-04-26 14:21:59 +0100514 select COMMON_CLKDEV
Russell King788c9702009-04-26 14:21:59 +0100515 select GENERIC_CLOCKEVENTS
516 select TICK_ONESHOT
517 select PLAT_PXA
518 help
Haojian Zhuang2f7e8fa2009-12-04 09:41:28 -0500519 Support for Marvell's PXA168/PXA910(MMP) and MMP2 processor line.
Russell King788c9702009-04-26 14:21:59 +0100520
Andrew Victorc53c9cf2007-05-11 21:01:28 +0100521config ARCH_KS8695
522 bool "Micrel/Kendin KS8695"
Russell Kingc7508152008-10-26 10:55:14 +0000523 select CPU_ARM922T
Hartley Sweeten98830bc2010-05-17 17:18:10 +0100524 select ARCH_REQUIRE_GPIOLIB
John Stultz5cfc8ee2010-03-24 00:22:36 +0000525 select ARCH_USES_GETTIMEOFFSET
Andrew Victorc53c9cf2007-05-11 21:01:28 +0100526 help
527 Support for Micrel/Kendin KS8695 "Centaur" (ARM922T) based
528 System-on-Chip devices.
529
Uwe Kleine-König9918cda2007-02-16 15:36:55 +0100530config ARCH_NS9XXX
531 bool "NetSilicon NS9xxx"
Russell Kingc7508152008-10-26 10:55:14 +0000532 select CPU_ARM926T
Uwe Kleine-König689f2a02007-09-30 20:35:09 +0100533 select GENERIC_GPIO
Uwe Kleine-Königc0bb87f2007-09-30 20:36:00 +0100534 select GENERIC_CLOCKEVENTS
David Brownell9483a572008-07-23 21:26:48 -0700535 select HAVE_CLK
Uwe Kleine-König9918cda2007-02-16 15:36:55 +0100536 help
537 Say Y here if you intend to run this kernel on a NetSilicon NS9xxx
538 System.
539
540 <http://www.digi.com/products/microprocessors/index.jsp>
541
Russell King788c9702009-04-26 14:21:59 +0100542config ARCH_W90X900
543 bool "Nuvoton W90X900 CPU"
544 select CPU_ARM926T
wanzongshunc52d3d62009-06-10 15:49:32 +0100545 select ARCH_REQUIRE_GPIOLIB
wanzongshun0e4a34b2009-06-10 15:50:44 +0100546 select COMMON_CLKDEV
wanzongshun58b53692009-08-14 15:36:44 +0100547 select GENERIC_CLOCKEVENTS
Lennert Buytenhek777f9be2008-06-22 22:45:02 +0200548 help
wanzongshuna8bc4ea2009-08-14 15:38:29 +0100549 Support for Nuvoton (Winbond logic dept.) ARM9 processor,
550 At present, the w90x900 has been renamed nuc900, regarding
551 the ARM series product line, you can login the following
552 link address to know more.
553
554 <http://www.nuvoton.com/hq/enu/ProductAndSales/ProductLines/
555 ConsumerElectronicsIC/ARMMicrocontroller/ARMMicrocontroller>
Tzachi Perelstein585cf172007-10-23 15:14:41 -0400556
wanzongshuna62e9032009-12-31 15:06:05 +0100557config ARCH_NUC93X
558 bool "Nuvoton NUC93X CPU"
559 select CPU_ARM926T
wanzongshuna62e9032009-12-31 15:06:05 +0100560 select COMMON_CLKDEV
561 help
562 Support for Nuvoton (Winbond logic dept.) NUC93X MCU,The NUC93X is a
563 low-power and high performance MPEG-4/JPEG multimedia controller chip.
564
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100565config ARCH_PNX4008
566 bool "Philips Nexperia PNX4008 Mobile"
Russell Kingc7508152008-10-26 10:55:14 +0000567 select CPU_ARM926T
Russell King6985a5a2009-11-20 10:32:41 +0000568 select COMMON_CLKDEV
John Stultz5cfc8ee2010-03-24 00:22:36 +0000569 select ARCH_USES_GETTIMEOFFSET
Deepak Saxena4af6fee2006-06-20 21:30:44 +0100570 help
571 This enables support for Philips PNX4008 mobile platform.
572
Linus Torvalds1da177e2005-04-16 15:20:36 -0700573config ARCH_PXA
eric miao2c8086a2007-09-11 19:13:17 -0700574 bool "PXA2xx/PXA3xx-based"
Russell Kinga4f7e762006-06-28 12:52:41 +0100575 depends on MMU
Al Viro034d2f52005-12-19 16:27:59 -0500576 select ARCH_MTD_XIP
Ben Dooks89c52ed2009-07-30 23:23:24 +0100577 select ARCH_HAS_CPUFREQ
Russell King8c3abc72008-11-08 20:25:21 +0000578 select COMMON_CLKDEV
Michael Buesch7444a722008-07-25 01:46:11 -0700579 select ARCH_REQUIRE_GPIOLIB
Eric Miao981d0f32007-07-24 01:22:43 +0100580 select GENERIC_CLOCKEVENTS
Russell Kinga88264c2007-11-12 22:45:16 +0000581 select TICK_ONESHOT
Eric Miaobd5ce432009-01-20 12:06:01 +0800582 select PLAT_PXA
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000583 help
eric miao2c8086a2007-09-11 19:13:17 -0700584 Support for Intel/Marvell's PXA2xx/PXA3xx processor line.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700585
Russell King788c9702009-04-26 14:21:59 +0100586config ARCH_MSM
587 bool "Qualcomm MSM"
Steve Muckle4b536b82008-12-29 16:17:22 -0500588 select HAVE_CLK
Eric Miao49cbe782009-01-20 14:15:18 +0800589 select GENERIC_CLOCKEVENTS
Eric Miao49cbe782009-01-20 14:15:18 +0800590 help
Daniel Walker4b53eb42010-01-01 15:11:43 -0800591 Support for Qualcomm MSM/QSD based systems. This runs on the
592 apps processor of the MSM/QSD and depends on a shared memory
593 interface to the modem processor which runs the baseband
594 stack and controls some vital subsystems
595 (clock and power control, etc).
Eric Miao49cbe782009-01-20 14:15:18 +0800596
Magnus Dammc793c1b2010-02-05 11:14:49 +0000597config ARCH_SHMOBILE
598 bool "Renesas SH-Mobile"
599 help
600 Support for Renesas's SH-Mobile ARM platforms
601
Linus Torvalds1da177e2005-04-16 15:20:36 -0700602config ARCH_RPC
603 bool "RiscPC"
604 select ARCH_ACORN
605 select FIQ
606 select TIMER_ACORN
viro@ZenIV.linux.org.uka08b6b72005-09-06 01:48:42 +0100607 select ARCH_MAY_HAVE_PC_FDC
Ben Dooks341eb782008-07-01 14:16:49 +0100608 select HAVE_PATA_PLATFORM
Russell King065909b2006-01-04 15:44:16 +0000609 select ISA_DMA_API
Al Viro5ea81762007-02-11 15:41:31 +0000610 select NO_IOPORT
Russell King07f841b2008-10-01 17:11:06 +0100611 select ARCH_SPARSEMEM_ENABLE
John Stultz5cfc8ee2010-03-24 00:22:36 +0000612 select ARCH_USES_GETTIMEOFFSET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700613 help
614 On the Acorn Risc-PC, Linux can support the internal IDE disk and
615 CD-ROM interface, serial and parallel port, and the floppy drive.
616
617config ARCH_SA1100
618 bool "SA1100-based"
Russell Kingc7508152008-10-26 10:55:14 +0000619 select CPU_SA1100
Russell Kingf7e68bb2005-05-05 14:49:01 +0100620 select ISA
Russell King05944d72006-11-30 20:43:51 +0000621 select ARCH_SPARSEMEM_ENABLE
Al Viro034d2f52005-12-19 16:27:59 -0500622 select ARCH_MTD_XIP
Ben Dooks89c52ed2009-07-30 23:23:24 +0100623 select ARCH_HAS_CPUFREQ
Russell King1937f5b2009-12-12 16:20:57 +0000624 select CPU_FREQ
Russell King3e238be2008-04-14 23:03:10 +0100625 select GENERIC_CLOCKEVENTS
David Brownell9483a572008-07-23 21:26:48 -0700626 select HAVE_CLK
Russell King3e238be2008-04-14 23:03:10 +0100627 select TICK_ONESHOT
Michael Buesch7444a722008-07-25 01:46:11 -0700628 select ARCH_REQUIRE_GPIOLIB
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000629 help
630 Support for StrongARM 11x0 based boards.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700631
632config ARCH_S3C2410
Ben Dooks63b1f512010-04-30 16:32:26 +0900633 bool "Samsung S3C2410, S3C2412, S3C2413, S3C2416, S3C2440, S3C2442, S3C2443, S3C2450"
David Brownell0a938b92007-03-05 00:30:18 -0800634 select GENERIC_GPIO
Ben Dooks9d56c022009-07-30 23:23:25 +0100635 select ARCH_HAS_CPUFREQ
David Brownell9483a572008-07-23 21:26:48 -0700636 select HAVE_CLK
John Stultz5cfc8ee2010-03-24 00:22:36 +0000637 select ARCH_USES_GETTIMEOFFSET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700638 help
639 Samsung S3C2410X CPU based systems, such as the Simtec Electronics
640 BAST (<http://www.simtec.co.uk/products/EB110ITX/>), the IPAQ 1940 or
Martin Michlmayrf6c89652006-02-08 21:09:07 +0000641 the Samsung SMDK2410 development board (and derivatives).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700642
Ben Dooks63b1f512010-04-30 16:32:26 +0900643 Note, the S3C2416 and the S3C2450 are so close that they even share
644 the same SoC ID code. This means that there is no seperate machine
645 directory (no arch/arm/mach-s3c2450) as the S3C2416 was first.
646
Ben Dooksa08ab632008-10-21 14:06:39 +0100647config ARCH_S3C64XX
648 bool "Samsung S3C64XX"
Ben Dooks89f1fa02010-01-29 09:02:17 +0000649 select PLAT_SAMSUNG
Ben Dooks89f0ce72010-01-26 15:49:15 +0900650 select CPU_V6
Ben Dooks89f0ce72010-01-26 15:49:15 +0900651 select ARM_VIC
Ben Dooksa08ab632008-10-21 14:06:39 +0100652 select HAVE_CLK
Ben Dooks89f0ce72010-01-26 15:49:15 +0900653 select NO_IOPORT
John Stultz5cfc8ee2010-03-24 00:22:36 +0000654 select ARCH_USES_GETTIMEOFFSET
Ben Dooks89c52ed2009-07-30 23:23:24 +0100655 select ARCH_HAS_CPUFREQ
Ben Dooks89f0ce72010-01-26 15:49:15 +0900656 select ARCH_REQUIRE_GPIOLIB
657 select SAMSUNG_CLKSRC
658 select SAMSUNG_IRQ_VIC_TIMER
659 select SAMSUNG_IRQ_UART
660 select S3C_GPIO_TRACK
661 select S3C_GPIO_PULL_UPDOWN
662 select S3C_GPIO_CFG_S3C24XX
663 select S3C_GPIO_CFG_S3C64XX
664 select S3C_DEV_NAND
665 select USB_ARCH_HAS_OHCI
666 select SAMSUNG_GPIOLIB_4BIT
Ben Dooksa08ab632008-10-21 14:06:39 +0100667 help
668 Samsung S3C64XX series based systems
669
Kukjin Kimc4ffccd2010-01-14 08:19:36 +0900670config ARCH_S5P6440
671 bool "Samsung S5P6440"
672 select CPU_V6
673 select GENERIC_GPIO
674 select HAVE_CLK
Ben Dooks925c68c2010-05-20 20:48:28 +0900675 select ARCH_USES_GETTIMEOFFSET
Kukjin Kimc4ffccd2010-01-14 08:19:36 +0900676 help
677 Samsung S5P6440 CPU based systems
678
Kukjin Kim550db7f2010-01-29 10:19:26 +0900679config ARCH_S5P6442
680 bool "Samsung S5P6442"
681 select CPU_V6
682 select GENERIC_GPIO
683 select HAVE_CLK
Ben Dooks925c68c2010-05-20 20:48:28 +0900684 select ARCH_USES_GETTIMEOFFSET
Kukjin Kim550db7f2010-01-29 10:19:26 +0900685 help
686 Samsung S5P6442 CPU based systems
687
Marek Szyprowskiacc84702010-05-20 07:51:08 +0200688config ARCH_S5PC100
689 bool "Samsung S5PC100"
Byungho Min5a7652f2009-06-23 21:39:42 +0900690 select GENERIC_GPIO
691 select HAVE_CLK
692 select CPU_V7
Kukjin Kimd6d502f2010-02-22 00:02:59 +0100693 select ARM_L1_CACHE_SHIFT_6
Ben Dooks925c68c2010-05-20 20:48:28 +0900694 select ARCH_USES_GETTIMEOFFSET
Byungho Min5a7652f2009-06-23 21:39:42 +0900695 help
Marek Szyprowskiacc84702010-05-20 07:51:08 +0200696 Samsung S5PC100 series based systems
Byungho Min5a7652f2009-06-23 21:39:42 +0900697
Kukjin Kim170f4e42010-02-24 16:40:44 +0900698config ARCH_S5PV210
699 bool "Samsung S5PV210/S5PC110"
700 select CPU_V7
701 select GENERIC_GPIO
702 select HAVE_CLK
703 select ARM_L1_CACHE_SHIFT_6
Ben Dooks925c68c2010-05-20 20:48:28 +0900704 select ARCH_USES_GETTIMEOFFSET
Kukjin Kim170f4e42010-02-24 16:40:44 +0900705 help
706 Samsung S5PV210/S5PC110 series based systems
707
Linus Torvalds1da177e2005-04-16 15:20:36 -0700708config ARCH_SHARK
709 bool "Shark"
Russell Kingc7508152008-10-26 10:55:14 +0000710 select CPU_SA110
Russell Kingf7e68bb2005-05-05 14:49:01 +0100711 select ISA
712 select ISA_DMA
Nicolas Pitre3bca1032008-10-07 20:14:55 +0100713 select ZONE_DMA
Russell Kingf7e68bb2005-05-05 14:49:01 +0100714 select PCI
John Stultz5cfc8ee2010-03-24 00:22:36 +0000715 select ARCH_USES_GETTIMEOFFSET
Martin Michlmayrf999b8b2006-02-08 21:09:05 +0000716 help
717 Support for the StrongARM based Digital DNARD machine, also known
718 as "Shark" (<http://www.shark-linux.de/shark.html>).
Linus Torvalds1da177e2005-04-16 15:20:36 -0700719
720config ARCH_LH7A40X
721 bool "Sharp LH7A40X"
Russell Kingc7508152008-10-26 10:55:14 +0000722 select CPU_ARM922T
Russell King4ba3f7c2008-10-01 21:38:23 +0100723 select ARCH_SPARSEMEM_ENABLE if !LH7A40X_CONTIGMEM
John Stultz5cfc8ee2010-03-24 00:22:36 +0000724 select ARCH_USES_GETTIMEOFFSET
Linus Torvalds1da177e2005-04-16 15:20:36 -0700725 help
726 Say Y here for systems based on one of the Sharp LH7A40X
727 System on a Chip processors. These CPUs include an ARM922T
728 core with a wide array of integrated devices for
729 hand-held and low-power applications.
730
Linus Walleijd98aac72009-04-27 10:21:46 +0100731config ARCH_U300
732 bool "ST-Ericsson U300 Series"
733 depends on MMU
734 select CPU_ARM926T
Linus Walleijbc581772009-09-15 17:30:37 +0100735 select HAVE_TCM
Linus Walleijd98aac72009-04-27 10:21:46 +0100736 select ARM_AMBA
737 select ARM_VIC
Linus Walleijd98aac72009-04-27 10:21:46 +0100738 select GENERIC_CLOCKEVENTS
Linus Walleijd98aac72009-04-27 10:21:46 +0100739 select COMMON_CLKDEV
740 select GENERIC_GPIO
741 help
742 Support for ST-Ericsson U300 series mobile platforms.
743
Russell Kingccf50e22010-03-15 19:03:06 +0000744config ARCH_U8500
745 bool "ST-Ericsson U8500 Series"
746 select CPU_V7
747 select ARM_AMBA
Russell Kingccf50e22010-03-15 19:03:06 +0000748 select GENERIC_CLOCKEVENTS
749 select COMMON_CLKDEV
Rabin Vincent94bdc0e2010-03-03 04:54:37 +0100750 select ARCH_REQUIRE_GPIOLIB
Russell Kingccf50e22010-03-15 19:03:06 +0000751 help
752 Support for ST-Ericsson's Ux500 architecture
753
754config ARCH_NOMADIK
755 bool "STMicroelectronics Nomadik"
756 select ARM_AMBA
757 select ARM_VIC
758 select CPU_ARM926T
Russell Kingccf50e22010-03-15 19:03:06 +0000759 select COMMON_CLKDEV
Russell Kingccf50e22010-03-15 19:03:06 +0000760 select GENERIC_CLOCKEVENTS
Russell Kingccf50e22010-03-15 19:03:06 +0000761 select ARCH_REQUIRE_GPIOLIB
762 help
763 Support for the Nomadik platform by ST-Ericsson
764
Kevin Hilman7c6337e2007-04-30 19:37:19 +0100765config ARCH_DAVINCI
766 bool "TI DaVinci"
Kevin Hilman7c6337e2007-04-30 19:37:19 +0100767 select GENERIC_CLOCKEVENTS
David Brownelldce11152008-09-07 23:41:04 -0700768 select ARCH_REQUIRE_GPIOLIB
Nicolas Pitre3bca1032008-10-07 20:14:55 +0100769 select ZONE_DMA
Kevin Hilman9232fcc2009-04-08 14:49:38 -0700770 select HAVE_IDE
Kevin Hilmanc5b736d2009-03-20 17:29:01 -0700771 select COMMON_CLKDEV
David Brownell20e99692009-05-07 09:31:42 -0700772 select GENERIC_ALLOCATOR
Sekhar Noriae88e052009-11-19 15:34:01 +0530773 select ARCH_HAS_HOLES_MEMORYMODEL
Kevin Hilman7c6337e2007-04-30 19:37:19 +0100774 help
775 Support for TI's DaVinci platform.
776
Russell King3b938be2007-05-12 11:25:44 +0100777config ARCH_OMAP
778 bool "TI OMAP"
David Brownell9483a572008-07-23 21:26:48 -0700779 select HAVE_CLK
Michael Buesch7444a722008-07-25 01:46:11 -0700780 select ARCH_REQUIRE_GPIOLIB
Ben Dooks89c52ed2009-07-30 23:23:24 +0100781 select ARCH_HAS_CPUFREQ
Kevin Hilman06cad092007-10-18 23:04:43 -0700782 select GENERIC_CLOCKEVENTS
Sriram9af915d2010-01-29 14:20:05 -0800783 select ARCH_HAS_HOLES_MEMORYMODEL
Russell King3b938be2007-05-12 11:25:44 +0100784 help
785 Support for TI's OMAP platform (OMAP1 and OMAP2).
786
viresh kumarcee37e52010-04-01 12:31:05 +0100787config PLAT_SPEAR
788 bool "ST SPEAr"
789 select ARM_AMBA
790 select ARCH_REQUIRE_GPIOLIB
791 select COMMON_CLKDEV
792 select GENERIC_CLOCKEVENTS
viresh kumarcee37e52010-04-01 12:31:05 +0100793 select HAVE_CLK
794 help
795 Support for ST's SPEAr platform (SPEAr3xx, SPEAr6xx and SPEAr13xx).
796
Linus Torvalds1da177e2005-04-16 15:20:36 -0700797endchoice
798
Russell Kingccf50e22010-03-15 19:03:06 +0000799#
800# This is sorted alphabetically by mach-* pathname. However, plat-*
801# Kconfigs may be included either alphabetically (according to the
802# plat- suffix) or along side the corresponding mach-* source.
803#
Russell King95b8f202010-01-14 11:43:54 +0000804source "arch/arm/mach-aaec2000/Kconfig"
805
806source "arch/arm/mach-at91/Kconfig"
807
808source "arch/arm/mach-bcmring/Kconfig"
809
Linus Torvalds1da177e2005-04-16 15:20:36 -0700810source "arch/arm/mach-clps711x/Kconfig"
811
Anton Vorontsovd94f9442010-03-25 17:12:41 +0300812source "arch/arm/mach-cns3xxx/Kconfig"
813
Russell King95b8f202010-01-14 11:43:54 +0000814source "arch/arm/mach-davinci/Kconfig"
815
816source "arch/arm/mach-dove/Kconfig"
817
Lennert Buytenheke7736d42006-03-20 17:10:13 +0000818source "arch/arm/mach-ep93xx/Kconfig"
819
Linus Torvalds1da177e2005-04-16 15:20:36 -0700820source "arch/arm/mach-footbridge/Kconfig"
821
Paulius Zaleckas59d3a192009-03-26 10:06:08 +0200822source "arch/arm/mach-gemini/Kconfig"
823
Russell King95b8f202010-01-14 11:43:54 +0000824source "arch/arm/mach-h720x/Kconfig"
825
Linus Torvalds1da177e2005-04-16 15:20:36 -0700826source "arch/arm/mach-integrator/Kconfig"
827
Lennert Buytenhek3f7e5812006-09-18 23:10:26 +0100828source "arch/arm/mach-iop32x/Kconfig"
829
830source "arch/arm/mach-iop33x/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700831
Dan Williams285f5fa2006-12-07 02:59:39 +0100832source "arch/arm/mach-iop13xx/Kconfig"
833
Linus Torvalds1da177e2005-04-16 15:20:36 -0700834source "arch/arm/mach-ixp4xx/Kconfig"
835
836source "arch/arm/mach-ixp2000/Kconfig"
837
Lennert Buytenhekc4713072006-03-28 21:18:54 +0100838source "arch/arm/mach-ixp23xx/Kconfig"
839
Russell King95b8f202010-01-14 11:43:54 +0000840source "arch/arm/mach-kirkwood/Kconfig"
841
842source "arch/arm/mach-ks8695/Kconfig"
843
844source "arch/arm/mach-lh7a40x/Kconfig"
845
Lennert Buytenhek777f9be2008-06-22 22:45:02 +0200846source "arch/arm/mach-loki/Kconfig"
847
Russell King95b8f202010-01-14 11:43:54 +0000848source "arch/arm/mach-msm/Kconfig"
849
Stanislav Samsonov794d15b2008-06-22 22:45:10 +0200850source "arch/arm/mach-mv78xx0/Kconfig"
851
Russell King95b8f202010-01-14 11:43:54 +0000852source "arch/arm/plat-mxc/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700853
Russell King95b8f202010-01-14 11:43:54 +0000854source "arch/arm/mach-netx/Kconfig"
Eric Miao49cbe782009-01-20 14:15:18 +0800855
Russell King95b8f202010-01-14 11:43:54 +0000856source "arch/arm/mach-nomadik/Kconfig"
857source "arch/arm/plat-nomadik/Kconfig"
858
859source "arch/arm/mach-ns9xxx/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700860
Russell Kingd91a8912010-02-04 18:13:17 +0000861source "arch/arm/mach-nuc93x/Kconfig"
862
Tony Lindgrend48af152005-07-10 19:58:17 +0100863source "arch/arm/plat-omap/Kconfig"
864
865source "arch/arm/mach-omap1/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700866
Tony Lindgren1dbae812005-11-10 14:26:51 +0000867source "arch/arm/mach-omap2/Kconfig"
868
Lennert Buytenhek9dd0b192008-03-27 14:51:41 -0400869source "arch/arm/mach-orion5x/Kconfig"
Tzachi Perelstein585cf172007-10-23 15:14:41 -0400870
Russell King95b8f202010-01-14 11:43:54 +0000871source "arch/arm/mach-pxa/Kconfig"
872source "arch/arm/plat-pxa/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700873
Russell King95b8f202010-01-14 11:43:54 +0000874source "arch/arm/mach-mmp/Kconfig"
875
876source "arch/arm/mach-realview/Kconfig"
877
878source "arch/arm/mach-sa1100/Kconfig"
Saeed Bisharaedabd382009-08-06 15:12:43 +0300879
Ben Dookscf383672009-11-10 00:14:58 +0000880source "arch/arm/plat-samsung/Kconfig"
Ben Dooksa21765a2007-02-11 18:31:01 +0100881source "arch/arm/plat-s3c24xx/Kconfig"
Kukjin Kimc4ffccd2010-01-14 08:19:36 +0900882source "arch/arm/plat-s5p/Kconfig"
Ben Dooksa21765a2007-02-11 18:31:01 +0100883
viresh kumarcee37e52010-04-01 12:31:05 +0100884source "arch/arm/plat-spear/Kconfig"
Ben Dooksa21765a2007-02-11 18:31:01 +0100885
886if ARCH_S3C2410
887source "arch/arm/mach-s3c2400/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700888source "arch/arm/mach-s3c2410/Kconfig"
Ben Dooksa21765a2007-02-11 18:31:01 +0100889source "arch/arm/mach-s3c2412/Kconfig"
Yauhen Kharuzhyf1290a42010-04-28 18:09:01 +0900890source "arch/arm/mach-s3c2416/Kconfig"
Ben Dooksa21765a2007-02-11 18:31:01 +0100891source "arch/arm/mach-s3c2440/Kconfig"
Ben Dookse4d06e32007-02-16 12:12:31 +0100892source "arch/arm/mach-s3c2443/Kconfig"
Ben Dooksa21765a2007-02-11 18:31:01 +0100893endif
Linus Torvalds1da177e2005-04-16 15:20:36 -0700894
Ben Dooksa08ab632008-10-21 14:06:39 +0100895if ARCH_S3C64XX
Ben Dooks431107e2010-01-26 10:11:04 +0900896source "arch/arm/mach-s3c64xx/Kconfig"
Ben Dooksa08ab632008-10-21 14:06:39 +0100897endif
898
Kukjin Kimc4ffccd2010-01-14 08:19:36 +0900899source "arch/arm/mach-s5p6440/Kconfig"
900
Kukjin Kim550db7f2010-01-29 10:19:26 +0900901source "arch/arm/mach-s5p6442/Kconfig"
dmitry pervushin7bd0f2f2009-04-27 10:35:04 +0100902
Byungho Min5a7652f2009-06-23 21:39:42 +0900903source "arch/arm/mach-s5pc100/Kconfig"
Byungho Min5a7652f2009-06-23 21:39:42 +0900904
Kukjin Kim170f4e42010-02-24 16:40:44 +0900905source "arch/arm/mach-s5pv210/Kconfig"
906
Russell King882d01f2010-03-02 23:40:15 +0000907source "arch/arm/mach-shmobile/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700908
Russell King882d01f2010-03-02 23:40:15 +0000909source "arch/arm/plat-stmp3xxx/Kconfig"
Brian Swetland9e73c842007-11-26 04:12:13 -0800910
Russell King95b8f202010-01-14 11:43:54 +0000911source "arch/arm/mach-u300/Kconfig"
Quinn Jensen52c543f2007-07-09 22:06:53 +0100912
Russell King95b8f202010-01-14 11:43:54 +0000913source "arch/arm/mach-ux500/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -0700914
915source "arch/arm/mach-versatile/Kconfig"
916
Russell Kingceade892010-02-11 21:44:53 +0000917source "arch/arm/mach-vexpress/Kconfig"
918
wanzongshun7ec80dd2008-12-03 03:55:38 +0100919source "arch/arm/mach-w90x900/Kconfig"
920
Linus Torvalds1da177e2005-04-16 15:20:36 -0700921# Definitions to make life easier
922config ARCH_ACORN
923 bool
924
Lennert Buytenhek7ae1f7e2006-09-18 23:12:53 +0100925config PLAT_IOP
926 bool
Mikael Pettersson469d30442009-10-29 11:46:54 -0700927 select GENERIC_CLOCKEVENTS
Lennert Buytenhek7ae1f7e2006-09-18 23:12:53 +0100928
Lennert Buytenhek69b02f62008-03-27 14:51:39 -0400929config PLAT_ORION
930 bool
931
Eric Miaobd5ce432009-01-20 12:06:01 +0800932config PLAT_PXA
933 bool
934
Russell Kingf4b8b312010-01-14 12:48:06 +0000935config PLAT_VERSATILE
936 bool
937
Russell Kinge3887712010-01-14 13:30:16 +0000938config ARM_TIMER_SP804
939 bool
940
Linus Torvalds1da177e2005-04-16 15:20:36 -0700941source arch/arm/mm/Kconfig
942
Lennert Buytenhekafe4b252006-12-03 18:51:14 +0100943config IWMMXT
944 bool "Enable iWMMXt support"
Eric Miao40305a52009-02-26 09:34:35 +0800945 depends on CPU_XSCALE || CPU_XSC3 || CPU_MOHAWK
946 default y if PXA27x || PXA3xx || ARCH_MMP
Lennert Buytenhekafe4b252006-12-03 18:51:14 +0100947 help
948 Enable support for iWMMXt context switching at run time if
949 running on a CPU that supports it.
950
Linus Torvalds1da177e2005-04-16 15:20:36 -0700951# bool 'Use XScale PMU as timer source' CONFIG_XSCALE_PMU_TIMER
952config XSCALE_PMU
953 bool
954 depends on CPU_XSCALE && !XSCALE_PMU_TIMER
955 default y
956
Jamie Iles0f4f0672010-02-02 20:23:15 +0100957config CPU_HAS_PMU
Will Deacon8954bb02010-06-21 15:32:54 +0100958 depends on (CPU_V6 || CPU_V7 || XSCALE_PMU) && \
959 (!ARCH_OMAP3 || OMAP3_EMU)
Jamie Iles0f4f0672010-02-02 20:23:15 +0100960 default y
961 bool
962
Hyok S. Choi3b93e7b2006-06-22 11:48:56 +0100963if !MMU
964source "arch/arm/Kconfig-nommu"
965endif
966
Catalin Marinas9cba3cc2009-04-30 17:06:03 +0100967config ARM_ERRATA_411920
968 bool "ARM errata: Invalidation of the Instruction Cache operation can fail"
969 depends on CPU_V6 && !SMP
970 help
971 Invalidation of the Instruction Cache operation can
972 fail. This erratum is present in 1136 (before r1p4), 1156 and 1176.
973 It does not affect the MPCore. This option enables the ARM Ltd.
974 recommended workaround.
975
Catalin Marinas7ce236f2009-04-30 17:06:09 +0100976config ARM_ERRATA_430973
977 bool "ARM errata: Stale prediction on replaced interworking branch"
978 depends on CPU_V7
979 help
980 This option enables the workaround for the 430973 Cortex-A8
981 (r1p0..r1p2) erratum. If a code sequence containing an ARM/Thumb
982 interworking branch is replaced with another code sequence at the
983 same virtual address, whether due to self-modifying code or virtual
984 to physical address re-mapping, Cortex-A8 does not recover from the
985 stale interworking branch prediction. This results in Cortex-A8
986 executing the new code sequence in the incorrect ARM or Thumb state.
987 The workaround enables the BTB/BTAC operations by setting ACTLR.IBE
988 and also flushes the branch target cache at every context switch.
989 Note that setting specific bits in the ACTLR register may not be
990 available in non-secure mode.
991
Catalin Marinas855c5512009-04-30 17:06:15 +0100992config ARM_ERRATA_458693
993 bool "ARM errata: Processor deadlock when a false hazard is created"
994 depends on CPU_V7
995 help
996 This option enables the workaround for the 458693 Cortex-A8 (r2p0)
997 erratum. For very specific sequences of memory operations, it is
998 possible for a hazard condition intended for a cache line to instead
999 be incorrectly associated with a different cache line. This false
1000 hazard might then cause a processor deadlock. The workaround enables
1001 the L1 caching of the NEON accesses and disables the PLD instruction
1002 in the ACTLR register. Note that setting specific bits in the ACTLR
1003 register may not be available in non-secure mode.
1004
Catalin Marinas0516e462009-04-30 17:06:20 +01001005config ARM_ERRATA_460075
1006 bool "ARM errata: Data written to the L2 cache can be overwritten with stale data"
1007 depends on CPU_V7
1008 help
1009 This option enables the workaround for the 460075 Cortex-A8 (r2p0)
1010 erratum. Any asynchronous access to the L2 cache may encounter a
1011 situation in which recent store transactions to the L2 cache are lost
1012 and overwritten with stale memory contents from external memory. The
1013 workaround disables the write-allocate mode for the L2 cache via the
1014 ACTLR register. Note that setting specific bits in the ACTLR register
1015 may not be available in non-secure mode.
1016
Santosh Shilimkar9e655822010-02-04 19:42:42 +01001017config PL310_ERRATA_588369
1018 bool "Clean & Invalidate maintenance operations do not invalidate clean lines"
1019 depends on CACHE_L2X0 && ARCH_OMAP4
1020 help
1021 The PL310 L2 cache controller implements three types of Clean &
1022 Invalidate maintenance operations: by Physical Address
1023 (offset 0x7F0), by Index/Way (0x7F8) and by Way (0x7FC).
1024 They are architecturally defined to behave as the execution of a
1025 clean operation followed immediately by an invalidate operation,
1026 both performing to the same memory location. This functionality
1027 is not correctly implemented in PL310 as clean lines are not
1028 invalidated as a result of these operations. Note that this errata
1029 uses Texas Instrument's secure monitor api.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001030endmenu
1031
1032source "arch/arm/common/Kconfig"
1033
1034config FORCE_MAX_ZONEORDER
1035 int
1036 depends on SA1111
1037 default "9"
1038
1039menu "Bus support"
1040
1041config ARM_AMBA
1042 bool
1043
1044config ISA
1045 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -07001046 help
1047 Find out whether you have ISA slots on your motherboard. ISA is the
1048 name of a bus system, i.e. the way the CPU talks to the other stuff
1049 inside your box. Other bus systems are PCI, EISA, MicroChannel
1050 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
1051 newer boards don't support it. If you have ISA, say Y, otherwise N.
1052
Russell King065909b2006-01-04 15:44:16 +00001053# Select ISA DMA controller support
Linus Torvalds1da177e2005-04-16 15:20:36 -07001054config ISA_DMA
1055 bool
Russell King065909b2006-01-04 15:44:16 +00001056 select ISA_DMA_API
Linus Torvalds1da177e2005-04-16 15:20:36 -07001057
Russell King065909b2006-01-04 15:44:16 +00001058# Select ISA DMA interface
Al Viro5cae8412005-05-04 05:39:22 +01001059config ISA_DMA_API
1060 bool
Al Viro5cae8412005-05-04 05:39:22 +01001061
Linus Torvalds1da177e2005-04-16 15:20:36 -07001062config PCI
Mike Rapoporta0113a92007-11-25 08:55:34 +01001063 bool "PCI support" if ARCH_INTEGRATOR_AP || ARCH_VERSATILE_PB || ARCH_IXP4XX || ARCH_KS8695 || MACH_ARMCORE
Linus Torvalds1da177e2005-04-16 15:20:36 -07001064 help
1065 Find out whether you have a PCI motherboard. PCI is the name of a
1066 bus system, i.e. the way the CPU talks to the other stuff inside
1067 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
1068 VESA. If you have PCI, say Y, otherwise N.
1069
Anton Vorontsov52882172010-04-19 13:20:49 +01001070config PCI_DOMAINS
1071 bool
1072 depends on PCI
1073
Matthew Wilcox36e23592007-07-10 10:54:40 -06001074config PCI_SYSCALL
1075 def_bool PCI
1076
Linus Torvalds1da177e2005-04-16 15:20:36 -07001077# Select the host bridge type
1078config PCI_HOST_VIA82C505
1079 bool
1080 depends on PCI && ARCH_SHARK
1081 default y
1082
Mike Rapoporta0113a92007-11-25 08:55:34 +01001083config PCI_HOST_ITE8152
1084 bool
1085 depends on PCI && MACH_ARMCORE
1086 default y
1087 select DMABOUNCE
1088
Linus Torvalds1da177e2005-04-16 15:20:36 -07001089source "drivers/pci/Kconfig"
1090
1091source "drivers/pcmcia/Kconfig"
1092
1093endmenu
1094
1095menu "Kernel Features"
1096
Kevin Hilman0567a0c2007-03-13 20:29:24 +01001097source "kernel/time/Kconfig"
1098
Linus Torvalds1da177e2005-04-16 15:20:36 -07001099config SMP
1100 bool "Symmetric Multi-Processing (EXPERIMENTAL)"
Russell King42578c82009-06-11 15:35:00 +01001101 depends on EXPERIMENTAL && (REALVIEW_EB_ARM11MP || REALVIEW_EB_A9MP ||\
Russell King59ac59f2010-02-11 21:56:07 +00001102 MACH_REALVIEW_PB11MP || MACH_REALVIEW_PBX || ARCH_OMAP4 ||\
1103 ARCH_U8500 || ARCH_VEXPRESS_CA9X4)
Russell Kingbc282482009-05-17 18:58:34 +01001104 depends on GENERIC_CLOCKEVENTS
Jens Axboef6dd9fa2008-06-10 20:48:30 +02001105 select USE_GENERIC_SMP_HELPERS
Russell King59ac59f2010-02-11 21:56:07 +00001106 select HAVE_ARM_SCU if (ARCH_REALVIEW || ARCH_OMAP4 || ARCH_U8500 || ARCH_VEXPRESS_CA9X4)
Linus Torvalds1da177e2005-04-16 15:20:36 -07001107 help
1108 This enables support for systems with more than one CPU. If you have
1109 a system with only one CPU, like most personal computers, say N. If
1110 you have a system with more than one CPU, say Y.
1111
1112 If you say N here, the kernel will run on single and multiprocessor
1113 machines, but will use only one CPU of a multiprocessor machine. If
1114 you say Y here, the kernel will run on many, but not all, single
1115 processor machines. On a single processor machine, the kernel will
1116 run faster if you say N here.
1117
Adrian Bunk03502fa2008-02-03 15:50:21 +02001118 See also <file:Documentation/i386/IO-APIC.txt>,
Linus Torvalds1da177e2005-04-16 15:20:36 -07001119 <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
1120 <http://www.linuxdoc.org/docs.html#howto>.
1121
1122 If you don't know what to do here, say N.
1123
Russell Kinga8cbcd92009-05-16 11:51:14 +01001124config HAVE_ARM_SCU
1125 bool
1126 depends on SMP
1127 help
1128 This option enables support for the ARM system coherency unit
1129
Russell Kingf32f4ce2009-05-16 12:14:21 +01001130config HAVE_ARM_TWD
1131 bool
1132 depends on SMP
1133 help
1134 This options enables support for the ARM timer and watchdog unit
1135
Lennert Buytenhek8d5796d2008-08-25 21:03:32 +01001136choice
1137 prompt "Memory split"
1138 default VMSPLIT_3G
1139 help
1140 Select the desired split between kernel and user memory.
1141
1142 If you are not absolutely sure what you are doing, leave this
1143 option alone!
1144
1145 config VMSPLIT_3G
1146 bool "3G/1G user/kernel split"
1147 config VMSPLIT_2G
1148 bool "2G/2G user/kernel split"
1149 config VMSPLIT_1G
1150 bool "1G/3G user/kernel split"
1151endchoice
1152
1153config PAGE_OFFSET
1154 hex
1155 default 0x40000000 if VMSPLIT_1G
1156 default 0x80000000 if VMSPLIT_2G
1157 default 0xC0000000
1158
Linus Torvalds1da177e2005-04-16 15:20:36 -07001159config NR_CPUS
1160 int "Maximum number of CPUs (2-32)"
1161 range 2 32
1162 depends on SMP
1163 default "4"
1164
Russell Kinga054a812005-11-02 22:24:33 +00001165config HOTPLUG_CPU
1166 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
1167 depends on SMP && HOTPLUG && EXPERIMENTAL
1168 help
1169 Say Y here to experiment with turning CPUs off and on. CPUs
1170 can be controlled through /sys/devices/system/cpu.
1171
Russell King37ee16a2005-11-08 19:08:05 +00001172config LOCAL_TIMERS
1173 bool "Use local timer interrupts"
Russell King42578c82009-06-11 15:35:00 +01001174 depends on SMP && (REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || \
Srinidhi Kasagar850265e2009-11-28 08:24:47 +01001175 REALVIEW_EB_A9MP || MACH_REALVIEW_PBX || ARCH_OMAP4 || ARCH_U8500)
Russell King37ee16a2005-11-08 19:08:05 +00001176 default y
Srinidhi Kasagar850265e2009-11-28 08:24:47 +01001177 select HAVE_ARM_TWD if (ARCH_REALVIEW || ARCH_OMAP4 || ARCH_U8500)
Russell King37ee16a2005-11-08 19:08:05 +00001178 help
1179 Enable support for local timers on SMP platforms, rather then the
1180 legacy IPI broadcast method. Local timers allows the system
1181 accounting to be spread across the timer interval, preventing a
1182 "thundering herd" at every timer tick.
1183
Uwe Kleine-Königd45a3982009-08-13 20:38:17 +02001184source kernel/Kconfig.preempt
Linus Torvalds1da177e2005-04-16 15:20:36 -07001185
Russell Kingf8065812006-03-02 22:41:59 +00001186config HZ
1187 int
1188 default 128 if ARCH_L7200
Kukjin Kim170f4e42010-02-24 16:40:44 +09001189 default 200 if ARCH_EBSA110 || ARCH_S3C2410 || ARCH_S5P6440 || ARCH_S5P6442 || ARCH_S5PV210
Russell Kingbfe65702006-03-04 11:01:53 +00001190 default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER
David Brownell5248c652007-11-12 17:59:10 +01001191 default AT91_TIMER_HZ if ARCH_AT91
Russell Kingf8065812006-03-02 22:41:59 +00001192 default 100
1193
Catalin Marinas16c79652009-07-24 12:33:02 +01001194config THUMB2_KERNEL
1195 bool "Compile the kernel in Thumb-2 mode"
1196 depends on CPU_V7 && EXPERIMENTAL
1197 select AEABI
1198 select ARM_ASM_UNIFIED
1199 help
1200 By enabling this option, the kernel will be compiled in
1201 Thumb-2 mode. A compiler/assembler that understand the unified
1202 ARM-Thumb syntax is needed.
1203
1204 If unsure, say N.
1205
Catalin Marinas0becb082009-07-24 12:32:53 +01001206config ARM_ASM_UNIFIED
1207 bool
1208
Nicolas Pitre704bdda02006-01-14 16:33:50 +00001209config AEABI
1210 bool "Use the ARM EABI to compile the kernel"
1211 help
1212 This option allows for the kernel to be compiled using the latest
1213 ARM ABI (aka EABI). This is only useful if you are using a user
1214 space environment that is also compiled with EABI.
1215
1216 Since there are major incompatibilities between the legacy ABI and
1217 EABI, especially with regard to structure member alignment, this
1218 option also changes the kernel syscall calling convention to
1219 disambiguate both ABIs and allow for backward compatibility support
1220 (selected with CONFIG_OABI_COMPAT).
1221
1222 To use this you need GCC version 4.0.0 or later.
1223
Nicolas Pitre6c90c872006-01-14 16:37:15 +00001224config OABI_COMPAT
Russell Kinga73a3ff2006-02-08 21:09:55 +00001225 bool "Allow old ABI binaries to run with this kernel (EXPERIMENTAL)"
Nicolas Pitre61c484d2006-02-08 21:09:08 +00001226 depends on AEABI && EXPERIMENTAL
Nicolas Pitre6c90c872006-01-14 16:37:15 +00001227 default y
1228 help
1229 This option preserves the old syscall interface along with the
1230 new (ARM EABI) one. It also provides a compatibility layer to
1231 intercept syscalls that have structure arguments which layout
1232 in memory differs between the legacy ABI and the new ARM EABI
1233 (only for non "thumb" binaries). This option adds a tiny
1234 overhead to all syscalls and produces a slightly larger kernel.
1235 If you know you'll be using only pure EABI user space then you
1236 can say N here. If this option is not selected and you attempt
1237 to execute a legacy ABI binary then the result will be
1238 UNPREDICTABLE (in fact it can be predicted that it won't work
1239 at all). If in doubt say Y.
1240
Mel Gormaneb335752009-05-13 17:34:48 +01001241config ARCH_HAS_HOLES_MEMORYMODEL
Mel Gormane80d6a22008-08-14 11:10:14 +01001242 bool
Mel Gormane80d6a22008-08-14 11:10:14 +01001243
Russell King05944d72006-11-30 20:43:51 +00001244config ARCH_SPARSEMEM_ENABLE
1245 bool
1246
Russell King07a2f732008-10-01 21:39:58 +01001247config ARCH_SPARSEMEM_DEFAULT
1248 def_bool ARCH_SPARSEMEM_ENABLE
1249
Russell King05944d72006-11-30 20:43:51 +00001250config ARCH_SELECT_MEMORY_MODEL
Russell Kingbe370302010-05-07 17:40:33 +01001251 def_bool ARCH_SPARSEMEM_ENABLE
Yasunori Gotoc80d79d2006-04-10 22:53:53 -07001252
Nicolas Pitre053a96c2008-09-19 00:36:12 -04001253config HIGHMEM
1254 bool "High Memory Support (EXPERIMENTAL)"
1255 depends on MMU && EXPERIMENTAL
1256 help
1257 The address space of ARM processors is only 4 Gigabytes large
1258 and it has to accommodate user address space, kernel address
1259 space as well as some memory mapped IO. That means that, if you
1260 have a large amount of physical memory and/or IO, not all of the
1261 memory can be "permanently mapped" by the kernel. The physical
1262 memory that is not permanently mapped is called "high memory".
1263
1264 Depending on the selected kernel/user memory split, minimum
1265 vmalloc space and actual amount of RAM, you may not need this
1266 option which should result in a slightly faster kernel.
1267
1268 If unsure, say n.
1269
Russell King65cec8e2009-08-17 20:02:06 +01001270config HIGHPTE
1271 bool "Allocate 2nd-level pagetables from highmem"
1272 depends on HIGHMEM
1273 depends on !OUTER_CACHE
1274
Jamie Iles1b8873a2010-02-02 20:25:44 +01001275config HW_PERF_EVENTS
1276 bool "Enable hardware performance counter support for perf events"
Will Deaconfe166142010-04-30 11:37:51 +01001277 depends on PERF_EVENTS && CPU_HAS_PMU
Jamie Iles1b8873a2010-02-02 20:25:44 +01001278 default y
1279 help
1280 Enable hardware performance counter support for perf events. If
1281 disabled, perf events will use software events only.
1282
Dave Hansen3f22ab22005-06-23 00:07:43 -07001283source "mm/Kconfig"
1284
Linus Torvalds1da177e2005-04-16 15:20:36 -07001285config LEDS
1286 bool "Timer and CPU usage LEDs"
Adrian Bunke055d5bf2008-04-22 01:43:27 +01001287 depends on ARCH_CDB89712 || ARCH_EBSA110 || \
Sascha Hauer8c8fdbc2009-04-01 12:40:15 +02001288 ARCH_EBSA285 || ARCH_INTEGRATOR || \
Linus Torvalds1da177e2005-04-16 15:20:36 -07001289 ARCH_LUBBOCK || MACH_MAINSTONE || ARCH_NETWINDER || \
1290 ARCH_OMAP || ARCH_P720T || ARCH_PXA_IDP || \
SAN People73a59c12006-01-09 17:05:41 +00001291 ARCH_SA1100 || ARCH_SHARK || ARCH_VERSATILE || \
Jürgen Schindele25329672008-09-16 21:36:30 +01001292 ARCH_AT91 || ARCH_DAVINCI || \
Colin Tuckleyff3042f2009-05-30 13:56:13 +01001293 ARCH_KS8695 || MACH_RD88F5182 || ARCH_REALVIEW
Linus Torvalds1da177e2005-04-16 15:20:36 -07001294 help
1295 If you say Y here, the LEDs on your machine will be used
1296 to provide useful information about your current system status.
1297
1298 If you are compiling a kernel for a NetWinder or EBSA-285, you will
1299 be able to select which LEDs are active using the options below. If
1300 you are compiling a kernel for the EBSA-110 or the LART however, the
1301 red LED will simply flash regularly to indicate that the system is
1302 still functional. It is safe to say Y here if you have a CATS
1303 system, but the driver will do nothing.
1304
1305config LEDS_TIMER
1306 bool "Timer LED" if (!ARCH_CDB89712 && !ARCH_OMAP) || \
David Brownelleebdf7d72007-04-02 12:48:10 -07001307 OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
1308 || MACH_OMAP_PERSEUS2
Linus Torvalds1da177e2005-04-16 15:20:36 -07001309 depends on LEDS
Kevin Hilman0567a0c2007-03-13 20:29:24 +01001310 depends on !GENERIC_CLOCKEVENTS
Linus Torvalds1da177e2005-04-16 15:20:36 -07001311 default y if ARCH_EBSA110
1312 help
1313 If you say Y here, one of the system LEDs (the green one on the
1314 NetWinder, the amber one on the EBSA285, or the red one on the LART)
1315 will flash regularly to indicate that the system is still
1316 operational. This is mainly useful to kernel hackers who are
1317 debugging unstable kernels.
1318
1319 The LART uses the same LED for both Timer LED and CPU usage LED
1320 functions. You may choose to use both, but the Timer LED function
1321 will overrule the CPU usage LED.
1322
1323config LEDS_CPU
1324 bool "CPU usage LED" if (!ARCH_CDB89712 && !ARCH_EBSA110 && \
David Brownelleebdf7d72007-04-02 12:48:10 -07001325 !ARCH_OMAP) \
1326 || OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
1327 || MACH_OMAP_PERSEUS2
Linus Torvalds1da177e2005-04-16 15:20:36 -07001328 depends on LEDS
1329 help
1330 If you say Y here, the red LED will be used to give a good real
1331 time indication of CPU usage, by lighting whenever the idle task
1332 is not currently executing.
1333
1334 The LART uses the same LED for both Timer LED and CPU usage LED
1335 functions. You may choose to use both, but the Timer LED function
1336 will overrule the CPU usage LED.
1337
1338config ALIGNMENT_TRAP
1339 bool
Hyok S. Choif12d0d72006-09-26 17:36:37 +09001340 depends on CPU_CP15_MMU
Linus Torvalds1da177e2005-04-16 15:20:36 -07001341 default y if !ARCH_EBSA110
Russell Kinge119bff2010-01-10 17:23:29 +00001342 select HAVE_PROC_CPU if PROC_FS
Linus Torvalds1da177e2005-04-16 15:20:36 -07001343 help
Matt LaPlante84eb8d02006-10-03 22:53:09 +02001344 ARM processors cannot fetch/store information which is not
Linus Torvalds1da177e2005-04-16 15:20:36 -07001345 naturally aligned on the bus, i.e., a 4 byte fetch must start at an
1346 address divisible by 4. On 32-bit ARM processors, these non-aligned
1347 fetch/store instructions will be emulated in software if you say
1348 here, which has a severe performance impact. This is necessary for
1349 correct operation of some network protocols. With an IP-only
1350 configuration it is safe to say N, otherwise say Y.
1351
Lennert Buytenhek39ec58f2009-03-09 14:30:09 -04001352config UACCESS_WITH_MEMCPY
1353 bool "Use kernel mem{cpy,set}() for {copy_to,clear}_user() (EXPERIMENTAL)"
1354 depends on MMU && EXPERIMENTAL
1355 default y if CPU_FEROCEON
1356 help
1357 Implement faster copy_to_user and clear_user methods for CPU
1358 cores where a 8-word STM instruction give significantly higher
1359 memory write throughput than a sequence of individual 32bit stores.
1360
1361 A possible side effect is a slight increase in scheduling latency
1362 between threads sharing the same address space if they invoke
1363 such copy operations with large buffers.
1364
1365 However, if the CPU data cache is using a write-allocate mode,
1366 this option is unlikely to provide any performance gain.
1367
Linus Torvalds1da177e2005-04-16 15:20:36 -07001368endmenu
1369
1370menu "Boot options"
1371
1372# Compressed boot loader in ROM. Yes, we really want to ask about
1373# TEXT and BSS so we preserve their values in the config files.
1374config ZBOOT_ROM_TEXT
1375 hex "Compressed ROM boot loader base address"
1376 default "0"
1377 help
1378 The physical address at which the ROM-able zImage is to be
1379 placed in the target. Platforms which normally make use of
1380 ROM-able zImage formats normally set this to a suitable
1381 value in their defconfig file.
1382
1383 If ZBOOT_ROM is not enabled, this has no effect.
1384
1385config ZBOOT_ROM_BSS
1386 hex "Compressed ROM boot loader BSS address"
1387 default "0"
1388 help
Dan Fandrichf8c440b2006-09-20 23:28:51 +01001389 The base address of an area of read/write memory in the target
1390 for the ROM-able zImage which must be available while the
1391 decompressor is running. It must be large enough to hold the
1392 entire decompressed kernel plus an additional 128 KiB.
1393 Platforms which normally make use of ROM-able zImage formats
1394 normally set this to a suitable value in their defconfig file.
Linus Torvalds1da177e2005-04-16 15:20:36 -07001395
1396 If ZBOOT_ROM is not enabled, this has no effect.
1397
1398config ZBOOT_ROM
1399 bool "Compressed boot loader in ROM/flash"
1400 depends on ZBOOT_ROM_TEXT != ZBOOT_ROM_BSS
1401 help
1402 Say Y here if you intend to execute your compressed kernel image
1403 (zImage) directly from ROM or flash. If unsure, say N.
1404
1405config CMDLINE
1406 string "Default kernel command string"
1407 default ""
1408 help
1409 On some architectures (EBSA110 and CATS), there is currently no way
1410 for the boot loader to pass arguments to the kernel. For these
1411 architectures, you should supply some command-line options at build
1412 time by entering them here. As a minimum, you should specify the
1413 memory size and the root device (e.g., mem=64M root=/dev/nfs).
1414
Alexander Holler92d20402010-02-16 19:04:53 +01001415config CMDLINE_FORCE
1416 bool "Always use the default kernel command string"
1417 depends on CMDLINE != ""
1418 help
1419 Always use the default kernel command string, even if the boot
1420 loader passes other arguments to the kernel.
1421 This is useful if you cannot or don't want to change the
1422 command-line options your boot loader passes to the kernel.
1423
1424 If unsure, say N.
1425
Linus Torvalds1da177e2005-04-16 15:20:36 -07001426config XIP_KERNEL
1427 bool "Kernel Execute-In-Place from ROM"
1428 depends on !ZBOOT_ROM
1429 help
1430 Execute-In-Place allows the kernel to run from non-volatile storage
1431 directly addressable by the CPU, such as NOR flash. This saves RAM
1432 space since the text section of the kernel is not loaded from flash
1433 to RAM. Read-write sections, such as the data section and stack,
1434 are still copied to RAM. The XIP kernel is not compressed since
1435 it has to run directly from flash, so it will take more space to
1436 store it. The flash address used to link the kernel object files,
1437 and for storing it, is configuration dependent. Therefore, if you
1438 say Y here, you must know the proper physical address where to
1439 store the kernel image depending on your own flash memory usage.
1440
1441 Also note that the make target becomes "make xipImage" rather than
1442 "make zImage" or "make Image". The final kernel binary to put in
1443 ROM memory will be arch/arm/boot/xipImage.
1444
1445 If unsure, say N.
1446
1447config XIP_PHYS_ADDR
1448 hex "XIP Kernel Physical Location"
1449 depends on XIP_KERNEL
1450 default "0x00080000"
1451 help
1452 This is the physical address in your flash memory the kernel will
1453 be linked for and stored to. This address is dependent on your
1454 own flash usage.
1455
Richard Purdiec587e4a2007-02-06 21:29:00 +01001456config KEXEC
1457 bool "Kexec system call (EXPERIMENTAL)"
1458 depends on EXPERIMENTAL
1459 help
1460 kexec is a system call that implements the ability to shutdown your
1461 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante01dd2fb2007-10-20 01:34:40 +02001462 but it is independent of the system firmware. And like a reboot
Richard Purdiec587e4a2007-02-06 21:29:00 +01001463 you can start any kernel with it, not just Linux.
1464
1465 It is an ongoing process to be certain the hardware in a machine
1466 is properly shutdown, so do not be surprised if this code does not
1467 initially work for you. It may help to enable device hotplugging
1468 support.
1469
Richard Purdie4cd9d6f2008-01-02 00:56:46 +01001470config ATAGS_PROC
1471 bool "Export atags in procfs"
Uli Luckasb98d7292008-02-22 16:45:18 +01001472 depends on KEXEC
1473 default y
Richard Purdie4cd9d6f2008-01-02 00:56:46 +01001474 help
1475 Should the atags used to boot the kernel be exported in an "atags"
1476 file in procfs. Useful with kexec.
1477
Linus Torvalds1da177e2005-04-16 15:20:36 -07001478endmenu
1479
Russell Kingac9d7ef2008-08-18 17:26:00 +01001480menu "CPU Power Management"
Linus Torvalds1da177e2005-04-16 15:20:36 -07001481
Ben Dooks89c52ed2009-07-30 23:23:24 +01001482if ARCH_HAS_CPUFREQ
Linus Torvalds1da177e2005-04-16 15:20:36 -07001483
1484source "drivers/cpufreq/Kconfig"
1485
1486config CPU_FREQ_SA1100
1487 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -07001488
1489config CPU_FREQ_SA1110
1490 bool
Linus Torvalds1da177e2005-04-16 15:20:36 -07001491
1492config CPU_FREQ_INTEGRATOR
1493 tristate "CPUfreq driver for ARM Integrator CPUs"
1494 depends on ARCH_INTEGRATOR && CPU_FREQ
1495 default y
1496 help
1497 This enables the CPUfreq driver for ARM Integrator CPUs.
1498
1499 For details, take a look at <file:Documentation/cpu-freq>.
1500
1501 If in doubt, say Y.
1502
Russell King9e2697f2007-12-14 13:30:14 +00001503config CPU_FREQ_PXA
1504 bool
1505 depends on CPU_FREQ && ARCH_PXA && PXA25x
1506 default y
1507 select CPU_FREQ_DEFAULT_GOV_USERSPACE
1508
Mark Brownb3748dd2009-06-15 11:23:20 +01001509config CPU_FREQ_S3C64XX
1510 bool "CPUfreq support for Samsung S3C64XX CPUs"
1511 depends on CPU_FREQ && CPU_S3C6410
1512
Ben Dooks9d56c022009-07-30 23:23:25 +01001513config CPU_FREQ_S3C
1514 bool
1515 help
1516 Internal configuration node for common cpufreq on Samsung SoC
1517
1518config CPU_FREQ_S3C24XX
1519 bool "CPUfreq driver for Samsung S3C24XX series CPUs"
1520 depends on ARCH_S3C2410 && CPU_FREQ && EXPERIMENTAL
1521 select CPU_FREQ_S3C
1522 help
1523 This enables the CPUfreq driver for the Samsung S3C24XX family
1524 of CPUs.
1525
1526 For details, take a look at <file:Documentation/cpu-freq>.
1527
1528 If in doubt, say N.
1529
1530config CPU_FREQ_S3C24XX_PLL
1531 bool "Support CPUfreq changing of PLL frequency"
1532 depends on CPU_FREQ_S3C24XX && EXPERIMENTAL
1533 help
1534 Compile in support for changing the PLL frequency from the
1535 S3C24XX series CPUfreq driver. The PLL takes time to settle
1536 after a frequency change, so by default it is not enabled.
1537
1538 This also means that the PLL tables for the selected CPU(s) will
1539 be built which may increase the size of the kernel image.
1540
1541config CPU_FREQ_S3C24XX_DEBUG
1542 bool "Debug CPUfreq Samsung driver core"
1543 depends on CPU_FREQ_S3C24XX
1544 help
1545 Enable s3c_freq_dbg for the Samsung S3C CPUfreq core
1546
1547config CPU_FREQ_S3C24XX_IODEBUG
1548 bool "Debug CPUfreq Samsung driver IO timing"
1549 depends on CPU_FREQ_S3C24XX
1550 help
1551 Enable s3c_freq_iodbg for the Samsung S3C CPUfreq core
1552
Ben Dookse6d197a2009-07-30 23:23:42 +01001553config CPU_FREQ_S3C24XX_DEBUGFS
1554 bool "Export debugfs for CPUFreq"
1555 depends on CPU_FREQ_S3C24XX && DEBUG_FS
1556 help
1557 Export status information via debugfs.
1558
Linus Torvalds1da177e2005-04-16 15:20:36 -07001559endif
1560
Russell Kingac9d7ef2008-08-18 17:26:00 +01001561source "drivers/cpuidle/Kconfig"
1562
1563endmenu
1564
Linus Torvalds1da177e2005-04-16 15:20:36 -07001565menu "Floating point emulation"
1566
1567comment "At least one emulation must be selected"
1568
1569config FPE_NWFPE
1570 bool "NWFPE math emulation"
Nicolas Pitre8993a442006-01-14 16:36:50 +00001571 depends on !AEABI || OABI_COMPAT
Linus Torvalds1da177e2005-04-16 15:20:36 -07001572 ---help---
1573 Say Y to include the NWFPE floating point emulator in the kernel.
1574 This is necessary to run most binaries. Linux does not currently
1575 support floating point hardware so you need to say Y here even if
1576 your machine has an FPA or floating point co-processor podule.
1577
1578 You may say N here if you are going to load the Acorn FPEmulator
1579 early in the bootup.
1580
1581config FPE_NWFPE_XP
1582 bool "Support extended precision"
Lennert Buytenhekbedf1422005-11-07 21:12:08 +00001583 depends on FPE_NWFPE
Linus Torvalds1da177e2005-04-16 15:20:36 -07001584 help
1585 Say Y to include 80-bit support in the kernel floating-point
1586 emulator. Otherwise, only 32 and 64-bit support is compiled in.
1587 Note that gcc does not generate 80-bit operations by default,
1588 so in most cases this option only enlarges the size of the
1589 floating point emulator without any good reason.
1590
1591 You almost surely want to say N here.
1592
1593config FPE_FASTFPE
1594 bool "FastFPE math emulation (EXPERIMENTAL)"
Nicolas Pitre8993a442006-01-14 16:36:50 +00001595 depends on (!AEABI || OABI_COMPAT) && !CPU_32v3 && EXPERIMENTAL
Linus Torvalds1da177e2005-04-16 15:20:36 -07001596 ---help---
1597 Say Y here to include the FAST floating point emulator in the kernel.
1598 This is an experimental much faster emulator which now also has full
1599 precision for the mantissa. It does not support any exceptions.
1600 It is very simple, and approximately 3-6 times faster than NWFPE.
1601
1602 It should be sufficient for most programs. It may be not suitable
1603 for scientific calculations, but you have to check this for yourself.
1604 If you do not feel you need a faster FP emulation you should better
1605 choose NWFPE.
1606
1607config VFP
1608 bool "VFP-format floating point maths"
Russell Kingc00d4ff2008-01-28 13:21:30 +00001609 depends on CPU_V6 || CPU_ARM926T || CPU_V7 || CPU_FEROCEON
Linus Torvalds1da177e2005-04-16 15:20:36 -07001610 help
1611 Say Y to include VFP support code in the kernel. This is needed
1612 if your hardware includes a VFP unit.
1613
1614 Please see <file:Documentation/arm/VFP/release-notes.txt> for
1615 release notes and additional status information.
1616
1617 Say N if your target does not have VFP hardware.
1618
Catalin Marinas25ebee02007-09-25 15:22:24 +01001619config VFPv3
1620 bool
1621 depends on VFP
1622 default y if CPU_V7
1623
Catalin Marinasb5872db2008-01-10 19:16:17 +01001624config NEON
1625 bool "Advanced SIMD (NEON) Extension support"
1626 depends on VFPv3 && CPU_V7
1627 help
1628 Say Y to include support code for NEON, the ARMv7 Advanced SIMD
1629 Extension.
1630
Linus Torvalds1da177e2005-04-16 15:20:36 -07001631endmenu
1632
1633menu "Userspace binary formats"
1634
1635source "fs/Kconfig.binfmt"
1636
1637config ARTHUR
1638 tristate "RISC OS personality"
Nicolas Pitre704bdda02006-01-14 16:33:50 +00001639 depends on !AEABI
Linus Torvalds1da177e2005-04-16 15:20:36 -07001640 help
1641 Say Y here to include the kernel code necessary if you want to run
1642 Acorn RISC OS/Arthur binaries under Linux. This code is still very
1643 experimental; if this sounds frightening, say N and sleep in peace.
1644 You can also say M here to compile this support as a module (which
1645 will be called arthur).
1646
1647endmenu
1648
1649menu "Power management options"
1650
Russell Kingeceab4a2005-11-15 11:31:41 +00001651source "kernel/power/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -07001652
Johannes Bergf4cb5702007-12-08 02:14:00 +01001653config ARCH_SUSPEND_POSSIBLE
1654 def_bool y
1655
Linus Torvalds1da177e2005-04-16 15:20:36 -07001656endmenu
1657
Sam Ravnborgd5950b42005-07-11 21:03:49 -07001658source "net/Kconfig"
1659
Uwe Kleine-Königac251502009-08-13 21:09:21 +02001660source "drivers/Kconfig"
Linus Torvalds1da177e2005-04-16 15:20:36 -07001661
1662source "fs/Kconfig"
1663
Linus Torvalds1da177e2005-04-16 15:20:36 -07001664source "arch/arm/Kconfig.debug"
1665
1666source "security/Kconfig"
1667
1668source "crypto/Kconfig"
1669
1670source "lib/Kconfig"