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