diff --git a/arch/arm64/kernel/traps.c b/arch/arm64/kernel/traps.c index b9da093e03417af345000ec2b16a9ff8072d35d6..bfaaba50507a775b7b0ee3fa583ee6f8afe93cb2 100644 --- a/arch/arm64/kernel/traps.c +++ b/arch/arm64/kernel/traps.c @@ -354,6 +354,9 @@ void force_signal_inject(int signal, int code, unsigned long address) const char *desc; struct pt_regs *regs = current_pt_regs(); + if (WARN_ON(!user_mode(regs))) + return; + clear_siginfo(&info); switch (signal) { @@ -408,8 +411,8 @@ asmlinkage void __exception do_undefinstr(struct pt_regs *regs) if (call_undef_hook(regs) == 0) return; - force_signal_inject(SIGILL, ILL_ILLOPC, regs->pc); BUG_ON(!user_mode(regs)); + force_signal_inject(SIGILL, ILL_ILLOPC, regs->pc); } void cpu_enable_cache_maint_trap(const struct arm64_cpu_capabilities *__unused)