diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2009-06-11 09:01:14 +0300 | 
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2009-06-11 09:01:14 +0300 | 
| commit | cf9fe114e3b37e14fc8434d5abb192e35df551b1 (patch) | |
| tree | 0f82879295dc792f9df1a3ce79e143a3c073510f /arch/x86/kvm/x86.c | |
| parent | c1d0d32a603ed06377f404adf2c538de33bb3634 (diff) | |
| parent | 991ec02cdca33b03a132a0cacfe6f0aa0be9aa8d (diff) | |
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
Diffstat (limited to 'arch/x86/kvm/x86.c')
| -rw-r--r-- | arch/x86/kvm/x86.c | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 49079a46687..3944e917e79 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -338,6 +338,9 @@ EXPORT_SYMBOL_GPL(kvm_lmsw);  void kvm_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4)  { +	unsigned long old_cr4 = vcpu->arch.cr4; +	unsigned long pdptr_bits = X86_CR4_PGE | X86_CR4_PSE | X86_CR4_PAE; +  	if (cr4 & CR4_RESERVED_BITS) {  		printk(KERN_DEBUG "set_cr4: #GP, reserved bits\n");  		kvm_inject_gp(vcpu, 0); @@ -351,7 +354,8 @@ void kvm_set_cr4(struct kvm_vcpu *vcpu, unsigned long cr4)  			kvm_inject_gp(vcpu, 0);  			return;  		} -	} else if (is_paging(vcpu) && !is_pae(vcpu) && (cr4 & X86_CR4_PAE) +	} else if (is_paging(vcpu) && (cr4 & X86_CR4_PAE) +		   && ((cr4 ^ old_cr4) & pdptr_bits)  		   && !load_pdptrs(vcpu, vcpu->arch.cr3)) {  		printk(KERN_DEBUG "set_cr4: #GP, pdptrs reserved bits\n");  		kvm_inject_gp(vcpu, 0); | 
