| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 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 |  | 
| Arnd Bergmann | a0ae9c7 | 2007-06-13 02:30:17 +1000 | [diff] [blame] | 7 | source "arch/powerpc/platforms/Kconfig.cputype" | 
| Johannes Berg | 17e638b | 2007-03-19 11:53:53 +0100 | [diff] [blame] | 8 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 9 | config PPC32 | 
|  | 10 | bool | 
|  | 11 | default y if !PPC64 | 
|  | 12 |  | 
|  | 13 | config 64BIT | 
|  | 14 | bool | 
|  | 15 | default y if PPC64 | 
|  | 16 |  | 
| Stephen Rothwell | 2578bfa | 2007-09-21 10:16:20 +1000 | [diff] [blame] | 17 | config WORD_SIZE | 
|  | 18 | int | 
|  | 19 | default 64 if PPC64 | 
|  | 20 | default 32 if !PPC64 | 
|  | 21 |  | 
| Jeremy Fitzhardinge | 600715d | 2008-09-11 01:31:45 -0700 | [diff] [blame] | 22 | config ARCH_PHYS_ADDR_T_64BIT | 
|  | 23 | def_bool PPC64 || PHYS_64BIT | 
|  | 24 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 25 | config MMU | 
|  | 26 | bool | 
|  | 27 | default y | 
|  | 28 |  | 
| Tony Breeds | aa3be5f | 2007-09-21 13:26:02 +1000 | [diff] [blame] | 29 | config GENERIC_CMOS_UPDATE | 
|  | 30 | def_bool y | 
|  | 31 |  | 
| Tony Breeds | 4a4cfe3 | 2007-09-22 07:35:52 +1000 | [diff] [blame] | 32 | config GENERIC_TIME | 
|  | 33 | def_bool y | 
|  | 34 |  | 
|  | 35 | config GENERIC_TIME_VSYSCALL | 
|  | 36 | def_bool y | 
|  | 37 |  | 
| Tony Breeds | d831d0b | 2007-09-21 13:26:03 +1000 | [diff] [blame] | 38 | config GENERIC_CLOCKEVENTS | 
|  | 39 | def_bool y | 
|  | 40 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 41 | config GENERIC_HARDIRQS | 
|  | 42 | bool | 
|  | 43 | default y | 
|  | 44 |  | 
| Michael Ellerman | 8e27f4d | 2009-04-22 15:31:45 +0000 | [diff] [blame] | 45 | config GENERIC_HARDIRQS_NO__DO_IRQ | 
|  | 46 | bool | 
|  | 47 | default y | 
|  | 48 |  | 
| Tejun Heo | c2a7e81 | 2009-08-14 15:00:53 +0900 | [diff] [blame] | 49 | config HAVE_SETUP_PER_CPU_AREA | 
| Tejun Heo | e74e396 | 2009-03-30 19:07:44 +0900 | [diff] [blame] | 50 | def_bool PPC64 | 
|  | 51 |  | 
| Tejun Heo | c2a7e81 | 2009-08-14 15:00:53 +0900 | [diff] [blame] | 52 | config NEED_PER_CPU_EMBED_FIRST_CHUNK | 
| travis@sgi.com | b32ef63 | 2008-01-30 13:32:51 +0100 | [diff] [blame] | 53 | def_bool PPC64 | 
|  | 54 |  | 
| Ingo Molnar | 0d7012a | 2006-06-29 02:24:43 -0700 | [diff] [blame] | 55 | config IRQ_PER_CPU | 
|  | 56 | bool | 
|  | 57 | default y | 
|  | 58 |  | 
| Michael Ellerman | 551b81f | 2009-10-13 19:44:44 +0000 | [diff] [blame] | 59 | config NR_IRQS | 
|  | 60 | int "Number of virtual interrupt numbers" | 
|  | 61 | range 32 512 | 
|  | 62 | default "512" | 
|  | 63 | help | 
|  | 64 | This defines the number of virtual interrupt numbers the kernel | 
|  | 65 | can manage. Virtual interrupt numbers are what you see in | 
|  | 66 | /proc/interrupts. If you configure your system to have too few, | 
|  | 67 | drivers will fail to load or worse - handle with care. | 
|  | 68 |  | 
| Christoph Hellwig | fd3e0bb | 2008-04-17 14:35:00 +1000 | [diff] [blame] | 69 | config STACKTRACE_SUPPORT | 
|  | 70 | bool | 
|  | 71 | default y | 
|  | 72 |  | 
| Arnd Bergmann | 01f4b8b | 2008-07-11 00:08:18 +1000 | [diff] [blame] | 73 | config HAVE_LATENCYTOP_SUPPORT | 
|  | 74 | def_bool y | 
|  | 75 |  | 
| Benjamin Herrenschmidt | 945feb1 | 2008-04-17 14:35:01 +1000 | [diff] [blame] | 76 | config TRACE_IRQFLAGS_SUPPORT | 
|  | 77 | bool | 
| Benjamin Herrenschmidt | 945feb1 | 2008-04-17 14:35:01 +1000 | [diff] [blame] | 78 | default y | 
|  | 79 |  | 
|  | 80 | config LOCKDEP_SUPPORT | 
|  | 81 | bool | 
|  | 82 | default y | 
|  | 83 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 84 | config RWSEM_GENERIC_SPINLOCK | 
|  | 85 | bool | 
|  | 86 |  | 
|  | 87 | config RWSEM_XCHGADD_ALGORITHM | 
|  | 88 | bool | 
|  | 89 | default y | 
|  | 90 |  | 
| Nick Piggin | 95c354f | 2008-01-30 13:31:20 +0100 | [diff] [blame] | 91 | config GENERIC_LOCKBREAK | 
|  | 92 | bool | 
|  | 93 | default y | 
|  | 94 | depends on SMP && PREEMPT | 
|  | 95 |  | 
| David Howells | f0d1b0b | 2006-12-08 02:37:49 -0800 | [diff] [blame] | 96 | config ARCH_HAS_ILOG2_U32 | 
|  | 97 | bool | 
| David Howells | ef55d53 | 2006-12-08 02:37:53 -0800 | [diff] [blame] | 98 | default y | 
| David Howells | f0d1b0b | 2006-12-08 02:37:49 -0800 | [diff] [blame] | 99 |  | 
|  | 100 | config ARCH_HAS_ILOG2_U64 | 
|  | 101 | bool | 
| David Howells | ef55d53 | 2006-12-08 02:37:53 -0800 | [diff] [blame] | 102 | default y if 64BIT | 
| David Howells | f0d1b0b | 2006-12-08 02:37:49 -0800 | [diff] [blame] | 103 |  | 
| Akinobu Mita | e779b2f | 2006-03-26 01:39:33 -0800 | [diff] [blame] | 104 | config GENERIC_HWEIGHT | 
|  | 105 | bool | 
|  | 106 | default y | 
|  | 107 |  | 
| Jon Mason | 0a9cb46 | 2006-05-19 15:35:32 -0500 | [diff] [blame] | 108 | config GENERIC_FIND_NEXT_BIT | 
|  | 109 | bool | 
|  | 110 | default y | 
|  | 111 |  | 
| Anton Vorontsov | b7ce341 | 2008-04-11 23:06:36 +1000 | [diff] [blame] | 112 | config GENERIC_GPIO | 
|  | 113 | bool | 
|  | 114 | help | 
|  | 115 | Generic GPIO API support | 
|  | 116 |  | 
| Stephen Rothwell | f057eac | 2007-07-15 23:40:05 -0700 | [diff] [blame] | 117 | config ARCH_NO_VIRT_TO_BUS | 
|  | 118 | def_bool PPC64 | 
|  | 119 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 120 | config PPC | 
|  | 121 | bool | 
|  | 122 | default y | 
| Steven Rostedt | 2b79d69 | 2009-01-06 18:49:17 +0000 | [diff] [blame] | 123 | select HAVE_FTRACE_MCOUNT_RECORD | 
|  | 124 | select HAVE_DYNAMIC_FTRACE | 
| Steven Rostedt | 606576c | 2008-10-06 19:06:12 -0400 | [diff] [blame] | 125 | select HAVE_FUNCTION_TRACER | 
| Steven Rostedt | 60ce8f7 | 2009-02-11 20:06:43 -0500 | [diff] [blame] | 126 | select HAVE_FUNCTION_GRAPH_TRACER | 
| Michael Buesch | 7444a72 | 2008-07-25 01:46:11 -0700 | [diff] [blame] | 127 | select ARCH_WANT_OPTIONAL_GPIOLIB | 
| Sam Ravnborg | ec7748b | 2008-02-09 10:46:40 +0100 | [diff] [blame] | 128 | select HAVE_IDE | 
| Benjamin Herrenschmidt | a1f242f | 2008-07-23 21:27:08 -0700 | [diff] [blame] | 129 | select HAVE_IOREMAP_PROT | 
| Johannes Berg | 58340a0 | 2008-07-25 01:45:33 -0700 | [diff] [blame] | 130 | select HAVE_EFFICIENT_UNALIGNED_ACCESS | 
| Mathieu Desnoyers | 3f55009 | 2008-02-02 15:10:35 -0500 | [diff] [blame] | 131 | select HAVE_KPROBES | 
| Jason Wessel | 17ce452 | 2008-07-23 11:30:15 -0500 | [diff] [blame] | 132 | select HAVE_ARCH_KGDB | 
| Ananth N Mavinakayanahalli | 9edddaa | 2008-03-04 14:28:37 -0800 | [diff] [blame] | 133 | select HAVE_KRETPROBES | 
| Roland McGrath | dec2b0d | 2008-07-27 16:53:20 +1000 | [diff] [blame] | 134 | select HAVE_ARCH_TRACEHOOK | 
| David S. Miller | d9b2b2a | 2008-02-13 16:56:49 -0800 | [diff] [blame] | 135 | select HAVE_LMB | 
| FUJITA Tomonori | 46bab4e | 2009-08-04 19:08:26 +0000 | [diff] [blame] | 136 | select HAVE_DMA_ATTRS | 
| FUJITA Tomonori | 80d3e8a | 2009-08-04 19:08:28 +0000 | [diff] [blame] | 137 | select HAVE_DMA_API_DEBUG | 
| Jens Axboe | b7d7a24 | 2008-06-26 11:22:13 +0200 | [diff] [blame] | 138 | select USE_GENERIC_SMP_HELPERS if SMP | 
| Steven Rostedt | 4e491d1 | 2008-05-14 23:49:44 -0400 | [diff] [blame] | 139 | select HAVE_OPROFILE | 
| Benjamin Herrenschmidt | ee6a093 | 2009-01-14 14:14:00 +0100 | [diff] [blame] | 140 | select HAVE_SYSCALL_WRAPPERS if PPC64 | 
| Paul Mackerras | c2e95c6 | 2009-06-12 21:10:41 +0000 | [diff] [blame] | 141 | select GENERIC_ATOMIC64 if PPC32 | 
| Ingo Molnar | cdd6c48 | 2009-09-21 12:02:48 +0200 | [diff] [blame] | 142 | select HAVE_PERF_EVENTS | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 143 |  | 
|  | 144 | config EARLY_PRINTK | 
|  | 145 | bool | 
| Benjamin Herrenschmidt | 51d3082 | 2005-11-23 17:57:25 +1100 | [diff] [blame] | 146 | default y | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 147 |  | 
|  | 148 | config COMPAT | 
|  | 149 | bool | 
|  | 150 | default y if PPC64 | 
| Roland McGrath | 01e31db | 2008-01-02 17:03:11 -0800 | [diff] [blame] | 151 | select COMPAT_BINFMT_ELF | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 152 |  | 
|  | 153 | config SYSVIPC_COMPAT | 
|  | 154 | bool | 
|  | 155 | depends on COMPAT && SYSVIPC | 
|  | 156 | default y | 
|  | 157 |  | 
|  | 158 | # All PPC32s use generic nvram driver through ppc_md | 
|  | 159 | config GENERIC_NVRAM | 
|  | 160 | bool | 
|  | 161 | default y if PPC32 | 
|  | 162 |  | 
| Ingo Molnar | ae1e913 | 2008-11-11 09:05:16 +0100 | [diff] [blame] | 163 | config SCHED_OMIT_FRAME_POINTER | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 164 | bool | 
|  | 165 | default y | 
|  | 166 |  | 
|  | 167 | config ARCH_MAY_HAVE_PC_FDC | 
|  | 168 | bool | 
| Stephen Rothwell | bed5927 | 2007-03-04 17:04:44 +1100 | [diff] [blame] | 169 | default !PPC_PSERIES || PCI | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 170 |  | 
| Kumar Gala | 08264cb | 2006-01-10 21:43:56 -0600 | [diff] [blame] | 171 | config PPC_OF | 
|  | 172 | def_bool y | 
|  | 173 |  | 
| Stephen Rothwell | 97e873e | 2007-05-01 16:26:07 +1000 | [diff] [blame] | 174 | config OF | 
|  | 175 | def_bool y | 
|  | 176 |  | 
| Kumar Gala | 08264cb | 2006-01-10 21:43:56 -0600 | [diff] [blame] | 177 | config PPC_UDBG_16550 | 
|  | 178 | bool | 
|  | 179 | default n | 
|  | 180 |  | 
| Kumar Gala | 08264cb | 2006-01-10 21:43:56 -0600 | [diff] [blame] | 181 | config GENERIC_TBSYNC | 
|  | 182 | bool | 
|  | 183 | default y if PPC32 && SMP | 
|  | 184 | default n | 
|  | 185 |  | 
| Al Viro | e65e1fc | 2006-09-12 03:04:40 -0400 | [diff] [blame] | 186 | config AUDIT_ARCH | 
|  | 187 | bool | 
|  | 188 | default y | 
|  | 189 |  | 
| Jeremy Fitzhardinge | 73c9cea | 2006-12-08 03:30:41 -0800 | [diff] [blame] | 190 | config GENERIC_BUG | 
|  | 191 | bool | 
|  | 192 | default y | 
|  | 193 | depends on BUG | 
|  | 194 |  | 
| Johannes Berg | b302887 | 2007-03-20 05:18:02 +1100 | [diff] [blame] | 195 | config SYS_SUPPORTS_APM_EMULATION | 
| Kumar Gala | 58da10b | 2007-05-23 09:51:46 -0500 | [diff] [blame] | 196 | default y if PMAC_APM_EMU | 
| Johannes Berg | b302887 | 2007-03-20 05:18:02 +1100 | [diff] [blame] | 197 | bool | 
|  | 198 |  | 
| David Gibson | 9fffb55 | 2009-04-30 15:25:53 +1000 | [diff] [blame] | 199 | config DTC | 
|  | 200 | bool | 
|  | 201 | default y | 
|  | 202 |  | 
| Kumar Gala | f4fc4a5 | 2006-01-16 10:53:22 -0600 | [diff] [blame] | 203 | config DEFAULT_UIMAGE | 
|  | 204 | bool | 
|  | 205 | help | 
|  | 206 | Used to allow a board to specify it wants a uImage built by default | 
|  | 207 | default n | 
|  | 208 |  | 
| Scott Wood | b09c164 | 2008-01-17 16:31:40 -0600 | [diff] [blame] | 209 | config REDBOOT | 
|  | 210 | bool | 
|  | 211 |  | 
| Johannes Berg | 801e406 | 2007-12-08 02:12:39 +0100 | [diff] [blame] | 212 | config ARCH_HIBERNATION_POSSIBLE | 
|  | 213 | bool | 
| Johannes Berg | 543b9fd | 2007-05-03 22:31:38 +1000 | [diff] [blame] | 214 | default y | 
|  | 215 |  | 
| Johannes Berg | f4cb570 | 2007-12-08 02:14:00 +0100 | [diff] [blame] | 216 | config ARCH_SUSPEND_POSSIBLE | 
|  | 217 | def_bool y | 
| Scott Wood | d49747b | 2007-10-09 12:37:13 -0500 | [diff] [blame] | 218 | depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 || PPC_83xx | 
| Johannes Berg | f4cb570 | 2007-12-08 02:14:00 +0100 | [diff] [blame] | 219 |  | 
| Benjamin Herrenschmidt | 4c75a6f | 2006-11-11 17:24:53 +1100 | [diff] [blame] | 220 | config PPC_DCR_NATIVE | 
|  | 221 | bool | 
|  | 222 | default n | 
|  | 223 |  | 
|  | 224 | config PPC_DCR_MMIO | 
|  | 225 | bool | 
|  | 226 | default n | 
|  | 227 |  | 
|  | 228 | config PPC_DCR | 
|  | 229 | bool | 
|  | 230 | depends on PPC_DCR_NATIVE || PPC_DCR_MMIO | 
|  | 231 | default y | 
|  | 232 |  | 
| Benjamin Herrenschmidt | 4c9d280 | 2006-11-11 17:25:08 +1100 | [diff] [blame] | 233 | config PPC_OF_PLATFORM_PCI | 
|  | 234 | bool | 
| Stephen Rothwell | 373a6da | 2007-12-21 15:37:07 +1100 | [diff] [blame] | 235 | depends on PCI | 
| Benjamin Herrenschmidt | 4c9d280 | 2006-11-11 17:25:08 +1100 | [diff] [blame] | 236 | depends on PPC64 # not supported on 32 bits yet | 
|  | 237 | default n | 
|  | 238 |  | 
| Akinobu Mita | 6a11f75 | 2009-03-31 15:23:17 -0700 | [diff] [blame] | 239 | config ARCH_SUPPORTS_DEBUG_PAGEALLOC | 
|  | 240 | def_bool y | 
|  | 241 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 242 | source "init/Kconfig" | 
|  | 243 |  | 
| Matt Helsley | dc52ddc | 2008-10-18 20:27:21 -0700 | [diff] [blame] | 244 | source "kernel/Kconfig.freezer" | 
|  | 245 |  | 
| Benjamin Herrenschmidt | a2d2e1e | 2007-12-21 15:39:24 +1100 | [diff] [blame] | 246 | source "arch/powerpc/sysdev/Kconfig" | 
| Kumar Gala | 4330f5d | 2007-03-16 09:32:17 -0500 | [diff] [blame] | 247 | source "arch/powerpc/platforms/Kconfig" | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 248 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 249 | menu "Kernel options" | 
|  | 250 |  | 
|  | 251 | config HIGHMEM | 
|  | 252 | bool "High memory support" | 
|  | 253 | depends on PPC32 | 
|  | 254 |  | 
| Tony Breeds | 1ad7499 | 2007-09-21 13:26:03 +1000 | [diff] [blame] | 255 | source kernel/time/Kconfig | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 256 | source kernel/Kconfig.hz | 
|  | 257 | source kernel/Kconfig.preempt | 
|  | 258 | source "fs/Kconfig.binfmt" | 
|  | 259 |  | 
| Mel Gorman | ba72cb8 | 2007-11-28 16:21:13 -0800 | [diff] [blame] | 260 | config HUGETLB_PAGE_SIZE_VARIABLE | 
|  | 261 | bool | 
|  | 262 | depends on HUGETLB_PAGE | 
|  | 263 | default y | 
|  | 264 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 265 | config MATH_EMULATION | 
|  | 266 | bool "Math emulation" | 
| Kumar Gala | 4d52719 | 2007-01-26 00:23:34 -0600 | [diff] [blame] | 267 | depends on 4xx || 8xx || E200 || PPC_MPC832x || E500 | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 268 | ---help--- | 
|  | 269 | Some PowerPC chips designed for embedded applications do not have | 
|  | 270 | a floating-point unit and therefore do not implement the | 
|  | 271 | floating-point instructions in the PowerPC instruction set.  If you | 
|  | 272 | say Y here, the kernel will include code to emulate a floating-point | 
|  | 273 | unit, which will allow programs that use floating-point | 
|  | 274 | instructions to run. | 
|  | 275 |  | 
| Scott Wood | 5dd57a1 | 2007-09-18 15:29:35 -0500 | [diff] [blame] | 276 | config 8XX_MINIMAL_FPEMU | 
|  | 277 | bool "Minimal math emulation for 8xx" | 
|  | 278 | depends on 8xx && !MATH_EMULATION | 
|  | 279 | help | 
|  | 280 | Older arch/ppc kernels still emulated a few floating point | 
|  | 281 | instructions such as load and store, even when full math | 
|  | 282 | emulation is disabled.  Say "Y" here if you want to preserve | 
|  | 283 | this behavior. | 
|  | 284 |  | 
|  | 285 | It is recommended that you build a soft-float userspace instead. | 
|  | 286 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 287 | config IOMMU_VMERGE | 
| Linas Vepstas | 768cc2d | 2007-07-18 02:09:35 +1000 | [diff] [blame] | 288 | bool "Enable IOMMU virtual merging" | 
|  | 289 | depends on PPC64 | 
|  | 290 | default y | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 291 | help | 
|  | 292 | Cause IO segments sent to a device for DMA to be merged virtually | 
|  | 293 | by the IOMMU when they happen to have been allocated contiguously. | 
|  | 294 | This doesn't add pressure to the IOMMU allocator. However, some | 
|  | 295 | drivers don't support getting large merged segments coming back | 
| Linas Vepstas | 768cc2d | 2007-07-18 02:09:35 +1000 | [diff] [blame] | 296 | from *_map_sg(). | 
|  | 297 |  | 
|  | 298 | Most drivers don't have this problem; it is safe to say Y here. | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 299 |  | 
| FUJITA Tomonori | fb3475e | 2008-02-04 22:28:08 -0800 | [diff] [blame] | 300 | config IOMMU_HELPER | 
|  | 301 | def_bool PPC64 | 
|  | 302 |  | 
| Becky Bruce | ec3cf2e | 2009-05-14 12:42:28 +0000 | [diff] [blame] | 303 | config SWIOTLB | 
|  | 304 | bool "SWIOTLB support" | 
|  | 305 | default n | 
|  | 306 | select IOMMU_HELPER | 
|  | 307 | ---help--- | 
|  | 308 | Support for IO bounce buffering for systems without an IOMMU. | 
|  | 309 | This allows us to DMA to the full physical address space on | 
|  | 310 | platforms where the size of a physical address is larger | 
|  | 311 | than the bus address.  Not all platforms support this. | 
|  | 312 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 313 | config HOTPLUG_CPU | 
|  | 314 | bool "Support for enabling/disabling CPUs" | 
|  | 315 | depends on SMP && HOTPLUG && EXPERIMENTAL && (PPC_PSERIES || PPC_PMAC) | 
|  | 316 | ---help--- | 
|  | 317 | Say Y here to be able to disable and re-enable individual | 
|  | 318 | CPUs at runtime on SMP machines. | 
|  | 319 |  | 
|  | 320 | Say N if you are unsure. | 
|  | 321 |  | 
| Yasunori Goto | cc57637 | 2006-06-29 02:24:27 -0700 | [diff] [blame] | 322 | config ARCH_ENABLE_MEMORY_HOTPLUG | 
|  | 323 | def_bool y | 
|  | 324 |  | 
| Badari Pulavarty | a99824f | 2008-02-05 00:10:18 -0800 | [diff] [blame] | 325 | config ARCH_HAS_WALK_MEMORY | 
|  | 326 | def_bool y | 
|  | 327 |  | 
| Badari Pulavarty | 1482471 | 2008-02-05 00:10:17 -0800 | [diff] [blame] | 328 | config ARCH_ENABLE_MEMORY_HOTREMOVE | 
|  | 329 | def_bool y | 
|  | 330 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 331 | config KEXEC | 
|  | 332 | bool "kexec system call (EXPERIMENTAL)" | 
| Geert Uytterhoeven | cb93d56 | 2009-04-02 06:25:41 +0000 | [diff] [blame] | 333 | depends on PPC_BOOK3S && EXPERIMENTAL | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 334 | help | 
|  | 335 | kexec is a system call that implements the ability to shutdown your | 
|  | 336 | current kernel, and to start another kernel.  It is like a reboot | 
| Matt LaPlante | 1f1332f | 2006-06-29 01:32:47 -0400 | [diff] [blame] | 337 | but it is independent of the system firmware.   And like a reboot | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 338 | you can start any kernel with it, not just Linux. | 
|  | 339 |  | 
| Matt LaPlante | 1f1332f | 2006-06-29 01:32:47 -0400 | [diff] [blame] | 340 | The name comes from the similarity to the exec system call. | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 341 |  | 
|  | 342 | It is an ongoing process to be certain the hardware in a machine | 
|  | 343 | is properly shutdown, so do not be surprised if this code does not | 
|  | 344 | initially work for you.  It may help to enable device hotplugging | 
|  | 345 | support.  As of this writing the exact hardware interface is | 
|  | 346 | strongly in flux, so no good recommendation can be made. | 
|  | 347 |  | 
| Haren Myneni | e8625d46 | 2006-01-14 13:48:25 -0800 | [diff] [blame] | 348 | config CRASH_DUMP | 
| Bernhard Walle | 3420b5d | 2008-06-27 03:02:15 +1000 | [diff] [blame] | 349 | bool "Build a kdump crash kernel" | 
| Mohan Kumar M | c6ac71a | 2009-01-06 00:23:01 +0000 | [diff] [blame] | 350 | depends on PPC64 || 6xx | 
|  | 351 | select RELOCATABLE if PPC64 | 
| Haren Myneni | e8625d46 | 2006-01-14 13:48:25 -0800 | [diff] [blame] | 352 | help | 
|  | 353 | Build a kernel suitable for use as a kdump capture kernel. | 
| Mohan Kumar M | 54622f1 | 2008-10-21 17:38:10 +0000 | [diff] [blame] | 354 | The same kernel binary can be used as production kernel and dump | 
|  | 355 | capture kernel. | 
| Haren Myneni | e8625d46 | 2006-01-14 13:48:25 -0800 | [diff] [blame] | 356 |  | 
| Manish Ahuja | 242f271 | 2008-03-22 10:50:50 +1100 | [diff] [blame] | 357 | config PHYP_DUMP | 
|  | 358 | bool "Hypervisor-assisted dump (EXPERIMENTAL)" | 
|  | 359 | depends on PPC_PSERIES && EXPERIMENTAL | 
|  | 360 | help | 
|  | 361 | Hypervisor-assisted dump is meant to be a kdump replacement | 
|  | 362 | offering robustness and speed not possible without system | 
| Matt LaPlante | 692105b | 2009-01-26 11:12:25 +0100 | [diff] [blame] | 363 | hypervisor assistance. | 
| Manish Ahuja | 242f271 | 2008-03-22 10:50:50 +1100 | [diff] [blame] | 364 |  | 
|  | 365 | If unsure, say "N" | 
|  | 366 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 367 | config PPCBUG_NVRAM | 
|  | 368 | bool "Enable reading PPCBUG NVRAM during boot" if PPLUS || LOPEC | 
|  | 369 | default y if PPC_PREP | 
|  | 370 |  | 
|  | 371 | config IRQ_ALL_CPUS | 
|  | 372 | bool "Distribute interrupts on all CPUs by default" | 
|  | 373 | depends on SMP && !MV64360 | 
|  | 374 | help | 
|  | 375 | This option gives the kernel permission to distribute IRQs across | 
|  | 376 | multiple CPUs.  Saying N here will route all IRQs to the first | 
|  | 377 | CPU.  Generally saying Y is safe, although some problems have been | 
|  | 378 | reported with SMP Power Macintoshes with this option enabled. | 
|  | 379 |  | 
| Michael Ellerman | cd01570 | 2009-10-13 19:45:03 +0000 | [diff] [blame^] | 380 | config SPARSE_IRQ | 
|  | 381 | bool "Support sparse irq numbering" | 
|  | 382 | default y | 
|  | 383 | help | 
|  | 384 | This enables support for sparse irqs. This is useful for distro | 
|  | 385 | kernels that want to define a high CONFIG_NR_CPUS value but still | 
|  | 386 | want to have low kernel memory footprint on smaller machines. | 
|  | 387 |  | 
|  | 388 | ( Sparse IRQs can also be beneficial on NUMA boxes, as they spread | 
|  | 389 | out the irq_desc[] array in a more NUMA-friendly way. ) | 
|  | 390 |  | 
|  | 391 | If you don't know what to do here, say Y. | 
|  | 392 |  | 
| Andy Whitcroft | ffa27b6 | 2005-10-28 17:46:58 -0700 | [diff] [blame] | 393 | config NUMA | 
|  | 394 | bool "NUMA support" | 
|  | 395 | depends on PPC64 | 
|  | 396 | default y if SMP && PPC_PSERIES | 
|  | 397 |  | 
| Yasunori Goto | c80d79d | 2006-04-10 22:53:53 -0700 | [diff] [blame] | 398 | config NODES_SHIFT | 
|  | 399 | int | 
| Anton Blanchard | ea55bf2 | 2009-09-21 19:56:43 +0000 | [diff] [blame] | 400 | default "8" if PPC64 | 
| Yasunori Goto | c80d79d | 2006-04-10 22:53:53 -0700 | [diff] [blame] | 401 | default "4" | 
|  | 402 | depends on NEED_MULTIPLE_NODES | 
|  | 403 |  | 
| Anton Blanchard | ea55bf2 | 2009-09-21 19:56:43 +0000 | [diff] [blame] | 404 | config MAX_ACTIVE_REGIONS | 
|  | 405 | int | 
|  | 406 | default "256" if PPC64 | 
|  | 407 | default "32" | 
|  | 408 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 409 | config ARCH_SELECT_MEMORY_MODEL | 
|  | 410 | def_bool y | 
|  | 411 | depends on PPC64 | 
|  | 412 |  | 
|  | 413 | config ARCH_FLATMEM_ENABLE | 
| Andy Whitcroft | 9100b20 | 2005-11-29 19:20:55 +0000 | [diff] [blame] | 414 | def_bool y | 
|  | 415 | depends on (PPC64 && !NUMA) || PPC32 | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 416 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 417 | config ARCH_SPARSEMEM_ENABLE | 
|  | 418 | def_bool y | 
| Andy Whitcroft | 9100b20 | 2005-11-29 19:20:55 +0000 | [diff] [blame] | 419 | depends on PPC64 | 
| Andy Whitcroft | d29eff7 | 2007-10-16 01:24:17 -0700 | [diff] [blame] | 420 | select SPARSEMEM_VMEMMAP_ENABLE | 
| Anton Blanchard | 45fb6ce | 2005-11-11 14:22:35 +1100 | [diff] [blame] | 421 |  | 
|  | 422 | config ARCH_SPARSEMEM_DEFAULT | 
|  | 423 | def_bool y | 
| Benjamin Herrenschmidt | 78bde53 | 2007-02-13 11:46:06 +1100 | [diff] [blame] | 424 | depends on (SMP && PPC_PSERIES) || PPC_PS3 | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 425 |  | 
| Mel Gorman | c67c3cb | 2006-09-27 01:49:49 -0700 | [diff] [blame] | 426 | config ARCH_POPULATES_NODE_MAP | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 427 | def_bool y | 
| Mel Gorman | c67c3cb | 2006-09-27 01:49:49 -0700 | [diff] [blame] | 428 |  | 
| Benjamin Herrenschmidt | 5a1eb5c | 2009-10-30 15:03:54 +1100 | [diff] [blame] | 429 | config SYS_SUPPORTS_HUGETLBFS | 
|  | 430 | def_bool y | 
|  | 431 | depends on PPC_BOOK3S_64 | 
|  | 432 |  | 
| Mel Gorman | c67c3cb | 2006-09-27 01:49:49 -0700 | [diff] [blame] | 433 | source "mm/Kconfig" | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 434 |  | 
| Mike Kravetz | 7e9191d | 2005-11-07 09:39:48 -0800 | [diff] [blame] | 435 | config ARCH_MEMORY_PROBE | 
|  | 436 | def_bool y | 
|  | 437 | depends on MEMORY_HOTPLUG | 
|  | 438 |  | 
| Andy Whitcroft | 7516795 | 2006-10-21 10:24:14 -0700 | [diff] [blame] | 439 | # Some NUMA nodes have memory ranges that span | 
|  | 440 | # other nodes.  Even though a pfn is valid and | 
|  | 441 | # between a node's start and end pfns, it may not | 
|  | 442 | # reside on that node.  See memmap_init_zone() | 
|  | 443 | # for details. | 
|  | 444 | config NODES_SPAN_OTHER_NODES | 
|  | 445 | def_bool y | 
|  | 446 | depends on NEED_MULTIPLE_NODES | 
|  | 447 |  | 
| Benjamin Herrenschmidt | 16c2d47 | 2007-05-08 16:27:28 +1000 | [diff] [blame] | 448 | config PPC_HAS_HASH_64K | 
|  | 449 | bool | 
|  | 450 | depends on PPC64 | 
|  | 451 | default n | 
|  | 452 |  | 
| Yuri Tikhonov | e124012 | 2009-01-29 01:40:44 +0000 | [diff] [blame] | 453 | config STDBINUTILS | 
|  | 454 | bool "Using standard binutils settings" | 
|  | 455 | depends on 44x | 
|  | 456 | default y | 
|  | 457 | help | 
|  | 458 | Turning this option off allows you to select 256KB PAGE_SIZE on 44x. | 
|  | 459 | Note, that kernel will be able to run only those applications, | 
|  | 460 | which had been compiled using binutils later than 2.17.50.0.3 with | 
|  | 461 | '-zmax-page-size' set to 256K (the default is 64K). Or, if using | 
|  | 462 | the older binutils, you can patch them with a trivial patch, which | 
|  | 463 | changes the ELF_MAXPAGESIZE definition from 0x10000 to 0x40000. | 
|  | 464 |  | 
| Ilya Yanok | ca9153a | 2008-12-11 04:55:41 +0300 | [diff] [blame] | 465 | choice | 
|  | 466 | prompt "Page size" | 
|  | 467 | default PPC_4K_PAGES | 
| Benjamin Herrenschmidt | 3c726f8 | 2005-11-07 11:06:55 +1100 | [diff] [blame] | 468 | help | 
| Ilya Yanok | ca9153a | 2008-12-11 04:55:41 +0300 | [diff] [blame] | 469 | Select the kernel logical page size. Increasing the page size | 
|  | 470 | will reduce software overhead at each page boundary, allow | 
|  | 471 | hardware prefetch mechanisms to be more effective, and allow | 
|  | 472 | larger dma transfers increasing IO efficiency and reducing | 
|  | 473 | overhead. However the utilization of memory will increase. | 
|  | 474 | For example, each cached file will using a multiple of the | 
|  | 475 | page size to hold its contents and the difference between the | 
|  | 476 | end of file and the end of page is wasted. | 
|  | 477 |  | 
|  | 478 | Some dedicated systems, such as software raid serving with | 
|  | 479 | accelerated calculations, have shown significant increases. | 
|  | 480 |  | 
|  | 481 | If you configure a 64 bit kernel for 64k pages but the | 
|  | 482 | processor does not support them, then the kernel will simulate | 
|  | 483 | them with 4k pages, loading them on demand, but with the | 
|  | 484 | reduced software overhead and larger internal fragmentation. | 
|  | 485 | For the 32 bit kernel, a large page option will not be offered | 
|  | 486 | unless it is supported by the configured processor. | 
|  | 487 |  | 
|  | 488 | If unsure, choose 4K_PAGES. | 
|  | 489 |  | 
|  | 490 | config PPC_4K_PAGES | 
|  | 491 | bool "4k page size" | 
|  | 492 |  | 
|  | 493 | config PPC_16K_PAGES | 
|  | 494 | bool "16k page size" if 44x | 
|  | 495 |  | 
|  | 496 | config PPC_64K_PAGES | 
| Benjamin Herrenschmidt | 2d27cfd | 2009-07-23 23:15:59 +0000 | [diff] [blame] | 497 | bool "64k page size" if 44x || PPC_STD_MMU_64 || PPC_BOOK3E_64 | 
| Ilya Yanok | ca9153a | 2008-12-11 04:55:41 +0300 | [diff] [blame] | 498 | select PPC_HAS_HASH_64K if PPC_STD_MMU_64 | 
|  | 499 |  | 
| Yuri Tikhonov | e124012 | 2009-01-29 01:40:44 +0000 | [diff] [blame] | 500 | config PPC_256K_PAGES | 
|  | 501 | bool "256k page size" if 44x | 
| Hugh Dickins | adf213c | 2009-04-06 11:01:15 +0000 | [diff] [blame] | 502 | depends on !STDBINUTILS | 
| Yuri Tikhonov | e124012 | 2009-01-29 01:40:44 +0000 | [diff] [blame] | 503 | help | 
|  | 504 | Make the page size 256k. | 
|  | 505 |  | 
|  | 506 | As the ELF standard only requires alignment to support page | 
|  | 507 | sizes up to 64k, you will need to compile all of your user | 
|  | 508 | space applications with a non-standard binutils settings | 
|  | 509 | (see the STDBINUTILS description for details). | 
|  | 510 |  | 
|  | 511 | Say N unless you know what you are doing. | 
|  | 512 |  | 
| Ilya Yanok | ca9153a | 2008-12-11 04:55:41 +0300 | [diff] [blame] | 513 | endchoice | 
| Benjamin Herrenschmidt | 3c726f8 | 2005-11-07 11:06:55 +1100 | [diff] [blame] | 514 |  | 
| Stephen Rothwell | 53bcddb | 2008-04-11 11:11:56 +1000 | [diff] [blame] | 515 | config FORCE_MAX_ZONEORDER | 
|  | 516 | int "Maximum zone order" | 
| Benjamin Herrenschmidt | 066c4b8 | 2009-07-21 15:25:53 +0000 | [diff] [blame] | 517 | range 9 64 if PPC64 && PPC_64K_PAGES | 
|  | 518 | default "9" if PPC64 && PPC_64K_PAGES | 
|  | 519 | range 13 64 if PPC64 && !PPC_64K_PAGES | 
|  | 520 | default "13" if PPC64 && !PPC_64K_PAGES | 
|  | 521 | range 9 64 if PPC32 && PPC_16K_PAGES | 
|  | 522 | default "9" if PPC32 && PPC_16K_PAGES | 
|  | 523 | range 7 64 if PPC32 && PPC_64K_PAGES | 
|  | 524 | default "7" if PPC32 && PPC_64K_PAGES | 
|  | 525 | range 5 64 if PPC32 && PPC_256K_PAGES | 
|  | 526 | default "5" if PPC32 && PPC_256K_PAGES | 
| Johannes Berg | ebe40c5 | 2008-09-24 04:29:08 +0000 | [diff] [blame] | 527 | range 11 64 | 
| Stephen Rothwell | 53bcddb | 2008-04-11 11:11:56 +1000 | [diff] [blame] | 528 | default "11" | 
|  | 529 | help | 
|  | 530 | The kernel memory allocator divides physically contiguous memory | 
|  | 531 | blocks into "zones", where each zone is a power of two number of | 
|  | 532 | pages.  This option selects the largest power of two that the kernel | 
|  | 533 | keeps in the memory allocator.  If you need to allocate very large | 
|  | 534 | blocks of physically contiguous memory, then you may need to | 
|  | 535 | increase this value. | 
|  | 536 |  | 
|  | 537 | This config option is actually maximum order plus one. For example, | 
|  | 538 | a value of 11 means that the largest free memory block is 2^10 pages. | 
|  | 539 |  | 
|  | 540 | The page size is not necessarily 4KB.  For example, on 64-bit | 
|  | 541 | systems, 64KB pages can be enabled via CONFIG_PPC_64K_PAGES.  Keep | 
|  | 542 | this in mind when choosing a value for this option. | 
|  | 543 |  | 
| Paul Mackerras | fa28237 | 2008-01-24 08:35:13 +1100 | [diff] [blame] | 544 | config PPC_SUBPAGE_PROT | 
|  | 545 | bool "Support setting protections for 4k subpages" | 
| Ilya Yanok | ca9153a | 2008-12-11 04:55:41 +0300 | [diff] [blame] | 546 | depends on PPC_STD_MMU_64 && PPC_64K_PAGES | 
| Paul Mackerras | fa28237 | 2008-01-24 08:35:13 +1100 | [diff] [blame] | 547 | help | 
|  | 548 | This option adds support for a system call to allow user programs | 
|  | 549 | to set access permissions (read/write, readonly, or no access) | 
|  | 550 | on the 4k subpages of each 64k page. | 
|  | 551 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 552 | config SCHED_SMT | 
|  | 553 | bool "SMT (Hyperthreading) scheduler support" | 
|  | 554 | depends on PPC64 && SMP | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 555 | help | 
|  | 556 | SMT scheduler support improves the CPU scheduler's decision making | 
|  | 557 | when dealing with POWER5 cpus at a cost of slightly increased | 
|  | 558 | overhead in some places. If unsure say N here. | 
|  | 559 |  | 
|  | 560 | config PROC_DEVICETREE | 
| Paul Mackerras | 5f29675 | 2005-10-17 20:14:59 +1000 | [diff] [blame] | 561 | bool "Support for device tree in /proc" | 
|  | 562 | depends on PROC_FS | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 563 | help | 
|  | 564 | This option adds a device-tree directory under /proc which contains | 
|  | 565 | an image of the device tree that the kernel copies from Open | 
| Paul Mackerras | 5f29675 | 2005-10-17 20:14:59 +1000 | [diff] [blame] | 566 | Firmware or other boot firmware. If unsure, say Y here. | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 567 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 568 | config CMDLINE_BOOL | 
|  | 569 | bool "Default bootloader kernel arguments" | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 570 |  | 
|  | 571 | config CMDLINE | 
|  | 572 | string "Initial kernel command string" | 
|  | 573 | depends on CMDLINE_BOOL | 
|  | 574 | default "console=ttyS0,9600 console=tty0 root=/dev/sda2" | 
|  | 575 | help | 
|  | 576 | On some platforms, there is currently no way for the boot loader to | 
|  | 577 | pass arguments to the kernel. For these platforms, you can supply | 
|  | 578 | some command-line options at build time by entering them here.  In | 
|  | 579 | most cases you will need to specify the root device here. | 
|  | 580 |  | 
| Grant Likely | c356aa4 | 2008-07-09 09:41:52 -0600 | [diff] [blame] | 581 | config EXTRA_TARGETS | 
|  | 582 | string "Additional default image types" | 
|  | 583 | help | 
|  | 584 | List additional targets to be built by the bootwrapper here (separated | 
|  | 585 | by spaces).  This is useful for targets that depend of device tree | 
|  | 586 | files in the .dts directory. | 
|  | 587 |  | 
|  | 588 | Targets in this list will be build as part of the default build | 
|  | 589 | target, or when the user does a 'make zImage' or a | 
|  | 590 | 'make zImage.initrd'. | 
|  | 591 |  | 
|  | 592 | If unsure, leave blank | 
|  | 593 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 594 | if !44x || BROKEN | 
| Johannes Berg | b28f508 | 2008-01-15 23:17:00 -0500 | [diff] [blame] | 595 | config ARCH_WANTS_FREEZER_CONTROL | 
|  | 596 | def_bool y | 
|  | 597 | depends on ADB_PMU | 
|  | 598 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 599 | source kernel/power/Kconfig | 
|  | 600 | endif | 
|  | 601 |  | 
|  | 602 | config SECCOMP | 
|  | 603 | bool "Enable seccomp to safely compute untrusted bytecode" | 
|  | 604 | depends on PROC_FS | 
|  | 605 | default y | 
|  | 606 | help | 
|  | 607 | This kernel feature is useful for number crunching applications | 
|  | 608 | that may need to compute untrusted bytecode during their | 
|  | 609 | execution. By using pipes or other transports made available to | 
|  | 610 | the process as file descriptors supporting the read/write | 
|  | 611 | syscalls, it's possible to isolate those applications in | 
|  | 612 | their own address space using seccomp. Once seccomp is | 
|  | 613 | enabled via /proc/<pid>/seccomp, it cannot be disabled | 
|  | 614 | and the task is only allowed to execute a few safe syscalls | 
|  | 615 | defined by each seccomp mode. | 
|  | 616 |  | 
|  | 617 | If unsure, say Y. Only embedded should say N here. | 
|  | 618 |  | 
|  | 619 | endmenu | 
|  | 620 |  | 
|  | 621 | config ISA_DMA_API | 
|  | 622 | bool | 
| Stephen Rothwell | 373a6da | 2007-12-21 15:37:07 +1100 | [diff] [blame] | 623 | default !PPC_ISERIES || PCI | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 624 |  | 
|  | 625 | menu "Bus options" | 
|  | 626 |  | 
|  | 627 | config ISA | 
|  | 628 | bool "Support for ISA-bus hardware" | 
|  | 629 | depends on PPC_PREP || PPC_CHRP | 
| Paul Mackerras | f9bd170 | 2005-10-26 16:47:42 +1000 | [diff] [blame] | 630 | select PPC_I8259 | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 631 | help | 
|  | 632 | Find out whether you have ISA slots on your motherboard.  ISA is the | 
|  | 633 | name of a bus system, i.e. the way the CPU talks to the other stuff | 
|  | 634 | inside your box.  If you have an Apple machine, say N here; if you | 
|  | 635 | have an IBM RS/6000 or pSeries machine or a PReP machine, say Y.  If | 
|  | 636 | you have an embedded board, consult your board documentation. | 
|  | 637 |  | 
| Christoph Lameter | 5ac6da6 | 2007-02-10 01:43:14 -0800 | [diff] [blame] | 638 | config ZONE_DMA | 
|  | 639 | bool | 
|  | 640 | default y | 
|  | 641 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 642 | config GENERIC_ISA_DMA | 
|  | 643 | bool | 
|  | 644 | depends on PPC64 || POWER4 || 6xx && !CPM2 | 
|  | 645 | default y | 
|  | 646 |  | 
| Paul Mackerras | 25635c7 | 2005-10-26 16:36:55 +1000 | [diff] [blame] | 647 | config PPC_INDIRECT_PCI | 
|  | 648 | bool | 
|  | 649 | depends on PCI | 
| Becky Bruce | 63dafe5 | 2006-01-14 16:57:39 -0600 | [diff] [blame] | 650 | default y if 40x || 44x | 
| Paul Mackerras | 25635c7 | 2005-10-26 16:36:55 +1000 | [diff] [blame] | 651 | default n | 
|  | 652 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 653 | config EISA | 
|  | 654 | bool | 
|  | 655 |  | 
|  | 656 | config SBUS | 
|  | 657 | bool | 
|  | 658 |  | 
| Kumar Gala | 08264cb | 2006-01-10 21:43:56 -0600 | [diff] [blame] | 659 | config FSL_SOC | 
|  | 660 | bool | 
|  | 661 |  | 
| Roy Zang | 55c4499 | 2007-07-10 18:44:34 +0800 | [diff] [blame] | 662 | config FSL_PCI | 
|  | 663 | bool | 
|  | 664 | select PPC_INDIRECT_PCI | 
| Kumar Gala | d083911 | 2009-01-28 13:25:29 -0600 | [diff] [blame] | 665 | select PCI_QUIRKS | 
| Roy Zang | 55c4499 | 2007-07-10 18:44:34 +0800 | [diff] [blame] | 666 |  | 
| Stefan Roese | 2a70691 | 2008-03-26 22:39:50 +1100 | [diff] [blame] | 667 | config 4xx_SOC | 
|  | 668 | bool | 
|  | 669 |  | 
| Anton Vorontsov | acaa7aa | 2008-04-11 21:03:40 +0400 | [diff] [blame] | 670 | config FSL_LBC | 
|  | 671 | bool | 
|  | 672 | help | 
|  | 673 | Freescale Localbus support | 
|  | 674 |  | 
| Anton Vorontsov | 83ff9dc | 2008-05-23 20:38:54 +0400 | [diff] [blame] | 675 | config FSL_GTM | 
|  | 676 | bool | 
|  | 677 | depends on PPC_83xx || QUICC_ENGINE || CPM2 | 
|  | 678 | help | 
|  | 679 | Freescale General-purpose Timers support | 
|  | 680 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 681 | # Yes MCA RS/6000s exist but Linux-PPC does not currently support any | 
|  | 682 | config MCA | 
|  | 683 | bool | 
|  | 684 |  | 
| John Rigby | b500563 | 2008-06-26 11:07:56 -0600 | [diff] [blame] | 685 | # Platforms that what PCI turned unconditionally just do select PCI | 
|  | 686 | # in their config node.  Platforms that want to choose at config | 
|  | 687 | # time should select PPC_PCI_CHOICE | 
|  | 688 | config PPC_PCI_CHOICE | 
|  | 689 | bool | 
|  | 690 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 691 | config PCI | 
| John Rigby | b500563 | 2008-06-26 11:07:56 -0600 | [diff] [blame] | 692 | bool "PCI support" if PPC_PCI_CHOICE | 
|  | 693 | default y if !40x && !CPM2 && !8xx && !PPC_83xx \ | 
| Jon Loeliger | 5315862 | 2006-08-09 10:37:28 -0500 | [diff] [blame] | 694 | && !PPC_85xx && !PPC_86xx | 
| David Gibson | f21f49e | 2007-06-13 14:52:54 +1000 | [diff] [blame] | 695 | default PCI_PERMEDIA if !4xx && !CPM2 && !8xx | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 696 | default PCI_QSPAN if !4xx && !CPM2 && 8xx | 
| Michael Ellerman | df87ef5 | 2007-05-08 12:58:34 +1000 | [diff] [blame] | 697 | select ARCH_SUPPORTS_MSI | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 698 | help | 
|  | 699 | Find out whether your system includes a PCI bus. PCI is the name of | 
|  | 700 | a bus system, i.e. the way the CPU talks to the other stuff inside | 
|  | 701 | your box.  If you say Y here, the kernel will include drivers and | 
|  | 702 | infrastructure code to support PCI bus devices. | 
|  | 703 |  | 
|  | 704 | config PCI_DOMAINS | 
| Matthew Wilcox | 36e2359 | 2007-07-10 10:54:40 -0600 | [diff] [blame] | 705 | def_bool PCI | 
|  | 706 |  | 
|  | 707 | config PCI_SYSCALL | 
|  | 708 | def_bool PCI | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 709 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 710 | config PCI_QSPAN | 
|  | 711 | bool "QSpan PCI" | 
|  | 712 | depends on !4xx && !CPM2 && 8xx | 
| Paul Mackerras | f9bd170 | 2005-10-26 16:47:42 +1000 | [diff] [blame] | 713 | select PPC_I8259 | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 714 | help | 
|  | 715 | Say Y here if you have a system based on a Motorola 8xx-series | 
|  | 716 | embedded processor with a QSPAN PCI interface, otherwise say N. | 
|  | 717 |  | 
|  | 718 | config PCI_8260 | 
|  | 719 | bool | 
|  | 720 | depends on PCI && 8260 | 
| Paul Mackerras | 25635c7 | 2005-10-26 16:36:55 +1000 | [diff] [blame] | 721 | select PPC_INDIRECT_PCI | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 722 | default y | 
|  | 723 |  | 
|  | 724 | config 8260_PCI9 | 
| Andrew Morton | 4a3ecc6 | 2006-06-01 20:36:04 -0700 | [diff] [blame] | 725 | bool "Enable workaround for MPC826x erratum PCI 9" | 
| Scott Wood | e00c549 | 2007-09-14 15:41:56 -0500 | [diff] [blame] | 726 | depends on PCI_8260 && !8272 | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 727 | default y | 
|  | 728 |  | 
|  | 729 | choice | 
| Andrew Morton | 4a3ecc6 | 2006-06-01 20:36:04 -0700 | [diff] [blame] | 730 | prompt "IDMA channel for PCI 9 workaround" | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 731 | depends on 8260_PCI9 | 
|  | 732 |  | 
|  | 733 | config 8260_PCI9_IDMA1 | 
|  | 734 | bool "IDMA1" | 
|  | 735 |  | 
|  | 736 | config 8260_PCI9_IDMA2 | 
|  | 737 | bool "IDMA2" | 
|  | 738 |  | 
|  | 739 | config 8260_PCI9_IDMA3 | 
|  | 740 | bool "IDMA3" | 
|  | 741 |  | 
|  | 742 | config 8260_PCI9_IDMA4 | 
|  | 743 | bool "IDMA4" | 
|  | 744 |  | 
|  | 745 | endchoice | 
|  | 746 |  | 
| Jake Moilanen | bb53bb3 | 2006-06-07 16:05:46 -0500 | [diff] [blame] | 747 | source "drivers/pci/pcie/Kconfig" | 
|  | 748 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 749 | source "drivers/pci/Kconfig" | 
|  | 750 |  | 
|  | 751 | source "drivers/pcmcia/Kconfig" | 
|  | 752 |  | 
|  | 753 | source "drivers/pci/hotplug/Kconfig" | 
|  | 754 |  | 
| Zhang Wei | f1f389d | 2008-04-18 13:33:39 -0700 | [diff] [blame] | 755 | config HAS_RAPIDIO | 
|  | 756 | bool | 
|  | 757 | default n | 
|  | 758 |  | 
|  | 759 | config RAPIDIO | 
|  | 760 | bool "RapidIO support" | 
|  | 761 | depends on HAS_RAPIDIO | 
|  | 762 | help | 
|  | 763 | If you say Y here, the kernel will include drivers and | 
|  | 764 | infrastructure code to support RapidIO interconnect devices. | 
|  | 765 |  | 
|  | 766 | source "drivers/rapidio/Kconfig" | 
|  | 767 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 768 | endmenu | 
|  | 769 |  | 
|  | 770 | menu "Advanced setup" | 
|  | 771 | depends on PPC32 | 
|  | 772 |  | 
|  | 773 | config ADVANCED_OPTIONS | 
|  | 774 | bool "Prompt for advanced kernel configuration options" | 
|  | 775 | help | 
|  | 776 | This option will enable prompting for a variety of advanced kernel | 
|  | 777 | configuration options.  These options can cause the kernel to not | 
|  | 778 | work if they are set incorrectly, but can be used to optimize certain | 
|  | 779 | aspects of kernel memory management. | 
|  | 780 |  | 
|  | 781 | Unless you know what you are doing, say N here. | 
|  | 782 |  | 
|  | 783 | comment "Default settings for advanced configuration options are used" | 
|  | 784 | depends on !ADVANCED_OPTIONS | 
|  | 785 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 786 | config LOWMEM_SIZE_BOOL | 
|  | 787 | bool "Set maximum low memory" | 
|  | 788 | depends on ADVANCED_OPTIONS | 
|  | 789 | help | 
|  | 790 | This option allows you to set the maximum amount of memory which | 
|  | 791 | will be used as "low memory", that is, memory which the kernel can | 
|  | 792 | access directly, without having to set up a kernel virtual mapping. | 
|  | 793 | This can be useful in optimizing the layout of kernel virtual | 
|  | 794 | memory. | 
|  | 795 |  | 
|  | 796 | Say N here unless you know what you are doing. | 
|  | 797 |  | 
|  | 798 | config LOWMEM_SIZE | 
|  | 799 | hex "Maximum low memory size (in bytes)" if LOWMEM_SIZE_BOOL | 
|  | 800 | default "0x30000000" | 
|  | 801 |  | 
| Trent Piepho | 9605146 | 2008-12-08 19:34:58 -0800 | [diff] [blame] | 802 | config LOWMEM_CAM_NUM_BOOL | 
|  | 803 | bool "Set number of CAMs to use to map low memory" | 
|  | 804 | depends on ADVANCED_OPTIONS && FSL_BOOKE | 
|  | 805 | help | 
|  | 806 | This option allows you to set the maximum number of CAM slots that | 
|  | 807 | will be used to map low memory.  There are a limited number of slots | 
|  | 808 | available and even more limited number that will fit in the L1 MMU. | 
|  | 809 | However, using more entries will allow mapping more low memory.  This | 
|  | 810 | can be useful in optimizing the layout of kernel virtual memory. | 
|  | 811 |  | 
|  | 812 | Say N here unless you know what you are doing. | 
|  | 813 |  | 
|  | 814 | config LOWMEM_CAM_NUM | 
| Josh Boyer | 9b71dbd | 2009-03-31 08:05:50 -0400 | [diff] [blame] | 815 | depends on FSL_BOOKE | 
| Trent Piepho | 9605146 | 2008-12-08 19:34:58 -0800 | [diff] [blame] | 816 | int "Number of CAMs to use to map low memory" if LOWMEM_CAM_NUM_BOOL | 
|  | 817 | default 3 | 
|  | 818 |  | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 819 | config RELOCATABLE | 
|  | 820 | bool "Build a relocatable kernel (EXPERIMENTAL)" | 
|  | 821 | depends on EXPERIMENTAL && ADVANCED_OPTIONS && FLATMEM && FSL_BOOKE | 
|  | 822 | help | 
|  | 823 | This builds a kernel image that is capable of running at the | 
|  | 824 | location the kernel is loaded at (some alignment restrictions may | 
|  | 825 | exist). | 
|  | 826 |  | 
|  | 827 | One use is for the kexec on panic case where the recovery kernel | 
|  | 828 | must live at a different physical address than the primary | 
|  | 829 | kernel. | 
|  | 830 |  | 
|  | 831 | Note: If CONFIG_RELOCATABLE=y, then the kernel runs from the address | 
|  | 832 | it has been loaded at and the compile time physical addresses | 
|  | 833 | CONFIG_PHYSICAL_START is ignored.  However CONFIG_PHYSICAL_START | 
|  | 834 | setting can still be useful to bootwrappers that need to know the | 
|  | 835 | load location of the kernel (eg. u-boot/mkimage). | 
|  | 836 |  | 
|  | 837 | config PAGE_OFFSET_BOOL | 
|  | 838 | bool "Set custom page offset address" | 
|  | 839 | depends on ADVANCED_OPTIONS | 
|  | 840 | help | 
|  | 841 | This option allows you to set the kernel virtual address at which | 
|  | 842 | the kernel will map low memory.  This can be useful in optimizing | 
|  | 843 | the virtual memory layout of the system. | 
|  | 844 |  | 
|  | 845 | Say N here unless you know what you are doing. | 
|  | 846 |  | 
|  | 847 | config PAGE_OFFSET | 
|  | 848 | hex "Virtual address of memory base" if PAGE_OFFSET_BOOL | 
|  | 849 | default "0xc0000000" | 
|  | 850 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 851 | config KERNEL_START_BOOL | 
|  | 852 | bool "Set custom kernel base address" | 
|  | 853 | depends on ADVANCED_OPTIONS | 
|  | 854 | help | 
|  | 855 | This option allows you to set the kernel virtual address at which | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 856 | the kernel will be loaded.  Normally this should match PAGE_OFFSET | 
|  | 857 | however there are times (like kdump) that one might not want them | 
|  | 858 | to be the same. | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 859 |  | 
|  | 860 | Say N here unless you know what you are doing. | 
|  | 861 |  | 
|  | 862 | config KERNEL_START | 
|  | 863 | hex "Virtual address of kernel base" if KERNEL_START_BOOL | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 864 | default PAGE_OFFSET if PAGE_OFFSET_BOOL | 
|  | 865 | default "0xc2000000" if CRASH_DUMP | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 866 | default "0xc0000000" | 
|  | 867 |  | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 868 | config PHYSICAL_START_BOOL | 
|  | 869 | bool "Set physical address where the kernel is loaded" | 
|  | 870 | depends on ADVANCED_OPTIONS && FLATMEM && FSL_BOOKE | 
|  | 871 | help | 
|  | 872 | This gives the physical address where the kernel is loaded. | 
|  | 873 |  | 
|  | 874 | Say N here unless you know what you are doing. | 
|  | 875 |  | 
|  | 876 | config PHYSICAL_START | 
|  | 877 | hex "Physical address where the kernel is loaded" if PHYSICAL_START_BOOL | 
|  | 878 | default "0x02000000" if PPC_STD_MMU && CRASH_DUMP | 
|  | 879 | default "0x00000000" | 
|  | 880 |  | 
|  | 881 | config PHYSICAL_ALIGN | 
|  | 882 | hex | 
| Trent Piepho | c8f3570 | 2008-12-08 19:34:59 -0800 | [diff] [blame] | 883 | default "0x04000000" if FSL_BOOKE | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 884 | help | 
|  | 885 | This value puts the alignment restrictions on physical address | 
|  | 886 | where kernel is loaded and run from. Kernel is compiled for an | 
|  | 887 | address which meets above alignment restriction. | 
|  | 888 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 889 | config TASK_SIZE_BOOL | 
|  | 890 | bool "Set custom user task size" | 
|  | 891 | depends on ADVANCED_OPTIONS | 
|  | 892 | help | 
|  | 893 | This option allows you to set the amount of virtual address space | 
|  | 894 | allocated to user tasks.  This can be useful in optimizing the | 
|  | 895 | virtual memory layout of the system. | 
|  | 896 |  | 
|  | 897 | Say N here unless you know what you are doing. | 
|  | 898 |  | 
|  | 899 | config TASK_SIZE | 
|  | 900 | hex "Size of user task space" if TASK_SIZE_BOOL | 
| Kumar Gala | 4d9e5510 | 2007-10-11 13:40:21 -0500 | [diff] [blame] | 901 | default "0x80000000" if PPC_PREP || PPC_8xx | 
|  | 902 | default "0xc0000000" | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 903 |  | 
| Benjamin Herrenschmidt | 84532a0 | 2009-05-27 13:33:14 +1000 | [diff] [blame] | 904 | config CONSISTENT_SIZE_BOOL | 
|  | 905 | bool "Set custom consistent memory pool size" | 
|  | 906 | depends on ADVANCED_OPTIONS && NOT_COHERENT_CACHE | 
|  | 907 | help | 
|  | 908 | This option allows you to set the size of the | 
|  | 909 | consistent memory pool.  This pool of virtual memory | 
|  | 910 | is used to make consistent memory allocations. | 
|  | 911 |  | 
|  | 912 | config CONSISTENT_SIZE | 
|  | 913 | hex "Size of consistent memory pool" if CONSISTENT_SIZE_BOOL | 
|  | 914 | default "0x00200000" if NOT_COHERENT_CACHE | 
|  | 915 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 916 | config PIN_TLB | 
|  | 917 | bool "Pinned Kernel TLBs (860 ONLY)" | 
|  | 918 | depends on ADVANCED_OPTIONS && 8xx | 
|  | 919 | endmenu | 
|  | 920 |  | 
| Stephen Rothwell | cabb558 | 2005-09-30 16:16:52 +1000 | [diff] [blame] | 921 | if PPC64 | 
| Paul Mackerras | 549e815 | 2008-08-30 11:43:47 +1000 | [diff] [blame] | 922 | config RELOCATABLE | 
|  | 923 | bool "Build a relocatable kernel" | 
|  | 924 | help | 
|  | 925 | This builds a kernel image that is capable of running anywhere | 
|  | 926 | in the RMA (real memory area) at any 16k-aligned base address. | 
|  | 927 | The kernel is linked as a position-independent executable (PIE) | 
|  | 928 | and contains dynamic relocations which are processed early | 
|  | 929 | in the bootup process. | 
|  | 930 |  | 
|  | 931 | One use is for the kexec on panic case where the recovery kernel | 
|  | 932 | must live at a different physical address than the primary | 
|  | 933 | kernel. | 
|  | 934 |  | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 935 | config PAGE_OFFSET | 
| Stephen Rothwell | cabb558 | 2005-09-30 16:16:52 +1000 | [diff] [blame] | 936 | hex | 
| Stephen Rothwell | eeb2d21 | 2005-09-30 17:24:15 +1000 | [diff] [blame] | 937 | default "0xc000000000000000" | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 938 | config KERNEL_START | 
|  | 939 | hex | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 940 | default "0xc000000000000000" | 
|  | 941 | config PHYSICAL_START | 
|  | 942 | hex | 
| Kumar Gala | 37dd2ba | 2008-04-22 04:22:34 +1000 | [diff] [blame] | 943 | default "0x00000000" | 
| Stephen Rothwell | cabb558 | 2005-09-30 16:16:52 +1000 | [diff] [blame] | 944 | endif | 
|  | 945 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 946 | source "net/Kconfig" | 
|  | 947 |  | 
|  | 948 | source "drivers/Kconfig" | 
|  | 949 |  | 
|  | 950 | source "fs/Kconfig" | 
|  | 951 |  | 
| Li Yang | 9865853 | 2006-10-03 23:10:46 -0500 | [diff] [blame] | 952 | source "arch/powerpc/sysdev/qe_lib/Kconfig" | 
|  | 953 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 954 | source "lib/Kconfig" | 
|  | 955 |  | 
| Paul Mackerras | 14cf11a | 2005-09-26 16:04:21 +1000 | [diff] [blame] | 956 | source "arch/powerpc/Kconfig.debug" | 
|  | 957 |  | 
|  | 958 | source "security/Kconfig" | 
|  | 959 |  | 
|  | 960 | config KEYS_COMPAT | 
|  | 961 | bool | 
|  | 962 | depends on COMPAT && KEYS | 
|  | 963 | default y | 
|  | 964 |  | 
|  | 965 | source "crypto/Kconfig" | 
| Domen Puncer | 6f66828 | 2007-09-21 00:00:11 +1000 | [diff] [blame] | 966 |  | 
|  | 967 | config PPC_CLOCK | 
|  | 968 | bool | 
|  | 969 | default n | 
| David Brownell | 9483a57 | 2008-07-23 21:26:48 -0700 | [diff] [blame] | 970 | select HAVE_CLK | 
| Sylvain Munaut | 1088a20 | 2007-09-16 20:53:25 +1000 | [diff] [blame] | 971 |  | 
|  | 972 | config PPC_LIB_RHEAP | 
|  | 973 | bool | 
|  | 974 |  | 
| Hollis Blanchard | bbf45ba | 2008-04-16 23:28:09 -0500 | [diff] [blame] | 975 | source "arch/powerpc/kvm/Kconfig" |