diff options
author | Christoffer Dall <c.dall@virtualopensystems.com> | 2013-01-20 18:28:09 -0500 |
---|---|---|
committer | Christoffer Dall <c.dall@virtualopensystems.com> | 2013-01-23 13:29:13 -0500 |
commit | 5b3e5e5bf230f56309706dfc05fc0cb173cc83aa (patch) | |
tree | da2ed7c2553526469c802c2a7903b1595b8be3ce /arch/arm/include/asm/kvm_emulate.h | |
parent | f7ed45be3ba524e06a6d933f0517dc7ad2d06703 (diff) |
KVM: ARM: Emulation framework and CP15 emulation
Adds a new important function in the main KVM/ARM code called
handle_exit() which is called from kvm_arch_vcpu_ioctl_run() on returns
from guest execution. This function examines the Hyp-Syndrome-Register
(HSR), which contains information telling KVM what caused the exit from
the guest.
Some of the reasons for an exit are CP15 accesses, which are
not allowed from the guest and this commit handles these exits by
emulating the intended operation in software and skipping the guest
instruction.
Minor notes about the coproc register reset:
1) We reserve a value of 0 as an invalid cp15 offset, to catch bugs in our
table, at cost of 4 bytes per vcpu.
2) Added comments on the table indicating how we handle each register, for
simplicity of understanding.
Reviewed-by: Will Deacon <will.deacon@arm.com>
Reviewed-by: Marcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Signed-off-by: Christoffer Dall <c.dall@virtualopensystems.com>
Diffstat (limited to 'arch/arm/include/asm/kvm_emulate.h')
-rw-r--r-- | arch/arm/include/asm/kvm_emulate.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/arch/arm/include/asm/kvm_emulate.h b/arch/arm/include/asm/kvm_emulate.h index 17dad674b90f..01a755b80632 100644 --- a/arch/arm/include/asm/kvm_emulate.h +++ b/arch/arm/include/asm/kvm_emulate.h | |||
@@ -25,6 +25,12 @@ | |||
25 | u32 *vcpu_reg(struct kvm_vcpu *vcpu, u8 reg_num); | 25 | u32 *vcpu_reg(struct kvm_vcpu *vcpu, u8 reg_num); |
26 | u32 *vcpu_spsr(struct kvm_vcpu *vcpu); | 26 | u32 *vcpu_spsr(struct kvm_vcpu *vcpu); |
27 | 27 | ||
28 | int kvm_handle_wfi(struct kvm_vcpu *vcpu, struct kvm_run *run); | ||
29 | void kvm_skip_instr(struct kvm_vcpu *vcpu, bool is_wide_instr); | ||
30 | void kvm_inject_undefined(struct kvm_vcpu *vcpu); | ||
31 | void kvm_inject_dabt(struct kvm_vcpu *vcpu, unsigned long addr); | ||
32 | void kvm_inject_pabt(struct kvm_vcpu *vcpu, unsigned long addr); | ||
33 | |||
28 | static inline u32 *vcpu_pc(struct kvm_vcpu *vcpu) | 34 | static inline u32 *vcpu_pc(struct kvm_vcpu *vcpu) |
29 | { | 35 | { |
30 | return (u32 *)&vcpu->arch.regs.usr_regs.ARM_pc; | 36 | return (u32 *)&vcpu->arch.regs.usr_regs.ARM_pc; |