armv7m: R14 should reset to 0xffffffff
For M profile (unlike A profile) the reset value of R14 is specified as 0xffffffff. (The rationale is that this is an illegal exception return value, so if guest code tries to return to it it will result in a helpful exception.) Registers r0 to r12 and the flags are architecturally UNKNOWN on reset, so we leave those at zero. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Alex Bennée <alex.bennee@linaro.org> Message-id: 1485285380-10565-11-git-send-email-peter.maydell@linaro.org
This commit is contained in:
parent
dc7abe4d65
commit
056f43df91
@ -196,6 +196,9 @@ static void arm_cpu_reset(CPUState *s)
|
||||
*/
|
||||
env->v7m.ccr = R_V7M_CCR_STKALIGN_MASK;
|
||||
|
||||
/* Unlike A/R profile, M profile defines the reset LR value */
|
||||
env->regs[14] = 0xffffffff;
|
||||
|
||||
/* Load the initial SP and PC from the vector table at address 0 */
|
||||
rom = rom_ptr(0);
|
||||
if (rom) {
|
||||
|
Loading…
Reference in New Issue
Block a user