kvm.txt 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. *** BIG FAT WARNING ***
  2. The kvm module is currently in EXPERIMENTAL state for s390. This means that
  3. the interface to the module is not yet considered to remain stable. Thus, be
  4. prepared that we keep breaking your userspace application and guest
  5. compatibility over and over again until we feel happy with the result. Make sure
  6. your guest kernel, your host kernel, and your userspace launcher are in a
  7. consistent state.
  8. This Documentation describes the unique ioctl calls to /dev/kvm, the resulting
  9. kvm-vm file descriptors, and the kvm-vcpu file descriptors that differ from x86.
  10. 1. ioctl calls to /dev/kvm
  11. KVM does support the following ioctls on s390 that are common with other
  12. architectures and do behave the same:
  13. KVM_GET_API_VERSION
  14. KVM_CREATE_VM (*) see note
  15. KVM_CHECK_EXTENSION
  16. KVM_GET_VCPU_MMAP_SIZE
  17. Notes:
  18. * KVM_CREATE_VM may fail on s390, if the calling process has multiple
  19. threads and has not called KVM_S390_ENABLE_SIE before.
  20. In addition, on s390 the following architecture specific ioctls are supported:
  21. ioctl: KVM_S390_ENABLE_SIE
  22. args: none
  23. see also: include/linux/kvm.h
  24. This call causes the kernel to switch on PGSTE in the user page table. This
  25. operation is needed in order to run a virtual machine, and it requires the
  26. calling process to be single-threaded. Note that the first call to KVM_CREATE_VM
  27. will implicitly try to switch on PGSTE if the user process has not called
  28. KVM_S390_ENABLE_SIE before. User processes that want to launch multiple threads
  29. before creating a virtual machine have to call KVM_S390_ENABLE_SIE, or will
  30. observe an error calling KVM_CREATE_VM. Switching on PGSTE is a one-time
  31. operation, is not reversible, and will persist over the entire lifetime of
  32. the calling process. It does not have any user-visible effect other than a small
  33. performance penalty.
  34. 2. ioctl calls to the kvm-vm file descriptor
  35. KVM does support the following ioctls on s390 that are common with other
  36. architectures and do behave the same:
  37. KVM_CREATE_VCPU
  38. KVM_SET_USER_MEMORY_REGION (*) see note
  39. KVM_GET_DIRTY_LOG (**) see note
  40. Notes:
  41. * kvm does only allow exactly one memory slot on s390, which has to start
  42. at guest absolute address zero and at a user address that is aligned on any
  43. page boundary. This hardware "limitation" allows us to have a few unique
  44. optimizations. The memory slot doesn't have to be filled
  45. with memory actually, it may contain sparse holes. That said, with different
  46. user memory layout this does still allow a large flexibility when
  47. doing the guest memory setup.
  48. ** KVM_GET_DIRTY_LOG doesn't work properly yet. The user will receive an empty
  49. log. This ioctl call is only needed for guest migration, and we intend to
  50. implement this one in the future.
  51. In addition, on s390 the following architecture specific ioctls for the kvm-vm
  52. file descriptor are supported:
  53. ioctl: KVM_S390_INTERRUPT
  54. args: struct kvm_s390_interrupt *
  55. see also: include/linux/kvm.h
  56. This ioctl is used to submit a floating interrupt for a virtual machine.
  57. Floating interrupts may be delivered to any virtual cpu in the configuration.
  58. Only some interrupt types defined in include/linux/kvm.h make sense when
  59. submitted as floating interrupts. The following interrupts are not considered
  60. to be useful as floating interrupts, and a call to inject them will result in
  61. -EINVAL error code: program interrupts and interprocessor signals. Valid
  62. floating interrupts are:
  63. KVM_S390_INT_VIRTIO
  64. KVM_S390_INT_SERVICE
  65. 3. ioctl calls to the kvm-vcpu file descriptor
  66. KVM does support the following ioctls on s390 that are common with other
  67. architectures and do behave the same:
  68. KVM_RUN
  69. KVM_GET_REGS
  70. KVM_SET_REGS
  71. KVM_GET_SREGS
  72. KVM_SET_SREGS
  73. KVM_GET_FPU
  74. KVM_SET_FPU
  75. In addition, on s390 the following architecture specific ioctls for the
  76. kvm-vcpu file descriptor are supported:
  77. ioctl: KVM_S390_INTERRUPT
  78. args: struct kvm_s390_interrupt *
  79. see also: include/linux/kvm.h
  80. This ioctl is used to submit an interrupt for a specific virtual cpu.
  81. Only some interrupt types defined in include/linux/kvm.h make sense when
  82. submitted for a specific cpu. The following interrupts are not considered
  83. to be useful, and a call to inject them will result in -EINVAL error code:
  84. service processor calls and virtio interrupts. Valid interrupt types are:
  85. KVM_S390_PROGRAM_INT
  86. KVM_S390_SIGP_STOP
  87. KVM_S390_RESTART
  88. KVM_S390_SIGP_SET_PREFIX
  89. KVM_S390_INT_EMERGENCY
  90. ioctl: KVM_S390_STORE_STATUS
  91. args: unsigned long
  92. see also: include/linux/kvm.h
  93. This ioctl stores the state of the cpu at the guest real address given as
  94. argument, unless one of the following values defined in include/linux/kvm.h
  95. is given as argument:
  96. KVM_S390_STORE_STATUS_NOADDR - the CPU stores its status to the save area in
  97. absolute lowcore as defined by the principles of operation
  98. KVM_S390_STORE_STATUS_PREFIXED - the CPU stores its status to the save area in
  99. its prefix page just like the dump tool that comes with zipl. This is useful
  100. to create a system dump for use with lkcdutils or crash.
  101. ioctl: KVM_S390_SET_INITIAL_PSW
  102. args: struct kvm_s390_psw *
  103. see also: include/linux/kvm.h
  104. This ioctl can be used to set the processor status word (psw) of a stopped cpu
  105. prior to running it with KVM_RUN. Note that this call is not required to modify
  106. the psw during sie intercepts that fall back to userspace because struct kvm_run
  107. does contain the psw, and this value is evaluated during reentry of KVM_RUN
  108. after the intercept exit was recognized.
  109. ioctl: KVM_S390_INITIAL_RESET
  110. args: none
  111. see also: include/linux/kvm.h
  112. This ioctl can be used to perform an initial cpu reset as defined by the
  113. principles of operation. The target cpu has to be in stopped state.