kvm.txt 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. Currently, kvm module is in EXPERIMENTAL stage on IA64. This means that
  2. interfaces are not stable enough to use. So, please don't run critical
  3. applications in virtual machine.
  4. We will try our best to improve it in future versions!
  5. Guide: How to boot up guests on kvm/ia64
  6. This guide is to describe how to enable kvm support for IA-64 systems.
  7. 1. Get the kvm source from git.kernel.org.
  8. Userspace source:
  9. git clone git://git.kernel.org/pub/scm/virt/kvm/kvm-userspace.git
  10. Kernel Source:
  11. git clone git://git.kernel.org/pub/scm/linux/kernel/git/xiantao/kvm-ia64.git
  12. 2. Compile the source code.
  13. 2.1 Compile userspace code:
  14. (1)cd ./kvm-userspace
  15. (2)./configure
  16. (3)cd kernel
  17. (4)make sync LINUX= $kernel_dir (kernel_dir is the directory of kernel source.)
  18. (5)cd ..
  19. (6)make qemu
  20. (7)cd qemu; make install
  21. 2.2 Compile kernel source code:
  22. (1) cd ./$kernel_dir
  23. (2) Make menuconfig
  24. (3) Enter into virtualization option, and choose kvm.
  25. (4) make
  26. (5) Once (4) done, make modules_install
  27. (6) Make initrd, and use new kernel to reboot up host machine.
  28. (7) Once (6) done, cd $kernel_dir/arch/ia64/kvm
  29. (8) insmod kvm.ko; insmod kvm-intel.ko
  30. Note: For step 2, please make sure that host page size == TARGET_PAGE_SIZE of qemu, otherwise, may fail.
  31. 3. Get Guest Firmware named as Flash.fd, and put it under right place:
  32. (1) If you have the guest firmware (binary) released by Intel Corp for Xen, use it directly.
  33. (2) If you have no firmware at hand, Please download its source from
  34. hg clone http://xenbits.xensource.com/ext/efi-vfirmware.hg
  35. you can get the firmware's binary in the directory of efi-vfirmware.hg/binaries.
  36. (3) Rename the firmware you owned to Flash.fd, and copy it to /usr/local/share/qemu
  37. 4. Boot up Linux or Windows guests:
  38. 4.1 Create or install a image for guest boot. If you have xen experience, it should be easy.
  39. 4.2 Boot up guests use the following command.
  40. /usr/local/bin/qemu-system-ia64 -smp xx -m 512 -hda $your_image
  41. (xx is the number of virtual processors for the guest, now the maximum value is 4)
  42. 5. Known possible issue on some platforms with old Firmware.
  43. In the event of strange host crash issues, try to solve it through either of the following ways:
  44. (1): Upgrade your Firmware to the latest one.
  45. (2): Applying the below patch to kernel source.
  46. diff --git a/arch/ia64/kernel/pal.S b/arch/ia64/kernel/pal.S
  47. index 0b53344..f02b0f7 100644
  48. --- a/arch/ia64/kernel/pal.S
  49. +++ b/arch/ia64/kernel/pal.S
  50. @@ -84,7 +84,8 @@ GLOBAL_ENTRY(ia64_pal_call_static)
  51. mov ar.pfs = loc1
  52. mov rp = loc0
  53. ;;
  54. - srlz.d // serialize restoration of psr.l
  55. + srlz.i // serialize restoration of psr.l
  56. + ;;
  57. br.ret.sptk.many b0
  58. END(ia64_pal_call_static)
  59. 6. Bug report:
  60. If you found any issues when use kvm/ia64, Please post the bug info to kvm-ia64-devel mailing list.
  61. https://lists.sourceforge.net/lists/listinfo/kvm-ia64-devel/
  62. Thanks for your interest! Let's work together, and make kvm/ia64 stronger and stronger!
  63. Xiantao Zhang <xiantao.zhang@intel.com>
  64. 2008.3.10