]> git.proxmox.com Git - mirror_qemu.git/commit
target-arm: Ignore low bit of PC in M-profile exception return
authorPeter Maydell <peter.maydell@linaro.org>
Mon, 16 Mar 2015 12:30:47 +0000 (12:30 +0000)
committerPeter Maydell <peter.maydell@linaro.org>
Mon, 16 Mar 2015 12:30:47 +0000 (12:30 +0000)
commitfcf83ab103dce6d2951f24f48e30820e7dbb3622
tree45fd7842e9c64372faca50d236807dce7b11c362
parentda3e53ddcb0ca924da97ca5a35605fc554aa3e05
target-arm: Ignore low bit of PC in M-profile exception return

For the ARM M-profile cores, exception return pops various registers
including the PC from the stack. The architecture defines that if the
lowest bit in the new PC value is set (ie the PC is not halfword
aligned) then behaviour is UNPREDICTABLE. In practice hardware
implementations seem to simply ignore the low bit, and some buggy
RTOSes incorrectly rely on this. QEMU's behaviour was architecturally
permitted, but bringing QEMU into line with the hardware behaviour
allows more guest code to run. We log the situation as a guest error.

This was reported as LP:1428657.

Reported-by: Anders Esbensen <anders@lyes.dk>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
target-arm/helper.c