[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 04/41] accel/tcg: Fold cpu_exit_tb_from_sighandler into caller
From: |
Richard Henderson |
Subject: |
[PATCH v3 04/41] accel/tcg: Fold cpu_exit_tb_from_sighandler into caller |
Date: |
Fri, 1 Oct 2021 13:11:14 -0400 |
Remove the comment about siglongjmp. We do use sigsetjmp
in the main cpu loop, but we do not save the signal mask
as most exits from the cpu loop do not require them.
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
accel/tcg/user-exec.c | 14 ++------------
1 file changed, 2 insertions(+), 12 deletions(-)
diff --git a/accel/tcg/user-exec.c b/accel/tcg/user-exec.c
index 6f4fc01b60..de4565f13e 100644
--- a/accel/tcg/user-exec.c
+++ b/accel/tcg/user-exec.c
@@ -46,17 +46,6 @@ __thread uintptr_t helper_retaddr;
//#define DEBUG_SIGNAL
-/* exit the current TB from a signal handler. The host registers are
- restored in a state compatible with the CPU emulator
- */
-static void QEMU_NORETURN cpu_exit_tb_from_sighandler(CPUState *cpu,
- sigset_t *old_set)
-{
- /* XXX: use siglongjmp ? */
- sigprocmask(SIG_SETMASK, old_set, NULL);
- cpu_loop_exit_noexc(cpu);
-}
-
/*
* Adjust the pc to pass to cpu_restore_state; return the memop type.
*/
@@ -155,7 +144,8 @@ bool handle_sigsegv_accerr_write(CPUState *cpu, sigset_t
*old_set,
* currently executing TB was modified and must be exited
* immediately. Clear helper_retaddr for next execution.
*/
- cpu_exit_tb_from_sighandler(cpu, old_set);
+ sigprocmask(SIG_SETMASK, old_set, NULL);
+ cpu_loop_exit_noexc(cpu);
/* NORETURN */
default:
g_assert_not_reached();
--
2.25.1
- [PATCH v3 00/41] linux-user: Streamline handling of SIGSEGV, Richard Henderson, 2021/10/01
- [PATCH v3 02/41] accel/tcg: Move clear_helper_retaddr to cpu loop, Richard Henderson, 2021/10/01
- [PATCH v3 03/41] accel/tcg: Split out handle_sigsegv_accerr_write, Richard Henderson, 2021/10/01
- [PATCH v3 01/41] accel/tcg: Split out adjust_signal_pc, Richard Henderson, 2021/10/01
- [PATCH v3 04/41] accel/tcg: Fold cpu_exit_tb_from_sighandler into caller,
Richard Henderson <=
- [PATCH v3 11/41] linux-user/host/arm: Populate host_signal.h, Richard Henderson, 2021/10/01
- [PATCH v3 07/41] linux-user/host/x86: Populate host_signal.h, Richard Henderson, 2021/10/01
- [PATCH v3 15/41] linux-user/host/riscv: Populate host_signal.h, Richard Henderson, 2021/10/01
- [PATCH v3 05/41] configure: Merge riscv32 and riscv64 host architectures, Richard Henderson, 2021/10/01
- [PATCH v3 10/41] linux-user/host/sparc: Populate host_signal.h, Richard Henderson, 2021/10/01
- [PATCH v3 06/41] linux-user: Reorg handling for SIGSEGV, Richard Henderson, 2021/10/01
- [PATCH v3 08/41] linux-user/host/ppc: Populate host_signal.h, Richard Henderson, 2021/10/01
- [PATCH v3 14/41] linux-user/host/mips: Populate host_signal.h, Richard Henderson, 2021/10/01