aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorJan Kiszka <jan.kiszka@siemens.com>2013-08-04 11:17:27 -0400
committerPaolo Bonzini <pbonzini@redhat.com>2013-08-07 09:57:45 -0400
commit44811c02ed94abbf0b0978c8bcce4f2603b11651 (patch)
tree0ee992f806a58e70fa57185ad6134804eb8fe5d7 /arch
parentf5c4368f8514e092556cb95172024cab92d00859 (diff)
nVMX: Keep arch.pat in sync on L1-L2 switches
When asking vmx to load the PAT MSR for us while switching from L1 to L2 or vice versa, we have to update arch.pat as well as it may later be used again to load or read out the MSR content. Reviewed-by: Gleb Natapov <gleb@redhat.com> Tested-by: Arthur Chunqi Li <yzt356@gmail.com> Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/kvm/vmx.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c
index 5b6f2a86826b..6d53dc33c0b0 100644
--- a/arch/x86/kvm/vmx.c
+++ b/arch/x86/kvm/vmx.c
@@ -7694,9 +7694,10 @@ static void prepare_vmcs02(struct kvm_vcpu *vcpu, struct vmcs12 *vmcs12)
7694 ~VM_ENTRY_IA32E_MODE) | 7694 ~VM_ENTRY_IA32E_MODE) |
7695 (vmcs_config.vmentry_ctrl & ~VM_ENTRY_IA32E_MODE)); 7695 (vmcs_config.vmentry_ctrl & ~VM_ENTRY_IA32E_MODE));
7696 7696
7697 if (vmcs12->vm_entry_controls & VM_ENTRY_LOAD_IA32_PAT) 7697 if (vmcs12->vm_entry_controls & VM_ENTRY_LOAD_IA32_PAT) {
7698 vmcs_write64(GUEST_IA32_PAT, vmcs12->guest_ia32_pat); 7698 vmcs_write64(GUEST_IA32_PAT, vmcs12->guest_ia32_pat);
7699 else if (vmcs_config.vmentry_ctrl & VM_ENTRY_LOAD_IA32_PAT) 7699 vcpu->arch.pat = vmcs12->guest_ia32_pat;
7700 } else if (vmcs_config.vmentry_ctrl & VM_ENTRY_LOAD_IA32_PAT)
7700 vmcs_write64(GUEST_IA32_PAT, vmx->vcpu.arch.pat); 7701 vmcs_write64(GUEST_IA32_PAT, vmx->vcpu.arch.pat);
7701 7702
7702 7703
@@ -8217,8 +8218,10 @@ static void load_vmcs12_host_state(struct kvm_vcpu *vcpu,
8217 vmcs_writel(GUEST_IDTR_BASE, vmcs12->host_idtr_base); 8218 vmcs_writel(GUEST_IDTR_BASE, vmcs12->host_idtr_base);
8218 vmcs_writel(GUEST_GDTR_BASE, vmcs12->host_gdtr_base); 8219 vmcs_writel(GUEST_GDTR_BASE, vmcs12->host_gdtr_base);
8219 8220
8220 if (vmcs12->vm_exit_controls & VM_EXIT_LOAD_IA32_PAT) 8221 if (vmcs12->vm_exit_controls & VM_EXIT_LOAD_IA32_PAT) {
8221 vmcs_write64(GUEST_IA32_PAT, vmcs12->host_ia32_pat); 8222 vmcs_write64(GUEST_IA32_PAT, vmcs12->host_ia32_pat);
8223 vcpu->arch.pat = vmcs12->host_ia32_pat;
8224 }
8222 if (vmcs12->vm_exit_controls & VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL) 8225 if (vmcs12->vm_exit_controls & VM_EXIT_LOAD_IA32_PERF_GLOBAL_CTRL)
8223 vmcs_write64(GUEST_IA32_PERF_GLOBAL_CTRL, 8226 vmcs_write64(GUEST_IA32_PERF_GLOBAL_CTRL,
8224 vmcs12->host_ia32_perf_global_ctrl); 8227 vmcs12->host_ia32_perf_global_ctrl);