Kconfig 17 KB

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