summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@cvs.openbsd.org>2006-02-05 19:53:35 +0000
committerMark Kettenis <kettenis@cvs.openbsd.org>2006-02-05 19:53:35 +0000
commit3fe041c0324ee86aa815121f7c724ec4958c9a97 (patch)
tree20db5648a132cb5860df13c6d261a0b4b872409c /sys
parent94e57ab59d4f7c46b1dff3080c5d629576558290 (diff)
Commit uncommitted bit from 2006/01/03 change to locore.s:
Try to prevent red stating the machine on a misaligned user space stack by SIGKILLing the process. ok miod@, henric@
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/sparc64/sparc64/trap.c18
1 files changed, 16 insertions, 2 deletions
diff --git a/sys/arch/sparc64/sparc64/trap.c b/sys/arch/sparc64/sparc64/trap.c
index b16e3c4b5dc..e83de626ae7 100644
--- a/sys/arch/sparc64/sparc64/trap.c
+++ b/sys/arch/sparc64/sparc64/trap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: trap.c,v 1.39 2006/01/30 21:26:19 miod Exp $ */
+/* $OpenBSD: trap.c,v 1.40 2006/02/05 19:53:34 kettenis Exp $ */
/* $NetBSD: trap.c,v 1.73 2001/08/09 01:03:01 eeh Exp $ */
/*
@@ -477,7 +477,8 @@ trap(tf, type, pc, tstate)
tf->tf_tstate |= (PSTATE_PEF<<TSTATE_PSTATE_SHIFT);
return;
}
- goto dopanic;
+ if (type != T_SPILL_N_NORM && type != T_FILL_N_NORM)
+ goto dopanic;
}
if ((p = curproc) == NULL)
p = &proc0;
@@ -627,6 +628,19 @@ badtrap:
break;
}
+ case T_SPILL_N_NORM:
+ case T_FILL_N_NORM:
+ /*
+ * We got an alignment trap in the spill/fill handler.
+ *
+ * XXX We really should generate a bus error here, but
+ * we could be on the interrupt stack, and dumping
+ * core from the interrupt stack is not a good idea.
+ * It causes random crashes.
+ */
+ sigexit(p, SIGKILL);
+ break;
+
case T_ALIGN:
case T_LDDF_ALIGN:
case T_STDF_ALIGN: