Kconfig 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630
  1. #
  2. # For a description of the syntax of this configuration file,
  3. # see Documentation/kbuild/kconfig-language.txt.
  4. #
  5. mainmenu "IA-64 Linux Kernel Configuration"
  6. source "init/Kconfig"
  7. menu "Processor type and features"
  8. config IA64
  9. bool
  10. select PCI if (!IA64_HP_SIM)
  11. select ACPI if (!IA64_HP_SIM)
  12. select PM if (!IA64_HP_SIM)
  13. select ARCH_SUPPORTS_MSI
  14. select HAVE_IDE
  15. select HAVE_OPROFILE
  16. select HAVE_KPROBES
  17. select HAVE_KRETPROBES
  18. select HAVE_DMA_ATTRS
  19. select HAVE_KVM
  20. default y
  21. help
  22. The Itanium Processor Family is Intel's 64-bit successor to
  23. the 32-bit X86 line. The IA-64 Linux project has a home
  24. page at <http://www.linuxia64.org/> and a mailing list at
  25. <linux-ia64@vger.kernel.org>.
  26. config 64BIT
  27. bool
  28. select ATA_NONSTANDARD if ATA
  29. default y
  30. config ZONE_DMA
  31. def_bool y
  32. depends on !IA64_SGI_SN2
  33. config QUICKLIST
  34. bool
  35. default y
  36. config MMU
  37. bool
  38. default y
  39. config SWIOTLB
  40. bool
  41. config IOMMU_HELPER
  42. bool
  43. config GENERIC_LOCKBREAK
  44. bool
  45. default y
  46. depends on SMP && PREEMPT
  47. config RWSEM_XCHGADD_ALGORITHM
  48. bool
  49. default y
  50. config ARCH_HAS_ILOG2_U32
  51. bool
  52. default n
  53. config ARCH_HAS_ILOG2_U64
  54. bool
  55. default n
  56. config HUGETLB_PAGE_SIZE_VARIABLE
  57. bool
  58. depends on HUGETLB_PAGE
  59. default y
  60. config GENERIC_FIND_NEXT_BIT
  61. bool
  62. default y
  63. config GENERIC_CALIBRATE_DELAY
  64. bool
  65. default y
  66. config GENERIC_TIME
  67. bool
  68. default y
  69. config GENERIC_TIME_VSYSCALL
  70. bool
  71. default y
  72. config HAVE_SETUP_PER_CPU_AREA
  73. def_bool y
  74. config DMI
  75. bool
  76. default y
  77. config EFI
  78. bool
  79. default y
  80. config GENERIC_IOMAP
  81. bool
  82. default y
  83. config SCHED_NO_NO_OMIT_FRAME_POINTER
  84. bool
  85. default y
  86. config IA64_UNCACHED_ALLOCATOR
  87. bool
  88. select GENERIC_ALLOCATOR
  89. config AUDIT_ARCH
  90. bool
  91. default y
  92. choice
  93. prompt "System type"
  94. default IA64_GENERIC
  95. config IA64_GENERIC
  96. bool "generic"
  97. select NUMA
  98. select ACPI_NUMA
  99. select SWIOTLB
  100. help
  101. This selects the system type of your hardware. A "generic" kernel
  102. will run on any supported IA-64 system. However, if you configure
  103. a kernel for your specific system, it will be faster and smaller.
  104. generic For any supported IA-64 system
  105. DIG-compliant For DIG ("Developer's Interface Guide") compliant systems
  106. HP-zx1/sx1000 For HP systems
  107. HP-zx1/sx1000+swiotlb For HP systems with (broken) DMA-constrained devices.
  108. SGI-SN2 For SGI Altix systems
  109. Ski-simulator For the HP simulator <http://www.hpl.hp.com/research/linux/ski/>
  110. If you don't know what to do, choose "generic".
  111. config IA64_DIG
  112. bool "DIG-compliant"
  113. select SWIOTLB
  114. config IA64_HP_ZX1
  115. bool "HP-zx1/sx1000"
  116. help
  117. Build a kernel that runs on HP zx1 and sx1000 systems. This adds
  118. support for the HP I/O MMU.
  119. config IA64_HP_ZX1_SWIOTLB
  120. bool "HP-zx1/sx1000 with software I/O TLB"
  121. select SWIOTLB
  122. help
  123. Build a kernel that runs on HP zx1 and sx1000 systems even when they
  124. have broken PCI devices which cannot DMA to full 32 bits. Apart
  125. from support for the HP I/O MMU, this includes support for the software
  126. I/O TLB, which allows supporting the broken devices at the expense of
  127. wasting some kernel memory (about 2MB by default).
  128. config IA64_SGI_SN2
  129. bool "SGI-SN2"
  130. select NUMA
  131. select ACPI_NUMA
  132. help
  133. Selecting this option will optimize the kernel for use on sn2 based
  134. systems, but the resulting kernel binary will not run on other
  135. types of ia64 systems. If you have an SGI Altix system, it's safe
  136. to select this option. If in doubt, select ia64 generic support
  137. instead.
  138. config IA64_HP_SIM
  139. bool "Ski-simulator"
  140. select SWIOTLB
  141. endchoice
  142. choice
  143. prompt "Processor type"
  144. default ITANIUM
  145. config ITANIUM
  146. bool "Itanium"
  147. help
  148. Select your IA-64 processor type. The default is Itanium.
  149. This choice is safe for all IA-64 systems, but may not perform
  150. optimally on systems with, say, Itanium 2 or newer processors.
  151. config MCKINLEY
  152. bool "Itanium 2"
  153. help
  154. Select this to configure for an Itanium 2 (McKinley) processor.
  155. endchoice
  156. choice
  157. prompt "Kernel page size"
  158. default IA64_PAGE_SIZE_16KB
  159. config IA64_PAGE_SIZE_4KB
  160. bool "4KB"
  161. help
  162. This lets you select the page size of the kernel. For best IA-64
  163. performance, a page size of 8KB or 16KB is recommended. For best
  164. IA-32 compatibility, a page size of 4KB should be selected (the vast
  165. majority of IA-32 binaries work perfectly fine with a larger page
  166. size). For Itanium 2 or newer systems, a page size of 64KB can also
  167. be selected.
  168. 4KB For best IA-32 compatibility
  169. 8KB For best IA-64 performance
  170. 16KB For best IA-64 performance
  171. 64KB Requires Itanium 2 or newer processor.
  172. If you don't know what to do, choose 16KB.
  173. config IA64_PAGE_SIZE_8KB
  174. bool "8KB"
  175. config IA64_PAGE_SIZE_16KB
  176. bool "16KB"
  177. config IA64_PAGE_SIZE_64KB
  178. depends on !ITANIUM
  179. bool "64KB"
  180. endchoice
  181. choice
  182. prompt "Page Table Levels"
  183. default PGTABLE_3
  184. config PGTABLE_3
  185. bool "3 Levels"
  186. config PGTABLE_4
  187. depends on !IA64_PAGE_SIZE_64KB
  188. bool "4 Levels"
  189. endchoice
  190. if IA64_HP_SIM
  191. config HZ
  192. default 32
  193. endif
  194. if !IA64_HP_SIM
  195. source kernel/Kconfig.hz
  196. endif
  197. config IA64_BRL_EMU
  198. bool
  199. depends on ITANIUM
  200. default y
  201. # align cache-sensitive data to 128 bytes
  202. config IA64_L1_CACHE_SHIFT
  203. int
  204. default "7" if MCKINLEY
  205. default "6" if ITANIUM
  206. config IA64_CYCLONE
  207. bool "Cyclone (EXA) Time Source support"
  208. help
  209. Say Y here to enable support for IBM EXA Cyclone time source.
  210. If you're unsure, answer N.
  211. config IOSAPIC
  212. bool
  213. depends on !IA64_HP_SIM
  214. default y
  215. config FORCE_MAX_ZONEORDER
  216. int "MAX_ORDER (11 - 17)" if !HUGETLB_PAGE
  217. range 11 17 if !HUGETLB_PAGE
  218. default "17" if HUGETLB_PAGE
  219. default "11"
  220. config VIRT_CPU_ACCOUNTING
  221. bool "Deterministic task and CPU time accounting"
  222. default n
  223. help
  224. Select this option to enable more accurate task and CPU time
  225. accounting. This is done by reading a CPU counter on each
  226. kernel entry and exit and on transitions within the kernel
  227. between system, softirq and hardirq state, so there is a
  228. small performance impact.
  229. If in doubt, say N here.
  230. config SMP
  231. bool "Symmetric multi-processing support"
  232. help
  233. This enables support for systems with more than one CPU. If you have
  234. a system with only one CPU, say N. If you have a system with more
  235. than one CPU, say Y.
  236. If you say N here, the kernel will run on single and multiprocessor
  237. systems, but will use only one CPU of a multiprocessor system. If
  238. you say Y here, the kernel will run on many, but not all,
  239. single processor systems. On a single processor system, the kernel
  240. will run faster if you say N here.
  241. See also the SMP-HOWTO available at
  242. <http://www.tldp.org/docs.html#howto>.
  243. If you don't know what to do here, say N.
  244. config NR_CPUS
  245. int "Maximum number of CPUs (2-1024)"
  246. range 2 1024
  247. depends on SMP
  248. default "1024"
  249. help
  250. You should set this to the number of CPUs in your system, but
  251. keep in mind that a kernel compiled for, e.g., 2 CPUs will boot but
  252. only use 2 CPUs on a >2 CPU system. Setting this to a value larger
  253. than 64 will cause the use of a CPU mask array, causing a small
  254. performance hit.
  255. config HOTPLUG_CPU
  256. bool "Support for hot-pluggable CPUs (EXPERIMENTAL)"
  257. depends on SMP && EXPERIMENTAL
  258. select HOTPLUG
  259. default n
  260. ---help---
  261. Say Y here to experiment with turning CPUs off and on. CPUs
  262. can be controlled through /sys/devices/system/cpu/cpu#.
  263. Say N if you want to disable CPU hotplug.
  264. config ARCH_ENABLE_MEMORY_HOTPLUG
  265. def_bool y
  266. config ARCH_ENABLE_MEMORY_HOTREMOVE
  267. def_bool y
  268. config SCHED_SMT
  269. bool "SMT scheduler support"
  270. depends on SMP
  271. help
  272. Improves the CPU scheduler's decision making when dealing with
  273. Intel IA64 chips with MultiThreading at a cost of slightly increased
  274. overhead in some places. If unsure say N here.
  275. config PERMIT_BSP_REMOVE
  276. bool "Support removal of Bootstrap Processor"
  277. depends on HOTPLUG_CPU
  278. default n
  279. ---help---
  280. Say Y here if your platform SAL will support removal of BSP with HOTPLUG_CPU
  281. support.
  282. config FORCE_CPEI_RETARGET
  283. bool "Force assumption that CPEI can be re-targetted"
  284. depends on PERMIT_BSP_REMOVE
  285. default n
  286. ---help---
  287. Say Y if you need to force the assumption that CPEI can be re-targetted to
  288. any cpu in the system. This hint is available via ACPI 3.0 specifications.
  289. Tiger4 systems are capable of re-directing CPEI to any CPU other than BSP.
  290. This option it useful to enable this feature on older BIOS's as well.
  291. You can also enable this by using boot command line option force_cpei=1.
  292. source "kernel/Kconfig.preempt"
  293. source "mm/Kconfig"
  294. config ARCH_SELECT_MEMORY_MODEL
  295. def_bool y
  296. config ARCH_DISCONTIGMEM_ENABLE
  297. def_bool y
  298. help
  299. Say Y to support efficient handling of discontiguous physical memory,
  300. for architectures which are either NUMA (Non-Uniform Memory Access)
  301. or have huge holes in the physical address space for other reasons.
  302. See <file:Documentation/vm/numa> for more.
  303. config ARCH_FLATMEM_ENABLE
  304. def_bool y
  305. config ARCH_SPARSEMEM_ENABLE
  306. def_bool y
  307. depends on ARCH_DISCONTIGMEM_ENABLE
  308. select SPARSEMEM_VMEMMAP_ENABLE
  309. config ARCH_DISCONTIGMEM_DEFAULT
  310. def_bool y if (IA64_SGI_SN2 || IA64_GENERIC || IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB)
  311. depends on ARCH_DISCONTIGMEM_ENABLE
  312. config NUMA
  313. bool "NUMA support"
  314. depends on !IA64_HP_SIM && !FLATMEM
  315. default y if IA64_SGI_SN2
  316. select ACPI_NUMA if ACPI
  317. help
  318. Say Y to compile the kernel to support NUMA (Non-Uniform Memory
  319. Access). This option is for configuring high-end multiprocessor
  320. server systems. If in doubt, say N.
  321. config NODES_SHIFT
  322. int "Max num nodes shift(3-10)"
  323. range 3 10
  324. default "10"
  325. depends on NEED_MULTIPLE_NODES
  326. help
  327. This option specifies the maximum number of nodes in your SSI system.
  328. MAX_NUMNODES will be 2^(This value).
  329. If in doubt, use the default.
  330. config ARCH_POPULATES_NODE_MAP
  331. def_bool y
  332. # VIRTUAL_MEM_MAP and FLAT_NODE_MEM_MAP are functionally equivalent.
  333. # VIRTUAL_MEM_MAP has been retained for historical reasons.
  334. config VIRTUAL_MEM_MAP
  335. bool "Virtual mem map"
  336. depends on !SPARSEMEM
  337. default y if !IA64_HP_SIM
  338. help
  339. Say Y to compile the kernel with support for a virtual mem map.
  340. This code also only takes effect if a memory hole of greater than
  341. 1 Gb is found during boot. You must turn this option on if you
  342. require the DISCONTIGMEM option for your machine. If you are
  343. unsure, say Y.
  344. config HOLES_IN_ZONE
  345. bool
  346. default y if VIRTUAL_MEM_MAP
  347. config HAVE_ARCH_EARLY_PFN_TO_NID
  348. def_bool y
  349. depends on NEED_MULTIPLE_NODES
  350. config HAVE_ARCH_NODEDATA_EXTENSION
  351. def_bool y
  352. depends on NUMA
  353. config IA32_SUPPORT
  354. bool "Support for Linux/x86 binaries"
  355. help
  356. IA-64 processors can execute IA-32 (X86) instructions. By
  357. saying Y here, the kernel will include IA-32 system call
  358. emulation support which makes it possible to transparently
  359. run IA-32 Linux binaries on an IA-64 Linux system.
  360. If in doubt, say Y.
  361. config COMPAT
  362. bool
  363. depends on IA32_SUPPORT
  364. default y
  365. config COMPAT_FOR_U64_ALIGNMENT
  366. def_bool COMPAT
  367. config IA64_MCA_RECOVERY
  368. tristate "MCA recovery from errors other than TLB."
  369. config PERFMON
  370. bool "Performance monitor support"
  371. help
  372. Selects whether support for the IA-64 performance monitor hardware
  373. is included in the kernel. This makes some kernel data-structures a
  374. little bigger and slows down execution a bit, but it is generally
  375. a good idea to turn this on. If you're unsure, say Y.
  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. To use this option, you have to ensure that the "/proc file system
  384. support" (CONFIG_PROC_FS) is enabled, too.
  385. config IA64_MC_ERR_INJECT
  386. tristate "MC error injection support"
  387. help
  388. Adds support for MC error injection. If enabled, the kernel
  389. will provide a sysfs interface for user applications to
  390. call MC error injection PAL procedures to inject various errors.
  391. This is a useful tool for MCA testing.
  392. If you're unsure, do not select this option.
  393. config SGI_SN
  394. def_bool y if (IA64_SGI_SN2 || IA64_GENERIC)
  395. config IA64_ESI
  396. bool "ESI (Extensible SAL Interface) support"
  397. help
  398. If you say Y here, support is built into the kernel to
  399. make ESI calls. ESI calls are used to support vendor-specific
  400. firmware extensions, such as the ability to inject memory-errors
  401. for test-purposes. If you're unsure, say N.
  402. config IA64_HP_AML_NFW
  403. bool "Support ACPI AML calls to native firmware"
  404. help
  405. This driver installs a global ACPI Operation Region handler for
  406. region 0xA1. AML methods can use this OpRegion to call arbitrary
  407. native firmware functions. The driver installs the OpRegion
  408. handler if there is an HPQ5001 device or if the user supplies
  409. the "force" module parameter, e.g., with the "aml_nfw.force"
  410. kernel command line option.
  411. source "drivers/sn/Kconfig"
  412. config KEXEC
  413. bool "kexec system call (EXPERIMENTAL)"
  414. depends on EXPERIMENTAL && !IA64_HP_SIM && (!SMP || HOTPLUG_CPU)
  415. help
  416. kexec is a system call that implements the ability to shutdown your
  417. current kernel, and to start another kernel. It is like a reboot
  418. but it is independent of the system firmware. And like a reboot
  419. you can start any kernel with it, not just Linux.
  420. The name comes from the similarity to the exec system call.
  421. It is an ongoing process to be certain the hardware in a machine
  422. is properly shutdown, so do not be surprised if this code does not
  423. initially work for you. It may help to enable device hotplugging
  424. support. As of this writing the exact hardware interface is
  425. strongly in flux, so no good recommendation can be made.
  426. config CRASH_DUMP
  427. bool "kernel crash dumps (EXPERIMENTAL)"
  428. depends on EXPERIMENTAL && IA64_MCA_RECOVERY && !IA64_HP_SIM && (!SMP || HOTPLUG_CPU)
  429. help
  430. Generate crash dump after being started by kexec.
  431. source "drivers/firmware/Kconfig"
  432. source "fs/Kconfig.binfmt"
  433. endmenu
  434. menu "Power management and ACPI"
  435. source "kernel/power/Kconfig"
  436. source "drivers/acpi/Kconfig"
  437. if PM
  438. source "arch/ia64/kernel/cpufreq/Kconfig"
  439. endif
  440. endmenu
  441. if !IA64_HP_SIM
  442. menu "Bus options (PCI, PCMCIA)"
  443. config PCI
  444. bool "PCI support"
  445. help
  446. Real IA-64 machines all have PCI/PCI-X/PCI Express busses. Say Y
  447. here unless you are using a simulator without PCI support.
  448. config PCI_DOMAINS
  449. def_bool PCI
  450. config PCI_SYSCALL
  451. def_bool PCI
  452. source "drivers/pci/pcie/Kconfig"
  453. source "drivers/pci/Kconfig"
  454. source "drivers/pci/hotplug/Kconfig"
  455. source "drivers/pcmcia/Kconfig"
  456. endmenu
  457. endif
  458. source "net/Kconfig"
  459. source "drivers/Kconfig"
  460. config MSPEC
  461. tristate "Memory special operations driver"
  462. depends on IA64
  463. select IA64_UNCACHED_ALLOCATOR
  464. help
  465. If you have an ia64 and you want to enable memory special
  466. operations support (formerly known as fetchop), say Y here,
  467. otherwise say N.
  468. source "fs/Kconfig"
  469. source "arch/ia64/kvm/Kconfig"
  470. source "lib/Kconfig"
  471. #
  472. # Use the generic interrupt handling code in kernel/irq/:
  473. #
  474. config GENERIC_HARDIRQS
  475. bool
  476. default y
  477. config GENERIC_IRQ_PROBE
  478. bool
  479. default y
  480. config GENERIC_PENDING_IRQ
  481. bool
  482. depends on GENERIC_HARDIRQS && SMP
  483. default y
  484. config IRQ_PER_CPU
  485. bool
  486. default y
  487. config IOMMU_HELPER
  488. def_bool (IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB || IA64_GENERIC || SWIOTLB)
  489. source "arch/ia64/hp/sim/Kconfig"
  490. source "arch/ia64/Kconfig.debug"
  491. source "security/Kconfig"
  492. source "crypto/Kconfig"