mirror of https://github.com/xemu-project/xemu.git
target/riscv: remove RISCV_FEATURE_MMU
RISCV_FEATURE_MMU is set whether cpu->cfg.mmu is set, so let's just use the flag directly instead. With this change the enum is also removed. It is worth noticing that this enum, and all the RISCV_FEATURES_* that were contained in it, predates the existence of the cpu->cfg object. Today, using cpu->cfg is an easier way to retrieve all the features and extensions enabled in the hart. Signed-off-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Reviewed-by: Weiwei Li <liweiwei@iscas.ac.cn> Reviewed-by: Bin Meng <bmeng@tinylab.org> Reviewed-by: Andrew Jones <ajones@ventanamicro.com> Reviewed-by: LIU Zhiwei <zhiwei_liu@linux.alibaba.com> Message-ID: <20230222185205.355361-10-dbarboza@ventanamicro.com> Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
This commit is contained in:
parent
c95c9d200e
commit
dcf654a3e8
|
@ -919,10 +919,6 @@ static void riscv_cpu_realize(DeviceState *dev, Error **errp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cpu->cfg.mmu) {
|
|
||||||
riscv_set_feature(env, RISCV_FEATURE_MMU);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (cpu->cfg.epmp && !cpu->cfg.pmp) {
|
if (cpu->cfg.epmp && !cpu->cfg.pmp) {
|
||||||
/*
|
/*
|
||||||
* Enhanced PMP should only be available
|
* Enhanced PMP should only be available
|
||||||
|
|
|
@ -81,13 +81,6 @@
|
||||||
#define RVH RV('H')
|
#define RVH RV('H')
|
||||||
#define RVJ RV('J')
|
#define RVJ RV('J')
|
||||||
|
|
||||||
/* S extension denotes that Supervisor mode exists, however it is possible
|
|
||||||
to have a core that support S mode but does not have an MMU and there
|
|
||||||
is currently no bit in misa to indicate whether an MMU exists or not
|
|
||||||
so a cpu features bitfield is required, likewise for optional PMP support */
|
|
||||||
enum {
|
|
||||||
RISCV_FEATURE_MMU,
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Privileged specification version */
|
/* Privileged specification version */
|
||||||
enum {
|
enum {
|
||||||
|
|
|
@ -796,7 +796,7 @@ static int get_physical_address(CPURISCVState *env, hwaddr *physical,
|
||||||
mode = PRV_U;
|
mode = PRV_U;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mode == PRV_M || !riscv_feature(env, RISCV_FEATURE_MMU)) {
|
if (mode == PRV_M || !riscv_cpu_cfg(env)->mmu) {
|
||||||
*physical = addr;
|
*physical = addr;
|
||||||
*prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;
|
*prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;
|
||||||
return TRANSLATE_SUCCESS;
|
return TRANSLATE_SUCCESS;
|
||||||
|
|
|
@ -2621,7 +2621,7 @@ static RISCVException rmw_siph(CPURISCVState *env, int csrno,
|
||||||
static RISCVException read_satp(CPURISCVState *env, int csrno,
|
static RISCVException read_satp(CPURISCVState *env, int csrno,
|
||||||
target_ulong *val)
|
target_ulong *val)
|
||||||
{
|
{
|
||||||
if (!riscv_feature(env, RISCV_FEATURE_MMU)) {
|
if (!riscv_cpu_cfg(env)->mmu) {
|
||||||
*val = 0;
|
*val = 0;
|
||||||
return RISCV_EXCP_NONE;
|
return RISCV_EXCP_NONE;
|
||||||
}
|
}
|
||||||
|
@ -2640,7 +2640,7 @@ static RISCVException write_satp(CPURISCVState *env, int csrno,
|
||||||
{
|
{
|
||||||
target_ulong vm, mask;
|
target_ulong vm, mask;
|
||||||
|
|
||||||
if (!riscv_feature(env, RISCV_FEATURE_MMU)) {
|
if (!riscv_cpu_cfg(env)->mmu) {
|
||||||
return RISCV_EXCP_NONE;
|
return RISCV_EXCP_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -218,7 +218,7 @@ void hmp_info_mem(Monitor *mon, const QDict *qdict)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!riscv_feature(env, RISCV_FEATURE_MMU)) {
|
if (!riscv_cpu_cfg(env)->mmu) {
|
||||||
monitor_printf(mon, "S-mode MMU unavailable\n");
|
monitor_printf(mon, "S-mode MMU unavailable\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -315,7 +315,7 @@ int pmp_hart_has_privs(CPURISCVState *env, target_ulong addr,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (size == 0) {
|
if (size == 0) {
|
||||||
if (riscv_feature(env, RISCV_FEATURE_MMU)) {
|
if (riscv_cpu_cfg(env)->mmu) {
|
||||||
/*
|
/*
|
||||||
* If size is unknown (0), assume that all bytes
|
* If size is unknown (0), assume that all bytes
|
||||||
* from addr to the end of the page will be accessed.
|
* from addr to the end of the page will be accessed.
|
||||||
|
|
Loading…
Reference in New Issue