mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-02 23:33:54 -06:00
target/riscv: pmp: Clear pmp/smepmp bits on reset
As per the Priv and Smepmp specifications, certain bits such as the 'L' bit of pmp entries and mseccfg.MML can only be cleared upon reset and it is necessary to do so to allow 'M' mode firmware to correctly reinitialize the pmp/smpemp state across reboots. As required by the spec, also clear the 'A' field of pmp entries. Signed-off-by: Mayuresh Chitale <mchitale@ventanamicro.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-ID: <20231019065644.1431798-1-mchitale@ventanamicro.com> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
parent
095fe72a12
commit
4bf501dc01
3 changed files with 23 additions and 0 deletions
|
@ -884,6 +884,17 @@ static void riscv_cpu_reset_hold(Object *obj)
|
|||
}
|
||||
/* mmte is supposed to have pm.current hardwired to 1 */
|
||||
env->mmte |= (EXT_STATUS_INITIAL | MMTE_M_PM_CURRENT);
|
||||
|
||||
/*
|
||||
* Clear mseccfg and unlock all the PMP entries upon reset.
|
||||
* This is allowed as per the priv and smepmp specifications
|
||||
* and is needed to clear stale entries across reboots.
|
||||
*/
|
||||
if (riscv_cpu_cfg(env)->ext_smepmp) {
|
||||
env->mseccfg = 0;
|
||||
}
|
||||
|
||||
pmp_unlock_entries(env);
|
||||
#endif
|
||||
env->xl = riscv_cpu_mxl(env);
|
||||
riscv_cpu_update_mask(env);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue