[POWERPC] Fix MAX_ORDER config problem
[linux-2.6] / 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 source "arch/powerpc/platforms/Kconfig.cputype"
8
9 config PPC32
10         bool
11         default y if !PPC64
12
13 config 64BIT
14         bool
15         default y if PPC64
16
17 config WORD_SIZE
18         int
19         default 64 if PPC64
20         default 32 if !PPC64
21
22 config PPC_MERGE
23         def_bool y
24
25 config MMU
26         bool
27         default y
28
29 config GENERIC_CMOS_UPDATE
30         def_bool y
31
32 config GENERIC_TIME
33         def_bool y
34
35 config GENERIC_TIME_VSYSCALL
36         def_bool y
37
38 config GENERIC_CLOCKEVENTS
39         def_bool y
40
41 config GENERIC_HARDIRQS
42         bool
43         default y
44
45 config HAVE_SETUP_PER_CPU_AREA
46         def_bool PPC64
47
48 config IRQ_PER_CPU
49         bool
50         default y
51
52 config RWSEM_GENERIC_SPINLOCK
53         bool
54
55 config RWSEM_XCHGADD_ALGORITHM
56         bool
57         default y
58
59 config GENERIC_LOCKBREAK
60         bool
61         default y
62         depends on SMP && PREEMPT
63
64 config ARCH_HAS_ILOG2_U32
65         bool
66         default y
67
68 config ARCH_HAS_ILOG2_U64
69         bool
70         default y if 64BIT
71
72 config GENERIC_HWEIGHT
73         bool
74         default y
75
76 config GENERIC_CALIBRATE_DELAY
77         bool
78         default y
79
80 config GENERIC_FIND_NEXT_BIT
81         bool
82         default y
83
84 config ARCH_NO_VIRT_TO_BUS
85         def_bool PPC64
86
87 config PPC
88         bool
89         default y
90         select HAVE_IDE
91         select HAVE_OPROFILE
92         select HAVE_KPROBES
93         select HAVE_KRETPROBES
94         select HAVE_LMB
95
96 config EARLY_PRINTK
97         bool
98         default y
99
100 config COMPAT
101         bool
102         default y if PPC64
103         select COMPAT_BINFMT_ELF
104
105 config SYSVIPC_COMPAT
106         bool
107         depends on COMPAT && SYSVIPC
108         default y
109
110 # All PPC32s use generic nvram driver through ppc_md
111 config GENERIC_NVRAM
112         bool
113         default y if PPC32
114
115 config SCHED_NO_NO_OMIT_FRAME_POINTER
116         bool
117         default y
118
119 config ARCH_MAY_HAVE_PC_FDC
120         bool
121         default !PPC_PSERIES || PCI
122
123 config PPC_OF
124         def_bool y
125
126 config OF
127         def_bool y
128
129 config PPC_UDBG_16550
130         bool
131         default n
132
133 config GENERIC_TBSYNC
134         bool
135         default y if PPC32 && SMP
136         default n
137
138 config AUDIT_ARCH
139         bool
140         default y
141
142 config GENERIC_BUG
143         bool
144         default y
145         depends on BUG
146
147 config SYS_SUPPORTS_APM_EMULATION
148         default y if PMAC_APM_EMU
149         bool
150
151 config DEFAULT_UIMAGE
152         bool
153         help
154           Used to allow a board to specify it wants a uImage built by default
155         default n
156
157 config REDBOOT
158         bool
159
160 config HIBERNATE_32
161         bool
162         depends on (PPC_PMAC && !SMP) || BROKEN
163         default y
164
165 config HIBERNATE_64
166         bool
167         depends on BROKEN || (PPC_PMAC64 && EXPERIMENTAL)
168         default y
169
170 config ARCH_HIBERNATION_POSSIBLE
171         bool
172         depends on (PPC64 && HIBERNATE_64) || (PPC32 && HIBERNATE_32)
173         default y
174
175 config ARCH_SUSPEND_POSSIBLE
176         def_bool y
177         depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200
178
179 config PPC_DCR_NATIVE
180         bool
181         default n
182
183 config PPC_DCR_MMIO
184         bool
185         default n
186
187 config PPC_DCR
188         bool
189         depends on PPC_DCR_NATIVE || PPC_DCR_MMIO
190         default y
191
192 config PPC_OF_PLATFORM_PCI
193         bool
194         depends on PCI
195         depends on PPC64 # not supported on 32 bits yet
196         default n
197
198 source "init/Kconfig"
199
200 source "arch/powerpc/sysdev/Kconfig"
201 source "arch/powerpc/platforms/Kconfig"
202
203 menu "Kernel options"
204
205 config HIGHMEM
206         bool "High memory support"
207         depends on PPC32
208
209 source kernel/time/Kconfig
210 source kernel/Kconfig.hz
211 source kernel/Kconfig.preempt
212 source "fs/Kconfig.binfmt"
213
214 config HUGETLB_PAGE_SIZE_VARIABLE
215         bool
216         depends on HUGETLB_PAGE
217         default y
218
219 config MATH_EMULATION
220         bool "Math emulation"
221         depends on 4xx || 8xx || E200 || PPC_MPC832x || E500
222         ---help---
223           Some PowerPC chips designed for embedded applications do not have
224           a floating-point unit and therefore do not implement the
225           floating-point instructions in the PowerPC instruction set.  If you
226           say Y here, the kernel will include code to emulate a floating-point
227           unit, which will allow programs that use floating-point
228           instructions to run.
229
230 config 8XX_MINIMAL_FPEMU
231         bool "Minimal math emulation for 8xx"
232         depends on 8xx && !MATH_EMULATION
233         help
234           Older arch/ppc kernels still emulated a few floating point
235           instructions such as load and store, even when full math
236           emulation is disabled.  Say "Y" here if you want to preserve
237           this behavior.
238
239           It is recommended that you build a soft-float userspace instead.
240
241 config IOMMU_VMERGE
242         bool "Enable IOMMU virtual merging"
243         depends on PPC64
244         default y
245         help
246           Cause IO segments sent to a device for DMA to be merged virtually
247           by the IOMMU when they happen to have been allocated contiguously.
248           This doesn't add pressure to the IOMMU allocator. However, some
249           drivers don't support getting large merged segments coming back
250           from *_map_sg().
251
252           Most drivers don't have this problem; it is safe to say Y here.
253
254 config IOMMU_HELPER
255         def_bool PPC64
256
257 config HOTPLUG_CPU
258         bool "Support for enabling/disabling CPUs"
259         depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC)
260         ---help---
261           Say Y here to be able to disable and re-enable individual
262           CPUs at runtime on SMP machines.
263
264           Say N if you are unsure.
265
266 config ARCH_ENABLE_MEMORY_HOTPLUG
267         def_bool y
268
269 config ARCH_HAS_WALK_MEMORY
270         def_bool y
271
272 config ARCH_ENABLE_MEMORY_HOTREMOVE
273         def_bool y
274
275 config KEXEC
276         bool "kexec system call (EXPERIMENTAL)"
277         depends on (PPC_PRPMC2800 || PPC_MULTIPLATFORM) && EXPERIMENTAL
278         help
279           kexec is a system call that implements the ability to shutdown your
280           current kernel, and to start another kernel.  It is like a reboot
281           but it is independent of the system firmware.   And like a reboot
282           you can start any kernel with it, not just Linux.
283
284           The name comes from the similarity to the exec system call.
285
286           It is an ongoing process to be certain the hardware in a machine
287           is properly shutdown, so do not be surprised if this code does not
288           initially work for you.  It may help to enable device hotplugging
289           support.  As of this writing the exact hardware interface is
290           strongly in flux, so no good recommendation can be made.
291
292 config CRASH_DUMP
293         bool "Build a kdump crash kernel (EXPERIMENTAL)"
294         depends on PPC_MULTIPLATFORM && PPC64 && EXPERIMENTAL
295         help
296           Build a kernel suitable for use as a kdump capture kernel.
297           The kernel will be linked at a different address than normal, and
298           so can only be used for Kdump.
299
300           Don't change this unless you know what you are doing.
301
302 config PHYP_DUMP
303         bool "Hypervisor-assisted dump (EXPERIMENTAL)"
304         depends on PPC_PSERIES && EXPERIMENTAL
305         help
306           Hypervisor-assisted dump is meant to be a kdump replacement
307           offering robustness and speed not possible without system
308           hypervisor assistence.
309
310           If unsure, say "N"
311
312 config PPCBUG_NVRAM
313         bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC
314         default y if PPC_PREP
315
316 config IRQ_ALL_CPUS
317         bool "Distribute interrupts on all CPUs by default"
318         depends on SMP && !MV64360
319         help
320           This option gives the kernel permission to distribute IRQs across
321           multiple CPUs.  Saying N here will route all IRQs to the first
322           CPU.  Generally saying Y is safe, although some problems have been
323           reported with SMP Power Macintoshes with this option enabled.
324
325 config NUMA
326         bool "NUMA support"
327         depends on PPC64
328         default y if SMP && PPC_PSERIES
329
330 config NODES_SHIFT
331         int
332         default "4"
333         depends on NEED_MULTIPLE_NODES
334
335 config ARCH_SELECT_MEMORY_MODEL
336         def_bool y
337         depends on PPC64
338
339 config ARCH_FLATMEM_ENABLE
340         def_bool y
341         depends on (PPC64 && !NUMA) || PPC32
342
343 config ARCH_SPARSEMEM_ENABLE
344         def_bool y
345         depends on PPC64
346         select SPARSEMEM_VMEMMAP_ENABLE
347
348 config ARCH_SPARSEMEM_DEFAULT
349         def_bool y
350         depends on (SMP && PPC_PSERIES) || PPC_PS3
351
352 config ARCH_POPULATES_NODE_MAP
353         def_bool y
354
355 source "mm/Kconfig"
356
357 config ARCH_MEMORY_PROBE
358         def_bool y
359         depends on MEMORY_HOTPLUG
360
361 # Some NUMA nodes have memory ranges that span
362 # other nodes.  Even though a pfn is valid and
363 # between a node's start and end pfns, it may not
364 # reside on that node.  See memmap_init_zone()
365 # for details.
366 config NODES_SPAN_OTHER_NODES
367         def_bool y
368         depends on NEED_MULTIPLE_NODES
369
370 config PPC_HAS_HASH_64K
371         bool
372         depends on PPC64
373         default n
374
375 config PPC_64K_PAGES
376         bool "64k page size"
377         depends on PPC64
378         select PPC_HAS_HASH_64K
379         help
380           This option changes the kernel logical page size to 64k. On machines
381           without processor support for 64k pages, the kernel will simulate
382           them by loading each individual 4k page on demand transparently,
383           while on hardware with such support, it will be used to map
384           normal application pages.
385
386 config FORCE_MAX_ZONEORDER
387         int "Maximum zone order"
388         default "9" if PPC_64K_PAGES
389         default "13" if PPC64 && !PPC_64K_PAGES
390         default "11"
391         help
392           The kernel memory allocator divides physically contiguous memory
393           blocks into "zones", where each zone is a power of two number of
394           pages.  This option selects the largest power of two that the kernel
395           keeps in the memory allocator.  If you need to allocate very large
396           blocks of physically contiguous memory, then you may need to
397           increase this value.
398
399           This config option is actually maximum order plus one. For example,
400           a value of 11 means that the largest free memory block is 2^10 pages.
401
402           The page size is not necessarily 4KB.  For example, on 64-bit
403           systems, 64KB pages can be enabled via CONFIG_PPC_64K_PAGES.  Keep
404           this in mind when choosing a value for this option.
405
406 config PPC_SUBPAGE_PROT
407         bool "Support setting protections for 4k subpages"
408         depends on PPC_64K_PAGES
409         help
410           This option adds support for a system call to allow user programs
411           to set access permissions (read/write, readonly, or no access)
412           on the 4k subpages of each 64k page.
413
414 config SCHED_SMT
415         bool "SMT (Hyperthreading) scheduler support"
416         depends on PPC64 && SMP
417         help
418           SMT scheduler support improves the CPU scheduler's decision making
419           when dealing with POWER5 cpus at a cost of slightly increased
420           overhead in some places. If unsure say N here.
421
422 config PROC_DEVICETREE
423         bool "Support for device tree in /proc"
424         depends on PROC_FS
425         help
426           This option adds a device-tree directory under /proc which contains
427           an image of the device tree that the kernel copies from Open
428           Firmware or other boot firmware. If unsure, say Y here.
429
430 config CMDLINE_BOOL
431         bool "Default bootloader kernel arguments"
432
433 config CMDLINE
434         string "Initial kernel command string"
435         depends on CMDLINE_BOOL
436         default "console=ttyS0,9600 console=tty0 root=/dev/sda2"
437         help
438           On some platforms, there is currently no way for the boot loader to
439           pass arguments to the kernel. For these platforms, you can supply
440           some command-line options at build time by entering them here.  In
441           most cases you will need to specify the root device here.
442
443 if !44x || BROKEN
444 config ARCH_WANTS_FREEZER_CONTROL
445         def_bool y
446         depends on ADB_PMU
447
448 source kernel/power/Kconfig
449 endif
450
451 config SECCOMP
452         bool "Enable seccomp to safely compute untrusted bytecode"
453         depends on PROC_FS
454         default y
455         help
456           This kernel feature is useful for number crunching applications
457           that may need to compute untrusted bytecode during their
458           execution. By using pipes or other transports made available to
459           the process as file descriptors supporting the read/write
460           syscalls, it's possible to isolate those applications in
461           their own address space using seccomp. Once seccomp is
462           enabled via /proc/<pid>/seccomp, it cannot be disabled
463           and the task is only allowed to execute a few safe syscalls
464           defined by each seccomp mode.
465
466           If unsure, say Y. Only embedded should say N here.
467
468 endmenu
469
470 config ISA_DMA_API
471         bool
472         default !PPC_ISERIES || PCI
473
474 menu "Bus options"
475
476 config ISA
477         bool "Support for ISA-bus hardware"
478         depends on PPC_PREP || PPC_CHRP
479         select PPC_I8259
480         help
481           Find out whether you have ISA slots on your motherboard.  ISA is the
482           name of a bus system, i.e. the way the CPU talks to the other stuff
483           inside your box.  If you have an Apple machine, say N here; if you
484           have an IBM RS/6000 or pSeries machine or a PReP machine, say Y.  If
485           you have an embedded board, consult your board documentation.
486
487 config ZONE_DMA
488         bool
489         default y
490
491 config GENERIC_ISA_DMA
492         bool
493         depends on PPC64 || POWER4 || 6xx && !CPM2
494         default y
495
496 config PPC_INDIRECT_PCI
497         bool
498         depends on PCI
499         default y if 40x || 44x
500         default n
501
502 config EISA
503         bool
504
505 config SBUS
506         bool
507
508 config FSL_SOC
509         bool
510
511 config FSL_PCI
512         bool
513         select PPC_INDIRECT_PCI
514
515 config 4xx_SOC
516         bool
517
518 # Yes MCA RS/6000s exist but Linux-PPC does not currently support any
519 config MCA
520         bool
521
522 config PCI
523         bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \
524                 || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \
525                 || PPC_PS3 || 44x
526         default y if !40x && !CPM2 && !8xx && !PPC_MPC512x && !PPC_83xx \
527                 && !PPC_85xx && !PPC_86xx
528         default PCI_PERMEDIA if !4xx && !CPM2 && !8xx
529         default PCI_QSPAN if !4xx && !CPM2 && 8xx
530         select ARCH_SUPPORTS_MSI
531         help
532           Find out whether your system includes a PCI bus. PCI is the name of
533           a bus system, i.e. the way the CPU talks to the other stuff inside
534           your box.  If you say Y here, the kernel will include drivers and
535           infrastructure code to support PCI bus devices.
536
537 config PCI_DOMAINS
538         def_bool PCI
539
540 config PCI_SYSCALL
541         def_bool PCI
542
543 config PCI_QSPAN
544         bool "QSpan PCI"
545         depends on !4xx && !CPM2 && 8xx
546         select PPC_I8259
547         help
548           Say Y here if you have a system based on a Motorola 8xx-series
549           embedded processor with a QSPAN PCI interface, otherwise say N.
550
551 config PCI_8260
552         bool
553         depends on PCI && 8260
554         select PPC_INDIRECT_PCI
555         default y
556
557 config 8260_PCI9
558         bool "Enable workaround for MPC826x erratum PCI 9"
559         depends on PCI_8260 && !8272
560         default y
561
562 choice
563         prompt "IDMA channel for PCI 9 workaround"
564         depends on 8260_PCI9
565
566 config 8260_PCI9_IDMA1
567         bool "IDMA1"
568
569 config 8260_PCI9_IDMA2
570         bool "IDMA2"
571
572 config 8260_PCI9_IDMA3
573         bool "IDMA3"
574
575 config 8260_PCI9_IDMA4
576         bool "IDMA4"
577
578 endchoice
579
580 source "drivers/pci/pcie/Kconfig"
581
582 source "drivers/pci/Kconfig"
583
584 source "drivers/pcmcia/Kconfig"
585
586 source "drivers/pci/hotplug/Kconfig"
587
588 endmenu
589
590 menu "Advanced setup"
591         depends on PPC32
592
593 config ADVANCED_OPTIONS
594         bool "Prompt for advanced kernel configuration options"
595         help
596           This option will enable prompting for a variety of advanced kernel
597           configuration options.  These options can cause the kernel to not
598           work if they are set incorrectly, but can be used to optimize certain
599           aspects of kernel memory management.
600
601           Unless you know what you are doing, say N here.
602
603 comment "Default settings for advanced configuration options are used"
604         depends on !ADVANCED_OPTIONS
605
606 config HIGHMEM_START_BOOL
607         bool "Set high memory pool address"
608         depends on ADVANCED_OPTIONS && HIGHMEM
609         help
610           This option allows you to set the base address of the kernel virtual
611           area used to map high memory pages.  This can be useful in
612           optimizing the layout of kernel virtual memory.
613
614           Say N here unless you know what you are doing.
615
616 config HIGHMEM_START
617         hex "Virtual start address of high memory pool" if HIGHMEM_START_BOOL
618         default "0xfe000000"
619
620 config LOWMEM_SIZE_BOOL
621         bool "Set maximum low memory"
622         depends on ADVANCED_OPTIONS
623         help
624           This option allows you to set the maximum amount of memory which
625           will be used as "low memory", that is, memory which the kernel can
626           access directly, without having to set up a kernel virtual mapping.
627           This can be useful in optimizing the layout of kernel virtual
628           memory.
629
630           Say N here unless you know what you are doing.
631
632 config LOWMEM_SIZE
633         hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
634         default "0x30000000"
635
636 config KERNEL_START_BOOL
637         bool "Set custom kernel base address"
638         depends on ADVANCED_OPTIONS
639         help
640           This option allows you to set the kernel virtual address at which
641           the kernel will map low memory (the kernel image will be linked at
642           this address).  This can be useful in optimizing the virtual memory
643           layout of the system.
644
645           Say N here unless you know what you are doing.
646
647 config KERNEL_START
648         hex "Virtual address of kernel base" if KERNEL_START_BOOL
649         default "0xc0000000"
650
651 config TASK_SIZE_BOOL
652         bool "Set custom user task size"
653         depends on ADVANCED_OPTIONS
654         help
655           This option allows you to set the amount of virtual address space
656           allocated to user tasks.  This can be useful in optimizing the
657           virtual memory layout of the system.
658
659           Say N here unless you know what you are doing.
660
661 config TASK_SIZE
662         hex "Size of user task space" if TASK_SIZE_BOOL
663         default "0x80000000" if PPC_PREP || PPC_8xx
664         default "0xc0000000"
665
666 config CONSISTENT_START_BOOL
667         bool "Set custom consistent memory pool address"
668         depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
669         help
670           This option allows you to set the base virtual address
671           of the consistent memory pool.  This pool of virtual
672           memory is used to make consistent memory allocations.
673
674 config CONSISTENT_START
675         hex "Base virtual address of consistent memory pool" if CONSISTENT_START_BOOL
676         default "0xfd000000" if (NOT_COHERENT_CACHE && 8xx)
677         default "0xff100000" if NOT_COHERENT_CACHE
678
679 config CONSISTENT_SIZE_BOOL
680         bool "Set custom consistent memory pool size"
681         depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
682         help
683           This option allows you to set the size of the
684           consistent memory pool.  This pool of virtual memory
685           is used to make consistent memory allocations.
686
687 config CONSISTENT_SIZE
688         hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL
689         default "0x00200000" if NOT_COHERENT_CACHE
690
691 config BOOT_LOAD_BOOL
692         bool "Set the boot link/load address"
693         depends on ADVANCED_OPTIONS && !PPC_MULTIPLATFORM
694         help
695           This option allows you to set the initial load address of the zImage
696           or zImage.initrd file.  This can be useful if you are on a board
697           which has a small amount of memory.
698
699           Say N here unless you know what you are doing.
700
701 config BOOT_LOAD
702         hex "Link/load address for booting" if BOOT_LOAD_BOOL
703         default "0x00400000" if 40x || 8xx || 8260
704         default "0x01000000" if 44x
705         default "0x00800000"
706
707 config PIN_TLB
708         bool "Pinned Kernel TLBs (860 ONLY)"
709         depends on ADVANCED_OPTIONS && 8xx
710 endmenu
711
712 if PPC64
713 config KERNEL_START
714         hex
715         default "0xc000000000000000"
716 endif
717
718 source "net/Kconfig"
719
720 source "drivers/Kconfig"
721
722 source "fs/Kconfig"
723
724 # XXX source "arch/ppc/8xx_io/Kconfig"
725
726 # XXX source "arch/ppc/8260_io/Kconfig"
727
728 source "arch/powerpc/sysdev/qe_lib/Kconfig"
729
730 source "lib/Kconfig"
731
732 source "arch/powerpc/Kconfig.debug"
733
734 source "security/Kconfig"
735
736 config KEYS_COMPAT
737         bool
738         depends on COMPAT && KEYS
739         default y
740
741 source "crypto/Kconfig"
742
743 config PPC_CLOCK
744         bool
745         default n
746
747 config PPC_LIB_RHEAP
748         bool
749