diff options
author | John Baldwin <jhb@FreeBSD.org> | 2023-08-25 19:00:37 +0000 |
---|---|---|
committer | John Baldwin <jhb@FreeBSD.org> | 2023-10-11 15:09:52 +0000 |
commit | 0b76796abdc865f5cb275f229569fe3259434d4c (patch) | |
tree | 9f7e988a63eaa353f54cac6e8040cbca78d4de4c | |
parent | e6dbc4dfd1444a38647fb55e9238112291b9e4cd (diff) | |
download | src-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.c | 9 |
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; |