[ARM] nommu: defines CPU_CP15, CPU_CP15_MMU and CPU_CP15_MPU
[deliverable/linux.git] / arch / arm / Kconfig
CommitLineData
1da177e4
LT
1#
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
12b824fb 11 select RTC_LIB
1da177e4
LT
12 help
13 The ARM series is a line of low-power-consumption RISC chip designs
f6c8965a 14 licensed by ARM Ltd and targeted at embedded applications and
1da177e4 15 handhelds such as the Compaq IPAQ. ARM-based PCs are no longer
f6c8965a 16 manufactured, but legacy ARM-based PC hardware remains popular in
1da177e4
LT
17 Europe. There is an ARM Linux project with a web page at
18 <http://www.arm.linux.org.uk/>.
19
20config MMU
21 bool
22 default y
23
24config EISA
25 bool
26 ---help---
27 The Extended Industry Standard Architecture (EISA) bus was
28 developed as an open alternative to the IBM MicroChannel bus.
29
30 The EISA bus provided some of the features of the IBM MicroChannel
31 bus while maintaining backward compatibility with cards made for
32 the older ISA bus. The EISA bus saw limited use between 1988 and
33 1995 when it was made obsolete by the PCI bus.
34
35 Say Y here if you are building a kernel for an EISA-based machine.
36
37 Otherwise, say N.
38
39config SBUS
40 bool
41
42config MCA
43 bool
44 help
45 MicroChannel Architecture is found in some IBM PS/2 machines and
46 laptops. It is a bus system similar to PCI or ISA. See
47 <file:Documentation/mca.txt> (and especially the web page given
48 there) before attempting to build an MCA bus kernel.
49
4a2581a0
TG
50config GENERIC_HARDIRQS
51 bool
52 default y
53
7ad1bcb2
RK
54config TRACE_IRQFLAGS_SUPPORT
55 bool
56 default y
57
4a2581a0
TG
58config HARDIRQS_SW_RESEND
59 bool
60 default y
61
62config GENERIC_IRQ_PROBE
63 bool
64 default y
65
1da177e4
LT
66config RWSEM_GENERIC_SPINLOCK
67 bool
68 default y
69
70config RWSEM_XCHGADD_ALGORITHM
71 bool
72
b89c3b16
AM
73config GENERIC_HWEIGHT
74 bool
75 default y
76
1da177e4
LT
77config GENERIC_CALIBRATE_DELAY
78 bool
79 default y
80
81config GENERIC_BUST_SPINLOCK
82 bool
83
a08b6b79
Z
84config ARCH_MAY_HAVE_PC_FDC
85 bool
86
1da177e4
LT
87config GENERIC_ISA_DMA
88 bool
89
1da177e4
LT
90config FIQ
91 bool
92
034d2f5a
AV
93config ARCH_MTD_XIP
94 bool
95
c760fc19
HC
96config VECTORS_BASE
97 hex
98 default 0xffff0000 if MMU
99 default DRAM_BASE if REMAP_VECTORS_TO_RAM
100 default 0x00000000
101 help
102 The base address of exception vectors.
103
1da177e4
LT
104source "init/Kconfig"
105
106menu "System Type"
107
108choice
109 prompt "ARM system type"
6a0e2430 110 default ARCH_VERSATILE
1da177e4 111
4af6fee1
DS
112config ARCH_AAEC2000
113 bool "Agilent AAEC-2000 based"
114 select ARM_AMBA
115 help
116 This enables support for systems based on the Agilent AAEC-2000
117
118config ARCH_INTEGRATOR
119 bool "ARM Ltd. Integrator family"
120 select ARM_AMBA
121 select ICST525
122 help
123 Support for ARM's Integrator platform.
124
125config ARCH_REALVIEW
126 bool "ARM Ltd. RealView family"
127 select ARM_AMBA
128 select ICST307
129 help
130 This enables support for ARM Ltd RealView boards.
131
132config ARCH_VERSATILE
133 bool "ARM Ltd. Versatile family"
134 select ARM_AMBA
135 select ARM_VIC
136 select ICST307
137 help
138 This enables support for ARM Ltd Versatile board.
139
8fc5ffa0
AV
140config ARCH_AT91
141 bool "Atmel AT91"
4af6fee1 142 help
8fc5ffa0
AV
143 This enables support for systems based on the Atmel AT91RM9200
144 and AT91SAM9xxx processors.
4af6fee1 145
1da177e4 146config ARCH_CLPS7500
4af6fee1 147 bool "Cirrus CL-PS7500FE"
1da177e4 148 select TIMER_ACORN
f7e68bbf 149 select ISA
f999b8bd
MM
150 help
151 Support for the Cirrus Logic PS7500FE system-on-a-chip.
1da177e4
LT
152
153config ARCH_CLPS711X
4af6fee1 154 bool "Cirrus Logic CLPS711x/EP721x-based"
f999b8bd
MM
155 help
156 Support for Cirrus Logic 711x/721x based boards.
1da177e4
LT
157
158config ARCH_CO285
159 bool "Co-EBSA285"
160 select FOOTBRIDGE
161 select FOOTBRIDGE_ADDIN
f999b8bd
MM
162 help
163 Support for Intel's EBSA285 companion chip.
1da177e4
LT
164
165config ARCH_EBSA110
166 bool "EBSA-110"
f7e68bbf 167 select ISA
1da177e4
LT
168 help
169 This is an evaluation board for the StrongARM processor available
f6c8965a 170 from Digital. It has limited hardware on-board, including an
1da177e4
LT
171 Ethernet interface, two PCMCIA sockets, two serial ports and a
172 parallel port.
173
e7736d47
LB
174config ARCH_EP93XX
175 bool "EP93xx-based"
176 select ARM_AMBA
177 select ARM_VIC
178 help
179 This enables support for the Cirrus EP93xx series of CPUs.
180
1da177e4
LT
181config ARCH_FOOTBRIDGE
182 bool "FootBridge"
183 select FOOTBRIDGE
f999b8bd
MM
184 help
185 Support for systems based on the DC21285 companion chip
186 ("FootBridge"), such as the Simtec CATS and the Rebel NetWinder.
1da177e4 187
4af6fee1
DS
188config ARCH_NETX
189 bool "Hilscher NetX based"
190 select ARM_VIC
f999b8bd 191 help
4af6fee1
DS
192 This enables support for systems based on the Hilscher NetX Soc
193
194config ARCH_H720X
195 bool "Hynix HMS720x-based"
196 select ISA_DMA_API
197 help
198 This enables support for systems based on the Hynix HMS720x
199
200config ARCH_IMX
201 bool "IMX"
202 help
203 Support for Motorola's i.MX family of processors (MX1, MXL).
1da177e4 204
3f7e5815
LB
205config ARCH_IOP32X
206 bool "IOP32x-based"
a4f7e763 207 depends on MMU
7ae1f7ec 208 select PLAT_IOP
f7e68bbf 209 select PCI
f999b8bd 210 help
3f7e5815
LB
211 Support for Intel's 80219 and IOP32X (XScale) family of
212 processors.
213
214config ARCH_IOP33X
215 bool "IOP33x-based"
216 depends on MMU
7ae1f7ec 217 select PLAT_IOP
3f7e5815
LB
218 select PCI
219 help
220 Support for Intel's IOP33X (XScale) family of processors.
1da177e4
LT
221
222config ARCH_IXP4XX
223 bool "IXP4xx-based"
a4f7e763 224 depends on MMU
f999b8bd
MM
225 help
226 Support for Intel's IXP4XX (XScale) family of processors.
1da177e4
LT
227
228config ARCH_IXP2000
229 bool "IXP2400/2800-based"
a4f7e763 230 depends on MMU
f7e68bbf 231 select PCI
f999b8bd
MM
232 help
233 Support for Intel's IXP2400/2800 (XScale) family of processors.
1da177e4 234
c4713074
LB
235config ARCH_IXP23XX
236 bool "IXP23XX-based"
a4f7e763 237 depends on MMU
c4713074
LB
238 select PCI
239 help
240 Support for Intel's IXP23xx (XScale) family of processors.
241
1da177e4
LT
242config ARCH_L7200
243 bool "LinkUp-L7200"
244 select FIQ
245 help
246 Say Y here if you intend to run this kernel on a LinkUp Systems
247 L7200 Software Development Board which uses an ARM720T processor.
248 Information on this board can be obtained at:
249
250 <http://www.linkupsys.com/>
251
252 If you have any questions or comments about the Linux kernel port
253 to this board, send e-mail to <sjhill@cotw.com>.
254
4af6fee1
DS
255config ARCH_PNX4008
256 bool "Philips Nexperia PNX4008 Mobile"
257 help
258 This enables support for Philips PNX4008 mobile platform.
259
1da177e4
LT
260config ARCH_PXA
261 bool "PXA2xx-based"
a4f7e763 262 depends on MMU
034d2f5a 263 select ARCH_MTD_XIP
f999b8bd
MM
264 help
265 Support for Intel's PXA2XX processor line.
1da177e4
LT
266
267config ARCH_RPC
268 bool "RiscPC"
269 select ARCH_ACORN
270 select FIQ
271 select TIMER_ACORN
a08b6b79 272 select ARCH_MAY_HAVE_PC_FDC
065909b9 273 select ISA_DMA_API
1da177e4
LT
274 help
275 On the Acorn Risc-PC, Linux can support the internal IDE disk and
276 CD-ROM interface, serial and parallel port, and the floppy drive.
277
278config ARCH_SA1100
279 bool "SA1100-based"
f7e68bbf 280 select ISA
3cd9e19e 281 select ARCH_DISCONTIGMEM_ENABLE
034d2f5a 282 select ARCH_MTD_XIP
f999b8bd
MM
283 help
284 Support for StrongARM 11x0 based boards.
1da177e4
LT
285
286config ARCH_S3C2410
cd701aa2 287 bool "Samsung S3C2410, S3C2412, S3C2413, S3C2440, S3C2442"
1da177e4
LT
288 help
289 Samsung S3C2410X CPU based systems, such as the Simtec Electronics
290 BAST (<http://www.simtec.co.uk/products/EB110ITX/>), the IPAQ 1940 or
f6c8965a 291 the Samsung SMDK2410 development board (and derivatives).
1da177e4
LT
292
293config ARCH_SHARK
294 bool "Shark"
f7e68bbf
RK
295 select ISA
296 select ISA_DMA
297 select PCI
f999b8bd
MM
298 help
299 Support for the StrongARM based Digital DNARD machine, also known
300 as "Shark" (<http://www.shark-linux.de/shark.html>).
1da177e4
LT
301
302config ARCH_LH7A40X
303 bool "Sharp LH7A40X"
304 help
305 Say Y here for systems based on one of the Sharp LH7A40X
306 System on a Chip processors. These CPUs include an ARM922T
307 core with a wide array of integrated devices for
308 hand-held and low-power applications.
309
310config ARCH_OMAP
311 bool "TI OMAP"
f999b8bd
MM
312 help
313 Support for TI's OMAP platform (OMAP1 and OMAP2).
1da177e4 314
1da177e4
LT
315endchoice
316
317source "arch/arm/mach-clps711x/Kconfig"
318
e7736d47
LB
319source "arch/arm/mach-ep93xx/Kconfig"
320
1da177e4
LT
321source "arch/arm/mach-footbridge/Kconfig"
322
323source "arch/arm/mach-integrator/Kconfig"
324
3f7e5815
LB
325source "arch/arm/mach-iop32x/Kconfig"
326
327source "arch/arm/mach-iop33x/Kconfig"
1da177e4
LT
328
329source "arch/arm/mach-ixp4xx/Kconfig"
330
331source "arch/arm/mach-ixp2000/Kconfig"
332
c4713074
LB
333source "arch/arm/mach-ixp23xx/Kconfig"
334
1da177e4
LT
335source "arch/arm/mach-pxa/Kconfig"
336
337source "arch/arm/mach-sa1100/Kconfig"
338
d48af15e
TL
339source "arch/arm/plat-omap/Kconfig"
340
341source "arch/arm/mach-omap1/Kconfig"
1da177e4 342
1dbae815
TL
343source "arch/arm/mach-omap2/Kconfig"
344
1da177e4
LT
345source "arch/arm/mach-s3c2410/Kconfig"
346
347source "arch/arm/mach-lh7a40x/Kconfig"
348
349source "arch/arm/mach-imx/Kconfig"
350
351source "arch/arm/mach-h720x/Kconfig"
352
353source "arch/arm/mach-versatile/Kconfig"
354
038c5b60
BN
355source "arch/arm/mach-aaec2000/Kconfig"
356
8ad68bbf
CM
357source "arch/arm/mach-realview/Kconfig"
358
73a59c1c
SP
359source "arch/arm/mach-at91rm9200/Kconfig"
360
bb6d8c88
SH
361source "arch/arm/mach-netx/Kconfig"
362
1da177e4
LT
363# Definitions to make life easier
364config ARCH_ACORN
365 bool
366
7ae1f7ec
LB
367config PLAT_IOP
368 bool
369
1da177e4
LT
370source arch/arm/mm/Kconfig
371
372# bool 'Use XScale PMU as timer source' CONFIG_XSCALE_PMU_TIMER
373config XSCALE_PMU
374 bool
375 depends on CPU_XSCALE && !XSCALE_PMU_TIMER
376 default y
377
3b93e7b0
HC
378if !MMU
379source "arch/arm/Kconfig-nommu"
380endif
381
1da177e4
LT
382endmenu
383
384source "arch/arm/common/Kconfig"
385
386config FORCE_MAX_ZONEORDER
387 int
388 depends on SA1111
389 default "9"
390
391menu "Bus support"
392
393config ARM_AMBA
394 bool
395
396config ISA
397 bool
1da177e4
LT
398 help
399 Find out whether you have ISA slots on your motherboard. ISA is the
400 name of a bus system, i.e. the way the CPU talks to the other stuff
401 inside your box. Other bus systems are PCI, EISA, MicroChannel
402 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
403 newer boards don't support it. If you have ISA, say Y, otherwise N.
404
065909b9 405# Select ISA DMA controller support
1da177e4
LT
406config ISA_DMA
407 bool
065909b9 408 select ISA_DMA_API
1da177e4 409
065909b9 410# Select ISA DMA interface
5cae841b
AV
411config ISA_DMA_API
412 bool
5cae841b 413
1da177e4 414config PCI
68939121 415 bool "PCI support" if ARCH_INTEGRATOR_AP || ARCH_VERSATILE_PB || ARCH_IXP4XX
1da177e4
LT
416 help
417 Find out whether you have a PCI motherboard. PCI is the name of a
418 bus system, i.e. the way the CPU talks to the other stuff inside
419 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
420 VESA. If you have PCI, say Y, otherwise N.
421
422 The PCI-HOWTO, available from
423 <http://www.tldp.org/docs.html#howto>, contains valuable
424 information about which PCI hardware does work under Linux and which
425 doesn't.
426
427# Select the host bridge type
428config PCI_HOST_VIA82C505
429 bool
430 depends on PCI && ARCH_SHARK
431 default y
432
433source "drivers/pci/Kconfig"
434
435source "drivers/pcmcia/Kconfig"
436
437endmenu
438
439menu "Kernel Features"
440
441config SMP
442 bool "Symmetric Multi-Processing (EXPERIMENTAL)"
f6db449c 443 depends on EXPERIMENTAL && REALVIEW_MPCORE
1da177e4
LT
444 help
445 This enables support for systems with more than one CPU. If you have
446 a system with only one CPU, like most personal computers, say N. If
447 you have a system with more than one CPU, say Y.
448
449 If you say N here, the kernel will run on single and multiprocessor
450 machines, but will use only one CPU of a multiprocessor machine. If
451 you say Y here, the kernel will run on many, but not all, single
452 processor machines. On a single processor machine, the kernel will
453 run faster if you say N here.
454
12c62c2e
AO
455 See also the <file:Documentation/smp.txt>,
456 <file:Documentation/i386/IO-APIC.txt>,
1da177e4
LT
457 <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
458 <http://www.linuxdoc.org/docs.html#howto>.
459
460 If you don't know what to do here, say N.
461
462config NR_CPUS
463 int "Maximum number of CPUs (2-32)"
464 range 2 32
465 depends on SMP
466 default "4"
467
a054a811
RK
468config HOTPLUG_CPU
469 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
470 depends on SMP && HOTPLUG && EXPERIMENTAL
471 help
472 Say Y here to experiment with turning CPUs off and on. CPUs
473 can be controlled through /sys/devices/system/cpu.
474
37ee16ae
RK
475config LOCAL_TIMERS
476 bool "Use local timer interrupts"
2a98beb6 477 depends on SMP && REALVIEW_MPCORE
37ee16ae
RK
478 default y
479 help
480 Enable support for local timers on SMP platforms, rather then the
481 legacy IPI broadcast method. Local timers allows the system
482 accounting to be spread across the timer interval, preventing a
483 "thundering herd" at every timer tick.
484
1da177e4
LT
485config PREEMPT
486 bool "Preemptible Kernel (EXPERIMENTAL)"
487 depends on EXPERIMENTAL
488 help
489 This option reduces the latency of the kernel when reacting to
490 real-time or interactive events by allowing a low priority process to
491 be preempted even if it is in kernel mode executing a system call.
492 This allows applications to run more reliably even when the system is
493 under load.
494
495 Say Y here if you are building a kernel for a desktop, embedded
496 or real-time system. Say N if you are unsure.
497
8749af68
RK
498config NO_IDLE_HZ
499 bool "Dynamic tick timer"
500 help
501 Select this option if you want to disable continuous timer ticks
502 and have them programmed to occur as required. This option saves
503 power as the system can remain in idle state for longer.
504
505 By default dynamic tick is disabled during the boot, and can be
506 manually enabled with:
507
508 echo 1 > /sys/devices/system/timer/timer0/dyn_tick
509
510 Alternatively, if you want dynamic tick automatically enabled
511 during boot, pass "dyntick=enable" via the kernel command string.
512
f2be64b3
TL
513 Please note that dynamic tick may affect the accuracy of
514 timekeeping on some platforms depending on the implementation.
569d2c34
NP
515 Currently at least OMAP, PXA2xx and SA11x0 platforms are known
516 to have accurate timekeeping with dynamic tick.
f2be64b3 517
f8065813
RK
518config HZ
519 int
520 default 128 if ARCH_L7200
521 default 200 if ARCH_EBSA110 || ARCH_S3C2410
bfe65704 522 default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER
f8065813
RK
523 default 100
524
704bdda0
NP
525config AEABI
526 bool "Use the ARM EABI to compile the kernel"
527 help
528 This option allows for the kernel to be compiled using the latest
529 ARM ABI (aka EABI). This is only useful if you are using a user
530 space environment that is also compiled with EABI.
531
532 Since there are major incompatibilities between the legacy ABI and
533 EABI, especially with regard to structure member alignment, this
534 option also changes the kernel syscall calling convention to
535 disambiguate both ABIs and allow for backward compatibility support
536 (selected with CONFIG_OABI_COMPAT).
537
538 To use this you need GCC version 4.0.0 or later.
539
6c90c872 540config OABI_COMPAT
a73a3ff1 541 bool "Allow old ABI binaries to run with this kernel (EXPERIMENTAL)"
61c484d4 542 depends on AEABI && EXPERIMENTAL
6c90c872
NP
543 default y
544 help
545 This option preserves the old syscall interface along with the
546 new (ARM EABI) one. It also provides a compatibility layer to
547 intercept syscalls that have structure arguments which layout
548 in memory differs between the legacy ABI and the new ARM EABI
549 (only for non "thumb" binaries). This option adds a tiny
550 overhead to all syscalls and produces a slightly larger kernel.
551 If you know you'll be using only pure EABI user space then you
552 can say N here. If this option is not selected and you attempt
553 to execute a legacy ABI binary then the result will be
554 UNPREDICTABLE (in fact it can be predicted that it won't work
555 at all). If in doubt say Y.
556
3f22ab27 557config ARCH_DISCONTIGMEM_ENABLE
1da177e4 558 bool
f7e68bbf 559 default (ARCH_LH7A40X && !LH7A40X_CONTIGMEM)
1da177e4
LT
560 help
561 Say Y to support efficient handling of discontiguous physical memory,
562 for architectures which are either NUMA (Non-Uniform Memory Access)
563 or have huge holes in the physical address space for other reasons.
564 See <file:Documentation/vm/numa> for more.
565
c80d79d7
YG
566config NODES_SHIFT
567 int
568 default "4" if ARCH_LH7A40X
569 default "2"
570 depends on NEED_MULTIPLE_NODES
571
3f22ab27
DH
572source "mm/Kconfig"
573
1da177e4
LT
574config LEDS
575 bool "Timer and CPU usage LEDs"
576 depends on ARCH_CDB89712 || ARCH_CO285 || ARCH_EBSA110 || \
577 ARCH_EBSA285 || ARCH_IMX || ARCH_INTEGRATOR || \
578 ARCH_LUBBOCK || MACH_MAINSTONE || ARCH_NETWINDER || \
579 ARCH_OMAP || ARCH_P720T || ARCH_PXA_IDP || \
73a59c1c 580 ARCH_SA1100 || ARCH_SHARK || ARCH_VERSATILE || \