aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Baldwin <jhb@FreeBSD.org>2023-08-25 19:00:37 +0000
committerJohn Baldwin <jhb@FreeBSD.org>2023-10-11 15:10:31 +0000
commitf9984cda960915c594a777d6423804bcaa0fab4e (patch)
tree98e4e09db1d52cdc9d35a3f2c4c567ed3b61d563
parentb53155d4dfc67ee3754d886a03682e8522d85b31 (diff)
downloadsrc-f9984cda960915c594a777d6423804bcaa0fab4e.tar.gz
src-f9984cda960915c594a777d6423804bcaa0fab4e.zip
arm unwind: Reject unaligned stack pointers
Reviewed by: andrew Differential Revision: https://reviews.freebsd.org/D41533 (cherry picked from commit 247e8662d2c080c27937ec4d62e80b2358e8c74f)
-rw-r--r--sys/arm/arm/unwind.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/sys/arm/arm/unwind.c b/sys/arm/arm/unwind.c
index cdc9ef225ee7..591bae3dfc26 100644
--- a/sys/arm/arm/unwind.c
+++ b/sys/arm/arm/unwind.c
@@ -398,6 +398,9 @@ unwind_exec_insn(struct unwind_state *state)
if (mask == 0)
return 1;
+ if (!__is_aligned(vsp, sizeof(register_t)))
+ return 1;
+
/* Update SP */
update_vsp = 1;
@@ -430,6 +433,9 @@ unwind_exec_insn(struct unwind_state *state)
/* Read how many registers to load */
count = insn & INSN_POP_COUNT_MASK;
+ if (!__is_aligned(vsp, sizeof(register_t)))
+ return 1;
+
/* Update sp */
update_vsp = 1;
@@ -460,6 +466,9 @@ unwind_exec_insn(struct unwind_state *state)
if (mask == 0 || (mask & 0xf0) != 0)
return 1;
+ if (!__is_aligned(vsp, sizeof(register_t)))
+ return 1;
+
/* Update SP */
update_vsp = 1;