qemu-e2k/target
Paolo Bonzini 65c9d60a3a target-i386: correctly propagate retaddr into SVM helpers
Commit 2afbdf8 ("target-i386: exception handling for memory helpers",
2015-09-15) changed tlb_fill's cpu_restore_state+raise_exception_err
to raise_exception_err_ra.  After this change, the cpu_restore_state
and raise_exception_err's cpu_loop_exit are merged into
raise_exception_err_ra's cpu_loop_exit_restore.

This actually fixed some bugs, but when SVM is enabled there is a
second path from raise_exception_err_ra to cpu_loop_exit.  This is
the VMEXIT path, and now cpu_vmexit is called without a
cpu_restore_state before.

The fix is to pass the retaddr to cpu_vmexit (via
cpu_svm_check_intercept_param).  All helpers can now use GETPC() to pass
the correct retaddr, too.

Cc: qemu-stable@nongnu.org
Fixes: 2afbdf8480
Reported-by: Alexander Boettcher <alexander.boettcher@genode-labs.com>
Tested-by: Alexander Boettcher <alexander.boettcher@genode-labs.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2017-02-16 18:37:01 +01:00
..
alpha
arm target-arm: Enable vPMU support under TCG mode 2017-02-10 17:40:28 +00:00
cris
hppa target/hppa: Fix gdb_write_register 2017-02-06 18:25:31 -08:00
i386 target-i386: correctly propagate retaddr into SVM helpers 2017-02-16 18:37:01 +01:00
lm32
m68k
microblaze
mips
moxie
nios2
openrisc target/openrisc: Optimize for r0 being zero 2017-02-14 08:15:00 +11:00
ppc
s390x report guest crash information in GUEST_PANICKED event 2017-02-16 15:30:49 +01:00
sh4
sparc
tilegx
tricore
unicore32
xtensa