svn commit: r353920 - head/sys/arm64/arm64
Andrew Turner
andrew at FreeBSD.org
Wed Oct 23 13:21:16 UTC 2019
Author: andrew
Date: Wed Oct 23 13:21:15 2019
New Revision: 353920
URL: https://svnweb.freebsd.org/changeset/base/353920
Log:
Stop enabling interrupts when reentering kdb on arm64
When we raise a data abort from the kernel we need to enable interrupts,
however we shouldn't be doing this when in the kernel debugger. In this
case interrupts can lead to a further panic as they don't expect to be
run from such a context.
MFC after: 2 weeks
Sponsored by: DARPA, AFRL
Modified:
head/sys/arm64/arm64/trap.c
Modified: head/sys/arm64/arm64/trap.c
==============================================================================
--- head/sys/arm64/arm64/trap.c Wed Oct 23 09:56:53 2019 (r353919)
+++ head/sys/arm64/arm64/trap.c Wed Oct 23 13:21:15 2019 (r353920)
@@ -179,6 +179,8 @@ data_abort(struct thread *td, struct trapframe *frame,
if (lower)
map = &p->p_vmspace->vm_map;
else {
+ intr_enable();
+
/* The top bit tells us which range to use */
if (far >= VM_MAXUSER_ADDRESS) {
map = kernel_map;
@@ -316,7 +318,6 @@ do_el1h_sync(struct thread *td, struct trapframe *fram
case EXCP_INSN_ABORT:
case EXCP_DATA_ABORT:
far = READ_SPECIALREG(far_el1);
- intr_enable();
data_abort(td, frame, esr, far, 0,
exception == EXCP_INSN_ABORT);
break;
More information about the svn-src-all
mailing list