]> Pileus Git - ~andy/linux/blobdiff - include/linux/kvm_host.h
Merge branch 'linux-next' of git://git.kernel.org/pub/scm/linux/kernel/git/jbarnes/pci
[~andy/linux] / include / linux / kvm_host.h
index 9efdf5c703a5fb0a2b36c6e5a96bf2fa19d05ead..900c76337e8f387b1dcf183260e43c1625536500 100644 (file)
@@ -52,6 +52,8 @@
 #define KVM_REQ_STEAL_UPDATE      13
 #define KVM_REQ_NMI               14
 #define KVM_REQ_IMMEDIATE_EXIT    15
+#define KVM_REQ_PMU               16
+#define KVM_REQ_PMI               17
 
 #define KVM_USERSPACE_IRQ_SOURCE_ID    0
 
@@ -239,6 +241,8 @@ struct kvm_irq_routing_table {};
 struct kvm_memslots {
        u64 generation;
        struct kvm_memory_slot memslots[KVM_MEM_SLOTS_NUM];
+       /* The mapping table from slot id to the index in memslots[]. */
+       int id_to_index[KVM_MEM_SLOTS_NUM];
 };
 
 struct kvm {
@@ -249,7 +253,6 @@ struct kvm {
        struct srcu_struct srcu;
 #ifdef CONFIG_KVM_APIC_ARCHITECTURE
        u32 bsp_vcpu_id;
-       struct kvm_vcpu *bsp_vcpu;
 #endif
        struct kvm_vcpu *vcpus[KVM_MAX_VCPUS];
        atomic_t online_vcpus;
@@ -341,14 +344,13 @@ static inline struct kvm_memslots *kvm_memslots(struct kvm *kvm)
 static inline struct kvm_memory_slot *
 id_to_memslot(struct kvm_memslots *slots, int id)
 {
-       int i;
+       int index = slots->id_to_index[id];
+       struct kvm_memory_slot *slot;
 
-       for (i = 0; i < KVM_MEM_SLOTS_NUM; i++)
-               if (slots->memslots[i].id == id)
-                       return &slots->memslots[i];
+       slot = &slots->memslots[index];
 
-       WARN_ON(1);
-       return NULL;
+       WARN_ON(slot->id != id);
+       return slot;
 }
 
 #define HPA_MSB ((sizeof(hpa_t) * 8) - 1)