aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBorislav Petkov <bp@suse.de>2013-02-19 13:33:13 -0500
committerH. Peter Anvin <hpa@linux.intel.com>2013-02-19 13:44:07 -0500
commit2e32b7190641a184b8510d3e342400473ff1ab60 (patch)
tree49d91e37b7ff0ca564b946918102da29bf9f3791
parent52d3d06e706bdde3d6c5c386deb065c3b4c51618 (diff)
x86, kvm: Add MSR_AMD64_BU_CFG2 to the list of ignored MSRs
The "x86, AMD: Enable WC+ memory type on family 10 processors" patch currently in -tip added a workaround for AMD F10h CPUs which #GPs my guest when booted in kvm. This is because it accesses MSR_AMD64_BU_CFG2 which is not currently ignored by kvm. Do that because this MSR is only baremetal-relevant anyway. While at it, move the ignored MSRs at the beginning of kvm_set_msr_common so that we exit then and there. Acked-by: Gleb Natapov <gleb@redhat.com> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Cc: Andre Przywara <andre@andrep.de> Cc: Marcelo Tosatti <mtosatti@redhat.com> Signed-off-by: Borislav Petkov <bp@suse.de> Link: http://lkml.kernel.org/r/1361298793-31834-2-git-send-email-bp@alien8.de Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
-rw-r--r--arch/x86/kvm/x86.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c
index c243b81e3c74..37040079cd6b 100644
--- a/arch/x86/kvm/x86.c
+++ b/arch/x86/kvm/x86.c
@@ -1881,6 +1881,14 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info)
1881 u64 data = msr_info->data; 1881 u64 data = msr_info->data;
1882 1882
1883 switch (msr) { 1883 switch (msr) {
1884 case MSR_AMD64_NB_CFG:
1885 case MSR_IA32_UCODE_REV:
1886 case MSR_IA32_UCODE_WRITE:
1887 case MSR_VM_HSAVE_PA:
1888 case MSR_AMD64_PATCH_LOADER:
1889 case MSR_AMD64_BU_CFG2:
1890 break;
1891
1884 case MSR_EFER: 1892 case MSR_EFER:
1885 return set_efer(vcpu, data); 1893 return set_efer(vcpu, data);
1886 case MSR_K7_HWCR: 1894 case MSR_K7_HWCR:
@@ -1900,8 +1908,6 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info)
1900 return 1; 1908 return 1;
1901 } 1909 }
1902 break; 1910 break;
1903 case MSR_AMD64_NB_CFG:
1904 break;
1905 case MSR_IA32_DEBUGCTLMSR: 1911 case MSR_IA32_DEBUGCTLMSR:
1906 if (!data) { 1912 if (!data) {
1907 /* We support the non-activated case already */ 1913 /* We support the non-activated case already */
@@ -1914,11 +1920,6 @@ int kvm_set_msr_common(struct kvm_vcpu *vcpu, struct msr_data *msr_info)
1914 vcpu_unimpl(vcpu, "%s: MSR_IA32_DEBUGCTLMSR 0x%llx, nop\n", 1920 vcpu_unimpl(vcpu, "%s: MSR_IA32_DEBUGCTLMSR 0x%llx, nop\n",
1915 __func__, data); 1921 __func__, data);
1916 break; 1922 break;
1917 case MSR_IA32_UCODE_REV:
1918 case MSR_IA32_UCODE_WRITE:
1919 case MSR_VM_HSAVE_PA:
1920 case MSR_AMD64_PATCH_LOADER:
1921 break;
1922 case 0x200 ... 0x2ff: 1923 case 0x200 ... 0x2ff:
1923 return set_msr_mtrr(vcpu, msr, data); 1924 return set_msr_mtrr(vcpu, msr, data);
1924 case MSR_IA32_APICBASE: 1925 case MSR_IA32_APICBASE:
@@ -2253,6 +2254,7 @@ int kvm_get_msr_common(struct kvm_vcpu *vcpu, u32 msr, u64 *pdata)
2253 case MSR_K8_INT_PENDING_MSG: 2254 case MSR_K8_INT_PENDING_MSG:
2254 case MSR_AMD64_NB_CFG: 2255 case MSR_AMD64_NB_CFG:
2255 case MSR_FAM10H_MMIO_CONF_BASE: 2256 case MSR_FAM10H_MMIO_CONF_BASE:
2257 case MSR_AMD64_BU_CFG2:
2256 data = 0; 2258 data = 0;
2257 break; 2259 break;
2258 case MSR_P6_PERFCTR0: 2260 case MSR_P6_PERFCTR0: