]> bbs.cooldavid.org Git - net-next-2.6.git/blame - arch/powerpc/Kconfig
[PATCH] ppc32 8xx: Added setbitsXX/clrbitsXX macro for read-modify-write operations
[net-next-2.6.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
33config RWSEM_GENERIC_SPINLOCK
34 bool
35
36config RWSEM_XCHGADD_ALGORITHM
37 bool
38 default y
39
40config GENERIC_CALIBRATE_DELAY
41 bool
42 default y
43
44config PPC
45 bool
46 default y
47
48config EARLY_PRINTK
49 bool
51d3082f 50 default y
14cf11af
PM
51
52config COMPAT
53 bool
54 default y if PPC64
55
56config SYSVIPC_COMPAT
57 bool
58 depends on COMPAT && SYSVIPC
59 default y
60
61# All PPC32s use generic nvram driver through ppc_md
62config GENERIC_NVRAM
63 bool
64 default y if PPC32
65
66config SCHED_NO_NO_OMIT_FRAME_POINTER
67 bool
68 default y
69
70config ARCH_MAY_HAVE_PC_FDC
71 bool
72 default y
73
08264cbc
KG
74config PPC_OF
75 def_bool y
76
77config PPC_UDBG_16550
78 bool
79 default n
80
08264cbc
KG
81config GENERIC_TBSYNC
82 bool
83 default y if PPC32 && SMP
84 default n
85
14cf11af
PM
86menu "Processor support"
87choice
88 prompt "Processor Type"
89 depends on PPC32
90 default 6xx
91
08264cbc 92config CLASSIC32
14cf11af
PM
93 bool "6xx/7xx/74xx"
94 select PPC_FPU
08264cbc 95 select 6xx
14cf11af
PM
96 help
97 There are four families of PowerPC chips supported. The more common
98 types (601, 603, 604, 740, 750, 7400), the Motorola embedded
99 versions (821, 823, 850, 855, 860, 52xx, 82xx, 83xx), the AMCC
100 embedded versions (403 and 405) and the high end 64 bit Power
101 processors (POWER 3, POWER4, and IBM PPC970 also known as G5).
102
103 Unless you are building a kernel for one of the embedded processor
104 systems, 64 bit IBM RS/6000 or an Apple G5, choose 6xx.
105 Note that the kernel runs in 32-bit mode even on 64-bit chips.
106
107config PPC_52xx
108 bool "Freescale 52xx"
08264cbc
KG
109 select 6xx
110 select PPC_FPU
14cf11af
PM
111
112config PPC_82xx
113 bool "Freescale 82xx"
08264cbc
KG
114 select 6xx
115 select PPC_FPU
14cf11af
PM
116
117config PPC_83xx
118 bool "Freescale 83xx"
08264cbc
KG
119 select 6xx
120 select FSL_SOC
121 select 83xx
122 select PPC_FPU
14cf11af 123
63dafe57
BB
124config PPC_85xx
125 bool "Freescale 85xx"
126 select E500
127 select FSL_SOC
128 select 85xx
129
14cf11af
PM
130config 40x
131 bool "AMCC 40x"
132
133config 44x
134 bool "AMCC 44x"
135
14cf11af
PM
136config 8xx
137 bool "Freescale 8xx"
138
139config E200
140 bool "Freescale e200"
141
14cf11af
PM
142endchoice
143
144config POWER4_ONLY
145 bool "Optimize for POWER4"
187a0067 146 depends on PPC64
14cf11af
PM
147 default n
148 ---help---
149 Cause the compiler to optimize for POWER4/POWER5/PPC970 processors.
150 The resulting binary will not work on POWER3 or RS64 processors
151 when compiled with binutils 2.15 or later.
152
153config POWER3
154 bool
187a0067 155 depends on PPC64
14cf11af
PM
156 default y if !POWER4_ONLY
157
158config POWER4
187a0067 159 depends on PPC64
14cf11af
PM
160 def_bool y
161
08264cbc
KG
162config 6xx
163 bool
164
165# this is temp to handle compat with arch=ppc
166config 83xx
167 bool
168
63dafe57
BB
169# this is temp to handle compat with arch=ppc
170config 85xx
171 bool
172
173config E500
174 bool
175
14cf11af 176config PPC_FPU
187a0067
PM
177 bool
178 default y if PPC64
14cf11af
PM
179
180config BOOKE
181 bool
182 depends on E200 || E500
183 default y
184
185config FSL_BOOKE
186 bool
187 depends on E200 || E500
188 default y
189
190config PTE_64BIT
191 bool
192 depends on 44x || E500
193 default y if 44x
194 default y if E500 && PHYS_64BIT
195
196config PHYS_64BIT
197 bool 'Large physical address support' if E500
198 depends on 44x || E500
199 default y if 44x
200 ---help---
201 This option enables kernel support for larger than 32-bit physical
202 addresses. This features is not be available on all e500 cores.
203
204 If in doubt, say N here.
205
206config ALTIVEC
207 bool "AltiVec Support"
08264cbc 208 depends on CLASSIC32 || POWER4
14cf11af
PM
209 ---help---
210 This option enables kernel support for the Altivec extensions to the
211 PowerPC processor. The kernel currently supports saving and restoring
212 altivec registers, and turning on the 'altivec enable' bit so user
213 processes can execute altivec instructions.
214
215 This option is only usefully if you have a processor that supports
216 altivec (G4, otherwise known as 74xx series), but does not have
217 any affect on a non-altivec cpu (it does, however add code to the
218 kernel).
219
220 If in doubt, say Y here.
221
222config SPE
223 bool "SPE Support"
224 depends on E200 || E500
63dafe57 225 default y
14cf11af
PM
226 ---help---
227 This option enables kernel support for the Signal Processing
228 Extensions (SPE) to the PowerPC processor. The kernel currently
229 supports saving and restoring SPE registers, and turning on the
230 'spe enable' bit so user processes can execute SPE instructions.
231
232 This option is only useful if you have a processor that supports
233 SPE (e500, otherwise known as 85xx series), but does not have any
234 effect on a non-spe cpu (it does, however add code to the kernel).
235
236 If in doubt, say Y here.
237
238config PPC_STD_MMU
239 bool
240 depends on 6xx || POWER3 || POWER4 || PPC64
241 default y
242
243config PPC_STD_MMU_32
244 def_bool y
245 depends on PPC_STD_MMU && PPC32
246
247config SMP
248 depends on PPC_STD_MMU
249 bool "Symmetric multi-processing support"
250 ---help---
251 This enables support for systems with more than one CPU. If you have
252 a system with only one CPU, say N. If you have a system with more
253 than one CPU, say Y. Note that the kernel does not currently
254 support SMP machines with 603/603e/603ev or PPC750 ("G3") processors
255 since they have inadequate hardware support for multiprocessor
256 operation.
257
258 If you say N here, the kernel will run on single and multiprocessor
259 machines, but will use only one CPU of a multiprocessor machine. If
260 you say Y here, the kernel will run on single-processor machines.
261 On a single-processor machine, the kernel will run faster if you say
262 N here.
263
264 If you don't know what to do here, say N.
265
266config NR_CPUS
e8a167ac 267 int "Maximum number of CPUs (2-128)"
14cf11af
PM
268 range 2 128
269 depends on SMP
270 default "32" if PPC64
271 default "4"
272
273config NOT_COHERENT_CACHE
274 bool
275 depends on 4xx || 8xx || E200
276 default y
277endmenu
278
279source "init/Kconfig"
280
281menu "Platform support"
08264cbc 282 depends on PPC64 || CLASSIC32
14cf11af
PM
283
284choice
285 prompt "Machine type"
286 default PPC_MULTIPLATFORM
287
288config PPC_MULTIPLATFORM
289 bool "Generic desktop/server/laptop"
290 help
291 Select this option if configuring for an IBM pSeries or
292 RS/6000 machine, an Apple machine, or a PReP, CHRP,
293 Maple or Cell-based machine.
294
295config PPC_ISERIES
296 bool "IBM Legacy iSeries"
297 depends on PPC64
298
299config EMBEDDED6xx
300 bool "Embedded 6xx/7xx/7xxx-based board"
5be396b0 301 depends on PPC32 && BROKEN
14cf11af
PM
302
303config APUS
304 bool "Amiga-APUS"
305 depends on PPC32 && BROKEN
306 help
307 Select APUS if configuring for a PowerUP Amiga.
308 More information is available at:
309 <http://linux-apus.sourceforge.net/>.
310endchoice
311
312config PPC_PSERIES
313 depends on PPC_MULTIPLATFORM && PPC64
314 bool " IBM pSeries & new (POWER5-based) iSeries"
f9bd170a 315 select PPC_I8259
033ef338
PM
316 select PPC_RTAS
317 select RTAS_ERROR_LOGGING
13b8a272 318 select PPC_UDBG_16550
14cf11af
PM
319 default y
320
321config PPC_CHRP
322 bool " Common Hardware Reference Platform (CHRP) based machines"
323 depends on PPC_MULTIPLATFORM && PPC32
f9bd170a 324 select PPC_I8259
25635c71 325 select PPC_INDIRECT_PCI
033ef338 326 select PPC_RTAS
830825d6 327 select PPC_MPC106
13b8a272 328 select PPC_UDBG_16550
14cf11af
PM
329 default y
330
331config PPC_PMAC
332 bool " Apple PowerMac based machines"
333 depends on PPC_MULTIPLATFORM
25635c71 334 select PPC_INDIRECT_PCI if PPC32
b6a4ce52 335 select PPC_MPC106 if PPC32
14cf11af
PM
336 default y
337
338config PPC_PMAC64
339 bool
340 depends on PPC_PMAC && POWER4
35499c01 341 select U3_DART
1beb6a7d 342 select MPIC_BROKEN_U3
8ad200d7 343 select GENERIC_TBSYNC
14cf11af
PM
344 default y
345
346config PPC_PREP
347 bool " PowerPC Reference Platform (PReP) based machines"
5be396b0 348 depends on PPC_MULTIPLATFORM && PPC32 && BROKEN
f9bd170a 349 select PPC_I8259
25635c71 350 select PPC_INDIRECT_PCI
13b8a272 351 select PPC_UDBG_16550
14cf11af
PM
352 default y
353
354config PPC_MAPLE
355 depends on PPC_MULTIPLATFORM && PPC64
356 bool " Maple 970FX Evaluation Board"
357 select U3_DART
358 select MPIC_BROKEN_U3
8ad200d7 359 select GENERIC_TBSYNC
13b8a272 360 select PPC_UDBG_16550
14cf11af
PM
361 default n
362 help
363 This option enables support for the Maple 970FX Evaluation Board.
364 For more informations, refer to <http://www.970eval.com>
365
f3f66f59
AB
366config PPC_CELL
367 bool " Cell Broadband Processor Architecture"
14cf11af 368 depends on PPC_MULTIPLATFORM && PPC64
033ef338 369 select PPC_RTAS
edf03c1e 370 select MMIO_NVRAM
13b8a272 371 select PPC_UDBG_16550
14cf11af 372
14cf11af
PM
373config XICS
374 depends on PPC_PSERIES
375 bool
376 default y
377
378config U3_DART
379 bool
380 depends on PPC_MULTIPLATFORM && PPC64
381 default n
382
383config MPIC
bbd0abda 384 depends on PPC_PSERIES || PPC_PMAC || PPC_MAPLE || PPC_CHRP
14cf11af
PM
385 bool
386 default y
387
033ef338
PM
388config PPC_RTAS
389 bool
390 default n
391
392config RTAS_ERROR_LOGGING
393 bool
394 depends on PPC_RTAS
395 default n
396
f4fcbbe9
PM
397config RTAS_PROC
398 bool "Proc interface to RTAS"
e9add2ee 399 depends on PPC_RTAS
f4fcbbe9
PM
400 default y
401
402config RTAS_FLASH
403 tristate "Firmware flash interface"
404 depends on PPC64 && RTAS_PROC
e9add2ee 405
edf03c1e
AB
406config MMIO_NVRAM
407 bool
408 default n
409
14cf11af
PM
410config MPIC_BROKEN_U3
411 bool
412 depends on PPC_MAPLE
413 default y
414
f3f66f59
AB
415config CELL_IIC
416 depends on PPC_CELL
14cf11af
PM
417 bool
418 default y
419
420config IBMVIO
421 depends on PPC_PSERIES || PPC_ISERIES
422 bool
423 default y
424
d7a30103
HS
425config IBMEBUS
426 depends on PPC_PSERIES
427 bool "Support for GX bus based adapters"
d7a30103
HS
428 help
429 Bus device driver for GX bus based adapters.
430
830825d6
PM
431config PPC_MPC106
432 bool
433 default n
434
14cf11af
PM
435source "drivers/cpufreq/Kconfig"
436
437config CPU_FREQ_PMAC
438 bool "Support for Apple PowerBooks"
439 depends on CPU_FREQ && ADB_PMU && PPC32
440 select CPU_FREQ_TABLE
441 help
442 This adds support for frequency switching on Apple PowerBooks,
443 this currently includes some models of iBook & Titanium
444 PowerBook.
445
4350147a
BH
446config CPU_FREQ_PMAC64
447 bool "Support for some Apple G5s"
448 depends on CPU_FREQ && PMAC_SMU && PPC64
449 select CPU_FREQ_TABLE
450 help
451 This adds support for frequency switching on Apple iMac G5,
452 and some of the more recent desktop G5 machines as well.
453
14cf11af
PM
454config PPC601_SYNC_FIX
455 bool "Workarounds for PPC601 bugs"
456 depends on 6xx && (PPC_PREP || PPC_PMAC)
457 help
458 Some versions of the PPC601 (the first PowerPC chip) have bugs which
459 mean that extra synchronization instructions are required near
460 certain instructions, typically those that make major changes to the
461 CPU state. These extra instructions reduce performance slightly.
462 If you say N here, these extra instructions will not be included,
463 resulting in a kernel which will run faster but may not run at all
464 on some systems with the PPC601 chip.
465
466 If in doubt, say Y here.
467
468config TAU
469 bool "Thermal Management Support"
470 depends on 6xx
471 help
472 G3 and G4 processors have an on-chip temperature sensor called the
473 'Thermal Assist Unit (TAU)', which, in theory, can measure the on-die
474 temperature within 2-4 degrees Celsius. This option shows the current
475 on-die temperature in /proc/cpuinfo if the cpu supports it.
476
477 Unfortunately, on some chip revisions, this sensor is very inaccurate
478 and in some cases, does not work at all, so don't assume the cpu
479 temp is actually what /proc/cpuinfo says it is.
480
481config TAU_INT
482 bool "Interrupt driven TAU driver (DANGEROUS)"
483 depends on TAU
484 ---help---
485 The TAU supports an interrupt driven mode which causes an interrupt
486 whenever the temperature goes out of range. This is the fastest way
487 to get notified the temp has exceeded a range. With this option off,
488 a timer is used to re-check the temperature periodically.
489
490 However, on some cpus it appears that the TAU interrupt hardware
491 is buggy and can cause a situation which would lead unexplained hard
492 lockups.
493
494 Unless you are extending the TAU driver, or enjoy kernel/hardware
495 debugging, leave this option off.
496
497config TAU_AVERAGE
498 bool "Average high and low temp"
499 depends on TAU
500 ---help---
501 The TAU hardware can compare the temperature to an upper and lower
502 bound. The default behavior is to show both the upper and lower
503 bound in /proc/cpuinfo. If the range is large, the temperature is
504 either changing a lot, or the TAU hardware is broken (likely on some
505 G4's). If the range is small (around 4 degrees), the temperature is
506 relatively stable. If you say Y here, a single temperature value,
507 halfway between the upper and lower bounds, will be reported in
508 /proc/cpuinfo.
509
510 If in doubt, say N here.
511endmenu
512
513source arch/powerpc/platforms/embedded6xx/Kconfig
514source arch/powerpc/platforms/4xx/Kconfig
08264cbc 515source arch/powerpc/platforms/83xx/Kconfig
14cf11af
PM
516source arch/powerpc/platforms/85xx/Kconfig
517source arch/powerpc/platforms/8xx/Kconfig
67207b96 518source arch/powerpc/platforms/cell/Kconfig
14cf11af
PM
519
520menu "Kernel options"
521
522config HIGHMEM
523 bool "High memory support"
524 depends on PPC32
525
526source kernel/Kconfig.hz
527source kernel/Kconfig.preempt
528source "fs/Kconfig.binfmt"
529
530# We optimistically allocate largepages from the VM, so make the limit
531# large enough (16MB). This badly named config option is actually
532# max order + 1
533config FORCE_MAX_ZONEORDER
534 int
535 depends on PPC64
02864867 536 default "9" if PPC_64K_PAGES
14cf11af
PM
537 default "13"
538
539config MATH_EMULATION
540 bool "Math emulation"
541 depends on 4xx || 8xx || E200 || E500
542 ---help---
543 Some PowerPC chips designed for embedded applications do not have
544 a floating-point unit and therefore do not implement the
545 floating-point instructions in the PowerPC instruction set. If you
546 say Y here, the kernel will include code to emulate a floating-point
547 unit, which will allow programs that use floating-point
548 instructions to run.
549
550config IOMMU_VMERGE
551 bool "Enable IOMMU virtual merging (EXPERIMENTAL)"
552 depends on EXPERIMENTAL && PPC64
553 default n
554 help
555 Cause IO segments sent to a device for DMA to be merged virtually
556 by the IOMMU when they happen to have been allocated contiguously.
557 This doesn't add pressure to the IOMMU allocator. However, some
558 drivers don't support getting large merged segments coming back
559 from *_map_sg(). Say Y if you know the drivers you are using are
560 properly handling this case.
561
562config HOTPLUG_CPU
563 bool "Support for enabling/disabling CPUs"
564 depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC)
565 ---help---
566 Say Y here to be able to disable and re-enable individual
567 CPUs at runtime on SMP machines.
568
569 Say N if you are unsure.
570
571config KEXEC
572 bool "kexec system call (EXPERIMENTAL)"
573 depends on PPC_MULTIPLATFORM && EXPERIMENTAL
574 help
575 kexec is a system call that implements the ability to shutdown your
576 current kernel, and to start another kernel. It is like a reboot
577 but it is indepedent of the system firmware. And like a reboot
578 you can start any kernel with it, not just Linux.
579
580 The name comes from the similiarity to the exec system call.
581
582 It is an ongoing process to be certain the hardware in a machine
583 is properly shutdown, so do not be surprised if this code does not
584 initially work for you. It may help to enable device hotplugging
585 support. As of this writing the exact hardware interface is
586 strongly in flux, so no good recommendation can be made.
587
e8625d46
HM
588config CRASH_DUMP
589 bool "kernel crash dumps (EXPERIMENTAL)"
590 depends on PPC_MULTIPLATFORM && PPC64 && EXPERIMENTAL
591 help
592 Build a kernel suitable for use as a kdump capture kernel.
593 The kernel will be linked at a different address than normal, and
594 so can only be used for Kdump.
595
596 Don't change this unless you know what you are doing.
597
14cf11af
PM
598config EMBEDDEDBOOT
599 bool
600 depends on 8xx || 8260
601 default y
602
603config PC_KEYBOARD
604 bool "PC PS/2 style Keyboard"
605 depends on 4xx || CPM2
606
607config PPCBUG_NVRAM
608 bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC
609 default y if PPC_PREP
610
611config IRQ_ALL_CPUS
612 bool "Distribute interrupts on all CPUs by default"
613 depends on SMP && !MV64360
614 help
615 This option gives the kernel permission to distribute IRQs across
616 multiple CPUs. Saying N here will route all IRQs to the first
617 CPU. Generally saying Y is safe, although some problems have been
618 reported with SMP Power Macintoshes with this option enabled.
619
620source "arch/powerpc/platforms/pseries/Kconfig"
621
ffa27b6b
AW
622config NUMA
623 bool "NUMA support"
624 depends on PPC64
625 default y if SMP && PPC_PSERIES
626
14cf11af
PM
627config ARCH_SELECT_MEMORY_MODEL
628 def_bool y
629 depends on PPC64
630
631config ARCH_FLATMEM_ENABLE
9100b205
AW
632 def_bool y
633 depends on (PPC64 && !NUMA) || PPC32
14cf11af 634
45fb6cea 635config ARCH_SPARSEMEM_ENABLE
14cf11af 636 def_bool y
9100b205 637 depends on PPC64
14cf11af 638
45fb6cea 639config ARCH_SPARSEMEM_DEFAULT
14cf11af 640 def_bool y
45fb6cea 641 depends on SMP && PPC_PSERIES
14cf11af
PM
642
643source "mm/Kconfig"
644
645config HAVE_ARCH_EARLY_PFN_TO_NID
646 def_bool y
647 depends on NEED_MULTIPLE_NODES
648
7e9191da
MK
649config ARCH_MEMORY_PROBE
650 def_bool y
651 depends on MEMORY_HOTPLUG
652
3c726f8d
BH
653config PPC_64K_PAGES
654 bool "64k page size"
863c84b9 655 depends on PPC64
3c726f8d
BH
656 help
657 This option changes the kernel logical page size to 64k. On machines
658 without processor support for 64k pages, the kernel will simulate
659 them by loading each individual 4k page on demand transparently,
660 while on hardware with such support, it will be used to map
661 normal application pages.
662
14cf11af
PM
663config SCHED_SMT
664 bool "SMT (Hyperthreading) scheduler support"
665 depends on PPC64 && SMP
666 default off
667 help
668 SMT scheduler support improves the CPU scheduler's decision making
669 when dealing with POWER5 cpus at a cost of slightly increased
670 overhead in some places. If unsure say N here.
671
672config PROC_DEVICETREE
5f296755
PM
673 bool "Support for device tree in /proc"
674 depends on PROC_FS
14cf11af
PM
675 help
676 This option adds a device-tree directory under /proc which contains
677 an image of the device tree that the kernel copies from Open
5f296755 678 Firmware or other boot firmware. If unsure, say Y here.
14cf11af
PM
679
680source "arch/powerpc/platforms/prep/Kconfig"
681
682config CMDLINE_BOOL
683 bool "Default bootloader kernel arguments"
684 depends on !PPC_ISERIES
685
686config CMDLINE
687 string "Initial kernel command string"
688 depends on CMDLINE_BOOL
689 default "console=ttyS0,9600 console=tty0 root=/dev/sda2"
690 help
691 On some platforms, there is currently no way for the boot loader to
692 pass arguments to the kernel. For these platforms, you can supply
693 some command-line options at build time by entering them here. In
694 most cases you will need to specify the root device here.
695
696if !44x || BROKEN
697source kernel/power/Kconfig
698endif
699
700config SECCOMP
701 bool "Enable seccomp to safely compute untrusted bytecode"
702 depends on PROC_FS
703 default y
704 help
705 This kernel feature is useful for number crunching applications
706 that may need to compute untrusted bytecode during their
707 execution. By using pipes or other transports made available to
708 the process as file descriptors supporting the read/write
709 syscalls, it's possible to isolate those applications in
710 their own address space using seccomp. Once seccomp is
711 enabled via /proc/<pid>/seccomp, it cannot be disabled
712 and the task is only allowed to execute a few safe syscalls
713 defined by each seccomp mode.
714
715 If unsure, say Y. Only embedded should say N here.
716
717endmenu
718
719config ISA_DMA_API
720 bool
721 default y
722
723menu "Bus options"
724
725config ISA
726 bool "Support for ISA-bus hardware"
727 depends on PPC_PREP || PPC_CHRP
f9bd170a 728 select PPC_I8259
14cf11af
PM
729 help
730 Find out whether you have ISA slots on your motherboard. ISA is the
731 name of a bus system, i.e. the way the CPU talks to the other stuff
732 inside your box. If you have an Apple machine, say N here; if you
733 have an IBM RS/6000 or pSeries machine or a PReP machine, say Y. If
734 you have an embedded board, consult your board documentation.
735
736config GENERIC_ISA_DMA
737 bool
738 depends on PPC64 || POWER4 || 6xx && !CPM2
739 default y
740
f9bd170a
PM
741config PPC_I8259
742 bool
f9bd170a
PM
743 default n
744
25635c71
PM
745config PPC_INDIRECT_PCI
746 bool
747 depends on PCI
63dafe57 748 default y if 40x || 44x
25635c71
PM
749 default n
750
14cf11af
PM
751config EISA
752 bool
753
754config SBUS
755 bool
756
08264cbc
KG
757config FSL_SOC
758 bool
759
14cf11af
PM
760# Yes MCA RS/6000s exist but Linux-PPC does not currently support any
761config MCA
762 bool
763
764config PCI
63dafe57
BB
765 bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_MPC52xx || (EMBEDDED && PPC_ISERIES)
766 default y if !40x && !CPM2 && !8xx && !APUS && !PPC_83xx && !PPC_85xx
14cf11af
PM
767 default PCI_PERMEDIA if !4xx && !CPM2 && !8xx && APUS
768 default PCI_QSPAN if !4xx && !CPM2 && 8xx
769 help
770 Find out whether your system includes a PCI bus. PCI is the name of
771 a bus system, i.e. the way the CPU talks to the other stuff inside
772 your box. If you say Y here, the kernel will include drivers and
773 infrastructure code to support PCI bus devices.
774
775config PCI_DOMAINS
776 bool
777 default PCI
778
14cf11af
PM
779config PCI_QSPAN
780 bool "QSpan PCI"
781 depends on !4xx && !CPM2 && 8xx
f9bd170a 782 select PPC_I8259
14cf11af
PM
783 help
784 Say Y here if you have a system based on a Motorola 8xx-series
785 embedded processor with a QSPAN PCI interface, otherwise say N.
786
787config PCI_8260
788 bool
789 depends on PCI && 8260
25635c71 790 select PPC_INDIRECT_PCI
14cf11af
PM
791 default y
792
793config 8260_PCI9
794 bool " Enable workaround for MPC826x erratum PCI 9"
795 depends on PCI_8260 && !ADS8272
796 default y
797
798choice
799 prompt " IDMA channel for PCI 9 workaround"
800 depends on 8260_PCI9
801
802config 8260_PCI9_IDMA1
803 bool "IDMA1"
804
805config 8260_PCI9_IDMA2
806 bool "IDMA2"
807
808config 8260_PCI9_IDMA3
809 bool "IDMA3"
810
811config 8260_PCI9_IDMA4
812 bool "IDMA4"
813
814endchoice
815
816source "drivers/pci/Kconfig"
817
818source "drivers/pcmcia/Kconfig"
819
820source "drivers/pci/hotplug/Kconfig"
821
822endmenu
823
824menu "Advanced setup"
825 depends on PPC32
826
827config ADVANCED_OPTIONS
828 bool "Prompt for advanced kernel configuration options"
829 help
830 This option will enable prompting for a variety of advanced kernel
831 configuration options. These options can cause the kernel to not
832 work if they are set incorrectly, but can be used to optimize certain
833 aspects of kernel memory management.
834
835 Unless you know what you are doing, say N here.
836
837comment "Default settings for advanced configuration options are used"
838 depends on !ADVANCED_OPTIONS
839
840config HIGHMEM_START_BOOL
841 bool "Set high memory pool address"
842 depends on ADVANCED_OPTIONS && HIGHMEM
843 help
844 This option allows you to set the base address of the kernel virtual
845 area used to map high memory pages. This can be useful in
846 optimizing the layout of kernel virtual memory.
847
848 Say N here unless you know what you are doing.
849
850config HIGHMEM_START
851 hex "Virtual start address of high memory pool" if HIGHMEM_START_BOOL
852 default "0xfe000000"
853
854config LOWMEM_SIZE_BOOL
855 bool "Set maximum low memory"
856 depends on ADVANCED_OPTIONS
857 help
858 This option allows you to set the maximum amount of memory which
859 will be used as "low memory", that is, memory which the kernel can
860 access directly, without having to set up a kernel virtual mapping.
861 This can be useful in optimizing the layout of kernel virtual
862 memory.
863
864 Say N here unless you know what you are doing.
865
866config LOWMEM_SIZE
867 hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
868 default "0x30000000"
869
870config KERNEL_START_BOOL
871 bool "Set custom kernel base address"
872 depends on ADVANCED_OPTIONS
873 help
874 This option allows you to set the kernel virtual address at which
875 the kernel will map low memory (the kernel image will be linked at
876 this address). This can be useful in optimizing the virtual memory
877 layout of the system.
878
879 Say N here unless you know what you are doing.
880
881config KERNEL_START
882 hex "Virtual address of kernel base" if KERNEL_START_BOOL
883 default "0xc0000000"
884
885config TASK_SIZE_BOOL
886 bool "Set custom user task size"
887 depends on ADVANCED_OPTIONS
888 help
889 This option allows you to set the amount of virtual address space
890 allocated to user tasks. This can be useful in optimizing the
891 virtual memory layout of the system.
892
893 Say N here unless you know what you are doing.
894
895config TASK_SIZE
896 hex "Size of user task space" if TASK_SIZE_BOOL
897 default "0x80000000"
898
899config CONSISTENT_START_BOOL
900 bool "Set custom consistent memory pool address"
901 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
902 help
903 This option allows you to set the base virtual address
904 of the the consistent memory pool. This pool of virtual
905 memory is used to make consistent memory allocations.
906
907config CONSISTENT_START
908 hex "Base virtual address of consistent memory pool" if CONSISTENT_START_BOOL
909 default "0xff100000" if NOT_COHERENT_CACHE
910
911config CONSISTENT_SIZE_BOOL
912 bool "Set custom consistent memory pool size"
913 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
914 help
915 This option allows you to set the size of the the
916 consistent memory pool. This pool of virtual memory
917 is used to make consistent memory allocations.
918
919config CONSISTENT_SIZE
920 hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL
921 default "0x00200000" if NOT_COHERENT_CACHE
922
923config BOOT_LOAD_BOOL
924 bool "Set the boot link/load address"
925 depends on ADVANCED_OPTIONS && !PPC_MULTIPLATFORM
926 help
927 This option allows you to set the initial load address of the zImage
928 or zImage.initrd file. This can be useful if you are on a board
929 which has a small amount of memory.
930
931 Say N here unless you know what you are doing.
932
933config BOOT_LOAD
934 hex "Link/load address for booting" if BOOT_LOAD_BOOL
935 default "0x00400000" if 40x || 8xx || 8260
936 default "0x01000000" if 44x
937 default "0x00800000"
938
939config PIN_TLB
940 bool "Pinned Kernel TLBs (860 ONLY)"
941 depends on ADVANCED_OPTIONS && 8xx
942endmenu
943
cabb5587
SR
944if PPC64
945config KERNEL_START
946 hex
eeb2d218 947 default "0xc000000000000000"
cabb5587
SR
948endif
949
14cf11af
PM
950source "net/Kconfig"
951
952source "drivers/Kconfig"
953
954source "fs/Kconfig"
955
956# XXX source "arch/ppc/8xx_io/Kconfig"
957
958# XXX source "arch/ppc/8260_io/Kconfig"
959
960source "arch/powerpc/platforms/iseries/Kconfig"
961
962source "lib/Kconfig"
963
cd6b0762
PP
964menu "Instrumentation Support"
965 depends on EXPERIMENTAL
966
14cf11af
PM
967source "arch/powerpc/oprofile/Kconfig"
968
cd6b0762
PP
969config KPROBES
970 bool "Kprobes (EXPERIMENTAL)"
7568cb4e 971 depends on PPC64
cd6b0762
PP
972 help
973 Kprobes allows you to trap at almost any kernel address and
974 execute a callback function. register_kprobe() establishes
975 a probepoint and specifies the callback. Kprobes is useful
976 for kernel debugging, non-intrusive instrumentation and testing.
977 If in doubt, say "N".
978endmenu
979
14cf11af
PM
980source "arch/powerpc/Kconfig.debug"
981
982source "security/Kconfig"
983
984config KEYS_COMPAT
985 bool
986 depends on COMPAT && KEYS
987 default y
988
989source "crypto/Kconfig"