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