KVM虛擬化原理-創建KVM

kvm這個結構體包含了vCPU,內存,APIC,IRQ,MMU,Event事件管理等信息。該結構體中的信息主要在kvm虛擬機內部使用,用於跟蹤虛擬機的狀態。
對於一個kvm,就對應一個線程。
Kvm完全利用了硬件虛擬化技術,通過cat /proc/cpuinfo 查看信息,如果是intel處理器,那麼就加載kvm-intel.ko
用戶態創建一個虛擬機就是通過ioctl向/dev/kvm字符設備進行設置和管理kvm的。

點擊(此處)摺疊或打開

  1. struct kvm {
  2.     spinlock_t mmu_lock;
  3.     spinlock_t requests_lock;
  4.     struct rw_semaphore slots_lock;
  5.     struct mm_struct *mm; /* userspace tied to this vm */
  6.     int nmemslots;
  7.     struct kvm_memory_slot memslots[KVM_MEMORY_SLOTS +
  8.                     KVM_PRIVATE_MEM_SLOTS];
  9. #ifdef CONFIG_KVM_APIC_ARCHITECTURE
  10.     u32 bsp_vcpu_id;
  11.     struct kvm_vcpu *bsp_vcpu;
  12. #endif
  13.     struct kvm_vcpu *vcpus[KVM_MAX_VCPUS];
  14.     atomic_t online_vcpus;
  15.     struct list_head vm_list;
  16.     struct mutex lock;
  17.     struct kvm_io_bus mmio_bus;
  18.     struct kvm_io_bus pio_bus;
  19. #ifdef CONFIG_HAVE_KVM_EVENTFD
  20.     struct {
  21.         spinlock_t lock;
  22.         struct list_head items;
  23.     } irqfds;
  24.     struct list_head ioeventfds;
  25. #endif
  26.     struct kvm_vm_stat stat;
  27.     struct kvm_arch arch;
  28.     atomic_t users_count;
  29. #ifdef KVM_COALESCED_MMIO_PAGE_OFFSET
  30.     struct kvm_coalesced_mmio_dev *coalesced_mmio_dev;
  31.     struct kvm_coalesced_mmio_ring *coalesced_mmio_ring;
  32. #endif

  33.     struct mutex irq_lock;
  34. #ifdef CONFIG_HAVE_KVM_IRQCHIP
  35.     struct list_head irq_routing; /* of kvm_kernel_irq_routing_entry */
  36.     struct hlist_head mask_notifier_list;
  37. #endif

  38. #ifdef KVM_ARCH_WANT_MMU_NOTIFIER
  39.     struct mmu_notifier mmu_notifier;
  40.     unsigned long mmu_notifier_seq;
  41.     long mmu_notifier_count;
  42. #endif
  43. };
struct kvm_vm_stat stat;就是KVM虛擬機中的頁表、MMU等運行時狀態信息。
kvm_x86_ops 結構體中的所有成員都是函數指針,在kvm-intel.ko 和 kvm-amd.ko這兩個不同的模塊中,針對各自體系做不同的函數。KVM子系統代碼將通過該結構體函數進行實際的硬件操作。

針對kvm的fd,通過KVM_CREATE_VCPU指令字可以創建KVM的vCPU,並且獲得該vcpu_fd,vcpu_fd的操作主要包含在kvm_vcpu_fops中,kvm_vcpu_fops的實現方法如下:

點擊(此處)摺疊或打開

  1. static struct file_operations kvm_vcpu_fops = {
  2.     .release = kvm_vcpu_release,
  3.     .unlocked_ioctl = kvm_vcpu_ioctl,
  4.     .compat_ioctl = kvm_vcpu_ioctl,
  5.     .mmap = kvm_vcpu_mmap,
  6. };




<script type=text/javascript charset=utf-8 src="http://static.bshare.cn/b/buttonLite.js#style=-1&uuid=&pophcol=3&lang=zh"></script> <script type=text/javascript charset=utf-8 src="http://static.bshare.cn/b/bshareC0.js"></script>
閱讀(443) | 評論(1) | 轉發(1) |
1

上一篇:開源代碼中的遞歸宏

下一篇:NP完全問題

給主人留下些什麼吧!~~
評論熱議
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章