mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-03-23 06:25:12 +00:00
target/arm: Warn about restoring to unaligned stack
Attempting to do an exception return with an exception frame that is not 8-aligned is UNPREDICTABLE in v8M; warn about this. (It is not UNPREDICTABLE in v7M, and our implementation can handle the merely-4-aligned case fine, so we don't need to do anything except warn.) Backports commit cb484f9a6e790205e69d9a444c3e353a3a1cfd84 from qemu
This commit is contained in:
parent
5063ca11ab
commit
2aea283c4f
|
@ -5677,6 +5677,13 @@ static void do_v7m_exception_exit(ARMCPU *cpu)
|
|||
return_to_sp_process);
|
||||
uint32_t frameptr = *frame_sp_p;
|
||||
|
||||
if (!QEMU_IS_ALIGNED(frameptr, 8) &&
|
||||
arm_feature(env, ARM_FEATURE_V8)) {
|
||||
qemu_log_mask(LOG_GUEST_ERROR,
|
||||
"M profile exception return with non-8-aligned SP "
|
||||
"for destination state is UNPREDICTABLE\n");
|
||||
}
|
||||
|
||||
/* Pop registers. TODO: make these accesses use the correct
|
||||
* attributes and address space (S/NS, priv/unpriv) and handle
|
||||
* memory transaction failures.
|
||||
|
|
Loading…
Reference in a new issue