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:09:52 +0000
commit0b76796abdc865f5cb275f229569fe3259434d4c (patch)
tree9f7e988a63eaa353f54cac6e8040cbca78d4de4c
parente6dbc4dfd1444a38647fb55e9238112291b9e4cd (diff)
downloadsrc-0b76796abdc865f5cb275f229569fe3259434d4c.tar.gz
src-0b76796abdc865f5cb275f229569fe3259434d4c.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;