mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
target/arm: Make CCR register banked for v8M
Make the CCR register banked if v8M security extensions are enabled. This is slightly more complicated than the other "add banking" patches because there is one bit in the register which is not banked. We keep the live data in the NS copy of the register, and adjust it on register reads and writes. (Since we don't currently implement the behaviour that the bit controls, there is nowhere else that needs to care.) This patch includes the enforcement of the bits which are newly RES1 in ARMv8M. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Message-id: 1503414539-28762-17-git-send-email-peter.maydell@linaro.org
This commit is contained in:
parent
ecf5e8eae8
commit
9d40cd8a68
5 changed files with 42 additions and 13 deletions
|
@ -117,7 +117,7 @@ static const VMStateDescription vmstate_m = {
|
|||
VMSTATE_UINT32(env.v7m.vecbase[M_REG_NS], ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.basepri[M_REG_NS], ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.control[M_REG_NS], ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.ccr, ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.ccr[M_REG_NS], ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.cfsr, ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.hfsr, ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.dfsr, ARMCPU),
|
||||
|
@ -271,6 +271,7 @@ static const VMStateDescription vmstate_m_security = {
|
|||
VMSTATE_UINT32(env.pmsav7.rnr[M_REG_S], ARMCPU),
|
||||
VMSTATE_VALIDATE("secure MPU_RNR is valid", s_rnr_vmstate_validate),
|
||||
VMSTATE_UINT32(env.v7m.mpu_ctrl[M_REG_S], ARMCPU),
|
||||
VMSTATE_UINT32(env.v7m.ccr[M_REG_S], ARMCPU),
|
||||
VMSTATE_END_OF_LIST()
|
||||
}
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue