mirror of https://github.com/xemu-project/xemu.git
arm: Add ARMv6-M programmer's model support
Forbid stack alignment change. (CCR) Reserve FAULTMASK, BASEPRI registers. Report any fault as a HardFault. Disable MemManage, BusFault and UsageFault, so they always escalated to HardFault. (SHCSR) Signed-off-by: Julia Suvorova <jusual@mail.ru> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com> Message-id: 20180718095628.26442-1-jusual@mail.ru Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
7c9140afd5
commit
22ab346001
|
@ -879,6 +879,9 @@ static uint32_t nvic_readl(NVICState *s, uint32_t offset, MemTxAttrs attrs)
|
|||
val |= cpu->env.v7m.ccr[M_REG_NS] & R_V7M_CCR_BFHFNMIGN_MASK;
|
||||
return val;
|
||||
case 0xd24: /* System Handler Control and State (SHCSR) */
|
||||
if (!arm_feature(&cpu->env, ARM_FEATURE_V7)) {
|
||||
goto bad_offset;
|
||||
}
|
||||
val = 0;
|
||||
if (attrs.secure) {
|
||||
if (s->sec_vectors[ARMV7M_EXCP_MEM].active) {
|
||||
|
@ -1312,6 +1315,10 @@ static void nvic_writel(NVICState *s, uint32_t offset, uint32_t value,
|
|||
cpu->env.v7m.scr[attrs.secure] = value;
|
||||
break;
|
||||
case 0xd14: /* Configuration Control. */
|
||||
if (!arm_feature(&cpu->env, ARM_FEATURE_M_MAIN)) {
|
||||
goto bad_offset;
|
||||
}
|
||||
|
||||
/* Enforce RAZ/WI on reserved and must-RAZ/WI bits */
|
||||
value &= (R_V7M_CCR_STKALIGN_MASK |
|
||||
R_V7M_CCR_BFHFNMIGN_MASK |
|
||||
|
@ -1336,6 +1343,9 @@ static void nvic_writel(NVICState *s, uint32_t offset, uint32_t value,
|
|||
cpu->env.v7m.ccr[attrs.secure] = value;
|
||||
break;
|
||||
case 0xd24: /* System Handler Control and State (SHCSR) */
|
||||
if (!arm_feature(&cpu->env, ARM_FEATURE_V7)) {
|
||||
goto bad_offset;
|
||||
}
|
||||
if (attrs.secure) {
|
||||
s->sec_vectors[ARMV7M_EXCP_MEM].active = (value & (1 << 0)) != 0;
|
||||
/* Secure HardFault active bit cannot be written */
|
||||
|
|
|
@ -231,6 +231,10 @@ static void arm_cpu_reset(CPUState *s)
|
|||
env->v7m.ccr[M_REG_NS] |= R_V7M_CCR_NONBASETHRDENA_MASK;
|
||||
env->v7m.ccr[M_REG_S] |= R_V7M_CCR_NONBASETHRDENA_MASK;
|
||||
}
|
||||
if (!arm_feature(env, ARM_FEATURE_M_MAIN)) {
|
||||
env->v7m.ccr[M_REG_NS] |= R_V7M_CCR_UNALIGN_TRP_MASK;
|
||||
env->v7m.ccr[M_REG_S] |= R_V7M_CCR_UNALIGN_TRP_MASK;
|
||||
}
|
||||
|
||||
/* Unlike A/R profile, M profile defines the reset LR value */
|
||||
env->regs[14] = 0xffffffff;
|
||||
|
|
|
@ -10710,13 +10710,13 @@ void HELPER(v7m_msr)(CPUARMState *env, uint32_t maskreg, uint32_t val)
|
|||
env->v7m.primask[M_REG_NS] = val & 1;
|
||||
return;
|
||||
case 0x91: /* BASEPRI_NS */
|
||||
if (!env->v7m.secure) {
|
||||
if (!env->v7m.secure || !arm_feature(env, ARM_FEATURE_M_MAIN)) {
|
||||
return;
|
||||
}
|
||||
env->v7m.basepri[M_REG_NS] = val & 0xff;
|
||||
return;
|
||||
case 0x93: /* FAULTMASK_NS */
|
||||
if (!env->v7m.secure) {
|
||||
if (!env->v7m.secure || !arm_feature(env, ARM_FEATURE_M_MAIN)) {
|
||||
return;
|
||||
}
|
||||
env->v7m.faultmask[M_REG_NS] = val & 1;
|
||||
|
@ -10800,9 +10800,15 @@ void HELPER(v7m_msr)(CPUARMState *env, uint32_t maskreg, uint32_t val)
|
|||
env->v7m.primask[env->v7m.secure] = val & 1;
|
||||
break;
|
||||
case 17: /* BASEPRI */
|
||||
if (!arm_feature(env, ARM_FEATURE_M_MAIN)) {
|
||||
goto bad_reg;
|
||||
}
|
||||
env->v7m.basepri[env->v7m.secure] = val & 0xff;
|
||||
break;
|
||||
case 18: /* BASEPRI_MAX */
|
||||
if (!arm_feature(env, ARM_FEATURE_M_MAIN)) {
|
||||
goto bad_reg;
|
||||
}
|
||||
val &= 0xff;
|
||||
if (val != 0 && (val < env->v7m.basepri[env->v7m.secure]
|
||||
|| env->v7m.basepri[env->v7m.secure] == 0)) {
|
||||
|
@ -10810,6 +10816,9 @@ void HELPER(v7m_msr)(CPUARMState *env, uint32_t maskreg, uint32_t val)
|
|||
}
|
||||
break;
|
||||
case 19: /* FAULTMASK */
|
||||
if (!arm_feature(env, ARM_FEATURE_M_MAIN)) {
|
||||
goto bad_reg;
|
||||
}
|
||||
env->v7m.faultmask[env->v7m.secure] = val & 1;
|
||||
break;
|
||||
case 20: /* CONTROL */
|
||||
|
|
Loading…
Reference in New Issue