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