[POWERPC] Split 52xx platforms into their own Kconfig file
[linux-block.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
bed59275 92 default !PPC_PSERIES || PCI
14cf11af 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
5396132c 435source "arch/powerpc/platforms/52xx/Kconfig"
6b642531 436
14cf11af 437config PPC_PMAC
4a3ecc62 438 bool "Apple PowerMac based machines"
14cf11af 439 depends on PPC_MULTIPLATFORM
7233593b 440 select MPIC
25635c71 441 select PPC_INDIRECT_PCI if PPC32
b6a4ce52 442 select PPC_MPC106 if PPC32
e22ba7e3 443 select PPC_NATIVE
14cf11af
PM
444 default y
445
446config PPC_PMAC64
447 bool
448 depends on PPC_PMAC && POWER4
7233593b 449 select MPIC
35499c01 450 select U3_DART
1beb6a7d 451 select MPIC_BROKEN_U3
8ad200d7 452 select GENERIC_TBSYNC
f39224a8 453 select PPC_970_NAP
14cf11af
PM
454 default y
455
456config PPC_PREP
4a3ecc62 457 bool "PowerPC Reference Platform (PReP) based machines"
5be396b0 458 depends on PPC_MULTIPLATFORM && PPC32 && BROKEN
7233593b 459 select MPIC
f9bd170a 460 select PPC_I8259
25635c71 461 select PPC_INDIRECT_PCI
13b8a272 462 select PPC_UDBG_16550
e22ba7e3 463 select PPC_NATIVE
7232846b 464 default n
14cf11af
PM
465
466config PPC_MAPLE
467 depends on PPC_MULTIPLATFORM && PPC64
4a3ecc62 468 bool "Maple 970FX Evaluation Board"
7233593b 469 select MPIC
14cf11af
PM
470 select U3_DART
471 select MPIC_BROKEN_U3
8ad200d7 472 select GENERIC_TBSYNC
13b8a272 473 select PPC_UDBG_16550
f39224a8 474 select PPC_970_NAP
e22ba7e3 475 select PPC_NATIVE
9d9d868e 476 select PPC_RTAS
4297c986 477 select MMIO_NVRAM
8cdf92a9 478 select ATA_NONSTANDARD if ATA
14cf11af
PM
479 default n
480 help
481 This option enables support for the Maple 970FX Evaluation Board.
3cb2fccc 482 For more information, refer to <http://www.970eval.com>
14cf11af 483
1e76875e
OJ
484config PPC_PASEMI
485 depends on PPC_MULTIPLATFORM && PPC64
486 bool "PA Semi SoC-based platforms"
487 default n
488 select MPIC
489 select PPC_UDBG_16550
490 select GENERIC_TBSYNC
e22ba7e3 491 select PPC_NATIVE
1e76875e
OJ
492 help
493 This option enables support for PA Semi's PWRficient line
494 of SoC processors, including PA6T-1682M
495
f3f66f59 496config PPC_CELL
c01ea72a
GL
497 bool
498 default n
499
500config PPC_CELL_NATIVE
501 bool
502 select PPC_CELL
4c75a6f4 503 select PPC_DCR_MMIO
4c9d2800 504 select PPC_OF_PLATFORM_PCI
014da7ff 505 select PPC_INDIRECT_IO
e22ba7e3 506 select PPC_NATIVE
21fb5a1d 507 select MPIC
c01ea72a
GL
508 default n
509
510config PPC_IBM_CELL_BLADE
f127a2b5 511 bool "IBM Cell Blade"
14cf11af 512 depends on PPC_MULTIPLATFORM && PPC64
c01ea72a 513 select PPC_CELL_NATIVE
033ef338 514 select PPC_RTAS
edf03c1e 515 select MMIO_NVRAM
13b8a272 516 select PPC_UDBG_16550
94b60ec1 517 select UDBG_RTAS_CONSOLE
14cf11af 518
f58a9d17 519config PPC_PS3
05916eec 520 bool "Sony PS3 (incomplete)"
f58a9d17
GL
521 depends on PPC_MULTIPLATFORM && PPC64
522 select PPC_CELL
6a6c957e
GL
523 select USB_ARCH_HAS_OHCI
524 select USB_OHCI_LITTLE_ENDIAN
525 select USB_OHCI_BIG_ENDIAN_MMIO
ad75a410
GL
526 select USB_ARCH_HAS_EHCI
527 select USB_EHCI_BIG_ENDIAN_MMIO
f58a9d17
GL
528 help
529 This option enables support for the Sony PS3 game console
530 and other platforms using the PS3 hypervisor.
05916eec
GL
531 Support for this platform is not yet complete, so
532 enabling this will not result in a bootable kernel on a
533 PS3 system.
f58a9d17 534
c347b798
IK
535config PPC_CELLEB
536 bool "Toshiba's Cell Reference Set 'Celleb' Architecture"
537 depends on PPC_MULTIPLATFORM && PPC64
538 select PPC_CELL
539 select PPC_OF_PLATFORM_PCI
540 select HAS_TXX9_SERIAL
541 select PPC_UDBG_BEAT
542 select USB_OHCI_BIG_ENDIAN_MMIO
543 select USB_EHCI_BIG_ENDIAN_MMIO
544
e22ba7e3
AB
545config PPC_NATIVE
546 bool
547 depends on PPC_MULTIPLATFORM
548 help
549 Support for running natively on the hardware, i.e. without
550 a hypervisor. This option is not user-selectable but should
551 be selected by all platforms that need it.
552
553config UDBG_RTAS_CONSOLE
554 bool "RTAS based debug console"
555 depends on PPC_RTAS
556 default n
557
c347b798
IK
558config PPC_UDBG_BEAT
559 bool "BEAT based debug console"
560 depends on PPC_CELLEB
561 default n
562
14cf11af
PM
563config XICS
564 depends on PPC_PSERIES
565 bool
566 default y
567
568config U3_DART
569 bool
570 depends on PPC_MULTIPLATFORM && PPC64
571 default n
572
033ef338
PM
573config PPC_RTAS
574 bool
575 default n
576
577config RTAS_ERROR_LOGGING
578 bool
579 depends on PPC_RTAS
580 default n
581
f4fcbbe9
PM
582config RTAS_PROC
583 bool "Proc interface to RTAS"
e9add2ee 584 depends on PPC_RTAS
f4fcbbe9
PM
585 default y
586
587config RTAS_FLASH
588 tristate "Firmware flash interface"
589 depends on PPC64 && RTAS_PROC
e9add2ee 590
0e826643
CK
591config PPC_PMI
592 tristate "Support for PMI"
593 depends PPC_IBM_CELL_BLADE
594 help
595 PMI (Platform Management Interrupt) is a way to
596 communicate with the BMC (Baseboard Mangement Controller).
597 It is used in some IBM Cell blades.
598 default m
599
edf03c1e
AB
600config MMIO_NVRAM
601 bool
602 default n
603
14cf11af
PM
604config MPIC_BROKEN_U3
605 bool
606 depends on PPC_MAPLE
607 default y
608
14cf11af
PM
609config IBMVIO
610 depends on PPC_PSERIES || PPC_ISERIES
611 bool
612 default y
613
d7a30103
HS
614config IBMEBUS
615 depends on PPC_PSERIES
616 bool "Support for GX bus based adapters"
d7a30103
HS
617 help
618 Bus device driver for GX bus based adapters.
619
830825d6
PM
620config PPC_MPC106
621 bool
622 default n
623
f39224a8
PM
624config PPC_970_NAP
625 bool
626 default n
627
4cb3cee0
BH
628config PPC_INDIRECT_IO
629 bool
630 select GENERIC_IOMAP
631 default n
632
633config GENERIC_IOMAP
634 bool
635 default n
636
14cf11af
PM
637source "drivers/cpufreq/Kconfig"
638
639config CPU_FREQ_PMAC
640 bool "Support for Apple PowerBooks"
641 depends on CPU_FREQ && ADB_PMU && PPC32
642 select CPU_FREQ_TABLE
643 help
644 This adds support for frequency switching on Apple PowerBooks,
645 this currently includes some models of iBook & Titanium
646 PowerBook.
647
4350147a
BH
648config CPU_FREQ_PMAC64
649 bool "Support for some Apple G5s"
7ed14c21 650 depends on CPU_FREQ && PPC64
4350147a
BH
651 select CPU_FREQ_TABLE
652 help
653 This adds support for frequency switching on Apple iMac G5,
654 and some of the more recent desktop G5 machines as well.
655
14cf11af
PM
656config PPC601_SYNC_FIX
657 bool "Workarounds for PPC601 bugs"
658 depends on 6xx && (PPC_PREP || PPC_PMAC)
659 help
660 Some versions of the PPC601 (the first PowerPC chip) have bugs which
661 mean that extra synchronization instructions are required near
662 certain instructions, typically those that make major changes to the
663 CPU state. These extra instructions reduce performance slightly.
664 If you say N here, these extra instructions will not be included,
665 resulting in a kernel which will run faster but may not run at all
666 on some systems with the PPC601 chip.
667
668 If in doubt, say Y here.
669
670config TAU
9b781727 671 bool "On-chip CPU temperature sensor support"
14cf11af
PM
672 depends on 6xx
673 help
674 G3 and G4 processors have an on-chip temperature sensor called the
675 'Thermal Assist Unit (TAU)', which, in theory, can measure the on-die
676 temperature within 2-4 degrees Celsius. This option shows the current
677 on-die temperature in /proc/cpuinfo if the cpu supports it.
678
679 Unfortunately, on some chip revisions, this sensor is very inaccurate
9b781727 680 and in many cases, does not work at all, so don't assume the cpu
14cf11af
PM
681 temp is actually what /proc/cpuinfo says it is.
682
683config TAU_INT
684 bool "Interrupt driven TAU driver (DANGEROUS)"
685 depends on TAU
686 ---help---
687 The TAU supports an interrupt driven mode which causes an interrupt
688 whenever the temperature goes out of range. This is the fastest way
689 to get notified the temp has exceeded a range. With this option off,
690 a timer is used to re-check the temperature periodically.
691
692 However, on some cpus it appears that the TAU interrupt hardware
693 is buggy and can cause a situation which would lead unexplained hard
694 lockups.
695
696 Unless you are extending the TAU driver, or enjoy kernel/hardware
697 debugging, leave this option off.
698
699config TAU_AVERAGE
700 bool "Average high and low temp"
701 depends on TAU
702 ---help---
703 The TAU hardware can compare the temperature to an upper and lower
704 bound. The default behavior is to show both the upper and lower
705 bound in /proc/cpuinfo. If the range is large, the temperature is
706 either changing a lot, or the TAU hardware is broken (likely on some
707 G4's). If the range is small (around 4 degrees), the temperature is
708 relatively stable. If you say Y here, a single temperature value,
709 halfway between the upper and lower bounds, will be reported in
710 /proc/cpuinfo.
711
712 If in doubt, say N here.
c2201536 713
14cf11af
PM
714endmenu
715
716source arch/powerpc/platforms/embedded6xx/Kconfig
717source arch/powerpc/platforms/4xx/Kconfig
ed943c1f 718source arch/powerpc/platforms/82xx/Kconfig
08264cbc 719source arch/powerpc/platforms/83xx/Kconfig
14cf11af 720source arch/powerpc/platforms/85xx/Kconfig
c9b484b5 721source arch/powerpc/platforms/86xx/Kconfig
14cf11af 722source arch/powerpc/platforms/8xx/Kconfig
67207b96 723source arch/powerpc/platforms/cell/Kconfig
f58a9d17 724source arch/powerpc/platforms/ps3/Kconfig
31c56d82 725source arch/powerpc/platforms/pasemi/Kconfig
14cf11af
PM
726
727menu "Kernel options"
728
729config HIGHMEM
730 bool "High memory support"
731 depends on PPC32
732
733source kernel/Kconfig.hz
734source kernel/Kconfig.preempt
735source "fs/Kconfig.binfmt"
736
737# We optimistically allocate largepages from the VM, so make the limit
738# large enough (16MB). This badly named config option is actually
739# max order + 1
740config FORCE_MAX_ZONEORDER
741 int
742 depends on PPC64
02864867 743 default "9" if PPC_64K_PAGES
14cf11af
PM
744 default "13"
745
746config MATH_EMULATION
747 bool "Math emulation"
4d52719a 748 depends on 4xx || 8xx || E200 || PPC_MPC832x || E500
14cf11af
PM
749 ---help---
750 Some PowerPC chips designed for embedded applications do not have
751 a floating-point unit and therefore do not implement the
752 floating-point instructions in the PowerPC instruction set. If you
753 say Y here, the kernel will include code to emulate a floating-point
754 unit, which will allow programs that use floating-point
755 instructions to run.
756
757config IOMMU_VMERGE
758 bool "Enable IOMMU virtual merging (EXPERIMENTAL)"
759 depends on EXPERIMENTAL && PPC64
760 default n
761 help
762 Cause IO segments sent to a device for DMA to be merged virtually
763 by the IOMMU when they happen to have been allocated contiguously.
764 This doesn't add pressure to the IOMMU allocator. However, some
765 drivers don't support getting large merged segments coming back
766 from *_map_sg(). Say Y if you know the drivers you are using are
767 properly handling this case.
768
769config HOTPLUG_CPU
770 bool "Support for enabling/disabling CPUs"
771 depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC)
772 ---help---
773 Say Y here to be able to disable and re-enable individual
774 CPUs at runtime on SMP machines.
775
776 Say N if you are unsure.
777
cc57637b
YG
778config ARCH_ENABLE_MEMORY_HOTPLUG
779 def_bool y
780
14cf11af
PM
781config KEXEC
782 bool "kexec system call (EXPERIMENTAL)"
783 depends on PPC_MULTIPLATFORM && EXPERIMENTAL
784 help
785 kexec is a system call that implements the ability to shutdown your
786 current kernel, and to start another kernel. It is like a reboot
1f1332f7 787 but it is independent of the system firmware. And like a reboot
14cf11af
PM
788 you can start any kernel with it, not just Linux.
789
1f1332f7 790 The name comes from the similarity to the exec system call.
14cf11af
PM
791
792 It is an ongoing process to be certain the hardware in a machine
793 is properly shutdown, so do not be surprised if this code does not
794 initially work for you. It may help to enable device hotplugging
795 support. As of this writing the exact hardware interface is
796 strongly in flux, so no good recommendation can be made.
797
e8625d46 798config CRASH_DUMP
cd9c99d7 799 bool "Build a kdump crash kernel (EXPERIMENTAL)"
e8625d46
HM
800 depends on PPC_MULTIPLATFORM && PPC64 && EXPERIMENTAL
801 help
802 Build a kernel suitable for use as a kdump capture kernel.
803 The kernel will be linked at a different address than normal, and
804 so can only be used for Kdump.
805
806 Don't change this unless you know what you are doing.
807
14cf11af
PM
808config EMBEDDEDBOOT
809 bool
810 depends on 8xx || 8260
811 default y
812
813config PC_KEYBOARD
814 bool "PC PS/2 style Keyboard"
815 depends on 4xx || CPM2
816
817config PPCBUG_NVRAM
818 bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC
819 default y if PPC_PREP
820
821config IRQ_ALL_CPUS
822 bool "Distribute interrupts on all CPUs by default"
823 depends on SMP && !MV64360
824 help
825 This option gives the kernel permission to distribute IRQs across
826 multiple CPUs. Saying N here will route all IRQs to the first
827 CPU. Generally saying Y is safe, although some problems have been
828 reported with SMP Power Macintoshes with this option enabled.
829
830source "arch/powerpc/platforms/pseries/Kconfig"
831
ffa27b6b
AW
832config NUMA
833 bool "NUMA support"
834 depends on PPC64
835 default y if SMP && PPC_PSERIES
836
c80d79d7
YG
837config NODES_SHIFT
838 int
839 default "4"
840 depends on NEED_MULTIPLE_NODES
841
14cf11af
PM
842config ARCH_SELECT_MEMORY_MODEL
843 def_bool y
844 depends on PPC64
845
846config ARCH_FLATMEM_ENABLE
9100b205
AW
847 def_bool y
848 depends on (PPC64 && !NUMA) || PPC32
14cf11af 849
45fb6cea 850config ARCH_SPARSEMEM_ENABLE
14cf11af 851 def_bool y
9100b205 852 depends on PPC64
14cf11af 853
45fb6cea 854config ARCH_SPARSEMEM_DEFAULT
14cf11af 855 def_bool y
78bde53e 856 depends on (SMP && PPC_PSERIES) || PPC_PS3
14cf11af 857
c67c3cb4 858config ARCH_POPULATES_NODE_MAP
14cf11af 859 def_bool y
c67c3cb4
MG
860
861source "mm/Kconfig"
14cf11af 862
7e9191da
MK
863config ARCH_MEMORY_PROBE
864 def_bool y
865 depends on MEMORY_HOTPLUG
866
75167957
AW
867# Some NUMA nodes have memory ranges that span
868# other nodes. Even though a pfn is valid and
869# between a node's start and end pfns, it may not
870# reside on that node. See memmap_init_zone()
871# for details.
872config NODES_SPAN_OTHER_NODES
873 def_bool y
874 depends on NEED_MULTIPLE_NODES
875
3c726f8d
BH
876config PPC_64K_PAGES
877 bool "64k page size"
863c84b9 878 depends on PPC64
3c726f8d
BH
879 help
880 This option changes the kernel logical page size to 64k. On machines
881 without processor support for 64k pages, the kernel will simulate
882 them by loading each individual 4k page on demand transparently,
883 while on hardware with such support, it will be used to map
884 normal application pages.
885
14cf11af
PM
886config SCHED_SMT
887 bool "SMT (Hyperthreading) scheduler support"
888 depends on PPC64 && SMP
14cf11af
PM
889 help
890 SMT scheduler support improves the CPU scheduler's decision making
891 when dealing with POWER5 cpus at a cost of slightly increased
892 overhead in some places. If unsure say N here.
893
894config PROC_DEVICETREE
5f296755
PM
895 bool "Support for device tree in /proc"
896 depends on PROC_FS
14cf11af
PM
897 help
898 This option adds a device-tree directory under /proc which contains
899 an image of the device tree that the kernel copies from Open
5f296755 900 Firmware or other boot firmware. If unsure, say Y here.
14cf11af
PM
901
902source "arch/powerpc/platforms/prep/Kconfig"
903
904config CMDLINE_BOOL
905 bool "Default bootloader kernel arguments"
14cf11af
PM
906
907config CMDLINE
908 string "Initial kernel command string"
909 depends on CMDLINE_BOOL
910 default "console=ttyS0,9600 console=tty0 root=/dev/sda2"
911 help
912 On some platforms, there is currently no way for the boot loader to
913 pass arguments to the kernel. For these platforms, you can supply
914 some command-line options at build time by entering them here. In
915 most cases you will need to specify the root device here.
916
917if !44x || BROKEN
918source kernel/power/Kconfig
919endif
920
921config SECCOMP
922 bool "Enable seccomp to safely compute untrusted bytecode"
923 depends on PROC_FS
924 default y
925 help
926 This kernel feature is useful for number crunching applications
927 that may need to compute untrusted bytecode during their
928 execution. By using pipes or other transports made available to
929 the process as file descriptors supporting the read/write
930 syscalls, it's possible to isolate those applications in
931 their own address space using seccomp. Once seccomp is
932 enabled via /proc/<pid>/seccomp, it cannot be disabled
933 and the task is only allowed to execute a few safe syscalls
934 defined by each seccomp mode.
935
936 If unsure, say Y. Only embedded should say N here.
937
938endmenu
939
940config ISA_DMA_API
941 bool
942 default y
943
944menu "Bus options"
945
946config ISA
947 bool "Support for ISA-bus hardware"
948 depends on PPC_PREP || PPC_CHRP
f9bd170a 949 select PPC_I8259
14cf11af
PM
950 help
951 Find out whether you have ISA slots on your motherboard. ISA is the
952 name of a bus system, i.e. the way the CPU talks to the other stuff
953 inside your box. If you have an Apple machine, say N here; if you
954 have an IBM RS/6000 or pSeries machine or a PReP machine, say Y. If
955 you have an embedded board, consult your board documentation.
956
5ac6da66
CL
957config ZONE_DMA
958 bool
959 default y
960
14cf11af
PM
961config GENERIC_ISA_DMA
962 bool
963 depends on PPC64 || POWER4 || 6xx && !CPM2
964 default y
965
7233593b
ZR
966config MPIC
967 bool
968 default n
969
970config MPIC_WEIRD
971 bool
972 default n
973
f9bd170a
PM
974config PPC_I8259
975 bool
f9bd170a
PM
976 default n
977
25635c71
PM
978config PPC_INDIRECT_PCI
979 bool
980 depends on PCI
63dafe57 981 default y if 40x || 44x
25635c71
PM
982 default n
983
14cf11af
PM
984config EISA
985 bool
986
987config SBUS
988 bool
989
08264cbc
KG
990config FSL_SOC
991 bool
992
14cf11af
PM
993# Yes MCA RS/6000s exist but Linux-PPC does not currently support any
994config MCA
995 bool
996
997config PCI
53158620 998 bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \
bed59275
SR
999 || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \
1000 || MPC7448HPC2 || PPC_PS3
53158620
JL
1001 default y if !40x && !CPM2 && !8xx && !APUS && !PPC_83xx \
1002 && !PPC_85xx && !PPC_86xx
14cf11af
PM
1003 default PCI_PERMEDIA if !4xx && !CPM2 && !8xx && APUS
1004 default PCI_QSPAN if !4xx && !CPM2 && 8xx
1005 help
1006 Find out whether your system includes a PCI bus. PCI is the name of
1007 a bus system, i.e. the way the CPU talks to the other stuff inside
1008 your box. If you say Y here, the kernel will include drivers and
1009 infrastructure code to support PCI bus devices.
1010
1011config PCI_DOMAINS
1012 bool
1013 default PCI
1014
14cf11af
PM
1015config PCI_QSPAN
1016 bool "QSpan PCI"
1017 depends on !4xx && !CPM2 && 8xx
f9bd170a 1018 select PPC_I8259
14cf11af
PM
1019 help
1020 Say Y here if you have a system based on a Motorola 8xx-series
1021 embedded processor with a QSPAN PCI interface, otherwise say N.
1022
1023config PCI_8260
1024 bool
1025 depends on PCI && 8260
25635c71 1026 select PPC_INDIRECT_PCI
14cf11af
PM
1027 default y
1028
1029config 8260_PCI9
4a3ecc62 1030 bool "Enable workaround for MPC826x erratum PCI 9"
14cf11af
PM
1031 depends on PCI_8260 && !ADS8272
1032 default y
1033
1034choice
4a3ecc62 1035 prompt "IDMA channel for PCI 9 workaround"
14cf11af
PM
1036 depends on 8260_PCI9
1037
1038config 8260_PCI9_IDMA1
1039 bool "IDMA1"
1040
1041config 8260_PCI9_IDMA2
1042 bool "IDMA2"
1043
1044config 8260_PCI9_IDMA3
1045 bool "IDMA3"
1046
1047config 8260_PCI9_IDMA4
1048 bool "IDMA4"
1049
1050endchoice
1051
bb53bb3d
JM
1052source "drivers/pci/pcie/Kconfig"
1053
14cf11af
PM
1054source "drivers/pci/Kconfig"
1055
1056source "drivers/pcmcia/Kconfig"
1057
1058source "drivers/pci/hotplug/Kconfig"
1059
1060endmenu
1061
1062menu "Advanced setup"
1063 depends on PPC32
1064
1065config ADVANCED_OPTIONS
1066 bool "Prompt for advanced kernel configuration options"
1067 help
1068 This option will enable prompting for a variety of advanced kernel
1069 configuration options. These options can cause the kernel to not
1070 work if they are set incorrectly, but can be used to optimize certain
1071 aspects of kernel memory management.
1072
1073 Unless you know what you are doing, say N here.
1074
1075comment "Default settings for advanced configuration options are used"
1076 depends on !ADVANCED_OPTIONS
1077
1078config HIGHMEM_START_BOOL
1079 bool "Set high memory pool address"
1080 depends on ADVANCED_OPTIONS && HIGHMEM
1081 help
1082 This option allows you to set the base address of the kernel virtual
1083 area used to map high memory pages. This can be useful in
1084 optimizing the layout of kernel virtual memory.
1085
1086 Say N here unless you know what you are doing.
1087
1088config HIGHMEM_START
1089 hex "Virtual start address of high memory pool" if HIGHMEM_START_BOOL
1090 default "0xfe000000"
1091
1092config LOWMEM_SIZE_BOOL
1093 bool "Set maximum low memory"
1094 depends on ADVANCED_OPTIONS
1095 help
1096 This option allows you to set the maximum amount of memory which
1097 will be used as "low memory", that is, memory which the kernel can
1098 access directly, without having to set up a kernel virtual mapping.
1099 This can be useful in optimizing the layout of kernel virtual
1100 memory.
1101
1102 Say N here unless you know what you are doing.
1103
1104config LOWMEM_SIZE
1105 hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
1106 default "0x30000000"
1107
1108config KERNEL_START_BOOL
1109 bool "Set custom kernel base address"
1110 depends on ADVANCED_OPTIONS
1111 help
1112 This option allows you to set the kernel virtual address at which
1113 the kernel will map low memory (the kernel image will be linked at
1114 this address). This can be useful in optimizing the virtual memory
1115 layout of the system.
1116
1117 Say N here unless you know what you are doing.
1118
1119config KERNEL_START
1120 hex "Virtual address of kernel base" if KERNEL_START_BOOL
1121 default "0xc0000000"
1122
1123config TASK_SIZE_BOOL
1124 bool "Set custom user task size"
1125 depends on ADVANCED_OPTIONS
1126 help
1127 This option allows you to set the amount of virtual address space
1128 allocated to user tasks. This can be useful in optimizing the
1129 virtual memory layout of the system.
1130
1131 Say N here unless you know what you are doing.
1132
1133config TASK_SIZE
1134 hex "Size of user task space" if TASK_SIZE_BOOL
1135 default "0x80000000"
1136
1137config CONSISTENT_START_BOOL
1138 bool "Set custom consistent memory pool address"
1139 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
1140 help
1141 This option allows you to set the base virtual address
4b3f686d 1142 of the consistent memory pool. This pool of virtual
14cf11af
PM
1143 memory is used to make consistent memory allocations.
1144
1145config CONSISTENT_START
1146 hex "Base virtual address of consistent memory pool" if CONSISTENT_START_BOOL
1147 default "0xff100000" if NOT_COHERENT_CACHE
1148
1149config CONSISTENT_SIZE_BOOL
1150 bool "Set custom consistent memory pool size"
1151 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
1152 help
4b3f686d 1153 This option allows you to set the size of the
14cf11af
PM
1154 consistent memory pool. This pool of virtual memory
1155 is used to make consistent memory allocations.
1156
1157config CONSISTENT_SIZE
1158 hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL
1159 default "0x00200000" if NOT_COHERENT_CACHE
1160
1161config BOOT_LOAD_BOOL
1162 bool "Set the boot link/load address"
1163 depends on ADVANCED_OPTIONS && !PPC_MULTIPLATFORM
1164 help
1165 This option allows you to set the initial load address of the zImage
1166 or zImage.initrd file. This can be useful if you are on a board
1167 which has a small amount of memory.
1168
1169 Say N here unless you know what you are doing.
1170
1171config BOOT_LOAD
1172 hex "Link/load address for booting" if BOOT_LOAD_BOOL
1173 default "0x00400000" if 40x || 8xx || 8260
1174 default "0x01000000" if 44x
1175 default "0x00800000"
1176
1177config PIN_TLB
1178 bool "Pinned Kernel TLBs (860 ONLY)"
1179 depends on ADVANCED_OPTIONS && 8xx
1180endmenu
1181
cabb5587
SR
1182if PPC64
1183config KERNEL_START
1184 hex
eeb2d218 1185 default "0xc000000000000000"
cabb5587
SR
1186endif
1187
14cf11af
PM
1188source "net/Kconfig"
1189
1190source "drivers/Kconfig"
1191
1192source "fs/Kconfig"
1193
1194# XXX source "arch/ppc/8xx_io/Kconfig"
1195
1196# XXX source "arch/ppc/8260_io/Kconfig"
1197
98658538
LY
1198source "arch/powerpc/sysdev/qe_lib/Kconfig"
1199
14cf11af
PM
1200source "arch/powerpc/platforms/iseries/Kconfig"
1201
1202source "lib/Kconfig"
1203
cd6b0762
PP
1204menu "Instrumentation Support"
1205 depends on EXPERIMENTAL
1206
14cf11af
PM
1207source "arch/powerpc/oprofile/Kconfig"
1208
cd6b0762
PP
1209config KPROBES
1210 bool "Kprobes (EXPERIMENTAL)"
82090035 1211 depends on !BOOKE && !4xx && KALLSYMS && EXPERIMENTAL && MODULES
cd6b0762
PP
1212 help
1213 Kprobes allows you to trap at almost any kernel address and
1214 execute a callback function. register_kprobe() establishes
1215 a probepoint and specifies the callback. Kprobes is useful
1216 for kernel debugging, non-intrusive instrumentation and testing.
1217 If in doubt, say "N".
1218endmenu
1219
14cf11af
PM
1220source "arch/powerpc/Kconfig.debug"
1221
1222source "security/Kconfig"
1223
1224config KEYS_COMPAT
1225 bool
1226 depends on COMPAT && KEYS
1227 default y
1228
1229source "crypto/Kconfig"