blob: 5b1527883fcb590b361fcda998164a59f4a33e4a [file] [log] [blame]
Paul Mackerras14cf11a2005-09-26 16:04:21 +10001# For a description of the syntax of this configuration file,
2# see Documentation/kbuild/kconfig-language.txt.
3#
4
5mainmenu "Linux/PowerPC Kernel Configuration"
6
Arnd Bergmanna0ae9c72007-06-13 02:30:17 +10007source "arch/powerpc/platforms/Kconfig.cputype"
Johannes Berg17e638b2007-03-19 11:53:53 +01008
Paul Mackerras14cf11a2005-09-26 16:04:21 +10009config PPC32
10 bool
11 default y if !PPC64
12
13config 64BIT
14 bool
15 default y if PPC64
16
Stephen Rothwell2578bfa2007-09-21 10:16:20 +100017config WORD_SIZE
18 int
19 default 64 if PPC64
20 default 32 if !PPC64
21
Jeremy Fitzhardinge600715d2008-09-11 01:31:45 -070022config ARCH_PHYS_ADDR_T_64BIT
23 def_bool PPC64 || PHYS_64BIT
24
Paul Mackerras14cf11a2005-09-26 16:04:21 +100025config MMU
26 bool
27 default y
28
Tony Breedsaa3be5f2007-09-21 13:26:02 +100029config GENERIC_CMOS_UPDATE
30 def_bool y
31
Tony Breeds4a4cfe32007-09-22 07:35:52 +100032config GENERIC_TIME
33 def_bool y
34
35config GENERIC_TIME_VSYSCALL
36 def_bool y
37
Tony Breedsd831d0b2007-09-21 13:26:03 +100038config GENERIC_CLOCKEVENTS
39 def_bool y
40
Paul Mackerras14cf11a2005-09-26 16:04:21 +100041config GENERIC_HARDIRQS
42 bool
43 default y
44
travis@sgi.com988c3882008-01-30 23:27:58 +010045config HAVE_SETUP_PER_CPU_AREA
travis@sgi.comb32ef632008-01-30 13:32:51 +010046 def_bool PPC64
47
Ingo Molnar0d7012a2006-06-29 02:24:43 -070048config IRQ_PER_CPU
49 bool
50 default y
51
Christoph Hellwigfd3e0bb2008-04-17 14:35:00 +100052config STACKTRACE_SUPPORT
53 bool
54 default y
55
Arnd Bergmann01f4b8b2008-07-11 00:08:18 +100056config HAVE_LATENCYTOP_SUPPORT
57 def_bool y
58
Benjamin Herrenschmidt945feb12008-04-17 14:35:01 +100059config TRACE_IRQFLAGS_SUPPORT
60 bool
61 depends on PPC64
62 default y
63
64config LOCKDEP_SUPPORT
65 bool
66 default y
67
Paul Mackerras14cf11a2005-09-26 16:04:21 +100068config RWSEM_GENERIC_SPINLOCK
69 bool
70
71config RWSEM_XCHGADD_ALGORITHM
72 bool
73 default y
74
Nick Piggin95c354f2008-01-30 13:31:20 +010075config GENERIC_LOCKBREAK
76 bool
77 default y
78 depends on SMP && PREEMPT
79
David Howellsf0d1b0b2006-12-08 02:37:49 -080080config ARCH_HAS_ILOG2_U32
81 bool
David Howellsef55d532006-12-08 02:37:53 -080082 default y
David Howellsf0d1b0b2006-12-08 02:37:49 -080083
84config ARCH_HAS_ILOG2_U64
85 bool
David Howellsef55d532006-12-08 02:37:53 -080086 default y if 64BIT
David Howellsf0d1b0b2006-12-08 02:37:49 -080087
Akinobu Mitae779b2f2006-03-26 01:39:33 -080088config GENERIC_HWEIGHT
89 bool
90 default y
91
Paul Mackerras14cf11a2005-09-26 16:04:21 +100092config GENERIC_CALIBRATE_DELAY
93 bool
94 default y
95
Jon Mason0a9cb462006-05-19 15:35:32 -050096config GENERIC_FIND_NEXT_BIT
97 bool
98 default y
99
Anton Vorontsovb7ce3412008-04-11 23:06:36 +1000100config GENERIC_GPIO
101 bool
102 help
103 Generic GPIO API support
104
Stephen Rothwellf057eac2007-07-15 23:40:05 -0700105config ARCH_NO_VIRT_TO_BUS
106 def_bool PPC64
107
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000108config PPC
109 bool
110 default y
Steven Rostedt677aa9f2008-05-17 00:01:36 -0400111 select HAVE_DYNAMIC_FTRACE
Steven Rostedt4e491d12008-05-14 23:49:44 -0400112 select HAVE_FTRACE
Michael Buesch7444a722008-07-25 01:46:11 -0700113 select ARCH_WANT_OPTIONAL_GPIOLIB
Sam Ravnborgec7748b2008-02-09 10:46:40 +0100114 select HAVE_IDE
Benjamin Herrenschmidta1f242f2008-07-23 21:27:08 -0700115 select HAVE_IOREMAP_PROT
Johannes Berg58340a02008-07-25 01:45:33 -0700116 select HAVE_EFFICIENT_UNALIGNED_ACCESS
Mathieu Desnoyers3f550092008-02-02 15:10:35 -0500117 select HAVE_KPROBES
Jason Wessel17ce4522008-07-23 11:30:15 -0500118 select HAVE_ARCH_KGDB
Ananth N Mavinakayanahalli9edddaa2008-03-04 14:28:37 -0800119 select HAVE_KRETPROBES
Roland McGrathdec2b0d2008-07-27 16:53:20 +1000120 select HAVE_ARCH_TRACEHOOK
David S. Millerd9b2b2a2008-02-13 16:56:49 -0800121 select HAVE_LMB
Takashi Iwai7ff86b02008-07-16 02:20:11 +0200122 select HAVE_DMA_ATTRS if PPC64
Jens Axboeb7d7a242008-06-26 11:22:13 +0200123 select USE_GENERIC_SMP_HELPERS if SMP
Steven Rostedt4e491d12008-05-14 23:49:44 -0400124 select HAVE_OPROFILE
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000125
126config EARLY_PRINTK
127 bool
Benjamin Herrenschmidt51d30822005-11-23 17:57:25 +1100128 default y
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000129
130config COMPAT
131 bool
132 default y if PPC64
Roland McGrath01e31db2008-01-02 17:03:11 -0800133 select COMPAT_BINFMT_ELF
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000134
135config SYSVIPC_COMPAT
136 bool
137 depends on COMPAT && SYSVIPC
138 default y
139
140# All PPC32s use generic nvram driver through ppc_md
141config GENERIC_NVRAM
142 bool
143 default y if PPC32
144
145config SCHED_NO_NO_OMIT_FRAME_POINTER
146 bool
147 default y
148
149config ARCH_MAY_HAVE_PC_FDC
150 bool
Stephen Rothwellbed59272007-03-04 17:04:44 +1100151 default !PPC_PSERIES || PCI
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000152
Kumar Gala08264cb2006-01-10 21:43:56 -0600153config PPC_OF
154 def_bool y
155
Stephen Rothwell97e873e2007-05-01 16:26:07 +1000156config OF
157 def_bool y
158
Kumar Gala08264cb2006-01-10 21:43:56 -0600159config PPC_UDBG_16550
160 bool
161 default n
162
Kumar Gala08264cb2006-01-10 21:43:56 -0600163config GENERIC_TBSYNC
164 bool
165 default y if PPC32 && SMP
166 default n
167
Al Viroe65e1fc2006-09-12 03:04:40 -0400168config AUDIT_ARCH
169 bool
170 default y
171
Jeremy Fitzhardinge73c9cea2006-12-08 03:30:41 -0800172config GENERIC_BUG
173 bool
174 default y
175 depends on BUG
176
Johannes Bergb3028872007-03-20 05:18:02 +1100177config SYS_SUPPORTS_APM_EMULATION
Kumar Gala58da10b2007-05-23 09:51:46 -0500178 default y if PMAC_APM_EMU
Johannes Bergb3028872007-03-20 05:18:02 +1100179 bool
180
Kumar Galaf4fc4a52006-01-16 10:53:22 -0600181config DEFAULT_UIMAGE
182 bool
183 help
184 Used to allow a board to specify it wants a uImage built by default
185 default n
186
Scott Woodb09c1642008-01-17 16:31:40 -0600187config REDBOOT
188 bool
189
Johannes Berg801e4062007-12-08 02:12:39 +0100190config HIBERNATE_32
Johannes Berg543b9fd2007-05-03 22:31:38 +1000191 bool
Johannes Berg801e4062007-12-08 02:12:39 +0100192 depends on (PPC_PMAC && !SMP) || BROKEN
193 default y
194
195config HIBERNATE_64
196 bool
197 depends on BROKEN || (PPC_PMAC64 && EXPERIMENTAL)
198 default y
199
200config ARCH_HIBERNATION_POSSIBLE
201 bool
202 depends on (PPC64 && HIBERNATE_64) || (PPC32 && HIBERNATE_32)
Johannes Berg543b9fd2007-05-03 22:31:38 +1000203 default y
204
Johannes Bergf4cb5702007-12-08 02:14:00 +0100205config ARCH_SUSPEND_POSSIBLE
206 def_bool y
Scott Woodd49747b2007-10-09 12:37:13 -0500207 depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 || PPC_83xx
Johannes Bergf4cb5702007-12-08 02:14:00 +0100208
Benjamin Herrenschmidt4c75a6f2006-11-11 17:24:53 +1100209config PPC_DCR_NATIVE
210 bool
211 default n
212
213config PPC_DCR_MMIO
214 bool
215 default n
216
217config PPC_DCR
218 bool
219 depends on PPC_DCR_NATIVE || PPC_DCR_MMIO
220 default y
221
Benjamin Herrenschmidt4c9d2802006-11-11 17:25:08 +1100222config PPC_OF_PLATFORM_PCI
223 bool
Stephen Rothwell373a6da2007-12-21 15:37:07 +1100224 depends on PCI
Benjamin Herrenschmidt4c9d2802006-11-11 17:25:08 +1100225 depends on PPC64 # not supported on 32 bits yet
226 default n
227
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000228source "init/Kconfig"
229
Matt Helsleydc52ddc2008-10-18 20:27:21 -0700230source "kernel/Kconfig.freezer"
231
Benjamin Herrenschmidta2d2e1e2007-12-21 15:39:24 +1100232source "arch/powerpc/sysdev/Kconfig"
Kumar Gala4330f5d2007-03-16 09:32:17 -0500233source "arch/powerpc/platforms/Kconfig"
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000234
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000235menu "Kernel options"
236
237config HIGHMEM
238 bool "High memory support"
239 depends on PPC32
240
Tony Breeds1ad74992007-09-21 13:26:03 +1000241source kernel/time/Kconfig
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000242source kernel/Kconfig.hz
243source kernel/Kconfig.preempt
244source "fs/Kconfig.binfmt"
245
Mel Gormanba72cb82007-11-28 16:21:13 -0800246config HUGETLB_PAGE_SIZE_VARIABLE
247 bool
248 depends on HUGETLB_PAGE
249 default y
250
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000251config MATH_EMULATION
252 bool "Math emulation"
Kumar Gala4d527192007-01-26 00:23:34 -0600253 depends on 4xx || 8xx || E200 || PPC_MPC832x || E500
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000254 ---help---
255 Some PowerPC chips designed for embedded applications do not have
256 a floating-point unit and therefore do not implement the
257 floating-point instructions in the PowerPC instruction set. If you
258 say Y here, the kernel will include code to emulate a floating-point
259 unit, which will allow programs that use floating-point
260 instructions to run.
261
Scott Wood5dd57a12007-09-18 15:29:35 -0500262config 8XX_MINIMAL_FPEMU
263 bool "Minimal math emulation for 8xx"
264 depends on 8xx && !MATH_EMULATION
265 help
266 Older arch/ppc kernels still emulated a few floating point
267 instructions such as load and store, even when full math
268 emulation is disabled. Say "Y" here if you want to preserve
269 this behavior.
270
271 It is recommended that you build a soft-float userspace instead.
272
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000273config IOMMU_VMERGE
Linas Vepstas768cc2d2007-07-18 02:09:35 +1000274 bool "Enable IOMMU virtual merging"
275 depends on PPC64
276 default y
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000277 help
278 Cause IO segments sent to a device for DMA to be merged virtually
279 by the IOMMU when they happen to have been allocated contiguously.
280 This doesn't add pressure to the IOMMU allocator. However, some
281 drivers don't support getting large merged segments coming back
Linas Vepstas768cc2d2007-07-18 02:09:35 +1000282 from *_map_sg().
283
284 Most drivers don't have this problem; it is safe to say Y here.
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000285
FUJITA Tomonorifb3475e2008-02-04 22:28:08 -0800286config IOMMU_HELPER
287 def_bool PPC64
288
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000289config HOTPLUG_CPU
290 bool "Support for enabling/disabling CPUs"
291 depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC)
292 ---help---
293 Say Y here to be able to disable and re-enable individual
294 CPUs at runtime on SMP machines.
295
296 Say N if you are unsure.
297
Yasunori Gotocc576372006-06-29 02:24:27 -0700298config ARCH_ENABLE_MEMORY_HOTPLUG
299 def_bool y
300
Badari Pulavartya99824f2008-02-05 00:10:18 -0800301config ARCH_HAS_WALK_MEMORY
302 def_bool y
303
Badari Pulavarty14824712008-02-05 00:10:17 -0800304config ARCH_ENABLE_MEMORY_HOTREMOVE
305 def_bool y
306
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000307config KEXEC
308 bool "kexec system call (EXPERIMENTAL)"
Dale Farnsworthfd4ba7e2007-05-12 10:58:43 +1000309 depends on (PPC_PRPMC2800 || PPC_MULTIPLATFORM) && EXPERIMENTAL
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000310 help
311 kexec is a system call that implements the ability to shutdown your
312 current kernel, and to start another kernel. It is like a reboot
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400313 but it is independent of the system firmware. And like a reboot
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000314 you can start any kernel with it, not just Linux.
315
Matt LaPlante1f1332f2006-06-29 01:32:47 -0400316 The name comes from the similarity to the exec system call.
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000317
318 It is an ongoing process to be certain the hardware in a machine
319 is properly shutdown, so do not be surprised if this code does not
320 initially work for you. It may help to enable device hotplugging
321 support. As of this writing the exact hardware interface is
322 strongly in flux, so no good recommendation can be made.
323
Haren Mynenie8625d462006-01-14 13:48:25 -0800324config CRASH_DUMP
Bernhard Walle3420b5d2008-06-27 03:02:15 +1000325 bool "Build a kdump crash kernel"
Mohan Kumar M54622f12008-10-21 17:38:10 +0000326 depends on PPC_MULTIPLATFORM && PPC64 && RELOCATABLE
Haren Mynenie8625d462006-01-14 13:48:25 -0800327 help
328 Build a kernel suitable for use as a kdump capture kernel.
Mohan Kumar M54622f12008-10-21 17:38:10 +0000329 The same kernel binary can be used as production kernel and dump
330 capture kernel.
Haren Mynenie8625d462006-01-14 13:48:25 -0800331
Manish Ahuja242f2712008-03-22 10:50:50 +1100332config PHYP_DUMP
333 bool "Hypervisor-assisted dump (EXPERIMENTAL)"
334 depends on PPC_PSERIES && EXPERIMENTAL
335 help
336 Hypervisor-assisted dump is meant to be a kdump replacement
337 offering robustness and speed not possible without system
338 hypervisor assistence.
339
340 If unsure, say "N"
341
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000342config PPCBUG_NVRAM
343 bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC
344 default y if PPC_PREP
345
346config IRQ_ALL_CPUS
347 bool "Distribute interrupts on all CPUs by default"
348 depends on SMP && !MV64360
349 help
350 This option gives the kernel permission to distribute IRQs across
351 multiple CPUs. Saying N here will route all IRQs to the first
352 CPU. Generally saying Y is safe, although some problems have been
353 reported with SMP Power Macintoshes with this option enabled.
354
Andy Whitcroftffa27b62005-10-28 17:46:58 -0700355config NUMA
356 bool "NUMA support"
357 depends on PPC64
358 default y if SMP && PPC_PSERIES
359
Yasunori Gotoc80d79d2006-04-10 22:53:53 -0700360config NODES_SHIFT
361 int
362 default "4"
363 depends on NEED_MULTIPLE_NODES
364
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000365config ARCH_SELECT_MEMORY_MODEL
366 def_bool y
367 depends on PPC64
368
369config ARCH_FLATMEM_ENABLE
Andy Whitcroft9100b202005-11-29 19:20:55 +0000370 def_bool y
371 depends on (PPC64 && !NUMA) || PPC32
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000372
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000373config ARCH_SPARSEMEM_ENABLE
374 def_bool y
Andy Whitcroft9100b202005-11-29 19:20:55 +0000375 depends on PPC64
Andy Whitcroftd29eff72007-10-16 01:24:17 -0700376 select SPARSEMEM_VMEMMAP_ENABLE
Anton Blanchard45fb6ce2005-11-11 14:22:35 +1100377
378config ARCH_SPARSEMEM_DEFAULT
379 def_bool y
Benjamin Herrenschmidt78bde532007-02-13 11:46:06 +1100380 depends on (SMP && PPC_PSERIES) || PPC_PS3
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000381
Mel Gormanc67c3cb2006-09-27 01:49:49 -0700382config ARCH_POPULATES_NODE_MAP
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000383 def_bool y
Mel Gormanc67c3cb2006-09-27 01:49:49 -0700384
385source "mm/Kconfig"
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000386
Mike Kravetz7e9191d2005-11-07 09:39:48 -0800387config ARCH_MEMORY_PROBE
388 def_bool y
389 depends on MEMORY_HOTPLUG
390
Andy Whitcroft75167952006-10-21 10:24:14 -0700391# Some NUMA nodes have memory ranges that span
392# other nodes. Even though a pfn is valid and
393# between a node's start and end pfns, it may not
394# reside on that node. See memmap_init_zone()
395# for details.
396config NODES_SPAN_OTHER_NODES
397 def_bool y
398 depends on NEED_MULTIPLE_NODES
399
Benjamin Herrenschmidt16c2d472007-05-08 16:27:28 +1000400config PPC_HAS_HASH_64K
401 bool
402 depends on PPC64
403 default n
404
Benjamin Herrenschmidt3c726f82005-11-07 11:06:55 +1100405config PPC_64K_PAGES
406 bool "64k page size"
Benjamin Herrenschmidt863c84b2005-11-07 00:57:58 -0800407 depends on PPC64
Benjamin Herrenschmidt16c2d472007-05-08 16:27:28 +1000408 select PPC_HAS_HASH_64K
Benjamin Herrenschmidt3c726f82005-11-07 11:06:55 +1100409 help
410 This option changes the kernel logical page size to 64k. On machines
Kumar Gala98750262007-04-12 18:01:34 -0500411 without processor support for 64k pages, the kernel will simulate
412 them by loading each individual 4k page on demand transparently,
413 while on hardware with such support, it will be used to map
414 normal application pages.
Benjamin Herrenschmidt3c726f82005-11-07 11:06:55 +1100415
Stephen Rothwell53bcddb2008-04-11 11:11:56 +1000416config FORCE_MAX_ZONEORDER
417 int "Maximum zone order"
Johannes Bergebe40c52008-09-24 04:29:08 +0000418 range 9 64 if PPC_64K_PAGES
Stephen Rothwell53bcddb2008-04-11 11:11:56 +1000419 default "9" if PPC_64K_PAGES
Johannes Bergebe40c52008-09-24 04:29:08 +0000420 range 13 64 if PPC64 && !PPC_64K_PAGES
Stephen Rothwell53bcddb2008-04-11 11:11:56 +1000421 default "13" if PPC64 && !PPC_64K_PAGES
Johannes Bergebe40c52008-09-24 04:29:08 +0000422 range 11 64
Stephen Rothwell53bcddb2008-04-11 11:11:56 +1000423 default "11"
424 help
425 The kernel memory allocator divides physically contiguous memory
426 blocks into "zones", where each zone is a power of two number of
427 pages. This option selects the largest power of two that the kernel
428 keeps in the memory allocator. If you need to allocate very large
429 blocks of physically contiguous memory, then you may need to
430 increase this value.
431
432 This config option is actually maximum order plus one. For example,
433 a value of 11 means that the largest free memory block is 2^10 pages.
434
435 The page size is not necessarily 4KB. For example, on 64-bit
436 systems, 64KB pages can be enabled via CONFIG_PPC_64K_PAGES. Keep
437 this in mind when choosing a value for this option.
438
Paul Mackerrasfa282372008-01-24 08:35:13 +1100439config PPC_SUBPAGE_PROT
440 bool "Support setting protections for 4k subpages"
441 depends on PPC_64K_PAGES
442 help
443 This option adds support for a system call to allow user programs
444 to set access permissions (read/write, readonly, or no access)
445 on the 4k subpages of each 64k page.
446
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000447config SCHED_SMT
448 bool "SMT (Hyperthreading) scheduler support"
449 depends on PPC64 && SMP
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000450 help
451 SMT scheduler support improves the CPU scheduler's decision making
452 when dealing with POWER5 cpus at a cost of slightly increased
453 overhead in some places. If unsure say N here.
454
455config PROC_DEVICETREE
Paul Mackerras5f296752005-10-17 20:14:59 +1000456 bool "Support for device tree in /proc"
457 depends on PROC_FS
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000458 help
459 This option adds a device-tree directory under /proc which contains
460 an image of the device tree that the kernel copies from Open
Paul Mackerras5f296752005-10-17 20:14:59 +1000461 Firmware or other boot firmware. If unsure, say Y here.
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000462
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000463config CMDLINE_BOOL
464 bool "Default bootloader kernel arguments"
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000465
466config CMDLINE
467 string "Initial kernel command string"
468 depends on CMDLINE_BOOL
469 default "console=ttyS0,9600 console=tty0 root=/dev/sda2"
470 help
471 On some platforms, there is currently no way for the boot loader to
472 pass arguments to the kernel. For these platforms, you can supply
473 some command-line options at build time by entering them here. In
474 most cases you will need to specify the root device here.
475
Grant Likelyc356aa42008-07-09 09:41:52 -0600476config EXTRA_TARGETS
477 string "Additional default image types"
478 help
479 List additional targets to be built by the bootwrapper here (separated
480 by spaces). This is useful for targets that depend of device tree
481 files in the .dts directory.
482
483 Targets in this list will be build as part of the default build
484 target, or when the user does a 'make zImage' or a
485 'make zImage.initrd'.
486
487 If unsure, leave blank
488
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000489if !44x || BROKEN
Johannes Bergb28f5082008-01-15 23:17:00 -0500490config ARCH_WANTS_FREEZER_CONTROL
491 def_bool y
492 depends on ADB_PMU
493
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000494source kernel/power/Kconfig
495endif
496
497config SECCOMP
498 bool "Enable seccomp to safely compute untrusted bytecode"
499 depends on PROC_FS
500 default y
501 help
502 This kernel feature is useful for number crunching applications
503 that may need to compute untrusted bytecode during their
504 execution. By using pipes or other transports made available to
505 the process as file descriptors supporting the read/write
506 syscalls, it's possible to isolate those applications in
507 their own address space using seccomp. Once seccomp is
508 enabled via /proc/<pid>/seccomp, it cannot be disabled
509 and the task is only allowed to execute a few safe syscalls
510 defined by each seccomp mode.
511
512 If unsure, say Y. Only embedded should say N here.
513
514endmenu
515
516config ISA_DMA_API
517 bool
Stephen Rothwell373a6da2007-12-21 15:37:07 +1100518 default !PPC_ISERIES || PCI
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000519
520menu "Bus options"
521
522config ISA
523 bool "Support for ISA-bus hardware"
524 depends on PPC_PREP || PPC_CHRP
Paul Mackerrasf9bd1702005-10-26 16:47:42 +1000525 select PPC_I8259
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000526 help
527 Find out whether you have ISA slots on your motherboard. ISA is the
528 name of a bus system, i.e. the way the CPU talks to the other stuff
529 inside your box. If you have an Apple machine, say N here; if you
530 have an IBM RS/6000 or pSeries machine or a PReP machine, say Y. If
531 you have an embedded board, consult your board documentation.
532
Christoph Lameter5ac6da62007-02-10 01:43:14 -0800533config ZONE_DMA
534 bool
535 default y
536
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000537config GENERIC_ISA_DMA
538 bool
539 depends on PPC64 || POWER4 || 6xx && !CPM2
540 default y
541
Paul Mackerras25635c72005-10-26 16:36:55 +1000542config PPC_INDIRECT_PCI
543 bool
544 depends on PCI
Becky Bruce63dafe52006-01-14 16:57:39 -0600545 default y if 40x || 44x
Paul Mackerras25635c72005-10-26 16:36:55 +1000546 default n
547
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000548config EISA
549 bool
550
551config SBUS
552 bool
553
Kumar Gala08264cb2006-01-10 21:43:56 -0600554config FSL_SOC
555 bool
556
Roy Zang55c44992007-07-10 18:44:34 +0800557config FSL_PCI
558 bool
559 select PPC_INDIRECT_PCI
560
Stefan Roese2a706912008-03-26 22:39:50 +1100561config 4xx_SOC
562 bool
563
Anton Vorontsovacaa7aa2008-04-11 21:03:40 +0400564config FSL_LBC
565 bool
566 help
567 Freescale Localbus support
568
Anton Vorontsov83ff9dc2008-05-23 20:38:54 +0400569config FSL_GTM
570 bool
571 depends on PPC_83xx || QUICC_ENGINE || CPM2
572 help
573 Freescale General-purpose Timers support
574
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000575# Yes MCA RS/6000s exist but Linux-PPC does not currently support any
576config MCA
577 bool
578
John Rigbyb5005632008-06-26 11:07:56 -0600579# Platforms that what PCI turned unconditionally just do select PCI
580# in their config node. Platforms that want to choose at config
581# time should select PPC_PCI_CHOICE
582config PPC_PCI_CHOICE
583 bool
584
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000585config PCI
John Rigbyb5005632008-06-26 11:07:56 -0600586 bool "PCI support" if PPC_PCI_CHOICE
587 default y if !40x && !CPM2 && !8xx && !PPC_83xx \
Jon Loeliger53158622006-08-09 10:37:28 -0500588 && !PPC_85xx && !PPC_86xx
David Gibsonf21f49e2007-06-13 14:52:54 +1000589 default PCI_PERMEDIA if !4xx && !CPM2 && !8xx
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000590 default PCI_QSPAN if !4xx && !CPM2 && 8xx
Michael Ellermandf87ef52007-05-08 12:58:34 +1000591 select ARCH_SUPPORTS_MSI
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000592 help
593 Find out whether your system includes a PCI bus. PCI is the name of
594 a bus system, i.e. the way the CPU talks to the other stuff inside
595 your box. If you say Y here, the kernel will include drivers and
596 infrastructure code to support PCI bus devices.
597
598config PCI_DOMAINS
Matthew Wilcox36e23592007-07-10 10:54:40 -0600599 def_bool PCI
600
601config PCI_SYSCALL
602 def_bool PCI
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000603
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000604config PCI_QSPAN
605 bool "QSpan PCI"
606 depends on !4xx && !CPM2 && 8xx
Paul Mackerrasf9bd1702005-10-26 16:47:42 +1000607 select PPC_I8259
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000608 help
609 Say Y here if you have a system based on a Motorola 8xx-series
610 embedded processor with a QSPAN PCI interface, otherwise say N.
611
612config PCI_8260
613 bool
614 depends on PCI && 8260
Paul Mackerras25635c72005-10-26 16:36:55 +1000615 select PPC_INDIRECT_PCI
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000616 default y
617
618config 8260_PCI9
Andrew Morton4a3ecc62006-06-01 20:36:04 -0700619 bool "Enable workaround for MPC826x erratum PCI 9"
Scott Woode00c5492007-09-14 15:41:56 -0500620 depends on PCI_8260 && !8272
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000621 default y
622
623choice
Andrew Morton4a3ecc62006-06-01 20:36:04 -0700624 prompt "IDMA channel for PCI 9 workaround"
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000625 depends on 8260_PCI9
626
627config 8260_PCI9_IDMA1
628 bool "IDMA1"
629
630config 8260_PCI9_IDMA2
631 bool "IDMA2"
632
633config 8260_PCI9_IDMA3
634 bool "IDMA3"
635
636config 8260_PCI9_IDMA4
637 bool "IDMA4"
638
639endchoice
640
Jake Moilanenbb53bb32006-06-07 16:05:46 -0500641source "drivers/pci/pcie/Kconfig"
642
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000643source "drivers/pci/Kconfig"
644
645source "drivers/pcmcia/Kconfig"
646
647source "drivers/pci/hotplug/Kconfig"
648
Zhang Weif1f389d2008-04-18 13:33:39 -0700649config HAS_RAPIDIO
650 bool
651 default n
652
653config RAPIDIO
654 bool "RapidIO support"
655 depends on HAS_RAPIDIO
656 help
657 If you say Y here, the kernel will include drivers and
658 infrastructure code to support RapidIO interconnect devices.
659
660source "drivers/rapidio/Kconfig"
661
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000662endmenu
663
664menu "Advanced setup"
665 depends on PPC32
666
667config ADVANCED_OPTIONS
668 bool "Prompt for advanced kernel configuration options"
669 help
670 This option will enable prompting for a variety of advanced kernel
671 configuration options. These options can cause the kernel to not
672 work if they are set incorrectly, but can be used to optimize certain
673 aspects of kernel memory management.
674
675 Unless you know what you are doing, say N here.
676
677comment "Default settings for advanced configuration options are used"
678 depends on !ADVANCED_OPTIONS
679
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000680config LOWMEM_SIZE_BOOL
681 bool "Set maximum low memory"
682 depends on ADVANCED_OPTIONS
683 help
684 This option allows you to set the maximum amount of memory which
685 will be used as "low memory", that is, memory which the kernel can
686 access directly, without having to set up a kernel virtual mapping.
687 This can be useful in optimizing the layout of kernel virtual
688 memory.
689
690 Say N here unless you know what you are doing.
691
692config LOWMEM_SIZE
693 hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL
694 default "0x30000000"
695
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000696config RELOCATABLE
697 bool "Build a relocatable kernel (EXPERIMENTAL)"
698 depends on EXPERIMENTAL && ADVANCED_OPTIONS && FLATMEM && FSL_BOOKE
699 help
700 This builds a kernel image that is capable of running at the
701 location the kernel is loaded at (some alignment restrictions may
702 exist).
703
704 One use is for the kexec on panic case where the recovery kernel
705 must live at a different physical address than the primary
706 kernel.
707
708 Note: If CONFIG_RELOCATABLE=y, then the kernel runs from the address
709 it has been loaded at and the compile time physical addresses
710 CONFIG_PHYSICAL_START is ignored. However CONFIG_PHYSICAL_START
711 setting can still be useful to bootwrappers that need to know the
712 load location of the kernel (eg. u-boot/mkimage).
713
714config PAGE_OFFSET_BOOL
715 bool "Set custom page offset address"
716 depends on ADVANCED_OPTIONS
717 help
718 This option allows you to set the kernel virtual address at which
719 the kernel will map low memory. This can be useful in optimizing
720 the virtual memory layout of the system.
721
722 Say N here unless you know what you are doing.
723
724config PAGE_OFFSET
725 hex "Virtual address of memory base" if PAGE_OFFSET_BOOL
726 default "0xc0000000"
727
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000728config KERNEL_START_BOOL
729 bool "Set custom kernel base address"
730 depends on ADVANCED_OPTIONS
731 help
732 This option allows you to set the kernel virtual address at which
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000733 the kernel will be loaded. Normally this should match PAGE_OFFSET
734 however there are times (like kdump) that one might not want them
735 to be the same.
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000736
737 Say N here unless you know what you are doing.
738
739config KERNEL_START
740 hex "Virtual address of kernel base" if KERNEL_START_BOOL
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000741 default PAGE_OFFSET if PAGE_OFFSET_BOOL
742 default "0xc2000000" if CRASH_DUMP
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000743 default "0xc0000000"
744
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000745config PHYSICAL_START_BOOL
746 bool "Set physical address where the kernel is loaded"
747 depends on ADVANCED_OPTIONS && FLATMEM && FSL_BOOKE
748 help
749 This gives the physical address where the kernel is loaded.
750
751 Say N here unless you know what you are doing.
752
753config PHYSICAL_START
754 hex "Physical address where the kernel is loaded" if PHYSICAL_START_BOOL
755 default "0x02000000" if PPC_STD_MMU && CRASH_DUMP
756 default "0x00000000"
757
758config PHYSICAL_ALIGN
759 hex
760 default "0x10000000" if FSL_BOOKE
761 help
762 This value puts the alignment restrictions on physical address
763 where kernel is loaded and run from. Kernel is compiled for an
764 address which meets above alignment restriction.
765
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000766config TASK_SIZE_BOOL
767 bool "Set custom user task size"
768 depends on ADVANCED_OPTIONS
769 help
770 This option allows you to set the amount of virtual address space
771 allocated to user tasks. This can be useful in optimizing the
772 virtual memory layout of the system.
773
774 Say N here unless you know what you are doing.
775
776config TASK_SIZE
777 hex "Size of user task space" if TASK_SIZE_BOOL
Kumar Gala4d9e55102007-10-11 13:40:21 -0500778 default "0x80000000" if PPC_PREP || PPC_8xx
779 default "0xc0000000"
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000780
781config CONSISTENT_START_BOOL
782 bool "Set custom consistent memory pool address"
783 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
784 help
785 This option allows you to set the base virtual address
Matt LaPlante4b3f6862006-10-03 22:21:02 +0200786 of the consistent memory pool. This pool of virtual
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000787 memory is used to make consistent memory allocations.
788
789config CONSISTENT_START
790 hex "Base virtual address of consistent memory pool" if CONSISTENT_START_BOOL
Scott Woodccf0d682007-07-16 11:28:18 -0500791 default "0xfd000000" if (NOT_COHERENT_CACHE && 8xx)
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000792 default "0xff100000" if NOT_COHERENT_CACHE
793
794config CONSISTENT_SIZE_BOOL
795 bool "Set custom consistent memory pool size"
796 depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE
797 help
Matt LaPlante4b3f6862006-10-03 22:21:02 +0200798 This option allows you to set the size of the
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000799 consistent memory pool. This pool of virtual memory
800 is used to make consistent memory allocations.
801
802config CONSISTENT_SIZE
803 hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL
804 default "0x00200000" if NOT_COHERENT_CACHE
805
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000806config PIN_TLB
807 bool "Pinned Kernel TLBs (860 ONLY)"
808 depends on ADVANCED_OPTIONS && 8xx
809endmenu
810
Stephen Rothwellcabb5582005-09-30 16:16:52 +1000811if PPC64
Paul Mackerras549e8152008-08-30 11:43:47 +1000812config RELOCATABLE
813 bool "Build a relocatable kernel"
814 help
815 This builds a kernel image that is capable of running anywhere
816 in the RMA (real memory area) at any 16k-aligned base address.
817 The kernel is linked as a position-independent executable (PIE)
818 and contains dynamic relocations which are processed early
819 in the bootup process.
820
821 One use is for the kexec on panic case where the recovery kernel
822 must live at a different physical address than the primary
823 kernel.
824
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000825config PAGE_OFFSET
Stephen Rothwellcabb5582005-09-30 16:16:52 +1000826 hex
Stephen Rothwelleeb2d212005-09-30 17:24:15 +1000827 default "0xc000000000000000"
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000828config KERNEL_START
829 hex
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000830 default "0xc000000000000000"
831config PHYSICAL_START
832 hex
Kumar Gala37dd2ba2008-04-22 04:22:34 +1000833 default "0x00000000"
Stephen Rothwellcabb5582005-09-30 16:16:52 +1000834endif
835
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000836source "net/Kconfig"
837
838source "drivers/Kconfig"
839
840source "fs/Kconfig"
841
842# XXX source "arch/ppc/8xx_io/Kconfig"
843
844# XXX source "arch/ppc/8260_io/Kconfig"
845
Li Yang98658532006-10-03 23:10:46 -0500846source "arch/powerpc/sysdev/qe_lib/Kconfig"
847
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000848source "lib/Kconfig"
849
Paul Mackerras14cf11a2005-09-26 16:04:21 +1000850source "arch/powerpc/Kconfig.debug"
851
852source "security/Kconfig"
853
854config KEYS_COMPAT
855 bool
856 depends on COMPAT && KEYS
857 default y
858
859source "crypto/Kconfig"
Domen Puncer6f668282007-09-21 00:00:11 +1000860
861config PPC_CLOCK
862 bool
863 default n
David Brownell9483a572008-07-23 21:26:48 -0700864 select HAVE_CLK
Sylvain Munaut1088a202007-09-16 20:53:25 +1000865
866config PPC_LIB_RHEAP
867 bool
868
Hollis Blanchardbbf45ba2008-04-16 23:28:09 -0500869source "arch/powerpc/kvm/Kconfig"