diff options
author | Alex Bennée | 2022-02-04 21:43:35 +0100 |
---|---|---|
committer | Alex Bennée | 2022-02-09 14:26:29 +0100 |
commit | 6f15c076dae07c2438eb488d71fa332e2b8d0963 (patch) | |
tree | 4d88cbdafdb546272a5cbc886181e5de4245b8e5 /target/riscv/sbi_ecall_interface.h | |
parent | target/i386: use CPU_LOG_INT for IRQ servicing (diff) | |
download | qemu-6f15c076dae07c2438eb488d71fa332e2b8d0963.tar.gz qemu-6f15c076dae07c2438eb488d71fa332e2b8d0963.tar.xz qemu-6f15c076dae07c2438eb488d71fa332e2b8d0963.zip |
plugins: move reset of plugin data to tb_start
We can't always guarantee we get to the end of a translator loop.
Although this can happen for a variety of reasons it does happen more
often on x86 system emulation when an instruction spans across to an
un-faulted page. This caused confusion of the instruction tracking
data resulting in apparent reverse execution (at least from the
plugins point of view).
Fix this by moving the reset code to plugin_gen_tb_start so we always
start with a clean slate.
We unconditionally reset tcg_ctx->plugin_insn as the
plugin_insn_append code uses this as a proxy for knowing if plugins
are enabled for the current instruction. Otherwise we can hit a race
where a previously instrumented thread leaves a stale value after the
main thread exits and disables instrumentation.
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/824
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Message-Id: <20220204204335.1689602-27-alex.bennee@linaro.org>
Diffstat (limited to 'target/riscv/sbi_ecall_interface.h')
0 files changed, 0 insertions, 0 deletions