Merge tag 'armsoc-dt' of git://git.kernel.org/pub/scm/linux/kernel/git/soc/soc
[sfrench/cifs-2.6.git] / arch / ia64 / Kconfig
1 # SPDX-License-Identifier: GPL-2.0
2 config PGTABLE_LEVELS
3         int "Page Table Levels" if !IA64_PAGE_SIZE_64KB
4         range 3 4 if !IA64_PAGE_SIZE_64KB
5         default 3
6
7 menu "Processor type and features"
8
9 config IA64
10         bool
11         select ARCH_MIGHT_HAVE_PC_PARPORT
12         select ARCH_MIGHT_HAVE_PC_SERIO
13         select ACPI
14         select ACPI_NUMA if NUMA
15         select ARCH_SUPPORTS_ACPI
16         select ACPI_SYSTEM_POWER_STATES_SUPPORT if ACPI
17         select ARCH_MIGHT_HAVE_ACPI_PDC if ACPI
18         select FORCE_PCI
19         select PCI_DOMAINS if PCI
20         select PCI_MSI
21         select PCI_SYSCALL if PCI
22         select HAVE_UNSTABLE_SCHED_CLOCK
23         select HAVE_EXIT_THREAD
24         select HAVE_IDE
25         select HAVE_OPROFILE
26         select HAVE_KPROBES
27         select HAVE_KRETPROBES
28         select HAVE_FTRACE_MCOUNT_RECORD
29         select HAVE_DYNAMIC_FTRACE if (!ITANIUM)
30         select HAVE_FUNCTION_TRACER
31         select TTY
32         select HAVE_ARCH_TRACEHOOK
33         select HAVE_MEMBLOCK_NODE_MAP
34         select HAVE_VIRT_CPU_ACCOUNTING
35         select ARCH_HAS_DMA_COHERENT_TO_PFN
36         select ARCH_HAS_SYNC_DMA_FOR_CPU
37         select VIRT_TO_BUS
38         select GENERIC_IRQ_PROBE
39         select GENERIC_PENDING_IRQ if SMP
40         select GENERIC_IRQ_SHOW
41         select GENERIC_IRQ_LEGACY
42         select ARCH_HAVE_NMI_SAFE_CMPXCHG
43         select GENERIC_IOMAP
44         select GENERIC_SMP_IDLE_THREAD
45         select ARCH_TASK_STRUCT_ON_STACK
46         select ARCH_TASK_STRUCT_ALLOCATOR
47         select ARCH_THREAD_STACK_ALLOCATOR
48         select ARCH_CLOCKSOURCE_DATA
49         select GENERIC_TIME_VSYSCALL
50         select SWIOTLB
51         select SYSCTL_ARCH_UNALIGN_NO_WARN
52         select HAVE_MOD_ARCH_SPECIFIC
53         select MODULES_USE_ELF_RELA
54         select ARCH_USE_CMPXCHG_LOCKREF
55         select HAVE_ARCH_AUDITSYSCALL
56         select NEED_DMA_MAP_STATE
57         select NEED_SG_DMA_LENGTH
58         select NUMA if !FLATMEM
59         default y
60         help
61           The Itanium Processor Family is Intel's 64-bit successor to
62           the 32-bit X86 line.  The IA-64 Linux project has a home
63           page at <http://www.linuxia64.org/> and a mailing list at
64           <linux-ia64@vger.kernel.org>.
65
66 config 64BIT
67         bool
68         select ATA_NONSTANDARD if ATA
69         default y
70
71 config ZONE_DMA32
72         def_bool y
73
74 config QUICKLIST
75         bool
76         default y
77
78 config MMU
79         bool
80         default y
81
82 config STACKTRACE_SUPPORT
83         def_bool y
84
85 config GENERIC_LOCKBREAK
86         def_bool n
87
88 config HUGETLB_PAGE_SIZE_VARIABLE
89         bool
90         depends on HUGETLB_PAGE
91         default y
92
93 config GENERIC_CALIBRATE_DELAY
94         bool
95         default y
96
97 config HAVE_SETUP_PER_CPU_AREA
98         def_bool y
99
100 config DMI
101         bool
102         default y
103         select DMI_SCAN_MACHINE_NON_EFI_FALLBACK
104
105 config EFI
106         bool
107         select UCS2_STRING
108         default y
109
110 config SCHED_OMIT_FRAME_POINTER
111         bool
112         default y
113
114 config IA64_UNCACHED_ALLOCATOR
115         bool
116         select GENERIC_ALLOCATOR
117
118 config ARCH_USES_PG_UNCACHED
119         def_bool y
120         depends on IA64_UNCACHED_ALLOCATOR
121
122 config AUDIT_ARCH
123         bool
124         default y
125
126 choice
127         prompt "Processor type"
128         default ITANIUM
129
130 config ITANIUM
131         bool "Itanium"
132         help
133           Select your IA-64 processor type.  The default is Itanium.
134           This choice is safe for all IA-64 systems, but may not perform
135           optimally on systems with, say, Itanium 2 or newer processors.
136
137 config MCKINLEY
138         bool "Itanium 2"
139         help
140           Select this to configure for an Itanium 2 (McKinley) processor.
141
142 endchoice
143
144 choice
145         prompt "Kernel page size"
146         default IA64_PAGE_SIZE_16KB
147
148 config IA64_PAGE_SIZE_4KB
149         bool "4KB"
150         help
151           This lets you select the page size of the kernel.  For best IA-64
152           performance, a page size of 8KB or 16KB is recommended.  For best
153           IA-32 compatibility, a page size of 4KB should be selected (the vast
154           majority of IA-32 binaries work perfectly fine with a larger page
155           size).  For Itanium 2 or newer systems, a page size of 64KB can also
156           be selected.
157
158           4KB                For best IA-32 compatibility
159           8KB                For best IA-64 performance
160           16KB               For best IA-64 performance
161           64KB               Requires Itanium 2 or newer processor.
162
163           If you don't know what to do, choose 16KB.
164
165 config IA64_PAGE_SIZE_8KB
166         bool "8KB"
167
168 config IA64_PAGE_SIZE_16KB
169         bool "16KB"
170
171 config IA64_PAGE_SIZE_64KB
172         depends on !ITANIUM
173         bool "64KB"
174
175 endchoice
176
177 source "kernel/Kconfig.hz"
178
179 config IA64_BRL_EMU
180         bool
181         depends on ITANIUM
182         default y
183
184 # align cache-sensitive data to 128 bytes
185 config IA64_L1_CACHE_SHIFT
186         int
187         default "7" if MCKINLEY
188         default "6" if ITANIUM
189
190 config IA64_SGI_UV
191         bool "SGI-UV support"
192         help
193           Selecting this option will add specific support for running on SGI
194           UV based systems.  If you have an SGI UV system or are building a
195           distro kernel, select this option.
196
197 config IA64_HP_SBA_IOMMU
198         bool "HP SBA IOMMU support"
199         default y
200         help
201           Say Y here to add support for the SBA IOMMU found on HP zx1 and
202           sx1000 systems.  If you're unsure, answer Y.
203
204 config IA64_CYCLONE
205         bool "Cyclone (EXA) Time Source support"
206         help
207           Say Y here to enable support for IBM EXA Cyclone time source.
208           If you're unsure, answer N.
209
210 config FORCE_MAX_ZONEORDER
211         int "MAX_ORDER (11 - 17)"  if !HUGETLB_PAGE
212         range 11 17  if !HUGETLB_PAGE
213         default "17" if HUGETLB_PAGE
214         default "11"
215
216 config SMP
217         bool "Symmetric multi-processing support"
218         help
219           This enables support for systems with more than one CPU. If you have
220           a system with only one CPU, say N.  If you have a system with more
221           than one CPU, say Y.
222
223           If you say N here, the kernel will run on single and multiprocessor
224           systems, but will use only one CPU of a multiprocessor system.  If
225           you say Y here, the kernel will run on many, but not all,
226           single processor systems.  On a single processor system, the kernel
227           will run faster if you say N here.
228
229           See also the SMP-HOWTO available at
230           <http://www.tldp.org/docs.html#howto>.
231
232           If you don't know what to do here, say N.
233
234 config NR_CPUS
235         int "Maximum number of CPUs (2-4096)"
236         range 2 4096
237         depends on SMP
238         default "4096"
239         help
240           You should set this to the number of CPUs in your system, but
241           keep in mind that a kernel compiled for, e.g., 2 CPUs will boot but
242           only use 2 CPUs on a >2 CPU system.  Setting this to a value larger
243           than 64 will cause the use of a CPU mask array, causing a small
244           performance hit.
245
246 config HOTPLUG_CPU
247         bool "Support for hot-pluggable CPUs"
248         depends on SMP
249         default n
250         ---help---
251           Say Y here to experiment with turning CPUs off and on.  CPUs
252           can be controlled through /sys/devices/system/cpu/cpu#.
253           Say N if you want to disable CPU hotplug.
254
255 config ARCH_ENABLE_MEMORY_HOTPLUG
256         def_bool y
257
258 config ARCH_ENABLE_MEMORY_HOTREMOVE
259         def_bool y
260
261 config SCHED_SMT
262         bool "SMT scheduler support"
263         depends on SMP
264         help
265           Improves the CPU scheduler's decision making when dealing with
266           Intel IA64 chips with MultiThreading at a cost of slightly increased
267           overhead in some places. If unsure say N here.
268
269 config PERMIT_BSP_REMOVE
270         bool "Support removal of Bootstrap Processor"
271         depends on HOTPLUG_CPU
272         default n
273         ---help---
274         Say Y here if your platform SAL will support removal of BSP with HOTPLUG_CPU
275         support. 
276
277 config FORCE_CPEI_RETARGET
278         bool "Force assumption that CPEI can be re-targeted"
279         depends on PERMIT_BSP_REMOVE
280         default n
281         ---help---
282         Say Y if you need to force the assumption that CPEI can be re-targeted to
283         any cpu in the system. This hint is available via ACPI 3.0 specifications.
284         Tiger4 systems are capable of re-directing CPEI to any CPU other than BSP.
285         This option it useful to enable this feature on older BIOS's as well.
286         You can also enable this by using boot command line option force_cpei=1.
287
288 config ARCH_SELECT_MEMORY_MODEL
289         def_bool y
290
291 config ARCH_DISCONTIGMEM_ENABLE
292         def_bool y
293         help
294           Say Y to support efficient handling of discontiguous physical memory,
295           for architectures which are either NUMA (Non-Uniform Memory Access)
296           or have huge holes in the physical address space for other reasons.
297           See <file:Documentation/vm/numa.rst> for more.
298
299 config ARCH_FLATMEM_ENABLE
300         def_bool y
301
302 config ARCH_SPARSEMEM_ENABLE
303         def_bool y
304         depends on ARCH_DISCONTIGMEM_ENABLE
305         select SPARSEMEM_VMEMMAP_ENABLE
306
307 config ARCH_DISCONTIGMEM_DEFAULT
308         def_bool y
309         depends on ARCH_DISCONTIGMEM_ENABLE
310
311 config NUMA
312         bool "NUMA support"
313         depends on !FLATMEM
314         help
315           Say Y to compile the kernel to support NUMA (Non-Uniform Memory
316           Access).  This option is for configuring high-end multiprocessor
317           server systems.  If in doubt, say N.
318
319 config NODES_SHIFT
320         int "Max num nodes shift(3-10)"
321         range 3 10
322         default "10"
323         depends on NEED_MULTIPLE_NODES
324         help
325           This option specifies the maximum number of nodes in your SSI system.
326           MAX_NUMNODES will be 2^(This value).
327           If in doubt, use the default.
328
329 # VIRTUAL_MEM_MAP and FLAT_NODE_MEM_MAP are functionally equivalent.
330 # VIRTUAL_MEM_MAP has been retained for historical reasons.
331 config VIRTUAL_MEM_MAP
332         bool "Virtual mem map"
333         depends on !SPARSEMEM
334         default y
335         help
336           Say Y to compile the kernel with support for a virtual mem map.
337           This code also only takes effect if a memory hole of greater than
338           1 Gb is found during boot.  You must turn this option on if you
339           require the DISCONTIGMEM option for your machine. If you are
340           unsure, say Y.
341
342 config HOLES_IN_ZONE
343         bool
344         default y if VIRTUAL_MEM_MAP
345
346 config HAVE_ARCH_EARLY_PFN_TO_NID
347         def_bool NUMA && SPARSEMEM
348
349 config HAVE_ARCH_NODEDATA_EXTENSION
350         def_bool y
351         depends on NUMA
352
353 config USE_PERCPU_NUMA_NODE_ID
354         def_bool y
355         depends on NUMA
356
357 config HAVE_MEMORYLESS_NODES
358         def_bool NUMA
359
360 config ARCH_PROC_KCORE_TEXT
361         def_bool y
362         depends on PROC_KCORE
363
364 config IA64_MCA_RECOVERY
365         tristate "MCA recovery from errors other than TLB."
366
367 config PERFMON
368         bool "Performance monitor support"
369         depends on BROKEN
370         help
371           Selects whether support for the IA-64 performance monitor hardware
372           is included in the kernel.  This makes some kernel data-structures a
373           little bigger and slows down execution a bit, but it is generally
374           a good idea to turn this on.  If you're unsure, say Y.
375
376 config IA64_PALINFO
377         tristate "/proc/pal support"
378         help
379           If you say Y here, you are able to get PAL (Processor Abstraction
380           Layer) information in /proc/pal.  This contains useful information
381           about the processors in your systems, such as cache and TLB sizes
382           and the PAL firmware version in use.
383
384           To use this option, you have to ensure that the "/proc file system
385           support" (CONFIG_PROC_FS) is enabled, too.
386
387 config IA64_MC_ERR_INJECT
388         tristate "MC error injection support"
389         help
390           Adds support for MC error injection. If enabled, the kernel 
391           will provide a sysfs interface for user applications to
392           call MC error injection PAL procedures to inject various errors.
393           This is a useful tool for MCA testing.
394
395           If you're unsure, do not select this option.
396
397 config IA64_ESI
398         bool "ESI (Extensible SAL Interface) support"
399         help
400           If you say Y here, support is built into the kernel to
401           make ESI calls.  ESI calls are used to support vendor-specific
402           firmware extensions, such as the ability to inject memory-errors
403           for test-purposes.  If you're unsure, say N.
404
405 config IA64_HP_AML_NFW
406         bool "Support ACPI AML calls to native firmware"
407         help
408           This driver installs a global ACPI Operation Region handler for
409           region 0xA1.  AML methods can use this OpRegion to call arbitrary
410           native firmware functions.  The driver installs the OpRegion
411           handler if there is an HPQ5001 device or if the user supplies
412           the "force" module parameter, e.g., with the "aml_nfw.force"
413           kernel command line option.
414
415 config KEXEC
416         bool "kexec system call"
417         depends on !SMP || HOTPLUG_CPU
418         select KEXEC_CORE
419         help
420           kexec is a system call that implements the ability to shutdown your
421           current kernel, and to start another kernel.  It is like a reboot
422           but it is independent of the system firmware.   And like a reboot
423           you can start any kernel with it, not just Linux.
424
425           The name comes from the similarity to the exec system call.
426
427           It is an ongoing process to be certain the hardware in a machine
428           is properly shutdown, so do not be surprised if this code does not
429           initially work for you.  As of this writing the exact hardware
430           interface is strongly in flux, so no good recommendation can be
431           made.
432
433 config CRASH_DUMP
434           bool "kernel crash dumps"
435           depends on IA64_MCA_RECOVERY && (!SMP || HOTPLUG_CPU)
436           help
437             Generate crash dump after being started by kexec.
438
439 source "drivers/firmware/Kconfig"
440
441 endmenu
442
443 menu "Power management and ACPI options"
444
445 source "kernel/power/Kconfig"
446
447 source "drivers/acpi/Kconfig"
448
449 if PM
450 menu "CPU Frequency scaling"
451 source "drivers/cpufreq/Kconfig"
452 endmenu
453 endif
454
455 endmenu
456
457 config MSPEC
458         tristate "Memory special operations driver"
459         depends on IA64
460         select IA64_UNCACHED_ALLOCATOR
461         help
462           If you have an ia64 and you want to enable memory special
463           operations support (formerly known as fetchop), say Y here,
464           otherwise say N.