summaryrefslogtreecommitdiffstats
path: root/arch/x86/include
diff options
context:
space:
mode:
authorAvi Kivity <avi@redhat.com>2012-06-10 16:11:00 +0200
committerAvi Kivity <avi@redhat.com>2012-07-09 13:19:02 +0200
commitcbd27ee783f1e56d56415e8c5f2492ccedd565c4 (patch)
tree0e4f1211f1073550028cab8e9baa74feb3b68b23 /arch/x86/include
parentKVM: x86 emulator: emulate LEAVE (diff)
downloadlinux-cbd27ee783f1e56d56415e8c5f2492ccedd565c4.tar.xz
linux-cbd27ee783f1e56d56415e8c5f2492ccedd565c4.zip
KVM: x86 emulator: initialize memop
memop is not initialized; this can lead to a two-byte operation following a 4-byte operation to see garbage values. Usually truncation fixes things fot us later on, but at least in one case (call abs) it doesn't. Fix by moving memop to the auto-initialized field area. Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86/include')
-rw-r--r--arch/x86/include/asm/kvm_emulate.h2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/include/asm/kvm_emulate.h b/arch/x86/include/asm/kvm_emulate.h
index cd5c96b2496e..c764f43b71c5 100644
--- a/arch/x86/include/asm/kvm_emulate.h
+++ b/arch/x86/include/asm/kvm_emulate.h
@@ -280,9 +280,9 @@ struct x86_emulate_ctxt {
u8 modrm_seg;
bool rip_relative;
unsigned long _eip;
+ struct operand memop;
/* Fields above regs are cleared together. */
unsigned long regs[NR_VCPU_REGS];
- struct operand memop;
struct operand *memopp;
struct fetch_cache fetch;
struct read_cache io_read;