[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v3 0/4] x86/vvmx: correctly emulate VMREAD and VMWRITE
Currently, emulation of vmread and vmwrite for a guest leads to BUG() in cases when actual VMREAD or VMWRITE ends up in VMfail due to invalid arguments. The goal of this patch series is to prevent the BUG() from happening and report any kind of VMfail back to the guest, just like it would be done by H/W. v2 --> v3: * vmwrite_safe() and vmread_safe() now return "enum vmx_insn_errno" (32-bit value) instead of unsigned long * vmwrite_safe() is changed to plain inline from always_inline * set_vvmcs_safe() and related functions are added to match get_vvmcs_safe() * virtual_vmcs_vmwrite_safe() and virtual_vmcs_vmread_safe() are added in order to preserve the old behaviour for existing callers v1 --> v2: * Removed "ASM_FLAG_OUT" from tools/tests/x86_emulator/x86_emulate.h * Replaced "~0UL" with "~0" for VMX_INSN_FAIL_INVALID * Removed double underscore prefix from vmwrite_safe() and vmread_safe() * Replaced "setb --> setc" and "sete --> setz" * Removed "fail_" prefix from "invalid" and "valid" asm constraints * Added "\t" to asm * Added unlikely() for checking fail conditions * Moved "ASM_FLAG_OUT" from lib.h to asm_defns.h Sergey Dyasli (4): x86/vmx: introduce vmwrite_safe() x86/vmx: improve vmread_safe() x86/vvmx: correctly emulate VMWRITE x86/vvmx: correctly emulate VMREAD xen/arch/x86/hvm/vmx/vmcs.c | 26 +++++++++++++- xen/arch/x86/hvm/vmx/vvmx.c | 44 ++++++++++++++++++++--- xen/include/asm-x86/asm_defns.h | 6 ++++ xen/include/asm-x86/hvm/vmx/vmcs.h | 5 +++ xen/include/asm-x86/hvm/vmx/vmx.h | 72 +++++++++++++++++++++++++------------- xen/include/asm-x86/hvm/vmx/vvmx.h | 16 +++++++++ 6 files changed, 140 insertions(+), 29 deletions(-) -- 2.9.3 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |