[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 10/11] linux-user/aarch64: Reset btype for signal ha
From: |
Richard Henderson |
Subject: |
[Qemu-devel] [PATCH 10/11] linux-user/aarch64: Reset btype for signal handlers |
Date: |
Thu, 10 Jan 2019 23:17:35 +1100 |
It does not make sense for a SIGILL handler to enter with the
btype set as for the indirect branch that caused the SIGILL.
Nor does it make sense to return from a handler with BTYPE set.
This could be argued to be the handler's job, setting BTYPE
within ucontext->uc_mcontext.pstate, but handling this here
while the ABI is undiscussed.
Signed-off-by: Richard Henderson <address@hidden>
---
linux-user/aarch64/signal.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/linux-user/aarch64/signal.c b/linux-user/aarch64/signal.c
index f84a9cf28a..1fb229e696 100644
--- a/linux-user/aarch64/signal.c
+++ b/linux-user/aarch64/signal.c
@@ -218,6 +218,8 @@ static void target_restore_general_frame(CPUARMState *env,
__get_user(env->pc, &sf->uc.tuc_mcontext.pc);
__get_user(pstate, &sf->uc.tuc_mcontext.pstate);
pstate_write(env, pstate);
+ /* Reset btype that might have been there going into the frame. */
+ env->btype = 0;
}
static void target_restore_fpsimd_record(CPUARMState *env,
@@ -510,6 +512,8 @@ static void target_setup_frame(int usig, struct
target_sigaction *ka,
env->xregs[29] = frame_addr + fr_ofs;
env->pc = ka->_sa_handler;
env->xregs[30] = return_addr;
+ /* Reset btype going into the signal handler. */
+ env->btype = 0;
if (info) {
tswap_siginfo(&frame->info, info);
env->xregs[1] = frame_addr + offsetof(struct target_rt_sigframe, info);
--
2.17.2
- Re: [Qemu-devel] [PATCH 06/11] target/arm: Reset btype for direct branches and syscalls, (continued)
[Qemu-devel] [PATCH 09/11] target/arm: Enable BTI for -cpu max, Richard Henderson, 2019/01/10
[Qemu-devel] [PATCH 10/11] linux-user/aarch64: Reset btype for signal handlers,
Richard Henderson <=
[Qemu-devel] [PATCH 11/11] tests/tcg/aarch64: Add bti smoke test, Richard Henderson, 2019/01/10
Re: [Qemu-devel] [PATCH 00/11] target/arm: Implement ARMv8.5-BTI, no-reply, 2019/01/31