Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 44869
b: refs/heads/master
c: bf591b2
h: refs/heads/master
i:
  44867: 9b6eb72
v: v3
  • Loading branch information
Michael Riepe authored and Linus Torvalds committed Dec 22, 2006
1 parent 131c5de commit ff6321f
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 4 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 2c264957105b7c248a456ba6602df667ae986550
refs/heads/master: bf591b24d07126143356058966d79423661f491f
27 changes: 24 additions & 3 deletions trunk/drivers/kvm/kvm_main.c
Original file line number Diff line number Diff line change
Expand Up @@ -1417,6 +1417,9 @@ static int kvm_dev_ioctl_set_sregs(struct kvm *kvm, struct kvm_sregs *sregs)
/*
* 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,
Expand All @@ -1427,6 +1430,22 @@ static u32 msrs_to_save[] = {
MSR_IA32_TIME_STAMP_COUNTER,
};

static unsigned num_msrs_to_save;

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
Expand Down Expand Up @@ -1735,15 +1754,15 @@ static long kvm_dev_ioctl(struct file *filp,
if (copy_from_user(&msr_list, user_msr_list, sizeof msr_list))
goto out;
n = msr_list.nmsrs;
msr_list.nmsrs = ARRAY_SIZE(msrs_to_save);
msr_list.nmsrs = num_msrs_to_save;
if (copy_to_user(user_msr_list, &msr_list, sizeof msr_list))
goto out;
r = -E2BIG;
if (n < ARRAY_SIZE(msrs_to_save))
if (n < num_msrs_to_save)
goto out;
r = -EFAULT;
if (copy_to_user(user_msr_list->indices, &msrs_to_save,
sizeof msrs_to_save))
num_msrs_to_save * sizeof(u32)))
goto out;
r = 0;
}
Expand Down Expand Up @@ -1894,6 +1913,8 @@ static __init int kvm_init(void)

kvm_init_debug();

kvm_init_msr_list();

if ((bad_page = alloc_page(GFP_KERNEL)) == NULL) {
r = -ENOMEM;
goto out;
Expand Down

0 comments on commit ff6321f

Please sign in to comment.