1 # For a description of the syntax of this configuration file,
2 # see Documentation/kbuild/kconfig-language.txt.
5 mainmenu "Linux/PowerPC Kernel Configuration"
7 source "arch/powerpc/platforms/Kconfig.cputype"
29 config GENERIC_CMOS_UPDATE
35 config GENERIC_TIME_VSYSCALL
38 config GENERIC_CLOCKEVENTS
41 config GENERIC_HARDIRQS
45 config HAVE_SETUP_PER_CPU_AREA
52 config RWSEM_GENERIC_SPINLOCK
55 config RWSEM_XCHGADD_ALGORITHM
59 config GENERIC_LOCKBREAK
62 depends on SMP && PREEMPT
64 config ARCH_HAS_ILOG2_U32
68 config ARCH_HAS_ILOG2_U64
72 config GENERIC_HWEIGHT
76 config GENERIC_CALIBRATE_DELAY
80 config GENERIC_FIND_NEXT_BIT
84 config ARCH_NO_VIRT_TO_BUS
101 config SYSVIPC_COMPAT
103 depends on COMPAT && SYSVIPC
106 # All PPC32s use generic nvram driver through ppc_md
111 config SCHED_NO_NO_OMIT_FRAME_POINTER
115 config ARCH_MAY_HAVE_PC_FDC
117 default !PPC_PSERIES || PCI
125 config PPC_UDBG_16550
129 config GENERIC_TBSYNC
131 default y if PPC32 && SMP
143 config SYS_SUPPORTS_APM_EMULATION
144 default y if PMAC_APM_EMU
147 config DEFAULT_UIMAGE
150 Used to allow a board to specify it wants a uImage built by default
158 depends on (PPC_PMAC && !SMP) || BROKEN
163 depends on BROKEN || (PPC_PMAC64 && EXPERIMENTAL)
166 config ARCH_HIBERNATION_POSSIBLE
168 depends on (PPC64 && HIBERNATE_64) || (PPC32 && HIBERNATE_32)
171 config ARCH_SUSPEND_POSSIBLE
173 depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200
175 config PPC_DCR_NATIVE
185 depends on PPC_DCR_NATIVE || PPC_DCR_MMIO
188 config PPC_OF_PLATFORM_PCI
191 depends on PPC64 # not supported on 32 bits yet
194 source "init/Kconfig"
196 source "arch/powerpc/sysdev/Kconfig"
197 source "arch/powerpc/platforms/Kconfig"
199 menu "Kernel options"
202 bool "High memory support"
205 source kernel/time/Kconfig
206 source kernel/Kconfig.hz
207 source kernel/Kconfig.preempt
208 source "fs/Kconfig.binfmt"
210 # We optimistically allocate largepages from the VM, so make the limit
211 # large enough (16MB). This badly named config option is actually
213 config FORCE_MAX_ZONEORDER
216 default "9" if PPC_64K_PAGES
219 config HUGETLB_PAGE_SIZE_VARIABLE
221 depends on HUGETLB_PAGE
224 config MATH_EMULATION
225 bool "Math emulation"
226 depends on 4xx || 8xx || E200 || PPC_MPC832x || E500
228 Some PowerPC chips designed for embedded applications do not have
229 a floating-point unit and therefore do not implement the
230 floating-point instructions in the PowerPC instruction set. If you
231 say Y here, the kernel will include code to emulate a floating-point
232 unit, which will allow programs that use floating-point
235 config 8XX_MINIMAL_FPEMU
236 bool "Minimal math emulation for 8xx"
237 depends on 8xx && !MATH_EMULATION
239 Older arch/ppc kernels still emulated a few floating point
240 instructions such as load and store, even when full math
241 emulation is disabled. Say "Y" here if you want to preserve
244 It is recommended that you build a soft-float userspace instead.
247 bool "Enable IOMMU virtual merging"
251 Cause IO segments sent to a device for DMA to be merged virtually
252 by the IOMMU when they happen to have been allocated contiguously.
253 This doesn't add pressure to the IOMMU allocator. However, some
254 drivers don't support getting large merged segments coming back
257 Most drivers don't have this problem; it is safe to say Y here.
260 bool "Support for enabling/disabling CPUs"
261 depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC)
263 Say Y here to be able to disable and re-enable individual
264 CPUs at runtime on SMP machines.
266 Say N if you are unsure.
268 config ARCH_ENABLE_MEMORY_HOTPLUG
272 bool "kexec system call (EXPERIMENTAL)"
273 depends on (PPC_PRPMC2800 || PPC_MULTIPLATFORM) && EXPERIMENTAL
275 kexec is a system call that implements the ability to shutdown your
276 current kernel, and to start another kernel. It is like a reboot
277 but it is independent of the system firmware. And like a reboot
278 you can start any kernel with it, not just Linux.
280 The name comes from the similarity to the exec system call.
282 It is an ongoing process to be certain the hardware in a machine
283 is properly shutdown, so do not be surprised if this code does not
284 initially work for you. It may help to enable device hotplugging
285 support. As of this writing the exact hardware interface is
286 strongly in flux, so no good recommendation can be made.
289 bool "Build a kdump crash kernel (EXPERIMENTAL)"
290 depends on PPC_MULTIPLATFORM && PPC64 && EXPERIMENTAL
292 Build a kernel suitable for use as a kdump capture kernel.
293 The kernel will be linked at a different address than normal, and
294 so can only be used for Kdump.
296 Don't change this unless you know what you are doing.
299 bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC
300 default y if PPC_PREP
303 bool "Distribute interrupts on all CPUs by default"
304 depends on SMP && !MV64360
306 This option gives the kernel permission to distribute IRQs across
307 multiple CPUs. Saying N here will route all IRQs to the first
308 CPU. Generally saying Y is safe, although some problems have been
309 reported with SMP Power Macintoshes with this option enabled.
314 default y if SMP && PPC_PSERIES
319 depends on NEED_MULTIPLE_NODES
321 config ARCH_SELECT_MEMORY_MODEL
325 config ARCH_FLATMEM_ENABLE
327 depends on (PPC64 && !NUMA) || PPC32
329 config ARCH_SPARSEMEM_ENABLE
332 select SPARSEMEM_VMEMMAP_ENABLE
334 config ARCH_SPARSEMEM_DEFAULT
336 depends on (SMP && PPC_PSERIES) || PPC_PS3
338 config ARCH_POPULATES_NODE_MAP
343 config ARCH_MEMORY_PROBE
345 depends on MEMORY_HOTPLUG
347 # Some NUMA nodes have memory ranges that span
348 # other nodes. Even though a pfn is valid and
349 # between a node's start and end pfns, it may not
350 # reside on that node. See memmap_init_zone()
352 config NODES_SPAN_OTHER_NODES
354 depends on NEED_MULTIPLE_NODES
356 config PPC_HAS_HASH_64K
364 select PPC_HAS_HASH_64K
366 This option changes the kernel logical page size to 64k. On machines
367 without processor support for 64k pages, the kernel will simulate
368 them by loading each individual 4k page on demand transparently,
369 while on hardware with such support, it will be used to map
370 normal application pages.
372 config PPC_SUBPAGE_PROT
373 bool "Support setting protections for 4k subpages"
374 depends on PPC_64K_PAGES
376 This option adds support for a system call to allow user programs
377 to set access permissions (read/write, readonly, or no access)
378 on the 4k subpages of each 64k page.
381 bool "SMT (Hyperthreading) scheduler support"
382 depends on PPC64 && SMP
384 SMT scheduler support improves the CPU scheduler's decision making
385 when dealing with POWER5 cpus at a cost of slightly increased
386 overhead in some places. If unsure say N here.
388 config PROC_DEVICETREE
389 bool "Support for device tree in /proc"
392 This option adds a device-tree directory under /proc which contains
393 an image of the device tree that the kernel copies from Open
394 Firmware or other boot firmware. If unsure, say Y here.
397 bool "Default bootloader kernel arguments"
400 string "Initial kernel command string"
401 depends on CMDLINE_BOOL
402 default "console=ttyS0,9600 console=tty0 root=/dev/sda2"
404 On some platforms, there is currently no way for the boot loader to
405 pass arguments to the kernel. For these platforms, you can supply
406 some command-line options at build time by entering them here. In
407 most cases you will need to specify the root device here.
410 config ARCH_WANTS_FREEZER_CONTROL
414 source kernel/power/Kconfig
418 bool "Enable seccomp to safely compute untrusted bytecode"
422 This kernel feature is useful for number crunching applications
423 that may need to compute untrusted bytecode during their
424 execution. By using pipes or other transports made available to
425 the process as file descriptors supporting the read/write
426 syscalls, it's possible to isolate those applications in
427 their own address space using seccomp. Once seccomp is
428 enabled via /proc/<pid>/seccomp, it cannot be disabled
429 and the task is only allowed to execute a few safe syscalls
430 defined by each seccomp mode.
432 If unsure, say Y. Only embedded should say N here.
434 config WANT_DEVICE_TREE
439 string "Static device tree source file"
440 depends on WANT_DEVICE_TREE
442 This specifies the device tree source (.dts) file to be
443 compiled and included when building the bootwrapper. If a
444 relative filename is given, then it will be relative to
445 arch/powerpc/boot/dts. If you are not using the bootwrapper,
446 or do not need to build a dts into the bootwrapper, this
449 For example, this is required when building a cuImage target
450 for an older U-Boot, which cannot pass a device tree itself.
451 Such a kernel will not work with a newer U-Boot that tries to
452 pass a device tree (unless you tell it not to). If your U-Boot
453 does not mention a device tree in "help bootm", then use the
454 cuImage target and specify a device tree here. Otherwise, use
455 the uImage target and leave this field blank.
461 default !PPC_ISERIES || PCI
466 bool "Support for ISA-bus hardware"
467 depends on PPC_PREP || PPC_CHRP
470 Find out whether you have ISA slots on your motherboard. ISA is the
471 name of a bus system, i.e. the way the CPU talks to the other stuff
472 inside your box. If you have an Apple machine, say N here; if you
473 have an IBM RS/6000 or pSeries machine or a PReP machine, say Y. If
474 you have an embedded board, consult your board documentation.
480 config GENERIC_ISA_DMA
482 depends on PPC64 || POWER4 || 6xx && !CPM2
485 config PPC_INDIRECT_PCI
488 default y if 40x || 44x
502 select PPC_INDIRECT_PCI
504 # Yes MCA RS/6000s exist but Linux-PPC does not currently support any
509 bool "PCI support" if 40x || CPM2 || PPC_83xx || PPC_85xx || PPC_86xx \
510 || PPC_MPC52xx || (EMBEDDED && (PPC_PSERIES || PPC_ISERIES)) \
512 default y if !40x && !CPM2 && !8xx && !PPC_83xx \
513 && !PPC_85xx && !PPC_86xx
514 default PCI_PERMEDIA if !4xx && !CPM2 && !8xx
515 default PCI_QSPAN if !4xx && !CPM2 && 8xx
516 select ARCH_SUPPORTS_MSI
518 Find out whether your system includes a PCI bus. PCI is the name of
519 a bus system, i.e. the way the CPU talks to the other stuff inside
520 your box. If you say Y here, the kernel will include drivers and
521 infrastructure code to support PCI bus devices.
531 depends on !4xx && !CPM2 && 8xx
534 Say Y here if you have a system based on a Motorola 8xx-series
535 embedded processor with a QSPAN PCI interface, otherwise say N.
539 depends on PCI && 8260
540 select PPC_INDIRECT_PCI
544 bool "Enable workaround for MPC826x erratum PCI 9"
545 depends on PCI_8260 && !8272
549 prompt "IDMA channel for PCI 9 workaround"
552 config 8260_PCI9_IDMA1
555 config 8260_PCI9_IDMA2
558 config 8260_PCI9_IDMA3
561 config 8260_PCI9_IDMA4
566 source "drivers/pci/pcie/Kconfig"
568 source "drivers/pci/Kconfig"
570 source "drivers/pcmcia/Kconfig"
572 source "drivers/pci/hotplug/Kconfig"
576 menu "Advanced setup"
579 config ADVANCED_OPTIONS
580 bool "Prompt for advanced kernel configuration options"
582 This option will enable prompting for a variety of advanced kernel
583 configuration options. These options can cause the kernel to not
584 work if they are set incorrectly, but can be used to optimize certain
585 aspects of kernel memory management.
587 Unless you know what you are doing, say N here.
589 comment "Default settings for advanced configuration options are used"
590 depends on !ADVANCED_OPTIONS
592 config HIGHMEM_START_BOOL
593 bool "Set high memory pool address"
594 depends on ADVANCED_OPTIONS && HIGHMEM
596 This option allows you to set the base address of the kernel virtual
597 area used to map high memory pages. This can be useful in
598 optimizing the layout of kernel virtual memory.
600 Say N here unless you know what you are doing.
603 hex "Virtual start address of high memory pool" if HIGHMEM_START_BOOL
606 config LOWMEM_SIZE_BOOL
607 bool "Set maximum low memory"
608 depends on ADVANCED_OPTIONS
610 This option allows you to set the maximum amount of memory which
611 will be used as "low memory", that is, memory which the kernel can
612 access directly, without having to set up a kernel virtual mapping.
613 This can be useful in optimizing the layout of kernel virtual
616 Say N here unless you know what you are doing.
619 hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
622 config KERNEL_START_BOOL
623 bool "Set custom kernel base address"
624 depends on ADVANCED_OPTIONS
626 This option allows you to set the kernel virtual address at which
627 the kernel will map low memory (the kernel image will be linked at
628 this address). This can be useful in optimizing the virtual memory
629 layout of the system.
631 Say N here unless you know what you are doing.
634 hex "Virtual address of kernel base" if KERNEL_START_BOOL
637 config TASK_SIZE_BOOL
638 bool "Set custom user task size"
639 depends on ADVANCED_OPTIONS
641 This option allows you to set the amount of virtual address space
642 allocated to user tasks. This can be useful in optimizing the
643 virtual memory layout of the system.
645 Say N here unless you know what you are doing.
648 hex "Size of user task space" if TASK_SIZE_BOOL
649 default "0x80000000" if PPC_PREP || PPC_8xx
652 config CONSISTENT_START_BOOL
653 bool "Set custom consistent memory pool address"
654 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
656 This option allows you to set the base virtual address
657 of the consistent memory pool. This pool of virtual
658 memory is used to make consistent memory allocations.
660 config CONSISTENT_START
661 hex "Base virtual address of consistent memory pool" if CONSISTENT_START_BOOL
662 default "0xfd000000" if (NOT_COHERENT_CACHE && 8xx)
663 default "0xff100000" if NOT_COHERENT_CACHE
665 config CONSISTENT_SIZE_BOOL
666 bool "Set custom consistent memory pool size"
667 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
669 This option allows you to set the size of the
670 consistent memory pool. This pool of virtual memory
671 is used to make consistent memory allocations.
673 config CONSISTENT_SIZE
674 hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL
675 default "0x00200000" if NOT_COHERENT_CACHE
677 config BOOT_LOAD_BOOL
678 bool "Set the boot link/load address"
679 depends on ADVANCED_OPTIONS && !PPC_MULTIPLATFORM
681 This option allows you to set the initial load address of the zImage
682 or zImage.initrd file. This can be useful if you are on a board
683 which has a small amount of memory.
685 Say N here unless you know what you are doing.
688 hex "Link/load address for booting" if BOOT_LOAD_BOOL
689 default "0x00400000" if 40x || 8xx || 8260
690 default "0x01000000" if 44x
694 bool "Pinned Kernel TLBs (860 ONLY)"
695 depends on ADVANCED_OPTIONS && 8xx
701 default "0xc000000000000000"
706 source "drivers/Kconfig"
710 # XXX source "arch/ppc/8xx_io/Kconfig"
712 # XXX source "arch/ppc/8260_io/Kconfig"
714 source "arch/powerpc/sysdev/qe_lib/Kconfig"
718 source "arch/powerpc/Kconfig.debug"
720 source "security/Kconfig"
724 depends on COMPAT && KEYS
727 source "crypto/Kconfig"