arch/tile: support multiple huge page sizes dynamically
[firefly-linux-kernel-4.4.55.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_KVM if !TILEGX
7         select GENERIC_FIND_FIRST_BIT
8         select USE_GENERIC_SMP_HELPERS
9         select CC_OPTIMIZE_FOR_SIZE
10         select HAVE_GENERIC_HARDIRQS
11         select GENERIC_IRQ_PROBE
12         select GENERIC_PENDING_IRQ if SMP
13         select GENERIC_IRQ_SHOW
14         select HAVE_SYSCALL_WRAPPERS if TILEGX
15         select SYS_HYPERVISOR
16         select ARCH_HAVE_NMI_SAFE_CMPXCHG
17
18 # FIXME: investigate whether we need/want these options.
19 #       select HAVE_IOREMAP_PROT
20 #       select HAVE_OPTPROBES
21 #       select HAVE_REGS_AND_STACK_ACCESS_API
22 #       select HAVE_HW_BREAKPOINT
23 #       select PERF_EVENTS
24 #       select HAVE_USER_RETURN_NOTIFIER
25 #       config NO_BOOTMEM
26 #       config ARCH_SUPPORTS_DEBUG_PAGEALLOC
27 #       config HUGETLB_PAGE_SIZE_VARIABLE
28
29 config MMU
30         def_bool y
31
32 config GENERIC_CSUM
33         def_bool y
34
35 config SEMAPHORE_SLEEPERS
36         def_bool y
37
38 config HAVE_ARCH_ALLOC_REMAP
39         def_bool y
40
41 config HAVE_SETUP_PER_CPU_AREA
42         def_bool y
43
44 config NEED_PER_CPU_PAGE_FIRST_CHUNK
45         def_bool y
46
47 config SYS_SUPPORTS_HUGETLBFS
48         def_bool y
49
50 # Support for additional huge page sizes besides HPAGE_SIZE.
51 # The software support is currently only present in the TILE-Gx
52 # hypervisor. TILEPro in any case does not support page sizes
53 # larger than the default HPAGE_SIZE.
54 config HUGETLB_SUPER_PAGES
55         depends on HUGETLB_PAGE && TILEGX
56         def_bool y
57
58 config GENERIC_CLOCKEVENTS
59         def_bool y
60
61 # FIXME: tilegx can implement a more efficient rwsem.
62 config RWSEM_GENERIC_SPINLOCK
63         def_bool y
64
65 # We have a very flat architecture from a migration point of view,
66 # so save boot time by presetting this (particularly useful on tile-sim).
67 config DEFAULT_MIGRATION_COST
68         int
69         default "10000000"
70
71 # We only support gcc 4.4 and above, so this should work.
72 config ARCH_SUPPORTS_OPTIMIZED_INLINING
73         def_bool y
74
75 config ARCH_PHYS_ADDR_T_64BIT
76         def_bool y
77
78 config ARCH_DMA_ADDR_T_64BIT
79         def_bool y
80
81 config NEED_DMA_MAP_STATE
82         def_bool y
83
84 config LOCKDEP_SUPPORT
85         def_bool y
86
87 config STACKTRACE_SUPPORT
88         def_bool y
89         select STACKTRACE
90
91 # We use discontigmem for now; at some point we may want to switch
92 # to sparsemem (Tilera bug 7996).
93 config ARCH_DISCONTIGMEM_ENABLE
94         def_bool y
95
96 config ARCH_DISCONTIGMEM_DEFAULT
97         def_bool y
98
99 config TRACE_IRQFLAGS_SUPPORT
100         def_bool y
101
102 config STRICT_DEVMEM
103         def_bool y
104
105 # SMP is required for Tilera Linux.
106 config SMP
107         def_bool y
108
109 # Allow checking for compile-time determined overflow errors in
110 # copy_from_user().  There are still unprovable places in the
111 # generic code as of 2.6.34, so this option is not really compatible
112 # with -Werror, which is more useful in general.
113 config DEBUG_COPY_FROM_USER
114         def_bool n
115
116 config HVC_TILE
117         select HVC_DRIVER
118         def_bool y
119
120 # Please note: TILE-Gx support is not yet finalized; this is
121 # the preliminary support.  TILE-Gx drivers are only provided
122 # with the alpha or beta test versions for Tilera customers.
123 config TILEGX
124         depends on EXPERIMENTAL
125         bool "Building with TILE-Gx (64-bit) compiler and toolchain"
126
127 config 64BIT
128         depends on TILEGX
129         def_bool y
130
131 config ARCH_DEFCONFIG
132         string
133         default "arch/tile/configs/tilepro_defconfig" if !TILEGX
134         default "arch/tile/configs/tilegx_defconfig" if TILEGX
135
136 source "init/Kconfig"
137
138 menu "Tilera-specific configuration"
139
140 config NR_CPUS
141         int "Maximum number of tiles (2-255)"
142         range 2 255
143         depends on SMP
144         default "64"
145         ---help---
146           Building with 64 is the recommended value, but a slightly
147           smaller kernel memory footprint results from using a smaller
148           value on chips with fewer tiles.
149
150 if TILEGX
151
152 choice
153         prompt "Kernel page size"
154         default PAGE_SIZE_64KB
155         help
156           This lets you select the page size of the kernel.  For best
157           performance on memory-intensive applications, a page size of 64KB
158           is recommended.  For workloads involving many small files, many
159           connections, etc., it may be better to select 16KB, which uses
160           memory more efficiently at some cost in TLB performance.
161
162           Note that this option is TILE-Gx specific; currently
163           TILEPro page size is set by rebuilding the hypervisor.
164
165 config PAGE_SIZE_16KB
166         bool "16KB"
167
168 config PAGE_SIZE_64KB
169         bool "64KB"
170
171 endchoice
172
173 endif
174
175 source "kernel/time/Kconfig"
176
177 source "kernel/Kconfig.hz"
178
179 config KEXEC
180         bool "kexec system call"
181         ---help---
182           kexec is a system call that implements the ability to shutdown your
183           current kernel, and to start another kernel.  It is like a reboot
184           but it is independent of the system firmware.   It is used
185           to implement the "mboot" Tilera booter.
186
187           The name comes from the similarity to the exec system call.
188
189 config COMPAT
190         bool "Support 32-bit TILE-Gx binaries in addition to 64-bit"
191         depends on TILEGX
192         select COMPAT_BINFMT_ELF
193         default y
194         ---help---
195           If enabled, the kernel will support running TILE-Gx binaries
196           that were built with the -m32 option.
197
198 config SYSVIPC_COMPAT
199         def_bool y
200         depends on COMPAT && SYSVIPC
201
202 # We do not currently support disabling HIGHMEM on tile64 and tilepro.
203 config HIGHMEM
204         bool # "Support for more than 512 MB of RAM"
205         default !TILEGX
206         ---help---
207           Linux can use the full amount of RAM in the system by
208           default.  However, the address space of TILE processors is
209           only 4 Gigabytes large. That means that, if you have a large
210           amount of physical memory, not all of it can be "permanently
211           mapped" by the kernel. The physical memory that's not
212           permanently mapped is called "high memory".
213
214           If you are compiling a kernel which will never run on a
215           machine with more than 512 MB total physical RAM, answer
216           "false" here. This will result in the kernel mapping all of
217           physical memory into the top 1 GB of virtual memory space.
218
219           If unsure, say "true".
220
221 # We do not currently support disabling NUMA.
222 config NUMA
223         bool # "NUMA Memory Allocation and Scheduler Support"
224         depends on SMP && DISCONTIGMEM
225         default y
226         ---help---
227           NUMA memory allocation is required for TILE processors
228           unless booting with memory striping enabled in the
229           hypervisor, or with only a single memory controller.
230           It is recommended that this option always be enabled.
231
232 config NODES_SHIFT
233         int "Log base 2 of the max number of memory controllers"
234         default 2
235         depends on NEED_MULTIPLE_NODES
236         ---help---
237           By default, 2, i.e. 2^2 == 4 DDR2 controllers.
238           In a system with more controllers, this value should be raised.
239
240 choice
241         depends on !TILEGX
242         prompt "Memory split" if EXPERT
243         default VMSPLIT_3G
244         ---help---
245           Select the desired split between kernel and user memory.
246
247           If the address range available to the kernel is less than the
248           physical memory installed, the remaining memory will be available
249           as "high memory". Accessing high memory is a little more costly
250           than low memory, as it needs to be mapped into the kernel first.
251           Note that increasing the kernel address space limits the range
252           available to user programs, making the address space there
253           tighter.  Selecting anything other than the default 3G/1G split
254           will also likely make your kernel incompatible with binary-only
255           kernel modules.
256
257           If you are not absolutely sure what you are doing, leave this
258           option alone!
259
260         config VMSPLIT_3_75G
261                 bool "3.75G/0.25G user/kernel split (no kernel networking)"
262         config VMSPLIT_3_5G
263                 bool "3.5G/0.5G user/kernel split"
264         config VMSPLIT_3G
265                 bool "3G/1G user/kernel split"
266         config VMSPLIT_2_75G
267                 bool "2.75G/1.25G user/kernel split (for full 1G low memory)"
268         config VMSPLIT_2_5G
269                 bool "2.5G/1.5G user/kernel split"
270         config VMSPLIT_2_25G
271                 bool "2.25G/1.75G user/kernel split"
272         config VMSPLIT_2G
273                 bool "2G/2G user/kernel split"
274         config VMSPLIT_1G
275                 bool "1G/3G user/kernel split"
276 endchoice
277
278 config PAGE_OFFSET
279         hex
280         depends on !64BIT
281         default 0xF0000000 if VMSPLIT_3_75G
282         default 0xE0000000 if VMSPLIT_3_5G
283         default 0xB0000000 if VMSPLIT_2_75G
284         default 0xA0000000 if VMSPLIT_2_5G
285         default 0x90000000 if VMSPLIT_2_25G
286         default 0x80000000 if VMSPLIT_2G
287         default 0x40000000 if VMSPLIT_1G
288         default 0xC0000000
289
290 source "mm/Kconfig"
291
292 config CMDLINE_BOOL
293         bool "Built-in kernel command line"
294         default n
295         ---help---
296           Allow for specifying boot arguments to the kernel at
297           build time.  On some systems (e.g. embedded ones), it is
298           necessary or convenient to provide some or all of the
299           kernel boot arguments with the kernel itself (that is,
300           to not rely on the boot loader to provide them.)
301
302           To compile command line arguments into the kernel,
303           set this option to 'Y', then fill in the
304           the boot arguments in CONFIG_CMDLINE.
305
306           Systems with fully functional boot loaders (e.g. mboot, or
307           if booting over PCI) should leave this option set to 'N'.
308
309 config CMDLINE
310         string "Built-in kernel command string"
311         depends on CMDLINE_BOOL
312         default ""
313         ---help---
314           Enter arguments here that should be compiled into the kernel
315           image and used at boot time.  If the boot loader provides a
316           command line at boot time, it is appended to this string to
317           form the full kernel command line, when the system boots.
318
319           However, you can use the CONFIG_CMDLINE_OVERRIDE option to
320           change this behavior.
321
322           In most cases, the command line (whether built-in or provided
323           by the boot loader) should specify the device for the root
324           file system.
325
326 config CMDLINE_OVERRIDE
327         bool "Built-in command line overrides boot loader arguments"
328         default n
329         depends on CMDLINE_BOOL
330         ---help---
331           Set this option to 'Y' to have the kernel ignore the boot loader
332           command line, and use ONLY the built-in command line.
333
334           This is used to work around broken boot loaders.  This should
335           be set to 'N' under normal conditions.
336
337 config VMALLOC_RESERVE
338         hex
339         default 0x1000000
340
341 config HARDWALL
342         bool "Hardwall support to allow access to user dynamic network"
343         default y
344
345 config KERNEL_PL
346         int "Processor protection level for kernel"
347         range 1 2
348         default "1"
349         ---help---
350           This setting determines the processor protection level the
351           kernel will be built to run at.  Generally you should use
352           the default value here.
353
354 endmenu  # Tilera-specific configuration
355
356 menu "Bus options"
357
358 config PCI
359         bool "PCI support"
360         default y
361         select PCI_DOMAINS
362         select GENERIC_PCI_IOMAP
363         ---help---
364           Enable PCI root complex support, so PCIe endpoint devices can
365           be attached to the Tile chip.  Many, but not all, PCI devices
366           are supported under Tilera's root complex driver.
367
368 config PCI_DOMAINS
369         bool
370
371 config NO_IOMEM
372         def_bool !PCI
373
374 config NO_IOPORT
375         def_bool !PCI
376
377 source "drivers/pci/Kconfig"
378
379 config HOTPLUG
380         bool "Support for hot-pluggable devices"
381         ---help---
382           Say Y here if you want to plug devices into your computer while
383           the system is running, and be able to use them quickly.  In many
384           cases, the devices can likewise be unplugged at any time too.
385           One well-known example of this is USB.
386
387 source "drivers/pci/hotplug/Kconfig"
388
389 endmenu
390
391 menu "Executable file formats"
392
393 # only elf supported
394 config KCORE_ELF
395         def_bool y
396         depends on PROC_FS
397
398 source "fs/Kconfig.binfmt"
399
400 endmenu
401
402 source "net/Kconfig"
403
404 source "drivers/Kconfig"
405
406 source "fs/Kconfig"
407
408 source "arch/tile/Kconfig.debug"
409
410 source "security/Kconfig"
411
412 source "crypto/Kconfig"
413
414 source "lib/Kconfig"
415
416 source "arch/tile/kvm/Kconfig"