exit_thread: remove empty bodies
[sfrench/cifs-2.6.git] / arch / tile / Kconfig
1 # For a description of the syntax of this configuration file,
2 # see Documentation/kbuild/kconfig-language.txt.
3
4 config TILE
5         def_bool y
6         select HAVE_EXIT_THREAD
7         select HAVE_PERF_EVENTS
8         select USE_PMC if PERF_EVENTS
9         select HAVE_DMA_API_DEBUG
10         select HAVE_KVM if !TILEGX
11         select GENERIC_FIND_FIRST_BIT
12         select SYSCTL_EXCEPTION_TRACE
13         select CC_OPTIMIZE_FOR_SIZE
14         select HAVE_DEBUG_KMEMLEAK
15         select GENERIC_IRQ_PROBE
16         select GENERIC_PENDING_IRQ if SMP
17         select GENERIC_IRQ_SHOW
18         select HAVE_DEBUG_BUGVERBOSE
19         select VIRT_TO_BUS
20         select SYS_HYPERVISOR
21         select ARCH_HAS_DEBUG_STRICT_USER_COPY_CHECKS
22         select ARCH_HAS_DEVMEM_IS_ALLOWED
23         select ARCH_HAVE_NMI_SAFE_CMPXCHG
24         select GENERIC_CLOCKEVENTS
25         select MODULES_USE_ELF_RELA
26         select HAVE_ARCH_TRACEHOOK
27         select HAVE_SYSCALL_TRACEPOINTS
28         select USER_STACKTRACE_SUPPORT
29         select ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE
30         select HAVE_DEBUG_STACKOVERFLOW
31         select ARCH_WANT_FRAME_POINTERS
32         select HAVE_CONTEXT_TRACKING
33         select EDAC_SUPPORT
34         select GENERIC_STRNCPY_FROM_USER
35         select GENERIC_STRNLEN_USER
36         select HAVE_ARCH_SECCOMP_FILTER
37
38 # FIXME: investigate whether we need/want these options.
39 #       select HAVE_IOREMAP_PROT
40 #       select HAVE_OPTPROBES
41 #       select HAVE_REGS_AND_STACK_ACCESS_API
42 #       select HAVE_HW_BREAKPOINT
43 #       select PERF_EVENTS
44 #       select HAVE_USER_RETURN_NOTIFIER
45 #       config NO_BOOTMEM
46 #       config ARCH_SUPPORTS_DEBUG_PAGEALLOC
47 #       config HUGETLB_PAGE_SIZE_VARIABLE
48
49 config MMU
50         def_bool y
51
52 config GENERIC_CSUM
53         def_bool y
54
55 config HAVE_ARCH_ALLOC_REMAP
56         def_bool y
57
58 config HAVE_SETUP_PER_CPU_AREA
59         def_bool y
60
61 config NEED_PER_CPU_PAGE_FIRST_CHUNK
62         def_bool y
63
64 config SYS_SUPPORTS_HUGETLBFS
65         def_bool y
66
67 # Support for additional huge page sizes besides HPAGE_SIZE.
68 # The software support is currently only present in the TILE-Gx
69 # hypervisor. TILEPro in any case does not support page sizes
70 # larger than the default HPAGE_SIZE.
71 config HUGETLB_SUPER_PAGES
72         depends on HUGETLB_PAGE && TILEGX
73         def_bool y
74
75 config GENERIC_TIME_VSYSCALL
76         def_bool y
77
78 # Enable PMC if PERF_EVENTS, OPROFILE, or WATCHPOINTS are enabled.
79 config USE_PMC
80         bool
81
82 # FIXME: tilegx can implement a more efficient rwsem.
83 config RWSEM_GENERIC_SPINLOCK
84         def_bool y
85
86 # We only support gcc 4.4 and above, so this should work.
87 config ARCH_SUPPORTS_OPTIMIZED_INLINING
88         def_bool y
89
90 config ARCH_PHYS_ADDR_T_64BIT
91         def_bool y
92
93 config ARCH_DMA_ADDR_T_64BIT
94         def_bool y
95
96 config NEED_DMA_MAP_STATE
97         def_bool y
98
99 config ARCH_HAS_DMA_SET_COHERENT_MASK
100         bool
101
102 config LOCKDEP_SUPPORT
103         def_bool y
104
105 config STACKTRACE_SUPPORT
106         def_bool y
107         select STACKTRACE
108
109 # We use discontigmem for now; at some point we may want to switch
110 # to sparsemem (Tilera bug 7996).
111 config ARCH_DISCONTIGMEM_ENABLE
112         def_bool y
113
114 config ARCH_DISCONTIGMEM_DEFAULT
115         def_bool y
116
117 config TRACE_IRQFLAGS_SUPPORT
118         def_bool y
119
120 # SMP is required for Tilera Linux.
121 config SMP
122         def_bool y
123
124 config HVC_TILE
125         depends on TTY
126         select HVC_DRIVER
127         select HVC_IRQ if TILEGX
128         def_bool y
129
130 # Building with ARCH=tilegx (or ARCH=tile) implies using the
131 # 64-bit TILE-Gx toolchain, so force CONFIG_TILEGX on.
132 config TILEGX
133         def_bool ARCH != "tilepro"
134         select SPARSE_IRQ
135         select GENERIC_IRQ_LEGACY_ALLOC_HWIRQ
136         select HAVE_FUNCTION_TRACER
137         select HAVE_FUNCTION_GRAPH_TRACER
138         select HAVE_DYNAMIC_FTRACE
139         select HAVE_FTRACE_MCOUNT_RECORD
140         select HAVE_KPROBES
141         select HAVE_KRETPROBES
142         select HAVE_ARCH_KGDB
143         select ARCH_SUPPORTS_ATOMIC_RMW
144         select HAVE_ARCH_JUMP_LABEL
145
146 config TILEPRO
147         def_bool !TILEGX
148
149 config 64BIT
150         def_bool TILEGX
151
152 config ARCH_DEFCONFIG
153         string
154         default "arch/tile/configs/tilepro_defconfig" if !TILEGX
155         default "arch/tile/configs/tilegx_defconfig" if TILEGX
156
157 config PGTABLE_LEVELS
158         int
159         default 3 if 64BIT
160         default 2
161
162 source "init/Kconfig"
163
164 source "kernel/Kconfig.freezer"
165
166 menu "Tilera-specific configuration"
167
168 config NR_CPUS
169         int "Maximum number of tiles (2-255)"
170         range 2 255
171         depends on SMP
172         default "64"
173         ---help---
174           Building with 64 is the recommended value, but a slightly
175           smaller kernel memory footprint results from using a smaller
176           value on chips with fewer tiles.
177
178 choice
179         prompt "Kernel page size"
180         default PAGE_SIZE_64KB
181         help
182           This lets you select the page size of the kernel.  For best
183           performance on memory-intensive applications, a page size of 64KB
184           is recommended.  For workloads involving many small files, many
185           connections, etc., it may be better to select 16KB, which uses
186           memory more efficiently at some cost in TLB performance.
187
188           Note that for TILEPro, you must also rebuild the hypervisor
189           with a matching page size.
190
191 config PAGE_SIZE_4KB
192         bool "4KB" if TILEPRO
193
194 config PAGE_SIZE_16KB
195         bool "16KB"
196
197 config PAGE_SIZE_64KB
198         bool "64KB"
199
200 endchoice
201
202 source "kernel/Kconfig.hz"
203
204 config KEXEC
205         bool "kexec system call"
206         select KEXEC_CORE
207         ---help---
208           kexec is a system call that implements the ability to shutdown your
209           current kernel, and to start another kernel.  It is like a reboot
210           but it is independent of the system firmware.   It is used
211           to implement the "mboot" Tilera booter.
212
213           The name comes from the similarity to the exec system call.
214
215 config COMPAT
216         bool "Support 32-bit TILE-Gx binaries in addition to 64-bit"
217         depends on TILEGX
218         select COMPAT_BINFMT_ELF
219         default y
220         ---help---
221           If enabled, the kernel will support running TILE-Gx binaries
222           that were built with the -m32 option.
223
224 config SECCOMP
225         bool "Enable seccomp to safely compute untrusted bytecode"
226         depends on PROC_FS
227         help
228           This kernel feature is useful for number crunching applications
229           that may need to compute untrusted bytecode during their
230           execution. By using pipes or other transports made available to
231           the process as file descriptors supporting the read/write
232           syscalls, it's possible to isolate those applications in
233           their own address space using seccomp. Once seccomp is
234           enabled via prctl, it cannot be disabled and the task is only
235           allowed to execute a few safe syscalls defined by each seccomp
236           mode.
237
238           If unsure, say N.
239
240 config SYSVIPC_COMPAT
241         def_bool y
242         depends on COMPAT && SYSVIPC
243
244 # We do not currently support disabling HIGHMEM on tilepro.
245 config HIGHMEM
246         bool # "Support for more than 512 MB of RAM"
247         default !TILEGX
248         ---help---
249           Linux can use the full amount of RAM in the system by
250           default.  However, the address space of TILE processors is
251           only 4 Gigabytes large. That means that, if you have a large
252           amount of physical memory, not all of it can be "permanently
253           mapped" by the kernel. The physical memory that's not
254           permanently mapped is called "high memory".
255
256           If you are compiling a kernel which will never run on a
257           machine with more than 512 MB total physical RAM, answer
258           "false" here. This will result in the kernel mapping all of
259           physical memory into the top 1 GB of virtual memory space.
260
261           If unsure, say "true".
262
263 config ZONE_DMA
264         def_bool y
265
266 config IOMMU_HELPER
267         bool
268
269 config NEED_SG_DMA_LENGTH
270         bool
271
272 config SWIOTLB
273         bool
274         default TILEGX
275         select IOMMU_HELPER
276         select NEED_SG_DMA_LENGTH
277         select ARCH_HAS_DMA_SET_COHERENT_MASK
278
279 # We do not currently support disabling NUMA.
280 config NUMA
281         bool # "NUMA Memory Allocation and Scheduler Support"
282         depends on SMP && DISCONTIGMEM
283         default y
284         ---help---
285           NUMA memory allocation is required for TILE processors
286           unless booting with memory striping enabled in the
287           hypervisor, or with only a single memory controller.
288           It is recommended that this option always be enabled.
289
290 config NODES_SHIFT
291         int "Log base 2 of the max number of memory controllers"
292         default 2
293         depends on NEED_MULTIPLE_NODES
294         ---help---
295           By default, 2, i.e. 2^2 == 4 DDR2 controllers.
296           In a system with more controllers, this value should be raised.
297
298 choice
299         depends on !TILEGX
300         prompt "Memory split" if EXPERT
301         default VMSPLIT_3G
302         ---help---
303           Select the desired split between kernel and user memory.
304
305           If the address range available to the kernel is less than the
306           physical memory installed, the remaining memory will be available
307           as "high memory". Accessing high memory is a little more costly
308           than low memory, as it needs to be mapped into the kernel first.
309           Note that increasing the kernel address space limits the range
310           available to user programs, making the address space there
311           tighter.  Selecting anything other than the default 3G/1G split
312           will also likely make your kernel incompatible with binary-only
313           kernel modules.
314
315           If you are not absolutely sure what you are doing, leave this
316           option alone!
317
318         config VMSPLIT_3_75G
319                 bool "3.75G/0.25G user/kernel split (no kernel networking)"
320         config VMSPLIT_3_5G
321                 bool "3.5G/0.5G user/kernel split"
322         config VMSPLIT_3G
323                 bool "3G/1G user/kernel split"
324         config VMSPLIT_2_75G
325                 bool "2.75G/1.25G user/kernel split (for full 1G low memory)"
326         config VMSPLIT_2_5G
327                 bool "2.5G/1.5G user/kernel split"
328         config VMSPLIT_2_25G
329                 bool "2.25G/1.75G user/kernel split"
330         config VMSPLIT_2G
331                 bool "2G/2G user/kernel split"
332         config VMSPLIT_1G
333                 bool "1G/3G user/kernel split"
334 endchoice
335
336 config PAGE_OFFSET
337         hex
338         depends on !64BIT
339         default 0xF0000000 if VMSPLIT_3_75G
340         default 0xE0000000 if VMSPLIT_3_5G
341         default 0xB0000000 if VMSPLIT_2_75G
342         default 0xA0000000 if VMSPLIT_2_5G
343         default 0x90000000 if VMSPLIT_2_25G
344         default 0x80000000 if VMSPLIT_2G
345         default 0x40000000 if VMSPLIT_1G
346         default 0xC0000000
347
348 source "mm/Kconfig"
349
350 source "kernel/Kconfig.preempt"
351
352 config CMDLINE_BOOL
353         bool "Built-in kernel command line"
354         default n
355         ---help---
356           Allow for specifying boot arguments to the kernel at
357           build time.  On some systems (e.g. embedded ones), it is
358           necessary or convenient to provide some or all of the
359           kernel boot arguments with the kernel itself (that is,
360           to not rely on the boot loader to provide them.)
361
362           To compile command line arguments into the kernel,
363           set this option to 'Y', then fill in the
364           the boot arguments in CONFIG_CMDLINE.
365
366           Systems with fully functional boot loaders (e.g. mboot, or
367           if booting over PCI) should leave this option set to 'N'.
368
369 config CMDLINE
370         string "Built-in kernel command string"
371         depends on CMDLINE_BOOL
372         default ""
373         ---help---
374           Enter arguments here that should be compiled into the kernel
375           image and used at boot time.  If the boot loader provides a
376           command line at boot time, it is appended to this string to
377           form the full kernel command line, when the system boots.
378
379           However, you can use the CONFIG_CMDLINE_OVERRIDE option to
380           change this behavior.
381
382           In most cases, the command line (whether built-in or provided
383           by the boot loader) should specify the device for the root
384           file system.
385
386 config CMDLINE_OVERRIDE
387         bool "Built-in command line overrides boot loader arguments"
388         default n
389         depends on CMDLINE_BOOL
390         ---help---
391           Set this option to 'Y' to have the kernel ignore the boot loader
392           command line, and use ONLY the built-in command line.
393
394           This is used to work around broken boot loaders.  This should
395           be set to 'N' under normal conditions.
396
397 config VMALLOC_RESERVE
398         hex
399         default 0x2000000
400
401 config HARDWALL
402         bool "Hardwall support to allow access to user dynamic network"
403         default y
404
405 config KERNEL_PL
406         int "Processor protection level for kernel"
407         range 1 2
408         default 2 if TILEGX
409         default 1 if !TILEGX
410         ---help---
411           Since MDE 4.2, the Tilera hypervisor runs the kernel
412           at PL2 by default.  If running under an older hypervisor,
413           or as a KVM guest, you must run at PL1.  (The current
414           hypervisor may also be recompiled with "make HV_PL=2" to
415           allow it to run a kernel at PL1, but clients running at PL1
416           are not expected to be supported indefinitely.)
417
418           If you're not sure, don't change the default.
419
420 source "arch/tile/gxio/Kconfig"
421
422 endmenu  # Tilera-specific configuration
423
424 menu "Bus options"
425
426 config PCI
427         bool "PCI support"
428         default y
429         select PCI_DOMAINS
430         select GENERIC_PCI_IOMAP
431         select TILE_GXIO_TRIO if TILEGX
432         select PCI_MSI if TILEGX
433         ---help---
434           Enable PCI root complex support, so PCIe endpoint devices can
435           be attached to the Tile chip.  Many, but not all, PCI devices
436           are supported under Tilera's root complex driver.
437
438 config PCI_DOMAINS
439         bool
440
441 config NO_IOMEM
442         def_bool !PCI
443
444 config NO_IOPORT_MAP
445         def_bool !PCI
446
447 config TILE_PCI_IO
448         bool "PCI I/O space support"
449         default n
450         depends on PCI
451         depends on TILEGX
452         ---help---
453           Enable PCI I/O space support on TILEGx. Since the PCI I/O space
454           is used by few modern PCIe endpoint devices, its support is disabled
455           by default to save the TRIO PIO Region resource for other purposes.
456
457 source "drivers/pci/Kconfig"
458
459 config TILE_USB
460         tristate "Tilera USB host adapter support"
461         default y
462         depends on USB
463         depends on TILEGX
464         select TILE_GXIO_USB_HOST
465         ---help---
466           Provides USB host adapter support for the built-in EHCI and OHCI
467           interfaces on TILE-Gx chips.
468
469 endmenu
470
471 menu "Executable file formats"
472
473 source "fs/Kconfig.binfmt"
474
475 endmenu
476
477 source "net/Kconfig"
478
479 source "drivers/Kconfig"
480
481 source "fs/Kconfig"
482
483 source "arch/tile/Kconfig.debug"
484
485 source "security/Kconfig"
486
487 source "crypto/Kconfig"
488
489 source "lib/Kconfig"
490
491 source "arch/tile/kvm/Kconfig"