Kconfig 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. #
  2. # KVM configuration
  3. #
  4. source "virt/kvm/Kconfig"
  5. menuconfig VIRTUALIZATION
  6. bool "Virtualization"
  7. ---help---
  8. Say Y here to get to see options for using your Linux host to run
  9. other operating systems inside virtual machines (guests).
  10. This option alone does not add any kernel code.
  11. If you say N, all options in this submenu will be skipped and
  12. disabled.
  13. if VIRTUALIZATION
  14. config KVM
  15. bool
  16. select PREEMPT_NOTIFIERS
  17. select ANON_INODES
  18. select HAVE_KVM_EVENTFD
  19. select SRCU
  20. config KVM_BOOK3S_HANDLER
  21. bool
  22. config KVM_BOOK3S_32_HANDLER
  23. bool
  24. select KVM_BOOK3S_HANDLER
  25. select KVM_MMIO
  26. config KVM_BOOK3S_64_HANDLER
  27. bool
  28. select KVM_BOOK3S_HANDLER
  29. config KVM_BOOK3S_PR_POSSIBLE
  30. bool
  31. select KVM_MMIO
  32. select MMU_NOTIFIER
  33. config KVM_BOOK3S_HV_POSSIBLE
  34. bool
  35. config KVM_BOOK3S_32
  36. tristate "KVM support for PowerPC book3s_32 processors"
  37. depends on PPC_BOOK3S_32 && !SMP && !PTE_64BIT
  38. select KVM
  39. select KVM_BOOK3S_32_HANDLER
  40. select KVM_BOOK3S_PR_POSSIBLE
  41. ---help---
  42. Support running unmodified book3s_32 guest kernels
  43. in virtual machines on book3s_32 host processors.
  44. This module provides access to the hardware capabilities through
  45. a character device node named /dev/kvm.
  46. If unsure, say N.
  47. config KVM_BOOK3S_64
  48. tristate "KVM support for PowerPC book3s_64 processors"
  49. depends on PPC_BOOK3S_64
  50. select KVM_BOOK3S_64_HANDLER
  51. select KVM
  52. select KVM_BOOK3S_PR_POSSIBLE if !KVM_BOOK3S_HV_POSSIBLE
  53. ---help---
  54. Support running unmodified book3s_64 and book3s_32 guest kernels
  55. in virtual machines on book3s_64 host processors.
  56. This module provides access to the hardware capabilities through
  57. a character device node named /dev/kvm.
  58. If unsure, say N.
  59. config KVM_BOOK3S_64_HV
  60. tristate "KVM for POWER7 and later using hypervisor mode in host"
  61. depends on KVM_BOOK3S_64 && PPC_POWERNV
  62. select KVM_BOOK3S_HV_POSSIBLE
  63. select MMU_NOTIFIER
  64. select CMA
  65. ---help---
  66. Support running unmodified book3s_64 guest kernels in
  67. virtual machines on POWER7 and newer processors that have
  68. hypervisor mode available to the host.
  69. If you say Y here, KVM will use the hardware virtualization
  70. facilities of POWER7 (and later) processors, meaning that
  71. guest operating systems will run at full hardware speed
  72. using supervisor and user modes. However, this also means
  73. that KVM is not usable under PowerVM (pHyp), is only usable
  74. on POWER7 or later processors, and cannot emulate a
  75. different processor from the host processor.
  76. If unsure, say N.
  77. config KVM_BOOK3S_64_PR
  78. tristate "KVM support without using hypervisor mode in host"
  79. depends on KVM_BOOK3S_64
  80. select KVM_BOOK3S_PR_POSSIBLE
  81. ---help---
  82. Support running guest kernels in virtual machines on processors
  83. without using hypervisor mode in the host, by running the
  84. guest in user mode (problem state) and emulating all
  85. privileged instructions and registers.
  86. This is not as fast as using hypervisor mode, but works on
  87. machines where hypervisor mode is not available or not usable,
  88. and can emulate processors that are different from the host
  89. processor, including emulating 32-bit processors on a 64-bit
  90. host.
  91. config KVM_BOOK3S_HV_EXIT_TIMING
  92. bool "Detailed timing for hypervisor real-mode code"
  93. depends on KVM_BOOK3S_HV_POSSIBLE && DEBUG_FS
  94. ---help---
  95. Calculate time taken for each vcpu in the real-mode guest entry,
  96. exit, and interrupt handling code, plus time spent in the guest
  97. and in nap mode due to idle (cede) while other threads are still
  98. in the guest. The total, minimum and maximum times in nanoseconds
  99. together with the number of executions are reported in debugfs in
  100. kvm/vm#/vcpu#/timings. The overhead is of the order of 30 - 40
  101. ns per exit on POWER8.
  102. If unsure, say N.
  103. config KVM_BOOKE_HV
  104. bool
  105. config KVM_EXIT_TIMING
  106. bool "Detailed exit timing"
  107. depends on KVM_E500V2 || KVM_E500MC
  108. ---help---
  109. Calculate elapsed time for every exit/enter cycle. A per-vcpu
  110. report is available in debugfs kvm/vm#_vcpu#_timing.
  111. The overhead is relatively small, however it is not recommended for
  112. production environments.
  113. If unsure, say N.
  114. config KVM_E500V2
  115. bool "KVM support for PowerPC E500v2 processors"
  116. depends on E500 && !PPC_E500MC
  117. select KVM
  118. select KVM_MMIO
  119. select MMU_NOTIFIER
  120. ---help---
  121. Support running unmodified E500 guest kernels in virtual machines on
  122. E500v2 host processors.
  123. This module provides access to the hardware capabilities through
  124. a character device node named /dev/kvm.
  125. If unsure, say N.
  126. config KVM_E500MC
  127. bool "KVM support for PowerPC E500MC/E5500/E6500 processors"
  128. depends on PPC_E500MC
  129. select KVM
  130. select KVM_MMIO
  131. select KVM_BOOKE_HV
  132. select MMU_NOTIFIER
  133. ---help---
  134. Support running unmodified E500MC/E5500/E6500 guest kernels in
  135. virtual machines on E500MC/E5500/E6500 host processors.
  136. This module provides access to the hardware capabilities through
  137. a character device node named /dev/kvm.
  138. If unsure, say N.
  139. config KVM_MPIC
  140. bool "KVM in-kernel MPIC emulation"
  141. depends on KVM && E500
  142. select HAVE_KVM_IRQCHIP
  143. select HAVE_KVM_IRQFD
  144. select HAVE_KVM_IRQ_ROUTING
  145. select HAVE_KVM_MSI
  146. help
  147. Enable support for emulating MPIC devices inside the
  148. host kernel, rather than relying on userspace to emulate.
  149. Currently, support is limited to certain versions of
  150. Freescale's MPIC implementation.
  151. config KVM_XICS
  152. bool "KVM in-kernel XICS emulation"
  153. depends on KVM_BOOK3S_64 && !KVM_MPIC
  154. select HAVE_KVM_IRQCHIP
  155. select HAVE_KVM_IRQFD
  156. default y
  157. ---help---
  158. Include support for the XICS (eXternal Interrupt Controller
  159. Specification) interrupt controller architecture used on
  160. IBM POWER (pSeries) servers.
  161. source drivers/vhost/Kconfig
  162. endif # VIRTUALIZATION