]> bbs.cooldavid.org Git - net-next-2.6.git/blame - arch/arm/Kconfig
[ARM] versatile: add PL061 gpiolib support
[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
e17c6d56 11 select HAVE_AOUT
2064c946 12 select HAVE_IDE
12b824fb 13 select RTC_LIB
75e7153a 14 select SYS_SUPPORTS_APM_EMULATION
42d4b839 15 select HAVE_OPROFILE
5cbad0eb 16 select HAVE_ARCH_KGDB
3f550096 17 select HAVE_KPROBES if (!XIP_KERNEL)
9edddaa2 18 select HAVE_KRETPROBES if (HAVE_KPROBES)
606576ce 19 select HAVE_FUNCTION_TRACER if (!XIP_KERNEL)
1fe53268 20 select HAVE_GENERIC_DMA_COHERENT
1da177e4
LT
21 help
22 The ARM series is a line of low-power-consumption RISC chip designs
f6c8965a 23 licensed by ARM Ltd and targeted at embedded applications and
1da177e4 24 handhelds such as the Compaq IPAQ. ARM-based PCs are no longer
f6c8965a 25 manufactured, but legacy ARM-based PC hardware remains popular in
1da177e4
LT
26 Europe. There is an ARM Linux project with a web page at
27 <http://www.arm.linux.org.uk/>.
28
1a189b97
RK
29config HAVE_PWM
30 bool
31
75e7153a
RB
32config SYS_SUPPORTS_APM_EMULATION
33 bool
34
0a938b97
DB
35config GENERIC_GPIO
36 bool
0a938b97 37
746140c7
KH
38config GENERIC_TIME
39 bool
746140c7 40
0567a0c0
KH
41config GENERIC_CLOCKEVENTS
42 bool
0567a0c0 43
a8655e83
CM
44config GENERIC_CLOCKEVENTS_BROADCAST
45 bool
46 depends on GENERIC_CLOCKEVENTS
47 default y if SMP && !LOCAL_TIMERS
48
1da177e4
LT
49config MMU
50 bool
51 default y
52
5ea81769
AV
53config NO_IOPORT
54 bool
5ea81769 55
1da177e4
LT
56config EISA
57 bool
58 ---help---
59 The Extended Industry Standard Architecture (EISA) bus was
60 developed as an open alternative to the IBM MicroChannel bus.
61
62 The EISA bus provided some of the features of the IBM MicroChannel
63 bus while maintaining backward compatibility with cards made for
64 the older ISA bus. The EISA bus saw limited use between 1988 and
65 1995 when it was made obsolete by the PCI bus.
66
67 Say Y here if you are building a kernel for an EISA-based machine.
68
69 Otherwise, say N.
70
71config SBUS
72 bool
73
74config MCA
75 bool
76 help
77 MicroChannel Architecture is found in some IBM PS/2 machines and
78 laptops. It is a bus system similar to PCI or ISA. See
79 <file:Documentation/mca.txt> (and especially the web page given
80 there) before attempting to build an MCA bus kernel.
81
4a2581a0
TG
82config GENERIC_HARDIRQS
83 bool
84 default y
85
f16fb1ec
RK
86config STACKTRACE_SUPPORT
87 bool
88 default y
89
f76e9154
NP
90config HAVE_LATENCYTOP_SUPPORT
91 bool
92 depends on !SMP
93 default y
94
f16fb1ec
RK
95config LOCKDEP_SUPPORT
96 bool
97 default y
98
7ad1bcb2
RK
99config TRACE_IRQFLAGS_SUPPORT
100 bool
101 default y
102
4a2581a0
TG
103config HARDIRQS_SW_RESEND
104 bool
105 default y
106
107config GENERIC_IRQ_PROBE
108 bool
109 default y
110
95c354fe
NP
111config GENERIC_LOCKBREAK
112 bool
113 default y
114 depends on SMP && PREEMPT
115
1da177e4
LT
116config RWSEM_GENERIC_SPINLOCK
117 bool
118 default y
119
120config RWSEM_XCHGADD_ALGORITHM
121 bool
122
f0d1b0b3
DH
123config ARCH_HAS_ILOG2_U32
124 bool
f0d1b0b3
DH
125
126config ARCH_HAS_ILOG2_U64
127 bool
f0d1b0b3 128
b89c3b16
AM
129config GENERIC_HWEIGHT
130 bool
131 default y
132
1da177e4
LT
133config GENERIC_CALIBRATE_DELAY
134 bool
135 default y
136
a08b6b79
AV
137config ARCH_MAY_HAVE_PC_FDC
138 bool
139
5ac6da66
CL
140config ZONE_DMA
141 bool
5ac6da66 142
1da177e4
LT
143config GENERIC_ISA_DMA
144 bool
145
1da177e4
LT
146config FIQ
147 bool
148
034d2f5a
AV
149config ARCH_MTD_XIP
150 bool
151
60a752ef 152config GENERIC_HARDIRQS_NO__DO_IRQ
60a752ef
PZ
153 def_bool y
154
c0ffa3a9
MD
155if OPROFILE
156
157config OPROFILE_ARMV6
158 def_bool y
159 depends on CPU_V6 && !SMP
160 select OPROFILE_ARM11_CORE
161
162config OPROFILE_MPCORE
163 def_bool y
164 depends on CPU_V6 && SMP
165 select OPROFILE_ARM11_CORE
166
167config OPROFILE_ARM11_CORE
168 bool
169
d7ac4e28
JP
170config OPROFILE_ARMV7
171 def_bool y
172 depends on CPU_V7 && !SMP
173 bool
174
c0ffa3a9
MD
175endif
176
c760fc19
HC
177config VECTORS_BASE
178 hex
6afd6fae 179 default 0xffff0000 if MMU || CPU_HIGH_VECTOR
c760fc19
HC
180 default DRAM_BASE if REMAP_VECTORS_TO_RAM
181 default 0x00000000
182 help
183 The base address of exception vectors.
184
1da177e4
LT
185source "init/Kconfig"
186
dc52ddc0
MH
187source "kernel/Kconfig.freezer"
188
1da177e4
LT
189menu "System Type"
190
191choice
192 prompt "ARM system type"
6a0e2430 193 default ARCH_VERSATILE
1da177e4 194
4af6fee1
DS
195config ARCH_AAEC2000
196 bool "Agilent AAEC-2000 based"
c750815e 197 select CPU_ARM920T
4af6fee1 198 select ARM_AMBA
9483a578 199 select HAVE_CLK
4af6fee1
DS
200 help
201 This enables support for systems based on the Agilent AAEC-2000
202
203config ARCH_INTEGRATOR
204 bool "ARM Ltd. Integrator family"
205 select ARM_AMBA
9483a578 206 select HAVE_CLK
d72fbdf0 207 select COMMON_CLKDEV
4af6fee1
DS
208 select ICST525
209 help
210 Support for ARM's Integrator platform.
211
212config ARCH_REALVIEW
213 bool "ARM Ltd. RealView family"
214 select ARM_AMBA
9483a578 215 select HAVE_CLK
cf30fb4a 216 select COMMON_CLKDEV
4af6fee1 217 select ICST307
85802afe 218 select GENERIC_TIME
ae30ceac 219 select GENERIC_CLOCKEVENTS
4af6fee1
DS
220 help
221 This enables support for ARM Ltd RealView boards.
222
223config ARCH_VERSATILE
224 bool "ARM Ltd. Versatile family"
225 select ARM_AMBA
226 select ARM_VIC
9483a578 227 select HAVE_CLK
71a06da0 228 select COMMON_CLKDEV
4af6fee1 229 select ICST307
b49c87c2 230 select GENERIC_TIME
89df1272 231 select GENERIC_CLOCKEVENTS
bbeddc43 232 select ARCH_WANT_OPTIONAL_GPIOLIB
4af6fee1
DS
233 help
234 This enables support for ARM Ltd Versatile board.
235
8fc5ffa0
AV
236config ARCH_AT91
237 bool "Atmel AT91"
0a938b97 238 select GENERIC_GPIO
f373e8c0 239 select ARCH_REQUIRE_GPIOLIB
93686ae8 240 select HAVE_CLK
4af6fee1 241 help
2b3b3516
AV
242 This enables support for systems based on the Atmel AT91RM9200,
243 AT91SAM9 and AT91CAP9 processors.
4af6fee1 244
1da177e4 245config ARCH_CLPS711X
4af6fee1 246 bool "Cirrus Logic CLPS711x/EP721x-based"
c750815e 247 select CPU_ARM720T
f999b8bd
MM
248 help
249 Support for Cirrus Logic 711x/721x based boards.
1da177e4 250
788c9700
RK
251config ARCH_GEMINI
252 bool "Cortina Systems Gemini"
253 select CPU_FA526
254 select GENERIC_GPIO
255 select ARCH_REQUIRE_GPIOLIB
256 help
257 Support for the Cortina Systems Gemini family SoCs
258
1da177e4
LT
259config ARCH_EBSA110
260 bool "EBSA-110"
c750815e 261 select CPU_SA110
f7e68bbf 262 select ISA
c5eb2a2b 263 select NO_IOPORT
1da177e4
LT
264 help
265 This is an evaluation board for the StrongARM processor available
f6c8965a 266 from Digital. It has limited hardware on-board, including an
1da177e4
LT
267 Ethernet interface, two PCMCIA sockets, two serial ports and a
268 parallel port.
269
e7736d47
LB
270config ARCH_EP93XX
271 bool "EP93xx-based"
c750815e 272 select CPU_ARM920T
e7736d47
LB
273 select ARM_AMBA
274 select ARM_VIC
4e9f9fd5 275 select GENERIC_GPIO
9483a578 276 select HAVE_CLK
ae696fd5 277 select COMMON_CLKDEV
7444a72e 278 select ARCH_REQUIRE_GPIOLIB
eb33575c 279 select ARCH_HAS_HOLES_MEMORYMODEL
e7736d47
LB
280 help
281 This enables support for the Cirrus EP93xx series of CPUs.
282
1da177e4
LT
283config ARCH_FOOTBRIDGE
284 bool "FootBridge"
c750815e 285 select CPU_SA110
1da177e4 286 select FOOTBRIDGE
f999b8bd
MM
287 help
288 Support for systems based on the DC21285 companion chip
289 ("FootBridge"), such as the Simtec CATS and the Rebel NetWinder.
1da177e4 290
788c9700
RK
291config ARCH_MXC
292 bool "Freescale MXC/iMX-based"
293 select GENERIC_TIME
294 select GENERIC_CLOCKEVENTS
295 select ARCH_MTD_XIP
296 select GENERIC_GPIO
297 select ARCH_REQUIRE_GPIOLIB
a2ab67fa 298 select HAVE_CLK
788c9700
RK
299 help
300 Support for Freescale MXC/iMX-based family of processors
301
7bd0f2f5 302config ARCH_STMP3XXX
303 bool "Freescale STMP3xxx"
304 select CPU_ARM926T
305 select HAVE_CLK
306 select COMMON_CLKDEV
307 select ARCH_REQUIRE_GPIOLIB
308 select GENERIC_TIME
309 select GENERIC_CLOCKEVENTS
310 select GENERIC_GPIO
311 select USB_ARCH_HAS_EHCI
312 help
313 Support for systems based on the Freescale 3xxx CPUs.
314
4af6fee1
DS
315config ARCH_NETX
316 bool "Hilscher NetX based"
c750815e 317 select CPU_ARM926T
4af6fee1 318 select ARM_VIC
2fcfe6b8 319 select GENERIC_CLOCKEVENTS
21edecd3 320 select GENERIC_TIME
f999b8bd 321 help
4af6fee1
DS
322 This enables support for systems based on the Hilscher NetX Soc
323
324config ARCH_H720X
325 bool "Hynix HMS720x-based"
c750815e 326 select CPU_ARM720T
4af6fee1
DS
327 select ISA_DMA_API
328 help
329 This enables support for systems based on the Hynix HMS720x
330
3b938be6
RK
331config ARCH_IOP13XX
332 bool "IOP13xx-based"
333 depends on MMU
c750815e 334 select CPU_XSC3
3b938be6
RK
335 select PLAT_IOP
336 select PCI
337 select ARCH_SUPPORTS_MSI
8d5796d2 338 select VMSPLIT_1G
3b938be6
RK
339 help
340 Support for Intel's IOP13XX (XScale) family of processors.
341
3f7e5815
LB
342config ARCH_IOP32X
343 bool "IOP32x-based"
a4f7e763 344 depends on MMU
c750815e 345 select CPU_XSCALE
7ae1f7ec 346 select PLAT_IOP
f7e68bbf 347 select PCI
63f385cd 348 select GENERIC_GPIO
bb2b180c 349 select ARCH_REQUIRE_GPIOLIB
f999b8bd 350 help
3f7e5815
LB
351 Support for Intel's 80219 and IOP32X (XScale) family of
352 processors.
353
354config ARCH_IOP33X
355 bool "IOP33x-based"
356 depends on MMU
c750815e 357 select CPU_XSCALE
7ae1f7ec 358 select PLAT_IOP
3f7e5815 359 select PCI
63f385cd 360 select GENERIC_GPIO
bb2b180c 361 select ARCH_REQUIRE_GPIOLIB
3f7e5815
LB
362 help
363 Support for Intel's IOP33X (XScale) family of processors.
1da177e4 364
3b938be6
RK
365config ARCH_IXP23XX
366 bool "IXP23XX-based"
a4f7e763 367 depends on MMU
c750815e 368 select CPU_XSC3
3b938be6 369 select PCI
f999b8bd 370 help
3b938be6 371 Support for Intel's IXP23xx (XScale) family of processors.
1da177e4
LT
372
373config ARCH_IXP2000
374 bool "IXP2400/2800-based"
a4f7e763 375 depends on MMU
c750815e 376 select CPU_XSCALE
f7e68bbf 377 select PCI
f999b8bd
MM
378 help
379 Support for Intel's IXP2400/2800 (XScale) family of processors.
1da177e4 380
3b938be6
RK
381config ARCH_IXP4XX
382 bool "IXP4xx-based"
a4f7e763 383 depends on MMU
c750815e 384 select CPU_XSCALE
8858e9af 385 select GENERIC_GPIO
3b938be6
RK
386 select GENERIC_TIME
387 select GENERIC_CLOCKEVENTS
485bdde7 388 select DMABOUNCE if PCI
c4713074 389 help
3b938be6 390 Support for Intel's IXP4XX (XScale) family of processors.
c4713074 391
1da177e4
LT
392config ARCH_L7200
393 bool "LinkUp-L7200"
c750815e 394 select CPU_ARM720T
1da177e4
LT
395 select FIQ
396 help
397 Say Y here if you intend to run this kernel on a LinkUp Systems
398 L7200 Software Development Board which uses an ARM720T processor.
399 Information on this board can be obtained at:
400
401 <http://www.linkupsys.com/>
402
403 If you have any questions or comments about the Linux kernel port
404 to this board, send e-mail to <sjhill@cotw.com>.
405
651c74c7
SB
406config ARCH_KIRKWOOD
407 bool "Marvell Kirkwood"
c750815e 408 select CPU_FEROCEON
651c74c7 409 select PCI
4c213430 410 select GENERIC_GPIO
a8865655 411 select ARCH_REQUIRE_GPIOLIB
651c74c7
SB
412 select GENERIC_TIME
413 select GENERIC_CLOCKEVENTS
414 select PLAT_ORION
415 help
416 Support for the following Marvell Kirkwood series SoCs:
417 88F6180, 88F6192 and 88F6281.
418
777f9beb
LB
419config ARCH_LOKI
420 bool "Marvell Loki (88RC8480)"
c750815e 421 select CPU_FEROCEON
777f9beb
LB
422 select GENERIC_TIME
423 select GENERIC_CLOCKEVENTS
424 select PLAT_ORION
425 help
426 Support for the Marvell Loki (88RC8480) SoC.
427
794d15b2
SS
428config ARCH_MV78XX0
429 bool "Marvell MV78xx0"
c750815e 430 select CPU_FEROCEON
794d15b2 431 select PCI
b95a13d7 432 select GENERIC_GPIO
a8865655 433 select ARCH_REQUIRE_GPIOLIB
794d15b2
SS
434 select GENERIC_TIME
435 select GENERIC_CLOCKEVENTS
436 select PLAT_ORION
437 help
438 Support for the following Marvell MV78xx0 series SoCs:
439 MV781x0, MV782x0.
440
9dd0b194 441config ARCH_ORION5X
585cf175
TP
442 bool "Marvell Orion"
443 depends on MMU
c750815e 444 select CPU_FEROCEON
038ee083 445 select PCI
01af72e4 446 select GENERIC_GPIO
a8865655 447 select ARCH_REQUIRE_GPIOLIB
51cbff1d
TP
448 select GENERIC_TIME
449 select GENERIC_CLOCKEVENTS
69b02f6a 450 select PLAT_ORION
585cf175 451 help
9dd0b194 452 Support for the following Marvell Orion 5x series SoCs:
d2b2a6bb 453 Orion-1 (5181), Orion-VoIP (5181L), Orion-NAS (5182),
d323ade1 454 Orion-2 (5281), Orion-1-90 (6183).
585cf175 455
788c9700
RK
456config ARCH_MMP
457 bool "Marvell PXA168/910"
458 depends on MMU
459 select GENERIC_GPIO
460 select ARCH_REQUIRE_GPIOLIB
461 select HAVE_CLK
462 select COMMON_CLKDEV
463 select GENERIC_TIME
464 select GENERIC_CLOCKEVENTS
465 select TICK_ONESHOT
466 select PLAT_PXA
467 help
468 Support for Marvell's PXA168/910 processor line.
469
470config ARCH_KS8695
471 bool "Micrel/Kendin KS8695"
472 select CPU_ARM922T
473 select GENERIC_GPIO
474 select ARCH_REQUIRE_GPIOLIB
475 help
476 Support for Micrel/Kendin KS8695 "Centaur" (ARM922T) based
477 System-on-Chip devices.
478
479config ARCH_NS9XXX
480 bool "NetSilicon NS9xxx"
481 select CPU_ARM926T
482 select GENERIC_GPIO
483 select GENERIC_TIME
484 select GENERIC_CLOCKEVENTS
485 select HAVE_CLK
486 help
487 Say Y here if you intend to run this kernel on a NetSilicon NS9xxx
488 System.
489
490 <http://www.digi.com/products/microprocessors/index.jsp>
491
492config ARCH_W90X900
493 bool "Nuvoton W90X900 CPU"
494 select CPU_ARM926T
c52d3d68 495 select ARCH_REQUIRE_GPIOLIB
496 select GENERIC_GPIO
0e4a34bb 497 select COMMON_CLKDEV
788c9700
RK
498 help
499 Support for Nuvoton (Winbond logic dept.) ARM9 processor,You
500 can login www.mcuos.com or www.nuvoton.com to know more.
501
4af6fee1
DS
502config ARCH_PNX4008
503 bool "Philips Nexperia PNX4008 Mobile"
c750815e 504 select CPU_ARM926T
9483a578 505 select HAVE_CLK
4af6fee1
DS
506 help
507 This enables support for Philips PNX4008 mobile platform.
508
1da177e4 509config ARCH_PXA
2c8086a5 510 bool "PXA2xx/PXA3xx-based"
a4f7e763 511 depends on MMU
034d2f5a 512 select ARCH_MTD_XIP
0a938b97 513 select GENERIC_GPIO
9483a578 514 select HAVE_CLK
8c3abc7d 515 select COMMON_CLKDEV
7444a72e 516 select ARCH_REQUIRE_GPIOLIB
45cf5eef 517 select GENERIC_TIME
981d0f39 518 select GENERIC_CLOCKEVENTS
a88264c2 519 select TICK_ONESHOT
bd5ce433 520 select PLAT_PXA
f999b8bd 521 help
2c8086a5 522 Support for Intel/Marvell's PXA2xx/PXA3xx processor line.
1da177e4 523
788c9700
RK
524config ARCH_MSM
525 bool "Qualcomm MSM"
526 select CPU_V6
49cbe786
EM
527 select GENERIC_TIME
528 select GENERIC_CLOCKEVENTS
49cbe786 529 help
788c9700
RK
530 Support for Qualcomm MSM7K based systems. This runs on the ARM11
531 apps processor of the MSM7K and depends on a shared memory
532 interface to the ARM9 modem processor which runs the baseband stack
533 and controls some vital subsystems (clock and power control, etc).
49cbe786 534
1da177e4
LT
535config ARCH_RPC
536 bool "RiscPC"
537 select ARCH_ACORN
538 select FIQ
539 select TIMER_ACORN
a08b6b79 540 select ARCH_MAY_HAVE_PC_FDC
341eb781 541 select HAVE_PATA_PLATFORM
065909b9 542 select ISA_DMA_API
5ea81769 543 select NO_IOPORT
07f841b7 544 select ARCH_SPARSEMEM_ENABLE
1da177e4
LT
545 help
546 On the Acorn Risc-PC, Linux can support the internal IDE disk and
547 CD-ROM interface, serial and parallel port, and the floppy drive.
548
549config ARCH_SA1100
550 bool "SA1100-based"
c750815e 551 select CPU_SA1100
f7e68bbf 552 select ISA
05944d74 553 select ARCH_SPARSEMEM_ENABLE
034d2f5a 554 select ARCH_MTD_XIP
0a938b97 555 select GENERIC_GPIO
d142b6e7 556 select GENERIC_TIME
3e238be2 557 select GENERIC_CLOCKEVENTS
9483a578 558 select HAVE_CLK
3e238be2 559 select TICK_ONESHOT
7444a72e 560 select ARCH_REQUIRE_GPIOLIB
f999b8bd
MM
561 help
562 Support for StrongARM 11x0 based boards.
1da177e4
LT
563
564config ARCH_S3C2410
e4d06e39 565 bool "Samsung S3C2410, S3C2412, S3C2413, S3C2440, S3C2442, S3C2443"
0a938b97 566 select GENERIC_GPIO
9483a578 567 select HAVE_CLK
1da177e4
LT
568 help
569 Samsung S3C2410X CPU based systems, such as the Simtec Electronics
570 BAST (<http://www.simtec.co.uk/products/EB110ITX/>), the IPAQ 1940 or
f6c8965a 571 the Samsung SMDK2410 development board (and derivatives).
1da177e4 572
a08ab637
BD
573config ARCH_S3C64XX
574 bool "Samsung S3C64XX"
575 select GENERIC_GPIO
576 select HAVE_CLK
577 help
578 Samsung S3C64XX series based systems
579
1da177e4
LT
580config ARCH_SHARK
581 bool "Shark"
c750815e 582 select CPU_SA110
f7e68bbf
RK
583 select ISA
584 select ISA_DMA
3bca103a 585 select ZONE_DMA
f7e68bbf 586 select PCI
f999b8bd
MM
587 help
588 Support for the StrongARM based Digital DNARD machine, also known
589 as "Shark" (<http://www.shark-linux.de/shark.html>).
1da177e4
LT
590
591config ARCH_LH7A40X
592 bool "Sharp LH7A40X"
c750815e 593 select CPU_ARM922T
4ba3f7c5
RK
594 select ARCH_DISCONTIGMEM_ENABLE if !LH7A40X_CONTIGMEM
595 select ARCH_SPARSEMEM_ENABLE if !LH7A40X_CONTIGMEM
1da177e4
LT
596 help
597 Say Y here for systems based on one of the Sharp LH7A40X
598 System on a Chip processors. These CPUs include an ARM922T
599 core with a wide array of integrated devices for
600 hand-held and low-power applications.
601
d98aac75
LW
602config ARCH_U300
603 bool "ST-Ericsson U300 Series"
604 depends on MMU
605 select CPU_ARM926T
606 select ARM_AMBA
607 select ARM_VIC
608 select GENERIC_TIME
609 select GENERIC_CLOCKEVENTS
610 select HAVE_CLK
611 select COMMON_CLKDEV
612 select GENERIC_GPIO
613 help
614 Support for ST-Ericsson U300 series mobile platforms.
615
7c6337e2
KH
616config ARCH_DAVINCI
617 bool "TI DaVinci"
c750815e 618 select CPU_ARM926T
7c6337e2
KH
619 select GENERIC_TIME
620 select GENERIC_CLOCKEVENTS
3d9edf09 621 select GENERIC_GPIO
dce1115b 622 select ARCH_REQUIRE_GPIOLIB
9483a578 623 select HAVE_CLK
3bca103a 624 select ZONE_DMA
9232fcc9 625 select HAVE_IDE
c5b736d0 626 select COMMON_CLKDEV
20e9969b 627 select GENERIC_ALLOCATOR
7c6337e2
KH
628 help
629 Support for TI's DaVinci platform.
630
3b938be6
RK
631config ARCH_OMAP
632 bool "TI OMAP"
633 select GENERIC_GPIO
9483a578 634 select HAVE_CLK
7444a72e 635 select ARCH_REQUIRE_GPIOLIB
3b938be6 636 select GENERIC_TIME
06cad098 637 select GENERIC_CLOCKEVENTS
3b938be6
RK
638 help
639 Support for TI's OMAP platform (OMAP1 and OMAP2).
640
1da177e4
LT
641endchoice
642
643source "arch/arm/mach-clps711x/Kconfig"
644
e7736d47
LB
645source "arch/arm/mach-ep93xx/Kconfig"
646
1da177e4
LT
647source "arch/arm/mach-footbridge/Kconfig"
648
59d3a193
PZ
649source "arch/arm/mach-gemini/Kconfig"
650
1da177e4
LT
651source "arch/arm/mach-integrator/Kconfig"
652
3f7e5815
LB
653source "arch/arm/mach-iop32x/Kconfig"
654
655source "arch/arm/mach-iop33x/Kconfig"
1da177e4 656
285f5fa7
DW
657source "arch/arm/mach-iop13xx/Kconfig"
658
1da177e4
LT
659source "arch/arm/mach-ixp4xx/Kconfig"
660
661source "arch/arm/mach-ixp2000/Kconfig"
662
c4713074
LB
663source "arch/arm/mach-ixp23xx/Kconfig"
664
777f9beb
LB
665source "arch/arm/mach-loki/Kconfig"
666
794d15b2
SS
667source "arch/arm/mach-mv78xx0/Kconfig"
668
1da177e4 669source "arch/arm/mach-pxa/Kconfig"
bd5ce433 670source "arch/arm/plat-pxa/Kconfig"
1da177e4 671
49cbe786
EM
672source "arch/arm/mach-mmp/Kconfig"
673
1da177e4
LT
674source "arch/arm/mach-sa1100/Kconfig"
675
d48af15e
TL
676source "arch/arm/plat-omap/Kconfig"
677
678source "arch/arm/mach-omap1/Kconfig"
1da177e4 679
1dbae815
TL
680source "arch/arm/mach-omap2/Kconfig"
681
9dd0b194 682source "arch/arm/mach-orion5x/Kconfig"
585cf175 683
651c74c7 684source "arch/arm/mach-kirkwood/Kconfig"
585cf175 685
a21765a7 686source "arch/arm/plat-s3c24xx/Kconfig"
a08ab637 687source "arch/arm/plat-s3c64xx/Kconfig"
d58153d8 688source "arch/arm/plat-s3c/Kconfig"
a21765a7
BD
689
690if ARCH_S3C2410
691source "arch/arm/mach-s3c2400/Kconfig"
1da177e4 692source "arch/arm/mach-s3c2410/Kconfig"
a21765a7
BD
693source "arch/arm/mach-s3c2412/Kconfig"
694source "arch/arm/mach-s3c2440/Kconfig"
695source "arch/arm/mach-s3c2442/Kconfig"
e4d06e39 696source "arch/arm/mach-s3c2443/Kconfig"
a21765a7 697endif
1da177e4 698
a08ab637
BD
699if ARCH_S3C64XX
700source "arch/arm/mach-s3c6400/Kconfig"
701source "arch/arm/mach-s3c6410/Kconfig"
702endif
703
7bd0f2f5 704source "arch/arm/plat-stmp3xxx/Kconfig"
705
1da177e4
LT
706source "arch/arm/mach-lh7a40x/Kconfig"
707
1da177e4
LT
708source "arch/arm/mach-h720x/Kconfig"
709
710source "arch/arm/mach-versatile/Kconfig"
711
038c5b60
BN
712source "arch/arm/mach-aaec2000/Kconfig"
713
8ad68bbf
CM
714source "arch/arm/mach-realview/Kconfig"
715
9d041268 716source "arch/arm/mach-at91/Kconfig"
73a59c1c 717
52c543f9
QJ
718source "arch/arm/plat-mxc/Kconfig"
719
bb6d8c88
SH
720source "arch/arm/mach-netx/Kconfig"
721
9918cda5
UKK
722source "arch/arm/mach-ns9xxx/Kconfig"
723
7c6337e2
KH
724source "arch/arm/mach-davinci/Kconfig"
725
c53c9cf6
AV
726source "arch/arm/mach-ks8695/Kconfig"
727
9e73c84c
BS
728source "arch/arm/mach-msm/Kconfig"
729
d98aac75
LW
730source "arch/arm/mach-u300/Kconfig"
731
7ec80ddf 732source "arch/arm/mach-w90x900/Kconfig"
733
1da177e4
LT
734# Definitions to make life easier
735config ARCH_ACORN
736 bool
737
7ae1f7ec
LB
738config PLAT_IOP
739 bool
740
69b02f6a
LB
741config PLAT_ORION
742 bool
743
bd5ce433
EM
744config PLAT_PXA
745 bool
746
1da177e4
LT
747source arch/arm/mm/Kconfig
748
afe4b25e
LB
749config IWMMXT
750 bool "Enable iWMMXt support"
40305a58
EM
751 depends on CPU_XSCALE || CPU_XSC3 || CPU_MOHAWK
752 default y if PXA27x || PXA3xx || ARCH_MMP
afe4b25e
LB
753 help
754 Enable support for iWMMXt context switching at run time if
755 running on a CPU that supports it.
756
1da177e4
LT
757# bool 'Use XScale PMU as timer source' CONFIG_XSCALE_PMU_TIMER
758config XSCALE_PMU
759 bool
760 depends on CPU_XSCALE && !XSCALE_PMU_TIMER
761 default y
762
3b93e7b0
HC
763if !MMU
764source "arch/arm/Kconfig-nommu"
765endif
766
9cba3ccc
CM
767config ARM_ERRATA_411920
768 bool "ARM errata: Invalidation of the Instruction Cache operation can fail"
769 depends on CPU_V6 && !SMP
770 help
771 Invalidation of the Instruction Cache operation can
772 fail. This erratum is present in 1136 (before r1p4), 1156 and 1176.
773 It does not affect the MPCore. This option enables the ARM Ltd.
774 recommended workaround.
775
7ce236fc
CM
776config ARM_ERRATA_430973
777 bool "ARM errata: Stale prediction on replaced interworking branch"
778 depends on CPU_V7
779 help
780 This option enables the workaround for the 430973 Cortex-A8
781 (r1p0..r1p2) erratum. If a code sequence containing an ARM/Thumb
782 interworking branch is replaced with another code sequence at the
783 same virtual address, whether due to self-modifying code or virtual
784 to physical address re-mapping, Cortex-A8 does not recover from the
785 stale interworking branch prediction. This results in Cortex-A8
786 executing the new code sequence in the incorrect ARM or Thumb state.
787 The workaround enables the BTB/BTAC operations by setting ACTLR.IBE
788 and also flushes the branch target cache at every context switch.
789 Note that setting specific bits in the ACTLR register may not be
790 available in non-secure mode.
791
855c551f
CM
792config ARM_ERRATA_458693
793 bool "ARM errata: Processor deadlock when a false hazard is created"
794 depends on CPU_V7
795 help
796 This option enables the workaround for the 458693 Cortex-A8 (r2p0)
797 erratum. For very specific sequences of memory operations, it is
798 possible for a hazard condition intended for a cache line to instead
799 be incorrectly associated with a different cache line. This false
800 hazard might then cause a processor deadlock. The workaround enables
801 the L1 caching of the NEON accesses and disables the PLD instruction
802 in the ACTLR register. Note that setting specific bits in the ACTLR
803 register may not be available in non-secure mode.
804
0516e464
CM
805config ARM_ERRATA_460075
806 bool "ARM errata: Data written to the L2 cache can be overwritten with stale data"
807 depends on CPU_V7
808 help
809 This option enables the workaround for the 460075 Cortex-A8 (r2p0)
810 erratum. Any asynchronous access to the L2 cache may encounter a
811 situation in which recent store transactions to the L2 cache are lost
812 and overwritten with stale memory contents from external memory. The
813 workaround disables the write-allocate mode for the L2 cache via the
814 ACTLR register. Note that setting specific bits in the ACTLR register
815 may not be available in non-secure mode.
816
1da177e4
LT
817endmenu
818
819source "arch/arm/common/Kconfig"
820
821config FORCE_MAX_ZONEORDER
822 int
823 depends on SA1111
824 default "9"
825
826menu "Bus support"
827
828config ARM_AMBA
829 bool
830
831config ISA
832 bool
1da177e4
LT
833 help
834 Find out whether you have ISA slots on your motherboard. ISA is the
835 name of a bus system, i.e. the way the CPU talks to the other stuff
836 inside your box. Other bus systems are PCI, EISA, MicroChannel
837 (MCA) or VESA. ISA is an older system, now being displaced by PCI;
838 newer boards don't support it. If you have ISA, say Y, otherwise N.
839
065909b9 840# Select ISA DMA controller support
1da177e4
LT
841config ISA_DMA
842 bool
065909b9 843 select ISA_DMA_API
1da177e4 844
065909b9 845# Select ISA DMA interface
5cae841b
AV
846config ISA_DMA_API
847 bool
5cae841b 848
1da177e4 849config PCI
a0113a99 850 bool "PCI support" if ARCH_INTEGRATOR_AP || ARCH_VERSATILE_PB || ARCH_IXP4XX || ARCH_KS8695 || MACH_ARMCORE
1da177e4
LT
851 help
852 Find out whether you have a PCI motherboard. PCI is the name of a
853 bus system, i.e. the way the CPU talks to the other stuff inside
854 your box. Other bus systems are ISA, EISA, MicroChannel (MCA) or
855 VESA. If you have PCI, say Y, otherwise N.
856
36e23590
MW
857config PCI_SYSCALL
858 def_bool PCI
859
1da177e4
LT
860# Select the host bridge type
861config PCI_HOST_VIA82C505
862 bool
863 depends on PCI && ARCH_SHARK
864 default y
865
a0113a99
MR
866config PCI_HOST_ITE8152
867 bool
868 depends on PCI && MACH_ARMCORE
869 default y
870 select DMABOUNCE
871
1da177e4
LT
872source "drivers/pci/Kconfig"
873
874source "drivers/pcmcia/Kconfig"
875
876endmenu
877
878menu "Kernel Features"
879
0567a0c0
KH
880source "kernel/time/Kconfig"
881
1da177e4
LT
882config SMP
883 bool "Symmetric Multi-Processing (EXPERIMENTAL)"
42578c82
RK
884 depends on EXPERIMENTAL && (REALVIEW_EB_ARM11MP || REALVIEW_EB_A9MP ||\
885 MACH_REALVIEW_PB11MP || MACH_REALVIEW_PBX || ARCH_OMAP4)
bc28248e 886 depends on GENERIC_CLOCKEVENTS
f6dd9fa5 887 select USE_GENERIC_SMP_HELPERS
934f8be7 888 select HAVE_ARM_SCU if (ARCH_REALVIEW || ARCH_OMAP4)
1da177e4
LT
889 help
890 This enables support for systems with more than one CPU. If you have
891 a system with only one CPU, like most personal computers, say N. If
892 you have a system with more than one CPU, say Y.
893
894 If you say N here, the kernel will run on single and multiprocessor
895 machines, but will use only one CPU of a multiprocessor machine. If
896 you say Y here, the kernel will run on many, but not all, single
897 processor machines. On a single processor machine, the kernel will
898 run faster if you say N here.
899
03502faa 900 See also <file:Documentation/i386/IO-APIC.txt>,
1da177e4
LT
901 <file:Documentation/nmi_watchdog.txt> and the SMP-HOWTO available at
902 <http://www.linuxdoc.org/docs.html#howto>.
903
904 If you don't know what to do here, say N.
905
a8cbcd92
RK
906config HAVE_ARM_SCU
907 bool
908 depends on SMP
909 help
910 This option enables support for the ARM system coherency unit
911
f32f4ce2
RK
912config HAVE_ARM_TWD
913 bool
914 depends on SMP
915 help
916 This options enables support for the ARM timer and watchdog unit
917
8d5796d2
LB
918choice
919 prompt "Memory split"
920 default VMSPLIT_3G
921 help
922 Select the desired split between kernel and user memory.
923
924 If you are not absolutely sure what you are doing, leave this
925 option alone!
926
927 config VMSPLIT_3G
928 bool "3G/1G user/kernel split"
929 config VMSPLIT_2G
930 bool "2G/2G user/kernel split"
931 config VMSPLIT_1G
932 bool "1G/3G user/kernel split"
933endchoice
934
935config PAGE_OFFSET
936 hex
937 default 0x40000000 if VMSPLIT_1G
938 default 0x80000000 if VMSPLIT_2G
939 default 0xC0000000
940
1da177e4
LT
941config NR_CPUS
942 int "Maximum number of CPUs (2-32)"
943 range 2 32
944 depends on SMP
945 default "4"
946
a054a811
RK
947config HOTPLUG_CPU
948 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
949 depends on SMP && HOTPLUG && EXPERIMENTAL
950 help
951 Say Y here to experiment with turning CPUs off and on. CPUs
952 can be controlled through /sys/devices/system/cpu.
953
37ee16ae
RK
954config LOCAL_TIMERS
955 bool "Use local timer interrupts"
42578c82
RK
956 depends on SMP && (REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || \
957 REALVIEW_EB_A9MP || MACH_REALVIEW_PBX || ARCH_OMAP4)
37ee16ae 958 default y
934f8be7 959 select HAVE_ARM_TWD if (ARCH_REALVIEW || ARCH_OMAP4)
37ee16ae
RK
960 help
961 Enable support for local timers on SMP platforms, rather then the
962 legacy IPI broadcast method. Local timers allows the system
963 accounting to be spread across the timer interval, preventing a
964 "thundering herd" at every timer tick.
965
1da177e4
LT
966config PREEMPT
967 bool "Preemptible Kernel (EXPERIMENTAL)"
968 depends on EXPERIMENTAL
969 help
970 This option reduces the latency of the kernel when reacting to
971 real-time or interactive events by allowing a low priority process to
972 be preempted even if it is in kernel mode executing a system call.
973 This allows applications to run more reliably even when the system is
974 under load.
975
976 Say Y here if you are building a kernel for a desktop, embedded
977 or real-time system. Say N if you are unsure.
978
f8065813
RK
979config HZ
980 int
981 default 128 if ARCH_L7200
982 default 200 if ARCH_EBSA110 || ARCH_S3C2410
bfe65704 983 default OMAP_32K_TIMER_HZ if ARCH_OMAP && OMAP_32K_TIMER
5248c657 984 default AT91_TIMER_HZ if ARCH_AT91
f8065813
RK
985 default 100
986
704bdda0
NP
987config AEABI
988 bool "Use the ARM EABI to compile the kernel"
989 help
990 This option allows for the kernel to be compiled using the latest
991 ARM ABI (aka EABI). This is only useful if you are using a user
992 space environment that is also compiled with EABI.
993
994 Since there are major incompatibilities between the legacy ABI and
995 EABI, especially with regard to structure member alignment, this
996 option also changes the kernel syscall calling convention to
997 disambiguate both ABIs and allow for backward compatibility support
998 (selected with CONFIG_OABI_COMPAT).
999
1000 To use this you need GCC version 4.0.0 or later.
1001
6c90c872 1002config OABI_COMPAT
a73a3ff1 1003 bool "Allow old ABI binaries to run with this kernel (EXPERIMENTAL)"
61c484d4 1004 depends on AEABI && EXPERIMENTAL
6c90c872
NP
1005 default y
1006 help
1007 This option preserves the old syscall interface along with the
1008 new (ARM EABI) one. It also provides a compatibility layer to
1009 intercept syscalls that have structure arguments which layout
1010 in memory differs between the legacy ABI and the new ARM EABI
1011 (only for non "thumb" binaries). This option adds a tiny
1012 overhead to all syscalls and produces a slightly larger kernel.
1013 If you know you'll be using only pure EABI user space then you
1014 can say N here. If this option is not selected and you attempt
1015 to execute a legacy ABI binary then the result will be
1016 UNPREDICTABLE (in fact it can be predicted that it won't work
1017 at all). If in doubt say Y.
1018
eb33575c 1019config ARCH_HAS_HOLES_MEMORYMODEL
e80d6a24 1020 bool
e80d6a24 1021
07a2f737 1022# Discontigmem is deprecated
3f22ab27 1023config ARCH_DISCONTIGMEM_ENABLE
1da177e4 1024 bool
1da177e4 1025
05944d74
RK
1026config ARCH_SPARSEMEM_ENABLE
1027 bool
1028
07a2f737
RK
1029config ARCH_SPARSEMEM_DEFAULT
1030 def_bool ARCH_SPARSEMEM_ENABLE
1031
05944d74 1032config ARCH_SELECT_MEMORY_MODEL
07a2f737 1033 def_bool ARCH_DISCONTIGMEM_ENABLE && ARCH_SPARSEMEM_ENABLE
05944d74 1034
c80d79d7
YG
1035config NODES_SHIFT
1036 int
1037 default "4" if ARCH_LH7A40X
1038 default "2"
1039 depends on NEED_MULTIPLE_NODES
1040
053a96ca
NP
1041config HIGHMEM
1042 bool "High Memory Support (EXPERIMENTAL)"
1043 depends on MMU && EXPERIMENTAL
1044 help
1045 The address space of ARM processors is only 4 Gigabytes large
1046 and it has to accommodate user address space, kernel address
1047 space as well as some memory mapped IO. That means that, if you
1048 have a large amount of physical memory and/or IO, not all of the
1049 memory can be "permanently mapped" by the kernel. The physical
1050 memory that is not permanently mapped is called "high memory".
1051
1052 Depending on the selected kernel/user memory split, minimum
1053 vmalloc space and actual amount of RAM, you may not need this
1054 option which should result in a slightly faster kernel.
1055
1056 If unsure, say n.
1057
3f22ab27
DH
1058source "mm/Kconfig"
1059
1da177e4
LT
1060config LEDS
1061 bool "Timer and CPU usage LEDs"
e055d5bf 1062 depends on ARCH_CDB89712 || ARCH_EBSA110 || \
8c8fdbc9 1063 ARCH_EBSA285 || ARCH_INTEGRATOR || \
1da177e4
LT
1064 ARCH_LUBBOCK || MACH_MAINSTONE || ARCH_NETWINDER || \
1065 ARCH_OMAP || ARCH_P720T || ARCH_PXA_IDP || \
73a59c1c 1066 ARCH_SA1100 || ARCH_SHARK || ARCH_VERSATILE || \
25329671 1067 ARCH_AT91 || ARCH_DAVINCI || \
ff3042fb 1068 ARCH_KS8695 || MACH_RD88F5182 || ARCH_REALVIEW
1da177e4
LT
1069 help
1070 If you say Y here, the LEDs on your machine will be used
1071 to provide useful information about your current system status.
1072
1073 If you are compiling a kernel for a NetWinder or EBSA-285, you will
1074 be able to select which LEDs are active using the options below. If
1075 you are compiling a kernel for the EBSA-110 or the LART however, the
1076 red LED will simply flash regularly to indicate that the system is
1077 still functional. It is safe to say Y here if you have a CATS
1078 system, but the driver will do nothing.
1079
1080config LEDS_TIMER
1081 bool "Timer LED" if (!ARCH_CDB89712 && !ARCH_OMAP) || \
eebdf7d7
DB
1082 OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
1083 || MACH_OMAP_PERSEUS2
1da177e4 1084 depends on LEDS
0567a0c0 1085 depends on !GENERIC_CLOCKEVENTS
1da177e4
LT
1086 default y if ARCH_EBSA110
1087 help
1088 If you say Y here, one of the system LEDs (the green one on the
1089 NetWinder, the amber one on the EBSA285, or the red one on the LART)
1090 will flash regularly to indicate that the system is still
1091 operational. This is mainly useful to kernel hackers who are
1092 debugging unstable kernels.
1093
1094 The LART uses the same LED for both Timer LED and CPU usage LED
1095 functions. You may choose to use both, but the Timer LED function
1096 will overrule the CPU usage LED.
1097
1098config LEDS_CPU
1099 bool "CPU usage LED" if (!ARCH_CDB89712 && !ARCH_EBSA110 && \
eebdf7d7
DB
1100 !ARCH_OMAP) \
1101 || OMAP_OSK_MISTRAL || MACH_OMAP_H2 \
1102 || MACH_OMAP_PERSEUS2
1da177e4
LT
1103 depends on LEDS
1104 help
1105 If you say Y here, the red LED will be used to give a good real
1106 time indication of CPU usage, by lighting whenever the idle task
1107 is not currently executing.
1108
1109 The LART uses the same LED for both Timer LED and CPU usage LED
1110 functions. You may choose to use both, but the Timer LED function
1111 will overrule the CPU usage LED.
1112
1113config ALIGNMENT_TRAP
1114 bool
f12d0d7c 1115 depends on CPU_CP15_MMU
1da177e4
LT
1116 default y if !ARCH_EBSA110
1117 help
84eb8d06 1118 ARM processors cannot fetch/store information which is not
1da177e4
LT
1119 naturally aligned on the bus, i.e., a 4 byte fetch must start at an
1120 address divisible by 4. On 32-bit ARM processors, these non-aligned
1121 fetch/store instructions will be emulated in software if you say
1122 here, which has a severe performance impact. This is necessary for
1123 correct operation of some network protocols. With an IP-only
1124 configuration it is safe to say N, otherwise say Y.
1125
39ec58f3
LB
1126config UACCESS_WITH_MEMCPY
1127 bool "Use kernel mem{cpy,set}() for {copy_to,clear}_user() (EXPERIMENTAL)"
1128 depends on MMU && EXPERIMENTAL
1129 default y if CPU_FEROCEON
1130 help
1131 Implement faster copy_to_user and clear_user methods for CPU
1132 cores where a 8-word STM instruction give significantly higher
1133 memory write throughput than a sequence of individual 32bit stores.
1134
1135 A possible side effect is a slight increase in scheduling latency
1136 between threads sharing the same address space if they invoke
1137 such copy operations with large buffers.
1138
1139 However, if the CPU data cache is using a write-allocate mode,
1140 this option is unlikely to provide any performance gain.
1141
1da177e4
LT
1142endmenu
1143
1144menu "Boot options"
1145
1146# Compressed boot loader in ROM. Yes, we really want to ask about
1147# TEXT and BSS so we preserve their values in the config files.
1148config ZBOOT_ROM_TEXT
1149 hex "Compressed ROM boot loader base address"
1150 default "0"
1151 help
1152 The physical address at which the ROM-able zImage is to be
1153 placed in the target. Platforms which normally make use of
1154 ROM-able zImage formats normally set this to a suitable
1155 value in their defconfig file.
1156
1157 If ZBOOT_ROM is not enabled, this has no effect.
1158
1159config ZBOOT_ROM_BSS
1160 hex "Compressed ROM boot loader BSS address"
1161 default "0"
1162 help
f8c440b2
DF
1163 The base address of an area of read/write memory in the target
1164 for the ROM-able zImage which must be available while the
1165 decompressor is running. It must be large enough to hold the
1166 entire decompressed kernel plus an additional 128 KiB.
1167 Platforms which normally make use of ROM-able zImage formats
1168 normally set this to a suitable value in their defconfig file.
1da177e4
LT
1169
1170 If ZBOOT_ROM is not enabled, this has no effect.
1171
1172config ZBOOT_ROM
1173 bool "Compressed boot loader in ROM/flash"
1174 depends on ZBOOT_ROM_TEXT != ZBOOT_ROM_BSS
1175 help
1176 Say Y here if you intend to execute your compressed kernel image
1177 (zImage) directly from ROM or flash. If unsure, say N.
1178
1179config CMDLINE
1180 string "Default kernel command string"
1181 default ""
1182 help
1183 On some architectures (EBSA110 and CATS), there is currently no way
1184 for the boot loader to pass arguments to the kernel. For these
1185 architectures, you should supply some command-line options at build
1186 time by entering them here. As a minimum, you should specify the
1187 memory size and the root device (e.g., mem=64M root=/dev/nfs).
1188
1189config XIP_KERNEL
1190 bool "Kernel Execute-In-Place from ROM"
1191 depends on !ZBOOT_ROM
1192 help
1193 Execute-In-Place allows the kernel to run from non-volatile storage
1194 directly addressable by the CPU, such as NOR flash. This saves RAM
1195 space since the text section of the kernel is not loaded from flash
1196 to RAM. Read-write sections, such as the data section and stack,
1197 are still copied to RAM. The XIP kernel is not compressed since
1198 it has to run directly from flash, so it will take more space to
1199 store it. The flash address used to link the kernel object files,
1200 and for storing it, is configuration dependent. Therefore, if you
1201 say Y here, you must know the proper physical address where to
1202 store the kernel image depending on your own flash memory usage.
1203
1204 Also note that the make target becomes "make xipImage" rather than
1205 "make zImage" or "make Image". The final kernel binary to put in
1206 ROM memory will be arch/arm/boot/xipImage.
1207
1208 If unsure, say N.
1209
1210config XIP_PHYS_ADDR
1211 hex "XIP Kernel Physical Location"
1212 depends on XIP_KERNEL
1213 default "0x00080000"
1214 help
1215 This is the physical address in your flash memory the kernel will
1216 be linked for and stored to. This address is dependent on your
1217 own flash usage.
1218
c587e4a6
RP
1219config KEXEC
1220 bool "Kexec system call (EXPERIMENTAL)"
1221 depends on EXPERIMENTAL
1222 help
1223 kexec is a system call that implements the ability to shutdown your
1224 current kernel, and to start another kernel. It is like a reboot
01dd2fbf 1225 but it is independent of the system firmware. And like a reboot
c587e4a6
RP
1226 you can start any kernel with it, not just Linux.
1227
1228 It is an ongoing process to be certain the hardware in a machine
1229 is properly shutdown, so do not be surprised if this code does not
1230 initially work for you. It may help to enable device hotplugging
1231 support.
1232
4cd9d6f7
RP
1233config ATAGS_PROC
1234 bool "Export atags in procfs"
b98d7291
UL
1235 depends on KEXEC
1236 default y
4cd9d6f7
RP
1237 help
1238 Should the atags used to boot the kernel be exported in an "atags"
1239 file in procfs. Useful with kexec.
1240
1da177e4
LT
1241endmenu
1242
ac9d7efc 1243menu "CPU Power Management"
1da177e4 1244
b3748ddd 1245if (ARCH_SA1100 || ARCH_INTEGRATOR || ARCH_OMAP || ARCH_PXA || ARCH_S3C64XX)
1da177e4
LT
1246
1247source "drivers/cpufreq/Kconfig"
1248
1249config CPU_FREQ_SA1100
1250 bool
7bc35b56 1251 depends on CPU_FREQ && (SA1100_H3100 || SA1100_H3600 || SA1100_LART || SA1100_PLEB || SA1100_BADGE4 || SA1100_HACKKIT)
1da177e4
LT
1252 default y
1253
1254config CPU_FREQ_SA1110
1255 bool
1256 depends on CPU_FREQ && (SA1100_ASSABET || SA1100_CERF || SA1100_PT_SYSTEM3)
1257 default y
1258
1259config CPU_FREQ_INTEGRATOR
1260 tristate "CPUfreq driver for ARM Integrator CPUs"
1261 depends on ARCH_INTEGRATOR && CPU_FREQ
1262 default y
1263 help
1264 This enables the CPUfreq driver for ARM Integrator CPUs.
1265
1266 For details, take a look at <file:Documentation/cpu-freq>.
1267
1268 If in doubt, say Y.
1269
9e2697ff
RK
1270config CPU_FREQ_PXA
1271 bool
1272 depends on CPU_FREQ && ARCH_PXA && PXA25x
1273 default y
1274 select CPU_FREQ_DEFAULT_GOV_USERSPACE
1275
b3748ddd
MB
1276config CPU_FREQ_S3C64XX
1277 bool "CPUfreq support for Samsung S3C64XX CPUs"
1278 depends on CPU_FREQ && CPU_S3C6410
1279
1da177e4
LT
1280endif
1281
ac9d7efc
RK
1282source "drivers/cpuidle/Kconfig"
1283
1284endmenu
1285
1da177e4
LT
1286menu "Floating point emulation"
1287
1288comment "At least one emulation must be selected"
1289
1290config FPE_NWFPE
1291 bool "NWFPE math emulation"
8993a44c 1292 depends on !AEABI || OABI_COMPAT
1da177e4
LT
1293 ---help---
1294 Say Y to include the NWFPE floating point emulator in the kernel.
1295 This is necessary to run most binaries. Linux does not currently
1296 support floating point hardware so you need to say Y here even if
1297 your machine has an FPA or floating point co-processor podule.
1298
1299 You may say N here if you are going to load the Acorn FPEmulator
1300 early in the bootup.
1301
1302config FPE_NWFPE_XP
1303 bool "Support extended precision"
bedf142b 1304 depends on FPE_NWFPE
1da177e4
LT
1305 help
1306 Say Y to include 80-bit support in the kernel floating-point
1307 emulator. Otherwise, only 32 and 64-bit support is compiled in.
1308 Note that gcc does not generate 80-bit operations by default,
1309 so in most cases this option only enlarges the size of the
1310 floating point emulator without any good reason.
1311
1312 You almost surely want to say N here.
1313
1314config FPE_FASTFPE
1315 bool "FastFPE math emulation (EXPERIMENTAL)"
8993a44c 1316 depends on (!AEABI || OABI_COMPAT) && !CPU_32v3 && EXPERIMENTAL
1da177e4
LT
1317 ---help---
1318 Say Y here to include the FAST floating point emulator in the kernel.
1319 This is an experimental much faster emulator which now also has full
1320 precision for the mantissa. It does not support any exceptions.
1321 It is very simple, and approximately 3-6 times faster than NWFPE.
1322
1323 It should be sufficient for most programs. It may be not suitable
1324 for scientific calculations, but you have to check this for yourself.
1325 If you do not feel you need a faster FP emulation you should better
1326 choose NWFPE.
1327
1328config VFP
1329 bool "VFP-format floating point maths"
c00d4ffd 1330 depends on CPU_V6 || CPU_ARM926T || CPU_V7 || CPU_FEROCEON
1da177e4
LT
1331 help
1332 Say Y to include VFP support code in the kernel. This is needed
1333 if your hardware includes a VFP unit.
1334
1335 Please see <file:Documentation/arm/VFP/release-notes.txt> for
1336 release notes and additional status information.
1337
1338 Say N if your target does not have VFP hardware.
1339
25ebee02
CM
1340config VFPv3
1341 bool
1342 depends on VFP
1343 default y if CPU_V7
1344
b5872db4
CM
1345config NEON
1346 bool "Advanced SIMD (NEON) Extension support"
1347 depends on VFPv3 && CPU_V7
1348 help
1349 Say Y to include support code for NEON, the ARMv7 Advanced SIMD
1350 Extension.
1351
1da177e4
LT
1352endmenu
1353
1354menu "Userspace binary formats"
1355
1356source "fs/Kconfig.binfmt"
1357
1358config ARTHUR
1359 tristate "RISC OS personality"
704bdda0 1360 depends on !AEABI
1da177e4
LT
1361 help
1362 Say Y here to include the kernel code necessary if you want to run
1363 Acorn RISC OS/Arthur binaries under Linux. This code is still very
1364 experimental; if this sounds frightening, say N and sleep in peace.
1365 You can also say M here to compile this support as a module (which
1366 will be called arthur).
1367
1368endmenu
1369
1370menu "Power management options"
1371
eceab4ac 1372source "kernel/power/Kconfig"
1da177e4 1373
f4cb5700
JB
1374config ARCH_SUSPEND_POSSIBLE
1375 def_bool y
1376
1da177e4
LT
1377endmenu
1378
d5950b43
SR
1379source "net/Kconfig"
1380
1da177e4
LT
1381menu "Device Drivers"
1382
1383source "drivers/base/Kconfig"
1384
c35bf4a5
PM
1385source "drivers/connector/Kconfig"
1386
f12d0d7c 1387if ALIGNMENT_TRAP || !CPU_CP15_MMU
1da177e4
LT
1388source "drivers/mtd/Kconfig"
1389endif
1390
1391source "drivers/parport/Kconfig"
1392
1393source "drivers/pnp/Kconfig"
1394
1395source "drivers/block/Kconfig"
1396
58273e55
RK
1397# misc before ide - BLK_DEV_SGIIOC4 depends on SGI_IOC4
1398
1399source "drivers/misc/Kconfig"
1400
1da177e4 1401source "drivers/ide/Kconfig"
1da177e4
LT
1402
1403source "drivers/scsi/Kconfig"
1404
eb370f0b
MM
1405source "drivers/ata/Kconfig"
1406
1da177e4
LT
1407source "drivers/md/Kconfig"
1408
1409source "drivers/message/fusion/Kconfig"
1410
1411source "drivers/ieee1394/Kconfig"
1412
1413source "drivers/message/i2o/Kconfig"
1414
d5950b43 1415source "drivers/net/Kconfig"
1da177e4
LT
1416
1417source "drivers/isdn/Kconfig"
1418
1419# input before char - char/joystick depends on it. As does USB.
1420
1421source "drivers/input/Kconfig"
1422
1423source "drivers/char/Kconfig"
1424
1425source "drivers/i2c/Kconfig"
1426
8ae12a0d
DB
1427source "drivers/spi/Kconfig"
1428
a9c5fff5
DB
1429source "drivers/gpio/Kconfig"
1430
04916c0e
AZ
1431source "drivers/w1/Kconfig"
1432
58273e55
RK
1433source "drivers/power/Kconfig"
1434
ad2f931d
JD
1435source "drivers/hwmon/Kconfig"
1436
ac9d7efc
RK
1437source "drivers/thermal/Kconfig"
1438
70dfa3f8
RK
1439source "drivers/watchdog/Kconfig"
1440
58273e55 1441source "drivers/ssb/Kconfig"
1da177e4 1442
58273e55 1443#source "drivers/l3/Kconfig"
1da177e4 1444
a4e137ab
RK
1445source "drivers/mfd/Kconfig"
1446
1da177e4
LT
1447source "drivers/media/Kconfig"
1448
1449source "drivers/video/Kconfig"
1450
1451source "sound/Kconfig"
1452
c2dade51
SH
1453source "drivers/hid/Kconfig"
1454
1da177e4
LT
1455source "drivers/usb/Kconfig"
1456
2f86c3e6
GKH
1457source "drivers/uwb/Kconfig"
1458
1da177e4
LT
1459source "drivers/mmc/Kconfig"
1460
ac9d7efc
RK
1461source "drivers/memstick/Kconfig"
1462
1463source "drivers/accessibility/Kconfig"
1464
58273e55
RK
1465source "drivers/leds/Kconfig"
1466
12b824fb
AZ
1467source "drivers/rtc/Kconfig"
1468
5816815f
DW
1469source "drivers/dma/Kconfig"
1470
abf07b19
DW
1471source "drivers/dca/Kconfig"
1472
ac9d7efc
RK
1473source "drivers/auxdisplay/Kconfig"
1474
ba7e4763
LG
1475source "drivers/regulator/Kconfig"
1476
2dc034a8
HJK
1477source "drivers/uio/Kconfig"
1478
6e38a2ba
DH
1479source "drivers/staging/Kconfig"
1480
1da177e4
LT
1481endmenu
1482
1483source "fs/Kconfig"
1484
1da177e4
LT
1485source "arch/arm/Kconfig.debug"
1486
1487source "security/Kconfig"
1488
1489source "crypto/Kconfig"
1490
1491source "lib/Kconfig"