|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen stable-4.3] Revert "x86/HVM: correct CPUID leaf 80000008 handling"
commit 651da73a2bbe4a54008f779ef65a147a760f4def
Author: Jan Beulich <jbeulich@xxxxxxxx>
AuthorDate: Tue Apr 8 12:13:49 2014 +0200
Commit: Jan Beulich <jbeulich@xxxxxxxx>
CommitDate: Tue Apr 8 12:13:49 2014 +0200
Revert "x86/HVM: correct CPUID leaf 80000008 handling"
This reverts commit e7516b4015c87dc0e136352d8b6a1c850ebdda3f
(wrongly passing NULLs to hvm_cpuid()).
---
xen/arch/x86/hvm/hvm.c | 23 +++--------------------
xen/arch/x86/hvm/mtrr.c | 25 ++++++++++++-------------
2 files changed, 15 insertions(+), 33 deletions(-)
diff --git a/xen/arch/x86/hvm/hvm.c b/xen/arch/x86/hvm/hvm.c
index c52044e..a3a2c32 100644
--- a/xen/arch/x86/hvm/hvm.c
+++ b/xen/arch/x86/hvm/hvm.c
@@ -2810,8 +2810,6 @@ void hvm_cpuid(unsigned int input, unsigned int *eax,
unsigned int *ebx,
switch ( input )
{
- unsigned int sub_leaf, _eax, _ebx, _ecx, _edx;
-
case 0x1:
/* Fix up VLAPIC details. */
*ebx &= 0x00FFFFFFu;
@@ -2845,6 +2843,8 @@ void hvm_cpuid(unsigned int input, unsigned int *eax,
unsigned int *ebx,
*edx = v->vcpu_id * 2;
break;
case 0xd:
+ {
+ unsigned int sub_leaf, _eax, _ebx, _ecx, _edx;
/* EBX value of main leaf 0 depends on enabled xsave features */
if ( count == 0 && v->arch.xcr0 )
{
@@ -2861,7 +2861,7 @@ void hvm_cpuid(unsigned int input, unsigned int *eax,
unsigned int *ebx,
}
}
break;
-
+ }
case 0x80000001:
/* We expose RDTSCP feature to guest only when
tsc_mode == TSC_MODE_DEFAULT and host_tsc_is_safe() returns 1 */
@@ -2875,23 +2875,6 @@ void hvm_cpuid(unsigned int input, unsigned int *eax,
unsigned int *ebx,
if ( !(hvm_pae_enabled(v) || hvm_long_mode_enabled(v)) )
*edx &= ~cpufeat_mask(X86_FEATURE_PSE36);
break;
-
- case 0x80000008:
- count = cpuid_eax(0x80000008);
- count = (count >> 16) & 0xff ?: count & 0xff;
- if ( (*eax & 0xff) > count )
- *eax = (*eax & ~0xff) | count;
-
- hvm_cpuid(1, NULL, NULL, NULL, &_edx);
- count = _edx & (cpufeat_mask(X86_FEATURE_PAE) |
- cpufeat_mask(X86_FEATURE_PSE36)) ? 36 : 32;
- if ( (*eax & 0xff) < count )
- *eax = (*eax & ~0xff) | count;
-
- hvm_cpuid(0x80000001, NULL, NULL, NULL, &_edx);
- *eax = (*eax & ~0xffff00) | (_edx & cpufeat_mask(X86_FEATURE_LM)
- ? 0x3000 : 0x2000);
- break;
}
}
diff --git a/xen/arch/x86/hvm/mtrr.c b/xen/arch/x86/hvm/mtrr.c
index 243fa8b..aac80cc 100644
--- a/xen/arch/x86/hvm/mtrr.c
+++ b/xen/arch/x86/hvm/mtrr.c
@@ -145,7 +145,7 @@ bool_t is_var_mtrr_overlapped(struct mtrr_state *m)
static int hvm_mtrr_pat_init(void)
{
- unsigned int i, j;
+ unsigned int i, j, phys_addr;
memset(&mtrr_epat_tbl, INVALID_MEM_TYPE, sizeof(mtrr_epat_tbl));
for ( i = 0; i < MTRR_NUM_TYPES; i++ )
@@ -172,7 +172,11 @@ static int hvm_mtrr_pat_init(void)
}
}
- size_or_mask = ~((1 << (paddr_bits - PAGE_SHIFT)) - 1);
+ phys_addr = 36;
+ if ( cpuid_eax(0x80000000) >= 0x80000008 )
+ phys_addr = (uint8_t)cpuid_eax(0x80000008);
+
+ size_or_mask = ~((1 << (phys_addr - PAGE_SHIFT)) - 1);
return 0;
}
@@ -464,21 +468,16 @@ bool_t mtrr_var_range_msr_set(
type == 4 || type == 5 || type == 6)) )
return 0;
- if ( d == current->domain )
+ phys_addr = 36;
+ domain_cpuid(d, 0x80000000, 0, &eax, &ebx, &ecx, &edx);
+ if ( eax >= 0x80000008 )
{
- phys_addr = 36;
- hvm_cpuid(0x80000000, &eax, &ebx, &ecx, &edx);
- if ( eax >= 0x80000008 )
- {
- hvm_cpuid(0x80000008, &eax, &ebx, &ecx, &edx);
- phys_addr = (uint8_t)eax;
- }
+ domain_cpuid(d, 0x80000008, 0, &eax, &ebx, &ecx, &edx);
+ phys_addr = (uint8_t)eax;
}
- else
- phys_addr = paddr_bits;
msr_mask = ~((((uint64_t)1) << phys_addr) - 1);
msr_mask |= (index & 1) ? 0x7ffUL : 0xf00UL;
- if ( unlikely(msr_content & msr_mask) )
+ if ( unlikely(msr_content && (msr_content & msr_mask)) )
{
HVM_DBG_LOG(DBG_LEVEL_MSR, "invalid msr content:%"PRIx64"\n",
msr_content);
--
generated by git-patchbot for /home/xen/git/xen.git#stable-4.3
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |