remove Documentation/smp.txt
[GitHub/mt8127/android_kernel_alcatel_ttab.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
75e7153a 12 select SYS_SUPPORTS_APM_EMULATION
1da177e4
LT
13 help
14 The ARM series is a line of low-power-consumption RISC chip designs
f6c8965a 15 licensed by ARM Ltd and targeted at embedded applications and
1da177e4 16 handhelds such as the Compaq IPAQ. ARM-based PCs are no longer
f6c8965a 17 manufactured, but legacy ARM-based PC hardware remains popular in
1da177e4
LT
18 Europe. There is an ARM Linux project with a web page at
19 <http://www.arm.linux.org.uk/>.
20
75e7153a
RB
21config SYS_SUPPORTS_APM_EMULATION
22 bool
23
0a938b97
DB
24config GENERIC_GPIO
25 bool
26 default n
27
746140c7
KH
28config GENERIC_TIME
29 bool
30 default n
31
0567a0c0
KH
32config GENERIC_CLOCKEVENTS
33 bool
34 default n
35
1da177e4
LT
36config MMU
37 bool
38 default y
39
5ea81769
AV
40config NO_IOPORT
41 bool
42 default n
43
1da177e4
LT
44config EISA
45 bool
46 ---help---
47 The Extended Industry Standard Architecture (EISA) bus was
48 developed as an open alternative to the IBM MicroChannel bus.
49
50 The EISA bus provided some of the features of the IBM MicroChannel
51 bus while maintaining backward compatibility with cards made for
52 the older ISA bus. The EISA bus saw limited use between 1988 and
53 1995 when it was made obsolete by the PCI bus.
54
55 Say Y here if you are building a kernel for an EISA-based machine.
56
57 Otherwise, say N.
58
59config SBUS
60 bool
61
62config MCA
63 bool
64 help
65 MicroChannel Architecture is found in some IBM PS/2 machines and
66 laptops. It is a bus system similar to PCI or ISA. See
67 <file:Documentation/mca.txt> (and especially the web page given
68 there) before attempting to build an MCA bus kernel.
69
4a2581a0
TG
70config GENERIC_HARDIRQS
71 bool
72 default y
73
f16fb1ec
RK
74config STACKTRACE_SUPPORT
75 bool
76 default y
77
78config LOCKDEP_SUPPORT
79 bool
80 default y
81
7ad1bcb2
RK
82config TRACE_IRQFLAGS_SUPPORT
83 bool
84 default y
85
4a2581a0
TG
86config HARDIRQS_SW_RESEND
87 bool
88 default y
89
90config GENERIC_IRQ_PROBE
91 bool
92 default y
93
95c354fe
NP
94config GENERIC_LOCKBREAK
95 bool
96 default y
97 depends on SMP && PREEMPT
98
1da177e4
LT
99config RWSEM_GENERIC_SPINLOCK
100 bool
101 default y
102
103config RWSEM_XCHGADD_ALGORITHM
104 bool
105
f0d1b0b3
DH
106config ARCH_HAS_ILOG2_U32
107 bool
108 default n
109
110config ARCH_HAS_ILOG2_U64
111 bool
112 default n
113
b89c3b16
AM
114config GENERIC_HWEIGHT
115 bool
116 default y
117
1da177e4
LT
118config GENERIC_CALIBRATE_DELAY
119 bool
120 default y
121
a08b6b79
AV
122config ARCH_MAY_HAVE_PC_FDC
123 bool
124
5ac6da66
CL
125config ZONE_DMA
126 bool
127 default y
128
1da177e4
LT
129config GENERIC_ISA_DMA
130 bool
131
1da177e4
LT
132config FIQ
133 bool
134
034d2f5a
AV
135config ARCH_MTD_XIP
136 bool
137
c760fc19
HC
138config VECTORS_BASE
139 hex
6afd6fae 140 default 0xffff0000 if MMU || CPU_HIGH_VECTOR
c760fc19
HC
141 default DRAM_BASE if REMAP_VECTORS_TO_RAM
142 default 0x00000000
143 help
144 The base address of exception vectors.
145
1da177e4
LT
146source "init/Kconfig"
147
148menu "System Type"
149
150choice
151 prompt "ARM system type"
6a0e2430 152 default ARCH_VERSATILE
1da177e4 153
4af6fee1
DS
154config ARCH_AAEC2000
155 bool "Agilent AAEC-2000 based"
156 select ARM_AMBA
157 help
158 This enables support for systems based on the Agilent AAEC-2000
159
160config ARCH_INTEGRATOR
161 bool "ARM Ltd. Integrator family"
162 select ARM_AMBA
163 select ICST525
164 help
165 Support for ARM's Integrator platform.
166
167config ARCH_REALVIEW
168 bool "ARM Ltd. RealView family"
169 select ARM_AMBA
170 select ICST307
171 help
172 This enables support for ARM Ltd RealView boards.
173
174config ARCH_VERSATILE
175 bool "ARM Ltd. Versatile family"
176 select ARM_AMBA
177 select ARM_VIC
178 select ICST307
b49c87c2 179 select GENERIC_TIME
89df1272 180 select GENERIC_CLOCKEVENTS
4af6fee1
DS
181 help
182 This enables support for ARM Ltd Versatile board.
183
8fc5ffa0
AV
184config ARCH_AT91
185 bool "Atmel AT91"
0a938b97 186 select GENERIC_GPIO
4af6fee1 187 help
2b3b3516
AV
188 This enables support for systems based on the Atmel AT91RM9200,
189 AT91SAM9 and AT91CAP9 processors.
4af6fee1 190
1da177e4 191config ARCH_CLPS7500
4af6fee1 192 bool "Cirrus CL-PS7500FE"
1da177e4 193 select TIMER_ACORN
f7e68bbf 194 select ISA
e4169889 195 select NO_IOPORT
f999b8bd
MM
196 help
197 Support for the Cirrus Logic PS7500FE system-on-a-chip.
1da177e4
LT
198
199config ARCH_CLPS711X
4af6fee1 200 bool "Cirrus Logic CLPS711x/EP721x-based"
f999b8bd
MM
201 help
202 Support for Cirrus Logic 711x/721x based boards.
1da177e4
LT
203
204config ARCH_CO285
205 bool "Co-EBSA285"
206 select FOOTBRIDGE
207 select FOOTBRIDGE_ADDIN
f999b8bd
MM
208 help
209 Support for Intel's EBSA285 companion chip.
1da177e4
LT
210
211config ARCH_EBSA110
212 bool "EBSA-110"
f7e68bbf 213 select ISA
c5eb2a2b 214 select NO_IOPORT
1da177e4
LT
215 help
216 This is an evaluation board for the StrongARM processor available
f6c8965a 217 from Digital. It has limited hardware on-board, including an
1da177e4
LT
218 Ethernet interface, two PCMCIA sockets, two serial ports and a
219 parallel port.
220
e7736d47
LB
221config ARCH_EP93XX
222 bool "EP93xx-based"
223 select ARM_AMBA
224 select ARM_VIC
4e9f9fd5 225 select GENERIC_GPIO
e7736d47
LB
226 help
227 This enables support for the Cirrus EP93xx series of CPUs.
228
1da177e4
LT
229config ARCH_FOOTBRIDGE
230 bool "FootBridge"
231 select FOOTBRIDGE
f999b8bd
MM
232 help
233 Support for systems based on the DC21285 companion chip
234 ("FootBridge"), such as the Simtec CATS and the Rebel NetWinder.
1da177e4 235
4af6fee1
DS
236config ARCH_NETX
237 bool "Hilscher NetX based"
238 select ARM_VIC
f999b8bd 239 help
4af6fee1
DS
240 This enables support for systems based on the Hilscher NetX Soc
241
242config ARCH_H720X
243 bool "Hynix HMS720x-based"
244 select ISA_DMA_API
245 help
246 This enables support for systems based on the Hynix HMS720x
247
248config ARCH_IMX
249 bool "IMX"
b3e6a508 250 select GENERIC_GPIO
89bba435
PP
251 select GENERIC_TIME
252 select GENERIC_CLOCKEVENTS
4af6fee1
DS
253 help
254 Support for Motorola's i.MX family of processors (MX1, MXL).
1da177e4 255
3b938be6
RK
256config ARCH_IOP13XX
257 bool "IOP13xx-based"
258 depends on MMU
259 select PLAT_IOP
260 select PCI
261 select ARCH_SUPPORTS_MSI
262 help
263 Support for Intel's IOP13XX (XScale) family of processors.
264
3f7e5815
LB
265config ARCH_IOP32X
266 bool "IOP32x-based"
a4f7e763 267 depends on MMU
7ae1f7ec 268 select PLAT_IOP
f7e68bbf 269 select PCI
f999b8bd 270 help
3f7e5815
LB
271 Support for Intel's 80219 and IOP32X (XScale) family of
272 processors.
273
274config ARCH_IOP33X
275 bool "IOP33x-based"
276 depends on MMU
7ae1f7ec 277 select PLAT_IOP
3f7e5815
LB
278 select PCI
279 help
280 Support for Intel's IOP33X (XScale) family of processors.
1da177e4 281
3b938be6
RK
282config ARCH_IXP23XX
283 bool "IXP23XX-based"
a4f7e763 284 depends on MMU
3b938be6 285 select PCI
f999b8bd 286 help
3b938be6 287 Support for Intel's IXP23xx (XScale) family of processors.
1da177e4
LT
288
289config ARCH_IXP2000
290 bool "IXP2400/2800-based"
a4f7e763 291 depends on MMU
f7e68bbf 292 select PCI
f999b8bd
MM
293 help
294 Support for Intel's IXP2400/2800 (XScale) family of processors.
1da177e4 295
3b938be6
RK
296config ARCH_IXP4XX
297 bool "IXP4xx-based"
a4f7e763 298 depends on MMU
8858e9af 299 select GENERIC_GPIO
3b938be6
RK
300 select GENERIC_TIME
301 select GENERIC_CLOCKEVENTS
c4713074 302 help
3b938be6 303 Support for Intel's IXP4XX (XScale) family of processors.
c4713074 304
1da177e4
LT
305config ARCH_L7200
306 bool "LinkUp-L7200"
307 select FIQ
308 help
309 Say Y here if you intend to run this kernel on a LinkUp Systems
310 L7200 Software Development Board which uses an ARM720T processor.
311 Information on this board can be obtained at:
312
313 <http://www.linkupsys.com/>
314
315 If you have any questions or comments about the Linux kernel port
316 to this board, send e-mail to <sjhill@cotw.com>.
317
c53c9cf6
AV
318config ARCH_KS8695
319 bool "Micrel/Kendin KS8695"
8a87a996 320 select GENERIC_GPIO
c53c9cf6
AV
321 help
322 Support for Micrel/Kendin KS8695 "Centaur" (ARM922T) based
323 System-on-Chip devices.
324
9918cda5
UKK
325config ARCH_NS9XXX
326 bool "NetSilicon NS9xxx"
689f2a01 327 select GENERIC_GPIO
cef5975d 328 select GENERIC_TIME
c0bb87f7 329 select GENERIC_CLOCKEVENTS
9918cda5
UKK
330 help
331 Say Y here if you intend to run this kernel on a NetSilicon NS9xxx
332 System.
333
334 <http://www.digi.com/products/microprocessors/index.jsp>
335
52c543f9
QJ
336config ARCH_MXC
337 bool "Freescale MXC/iMX-based"
338 select ARCH_MTD_XIP
339 help
340 Support for Freescale MXC/iMX-based family of processors
341
585cf175
TP
342config ARCH_ORION
343 bool "Marvell Orion"
344 depends on MMU
038ee083 345 select PCI
01af72e4 346 select GENERIC_GPIO
51cbff1d
TP
347 select GENERIC_TIME
348 select GENERIC_CLOCKEVENTS
585cf175
TP
349 help
350 Support for Marvell Orion System on Chip family.
351
4af6fee1
DS
352config ARCH_PNX4008
353 bool "Philips Nexperia PNX4008 Mobile"
354 help
355 This enables support for Philips PNX4008 mobile platform.
356
1da177e4 357config ARCH_PXA
2c8086a5 358 bool "PXA2xx/PXA3xx-based"
a4f7e763 359 depends on MMU
034d2f5a 360 select ARCH_MTD_XIP
0a938b97 361 select GENERIC_GPIO
45cf5eef 362 select GENERIC_TIME
981d0f39 363 select GENERIC_CLOCKEVENTS
a88264c2 364 select TICK_ONESHOT
f999b8bd 365 help
2c8086a5 366 Support for Intel/Marvell's PXA2xx/PXA3xx processor line.
1da177e4
LT
367
368config ARCH_RPC
369 bool "RiscPC"
370 select ARCH_ACORN
371 select FIQ
372 select TIMER_ACORN
a08b6b79 373 select ARCH_MAY_HAVE_PC_FDC
065909b9 374 select ISA_DMA_API
5ea81769 375 select NO_IOPORT
1da177e4
LT
376 help
377 On the Acorn Risc-PC, Linux can support the internal IDE disk and
378 CD-ROM interface, serial and parallel port, and the floppy drive.
379
380config ARCH_SA1100
381 bool "SA1100-based"
f7e68bbf 382 select ISA
3cd9e19e 383 select ARCH_DISCONTIGMEM_ENABLE
034d2f5a 384 select ARCH_MTD_XIP
0a938b97 385 select GENERIC_GPIO
d142b6e7 386 select GENERIC_TIME
f999b8bd
MM
387 help
388 Support for StrongARM 11x0 based boards.
1da177e4
LT
389
390config ARCH_S3C2410
e4d06e39 391 bool "Samsung S3C2410, S3C2412, S3C2413, S3C2440, S3C2442, S3C2443"
0a938b97 392 select GENERIC_GPIO
1da177e4
LT
393 help
394 Samsung S3C2410X CPU based systems, such as the Simtec Electronics
395 BAST (<http://www.simtec.co.uk/products/EB110ITX/>), the IPAQ 1940 or
f6c8965a 396 the Samsung SMDK2410 development board (and derivatives).
1da177e4
LT
397
398config ARCH_SHARK
399 bool "Shark"
f7e68bbf
RK
400 select ISA
401 select ISA_DMA
402 select PCI
f999b8bd
MM
403 help
404 Support for the StrongARM based Digital DNARD machine, also known
405 as "Shark" (<http://www.shark-linux.de/shark.html>).
1da177e4
LT
406
407config ARCH_LH7A40X
408 bool "Sharp LH7A40X"
409 help
410 Say Y here for systems based on one of the Sharp LH7A40X
411 System on a Chip processors. These CPUs include an ARM922T
412 core with a wide array of integrated devices for
413 hand-held and low-power applications.
414
7c6337e2
KH
415config ARCH_DAVINCI
416 bool "TI DaVinci"
417 select GENERIC_TIME
418 select GENERIC_CLOCKEVENTS
3d9edf09 419 select GENERIC_GPIO
7c6337e2
KH
420 help
421 Support for TI's DaVinci platform.
422
3b938be6
RK
423config ARCH_OMAP
424 bool "TI OMAP"
425 select GENERIC_GPIO
426 select GENERIC_TIME
427 help
428 Support for TI's OMAP platform (OMAP1 and OMAP2).
429
3042102a
BS
430config ARCH_MSM7X00A
431 bool "Qualcomm MSM7X00A"
432 select GENERIC_TIME
433 select GENERIC_CLOCKEVENTS
434 help
435 Support for Qualcomm MSM7X00A based systems. This runs on the ARM11
436 apps processor of the MSM7X00A and depends on a shared memory
437 interface to the ARM9 modem processor which runs the baseband stack
438 and controls some vital subsystems (clock and power control, etc).
439 <http://www.cdmatech.com/products/msm7200_chipset_solution.jsp>
440
1da177e4
LT
441endchoice
442
443source "arch/arm/mach-clps711x/Kconfig"
444
e7736d47
LB
445source "arch/arm/mach-ep93xx/Kconfig"
446
1da177e4
LT
447source "arch/arm/mach-footbridge/Kconfig"
448
449source "arch/arm/mach-integrator/Kconfig"
450
3f7e5815
LB
451source "arch/arm/mach-iop32x/Kconfig"
452
453source "arch/arm/mach-iop33x/Kconfig"
1da177e4 454
285f5fa7
DW
455source "arch/arm/mach-iop13xx/Kconfig"
456
1da177e4
LT
457source "arch/arm/mach-ixp4xx/Kconfig"
458
459source "arch/arm/mach-ixp2000/Kconfig"
460
c4713074
LB
461source "arch/arm/mach-ixp23xx/Kconfig"
462
1da177e4
LT
463source "arch/arm/mach-pxa/Kconfig"
464
465source "arch/arm/mach-sa1100/Kconfig"
466
d48af15e
TL
467source "arch/arm/plat-omap/Kconfig"
468
469source "arch/arm/mach-omap1/Kconfig"
1da177e4 470
1dbae815
TL
471source "arch/arm/mach-omap2/Kconfig"
472
585cf175
TP
473source "arch/arm/mach-orion/Kconfig"
474
a21765a7 475source "arch/arm/plat-s3c24xx/Kconfig"
d58153d8 476source "arch/arm/plat-s3c/Kconfig"
a21765a7
BD
477
478if ARCH_S3C2410
479source "arch/arm/mach-s3c2400/Kconfig"
1da177e4 480source "arch/arm/mach-s3c2410/Kconfig"
a21765a7
BD
481source "arch/arm/mach-s3c2412/Kconfig"
482source "arch/arm/mach-s3c2440/Kconfig"
483source "arch/arm/mach-s3c2442/Kconfig"
e4d06e39 484source "arch/arm/mach-s3c2443/Kconfig"
a21765a7 485endif
1da177e4
LT
486
487source "arch/arm/mach-lh7a40x/Kconfig"
488
489source "arch/arm/mach-imx/Kconfig"
490
491source "arch/arm/mach-h720x/Kconfig"
492
493source "arch/arm/mach-versatile/Kconfig"
494
038c5b60
BN
495source "arch/arm/mach-aaec2000/Kconfig"
496
8ad68bbf
CM
497source "arch/arm/mach-realview/Kconfig"
498
9d041268 499source "arch/arm/mach-at91/Kconfig"
73a59c1c 500
52c543f9
QJ
501source "arch/arm/plat-mxc/Kconfig"
502
bb6d8c88
SH
503source "arch/arm/mach-netx/Kconfig"
504
9918cda5
UKK
505source "arch/arm/mach-ns9xxx/Kconfig"
506
7c6337e2
KH
507source "arch/arm/mach-davinci/Kconfig"
508
c53c9cf6
AV
509source "arch/arm/mach-ks8695/Kconfig"
510
9e73c84c
BS
511source "arch/arm/mach-msm/Kconfig"
512
1da177e4
LT
513# Definitions to make life easier
514config ARCH_ACORN
515 bool
516
7ae1f7ec
LB
517config PLAT_IOP
518 bool
519
1da177e4
LT
520source arch/arm/mm/Kconfig
521
afe4b25e
LB
522config IWMMXT
523 bool "Enable iWMMXt support"
6340aa61 524 depends on CPU_XSCALE || CPU_XSC3
2c8086a5 525 default y if PXA27x || PXA3xx
afe4b25e
LB
526 help
527 Enable support for iWMMXt context switching at run time if
528 running on a CPU that supports it.
529
1da177e4
LT
530# bool 'Use XScale PMU as timer source' CONFIG_XSCALE_PMU_TIMER
531config XSCALE_PMU
532 bool
533 depends on CPU_XSCALE && !XSCALE_PMU_TIMER
534 default y
535
3b93e7b0
HC
536if !MMU
537source "arch/arm/Kconfig-nommu"
538endif
539
1da177e4
LT
540endmenu
541
542source "arch/arm/common/Kconfig"
543
544config FORCE_MAX_ZONEORDER
545 int
546 depends on SA1111
547 default "9"
548
549menu "Bus support"
550
551config ARM_AMBA
552 bool
553
554config ISA
555 bool
1da177e4
LT
556 help
557 Find out whether you have ISA slots on your motherboard. ISA is the
558 name of a bus system, i.e. the way the CPU talks to the other stuff
559 inside your box. Other bus systems are PCI, EISA, MicroChannel
560 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
561 newer boards don't support it. If you have ISA, say Y, otherwise N.
562
065909b9 563# Select ISA DMA controller support
1da177e4
LT
564config ISA_DMA
565 bool
065909b9 566 select ISA_DMA_API
1da177e4 567
065909b9 568# Select ISA DMA interface
5cae841b
AV
569config ISA_DMA_API
570 bool
5cae841b 571
1da177e4 572config PCI
a0113a99 573 bool "PCI support" if ARCH_INTEGRATOR_AP || ARCH_VERSATILE_PB || ARCH_IXP4XX || ARCH_KS8695 || MACH_ARMCORE
1da177e4
LT
574 help
575 Find out whether you have a PCI motherboard. PCI is the name of a
576 bus system, i.e. the way the CPU talks to the other stuff inside
577 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
578 VESA. If you have PCI, say Y, otherwise N.
579
36e23590
MW
580config PCI_SYSCALL
581 def_bool PCI
582
1da177e4
LT
583# Select the host bridge type
584config PCI_HOST_VIA82C505
585 bool
586 depends on PCI && ARCH_SHARK
587 default y
588
a0113a99
MR
589config PCI_HOST_ITE8152
590 bool
591 depends on PCI && MACH_ARMCORE
592 default y
593 select DMABOUNCE
594
1da177e4
LT
595source "drivers/pci/Kconfig"
596
597source "drivers/pcmcia/Kconfig"
598
599endmenu
600
601menu "Kernel Features"
602
0567a0c0
KH
603source "kernel/time/Kconfig"
604
1da177e4
LT
605config SMP
606 bool "Symmetric Multi-Processing (EXPERIMENTAL)"
f6db449c 607 depends on EXPERIMENTAL && REALVIEW_MPCORE
1da177e4
LT
608 help
609 This enables support for systems with more than one CPU. If you have
610 a system with only one CPU, like most personal computers, say N. If
611 you have a system with more than one CPU, say Y.
612
613 If you say N here, the kernel will run on single and multiprocessor
614 machines, but will use only one CPU of a multiprocessor machine. If
615 you say Y here, the kernel will run on many, but not all, single
616 processor machines. On a single processor machine, the kernel will
617 run faster if you say N here.
618
03502faa 619 See also <file:Documentation/i386/IO-APIC.txt>,
1da177e4
LT
620 <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
621 <http://www.linuxdoc.org/docs.html#howto>.
622
623 If you don't know what to do here, say N.
624
625config NR_CPUS
626 int "Maximum number of CPUs (2-32)"
627 range 2 32
628 depends on SMP
629 default "4"
630
a054a811
RK
631config HOTPLUG_CPU
632 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
633 depends on SMP && HOTPLUG && EXPERIMENTAL
634 help
635 Say Y here to experiment with turning CPUs off and on. CPUs
636 can be controlled through /sys/devices/system/cpu.
637
37ee16ae
RK
638config LOCAL_TIMERS
639 bool "Use local timer interrupts"
2a98beb6 640 depends on SMP && REALVIEW_MPCORE
37ee16ae
RK
641 default y
642 help
643 Enable support for local timers on SMP platforms, rather then the
644 legacy IPI broadcast method. Local timers allows the system
645 accounting to be spread across the timer interval, preventing a
646 "thundering herd" at every timer tick.
647
1da177e4
LT
648config PREEMPT
649 bool "Preemptible Kernel (EXPERIMENTAL)"
650 depends on EXPERIMENTAL
651 help
652 This option reduces the latency of the kernel when reacting to
653 real-time or interactive events by allowing a low priority process to
654 be preempted even if it is in kernel mode executing a system call.
655 This allows applications to run more reliably even when the system is
656 under load.
657
658 Say Y here if you are building a kernel for a desktop, embedded
659 or real-time system. Say N if you are unsure.
660
8749af68
RK
661config NO_IDLE_HZ
662 bool "Dynamic tick timer"
0567a0c0 663 depends on !GENERIC_CLOCKEVENTS
8749af68
RK
664 help
665 Select this option if you want to disable continuous timer ticks
666 and have them programmed to occur as required. This option saves
667 power as the system can remain in idle state for longer.
668
669 By default dynamic tick is disabled during the boot, and can be
670 manually enabled with:
671
672 echo 1 > /sys/devices/system/timer/timer0/dyn_tick
673
674 Alternatively, if you want dynamic tick automatically enabled
675 during boot, pass "dyntick=enable" via the kernel command string.
676
f2be64b3
TL
677 Please note that dynamic tick may affect the accuracy of
678 timekeeping on some platforms depending on the implementation.
569d2c34
NP
679 Currently at least OMAP, PXA2xx and SA11x0 platforms are known
680 to have accurate timekeeping with dynamic tick.
f2be64b3 681
f8065813
RK
682config HZ
683 int
684 default 128 if ARCH_L7200
685 default 200 if ARCH_EBSA110 || ARCH_S3C2410
bfe65704 686 default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER
5248c657 687 default AT91_TIMER_HZ if ARCH_AT91
f8065813
RK
688 default 100
689
704bdda0
NP
690config AEABI
691 bool "Use the ARM EABI to compile the kernel"
692 help
693 This option allows for the kernel to be compiled using the latest
694 ARM ABI (aka EABI). This is only useful if you are using a user
695 space environment that is also compiled with EABI.
696
697 Since there are major incompatibilities between the legacy ABI and
698 EABI, especially with regard to structure member alignment, this
699 option also changes the kernel syscall calling convention to
700 disambiguate both ABIs and allow for backward compatibility support
701 (selected with CONFIG_OABI_COMPAT).
702
703 To use this you need GCC version 4.0.0 or later.
704
6c90c872 705config OABI_COMPAT
a73a3ff1 706 bool "Allow old ABI binaries to run with this kernel (EXPERIMENTAL)"
61c484d4 707 depends on AEABI && EXPERIMENTAL
6c90c872
NP
708 default y
709 help
710 This option preserves the old syscall interface along with the
711 new (ARM EABI) one. It also provides a compatibility layer to
712 intercept syscalls that have structure arguments which layout
713 in memory differs between the legacy ABI and the new ARM EABI
714 (only for non "thumb" binaries). This option adds a tiny
715 overhead to all syscalls and produces a slightly larger kernel.
716 If you know you'll be using only pure EABI user space then you
717 can say N here. If this option is not selected and you attempt
718 to execute a legacy ABI binary then the result will be
719 UNPREDICTABLE (in fact it can be predicted that it won't work
720 at all). If in doubt say Y.
721
3f22ab27 722config ARCH_DISCONTIGMEM_ENABLE
1da177e4 723 bool
f7e68bbf 724 default (ARCH_LH7A40X && !LH7A40X_CONTIGMEM)
1da177e4
LT
725 help
726 Say Y to support efficient handling of discontiguous physical memory,
727 for architectures which are either NUMA (Non-Uniform Memory Access)
728 or have huge holes in the physical address space for other reasons.
729 See <file:Documentation/vm/numa> for more.
730
c80d79d7
YG
731config NODES_SHIFT
732 int
733 default "4" if ARCH_LH7A40X
734 default "2"
735 depends on NEED_MULTIPLE_NODES
736
3f22ab27
DH
737source "mm/Kconfig"
738
1da177e4
LT
739config LEDS
740 bool "Timer and CPU usage LEDs"
741 depends on ARCH_CDB89712 || ARCH_CO285 || ARCH_EBSA110 || \
742 ARCH_EBSA285 || ARCH_IMX || ARCH_INTEGRATOR || \
743 ARCH_LUBBOCK || MACH_MAINSTONE || ARCH_NETWINDER || \
744 ARCH_OMAP || ARCH_P720T || ARCH_PXA_IDP || \
73a59c1c 745 ARCH_SA1100 || ARCH_SHARK || ARCH_VERSATILE || \
c53c9cf6 746 ARCH_AT91 || MACH_TRIZEPS4 || ARCH_DAVINCI || \
817eb210 747 ARCH_KS8695 || MACH_RD88F5182
1da177e4
LT
748 help
749 If you say Y here, the LEDs on your machine will be used
750 to provide useful information about your current system status.
751
752 If you are compiling a kernel for a NetWinder or EBSA-285, you will
753 be able to select which LEDs are active using the options below. If
754 you are compiling a kernel for the EBSA-110 or the LART however, the
755 red LED will simply flash regularly to indicate that the system is
756 still functional. It is safe to say Y here if you have a CATS
757 system, but the driver will do nothing.
758
759config LEDS_TIMER
760 bool "Timer LED" if (!ARCH_CDB89712 && !ARCH_OMAP) || \
eebdf7d7
DB
761 OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
762 || MACH_OMAP_PERSEUS2
1da177e4 763 depends on LEDS
0567a0c0 764 depends on !GENERIC_CLOCKEVENTS
1da177e4
LT
765 default y if ARCH_EBSA110
766 help
767 If you say Y here, one of the system LEDs (the green one on the
768 NetWinder, the amber one on the EBSA285, or the red one on the LART)
769 will flash regularly to indicate that the system is still
770 operational. This is mainly useful to kernel hackers who are
771 debugging unstable kernels.
772
773 The LART uses the same LED for both Timer LED and CPU usage LED
774 functions. You may choose to use both, but the Timer LED function
775 will overrule the CPU usage LED.
776
777config LEDS_CPU
778 bool "CPU usage LED" if (!ARCH_CDB89712 && !ARCH_EBSA110 && \
eebdf7d7
DB
779 !ARCH_OMAP) \
780 || OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
781 || MACH_OMAP_PERSEUS2
1da177e4
LT
782 depends on LEDS
783 help
784 If you say Y here, the red LED will be used to give a good real
785 time indication of CPU usage, by lighting whenever the idle task
786 is not currently executing.
787
788 The LART uses the same LED for both Timer LED and CPU usage LED
789 functions. You may choose to use both, but the Timer LED function
790 will overrule the CPU usage LED.
791
792config ALIGNMENT_TRAP
793 bool
f12d0d7c 794 depends on CPU_CP15_MMU
1da177e4
LT
795 default y if !ARCH_EBSA110
796 help
84eb8d06 797 ARM processors cannot fetch/store information which is not
1da177e4
LT
798 naturally aligned on the bus, i.e., a 4 byte fetch must start at an
799 address divisible by 4. On 32-bit ARM processors, these non-aligned
800 fetch/store instructions will be emulated in software if you say
801 here, which has a severe performance impact. This is necessary for
802 correct operation of some network protocols. With an IP-only
803 configuration it is safe to say N, otherwise say Y.
804
805endmenu
806
807menu "Boot options"
808
809# Compressed boot loader in ROM. Yes, we really want to ask about
810# TEXT and BSS so we preserve their values in the config files.
811config ZBOOT_ROM_TEXT
812 hex "Compressed ROM boot loader base address"
813 default "0"
814 help
815 The physical address at which the ROM-able zImage is to be
816 placed in the target. Platforms which normally make use of
817 ROM-able zImage formats normally set this to a suitable
818 value in their defconfig file.
819
820 If ZBOOT_ROM is not enabled, this has no effect.
821
822config ZBOOT_ROM_BSS
823 hex "Compressed ROM boot loader BSS address"
824 default "0"
825 help
f8c440b2
DF
826 The base address of an area of read/write memory in the target
827 for the ROM-able zImage which must be available while the
828 decompressor is running. It must be large enough to hold the
829 entire decompressed kernel plus an additional 128 KiB.
830 Platforms which normally make use of ROM-able zImage formats
831 normally set this to a suitable value in their defconfig file.
1da177e4
LT
832
833 If ZBOOT_ROM is not enabled, this has no effect.
834
835config ZBOOT_ROM
836 bool "Compressed boot loader in ROM/flash"
837 depends on ZBOOT_ROM_TEXT != ZBOOT_ROM_BSS
838 help
839 Say Y here if you intend to execute your compressed kernel image
840 (zImage) directly from ROM or flash. If unsure, say N.
841
842config CMDLINE
843 string "Default kernel command string"
844 default ""
845 help
846 On some architectures (EBSA110 and CATS), there is currently no way
847 for the boot loader to pass arguments to the kernel. For these
848 architectures, you should supply some command-line options at build
849 time by entering them here. As a minimum, you should specify the
850 memory size and the root device (e.g., mem=64M root=/dev/nfs).
851
852config XIP_KERNEL
853 bool "Kernel Execute-In-Place from ROM"
854 depends on !ZBOOT_ROM
855 help
856 Execute-In-Place allows the kernel to run from non-volatile storage
857 directly addressable by the CPU, such as NOR flash. This saves RAM
858 space since the text section of the kernel is not loaded from flash
859 to RAM. Read-write sections, such as the data section and stack,
860 are still copied to RAM. The XIP kernel is not compressed since
861 it has to run directly from flash, so it will take more space to
862 store it. The flash address used to link the kernel object files,
863 and for storing it, is configuration dependent. Therefore, if you
864 say Y here, you must know the proper physical address where to
865 store the kernel image depending on your own flash memory usage.
866
867 Also note that the make target becomes "make xipImage" rather than
868 "make zImage" or "make Image". The final kernel binary to put in
869 ROM memory will be arch/arm/boot/xipImage.
870
871 If unsure, say N.
872
873config XIP_PHYS_ADDR
874 hex "XIP Kernel Physical Location"
875 depends on XIP_KERNEL
876 default "0x00080000"
877 help
878 This is the physical address in your flash memory the kernel will
879 be linked for and stored to. This address is dependent on your
880 own flash usage.
881
c587e4a6
RP
882config KEXEC
883 bool "Kexec system call (EXPERIMENTAL)"
884 depends on EXPERIMENTAL
885 help
886 kexec is a system call that implements the ability to shutdown your
887 current kernel, and to start another kernel. It is like a reboot
01dd2fbf 888 but it is independent of the system firmware. And like a reboot
c587e4a6
RP
889 you can start any kernel with it, not just Linux.
890
891 It is an ongoing process to be certain the hardware in a machine
892 is properly shutdown, so do not be surprised if this code does not
893 initially work for you. It may help to enable device hotplugging
894 support.
895
1da177e4
LT
896endmenu
897
9e2697ff 898if (ARCH_SA1100 || ARCH_INTEGRATOR || ARCH_OMAP || ARCH_IMX || ARCH_PXA)
1da177e4
LT
899
900menu "CPU Frequency scaling"
901
902source "drivers/cpufreq/Kconfig"
903
904config CPU_FREQ_SA1100
905 bool
07c6d48f 906 depends on CPU_FREQ && (SA1100_H3100 || SA1100_H3600 || SA1100_H3800 || SA1100_LART || SA1100_PLEB || SA1100_BADGE4 || SA1100_HACKKIT)
1da177e4
LT
907 default y
908
909config CPU_FREQ_SA1110
910 bool
911 depends on CPU_FREQ && (SA1100_ASSABET || SA1100_CERF || SA1100_PT_SYSTEM3)
912 default y
913
914config CPU_FREQ_INTEGRATOR
915 tristate "CPUfreq driver for ARM Integrator CPUs"
916 depends on ARCH_INTEGRATOR && CPU_FREQ
917 default y
918 help
919 This enables the CPUfreq driver for ARM Integrator CPUs.
920
921 For details, take a look at <file:Documentation/cpu-freq>.
922
923 If in doubt, say Y.
924
3c8cd0cc
PP
925config CPU_FREQ_IMX
926 tristate "CPUfreq driver for i.MX CPUs"
927 depends on ARCH_IMX && CPU_FREQ
928 default n
929 help
930 This enables the CPUfreq driver for i.MX CPUs.
931
932 If in doubt, say N.
933
9e2697ff
RK
934config CPU_FREQ_PXA
935 bool
936 depends on CPU_FREQ && ARCH_PXA && PXA25x
937 default y
938 select CPU_FREQ_DEFAULT_GOV_USERSPACE
939
1da177e4
LT
940endmenu
941
942endif
943
944menu "Floating point emulation"
945
946comment "At least one emulation must be selected"
947
948config FPE_NWFPE
949 bool "NWFPE math emulation"
8993a44c 950 depends on !AEABI || OABI_COMPAT
1da177e4
LT
951 ---help---
952 Say Y to include the NWFPE floating point emulator in the kernel.
953 This is necessary to run most binaries. Linux does not currently
954 support floating point hardware so you need to say Y here even if
955 your machine has an FPA or floating point co-processor podule.
956
957 You may say N here if you are going to load the Acorn FPEmulator
958 early in the bootup.
959
960config FPE_NWFPE_XP
961 bool "Support extended precision"
bedf142b 962 depends on FPE_NWFPE
1da177e4
LT
963 help
964 Say Y to include 80-bit support in the kernel floating-point
965 emulator. Otherwise, only 32 and 64-bit support is compiled in.
966 Note that gcc does not generate 80-bit operations by default,
967 so in most cases this option only enlarges the size of the
968 floating point emulator without any good reason.
969
970 You almost surely want to say N here.
971
972config FPE_FASTFPE
973 bool "FastFPE math emulation (EXPERIMENTAL)"
8993a44c 974 depends on (!AEABI || OABI_COMPAT) && !CPU_32v3 && EXPERIMENTAL
1da177e4
LT
975 ---help---
976 Say Y here to include the FAST floating point emulator in the kernel.
977 This is an experimental much faster emulator which now also has full
978 precision for the mantissa. It does not support any exceptions.
979 It is very simple, and approximately 3-6 times faster than NWFPE.
980
981 It should be sufficient for most programs. It may be not suitable
982 for scientific calculations, but you have to check this for yourself.
983 If you do not feel you need a faster FP emulation you should better
984 choose NWFPE.
985
986config VFP
987 bool "VFP-format floating point maths"
c00d4ffd 988 depends on CPU_V6 || CPU_ARM926T || CPU_V7 || CPU_FEROCEON
1da177e4
LT
989 help
990 Say Y to include VFP support code in the kernel. This is needed
991 if your hardware includes a VFP unit.
992
993 Please see <file:Documentation/arm/VFP/release-notes.txt> for
994 release notes and additional status information.
995
996 Say N if your target does not have VFP hardware.
997
25ebee02
CM
998config VFPv3
999 bool
1000 depends on VFP
1001 default y if CPU_V7
1002
b5872db4
CM
1003config NEON
1004 bool "Advanced SIMD (NEON) Extension support"
1005 depends on VFPv3 && CPU_V7
1006 help
1007 Say Y to include support code for NEON, the ARMv7 Advanced SIMD
1008 Extension.
1009
1da177e4
LT
1010endmenu
1011
1012menu "Userspace binary formats"
1013
1014source "fs/Kconfig.binfmt"
1015
1016config ARTHUR
1017 tristate "RISC OS personality"
704bdda0 1018 depends on !AEABI
1da177e4
LT
1019 help
1020 Say Y here to include the kernel code necessary if you want to run
1021 Acorn RISC OS/Arthur binaries under Linux. This code is still very
1022 experimental; if this sounds frightening, say N and sleep in peace.
1023 You can also say M here to compile this support as a module (which
1024 will be called arthur).
1025
1026endmenu
1027
1028menu "Power management options"
1029
eceab4ac 1030source "kernel/power/Kconfig"
1da177e4 1031
f4cb5700
JB
1032config ARCH_SUSPEND_POSSIBLE
1033 def_bool y
1034
1da177e4
LT
1035endmenu
1036
d5950b43
SR
1037source "net/Kconfig"
1038
1da177e4
LT
1039menu "Device Drivers"
1040
1041source "drivers/base/Kconfig"
1042
c35bf4a5
PM
1043source "drivers/connector/Kconfig"
1044
f12d0d7c 1045if ALIGNMENT_TRAP || !CPU_CP15_MMU
1da177e4
LT
1046source "drivers/mtd/Kconfig"
1047endif
1048
1049source "drivers/parport/Kconfig"
1050
1051source "drivers/pnp/Kconfig"
1052
1053source "drivers/block/Kconfig"
1054
58273e55
RK
1055# misc before ide - BLK_DEV_SGIIOC4 depends on SGI_IOC4
1056
1057source "drivers/misc/Kconfig"
1058
3f7e5815 1059if PCMCIA || ARCH_CLPS7500 || ARCH_IOP32X || ARCH_IOP33X || ARCH_IXP4XX \
bb011b8e 1060 || ARCH_L7200 || ARCH_LH7A40X || ARCH_PXA || ARCH_RPC \
c4713074
LB
1061 || ARCH_S3C2410 || ARCH_SA1100 || ARCH_SHARK || FOOTBRIDGE \
1062 || ARCH_IXP23XX
1da177e4
LT
1063source "drivers/ide/Kconfig"
1064endif
1065
1066source "drivers/scsi/Kconfig"
1067
eb370f0b
MM
1068source "drivers/ata/Kconfig"
1069
1da177e4
LT
1070source "drivers/md/Kconfig"
1071
1072source "drivers/message/fusion/Kconfig"
1073
1074source "drivers/ieee1394/Kconfig"
1075
1076source "drivers/message/i2o/Kconfig"
1077
d5950b43 1078source "drivers/net/Kconfig"
1da177e4
LT
1079
1080source "drivers/isdn/Kconfig"
1081
1082# input before char - char/joystick depends on it. As does USB.
1083
1084source "drivers/input/Kconfig"
1085
1086source "drivers/char/Kconfig"
1087
1088source "drivers/i2c/Kconfig"
1089
8ae12a0d
DB
1090source "drivers/spi/Kconfig"
1091
04916c0e
AZ
1092source "drivers/w1/Kconfig"
1093
58273e55
RK
1094source "drivers/power/Kconfig"
1095
ad2f931d
JD
1096source "drivers/hwmon/Kconfig"
1097
70dfa3f8
RK
1098source "drivers/watchdog/Kconfig"
1099
58273e55 1100source "drivers/ssb/Kconfig"
1da177e4 1101
58273e55 1102#source "drivers/l3/Kconfig"
1da177e4 1103
a4e137ab
RK
1104source "drivers/mfd/Kconfig"
1105
1da177e4
LT
1106source "drivers/media/Kconfig"
1107
1108source "drivers/video/Kconfig"
1109
1110source "sound/Kconfig"
1111
c2dade51
SH
1112source "drivers/hid/Kconfig"
1113
1da177e4
LT
1114source "drivers/usb/Kconfig"
1115
1116source "drivers/mmc/Kconfig"
1117
58273e55
RK
1118source "drivers/leds/Kconfig"
1119
12b824fb
AZ
1120source "drivers/rtc/Kconfig"
1121
5816815f
DW
1122source "drivers/dma/Kconfig"
1123
abf07b19
DW
1124source "drivers/dca/Kconfig"
1125
1da177e4
LT
1126endmenu
1127
1128source "fs/Kconfig"
1129
38ad9aeb 1130source "arch/arm/Kconfig.instrumentation"
1da177e4
LT
1131
1132source "arch/arm/Kconfig.debug"
1133
1134source "security/Kconfig"
1135
1136source "crypto/Kconfig"
1137
1138source "lib/Kconfig"