]> bbs.cooldavid.org Git - net-next-2.6.git/blame - arch/arm/Kconfig
Hibernation: Clean up Kconfig (V2)
[net-next-2.6.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
580 The PCI-HOWTO, available from
581 <http://www.tldp.org/docs.html#howto>, contains valuable
582 information about which PCI hardware does work under Linux and which
583 doesn't.
584
36e23590
MW
585config PCI_SYSCALL
586 def_bool PCI
587
1da177e4
LT
588# Select the host bridge type
589config PCI_HOST_VIA82C505
590 bool
591 depends on PCI && ARCH_SHARK
592 default y
593
a0113a99
MR
594config PCI_HOST_ITE8152
595 bool
596 depends on PCI && MACH_ARMCORE
597 default y
598 select DMABOUNCE
599
1da177e4
LT
600source "drivers/pci/Kconfig"
601
602source "drivers/pcmcia/Kconfig"
603
604endmenu
605
606menu "Kernel Features"
607
0567a0c0
KH
608source "kernel/time/Kconfig"
609
1da177e4
LT
610config SMP
611 bool "Symmetric Multi-Processing (EXPERIMENTAL)"
f6db449c 612 depends on EXPERIMENTAL && REALVIEW_MPCORE
1da177e4
LT
613 help
614 This enables support for systems with more than one CPU. If you have
615 a system with only one CPU, like most personal computers, say N. If
616 you have a system with more than one CPU, say Y.
617
618 If you say N here, the kernel will run on single and multiprocessor
619 machines, but will use only one CPU of a multiprocessor machine. If
620 you say Y here, the kernel will run on many, but not all, single
621 processor machines. On a single processor machine, the kernel will
622 run faster if you say N here.
623
12c62c2e
AO
624 See also the <file:Documentation/smp.txt>,
625 <file:Documentation/i386/IO-APIC.txt>,
1da177e4
LT
626 <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
627 <http://www.linuxdoc.org/docs.html#howto>.
628
629 If you don't know what to do here, say N.
630
631config NR_CPUS
632 int "Maximum number of CPUs (2-32)"
633 range 2 32
634 depends on SMP
635 default "4"
636
a054a811
RK
637config HOTPLUG_CPU
638 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
639 depends on SMP && HOTPLUG && EXPERIMENTAL
640 help
641 Say Y here to experiment with turning CPUs off and on. CPUs
642 can be controlled through /sys/devices/system/cpu.
643
37ee16ae
RK
644config LOCAL_TIMERS
645 bool "Use local timer interrupts"
2a98beb6 646 depends on SMP && REALVIEW_MPCORE
37ee16ae
RK
647 default y
648 help
649 Enable support for local timers on SMP platforms, rather then the
650 legacy IPI broadcast method. Local timers allows the system
651 accounting to be spread across the timer interval, preventing a
652 "thundering herd" at every timer tick.
653
1da177e4
LT
654config PREEMPT
655 bool "Preemptible Kernel (EXPERIMENTAL)"
656 depends on EXPERIMENTAL
657 help
658 This option reduces the latency of the kernel when reacting to
659 real-time or interactive events by allowing a low priority process to
660 be preempted even if it is in kernel mode executing a system call.
661 This allows applications to run more reliably even when the system is
662 under load.
663
664 Say Y here if you are building a kernel for a desktop, embedded
665 or real-time system. Say N if you are unsure.
666
8749af68
RK
667config NO_IDLE_HZ
668 bool "Dynamic tick timer"
0567a0c0 669 depends on !GENERIC_CLOCKEVENTS
8749af68
RK
670 help
671 Select this option if you want to disable continuous timer ticks
672 and have them programmed to occur as required. This option saves
673 power as the system can remain in idle state for longer.
674
675 By default dynamic tick is disabled during the boot, and can be
676 manually enabled with:
677
678 echo 1 > /sys/devices/system/timer/timer0/dyn_tick
679
680 Alternatively, if you want dynamic tick automatically enabled
681 during boot, pass "dyntick=enable" via the kernel command string.
682
f2be64b3
TL
683 Please note that dynamic tick may affect the accuracy of
684 timekeeping on some platforms depending on the implementation.
569d2c34
NP
685 Currently at least OMAP, PXA2xx and SA11x0 platforms are known
686 to have accurate timekeeping with dynamic tick.
f2be64b3 687
f8065813
RK
688config HZ
689 int
690 default 128 if ARCH_L7200
691 default 200 if ARCH_EBSA110 || ARCH_S3C2410
bfe65704 692 default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER
5248c657 693 default AT91_TIMER_HZ if ARCH_AT91
f8065813
RK
694 default 100
695
704bdda0
NP
696config AEABI
697 bool "Use the ARM EABI to compile the kernel"
698 help
699 This option allows for the kernel to be compiled using the latest
700 ARM ABI (aka EABI). This is only useful if you are using a user
701 space environment that is also compiled with EABI.
702
703 Since there are major incompatibilities between the legacy ABI and
704 EABI, especially with regard to structure member alignment, this
705 option also changes the kernel syscall calling convention to
706 disambiguate both ABIs and allow for backward compatibility support
707 (selected with CONFIG_OABI_COMPAT).
708
709 To use this you need GCC version 4.0.0 or later.
710
6c90c872 711config OABI_COMPAT
a73a3ff1 712 bool "Allow old ABI binaries to run with this kernel (EXPERIMENTAL)"
61c484d4 713 depends on AEABI && EXPERIMENTAL
6c90c872
NP
714 default y
715 help
716 This option preserves the old syscall interface along with the
717 new (ARM EABI) one. It also provides a compatibility layer to
718 intercept syscalls that have structure arguments which layout
719 in memory differs between the legacy ABI and the new ARM EABI
720 (only for non "thumb" binaries). This option adds a tiny
721 overhead to all syscalls and produces a slightly larger kernel.
722 If you know you'll be using only pure EABI user space then you
723 can say N here. If this option is not selected and you attempt
724 to execute a legacy ABI binary then the result will be
725 UNPREDICTABLE (in fact it can be predicted that it won't work
726 at all). If in doubt say Y.
727
3f22ab27 728config ARCH_DISCONTIGMEM_ENABLE
1da177e4 729 bool
f7e68bbf 730 default (ARCH_LH7A40X && !LH7A40X_CONTIGMEM)
1da177e4
LT
731 help
732 Say Y to support efficient handling of discontiguous physical memory,
733 for architectures which are either NUMA (Non-Uniform Memory Access)
734 or have huge holes in the physical address space for other reasons.
735 See <file:Documentation/vm/numa> for more.
736
c80d79d7
YG
737config NODES_SHIFT
738 int
739 default "4" if ARCH_LH7A40X
740 default "2"
741 depends on NEED_MULTIPLE_NODES
742
3f22ab27
DH
743source "mm/Kconfig"
744
1da177e4
LT
745config LEDS
746 bool "Timer and CPU usage LEDs"
747 depends on ARCH_CDB89712 || ARCH_CO285 || ARCH_EBSA110 || \
748 ARCH_EBSA285 || ARCH_IMX || ARCH_INTEGRATOR || \
749 ARCH_LUBBOCK || MACH_MAINSTONE || ARCH_NETWINDER || \
750 ARCH_OMAP || ARCH_P720T || ARCH_PXA_IDP || \
73a59c1c 751 ARCH_SA1100 || ARCH_SHARK || ARCH_VERSATILE || \
c53c9cf6 752 ARCH_AT91 || MACH_TRIZEPS4 || ARCH_DAVINCI || \
817eb210 753 ARCH_KS8695 || MACH_RD88F5182
1da177e4
LT
754 help
755 If you say Y here, the LEDs on your machine will be used
756 to provide useful information about your current system status.
757
758 If you are compiling a kernel for a NetWinder or EBSA-285, you will
759 be able to select which LEDs are active using the options below. If
760 you are compiling a kernel for the EBSA-110 or the LART however, the
761 red LED will simply flash regularly to indicate that the system is
762 still functional. It is safe to say Y here if you have a CATS
763 system, but the driver will do nothing.
764
765config LEDS_TIMER
766 bool "Timer LED" if (!ARCH_CDB89712 && !ARCH_OMAP) || \
eebdf7d7
DB
767 OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
768 || MACH_OMAP_PERSEUS2
1da177e4 769 depends on LEDS
0567a0c0 770 depends on !GENERIC_CLOCKEVENTS
1da177e4
LT
771 default y if ARCH_EBSA110
772 help
773 If you say Y here, one of the system LEDs (the green one on the
774 NetWinder, the amber one on the EBSA285, or the red one on the LART)
775 will flash regularly to indicate that the system is still
776 operational. This is mainly useful to kernel hackers who are
777 debugging unstable kernels.
778
779 The LART uses the same LED for both Timer LED and CPU usage LED
780 functions. You may choose to use both, but the Timer LED function
781 will overrule the CPU usage LED.
782
783config LEDS_CPU
784 bool "CPU usage LED" if (!ARCH_CDB89712 && !ARCH_EBSA110 && \
eebdf7d7
DB
785 !ARCH_OMAP) \
786 || OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
787 || MACH_OMAP_PERSEUS2
1da177e4
LT
788 depends on LEDS
789 help
790 If you say Y here, the red LED will be used to give a good real
791 time indication of CPU usage, by lighting whenever the idle task
792 is not currently executing.
793
794 The LART uses the same LED for both Timer LED and CPU usage LED
795 functions. You may choose to use both, but the Timer LED function
796 will overrule the CPU usage LED.
797
798config ALIGNMENT_TRAP
799 bool
f12d0d7c 800 depends on CPU_CP15_MMU
1da177e4
LT
801 default y if !ARCH_EBSA110
802 help
84eb8d06 803 ARM processors cannot fetch/store information which is not
1da177e4
LT
804 naturally aligned on the bus, i.e., a 4 byte fetch must start at an
805 address divisible by 4. On 32-bit ARM processors, these non-aligned
806 fetch/store instructions will be emulated in software if you say
807 here, which has a severe performance impact. This is necessary for
808 correct operation of some network protocols. With an IP-only
809 configuration it is safe to say N, otherwise say Y.
810
811endmenu
812
813menu "Boot options"
814
815# Compressed boot loader in ROM. Yes, we really want to ask about
816# TEXT and BSS so we preserve their values in the config files.
817config ZBOOT_ROM_TEXT
818 hex "Compressed ROM boot loader base address"
819 default "0"
820 help
821 The physical address at which the ROM-able zImage is to be
822 placed in the target. Platforms which normally make use of
823 ROM-able zImage formats normally set this to a suitable
824 value in their defconfig file.
825
826 If ZBOOT_ROM is not enabled, this has no effect.
827
828config ZBOOT_ROM_BSS
829 hex "Compressed ROM boot loader BSS address"
830 default "0"
831 help
f8c440b2
DF
832 The base address of an area of read/write memory in the target
833 for the ROM-able zImage which must be available while the
834 decompressor is running. It must be large enough to hold the
835 entire decompressed kernel plus an additional 128 KiB.
836 Platforms which normally make use of ROM-able zImage formats
837 normally set this to a suitable value in their defconfig file.
1da177e4
LT
838
839 If ZBOOT_ROM is not enabled, this has no effect.
840
841config ZBOOT_ROM
842 bool "Compressed boot loader in ROM/flash"
843 depends on ZBOOT_ROM_TEXT != ZBOOT_ROM_BSS
844 help
845 Say Y here if you intend to execute your compressed kernel image
846 (zImage) directly from ROM or flash. If unsure, say N.
847
848config CMDLINE
849 string "Default kernel command string"
850 default ""
851 help
852 On some architectures (EBSA110 and CATS), there is currently no way
853 for the boot loader to pass arguments to the kernel. For these
854 architectures, you should supply some command-line options at build
855 time by entering them here. As a minimum, you should specify the
856 memory size and the root device (e.g., mem=64M root=/dev/nfs).
857
858config XIP_KERNEL
859 bool "Kernel Execute-In-Place from ROM"
860 depends on !ZBOOT_ROM
861 help
862 Execute-In-Place allows the kernel to run from non-volatile storage
863 directly addressable by the CPU, such as NOR flash. This saves RAM
864 space since the text section of the kernel is not loaded from flash
865 to RAM. Read-write sections, such as the data section and stack,
866 are still copied to RAM. The XIP kernel is not compressed since
867 it has to run directly from flash, so it will take more space to
868 store it. The flash address used to link the kernel object files,
869 and for storing it, is configuration dependent. Therefore, if you
870 say Y here, you must know the proper physical address where to
871 store the kernel image depending on your own flash memory usage.
872
873 Also note that the make target becomes "make xipImage" rather than
874 "make zImage" or "make Image". The final kernel binary to put in
875 ROM memory will be arch/arm/boot/xipImage.
876
877 If unsure, say N.
878
879config XIP_PHYS_ADDR
880 hex "XIP Kernel Physical Location"
881 depends on XIP_KERNEL
882 default "0x00080000"
883 help
884 This is the physical address in your flash memory the kernel will
885 be linked for and stored to. This address is dependent on your
886 own flash usage.
887
c587e4a6
RP
888config KEXEC
889 bool "Kexec system call (EXPERIMENTAL)"
890 depends on EXPERIMENTAL
891 help
892 kexec is a system call that implements the ability to shutdown your
893 current kernel, and to start another kernel. It is like a reboot
01dd2fbf 894 but it is independent of the system firmware. And like a reboot
c587e4a6
RP
895 you can start any kernel with it, not just Linux.
896
897 It is an ongoing process to be certain the hardware in a machine
898 is properly shutdown, so do not be surprised if this code does not
899 initially work for you. It may help to enable device hotplugging
900 support.
901
1da177e4
LT
902endmenu
903
9e2697ff 904if (ARCH_SA1100 || ARCH_INTEGRATOR || ARCH_OMAP || ARCH_IMX || ARCH_PXA)
1da177e4
LT
905
906menu "CPU Frequency scaling"
907
908source "drivers/cpufreq/Kconfig"
909
910config CPU_FREQ_SA1100
911 bool
07c6d48f 912 depends on CPU_FREQ && (SA1100_H3100 || SA1100_H3600 || SA1100_H3800 || SA1100_LART || SA1100_PLEB || SA1100_BADGE4 || SA1100_HACKKIT)
1da177e4
LT
913 default y
914
915config CPU_FREQ_SA1110
916 bool
917 depends on CPU_FREQ && (SA1100_ASSABET || SA1100_CERF || SA1100_PT_SYSTEM3)
918 default y
919
920config CPU_FREQ_INTEGRATOR
921 tristate "CPUfreq driver for ARM Integrator CPUs"
922 depends on ARCH_INTEGRATOR && CPU_FREQ
923 default y
924 help
925 This enables the CPUfreq driver for ARM Integrator CPUs.
926
927 For details, take a look at <file:Documentation/cpu-freq>.
928
929 If in doubt, say Y.
930
3c8cd0cc
PP
931config CPU_FREQ_IMX
932 tristate "CPUfreq driver for i.MX CPUs"
933 depends on ARCH_IMX && CPU_FREQ
934 default n
935 help
936 This enables the CPUfreq driver for i.MX CPUs.
937
938 If in doubt, say N.
939
9e2697ff
RK
940config CPU_FREQ_PXA
941 bool
942 depends on CPU_FREQ && ARCH_PXA && PXA25x
943 default y
944 select CPU_FREQ_DEFAULT_GOV_USERSPACE
945
1da177e4
LT
946endmenu
947
948endif
949
950menu "Floating point emulation"
951
952comment "At least one emulation must be selected"
953
954config FPE_NWFPE
955 bool "NWFPE math emulation"
8993a44c 956 depends on !AEABI || OABI_COMPAT
1da177e4
LT
957 ---help---
958 Say Y to include the NWFPE floating point emulator in the kernel.
959 This is necessary to run most binaries. Linux does not currently
960 support floating point hardware so you need to say Y here even if
961 your machine has an FPA or floating point co-processor podule.
962
963 You may say N here if you are going to load the Acorn FPEmulator
964 early in the bootup.
965
966config FPE_NWFPE_XP
967 bool "Support extended precision"
bedf142b 968 depends on FPE_NWFPE
1da177e4
LT
969 help
970 Say Y to include 80-bit support in the kernel floating-point
971 emulator. Otherwise, only 32 and 64-bit support is compiled in.
972 Note that gcc does not generate 80-bit operations by default,
973 so in most cases this option only enlarges the size of the
974 floating point emulator without any good reason.
975
976 You almost surely want to say N here.
977
978config FPE_FASTFPE
979 bool "FastFPE math emulation (EXPERIMENTAL)"
8993a44c 980 depends on (!AEABI || OABI_COMPAT) && !CPU_32v3 && EXPERIMENTAL
1da177e4
LT
981 ---help---
982 Say Y here to include the FAST floating point emulator in the kernel.
983 This is an experimental much faster emulator which now also has full
984 precision for the mantissa. It does not support any exceptions.
985 It is very simple, and approximately 3-6 times faster than NWFPE.
986
987 It should be sufficient for most programs. It may be not suitable
988 for scientific calculations, but you have to check this for yourself.
989 If you do not feel you need a faster FP emulation you should better
990 choose NWFPE.
991
992config VFP
993 bool "VFP-format floating point maths"
c00d4ffd 994 depends on CPU_V6 || CPU_ARM926T || CPU_V7 || CPU_FEROCEON
1da177e4
LT
995 help
996 Say Y to include VFP support code in the kernel. This is needed
997 if your hardware includes a VFP unit.
998
999 Please see <file:Documentation/arm/VFP/release-notes.txt> for
1000 release notes and additional status information.
1001
1002 Say N if your target does not have VFP hardware.
1003
25ebee02
CM
1004config VFPv3
1005 bool
1006 depends on VFP
1007 default y if CPU_V7
1008
b5872db4
CM
1009config NEON
1010 bool "Advanced SIMD (NEON) Extension support"
1011 depends on VFPv3 && CPU_V7
1012 help
1013 Say Y to include support code for NEON, the ARMv7 Advanced SIMD
1014 Extension.
1015
1da177e4
LT
1016endmenu
1017
1018menu "Userspace binary formats"
1019
1020source "fs/Kconfig.binfmt"
1021
1022config ARTHUR
1023 tristate "RISC OS personality"
704bdda0 1024 depends on !AEABI
1da177e4
LT
1025 help
1026 Say Y here to include the kernel code necessary if you want to run
1027 Acorn RISC OS/Arthur binaries under Linux. This code is still very
1028 experimental; if this sounds frightening, say N and sleep in peace.
1029 You can also say M here to compile this support as a module (which
1030 will be called arthur).
1031
1032endmenu
1033
1034menu "Power management options"
1035
eceab4ac 1036source "kernel/power/Kconfig"
1da177e4 1037
1da177e4
LT
1038endmenu
1039
d5950b43
SR
1040source "net/Kconfig"
1041
1da177e4
LT
1042menu "Device Drivers"
1043
1044source "drivers/base/Kconfig"
1045
c35bf4a5
PM
1046source "drivers/connector/Kconfig"
1047
f12d0d7c 1048if ALIGNMENT_TRAP || !CPU_CP15_MMU
1da177e4
LT
1049source "drivers/mtd/Kconfig"
1050endif
1051
1052source "drivers/parport/Kconfig"
1053
1054source "drivers/pnp/Kconfig"
1055
1056source "drivers/block/Kconfig"
1057
58273e55
RK
1058# misc before ide - BLK_DEV_SGIIOC4 depends on SGI_IOC4
1059
1060source "drivers/misc/Kconfig"
1061
3f7e5815 1062if PCMCIA || ARCH_CLPS7500 || ARCH_IOP32X || ARCH_IOP33X || ARCH_IXP4XX \
bb011b8e 1063 || ARCH_L7200 || ARCH_LH7A40X || ARCH_PXA || ARCH_RPC \
c4713074
LB
1064 || ARCH_S3C2410 || ARCH_SA1100 || ARCH_SHARK || FOOTBRIDGE \
1065 || ARCH_IXP23XX
1da177e4
LT
1066source "drivers/ide/Kconfig"
1067endif
1068
1069source "drivers/scsi/Kconfig"
1070
eb370f0b
MM
1071source "drivers/ata/Kconfig"
1072
1da177e4
LT
1073source "drivers/md/Kconfig"
1074
1075source "drivers/message/fusion/Kconfig"
1076
1077source "drivers/ieee1394/Kconfig"
1078
1079source "drivers/message/i2o/Kconfig"
1080
d5950b43 1081source "drivers/net/Kconfig"
1da177e4
LT
1082
1083source "drivers/isdn/Kconfig"
1084
1085# input before char - char/joystick depends on it. As does USB.
1086
1087source "drivers/input/Kconfig"
1088
1089source "drivers/char/Kconfig"
1090
1091source "drivers/i2c/Kconfig"
1092
8ae12a0d
DB
1093source "drivers/spi/Kconfig"
1094
04916c0e
AZ
1095source "drivers/w1/Kconfig"
1096
58273e55
RK
1097source "drivers/power/Kconfig"
1098
ad2f931d
JD
1099source "drivers/hwmon/Kconfig"
1100
70dfa3f8
RK
1101source "drivers/watchdog/Kconfig"
1102
58273e55 1103source "drivers/ssb/Kconfig"
1da177e4 1104
58273e55 1105#source "drivers/l3/Kconfig"
1da177e4 1106
a4e137ab
RK
1107source "drivers/mfd/Kconfig"
1108
1da177e4
LT
1109source "drivers/media/Kconfig"
1110
1111source "drivers/video/Kconfig"
1112
1113source "sound/Kconfig"
1114
c2dade51
SH
1115source "drivers/hid/Kconfig"
1116
1da177e4
LT
1117source "drivers/usb/Kconfig"
1118
1119source "drivers/mmc/Kconfig"
1120
58273e55
RK
1121source "drivers/leds/Kconfig"
1122
12b824fb
AZ
1123source "drivers/rtc/Kconfig"
1124
5816815f
DW
1125source "drivers/dma/Kconfig"
1126
abf07b19
DW
1127source "drivers/dca/Kconfig"
1128
1da177e4
LT
1129endmenu
1130
1131source "fs/Kconfig"
1132
38ad9aeb 1133source "arch/arm/Kconfig.instrumentation"
1da177e4
LT
1134
1135source "arch/arm/Kconfig.debug"
1136
1137source "security/Kconfig"
1138
1139source "crypto/Kconfig"
1140
1141source "lib/Kconfig"