Message ID | 20181108163329.19940-4-alex.bennee@linaro.org |
---|---|
State | Superseded |
Headers | show |
Series | KVM Guest Debug fixes (plus TCG EL2 debug tweaks) | expand |
On 11/8/18 5:33 PM, Alex Bennée wrote: > When we are debugging the guest all exceptions come our way but might > be for the guest's own debug exceptions. We use the ->do_interrupt() > infrastructure to inject the exception into the guest. However, we are > missing a full setup of the exception structure, causing an assert > later down the line. > > Signed-off-by: Alex Bennée <alex.bennee@linaro.org> > Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> r~
diff --git a/target/arm/kvm64.c b/target/arm/kvm64.c index 03b0f78831..bf7824d862 100644 --- a/target/arm/kvm64.c +++ b/target/arm/kvm64.c @@ -1000,6 +1000,7 @@ bool kvm_arm_handle_debug(CPUState *cs, struct kvm_debug_exit_arch *debug_exit) cs->exception_index = EXCP_BKPT; env->exception.syndrome = debug_exit->hsr; env->exception.vaddress = debug_exit->far; + env->exception.target_el = 1; qemu_mutex_lock_iothread(); cc->do_interrupt(cs); qemu_mutex_unlock_iothread();