提交 cbd27ee7 编写于 作者: A Avi Kivity

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: NAvi Kivity <avi@redhat.com>
上级 f47cfa31
...@@ -280,9 +280,9 @@ struct x86_emulate_ctxt { ...@@ -280,9 +280,9 @@ struct x86_emulate_ctxt {
u8 modrm_seg; u8 modrm_seg;
bool rip_relative; bool rip_relative;
unsigned long _eip; unsigned long _eip;
struct operand memop;
/* Fields above regs are cleared together. */ /* Fields above regs are cleared together. */
unsigned long regs[NR_VCPU_REGS]; unsigned long regs[NR_VCPU_REGS];
struct operand memop;
struct operand *memopp; struct operand *memopp;
struct fetch_cache fetch; struct fetch_cache fetch;
struct read_cache io_read; struct read_cache io_read;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册