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