Loading...
1# SPDX-License-Identifier: GPL-2.0
2config 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
7menu "Processor type and features"
8
9config IA64
10 bool
11 select ARCH_HAS_DMA_MARK_CLEAN
12 select ARCH_MIGHT_HAVE_PC_PARPORT
13 select ARCH_MIGHT_HAVE_PC_SERIO
14 select ACPI
15 select ACPI_NUMA if NUMA
16 select ARCH_ENABLE_MEMORY_HOTPLUG
17 select ARCH_ENABLE_MEMORY_HOTREMOVE
18 select ARCH_SUPPORTS_ACPI
19 select ACPI_SYSTEM_POWER_STATES_SUPPORT if ACPI
20 select ARCH_MIGHT_HAVE_ACPI_PDC if ACPI
21 select FORCE_PCI
22 select PCI_DOMAINS if PCI
23 select PCI_MSI
24 select PCI_SYSCALL if PCI
25 select HAVE_ASM_MODVERSIONS
26 select HAVE_UNSTABLE_SCHED_CLOCK
27 select HAVE_EXIT_THREAD
28 select HAVE_KPROBES
29 select HAVE_KRETPROBES
30 select HAVE_FTRACE_MCOUNT_RECORD
31 select HAVE_DYNAMIC_FTRACE if (!ITANIUM)
32 select HAVE_FUNCTION_TRACER
33 select TTY
34 select HAVE_ARCH_TRACEHOOK
35 select HAVE_VIRT_CPU_ACCOUNTING
36 select HUGETLB_PAGE_SIZE_VARIABLE if HUGETLB_PAGE
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 LEGACY_TIMER_TICK
51 select SWIOTLB
52 select SYSCTL_ARCH_UNALIGN_NO_WARN
53 select HAVE_MOD_ARCH_SPECIFIC
54 select MODULES_USE_ELF_RELA
55 select ARCH_USE_CMPXCHG_LOCKREF
56 select HAVE_ARCH_AUDITSYSCALL
57 select NEED_DMA_MAP_STATE
58 select NEED_SG_DMA_LENGTH
59 select NUMA if !FLATMEM
60 select PCI_MSI_ARCH_FALLBACKS if PCI_MSI
61 select SET_FS
62 select ZONE_DMA32
63 default y
64 help
65 The Itanium Processor Family is Intel's 64-bit successor to
66 the 32-bit X86 line. The IA-64 Linux project has a home
67 page at <http://www.linuxia64.org/> and a mailing list at
68 <linux-ia64@vger.kernel.org>.
69
70config 64BIT
71 bool
72 select ATA_NONSTANDARD if ATA
73 default y
74
75config MMU
76 bool
77 default y
78
79config STACKTRACE_SUPPORT
80 def_bool y
81
82config GENERIC_LOCKBREAK
83 def_bool n
84
85config GENERIC_CALIBRATE_DELAY
86 bool
87 default y
88
89config HAVE_SETUP_PER_CPU_AREA
90 def_bool y
91
92config DMI
93 bool
94 default y
95 select DMI_SCAN_MACHINE_NON_EFI_FALLBACK
96
97config EFI
98 bool
99 select UCS2_STRING
100 default y
101
102config SCHED_OMIT_FRAME_POINTER
103 bool
104 default y
105
106config IA64_UNCACHED_ALLOCATOR
107 bool
108 select GENERIC_ALLOCATOR
109
110config ARCH_USES_PG_UNCACHED
111 def_bool y
112 depends on IA64_UNCACHED_ALLOCATOR
113
114config AUDIT_ARCH
115 bool
116 default y
117
118choice
119 prompt "Processor type"
120 default ITANIUM
121
122config ITANIUM
123 bool "Itanium"
124 help
125 Select your IA-64 processor type. The default is Itanium.
126 This choice is safe for all IA-64 systems, but may not perform
127 optimally on systems with, say, Itanium 2 or newer processors.
128
129config MCKINLEY
130 bool "Itanium 2"
131 help
132 Select this to configure for an Itanium 2 (McKinley) processor.
133
134endchoice
135
136choice
137 prompt "Kernel page size"
138 default IA64_PAGE_SIZE_16KB
139
140config IA64_PAGE_SIZE_4KB
141 bool "4KB"
142 help
143 This lets you select the page size of the kernel. For best IA-64
144 performance, a page size of 8KB or 16KB is recommended. For best
145 IA-32 compatibility, a page size of 4KB should be selected (the vast
146 majority of IA-32 binaries work perfectly fine with a larger page
147 size). For Itanium 2 or newer systems, a page size of 64KB can also
148 be selected.
149
150 4KB For best IA-32 compatibility
151 8KB For best IA-64 performance
152 16KB For best IA-64 performance
153 64KB Requires Itanium 2 or newer processor.
154
155 If you don't know what to do, choose 16KB.
156
157config IA64_PAGE_SIZE_8KB
158 bool "8KB"
159
160config IA64_PAGE_SIZE_16KB
161 bool "16KB"
162
163config IA64_PAGE_SIZE_64KB
164 depends on !ITANIUM
165 bool "64KB"
166
167endchoice
168
169source "kernel/Kconfig.hz"
170
171config IA64_BRL_EMU
172 bool
173 depends on ITANIUM
174 default y
175
176# align cache-sensitive data to 128 bytes
177config IA64_L1_CACHE_SHIFT
178 int
179 default "7" if MCKINLEY
180 default "6" if ITANIUM
181
182config IA64_SGI_UV
183 bool "SGI-UV support"
184 help
185 Selecting this option will add specific support for running on SGI
186 UV based systems. If you have an SGI UV system or are building a
187 distro kernel, select this option.
188
189config IA64_HP_SBA_IOMMU
190 bool "HP SBA IOMMU support"
191 select DMA_OPS
192 default y
193 help
194 Say Y here to add support for the SBA IOMMU found on HP zx1 and
195 sx1000 systems. If you're unsure, answer Y.
196
197config IA64_CYCLONE
198 bool "Cyclone (EXA) Time Source support"
199 help
200 Say Y here to enable support for IBM EXA Cyclone time source.
201 If you're unsure, answer N.
202
203config FORCE_MAX_ZONEORDER
204 int "MAX_ORDER (11 - 17)" if !HUGETLB_PAGE
205 range 11 17 if !HUGETLB_PAGE
206 default "17" if HUGETLB_PAGE
207 default "11"
208
209config SMP
210 bool "Symmetric multi-processing support"
211 help
212 This enables support for systems with more than one CPU. If you have
213 a system with only one CPU, say N. If you have a system with more
214 than one CPU, say Y.
215
216 If you say N here, the kernel will run on single and multiprocessor
217 systems, but will use only one CPU of a multiprocessor system. If
218 you say Y here, the kernel will run on many, but not all,
219 single processor systems. On a single processor system, the kernel
220 will run faster if you say N here.
221
222 See also the SMP-HOWTO available at
223 <http://www.tldp.org/docs.html#howto>.
224
225 If you don't know what to do here, say N.
226
227config NR_CPUS
228 int "Maximum number of CPUs (2-4096)"
229 range 2 4096
230 depends on SMP
231 default "4096"
232 help
233 You should set this to the number of CPUs in your system, but
234 keep in mind that a kernel compiled for, e.g., 2 CPUs will boot but
235 only use 2 CPUs on a >2 CPU system. Setting this to a value larger
236 than 64 will cause the use of a CPU mask array, causing a small
237 performance hit.
238
239config HOTPLUG_CPU
240 bool "Support for hot-pluggable CPUs"
241 depends on SMP
242 default n
243 help
244 Say Y here to experiment with turning CPUs off and on. CPUs
245 can be controlled through /sys/devices/system/cpu/cpu#.
246 Say N if you want to disable CPU hotplug.
247
248config SCHED_SMT
249 bool "SMT scheduler support"
250 depends on SMP
251 help
252 Improves the CPU scheduler's decision making when dealing with
253 Intel IA64 chips with MultiThreading at a cost of slightly increased
254 overhead in some places. If unsure say N here.
255
256config PERMIT_BSP_REMOVE
257 bool "Support removal of Bootstrap Processor"
258 depends on HOTPLUG_CPU
259 default n
260 help
261 Say Y here if your platform SAL will support removal of BSP with HOTPLUG_CPU
262 support.
263
264config FORCE_CPEI_RETARGET
265 bool "Force assumption that CPEI can be re-targeted"
266 depends on PERMIT_BSP_REMOVE
267 default n
268 help
269 Say Y if you need to force the assumption that CPEI can be re-targeted to
270 any cpu in the system. This hint is available via ACPI 3.0 specifications.
271 Tiger4 systems are capable of re-directing CPEI to any CPU other than BSP.
272 This option it useful to enable this feature on older BIOS's as well.
273 You can also enable this by using boot command line option force_cpei=1.
274
275config ARCH_SELECT_MEMORY_MODEL
276 def_bool y
277
278config ARCH_FLATMEM_ENABLE
279 def_bool y
280
281config ARCH_SPARSEMEM_ENABLE
282 def_bool y
283 select SPARSEMEM_VMEMMAP_ENABLE
284
285config ARCH_SPARSEMEM_DEFAULT
286 def_bool y
287 depends on ARCH_SPARSEMEM_ENABLE
288
289config NUMA
290 bool "NUMA support"
291 depends on !FLATMEM
292 select SMP
293 help
294 Say Y to compile the kernel to support NUMA (Non-Uniform Memory
295 Access). This option is for configuring high-end multiprocessor
296 server systems. If in doubt, say N.
297
298config NODES_SHIFT
299 int "Max num nodes shift(3-10)"
300 range 3 10
301 default "10"
302 depends on NUMA
303 help
304 This option specifies the maximum number of nodes in your SSI system.
305 MAX_NUMNODES will be 2^(This value).
306 If in doubt, use the default.
307
308config HAVE_ARCH_NODEDATA_EXTENSION
309 def_bool y
310 depends on NUMA
311
312config USE_PERCPU_NUMA_NODE_ID
313 def_bool y
314 depends on NUMA
315
316config HAVE_MEMORYLESS_NODES
317 def_bool NUMA
318
319config ARCH_PROC_KCORE_TEXT
320 def_bool y
321 depends on PROC_KCORE
322
323config IA64_MCA_RECOVERY
324 tristate "MCA recovery from errors other than TLB."
325
326config IA64_PALINFO
327 tristate "/proc/pal support"
328 help
329 If you say Y here, you are able to get PAL (Processor Abstraction
330 Layer) information in /proc/pal. This contains useful information
331 about the processors in your systems, such as cache and TLB sizes
332 and the PAL firmware version in use.
333
334 To use this option, you have to ensure that the "/proc file system
335 support" (CONFIG_PROC_FS) is enabled, too.
336
337config IA64_MC_ERR_INJECT
338 tristate "MC error injection support"
339 help
340 Adds support for MC error injection. If enabled, the kernel
341 will provide a sysfs interface for user applications to
342 call MC error injection PAL procedures to inject various errors.
343 This is a useful tool for MCA testing.
344
345 If you're unsure, do not select this option.
346
347config IA64_ESI
348 bool "ESI (Extensible SAL Interface) support"
349 help
350 If you say Y here, support is built into the kernel to
351 make ESI calls. ESI calls are used to support vendor-specific
352 firmware extensions, such as the ability to inject memory-errors
353 for test-purposes. If you're unsure, say N.
354
355config IA64_HP_AML_NFW
356 bool "Support ACPI AML calls to native firmware"
357 help
358 This driver installs a global ACPI Operation Region handler for
359 region 0xA1. AML methods can use this OpRegion to call arbitrary
360 native firmware functions. The driver installs the OpRegion
361 handler if there is an HPQ5001 device or if the user supplies
362 the "force" module parameter, e.g., with the "aml_nfw.force"
363 kernel command line option.
364
365config KEXEC
366 bool "kexec system call"
367 depends on !SMP || HOTPLUG_CPU
368 select KEXEC_CORE
369 help
370 kexec is a system call that implements the ability to shutdown your
371 current kernel, and to start another kernel. It is like a reboot
372 but it is independent of the system firmware. And like a reboot
373 you can start any kernel with it, not just Linux.
374
375 The name comes from the similarity to the exec system call.
376
377 It is an ongoing process to be certain the hardware in a machine
378 is properly shutdown, so do not be surprised if this code does not
379 initially work for you. As of this writing the exact hardware
380 interface is strongly in flux, so no good recommendation can be
381 made.
382
383config CRASH_DUMP
384 bool "kernel crash dumps"
385 depends on IA64_MCA_RECOVERY && (!SMP || HOTPLUG_CPU)
386 help
387 Generate crash dump after being started by kexec.
388
389source "drivers/firmware/Kconfig"
390
391endmenu
392
393menu "Power management and ACPI options"
394
395source "kernel/power/Kconfig"
396
397source "drivers/acpi/Kconfig"
398
399if PM
400menu "CPU Frequency scaling"
401source "drivers/cpufreq/Kconfig"
402endmenu
403endif
404
405endmenu
406
407config MSPEC
408 tristate "Memory special operations driver"
409 depends on IA64
410 select IA64_UNCACHED_ALLOCATOR
411 help
412 If you have an ia64 and you want to enable memory special
413 operations support (formerly known as fetchop), say Y here,
414 otherwise say N.
1source "init/Kconfig"
2
3source "kernel/Kconfig.freezer"
4
5menu "Processor type and features"
6
7config IA64
8 bool
9 select PCI if (!IA64_HP_SIM)
10 select ACPI if (!IA64_HP_SIM)
11 select PM if (!IA64_HP_SIM)
12 select ARCH_SUPPORTS_MSI
13 select HAVE_UNSTABLE_SCHED_CLOCK
14 select HAVE_IDE
15 select HAVE_OPROFILE
16 select HAVE_KPROBES
17 select HAVE_KRETPROBES
18 select HAVE_FTRACE_MCOUNT_RECORD
19 select HAVE_DYNAMIC_FTRACE if (!ITANIUM)
20 select HAVE_FUNCTION_TRACER
21 select HAVE_DMA_ATTRS
22 select HAVE_KVM
23 select HAVE_ARCH_TRACEHOOK
24 select HAVE_DMA_API_DEBUG
25 select HAVE_GENERIC_HARDIRQS
26 select GENERIC_IRQ_PROBE
27 select GENERIC_PENDING_IRQ if SMP
28 select IRQ_PER_CPU
29 select GENERIC_IRQ_SHOW
30 select ARCH_WANT_OPTIONAL_GPIOLIB
31 select ARCH_HAVE_NMI_SAFE_CMPXCHG
32 default y
33 help
34 The Itanium Processor Family is Intel's 64-bit successor to
35 the 32-bit X86 line. The IA-64 Linux project has a home
36 page at <http://www.linuxia64.org/> and a mailing list at
37 <linux-ia64@vger.kernel.org>.
38
39config 64BIT
40 bool
41 select ATA_NONSTANDARD if ATA
42 default y
43
44config ZONE_DMA
45 def_bool y
46 depends on !IA64_SGI_SN2
47
48config QUICKLIST
49 bool
50 default y
51
52config MMU
53 bool
54 default y
55
56config ARCH_DMA_ADDR_T_64BIT
57 def_bool y
58
59config NEED_DMA_MAP_STATE
60 def_bool y
61
62config NEED_SG_DMA_LENGTH
63 def_bool y
64
65config SWIOTLB
66 bool
67
68config STACKTRACE_SUPPORT
69 def_bool y
70
71config GENERIC_LOCKBREAK
72 def_bool n
73
74config RWSEM_XCHGADD_ALGORITHM
75 bool
76 default y
77
78config HUGETLB_PAGE_SIZE_VARIABLE
79 bool
80 depends on HUGETLB_PAGE
81 default y
82
83config GENERIC_CALIBRATE_DELAY
84 bool
85 default y
86
87config GENERIC_TIME_VSYSCALL
88 bool
89 default y
90
91config HAVE_SETUP_PER_CPU_AREA
92 def_bool y
93
94config GENERIC_GPIO
95 def_bool y
96
97config DMI
98 bool
99 default y
100
101config EFI
102 bool
103 default y
104
105config GENERIC_IOMAP
106 bool
107 default y
108
109config ARCH_CLOCKSOURCE_DATA
110 def_bool y
111
112config SCHED_OMIT_FRAME_POINTER
113 bool
114 default y
115
116config IA64_UNCACHED_ALLOCATOR
117 bool
118 select GENERIC_ALLOCATOR
119
120config ARCH_USES_PG_UNCACHED
121 def_bool y
122 depends on IA64_UNCACHED_ALLOCATOR
123
124config AUDIT_ARCH
125 bool
126 default y
127
128menuconfig PARAVIRT_GUEST
129 bool "Paravirtualized guest support"
130 help
131 Say Y here to get to see options related to running Linux under
132 various hypervisors. This option alone does not add any kernel code.
133
134 If you say N, all options in this submenu will be skipped and disabled.
135
136if PARAVIRT_GUEST
137
138config PARAVIRT
139 bool "Enable paravirtualization code"
140 depends on PARAVIRT_GUEST
141 default y
142 bool
143 default y
144 help
145 This changes the kernel so it can modify itself when it is run
146 under a hypervisor, potentially improving performance significantly
147 over full virtualization. However, when run without a hypervisor
148 the kernel is theoretically slower and slightly larger.
149
150
151source "arch/ia64/xen/Kconfig"
152
153endif
154
155choice
156 prompt "System type"
157 default IA64_GENERIC
158
159config IA64_GENERIC
160 bool "generic"
161 select NUMA
162 select ACPI_NUMA
163 select SWIOTLB
164 select PCI_MSI
165 help
166 This selects the system type of your hardware. A "generic" kernel
167 will run on any supported IA-64 system. However, if you configure
168 a kernel for your specific system, it will be faster and smaller.
169
170 generic For any supported IA-64 system
171 DIG-compliant For DIG ("Developer's Interface Guide") compliant systems
172 DIG+Intel+IOMMU For DIG systems with Intel IOMMU
173 HP-zx1/sx1000 For HP systems
174 HP-zx1/sx1000+swiotlb For HP systems with (broken) DMA-constrained devices.
175 SGI-SN2 For SGI Altix systems
176 SGI-UV For SGI UV systems
177 Ski-simulator For the HP simulator <http://www.hpl.hp.com/research/linux/ski/>
178 Xen-domU For xen domU system
179
180 If you don't know what to do, choose "generic".
181
182config IA64_DIG
183 bool "DIG-compliant"
184 select SWIOTLB
185
186config IA64_DIG_VTD
187 bool "DIG+Intel+IOMMU"
188 select DMAR
189 select PCI_MSI
190
191config IA64_HP_ZX1
192 bool "HP-zx1/sx1000"
193 help
194 Build a kernel that runs on HP zx1 and sx1000 systems. This adds
195 support for the HP I/O MMU.
196
197config IA64_HP_ZX1_SWIOTLB
198 bool "HP-zx1/sx1000 with software I/O TLB"
199 select SWIOTLB
200 help
201 Build a kernel that runs on HP zx1 and sx1000 systems even when they
202 have broken PCI devices which cannot DMA to full 32 bits. Apart
203 from support for the HP I/O MMU, this includes support for the software
204 I/O TLB, which allows supporting the broken devices at the expense of
205 wasting some kernel memory (about 2MB by default).
206
207config IA64_SGI_SN2
208 bool "SGI-SN2"
209 select NUMA
210 select ACPI_NUMA
211 help
212 Selecting this option will optimize the kernel for use on sn2 based
213 systems, but the resulting kernel binary will not run on other
214 types of ia64 systems. If you have an SGI Altix system, it's safe
215 to select this option. If in doubt, select ia64 generic support
216 instead.
217
218config IA64_SGI_UV
219 bool "SGI-UV"
220 select NUMA
221 select ACPI_NUMA
222 select SWIOTLB
223 help
224 Selecting this option will optimize the kernel for use on UV based
225 systems, but the resulting kernel binary will not run on other
226 types of ia64 systems. If you have an SGI UV system, it's safe
227 to select this option. If in doubt, select ia64 generic support
228 instead.
229
230config IA64_HP_SIM
231 bool "Ski-simulator"
232 select SWIOTLB
233
234config IA64_XEN_GUEST
235 bool "Xen guest"
236 select SWIOTLB
237 depends on XEN
238 help
239 Build a kernel that runs on Xen guest domain. At this moment only
240 16KB page size in supported.
241
242endchoice
243
244choice
245 prompt "Processor type"
246 default ITANIUM
247
248config ITANIUM
249 bool "Itanium"
250 help
251 Select your IA-64 processor type. The default is Itanium.
252 This choice is safe for all IA-64 systems, but may not perform
253 optimally on systems with, say, Itanium 2 or newer processors.
254
255config MCKINLEY
256 bool "Itanium 2"
257 help
258 Select this to configure for an Itanium 2 (McKinley) processor.
259
260endchoice
261
262choice
263 prompt "Kernel page size"
264 default IA64_PAGE_SIZE_16KB
265
266config IA64_PAGE_SIZE_4KB
267 bool "4KB"
268 help
269 This lets you select the page size of the kernel. For best IA-64
270 performance, a page size of 8KB or 16KB is recommended. For best
271 IA-32 compatibility, a page size of 4KB should be selected (the vast
272 majority of IA-32 binaries work perfectly fine with a larger page
273 size). For Itanium 2 or newer systems, a page size of 64KB can also
274 be selected.
275
276 4KB For best IA-32 compatibility
277 8KB For best IA-64 performance
278 16KB For best IA-64 performance
279 64KB Requires Itanium 2 or newer processor.
280
281 If you don't know what to do, choose 16KB.
282
283config IA64_PAGE_SIZE_8KB
284 bool "8KB"
285
286config IA64_PAGE_SIZE_16KB
287 bool "16KB"
288
289config IA64_PAGE_SIZE_64KB
290 depends on !ITANIUM
291 bool "64KB"
292
293endchoice
294
295choice
296 prompt "Page Table Levels"
297 default PGTABLE_3
298
299config PGTABLE_3
300 bool "3 Levels"
301
302config PGTABLE_4
303 depends on !IA64_PAGE_SIZE_64KB
304 bool "4 Levels"
305
306endchoice
307
308if IA64_HP_SIM
309config HZ
310 default 32
311endif
312
313if !IA64_HP_SIM
314source kernel/Kconfig.hz
315endif
316
317config IA64_BRL_EMU
318 bool
319 depends on ITANIUM
320 default y
321
322# align cache-sensitive data to 128 bytes
323config IA64_L1_CACHE_SHIFT
324 int
325 default "7" if MCKINLEY
326 default "6" if ITANIUM
327
328config IA64_CYCLONE
329 bool "Cyclone (EXA) Time Source support"
330 help
331 Say Y here to enable support for IBM EXA Cyclone time source.
332 If you're unsure, answer N.
333
334config IOSAPIC
335 bool
336 depends on !IA64_HP_SIM
337 default y
338
339config FORCE_MAX_ZONEORDER
340 int "MAX_ORDER (11 - 17)" if !HUGETLB_PAGE
341 range 11 17 if !HUGETLB_PAGE
342 default "17" if HUGETLB_PAGE
343 default "11"
344
345config VIRT_CPU_ACCOUNTING
346 bool "Deterministic task and CPU time accounting"
347 default n
348 help
349 Select this option to enable more accurate task and CPU time
350 accounting. This is done by reading a CPU counter on each
351 kernel entry and exit and on transitions within the kernel
352 between system, softirq and hardirq state, so there is a
353 small performance impact.
354 If in doubt, say N here.
355
356config SMP
357 bool "Symmetric multi-processing support"
358 select USE_GENERIC_SMP_HELPERS
359 help
360 This enables support for systems with more than one CPU. If you have
361 a system with only one CPU, say N. If you have a system with more
362 than one CPU, say Y.
363
364 If you say N here, the kernel will run on single and multiprocessor
365 systems, but will use only one CPU of a multiprocessor system. If
366 you say Y here, the kernel will run on many, but not all,
367 single processor systems. On a single processor system, the kernel
368 will run faster if you say N here.
369
370 See also the SMP-HOWTO available at
371 <http://www.tldp.org/docs.html#howto>.
372
373 If you don't know what to do here, say N.
374
375config NR_CPUS
376 int "Maximum number of CPUs (2-4096)"
377 range 2 4096
378 depends on SMP
379 default "4096"
380 help
381 You should set this to the number of CPUs in your system, but
382 keep in mind that a kernel compiled for, e.g., 2 CPUs will boot but
383 only use 2 CPUs on a >2 CPU system. Setting this to a value larger
384 than 64 will cause the use of a CPU mask array, causing a small
385 performance hit.
386
387config HOTPLUG_CPU
388 bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
389 depends on SMP && EXPERIMENTAL
390 select HOTPLUG
391 default n
392 ---help---
393 Say Y here to experiment with turning CPUs off and on. CPUs
394 can be controlled through /sys/devices/system/cpu/cpu#.
395 Say N if you want to disable CPU hotplug.
396
397config ARCH_ENABLE_MEMORY_HOTPLUG
398 def_bool y
399
400config ARCH_ENABLE_MEMORY_HOTREMOVE
401 def_bool y
402
403config SCHED_SMT
404 bool "SMT scheduler support"
405 depends on SMP
406 help
407 Improves the CPU scheduler's decision making when dealing with
408 Intel IA64 chips with MultiThreading at a cost of slightly increased
409 overhead in some places. If unsure say N here.
410
411config PERMIT_BSP_REMOVE
412 bool "Support removal of Bootstrap Processor"
413 depends on HOTPLUG_CPU
414 default n
415 ---help---
416 Say Y here if your platform SAL will support removal of BSP with HOTPLUG_CPU
417 support.
418
419config FORCE_CPEI_RETARGET
420 bool "Force assumption that CPEI can be re-targeted"
421 depends on PERMIT_BSP_REMOVE
422 default n
423 ---help---
424 Say Y if you need to force the assumption that CPEI can be re-targeted to
425 any cpu in the system. This hint is available via ACPI 3.0 specifications.
426 Tiger4 systems are capable of re-directing CPEI to any CPU other than BSP.
427 This option it useful to enable this feature on older BIOS's as well.
428 You can also enable this by using boot command line option force_cpei=1.
429
430source "kernel/Kconfig.preempt"
431
432source "mm/Kconfig"
433
434config ARCH_SELECT_MEMORY_MODEL
435 def_bool y
436
437config ARCH_DISCONTIGMEM_ENABLE
438 def_bool y
439 help
440 Say Y to support efficient handling of discontiguous physical memory,
441 for architectures which are either NUMA (Non-Uniform Memory Access)
442 or have huge holes in the physical address space for other reasons.
443 See <file:Documentation/vm/numa> for more.
444
445config ARCH_FLATMEM_ENABLE
446 def_bool y
447
448config ARCH_SPARSEMEM_ENABLE
449 def_bool y
450 depends on ARCH_DISCONTIGMEM_ENABLE
451 select SPARSEMEM_VMEMMAP_ENABLE
452
453config ARCH_DISCONTIGMEM_DEFAULT
454 def_bool y if (IA64_SGI_SN2 || IA64_GENERIC || IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB)
455 depends on ARCH_DISCONTIGMEM_ENABLE
456
457config NUMA
458 bool "NUMA support"
459 depends on !IA64_HP_SIM && !FLATMEM
460 default y if IA64_SGI_SN2
461 select ACPI_NUMA if ACPI
462 help
463 Say Y to compile the kernel to support NUMA (Non-Uniform Memory
464 Access). This option is for configuring high-end multiprocessor
465 server systems. If in doubt, say N.
466
467config NODES_SHIFT
468 int "Max num nodes shift(3-10)"
469 range 3 10
470 default "10"
471 depends on NEED_MULTIPLE_NODES
472 help
473 This option specifies the maximum number of nodes in your SSI system.
474 MAX_NUMNODES will be 2^(This value).
475 If in doubt, use the default.
476
477config ARCH_POPULATES_NODE_MAP
478 def_bool y
479
480# VIRTUAL_MEM_MAP and FLAT_NODE_MEM_MAP are functionally equivalent.
481# VIRTUAL_MEM_MAP has been retained for historical reasons.
482config VIRTUAL_MEM_MAP
483 bool "Virtual mem map"
484 depends on !SPARSEMEM
485 default y if !IA64_HP_SIM
486 help
487 Say Y to compile the kernel with support for a virtual mem map.
488 This code also only takes effect if a memory hole of greater than
489 1 Gb is found during boot. You must turn this option on if you
490 require the DISCONTIGMEM option for your machine. If you are
491 unsure, say Y.
492
493config HOLES_IN_ZONE
494 bool
495 default y if VIRTUAL_MEM_MAP
496
497config HAVE_ARCH_EARLY_PFN_TO_NID
498 def_bool NUMA && SPARSEMEM
499
500config HAVE_ARCH_NODEDATA_EXTENSION
501 def_bool y
502 depends on NUMA
503
504config USE_PERCPU_NUMA_NODE_ID
505 def_bool y
506 depends on NUMA
507
508config HAVE_MEMORYLESS_NODES
509 def_bool NUMA
510
511config ARCH_PROC_KCORE_TEXT
512 def_bool y
513 depends on PROC_KCORE
514
515config IA64_MCA_RECOVERY
516 tristate "MCA recovery from errors other than TLB."
517
518config PERFMON
519 bool "Performance monitor support"
520 help
521 Selects whether support for the IA-64 performance monitor hardware
522 is included in the kernel. This makes some kernel data-structures a
523 little bigger and slows down execution a bit, but it is generally
524 a good idea to turn this on. If you're unsure, say Y.
525
526config IA64_PALINFO
527 tristate "/proc/pal support"
528 help
529 If you say Y here, you are able to get PAL (Processor Abstraction
530 Layer) information in /proc/pal. This contains useful information
531 about the processors in your systems, such as cache and TLB sizes
532 and the PAL firmware version in use.
533
534 To use this option, you have to ensure that the "/proc file system
535 support" (CONFIG_PROC_FS) is enabled, too.
536
537config IA64_MC_ERR_INJECT
538 tristate "MC error injection support"
539 help
540 Adds support for MC error injection. If enabled, the kernel
541 will provide a sysfs interface for user applications to
542 call MC error injection PAL procedures to inject various errors.
543 This is a useful tool for MCA testing.
544
545 If you're unsure, do not select this option.
546
547config SGI_SN
548 def_bool y if (IA64_SGI_SN2 || IA64_GENERIC)
549
550config IA64_ESI
551 bool "ESI (Extensible SAL Interface) support"
552 help
553 If you say Y here, support is built into the kernel to
554 make ESI calls. ESI calls are used to support vendor-specific
555 firmware extensions, such as the ability to inject memory-errors
556 for test-purposes. If you're unsure, say N.
557
558config IA64_HP_AML_NFW
559 bool "Support ACPI AML calls to native firmware"
560 help
561 This driver installs a global ACPI Operation Region handler for
562 region 0xA1. AML methods can use this OpRegion to call arbitrary
563 native firmware functions. The driver installs the OpRegion
564 handler if there is an HPQ5001 device or if the user supplies
565 the "force" module parameter, e.g., with the "aml_nfw.force"
566 kernel command line option.
567
568source "drivers/sn/Kconfig"
569
570config KEXEC
571 bool "kexec system call (EXPERIMENTAL)"
572 depends on EXPERIMENTAL && !IA64_HP_SIM && (!SMP || HOTPLUG_CPU)
573 help
574 kexec is a system call that implements the ability to shutdown your
575 current kernel, and to start another kernel. It is like a reboot
576 but it is independent of the system firmware. And like a reboot
577 you can start any kernel with it, not just Linux.
578
579 The name comes from the similarity to the exec system call.
580
581 It is an ongoing process to be certain the hardware in a machine
582 is properly shutdown, so do not be surprised if this code does not
583 initially work for you. It may help to enable device hotplugging
584 support. As of this writing the exact hardware interface is
585 strongly in flux, so no good recommendation can be made.
586
587config CRASH_DUMP
588 bool "kernel crash dumps"
589 depends on IA64_MCA_RECOVERY && !IA64_HP_SIM && (!SMP || HOTPLUG_CPU)
590 help
591 Generate crash dump after being started by kexec.
592
593source "drivers/firmware/Kconfig"
594
595source "fs/Kconfig.binfmt"
596
597endmenu
598
599menu "Power management and ACPI options"
600
601source "kernel/power/Kconfig"
602
603source "drivers/acpi/Kconfig"
604
605if PM
606
607source "arch/ia64/kernel/cpufreq/Kconfig"
608
609endif
610
611endmenu
612
613if !IA64_HP_SIM
614
615menu "Bus options (PCI, PCMCIA)"
616
617config PCI
618 bool "PCI support"
619 help
620 Real IA-64 machines all have PCI/PCI-X/PCI Express busses. Say Y
621 here unless you are using a simulator without PCI support.
622
623config PCI_DOMAINS
624 def_bool PCI
625
626config PCI_SYSCALL
627 def_bool PCI
628
629source "drivers/pci/pcie/Kconfig"
630
631source "drivers/pci/Kconfig"
632
633source "drivers/pci/hotplug/Kconfig"
634
635source "drivers/pcmcia/Kconfig"
636
637endmenu
638
639endif
640
641source "net/Kconfig"
642
643source "drivers/Kconfig"
644
645source "arch/ia64/hp/sim/Kconfig"
646
647config MSPEC
648 tristate "Memory special operations driver"
649 depends on IA64
650 select IA64_UNCACHED_ALLOCATOR
651 help
652 If you have an ia64 and you want to enable memory special
653 operations support (formerly known as fetchop), say Y here,
654 otherwise say N.
655
656source "fs/Kconfig"
657
658source "arch/ia64/Kconfig.debug"
659
660source "security/Kconfig"
661
662source "crypto/Kconfig"
663
664source "arch/ia64/kvm/Kconfig"
665
666source "lib/Kconfig"
667
668config IOMMU_HELPER
669 def_bool (IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB || IA64_GENERIC || SWIOTLB)