[PATCH] optional ZONE_DMA: remove ZONE_DMA remains from sh/sh64
[deliverable/linux.git] / arch / powerpc / Kconfig
CommitLineData
14cf11af
PM
1# For a description of the syntax of this configuration file,
2# see Documentation/kbuild/kconfig-language.txt.
3#
4
5mainmenu "Linux/PowerPC Kernel Configuration"
6
7config PPC64
8 bool "64-bit kernel"
9 default n
10 help
11 This option selects whether a 32-bit or a 64-bit kernel
12 will be built.
13
14config PPC32
15 bool
16 default y if !PPC64
17
18config 64BIT
19 bool
20 default y if PPC64
21
22config PPC_MERGE
23 def_bool y
24
25config MMU
26 bool
27 default y
28
14cf11af
PM
29config GENERIC_HARDIRQS
30 bool
31 default y
32
0d7012a9
IM
33config IRQ_PER_CPU
34 bool
35 default y
36
14cf11af
PM
37config RWSEM_GENERIC_SPINLOCK
38 bool
39
40config RWSEM_XCHGADD_ALGORITHM
41 bool
42 default y
43
f0d1b0b3
DH
44config ARCH_HAS_ILOG2_U32
45 bool
ef55d53c 46 default y
f0d1b0b3
DH
47
48config ARCH_HAS_ILOG2_U64
49 bool
ef55d53c 50 default y if 64BIT
f0d1b0b3 51
e779b2f9
AM
52config GENERIC_HWEIGHT
53 bool
54 default y
55
14cf11af
PM
56config GENERIC_CALIBRATE_DELAY
57 bool
58 default y
59
0a9cb46a
JM
60config GENERIC_FIND_NEXT_BIT
61 bool
62 default y
63
14cf11af
PM
64config PPC
65 bool
66 default y
67
68config EARLY_PRINTK
69 bool
51d3082f 70 default y
14cf11af
PM
71
72config COMPAT
73 bool
74 default y if PPC64
75
76config SYSVIPC_COMPAT
77 bool
78 depends on COMPAT && SYSVIPC
79 default y
80
81# All PPC32s use generic nvram driver through ppc_md
82config GENERIC_NVRAM
83 bool
84 default y if PPC32
85
86config SCHED_NO_NO_OMIT_FRAME_POINTER
87 bool
88 default y
89
90config ARCH_MAY_HAVE_PC_FDC
91 bool
92 default y
93
08264cbc
KG
94config PPC_OF
95 def_bool y
96
97config PPC_UDBG_16550
98 bool
99 default n
100
08264cbc
KG
101config GENERIC_TBSYNC
102 bool
103 default y if PPC32 && SMP
104 default n
105
e65e1fc2
AV
106config AUDIT_ARCH
107 bool
108 default y
109
73c9ceab
JF
110config GENERIC_BUG
111 bool
112 default y
113 depends on BUG
114
f4fc4a5b
KG
115config DEFAULT_UIMAGE
116 bool
117 help
118 Used to allow a board to specify it wants a uImage built by default
119 default n
120
14cf11af
PM
121menu "Processor support"
122choice
123 prompt "Processor Type"
124 depends on PPC32
125 default 6xx
126
08264cbc 127config CLASSIC32
650f3289 128 bool "52xx/6xx/7xx/74xx"
14cf11af 129 select PPC_FPU
08264cbc 130 select 6xx
14cf11af
PM
131 help
132 There are four families of PowerPC chips supported. The more common
133 types (601, 603, 604, 740, 750, 7400), the Motorola embedded
134 versions (821, 823, 850, 855, 860, 52xx, 82xx, 83xx), the AMCC
135 embedded versions (403 and 405) and the high end 64 bit Power
136 processors (POWER 3, POWER4, and IBM PPC970 also known as G5).
650f3289
GL
137
138 This option is the catch-all for 6xx types, including some of the
139 embedded versions. Unless there is see an option for the specific
140 chip family you are using, you want this option.
141
142 You do not want this if you are building a kernel for a 64 bit
143 IBM RS/6000 or an Apple G5, choose 6xx.
144
145 If unsure, select this option
14cf11af 146
14cf11af
PM
147 Note that the kernel runs in 32-bit mode even on 64-bit chips.
148
14cf11af
PM
149config PPC_82xx
150 bool "Freescale 82xx"
08264cbc
KG
151 select 6xx
152 select PPC_FPU
14cf11af
PM
153
154config PPC_83xx
155 bool "Freescale 83xx"
08264cbc
KG
156 select 6xx
157 select FSL_SOC
158 select 83xx
159 select PPC_FPU
14cf11af 160
63dafe57
BB
161config PPC_85xx
162 bool "Freescale 85xx"
163 select E500
164 select FSL_SOC
165 select 85xx
166
c9b484b5
JL
167config PPC_86xx
168 bool "Freescale 86xx"
169 select 6xx
170 select FSL_SOC
171 select PPC_FPU
172 select ALTIVEC
173 help
174 The Freescale E600 SoCs have 74xx cores.
175
5902ebce
VB
176config PPC_8xx
177 bool "Freescale 8xx"
178 select FSL_SOC
179 select 8xx
180
14cf11af
PM
181config 40x
182 bool "AMCC 40x"
4c75a6f4 183 select PPC_DCR_NATIVE
14cf11af
PM
184
185config 44x
186 bool "AMCC 44x"
4c75a6f4 187 select PPC_DCR_NATIVE
14cf11af 188
14cf11af
PM
189
190config E200
191 bool "Freescale e200"
192
14cf11af
PM
193endchoice
194
195config POWER4_ONLY
196 bool "Optimize for POWER4"
187a0067 197 depends on PPC64
14cf11af
PM
198 default n
199 ---help---
200 Cause the compiler to optimize for POWER4/POWER5/PPC970 processors.
201 The resulting binary will not work on POWER3 or RS64 processors
202 when compiled with binutils 2.15 or later.
203
204config POWER3
205 bool
187a0067 206 depends on PPC64
14cf11af
PM
207 default y if !POWER4_ONLY
208
209config POWER4
187a0067 210 depends on PPC64
14cf11af
PM
211 def_bool y
212
08264cbc
KG
213config 6xx
214 bool
215
5902ebce
VB
216# this is temp to handle compat with arch=ppc
217config 8xx
218 bool
219
08264cbc
KG
220# this is temp to handle compat with arch=ppc
221config 83xx
222 bool
223
63dafe57
BB
224# this is temp to handle compat with arch=ppc
225config 85xx
226 bool
227
228config E500
229 bool
230
14cf11af 231config PPC_FPU
187a0067
PM
232 bool
233 default y if PPC64
14cf11af 234
4c75a6f4
BH
235config PPC_DCR_NATIVE
236 bool
237 default n
238
239config PPC_DCR_MMIO
240 bool
241 default n
242
243config PPC_DCR
244 bool
245 depends on PPC_DCR_NATIVE || PPC_DCR_MMIO
246 default y
247
4c9d2800
BH
248config PPC_OF_PLATFORM_PCI
249 bool
250 depends on PPC64 # not supported on 32 bits yet
251 default n
252
14cf11af
PM
253config BOOKE
254 bool
255 depends on E200 || E500
256 default y
257
258config FSL_BOOKE
259 bool
260 depends on E200 || E500
261 default y
262
263config PTE_64BIT
264 bool
265 depends on 44x || E500
266 default y if 44x
267 default y if E500 && PHYS_64BIT
268
269config PHYS_64BIT
270 bool 'Large physical address support' if E500
271 depends on 44x || E500
3d1ea8e8 272 select RESOURCES_64BIT
14cf11af
PM
273 default y if 44x
274 ---help---
275 This option enables kernel support for larger than 32-bit physical
276 addresses. This features is not be available on all e500 cores.
277
278 If in doubt, say N here.
279
280config ALTIVEC
281 bool "AltiVec Support"
08264cbc 282 depends on CLASSIC32 || POWER4
14cf11af
PM
283 ---help---
284 This option enables kernel support for the Altivec extensions to the
285 PowerPC processor. The kernel currently supports saving and restoring
286 altivec registers, and turning on the 'altivec enable' bit so user
287 processes can execute altivec instructions.
288
289 This option is only usefully if you have a processor that supports
290 altivec (G4, otherwise known as 74xx series), but does not have
291 any affect on a non-altivec cpu (it does, however add code to the
292 kernel).
293
294 If in doubt, say Y here.
295
296config SPE
297 bool "SPE Support"
298 depends on E200 || E500
63dafe57 299 default y
14cf11af
PM
300 ---help---
301 This option enables kernel support for the Signal Processing
302 Extensions (SPE) to the PowerPC processor. The kernel currently
303 supports saving and restoring SPE registers, and turning on the
304 'spe enable' bit so user processes can execute SPE instructions.
305
306 This option is only useful if you have a processor that supports
307 SPE (e500, otherwise known as 85xx series), but does not have any
308 effect on a non-spe cpu (it does, however add code to the kernel).
309
310 If in doubt, say Y here.
311
312config PPC_STD_MMU
313 bool
314 depends on 6xx || POWER3 || POWER4 || PPC64
315 default y
316
317config PPC_STD_MMU_32
318 def_bool y
319 depends on PPC_STD_MMU && PPC32
320
c6622f63
PM
321config VIRT_CPU_ACCOUNTING
322 bool "Deterministic task and CPU time accounting"
323 depends on PPC64
324 default y
325 help
326 Select this option to enable more accurate task and CPU time
327 accounting. This is done by reading a CPU counter on each
328 kernel entry and exit and on transitions within the kernel
329 between system, softirq and hardirq state, so there is a
330 small performance impact. This also enables accounting of
331 stolen time on logically-partitioned systems running on
332 IBM POWER5-based machines.
333
334 If in doubt, say Y here.
335
14cf11af
PM
336config SMP
337 depends on PPC_STD_MMU
338 bool "Symmetric multi-processing support"
339 ---help---
340 This enables support for systems with more than one CPU. If you have
341 a system with only one CPU, say N. If you have a system with more
342 than one CPU, say Y. Note that the kernel does not currently
343 support SMP machines with 603/603e/603ev or PPC750 ("G3") processors
344 since they have inadequate hardware support for multiprocessor
345 operation.
346
347 If you say N here, the kernel will run on single and multiprocessor
348 machines, but will use only one CPU of a multiprocessor machine. If
349 you say Y here, the kernel will run on single-processor machines.
350 On a single-processor machine, the kernel will run faster if you say
351 N here.
352
353 If you don't know what to do here, say N.
354
355config NR_CPUS
e8a167ac 356 int "Maximum number of CPUs (2-128)"
14cf11af
PM
357 range 2 128
358 depends on SMP
359 default "32" if PPC64
360 default "4"
361
362config NOT_COHERENT_CACHE
363 bool
364 depends on 4xx || 8xx || E200
365 default y
366endmenu
367
368source "init/Kconfig"
369
370menu "Platform support"
08264cbc 371 depends on PPC64 || CLASSIC32
14cf11af
PM
372
373choice
374 prompt "Machine type"
375 default PPC_MULTIPLATFORM
376
377config PPC_MULTIPLATFORM
378 bool "Generic desktop/server/laptop"
379 help
380 Select this option if configuring for an IBM pSeries or
381 RS/6000 machine, an Apple machine, or a PReP, CHRP,
382 Maple or Cell-based machine.
383
14cf11af
PM
384config EMBEDDED6xx
385 bool "Embedded 6xx/7xx/7xxx-based board"
c5d56332 386 depends on PPC32 && (BROKEN||BROKEN_ON_SMP)
14cf11af
PM
387
388config APUS
389 bool "Amiga-APUS"
390 depends on PPC32 && BROKEN
391 help
392 Select APUS if configuring for a PowerUP Amiga.
393 More information is available at:
394 <http://linux-apus.sourceforge.net/>.
395endchoice
396
98658538
LY
397config QUICC_ENGINE
398 bool
399 depends on PPC_MPC836x || PPC_MPC832x
400 default y
401 help
402 The QUICC Engine (QE) is a new generation of communications
403 coprocessors on Freescale embedded CPUs (akin to CPM in older chips).
404 Selecting this option means that you wish to build a kernel
405 for a machine with a QE coprocessor.
406
14cf11af
PM
407config PPC_PSERIES
408 depends on PPC_MULTIPLATFORM && PPC64
4a3ecc62 409 bool "IBM pSeries & new (POWER5-based) iSeries"
7233593b 410 select MPIC
f9bd170a 411 select PPC_I8259
033ef338
PM
412 select PPC_RTAS
413 select RTAS_ERROR_LOGGING
13b8a272 414 select PPC_UDBG_16550
e22ba7e3 415 select PPC_NATIVE
14cf11af
PM
416 default y
417
a542dbd3
SR
418config PPC_ISERIES
419 bool "IBM Legacy iSeries"
420 depends on PPC_MULTIPLATFORM && PPC64
4cb3cee0 421 select PPC_INDIRECT_IO
a542dbd3 422
14cf11af 423config PPC_CHRP
4a3ecc62 424 bool "Common Hardware Reference Platform (CHRP) based machines"
14cf11af 425 depends on PPC_MULTIPLATFORM && PPC32
7233593b 426 select MPIC
f9bd170a 427 select PPC_I8259
25635c71 428 select PPC_INDIRECT_PCI
033ef338 429 select PPC_RTAS
830825d6 430 select PPC_MPC106
13b8a272 431 select PPC_UDBG_16550
e22ba7e3 432 select PPC_NATIVE
14cf11af
PM
433 default y
434
d4150248
GL
435config PPC_MPC52xx
436 bool
437 default n
438
f42963f8
GL
439config PPC_MPC5200
440 bool
441 select PPC_MPC52xx
442 default n
443
444config PPC_MPC5200_BUGFIX
445 bool "MPC5200 (L25R) bugfix support"
446 depends on PPC_MPC5200
447 default n
448 help
449 Enable workarounds for original MPC5200 errata. This is not required
450 for MPC5200B based boards.
451
452 It is safe to say 'Y' here
453
c37858d3
ND
454config PPC_EFIKA
455 bool "bPlan Efika 5k2. MPC5200B based computer"
456 depends on PPC_MULTIPLATFORM && PPC32
457 select PPC_RTAS
458 select RTAS_PROC
459 select PPC_MPC52xx
e22ba7e3 460 select PPC_NATIVE
7232846b 461 default n
c37858d3 462
6b642531
GL
463config PPC_LITE5200
464 bool "Freescale Lite5200 Eval Board"
465 depends on PPC_MULTIPLATFORM && PPC32
f42963f8 466 select PPC_MPC5200
6b642531
GL
467 default n
468
14cf11af 469config PPC_PMAC
4a3ecc62 470 bool "Apple PowerMac based machines"
14cf11af 471 depends on PPC_MULTIPLATFORM
7233593b 472 select MPIC
25635c71 473 select PPC_INDIRECT_PCI if PPC32
b6a4ce52 474 select PPC_MPC106 if PPC32
e22ba7e3 475 select PPC_NATIVE
14cf11af
PM
476 default y
477
478config PPC_PMAC64
479 bool
480 depends on PPC_PMAC && POWER4
7233593b 481 select MPIC
35499c01 482 select U3_DART
1beb6a7d 483 select MPIC_BROKEN_U3
8ad200d7 484 select GENERIC_TBSYNC
f39224a8 485 select PPC_970_NAP
14cf11af
PM
486 default y
487
488config PPC_PREP
4a3ecc62 489 bool "PowerPC Reference Platform (PReP) based machines"
5be396b0 490 depends on PPC_MULTIPLATFORM && PPC32 && BROKEN
7233593b 491 select MPIC
f9bd170a 492 select PPC_I8259
25635c71 493 select PPC_INDIRECT_PCI
13b8a272 494 select PPC_UDBG_16550
e22ba7e3 495 select PPC_NATIVE
7232846b 496 default n
14cf11af
PM
497
498config PPC_MAPLE
499 depends on PPC_MULTIPLATFORM && PPC64
4a3ecc62 500 bool "Maple 970FX Evaluation Board"
7233593b 501 select MPIC
14cf11af
PM
502 select U3_DART
503 select MPIC_BROKEN_U3
8ad200d7 504 select GENERIC_TBSYNC
13b8a272 505 select PPC_UDBG_16550
f39224a8 506 select PPC_970_NAP
e22ba7e3 507 select PPC_NATIVE
9d9d868e 508 select PPC_RTAS
4297c986 509 select MMIO_NVRAM
8cdf92a9 510 select ATA_NONSTANDARD if ATA
14cf11af
PM
511 default n
512 help
513 This option enables support for the Maple 970FX Evaluation Board.
3cb2fccc 514 For more information, refer to <http://www.970eval.com>
14cf11af 515
1e76875e
OJ
516config PPC_PASEMI
517 depends on PPC_MULTIPLATFORM && PPC64
518 bool "PA Semi SoC-based platforms"
519 default n
520 select MPIC
521 select PPC_UDBG_16550
522 select GENERIC_TBSYNC
e22ba7e3 523 select PPC_NATIVE
1e76875e
OJ
524 help
525 This option enables support for PA Semi's PWRficient line
526 of SoC processors, including PA6T-1682M
527
f3f66f59 528config PPC_CELL
c01ea72a
GL
529 bool
530 default n
531
532config PPC_CELL_NATIVE
533 bool
534 select PPC_CELL
4c75a6f4 535 select PPC_DCR_MMIO
4c9d2800 536 select PPC_OF_PLATFORM_PCI
014da7ff 537 select PPC_INDIRECT_IO
e22ba7e3 538 select PPC_NATIVE
21fb5a1d 539 select MPIC
c01ea72a
GL
540 default n
541
542config PPC_IBM_CELL_BLADE
f127a2b5 543 bool "IBM Cell Blade"
14cf11af 544 depends on PPC_MULTIPLATFORM && PPC64
c01ea72a 545 select PPC_CELL_NATIVE
033ef338 546 select PPC_RTAS
edf03c1e 547 select MMIO_NVRAM
13b8a272 548 select PPC_UDBG_16550
94b60ec1 549 select UDBG_RTAS_CONSOLE
14cf11af 550
f58a9d17 551config PPC_PS3
05916eec 552 bool "Sony PS3 (incomplete)"
f58a9d17
GL
553 depends on PPC_MULTIPLATFORM && PPC64
554 select PPC_CELL
6a6c957e
GL
555 select USB_ARCH_HAS_OHCI
556 select USB_OHCI_LITTLE_ENDIAN
557 select USB_OHCI_BIG_ENDIAN_MMIO
ad75a410
GL
558 select USB_ARCH_HAS_EHCI
559 select USB_EHCI_BIG_ENDIAN_MMIO
f58a9d17
GL
560 help
561 This option enables support for the Sony PS3 game console
562 and other platforms using the PS3 hypervisor.
05916eec
GL
563 Support for this platform is not yet complete, so
564 enabling this will not result in a bootable kernel on a
565 PS3 system.
f58a9d17 566
c347b798
IK
567config PPC_CELLEB
568 bool "Toshiba's Cell Reference Set 'Celleb' Architecture"
569 depends on PPC_MULTIPLATFORM && PPC64
570 select PPC_CELL
571 select PPC_OF_PLATFORM_PCI
572 select HAS_TXX9_SERIAL
573 select PPC_UDBG_BEAT
574 select USB_OHCI_BIG_ENDIAN_MMIO
575 select USB_EHCI_BIG_ENDIAN_MMIO
576
e22ba7e3
AB
577config PPC_NATIVE
578 bool
579 depends on PPC_MULTIPLATFORM
580 help
581 Support for running natively on the hardware, i.e. without
582 a hypervisor. This option is not user-selectable but should
583 be selected by all platforms that need it.
584
585config UDBG_RTAS_CONSOLE
586 bool "RTAS based debug console"
587 depends on PPC_RTAS
588 default n
589
c347b798
IK
590config PPC_UDBG_BEAT
591 bool "BEAT based debug console"
592 depends on PPC_CELLEB
593 default n
594
14cf11af
PM
595config XICS
596 depends on PPC_PSERIES
597 bool
598 default y
599
600config U3_DART
601 bool
602 depends on PPC_MULTIPLATFORM && PPC64
603 default n
604
033ef338
PM
605config PPC_RTAS
606 bool
607 default n
608
609config RTAS_ERROR_LOGGING
610 bool
611 depends on PPC_RTAS
612 default n
613
f4fcbbe9
PM
614config RTAS_PROC
615 bool "Proc interface to RTAS"
e9add2ee 616 depends on PPC_RTAS
f4fcbbe9
PM
617 default y
618
619config RTAS_FLASH
620 tristate "Firmware flash interface"
621 depends on PPC64 && RTAS_PROC
e9add2ee 622
edf03c1e
AB
623config MMIO_NVRAM
624 bool
625 default n
626
14cf11af
PM
627config MPIC_BROKEN_U3
628 bool
629 depends on PPC_MAPLE
630 default y
631
14cf11af
PM
632config IBMVIO
633 depends on PPC_PSERIES || PPC_ISERIES
634 bool
635 default y
636
d7a30103
HS
637config IBMEBUS
638 depends on PPC_PSERIES
639 bool "Support for GX bus based adapters"
d7a30103
HS
640 help
641 Bus device driver for GX bus based adapters.
642
830825d6
PM
643config PPC_MPC106
644 bool
645 default n
646
f39224a8
PM
647config PPC_970_NAP
648 bool
649 default n
650
4cb3cee0
BH
651config PPC_INDIRECT_IO
652 bool
653 select GENERIC_IOMAP
654 default n
655
656config GENERIC_IOMAP
657 bool
658 default n
659
14cf11af
PM
660source "drivers/cpufreq/Kconfig"
661
662config CPU_FREQ_PMAC
663 bool "Support for Apple PowerBooks"
664 depends on CPU_FREQ && ADB_PMU && PPC32
665 select CPU_FREQ_TABLE
666 help
667 This adds support for frequency switching on Apple PowerBooks,
668 this currently includes some models of iBook & Titanium
669 PowerBook.
670
4350147a
BH
671config CPU_FREQ_PMAC64
672 bool "Support for some Apple G5s"
7ed14c21 673 depends on CPU_FREQ && PPC64
4350147a
BH
674 select CPU_FREQ_TABLE
675 help
676 This adds support for frequency switching on Apple iMac G5,
677 and some of the more recent desktop G5 machines as well.
678
14cf11af
PM
679config PPC601_SYNC_FIX
680 bool "Workarounds for PPC601 bugs"
681 depends on 6xx && (PPC_PREP || PPC_PMAC)
682 help
683 Some versions of the PPC601 (the first PowerPC chip) have bugs which
684 mean that extra synchronization instructions are required near
685 certain instructions, typically those that make major changes to the
686 CPU state. These extra instructions reduce performance slightly.
687 If you say N here, these extra instructions will not be included,
688 resulting in a kernel which will run faster but may not run at all
689 on some systems with the PPC601 chip.
690
691 If in doubt, say Y here.
692
693config TAU
9b781727 694 bool "On-chip CPU temperature sensor support"
14cf11af
PM
695 depends on 6xx
696 help
697 G3 and G4 processors have an on-chip temperature sensor called the
698 'Thermal Assist Unit (TAU)', which, in theory, can measure the on-die
699 temperature within 2-4 degrees Celsius. This option shows the current
700 on-die temperature in /proc/cpuinfo if the cpu supports it.
701
702 Unfortunately, on some chip revisions, this sensor is very inaccurate
9b781727 703 and in many cases, does not work at all, so don't assume the cpu
14cf11af
PM
704 temp is actually what /proc/cpuinfo says it is.
705
706config TAU_INT
707 bool "Interrupt driven TAU driver (DANGEROUS)"
708 depends on TAU
709 ---help---
710 The TAU supports an interrupt driven mode which causes an interrupt
711 whenever the temperature goes out of range. This is the fastest way
712 to get notified the temp has exceeded a range. With this option off,
713 a timer is used to re-check the temperature periodically.
714
715 However, on some cpus it appears that the TAU interrupt hardware
716 is buggy and can cause a situation which would lead unexplained hard
717 lockups.
718
719 Unless you are extending the TAU driver, or enjoy kernel/hardware
720 debugging, leave this option off.
721
722config TAU_AVERAGE
723 bool "Average high and low temp"
724 depends on TAU
725 ---help---
726 The TAU hardware can compare the temperature to an upper and lower
727 bound. The default behavior is to show both the upper and lower
728 bound in /proc/cpuinfo. If the range is large, the temperature is
729 either changing a lot, or the TAU hardware is broken (likely on some
730 G4's). If the range is small (around 4 degrees), the temperature is
731 relatively stable. If you say Y here, a single temperature value,
732 halfway between the upper and lower bounds, will be reported in
733 /proc/cpuinfo.
734
735 If in doubt, say N here.
c2201536 736
14cf11af
PM
737endmenu
738
739source arch/powerpc/platforms/embedded6xx/Kconfig
740source arch/powerpc/platforms/4xx/Kconfig
ed943c1f 741source arch/powerpc/platforms/82xx/Kconfig
08264cbc 742source arch/powerpc/platforms/83xx/Kconfig
14cf11af 743source arch/powerpc/platforms/85xx/Kconfig
c9b484b5 744source arch/powerpc/platforms/86xx/Kconfig
14cf11af 745source arch/powerpc/platforms/8xx/Kconfig
67207b96 746source arch/powerpc/platforms/cell/Kconfig
f58a9d17 747source arch/powerpc/platforms/ps3/Kconfig
31c56d82 748source arch/powerpc/platforms/pasemi/Kconfig
14cf11af
PM
749
750menu "Kernel options"
751
752config HIGHMEM
753 bool "High memory support"
754 depends on PPC32
755
756source kernel/Kconfig.hz
757source kernel/Kconfig.preempt
758source "fs/Kconfig.binfmt"
759
760# We optimistically allocate largepages from the VM, so make the limit
761# large enough (16MB). This badly named config option is actually
762# max order + 1
763config FORCE_MAX_ZONEORDER
764 int
765 depends on PPC64
02864867 766 default "9" if PPC_64K_PAGES
14cf11af
PM
767 default "13"
768
769config MATH_EMULATION
770 bool "Math emulation"
4d52719a 771 depends on 4xx || 8xx || E200 || PPC_MPC832x || E500
14cf11af
PM
772 ---help---
773 Some PowerPC chips designed for embedded applications do not have
774 a floating-point unit and therefore do not implement the
775 floating-point instructions in the PowerPC instruction set. If you
776 say Y here, the kernel will include code to emulate a floating-point
777 unit, which will allow programs that use floating-point
778 instructions to run.
779
780config IOMMU_VMERGE
781 bool "Enable IOMMU virtual merging (EXPERIMENTAL)"
782 depends on EXPERIMENTAL && PPC64
783 default n
784 help
785 Cause IO segments sent to a device for DMA to be merged virtually
786 by the IOMMU when they happen to have been allocated contiguously.
787 This doesn't add pressure to the IOMMU allocator. However, some
788 drivers don't support getting large merged segments coming back
789 from *_map_sg(). Say Y if you know the drivers you are using are
790 properly handling this case.
791
792config HOTPLUG_CPU
793 bool "Support for enabling/disabling CPUs"
794 depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC)
795 ---help---
796 Say Y here to be able to disable and re-enable individual
797 CPUs at runtime on SMP machines.
798
799 Say N if you are unsure.
800
cc57637b
YG
801config ARCH_ENABLE_MEMORY_HOTPLUG
802 def_bool y
803
14cf11af
PM
804config KEXEC
805 bool "kexec system call (EXPERIMENTAL)"
806 depends on PPC_MULTIPLATFORM && EXPERIMENTAL
807 help
808 kexec is a system call that implements the ability to shutdown your
809 current kernel, and to start another kernel. It is like a reboot
1f1332f7 810 but it is independent of the system firmware. And like a reboot
14cf11af
PM
811 you can start any kernel with it, not just Linux.
812
1f1332f7 813 The name comes from the similarity to the exec system call.
14cf11af
PM
814
815 It is an ongoing process to be certain the hardware in a machine
816 is properly shutdown, so do not be surprised if this code does not
817 initially work for you. It may help to enable device hotplugging
818 support. As of this writing the exact hardware interface is
819 strongly in flux, so no good recommendation can be made.
820
e8625d46 821config CRASH_DUMP
cd9c99d7 822 bool "Build a kdump crash kernel (EXPERIMENTAL)"
e8625d46
HM
823 depends on PPC_MULTIPLATFORM && PPC64 && EXPERIMENTAL
824 help
825 Build a kernel suitable for use as a kdump capture kernel.
826 The kernel will be linked at a different address than normal, and
827 so can only be used for Kdump.
828
829 Don't change this unless you know what you are doing.
830
14cf11af
PM
831config EMBEDDEDBOOT
832 bool
833 depends on 8xx || 8260
834 default y
835
836config PC_KEYBOARD
837 bool "PC PS/2 style Keyboard"
838 depends on 4xx || CPM2
839
840config PPCBUG_NVRAM
841 bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC
842 default y if PPC_PREP
843
844config IRQ_ALL_CPUS
845 bool "Distribute interrupts on all CPUs by default"
846 depends on SMP && !MV64360
847 help
848 This option gives the kernel permission to distribute IRQs across
849 multiple CPUs. Saying N here will route all IRQs to the first
850 CPU. Generally saying Y is safe, although some problems have been
851 reported with SMP Power Macintoshes with this option enabled.
852
853source "arch/powerpc/platforms/pseries/Kconfig"
854
ffa27b6b
AW
855config NUMA
856 bool "NUMA support"
857 depends on PPC64
858 default y if SMP && PPC_PSERIES
859
c80d79d7
YG
860config NODES_SHIFT
861 int
862 default "4"
863 depends on NEED_MULTIPLE_NODES
864
14cf11af
PM
865config ARCH_SELECT_MEMORY_MODEL
866 def_bool y
867 depends on PPC64
868
869config ARCH_FLATMEM_ENABLE
9100b205
AW
870 def_bool y
871 depends on (PPC64 && !NUMA) || PPC32
14cf11af 872
45fb6cea 873config ARCH_SPARSEMEM_ENABLE
14cf11af 874 def_bool y
9100b205 875 depends on PPC64
14cf11af 876
45fb6cea 877config ARCH_SPARSEMEM_DEFAULT
14cf11af 878 def_bool y
36b600f2 879 depends on (SMP && PPC_PSERIES) || PPC_CELL
14cf11af 880
c67c3cb4 881config ARCH_POPULATES_NODE_MAP
14cf11af 882 def_bool y
c67c3cb4
MG
883
884source "mm/Kconfig"
14cf11af 885
7e9191da
MK
886config ARCH_MEMORY_PROBE
887 def_bool y
888 depends on MEMORY_HOTPLUG
889
75167957
AW
890# Some NUMA nodes have memory ranges that span
891# other nodes. Even though a pfn is valid and
892# between a node's start and end pfns, it may not
893# reside on that node. See memmap_init_zone()
894# for details.
895config NODES_SPAN_OTHER_NODES
896 def_bool y
897 depends on NEED_MULTIPLE_NODES
898
3c726f8d
BH
899config PPC_64K_PAGES
900 bool "64k page size"
863c84b9 901 depends on PPC64
3c726f8d
BH
902 help
903 This option changes the kernel logical page size to 64k. On machines
904 without processor support for 64k pages, the kernel will simulate
905 them by loading each individual 4k page on demand transparently,
906 while on hardware with such support, it will be used to map
907 normal application pages.
908
14cf11af
PM
909config SCHED_SMT
910 bool "SMT (Hyperthreading) scheduler support"
911 depends on PPC64 && SMP
14cf11af
PM
912 help
913 SMT scheduler support improves the CPU scheduler's decision making
914 when dealing with POWER5 cpus at a cost of slightly increased
915 overhead in some places. If unsure say N here.
916
917config PROC_DEVICETREE
5f296755
PM
918 bool "Support for device tree in /proc"
919 depends on PROC_FS
14cf11af
PM
920 help
921 This option adds a device-tree directory under /proc which contains
922 an image of the device tree that the kernel copies from Open
5f296755 923 Firmware or other boot firmware. If unsure, say Y here.
14cf11af
PM
924
925source "arch/powerpc/platforms/prep/Kconfig"
926
927config CMDLINE_BOOL
928 bool "Default bootloader kernel arguments"
14cf11af
PM
929
930config CMDLINE
931 string "Initial kernel command string"
932 depends on CMDLINE_BOOL
933 default "console=ttyS0,9600 console=tty0 root=/dev/sda2"
934 help
935 On some platforms, there is currently no way for the boot loader to
936 pass arguments to the kernel. For these platforms, you can supply
937 some command-line options at build time by entering them here. In
938 most cases you will need to specify the root device here.
939
940if !44x || BROKEN
941source kernel/power/Kconfig
942endif
943
944config SECCOMP
945 bool "Enable seccomp to safely compute untrusted bytecode"
946 depends on PROC_FS
947 default y
948 help
949 This kernel feature is useful for number crunching applications
950 that may need to compute untrusted bytecode during their
951 execution. By using pipes or other transports made available to
952 the process as file descriptors supporting the read/write
953 syscalls, it's possible to isolate those applications in
954 their own address space using seccomp. Once seccomp is
955 enabled via /proc/<pid>/seccomp, it cannot be disabled
956 and the task is only allowed to execute a few safe syscalls
957 defined by each seccomp mode.
958
959 If unsure, say Y. Only embedded should say N here.
960
961endmenu
962
963config ISA_DMA_API
964 bool
965 default y
966
967menu "Bus options"
968
969config ISA
970 bool "Support for ISA-bus hardware"
971 depends on PPC_PREP || PPC_CHRP
f9bd170a 972 select PPC_I8259
14cf11af
PM
973 help
974 Find out whether you have ISA slots on your motherboard. ISA is the
975 name of a bus system, i.e. the way the CPU talks to the other stuff
976 inside your box. If you have an Apple machine, say N here; if you
977 have an IBM RS/6000 or pSeries machine or a PReP machine, say Y. If
978 you have an embedded board, consult your board documentation.
979
980config GENERIC_ISA_DMA
981 bool
982 depends on PPC64 || POWER4 || 6xx && !CPM2
983 default y
984
7233593b
ZR
985config MPIC
986 bool
987 default n
988
989config MPIC_WEIRD
990 bool
991 default n
992
f9bd170a
PM
993config PPC_I8259
994 bool
f9bd170a
PM
995 default n
996
25635c71
PM
997config PPC_INDIRECT_PCI
998 bool
999 depends on PCI
63dafe57 1000 default y if 40x || 44x
25635c71
PM
1001 default n
1002
14cf11af
PM
1003config EISA
1004 bool
1005
1006config SBUS
1007 bool
1008
08264cbc
KG
1009config FSL_SOC
1010 bool
1011
14cf11af
PM
1012# Yes MCA RS/6000s exist but Linux-PPC does not currently support any
1013config MCA
1014 bool
1015
1016config PCI
53158620 1017 bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \
f58a9d17 1018 || PPC_MPC52xx || (EMBEDDED && PPC_ISERIES) || MPC7448HPC2 || PPC_PS3
53158620
JL
1019 default y if !40x && !CPM2 && !8xx && !APUS && !PPC_83xx \
1020 && !PPC_85xx && !PPC_86xx
14cf11af
PM
1021 default PCI_PERMEDIA if !4xx && !CPM2 && !8xx && APUS
1022 default PCI_QSPAN if !4xx && !CPM2 && 8xx
1023 help
1024 Find out whether your system includes a PCI bus. PCI is the name of
1025 a bus system, i.e. the way the CPU talks to the other stuff inside
1026 your box. If you say Y here, the kernel will include drivers and
1027 infrastructure code to support PCI bus devices.
1028
1029config PCI_DOMAINS
1030 bool
1031 default PCI
1032
14cf11af
PM
1033config PCI_QSPAN
1034 bool "QSpan PCI"
1035 depends on !4xx && !CPM2 && 8xx
f9bd170a 1036 select PPC_I8259
14cf11af
PM
1037 help
1038 Say Y here if you have a system based on a Motorola 8xx-series
1039 embedded processor with a QSPAN PCI interface, otherwise say N.
1040
1041config PCI_8260
1042 bool
1043 depends on PCI && 8260
25635c71 1044 select PPC_INDIRECT_PCI
14cf11af
PM
1045 default y
1046
1047config 8260_PCI9
4a3ecc62 1048 bool "Enable workaround for MPC826x erratum PCI 9"
14cf11af
PM
1049 depends on PCI_8260 && !ADS8272
1050 default y
1051
1052choice
4a3ecc62 1053 prompt "IDMA channel for PCI 9 workaround"
14cf11af
PM
1054 depends on 8260_PCI9
1055
1056config 8260_PCI9_IDMA1
1057 bool "IDMA1"
1058
1059config 8260_PCI9_IDMA2
1060 bool "IDMA2"
1061
1062config 8260_PCI9_IDMA3
1063 bool "IDMA3"
1064
1065config 8260_PCI9_IDMA4
1066 bool "IDMA4"
1067
1068endchoice
1069
bb53bb3d
JM
1070source "drivers/pci/pcie/Kconfig"
1071
14cf11af
PM
1072source "drivers/pci/Kconfig"
1073
1074source "drivers/pcmcia/Kconfig"
1075
1076source "drivers/pci/hotplug/Kconfig"
1077
1078endmenu
1079
1080menu "Advanced setup"
1081 depends on PPC32
1082
1083config ADVANCED_OPTIONS
1084 bool "Prompt for advanced kernel configuration options"
1085 help
1086 This option will enable prompting for a variety of advanced kernel
1087 configuration options. These options can cause the kernel to not
1088 work if they are set incorrectly, but can be used to optimize certain
1089 aspects of kernel memory management.
1090
1091 Unless you know what you are doing, say N here.
1092
1093comment "Default settings for advanced configuration options are used"
1094 depends on !ADVANCED_OPTIONS
1095
1096config HIGHMEM_START_BOOL
1097 bool "Set high memory pool address"
1098 depends on ADVANCED_OPTIONS && HIGHMEM
1099 help
1100 This option allows you to set the base address of the kernel virtual
1101 area used to map high memory pages. This can be useful in
1102 optimizing the layout of kernel virtual memory.
1103
1104 Say N here unless you know what you are doing.
1105
1106config HIGHMEM_START
1107 hex "Virtual start address of high memory pool" if HIGHMEM_START_BOOL
1108 default "0xfe000000"
1109
1110config LOWMEM_SIZE_BOOL
1111 bool "Set maximum low memory"
1112 depends on ADVANCED_OPTIONS
1113 help
1114 This option allows you to set the maximum amount of memory which
1115 will be used as "low memory", that is, memory which the kernel can
1116 access directly, without having to set up a kernel virtual mapping.
1117 This can be useful in optimizing the layout of kernel virtual
1118 memory.
1119
1120 Say N here unless you know what you are doing.
1121
1122config LOWMEM_SIZE
1123 hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
1124 default "0x30000000"
1125
1126config KERNEL_START_BOOL
1127 bool "Set custom kernel base address"
1128 depends on ADVANCED_OPTIONS
1129 help
1130 This option allows you to set the kernel virtual address at which
1131 the kernel will map low memory (the kernel image will be linked at
1132 this address). This can be useful in optimizing the virtual memory
1133 layout of the system.
1134
1135 Say N here unless you know what you are doing.
1136
1137config KERNEL_START
1138 hex "Virtual address of kernel base" if KERNEL_START_BOOL
1139 default "0xc0000000"
1140
1141config TASK_SIZE_BOOL
1142 bool "Set custom user task size"
1143 depends on ADVANCED_OPTIONS
1144 help
1145 This option allows you to set the amount of virtual address space
1146 allocated to user tasks. This can be useful in optimizing the
1147 virtual memory layout of the system.
1148
1149 Say N here unless you know what you are doing.
1150
1151config TASK_SIZE
1152 hex "Size of user task space" if TASK_SIZE_BOOL
1153 default "0x80000000"
1154
1155config CONSISTENT_START_BOOL
1156 bool "Set custom consistent memory pool address"
1157 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
1158 help
1159 This option allows you to set the base virtual address
4b3f686d 1160 of the consistent memory pool. This pool of virtual
14cf11af
PM
1161 memory is used to make consistent memory allocations.
1162
1163config CONSISTENT_START
1164 hex "Base virtual address of consistent memory pool" if CONSISTENT_START_BOOL
1165 default "0xff100000" if NOT_COHERENT_CACHE
1166
1167config CONSISTENT_SIZE_BOOL
1168 bool "Set custom consistent memory pool size"
1169 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
1170 help
4b3f686d 1171 This option allows you to set the size of the
14cf11af
PM
1172 consistent memory pool. This pool of virtual memory
1173 is used to make consistent memory allocations.
1174
1175config CONSISTENT_SIZE
1176 hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL
1177 default "0x00200000" if NOT_COHERENT_CACHE
1178
1179config BOOT_LOAD_BOOL
1180 bool "Set the boot link/load address"
1181 depends on ADVANCED_OPTIONS && !PPC_MULTIPLATFORM
1182 help
1183 This option allows you to set the initial load address of the zImage
1184 or zImage.initrd file. This can be useful if you are on a board
1185 which has a small amount of memory.
1186
1187 Say N here unless you know what you are doing.
1188
1189config BOOT_LOAD
1190 hex "Link/load address for booting" if BOOT_LOAD_BOOL
1191 default "0x00400000" if 40x || 8xx || 8260
1192 default "0x01000000" if 44x
1193 default "0x00800000"
1194
1195config PIN_TLB
1196 bool "Pinned Kernel TLBs (860 ONLY)"
1197 depends on ADVANCED_OPTIONS && 8xx
1198endmenu
1199
cabb5587
SR
1200if PPC64
1201config KERNEL_START
1202 hex
eeb2d218 1203 default "0xc000000000000000"
cabb5587
SR
1204endif
1205
14cf11af
PM
1206source "net/Kconfig"
1207
1208source "drivers/Kconfig"
1209
1210source "fs/Kconfig"
1211
1212# XXX source "arch/ppc/8xx_io/Kconfig"
1213
1214# XXX source "arch/ppc/8260_io/Kconfig"
1215
98658538
LY
1216source "arch/powerpc/sysdev/qe_lib/Kconfig"
1217
14cf11af
PM
1218source "arch/powerpc/platforms/iseries/Kconfig"
1219
1220source "lib/Kconfig"
1221
cd6b0762
PP
1222menu "Instrumentation Support"
1223 depends on EXPERIMENTAL
1224
14cf11af
PM
1225source "arch/powerpc/oprofile/Kconfig"
1226
cd6b0762
PP
1227config KPROBES
1228 bool "Kprobes (EXPERIMENTAL)"
82090035 1229 depends on !BOOKE && !4xx && KALLSYMS && EXPERIMENTAL && MODULES
cd6b0762
PP
1230 help
1231 Kprobes allows you to trap at almost any kernel address and
1232 execute a callback function. register_kprobe() establishes
1233 a probepoint and specifies the callback. Kprobes is useful
1234 for kernel debugging, non-intrusive instrumentation and testing.
1235 If in doubt, say "N".
1236endmenu
1237
14cf11af
PM
1238source "arch/powerpc/Kconfig.debug"
1239
1240source "security/Kconfig"
1241
1242config KEYS_COMPAT
1243 bool
1244 depends on COMPAT && KEYS
1245 default y
1246
1247source "crypto/Kconfig"
This page took 0.381134 seconds and 5 git commands to generate.