# HG changeset patch # User cegger # Date 1298892114 -3600 Allow guest to enable SVM in EFER Signed-off-by: Christoph Egger diff -r 9707e7a215bd -r cccf815a82a7 xen/arch/x86/hvm/hvm.c --- a/xen/arch/x86/hvm/hvm.c +++ b/xen/arch/x86/hvm/hvm.c @@ -627,10 +627,15 @@ static int hvm_save_cpu_ctxt(struct doma return 0; } -static bool_t hvm_efer_valid(uint64_t value, uint64_t efer_validbits) +static bool_t hvm_efer_valid(struct domain *d, + uint64_t value, uint64_t efer_validbits) { + if ( nestedhvm_enabled(d) && cpu_has_svm ) + efer_validbits |= EFER_SVME; + return !((value & ~efer_validbits) || ((sizeof(long) != 8) && (value & EFER_LME)) || + (!cpu_has_svm && (value & EFER_SVME)) || (!cpu_has_nx && (value & EFER_NX)) || (!cpu_has_syscall && (value & EFER_SCE)) || (!cpu_has_lmsl && (value & EFER_LMSLE)) || @@ -645,6 +650,7 @@ static int hvm_load_cpu_ctxt(struct doma struct hvm_hw_cpu ctxt; struct segment_register seg; struct vcpu_guest_context *vc; + uint64_t efer_validbits; /* Which vcpu is this? */ vcpuid = hvm_load_instance(h); @@ -684,9 +690,9 @@ static int hvm_load_cpu_ctxt(struct doma return -EINVAL; } - if ( !hvm_efer_valid( - ctxt.msr_efer, - EFER_FFXSE | EFER_LMSLE | EFER_LME | EFER_LMA | EFER_NX | EFER_SCE) ) + efer_validbits = EFER_FFXSE | EFER_LMSLE | EFER_LME | EFER_LMA + | EFER_NX | EFER_SCE; + if ( !hvm_efer_valid(d, ctxt.msr_efer, efer_validbits) ) { gdprintk(XENLOG_ERR, "HVM restore: bad EFER 0x%"PRIx64"\n", ctxt.msr_efer); @@ -1278,14 +1284,15 @@ err: int hvm_set_efer(uint64_t value) { struct vcpu *v = current; + uint64_t efer_validbits; value &= ~EFER_LMA; - if ( !hvm_efer_valid(value, - EFER_FFXSE | EFER_LMSLE | EFER_LME | EFER_NX | EFER_SCE) ) + efer_validbits = EFER_FFXSE | EFER_LMSLE | EFER_LME | EFER_NX | EFER_SCE; + if ( !hvm_efer_valid(v->domain, value, efer_validbits) ) { gdprintk(XENLOG_WARNING, "Trying to set reserved bit in " - "EFER: %"PRIx64"\n", value); + "EFER: 0x%"PRIx64"\n", value); hvm_inject_exception(TRAP_gp_fault, 0, 0); return X86EMUL_EXCEPTION; } diff -r 9707e7a215bd -r cccf815a82a7 xen/include/asm-x86/cpufeature.h --- a/xen/include/asm-x86/cpufeature.h +++ b/xen/include/asm-x86/cpufeature.h @@ -211,6 +211,8 @@ #define cpu_has_rdtscp boot_cpu_has(X86_FEATURE_RDTSCP) +#define cpu_has_svm boot_cpu_has(X86_FEATURE_SVM) + #endif /* __ASM_I386_CPUFEATURE_H */ /*