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