aboutsummaryrefslogtreecommitdiff
path: root/target/hppa/cpu.h
diff options
context:
space:
mode:
authorHelge Deller <deller@gmx.de>2023-08-07 11:32:09 +0200
committerHelge Deller <deller@gmx.de>2023-08-25 15:57:49 +0200
commitc01e5dfb9a5b7a4c044e5da8840b6bc1175e5839 (patch)
treee04b94aac8be3bbefba7597a259cc9559c361d43 /target/hppa/cpu.h
parentc400b6ed877213ad3d87d0e27f260401a9194c7c (diff)
downloadqemu-c01e5dfb9a5b7a4c044e5da8840b6bc1175e5839.zip
qemu-c01e5dfb9a5b7a4c044e5da8840b6bc1175e5839.tar.gz
qemu-c01e5dfb9a5b7a4c044e5da8840b6bc1175e5839.tar.bz2
target/hppa: Add privilege to MMU index conversion helpers
Add two macros which convert privilege level to/from MMU index: - PRIV_TO_MMU_IDX(priv) returns the MMU index for the given privilege level - MMU_IDX_TO_PRIV(mmu_idx) returns the corresponding privilege level for this MMU index The introduction of those macros make the code easier to read and will help to improve performance in follow-up patch. Signed-off-by: Helge Deller <deller@gmx.de> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Diffstat (limited to 'target/hppa/cpu.h')
-rw-r--r--target/hppa/cpu.h5
1 files changed, 4 insertions, 1 deletions
diff --git a/target/hppa/cpu.h b/target/hppa/cpu.h
index 6c5b0e6..50b513f 100644
--- a/target/hppa/cpu.h
+++ b/target/hppa/cpu.h
@@ -36,6 +36,9 @@
#define MMU_USER_IDX 3
#define MMU_PHYS_IDX 4
+#define PRIV_TO_MMU_IDX(priv) (priv)
+#define MMU_IDX_TO_PRIV(mmu_idx) (mmu_idx)
+
#define TARGET_INSN_START_EXTRA_WORDS 1
/* Hardware exceptions, interrupts, faults, and traps. */
@@ -236,7 +239,7 @@ static inline int cpu_mmu_index(CPUHPPAState *env, bool ifetch)
return MMU_USER_IDX;
#else
if (env->psw & (ifetch ? PSW_C : PSW_D)) {
- return env->iaoq_f & 3;
+ return PRIV_TO_MMU_IDX(env->iaoq_f & 3);
}
return MMU_PHYS_IDX; /* mmu disabled */
#endif