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