#ifdef TARGET_SPARC64
#define MMU_MODE2_SUFFIX _hypv
#endif
-#define MMU_USER_IDX 0
+#define MMU_USER_IDX 0
+#define MMU_KERNEL_IDX 1
+#define MMU_HYPV_IDX 2
+
static inline int cpu_mmu_index (CPUState *env)
{
#if defined(CONFIG_USER_ONLY)
- return 0;
+ return MMU_USER_IDX;
#elif !defined(TARGET_SPARC64)
return env->psrs;
#else
if (!env->psrs)
- return 0;
+ return MMU_USER_IDX;
else if ((env->hpstate & HS_PRIV) == 0)
- return 1;
+ return MMU_KERNEL_IDX;
else
- return 2;
+ return MMU_HYPV_IDX;
#endif
}
target_phys_addr_t phys_addr;
int prot, access_index;
- if (get_physical_address(env, &phys_addr, &prot, &access_index, addr, 2, 0) != 0)
- if (get_physical_address(env, &phys_addr, &prot, &access_index, addr, 0, 0) != 0)
+ if (get_physical_address(env, &phys_addr, &prot, &access_index, addr, 2,
+ MMU_KERNEL_IDX) != 0)
+ if (get_physical_address(env, &phys_addr, &prot, &access_index, addr,
+ 0, MMU_KERNEL_IDX) != 0)
return -1;
if (cpu_get_physical_page_desc(phys_addr) == IO_MEM_UNASSIGNED)
return -1;