mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-08 10:13:56 -06:00
hw/intc/armv7m_nvic: Implement SCR
We were previously making the system control register (SCR) just RAZ/WI. Although we don't implement the functionality this register controls, we should at least provide the state, including the banked state for v8M. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20180209165810.6668-7-peter.maydell@linaro.org
This commit is contained in:
parent
43bbce7fbe
commit
24ac0fb129
3 changed files with 27 additions and 4 deletions
|
@ -863,8 +863,7 @@ static uint32_t nvic_readl(NVICState *s, uint32_t offset, MemTxAttrs attrs)
|
|||
}
|
||||
return val;
|
||||
case 0xd10: /* System Control. */
|
||||
/* TODO: Implement SLEEPONEXIT. */
|
||||
return 0;
|
||||
return cpu->env.v7m.scr[attrs.secure];
|
||||
case 0xd14: /* Configuration Control. */
|
||||
/* The BFHFNMIGN bit is the only non-banked bit; we
|
||||
* keep it in the non-secure copy of the register.
|
||||
|
@ -1285,8 +1284,13 @@ static void nvic_writel(NVICState *s, uint32_t offset, uint32_t value,
|
|||
}
|
||||
break;
|
||||
case 0xd10: /* System Control. */
|
||||
/* TODO: Implement control registers. */
|
||||
qemu_log_mask(LOG_UNIMP, "NVIC: SCR unimplemented\n");
|
||||
/* We don't implement deep-sleep so these bits are RAZ/WI.
|
||||
* The other bits in the register are banked.
|
||||
* QEMU's implementation ignores SEVONPEND and SLEEPONEXIT, which
|
||||
* is architecturally permitted.
|
||||
*/
|
||||
value &= ~(R_V7M_SCR_SLEEPDEEP_MASK | R_V7M_SCR_SLEEPDEEPS_MASK);
|
||||
cpu->env.v7m.scr[attrs.secure] = value;
|
||||
break;
|
||||
case 0xd14: /* Configuration Control. */
|
||||
/* Enforce RAZ/WI on reserved and must-RAZ/WI bits */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue