[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen master] x86/hvm: Raise #SS faults for %ss-based segmentation violations
commit a94b35ddedf5c7327c6b2d9205d0a2aef2e4cfed Author: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> AuthorDate: Sat May 7 13:41:05 2016 +0100 Commit: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> CommitDate: Tue May 10 18:08:50 2016 +0100 x86/hvm: Raise #SS faults for %ss-based segmentation violations Raising #GP under such circumstances is architecturally wrong. Refer to the Intel or AMD manuals describing faults, and the conditions under which #SS is raised. Signed-off-by: Andrew Cooper <andrew.cooper3@xxxxxxxxxx> Reviewed-by: Jan Beulich <jbeulich@xxxxxxxx> Acked-by: Tim Deegan <tim@xxxxxxx> Release-acked-by: Wei Liu <wei.liu2@xxxxxxxxxx> --- xen/arch/x86/hvm/emulate.c | 3 ++- xen/arch/x86/mm/shadow/common.c | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/xen/arch/x86/hvm/emulate.c b/xen/arch/x86/hvm/emulate.c index be1e7c2..ee5cf1f 100644 --- a/xen/arch/x86/hvm/emulate.c +++ b/xen/arch/x86/hvm/emulate.c @@ -566,7 +566,8 @@ static int hvmemul_virtual_to_linear( /* This is a singleton operation: fail it with an exception. */ hvmemul_ctxt->exn_pending = 1; - hvmemul_ctxt->trap.vector = TRAP_gp_fault; + hvmemul_ctxt->trap.vector = + (seg == x86_seg_ss) ? TRAP_stack_error : TRAP_gp_fault; hvmemul_ctxt->trap.type = X86_EVENTTYPE_HW_EXCEPTION; hvmemul_ctxt->trap.error_code = 0; hvmemul_ctxt->trap.insn_len = 0; diff --git a/xen/arch/x86/mm/shadow/common.c b/xen/arch/x86/mm/shadow/common.c index 559d4a4..226e32d 100644 --- a/xen/arch/x86/mm/shadow/common.c +++ b/xen/arch/x86/mm/shadow/common.c @@ -148,7 +148,8 @@ static int hvm_translate_linear_addr( if ( !okay ) { - hvm_inject_hw_exception(TRAP_gp_fault, 0); + hvm_inject_hw_exception( + (seg == x86_seg_ss) ? TRAP_stack_error : TRAP_gp_fault, 0); return X86EMUL_EXCEPTION; } -- generated by git-patchbot for /home/xen/git/xen.git#master _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |