KVM: emulate: move init_decode_cache to emulate.c
Core emulator functions all belong in emulator.c, x86 should have no knowledge of emulator internals Signed-off-by: Bandan Das <bsd@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
f5f87dfbc7
commit
1498507a47
3 changed files with 14 additions and 13 deletions
|
@ -409,6 +409,7 @@ bool x86_page_table_writing_insn(struct x86_emulate_ctxt *ctxt);
|
||||||
#define EMULATION_OK 0
|
#define EMULATION_OK 0
|
||||||
#define EMULATION_RESTART 1
|
#define EMULATION_RESTART 1
|
||||||
#define EMULATION_INTERCEPTED 2
|
#define EMULATION_INTERCEPTED 2
|
||||||
|
void init_decode_cache(struct x86_emulate_ctxt *ctxt);
|
||||||
int x86_emulate_insn(struct x86_emulate_ctxt *ctxt);
|
int x86_emulate_insn(struct x86_emulate_ctxt *ctxt);
|
||||||
int emulator_task_switch(struct x86_emulate_ctxt *ctxt,
|
int emulator_task_switch(struct x86_emulate_ctxt *ctxt,
|
||||||
u16 tss_selector, int idt_index, int reason,
|
u16 tss_selector, int idt_index, int reason,
|
||||||
|
|
|
@ -4534,6 +4534,19 @@ static int fastop(struct x86_emulate_ctxt *ctxt, void (*fop)(struct fastop *))
|
||||||
return X86EMUL_CONTINUE;
|
return X86EMUL_CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void init_decode_cache(struct x86_emulate_ctxt *ctxt)
|
||||||
|
{
|
||||||
|
memset(&ctxt->opcode_len, 0,
|
||||||
|
(void *)&ctxt->_regs - (void *)&ctxt->opcode_len);
|
||||||
|
|
||||||
|
ctxt->fetch.start = 0;
|
||||||
|
ctxt->fetch.end = 0;
|
||||||
|
ctxt->io_read.pos = 0;
|
||||||
|
ctxt->io_read.end = 0;
|
||||||
|
ctxt->mem_read.pos = 0;
|
||||||
|
ctxt->mem_read.end = 0;
|
||||||
|
}
|
||||||
|
|
||||||
int x86_emulate_insn(struct x86_emulate_ctxt *ctxt)
|
int x86_emulate_insn(struct x86_emulate_ctxt *ctxt)
|
||||||
{
|
{
|
||||||
const struct x86_emulate_ops *ops = ctxt->ops;
|
const struct x86_emulate_ops *ops = ctxt->ops;
|
||||||
|
|
|
@ -4888,19 +4888,6 @@ static void inject_emulated_exception(struct kvm_vcpu *vcpu)
|
||||||
kvm_queue_exception(vcpu, ctxt->exception.vector);
|
kvm_queue_exception(vcpu, ctxt->exception.vector);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void init_decode_cache(struct x86_emulate_ctxt *ctxt)
|
|
||||||
{
|
|
||||||
memset(&ctxt->opcode_len, 0,
|
|
||||||
(void *)&ctxt->_regs - (void *)&ctxt->opcode_len);
|
|
||||||
|
|
||||||
ctxt->fetch.start = 0;
|
|
||||||
ctxt->fetch.end = 0;
|
|
||||||
ctxt->io_read.pos = 0;
|
|
||||||
ctxt->io_read.end = 0;
|
|
||||||
ctxt->mem_read.pos = 0;
|
|
||||||
ctxt->mem_read.end = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void init_emulate_ctxt(struct kvm_vcpu *vcpu)
|
static void init_emulate_ctxt(struct kvm_vcpu *vcpu)
|
||||||
{
|
{
|
||||||
struct x86_emulate_ctxt *ctxt = &vcpu->arch.emulate_ctxt;
|
struct x86_emulate_ctxt *ctxt = &vcpu->arch.emulate_ctxt;
|
||||||
|
|
Loading…
Reference in a new issue