aboutsummaryrefslogtreecommitdiff
path: root/target/riscv/internals.h
diff options
context:
space:
mode:
authorRichard Henderson <richard.henderson@linaro.org>2023-04-12 13:43:21 +0200
committerAlistair Francis <alistair.francis@wdc.com>2023-05-05 10:49:50 +1000
commit340b5805dbf42c0cb26eaa64d069bf3b43ee4f55 (patch)
tree1a7bc9be591bcf1ff71cdc44e0a94eae34aa6558 /target/riscv/internals.h
parent4005a799f190e8c07afa45c88b1b45a9df00ee92 (diff)
downloadqemu-340b5805dbf42c0cb26eaa64d069bf3b43ee4f55.zip
qemu-340b5805dbf42c0cb26eaa64d069bf3b43ee4f55.tar.gz
qemu-340b5805dbf42c0cb26eaa64d069bf3b43ee4f55.tar.bz2
target/riscv: Introduce mmuidx_priv
Use the priv level encoded into the mmu_idx, rather than starting from env->priv. We have already checked MPRV+MPP in riscv_cpu_mmu_index -- no need to repeat that. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Reviewed-by: Weiwei Li <liweiwei@iscas.ac.cn> Tested-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Message-Id: <20230325105429.1142530-14-richard.henderson@linaro.org> Message-Id: <20230412114333.118895-14-richard.henderson@linaro.org> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
Diffstat (limited to 'target/riscv/internals.h')
-rw-r--r--target/riscv/internals.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/target/riscv/internals.h b/target/riscv/internals.h
index 0b61f33..4aa1cb4 100644
--- a/target/riscv/internals.h
+++ b/target/riscv/internals.h
@@ -37,6 +37,15 @@
#define MMUIdx_M 3
#define MMU_2STAGE_BIT (1 << 2)
+static inline int mmuidx_priv(int mmu_idx)
+{
+ int ret = mmu_idx & 3;
+ if (ret == MMUIdx_S_SUM) {
+ ret = PRV_S;
+ }
+ return ret;
+}
+
static inline bool mmuidx_sum(int mmu_idx)
{
return (mmu_idx & 3) == MMUIdx_S_SUM;