|
@@ -16,6 +16,7 @@
|
|
|
*/
|
|
|
|
|
|
#include "kvm.h"
|
|
|
+#include "x86.h"
|
|
|
#include "x86_emulate.h"
|
|
|
#include "segment_descriptor.h"
|
|
|
#include "irq.h"
|
|
@@ -2507,43 +2508,6 @@ void kvm_get_cs_db_l_bits(struct kvm_vcpu *vcpu, int *db, int *l)
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(kvm_get_cs_db_l_bits);
|
|
|
|
|
|
-/*
|
|
|
- * List of msr numbers which we expose to userspace through KVM_GET_MSRS
|
|
|
- * and KVM_SET_MSRS, and KVM_GET_MSR_INDEX_LIST.
|
|
|
- *
|
|
|
- * This list is modified at module load time to reflect the
|
|
|
- * capabilities of the host cpu.
|
|
|
- */
|
|
|
-static u32 msrs_to_save[] = {
|
|
|
- MSR_IA32_SYSENTER_CS, MSR_IA32_SYSENTER_ESP, MSR_IA32_SYSENTER_EIP,
|
|
|
- MSR_K6_STAR,
|
|
|
-#ifdef CONFIG_X86_64
|
|
|
- MSR_CSTAR, MSR_KERNEL_GS_BASE, MSR_SYSCALL_MASK, MSR_LSTAR,
|
|
|
-#endif
|
|
|
- MSR_IA32_TIME_STAMP_COUNTER,
|
|
|
-};
|
|
|
-
|
|
|
-static unsigned num_msrs_to_save;
|
|
|
-
|
|
|
-static u32 emulated_msrs[] = {
|
|
|
- MSR_IA32_MISC_ENABLE,
|
|
|
-};
|
|
|
-
|
|
|
-static __init void kvm_init_msr_list(void)
|
|
|
-{
|
|
|
- u32 dummy[2];
|
|
|
- unsigned i, j;
|
|
|
-
|
|
|
- for (i = j = 0; i < ARRAY_SIZE(msrs_to_save); i++) {
|
|
|
- if (rdmsr_safe(msrs_to_save[i], &dummy[0], &dummy[1]) < 0)
|
|
|
- continue;
|
|
|
- if (j < i)
|
|
|
- msrs_to_save[j] = msrs_to_save[i];
|
|
|
- j++;
|
|
|
- }
|
|
|
- num_msrs_to_save = j;
|
|
|
-}
|
|
|
-
|
|
|
/*
|
|
|
* Adapt set_msr() to msr_io()'s calling convention
|
|
|
*/
|
|
@@ -3356,33 +3320,6 @@ static long kvm_dev_ioctl(struct file *filp,
|
|
|
goto out;
|
|
|
r = kvm_dev_ioctl_create_vm();
|
|
|
break;
|
|
|
- case KVM_GET_MSR_INDEX_LIST: {
|
|
|
- struct kvm_msr_list __user *user_msr_list = argp;
|
|
|
- struct kvm_msr_list msr_list;
|
|
|
- unsigned n;
|
|
|
-
|
|
|
- r = -EFAULT;
|
|
|
- if (copy_from_user(&msr_list, user_msr_list, sizeof msr_list))
|
|
|
- goto out;
|
|
|
- n = msr_list.nmsrs;
|
|
|
- msr_list.nmsrs = num_msrs_to_save + ARRAY_SIZE(emulated_msrs);
|
|
|
- if (copy_to_user(user_msr_list, &msr_list, sizeof msr_list))
|
|
|
- goto out;
|
|
|
- r = -E2BIG;
|
|
|
- if (n < num_msrs_to_save)
|
|
|
- goto out;
|
|
|
- r = -EFAULT;
|
|
|
- if (copy_to_user(user_msr_list->indices, &msrs_to_save,
|
|
|
- num_msrs_to_save * sizeof(u32)))
|
|
|
- goto out;
|
|
|
- if (copy_to_user(user_msr_list->indices
|
|
|
- + num_msrs_to_save * sizeof(u32),
|
|
|
- &emulated_msrs,
|
|
|
- ARRAY_SIZE(emulated_msrs) * sizeof(u32)))
|
|
|
- goto out;
|
|
|
- r = 0;
|
|
|
- break;
|
|
|
- }
|
|
|
case KVM_CHECK_EXTENSION: {
|
|
|
int ext = (long)argp;
|
|
|
|
|
@@ -3406,7 +3343,7 @@ static long kvm_dev_ioctl(struct file *filp,
|
|
|
r = 2 * PAGE_SIZE;
|
|
|
break;
|
|
|
default:
|
|
|
- ;
|
|
|
+ return kvm_arch_dev_ioctl(filp, ioctl, arg);
|
|
|
}
|
|
|
out:
|
|
|
return r;
|
|
@@ -3770,7 +3707,7 @@ static __init int kvm_init(void)
|
|
|
|
|
|
kvm_init_debug();
|
|
|
|
|
|
- kvm_init_msr_list();
|
|
|
+ kvm_arch_init();
|
|
|
|
|
|
bad_page = alloc_page(GFP_KERNEL);
|
|
|
|