[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-4.0-testing] svm: increment RIP over PAUSE instruction when emulating it
# HG changeset patch # User Keir Fraser <keir.fraser@xxxxxxxxxx> # Date 1281686006 -3600 # Node ID 273fb02cb434d8e96fda9d8e8d2393a31d9f457b # Parent 44c586efad6981994f7fa4c188c6a21eec16780b svm: increment RIP over PAUSE instruction when emulating it Signed-off-by: Christoph Egger <Christoph.Egger@xxxxxxx> xen-unstable changeset: 31d200e5b922 xen-unstable date: Fri Aug 13 08:31:49 2010 +0100 --- xen/arch/x86/hvm/svm/emulate.c | 4 +++- xen/arch/x86/hvm/svm/svm.c | 23 +++++++++++++++++------ xen/include/asm-x86/hvm/svm/emulate.h | 1 + 3 files changed, 21 insertions(+), 7 deletions(-) diff -r 44c586efad69 -r 273fb02cb434 xen/arch/x86/hvm/svm/emulate.c --- a/xen/arch/x86/hvm/svm/emulate.c Fri Aug 13 08:52:56 2010 +0100 +++ b/xen/arch/x86/hvm/svm/emulate.c Fri Aug 13 08:53:26 2010 +0100 @@ -100,6 +100,7 @@ MAKE_INSTR(HLT, 1, 0xf4); MAKE_INSTR(HLT, 1, 0xf4); MAKE_INSTR(INT3, 1, 0xcc); MAKE_INSTR(RDTSC, 2, 0x0f, 0x31); +MAKE_INSTR(PAUSE, 1, 0x90); static const u8 *opc_bytes[INSTR_MAX_COUNT] = { @@ -111,7 +112,8 @@ static const u8 *opc_bytes[INSTR_MAX_COU [INSTR_VMCALL] = OPCODE_VMCALL, [INSTR_HLT] = OPCODE_HLT, [INSTR_INT3] = OPCODE_INT3, - [INSTR_RDTSC] = OPCODE_RDTSC + [INSTR_RDTSC] = OPCODE_RDTSC, + [INSTR_PAUSE] = OPCODE_PAUSE, }; static int fetch(struct vcpu *v, u8 *buf, unsigned long addr, int len) diff -r 44c586efad69 -r 273fb02cb434 xen/arch/x86/hvm/svm/svm.c --- a/xen/arch/x86/hvm/svm/svm.c Fri Aug 13 08:52:56 2010 +0100 +++ b/xen/arch/x86/hvm/svm/svm.c Fri Aug 13 08:53:26 2010 +0100 @@ -1220,6 +1220,22 @@ static void svm_vmexit_do_rdtsc(struct c hvm_rdtsc_intercept(regs); } +static void svm_vmexit_do_pause(struct cpu_user_regs *regs) +{ + unsigned int inst_len; + + if ( (inst_len = __get_instruction_length(current, INSTR_PAUSE)) == 0 ) + return; + __update_guest_eip(regs, inst_len); + + /* + * The guest is running a contended spinlock and we've detected it. + * Do something useful, like reschedule the guest + */ + perfc_incr(pauseloop_exits); + do_sched_op_compat(SCHEDOP_yield, 0); +} + static void svm_vmexit_ud_intercept(struct cpu_user_regs *regs) { struct hvm_emulate_ctxt ctxt; @@ -1589,12 +1605,7 @@ asmlinkage void svm_vmexit_handler(struc break; case VMEXIT_PAUSE: - /* - * The guest is running a contended spinlock and we've detected it. - * Do something useful, like reschedule the guest - */ - perfc_incr(pauseloop_exits); - do_sched_op_compat(SCHEDOP_yield, 0); + svm_vmexit_do_pause(regs); break; default: diff -r 44c586efad69 -r 273fb02cb434 xen/include/asm-x86/hvm/svm/emulate.h --- a/xen/include/asm-x86/hvm/svm/emulate.h Fri Aug 13 08:52:56 2010 +0100 +++ b/xen/include/asm-x86/hvm/svm/emulate.h Fri Aug 13 08:53:26 2010 +0100 @@ -31,6 +31,7 @@ enum instruction_index { INSTR_HLT, INSTR_INT3, INSTR_RDTSC, + INSTR_PAUSE, INSTR_MAX_COUNT /* Must be last - Number of instructions supported */ }; _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |