target-ppc: Convert mmu-hash{32,64}.[ch] from CPUPPCState to PowerPCCPU

Like a lot of places these files include a mixture of functions taking
both the older CPUPPCState *env and newer PowerPCCPU *cpu.  Move a step
closer to cleaning this up by standardizing on PowerPCCPU, except for the
helper_* functions which are called with the CPUPPCState * from tcg.

Callers and some related functions are updated as well, the boundaries of
what's changed here are a bit arbitrary.

Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Reviewed-by: Laurent Vivier <lvivier@redhat.com>
Reviewed-by: Alexander Graf <agraf@suse.de>
This commit is contained in:
David Gibson 2016-01-14 15:33:27 +11:00
parent 512fe19330
commit 7ef23068bf
7 changed files with 136 additions and 109 deletions

View File

@ -161,7 +161,7 @@ static target_ulong h_enter(PowerPCCPU *cpu, sPAPRMachineState *spapr,
pte_index &= ~7ULL; pte_index &= ~7ULL;
token = ppc_hash64_start_access(cpu, pte_index); token = ppc_hash64_start_access(cpu, pte_index);
for (; index < 8; index++) { for (; index < 8; index++) {
if ((ppc_hash64_load_hpte0(env, token, index) & HPTE64_V_VALID) == 0) { if (!(ppc_hash64_load_hpte0(cpu, token, index) & HPTE64_V_VALID)) {
break; break;
} }
} }
@ -171,14 +171,14 @@ static target_ulong h_enter(PowerPCCPU *cpu, sPAPRMachineState *spapr,
} }
} else { } else {
token = ppc_hash64_start_access(cpu, pte_index); token = ppc_hash64_start_access(cpu, pte_index);
if (ppc_hash64_load_hpte0(env, token, 0) & HPTE64_V_VALID) { if (ppc_hash64_load_hpte0(cpu, token, 0) & HPTE64_V_VALID) {
ppc_hash64_stop_access(token); ppc_hash64_stop_access(token);
return H_PTEG_FULL; return H_PTEG_FULL;
} }
ppc_hash64_stop_access(token); ppc_hash64_stop_access(token);
} }
ppc_hash64_store_hpte(env, pte_index + index, ppc_hash64_store_hpte(cpu, pte_index + index,
pteh | HPTE64_V_HPTE_DIRTY, ptel); pteh | HPTE64_V_HPTE_DIRTY, ptel);
args[0] = pte_index + index; args[0] = pte_index + index;
@ -192,11 +192,12 @@ typedef enum {
REMOVE_HW = 3, REMOVE_HW = 3,
} RemoveResult; } RemoveResult;
static RemoveResult remove_hpte(CPUPPCState *env, target_ulong ptex, static RemoveResult remove_hpte(PowerPCCPU *cpu, target_ulong ptex,
target_ulong avpn, target_ulong avpn,
target_ulong flags, target_ulong flags,
target_ulong *vp, target_ulong *rp) target_ulong *vp, target_ulong *rp)
{ {
CPUPPCState *env = &cpu->env;
uint64_t token; uint64_t token;
target_ulong v, r, rb; target_ulong v, r, rb;
@ -204,9 +205,9 @@ static RemoveResult remove_hpte(CPUPPCState *env, target_ulong ptex,
return REMOVE_PARM; return REMOVE_PARM;
} }
token = ppc_hash64_start_access(ppc_env_get_cpu(env), ptex); token = ppc_hash64_start_access(cpu, ptex);
v = ppc_hash64_load_hpte0(env, token, 0); v = ppc_hash64_load_hpte0(cpu, token, 0);
r = ppc_hash64_load_hpte1(env, token, 0); r = ppc_hash64_load_hpte1(cpu, token, 0);
ppc_hash64_stop_access(token); ppc_hash64_stop_access(token);
if ((v & HPTE64_V_VALID) == 0 || if ((v & HPTE64_V_VALID) == 0 ||
@ -216,7 +217,7 @@ static RemoveResult remove_hpte(CPUPPCState *env, target_ulong ptex,
} }
*vp = v; *vp = v;
*rp = r; *rp = r;
ppc_hash64_store_hpte(env, ptex, HPTE64_V_HPTE_DIRTY, 0); ppc_hash64_store_hpte(cpu, ptex, HPTE64_V_HPTE_DIRTY, 0);
rb = compute_tlbie_rb(v, r, ptex); rb = compute_tlbie_rb(v, r, ptex);
ppc_tlb_invalidate_one(env, rb); ppc_tlb_invalidate_one(env, rb);
return REMOVE_SUCCESS; return REMOVE_SUCCESS;
@ -225,13 +226,12 @@ static RemoveResult remove_hpte(CPUPPCState *env, target_ulong ptex,
static target_ulong h_remove(PowerPCCPU *cpu, sPAPRMachineState *spapr, static target_ulong h_remove(PowerPCCPU *cpu, sPAPRMachineState *spapr,
target_ulong opcode, target_ulong *args) target_ulong opcode, target_ulong *args)
{ {
CPUPPCState *env = &cpu->env;
target_ulong flags = args[0]; target_ulong flags = args[0];
target_ulong pte_index = args[1]; target_ulong pte_index = args[1];
target_ulong avpn = args[2]; target_ulong avpn = args[2];
RemoveResult ret; RemoveResult ret;
ret = remove_hpte(env, pte_index, avpn, flags, ret = remove_hpte(cpu, pte_index, avpn, flags,
&args[0], &args[1]); &args[0], &args[1]);
switch (ret) { switch (ret) {
@ -272,7 +272,6 @@ static target_ulong h_remove(PowerPCCPU *cpu, sPAPRMachineState *spapr,
static target_ulong h_bulk_remove(PowerPCCPU *cpu, sPAPRMachineState *spapr, static target_ulong h_bulk_remove(PowerPCCPU *cpu, sPAPRMachineState *spapr,
target_ulong opcode, target_ulong *args) target_ulong opcode, target_ulong *args)
{ {
CPUPPCState *env = &cpu->env;
int i; int i;
for (i = 0; i < H_BULK_REMOVE_MAX_BATCH; i++) { for (i = 0; i < H_BULK_REMOVE_MAX_BATCH; i++) {
@ -294,7 +293,7 @@ static target_ulong h_bulk_remove(PowerPCCPU *cpu, sPAPRMachineState *spapr,
return H_PARAMETER; return H_PARAMETER;
} }
ret = remove_hpte(env, *tsh & H_BULK_REMOVE_PTEX, tsl, ret = remove_hpte(cpu, *tsh & H_BULK_REMOVE_PTEX, tsl,
(*tsh & H_BULK_REMOVE_FLAGS) >> 26, (*tsh & H_BULK_REMOVE_FLAGS) >> 26,
&v, &r); &v, &r);
@ -331,8 +330,8 @@ static target_ulong h_protect(PowerPCCPU *cpu, sPAPRMachineState *spapr,
} }
token = ppc_hash64_start_access(cpu, pte_index); token = ppc_hash64_start_access(cpu, pte_index);
v = ppc_hash64_load_hpte0(env, token, 0); v = ppc_hash64_load_hpte0(cpu, token, 0);
r = ppc_hash64_load_hpte1(env, token, 0); r = ppc_hash64_load_hpte1(cpu, token, 0);
ppc_hash64_stop_access(token); ppc_hash64_stop_access(token);
if ((v & HPTE64_V_VALID) == 0 || if ((v & HPTE64_V_VALID) == 0 ||
@ -346,11 +345,11 @@ static target_ulong h_protect(PowerPCCPU *cpu, sPAPRMachineState *spapr,
r |= (flags << 48) & HPTE64_R_KEY_HI; r |= (flags << 48) & HPTE64_R_KEY_HI;
r |= flags & (HPTE64_R_PP | HPTE64_R_N | HPTE64_R_KEY_LO); r |= flags & (HPTE64_R_PP | HPTE64_R_N | HPTE64_R_KEY_LO);
rb = compute_tlbie_rb(v, r, pte_index); rb = compute_tlbie_rb(v, r, pte_index);
ppc_hash64_store_hpte(env, pte_index, ppc_hash64_store_hpte(cpu, pte_index,
(v & ~HPTE64_V_VALID) | HPTE64_V_HPTE_DIRTY, 0); (v & ~HPTE64_V_VALID) | HPTE64_V_HPTE_DIRTY, 0);
ppc_tlb_invalidate_one(env, rb); ppc_tlb_invalidate_one(env, rb);
/* Don't need a memory barrier, due to qemu's global lock */ /* Don't need a memory barrier, due to qemu's global lock */
ppc_hash64_store_hpte(env, pte_index, v | HPTE64_V_HPTE_DIRTY, r); ppc_hash64_store_hpte(cpu, pte_index, v | HPTE64_V_HPTE_DIRTY, r);
return H_SUCCESS; return H_SUCCESS;
} }

View File

@ -1205,7 +1205,7 @@ int kvm_arch_get_registers(CPUState *cs)
* Only restore valid entries * Only restore valid entries
*/ */
if (rb & SLB_ESID_V) { if (rb & SLB_ESID_V) {
ppc_store_slb(env, rb, rs); ppc_store_slb(cpu, rb, rs);
} }
} }
#endif #endif

View File

@ -84,9 +84,10 @@ static int ppc_hash32_pp_prot(int key, int pp, int nx)
return prot; return prot;
} }
static int ppc_hash32_pte_prot(CPUPPCState *env, static int ppc_hash32_pte_prot(PowerPCCPU *cpu,
target_ulong sr, ppc_hash_pte32_t pte) target_ulong sr, ppc_hash_pte32_t pte)
{ {
CPUPPCState *env = &cpu->env;
unsigned pp, key; unsigned pp, key;
key = !!(msr_pr ? (sr & SR32_KP) : (sr & SR32_KS)); key = !!(msr_pr ? (sr & SR32_KP) : (sr & SR32_KS));
@ -95,9 +96,11 @@ static int ppc_hash32_pte_prot(CPUPPCState *env,
return ppc_hash32_pp_prot(key, pp, !!(sr & SR32_NX)); return ppc_hash32_pp_prot(key, pp, !!(sr & SR32_NX));
} }
static target_ulong hash32_bat_size(CPUPPCState *env, static target_ulong hash32_bat_size(PowerPCCPU *cpu,
target_ulong batu, target_ulong batl) target_ulong batu, target_ulong batl)
{ {
CPUPPCState *env = &cpu->env;
if ((msr_pr && !(batu & BATU32_VP)) if ((msr_pr && !(batu & BATU32_VP))
|| (!msr_pr && !(batu & BATU32_VS))) { || (!msr_pr && !(batu & BATU32_VS))) {
return 0; return 0;
@ -106,7 +109,7 @@ static target_ulong hash32_bat_size(CPUPPCState *env,
return BATU32_BEPI & ~((batu & BATU32_BL) << 15); return BATU32_BEPI & ~((batu & BATU32_BL) << 15);
} }
static int hash32_bat_prot(CPUPPCState *env, static int hash32_bat_prot(PowerPCCPU *cpu,
target_ulong batu, target_ulong batl) target_ulong batu, target_ulong batl)
{ {
int pp, prot; int pp, prot;
@ -122,7 +125,7 @@ static int hash32_bat_prot(CPUPPCState *env,
return prot; return prot;
} }
static target_ulong hash32_bat_601_size(CPUPPCState *env, static target_ulong hash32_bat_601_size(PowerPCCPU *cpu,
target_ulong batu, target_ulong batl) target_ulong batu, target_ulong batl)
{ {
if (!(batl & BATL32_601_V)) { if (!(batl & BATL32_601_V)) {
@ -132,9 +135,10 @@ static target_ulong hash32_bat_601_size(CPUPPCState *env,
return BATU32_BEPI & ~((batl & BATL32_601_BL) << 17); return BATU32_BEPI & ~((batl & BATL32_601_BL) << 17);
} }
static int hash32_bat_601_prot(CPUPPCState *env, static int hash32_bat_601_prot(PowerPCCPU *cpu,
target_ulong batu, target_ulong batl) target_ulong batu, target_ulong batl)
{ {
CPUPPCState *env = &cpu->env;
int key, pp; int key, pp;
pp = batu & BATU32_601_PP; pp = batu & BATU32_601_PP;
@ -146,9 +150,10 @@ static int hash32_bat_601_prot(CPUPPCState *env,
return ppc_hash32_pp_prot(key, pp, 0); return ppc_hash32_pp_prot(key, pp, 0);
} }
static hwaddr ppc_hash32_bat_lookup(CPUPPCState *env, target_ulong ea, int rwx, static hwaddr ppc_hash32_bat_lookup(PowerPCCPU *cpu, target_ulong ea, int rwx,
int *prot) int *prot)
{ {
CPUPPCState *env = &cpu->env;
target_ulong *BATlt, *BATut; target_ulong *BATlt, *BATut;
int i; int i;
@ -167,9 +172,9 @@ static hwaddr ppc_hash32_bat_lookup(CPUPPCState *env, target_ulong ea, int rwx,
target_ulong mask; target_ulong mask;
if (unlikely(env->mmu_model == POWERPC_MMU_601)) { if (unlikely(env->mmu_model == POWERPC_MMU_601)) {
mask = hash32_bat_601_size(env, batu, batl); mask = hash32_bat_601_size(cpu, batu, batl);
} else { } else {
mask = hash32_bat_size(env, batu, batl); mask = hash32_bat_size(cpu, batu, batl);
} }
LOG_BATS("%s: %cBAT%d v " TARGET_FMT_lx " BATu " TARGET_FMT_lx LOG_BATS("%s: %cBAT%d v " TARGET_FMT_lx " BATu " TARGET_FMT_lx
" BATl " TARGET_FMT_lx "\n", __func__, " BATl " TARGET_FMT_lx "\n", __func__,
@ -179,9 +184,9 @@ static hwaddr ppc_hash32_bat_lookup(CPUPPCState *env, target_ulong ea, int rwx,
hwaddr raddr = (batl & mask) | (ea & ~mask); hwaddr raddr = (batl & mask) | (ea & ~mask);
if (unlikely(env->mmu_model == POWERPC_MMU_601)) { if (unlikely(env->mmu_model == POWERPC_MMU_601)) {
*prot = hash32_bat_601_prot(env, batu, batl); *prot = hash32_bat_601_prot(cpu, batu, batl);
} else { } else {
*prot = hash32_bat_prot(env, batu, batl); *prot = hash32_bat_prot(cpu, batu, batl);
} }
return raddr & TARGET_PAGE_MASK; return raddr & TARGET_PAGE_MASK;
@ -210,11 +215,12 @@ static hwaddr ppc_hash32_bat_lookup(CPUPPCState *env, target_ulong ea, int rwx,
return -1; return -1;
} }
static int ppc_hash32_direct_store(CPUPPCState *env, target_ulong sr, static int ppc_hash32_direct_store(PowerPCCPU *cpu, target_ulong sr,
target_ulong eaddr, int rwx, target_ulong eaddr, int rwx,
hwaddr *raddr, int *prot) hwaddr *raddr, int *prot)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUState *cs = CPU(cpu);
CPUPPCState *env = &cpu->env;
int key = !!(msr_pr ? (sr & SR32_KP) : (sr & SR32_KS)); int key = !!(msr_pr ? (sr & SR32_KP) : (sr & SR32_KS));
qemu_log_mask(CPU_LOG_MMU, "direct store...\n"); qemu_log_mask(CPU_LOG_MMU, "direct store...\n");
@ -294,12 +300,14 @@ static int ppc_hash32_direct_store(CPUPPCState *env, target_ulong sr,
} }
} }
hwaddr get_pteg_offset32(CPUPPCState *env, hwaddr hash) hwaddr get_pteg_offset32(PowerPCCPU *cpu, hwaddr hash)
{ {
CPUPPCState *env = &cpu->env;
return (hash * HASH_PTEG_SIZE_32) & env->htab_mask; return (hash * HASH_PTEG_SIZE_32) & env->htab_mask;
} }
static hwaddr ppc_hash32_pteg_search(CPUPPCState *env, hwaddr pteg_off, static hwaddr ppc_hash32_pteg_search(PowerPCCPU *cpu, hwaddr pteg_off,
bool secondary, target_ulong ptem, bool secondary, target_ulong ptem,
ppc_hash_pte32_t *pte) ppc_hash_pte32_t *pte)
{ {
@ -308,8 +316,8 @@ static hwaddr ppc_hash32_pteg_search(CPUPPCState *env, hwaddr pteg_off,
int i; int i;
for (i = 0; i < HPTES_PER_GROUP; i++) { for (i = 0; i < HPTES_PER_GROUP; i++) {
pte0 = ppc_hash32_load_hpte0(env, pte_offset); pte0 = ppc_hash32_load_hpte0(cpu, pte_offset);
pte1 = ppc_hash32_load_hpte1(env, pte_offset); pte1 = ppc_hash32_load_hpte1(cpu, pte_offset);
if ((pte0 & HPTE32_V_VALID) if ((pte0 & HPTE32_V_VALID)
&& (secondary == !!(pte0 & HPTE32_V_SECONDARY)) && (secondary == !!(pte0 & HPTE32_V_SECONDARY))
@ -325,10 +333,11 @@ static hwaddr ppc_hash32_pteg_search(CPUPPCState *env, hwaddr pteg_off,
return -1; return -1;
} }
static hwaddr ppc_hash32_htab_lookup(CPUPPCState *env, static hwaddr ppc_hash32_htab_lookup(PowerPCCPU *cpu,
target_ulong sr, target_ulong eaddr, target_ulong sr, target_ulong eaddr,
ppc_hash_pte32_t *pte) ppc_hash_pte32_t *pte)
{ {
CPUPPCState *env = &cpu->env;
hwaddr pteg_off, pte_offset; hwaddr pteg_off, pte_offset;
hwaddr hash; hwaddr hash;
uint32_t vsid, pgidx, ptem; uint32_t vsid, pgidx, ptem;
@ -349,16 +358,16 @@ static hwaddr ppc_hash32_htab_lookup(CPUPPCState *env,
" vsid=%" PRIx32 " ptem=%" PRIx32 " vsid=%" PRIx32 " ptem=%" PRIx32
" hash=" TARGET_FMT_plx "\n", " hash=" TARGET_FMT_plx "\n",
env->htab_base, env->htab_mask, vsid, ptem, hash); env->htab_base, env->htab_mask, vsid, ptem, hash);
pteg_off = get_pteg_offset32(env, hash); pteg_off = get_pteg_offset32(cpu, hash);
pte_offset = ppc_hash32_pteg_search(env, pteg_off, 0, ptem, pte); pte_offset = ppc_hash32_pteg_search(cpu, pteg_off, 0, ptem, pte);
if (pte_offset == -1) { if (pte_offset == -1) {
/* Secondary PTEG lookup */ /* Secondary PTEG lookup */
qemu_log_mask(CPU_LOG_MMU, "1 htab=" TARGET_FMT_plx "/" TARGET_FMT_plx qemu_log_mask(CPU_LOG_MMU, "1 htab=" TARGET_FMT_plx "/" TARGET_FMT_plx
" vsid=%" PRIx32 " api=%" PRIx32 " vsid=%" PRIx32 " api=%" PRIx32
" hash=" TARGET_FMT_plx "\n", env->htab_base, " hash=" TARGET_FMT_plx "\n", env->htab_base,
env->htab_mask, vsid, ptem, ~hash); env->htab_mask, vsid, ptem, ~hash);
pteg_off = get_pteg_offset32(env, ~hash); pteg_off = get_pteg_offset32(cpu, ~hash);
pte_offset = ppc_hash32_pteg_search(env, pteg_off, 1, ptem, pte); pte_offset = ppc_hash32_pteg_search(cpu, pteg_off, 1, ptem, pte);
} }
return pte_offset; return pte_offset;
@ -400,7 +409,7 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
/* 2. Check Block Address Translation entries (BATs) */ /* 2. Check Block Address Translation entries (BATs) */
if (env->nb_BATs != 0) { if (env->nb_BATs != 0) {
raddr = ppc_hash32_bat_lookup(env, eaddr, rwx, &prot); raddr = ppc_hash32_bat_lookup(cpu, eaddr, rwx, &prot);
if (raddr != -1) { if (raddr != -1) {
if (need_prot[rwx] & ~prot) { if (need_prot[rwx] & ~prot) {
if (rwx == 2) { if (rwx == 2) {
@ -431,7 +440,7 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
/* 4. Handle direct store segments */ /* 4. Handle direct store segments */
if (sr & SR32_T) { if (sr & SR32_T) {
if (ppc_hash32_direct_store(env, sr, eaddr, rwx, if (ppc_hash32_direct_store(cpu, sr, eaddr, rwx,
&raddr, &prot) == 0) { &raddr, &prot) == 0) {
tlb_set_page(cs, eaddr & TARGET_PAGE_MASK, tlb_set_page(cs, eaddr & TARGET_PAGE_MASK,
raddr & TARGET_PAGE_MASK, prot, mmu_idx, raddr & TARGET_PAGE_MASK, prot, mmu_idx,
@ -450,7 +459,7 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
} }
/* 6. Locate the PTE in the hash table */ /* 6. Locate the PTE in the hash table */
pte_offset = ppc_hash32_htab_lookup(env, sr, eaddr, &pte); pte_offset = ppc_hash32_htab_lookup(cpu, sr, eaddr, &pte);
if (pte_offset == -1) { if (pte_offset == -1) {
if (rwx == 2) { if (rwx == 2) {
cs->exception_index = POWERPC_EXCP_ISI; cs->exception_index = POWERPC_EXCP_ISI;
@ -473,7 +482,7 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
/* 7. Check access permissions */ /* 7. Check access permissions */
prot = ppc_hash32_pte_prot(env, sr, pte); prot = ppc_hash32_pte_prot(cpu, sr, pte);
if (need_prot[rwx] & ~prot) { if (need_prot[rwx] & ~prot) {
/* Access right violation */ /* Access right violation */
@ -508,7 +517,7 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
} }
if (new_pte1 != pte.pte1) { if (new_pte1 != pte.pte1) {
ppc_hash32_store_hpte1(env, pte_offset, new_pte1); ppc_hash32_store_hpte1(cpu, pte_offset, new_pte1);
} }
/* 9. Determine the real address from the PTE */ /* 9. Determine the real address from the PTE */
@ -521,8 +530,9 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
return 0; return 0;
} }
hwaddr ppc_hash32_get_phys_page_debug(CPUPPCState *env, target_ulong eaddr) hwaddr ppc_hash32_get_phys_page_debug(PowerPCCPU *cpu, target_ulong eaddr)
{ {
CPUPPCState *env = &cpu->env;
target_ulong sr; target_ulong sr;
hwaddr pte_offset; hwaddr pte_offset;
ppc_hash_pte32_t pte; ppc_hash_pte32_t pte;
@ -534,7 +544,7 @@ hwaddr ppc_hash32_get_phys_page_debug(CPUPPCState *env, target_ulong eaddr)
} }
if (env->nb_BATs != 0) { if (env->nb_BATs != 0) {
hwaddr raddr = ppc_hash32_bat_lookup(env, eaddr, 0, &prot); hwaddr raddr = ppc_hash32_bat_lookup(cpu, eaddr, 0, &prot);
if (raddr != -1) { if (raddr != -1) {
return raddr; return raddr;
} }
@ -547,7 +557,7 @@ hwaddr ppc_hash32_get_phys_page_debug(CPUPPCState *env, target_ulong eaddr)
return -1; return -1;
} }
pte_offset = ppc_hash32_htab_lookup(env, sr, eaddr, &pte); pte_offset = ppc_hash32_htab_lookup(cpu, sr, eaddr, &pte);
if (pte_offset == -1) { if (pte_offset == -1) {
return -1; return -1;
} }

View File

@ -3,8 +3,8 @@
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
hwaddr get_pteg_offset32(CPUPPCState *env, hwaddr hash); hwaddr get_pteg_offset32(PowerPCCPU *cpu, hwaddr hash);
hwaddr ppc_hash32_get_phys_page_debug(CPUPPCState *env, target_ulong addr); hwaddr ppc_hash32_get_phys_page_debug(PowerPCCPU *cpu, target_ulong addr);
int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw, int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw,
int mmu_idx); int mmu_idx);
@ -65,40 +65,42 @@ int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw,
#define HPTE32_R_WIMG 0x00000078 #define HPTE32_R_WIMG 0x00000078
#define HPTE32_R_PP 0x00000003 #define HPTE32_R_PP 0x00000003
static inline target_ulong ppc_hash32_load_hpte0(CPUPPCState *env, static inline target_ulong ppc_hash32_load_hpte0(PowerPCCPU *cpu,
hwaddr pte_offset) hwaddr pte_offset)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
assert(!env->external_htab); /* Not supported on 32-bit for now */ assert(!env->external_htab); /* Not supported on 32-bit for now */
return ldl_phys(cs->as, env->htab_base + pte_offset); return ldl_phys(CPU(cpu)->as, env->htab_base + pte_offset);
} }
static inline target_ulong ppc_hash32_load_hpte1(CPUPPCState *env, static inline target_ulong ppc_hash32_load_hpte1(PowerPCCPU *cpu,
hwaddr pte_offset) hwaddr pte_offset)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
assert(!env->external_htab); /* Not supported on 32-bit for now */ assert(!env->external_htab); /* Not supported on 32-bit for now */
return ldl_phys(cs->as, env->htab_base + pte_offset + HASH_PTE_SIZE_32/2); return ldl_phys(CPU(cpu)->as,
env->htab_base + pte_offset + HASH_PTE_SIZE_32 / 2);
} }
static inline void ppc_hash32_store_hpte0(CPUPPCState *env, static inline void ppc_hash32_store_hpte0(PowerPCCPU *cpu,
hwaddr pte_offset, target_ulong pte0) hwaddr pte_offset, target_ulong pte0)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
assert(!env->external_htab); /* Not supported on 32-bit for now */ assert(!env->external_htab); /* Not supported on 32-bit for now */
stl_phys(cs->as, env->htab_base + pte_offset, pte0); stl_phys(CPU(cpu)->as, env->htab_base + pte_offset, pte0);
} }
static inline void ppc_hash32_store_hpte1(CPUPPCState *env, static inline void ppc_hash32_store_hpte1(PowerPCCPU *cpu,
hwaddr pte_offset, target_ulong pte1) hwaddr pte_offset, target_ulong pte1)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
assert(!env->external_htab); /* Not supported on 32-bit for now */ assert(!env->external_htab); /* Not supported on 32-bit for now */
stl_phys(cs->as, env->htab_base + pte_offset + HASH_PTE_SIZE_32/2, pte1); stl_phys(CPU(cpu)->as,
env->htab_base + pte_offset + HASH_PTE_SIZE_32 / 2, pte1);
} }
typedef struct { typedef struct {

View File

@ -41,8 +41,9 @@ bool kvmppc_kern_htab;
* SLB handling * SLB handling
*/ */
static ppc_slb_t *slb_lookup(CPUPPCState *env, target_ulong eaddr) static ppc_slb_t *slb_lookup(PowerPCCPU *cpu, target_ulong eaddr)
{ {
CPUPPCState *env = &cpu->env;
uint64_t esid_256M, esid_1T; uint64_t esid_256M, esid_1T;
int n; int n;
@ -70,12 +71,13 @@ static ppc_slb_t *slb_lookup(CPUPPCState *env, target_ulong eaddr)
return NULL; return NULL;
} }
void dump_slb(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env) void dump_slb(FILE *f, fprintf_function cpu_fprintf, PowerPCCPU *cpu)
{ {
CPUPPCState *env = &cpu->env;
int i; int i;
uint64_t slbe, slbv; uint64_t slbe, slbv;
cpu_synchronize_state(CPU(ppc_env_get_cpu(env))); cpu_synchronize_state(CPU(cpu));
cpu_fprintf(f, "SLB\tESID\t\t\tVSID\n"); cpu_fprintf(f, "SLB\tESID\t\t\tVSID\n");
for (i = 0; i < env->slb_nr; i++) { for (i = 0; i < env->slb_nr; i++) {
@ -118,7 +120,7 @@ void helper_slbie(CPUPPCState *env, target_ulong addr)
PowerPCCPU *cpu = ppc_env_get_cpu(env); PowerPCCPU *cpu = ppc_env_get_cpu(env);
ppc_slb_t *slb; ppc_slb_t *slb;
slb = slb_lookup(env, addr); slb = slb_lookup(cpu, addr);
if (!slb) { if (!slb) {
return; return;
} }
@ -134,8 +136,9 @@ void helper_slbie(CPUPPCState *env, target_ulong addr)
} }
} }
int ppc_store_slb(CPUPPCState *env, target_ulong rb, target_ulong rs) int ppc_store_slb(PowerPCCPU *cpu, target_ulong rb, target_ulong rs)
{ {
CPUPPCState *env = &cpu->env;
int slot = rb & 0xfff; int slot = rb & 0xfff;
ppc_slb_t *slb = &env->slb[slot]; ppc_slb_t *slb = &env->slb[slot];
@ -160,9 +163,10 @@ int ppc_store_slb(CPUPPCState *env, target_ulong rb, target_ulong rs)
return 0; return 0;
} }
static int ppc_load_slb_esid(CPUPPCState *env, target_ulong rb, static int ppc_load_slb_esid(PowerPCCPU *cpu, target_ulong rb,
target_ulong *rt) target_ulong *rt)
{ {
CPUPPCState *env = &cpu->env;
int slot = rb & 0xfff; int slot = rb & 0xfff;
ppc_slb_t *slb = &env->slb[slot]; ppc_slb_t *slb = &env->slb[slot];
@ -174,9 +178,10 @@ static int ppc_load_slb_esid(CPUPPCState *env, target_ulong rb,
return 0; return 0;
} }
static int ppc_load_slb_vsid(CPUPPCState *env, target_ulong rb, static int ppc_load_slb_vsid(PowerPCCPU *cpu, target_ulong rb,
target_ulong *rt) target_ulong *rt)
{ {
CPUPPCState *env = &cpu->env;
int slot = rb & 0xfff; int slot = rb & 0xfff;
ppc_slb_t *slb = &env->slb[slot]; ppc_slb_t *slb = &env->slb[slot];
@ -190,7 +195,9 @@ static int ppc_load_slb_vsid(CPUPPCState *env, target_ulong rb,
void helper_store_slb(CPUPPCState *env, target_ulong rb, target_ulong rs) void helper_store_slb(CPUPPCState *env, target_ulong rb, target_ulong rs)
{ {
if (ppc_store_slb(env, rb, rs) < 0) { PowerPCCPU *cpu = ppc_env_get_cpu(env);
if (ppc_store_slb(cpu, rb, rs) < 0) {
helper_raise_exception_err(env, POWERPC_EXCP_PROGRAM, helper_raise_exception_err(env, POWERPC_EXCP_PROGRAM,
POWERPC_EXCP_INVAL); POWERPC_EXCP_INVAL);
} }
@ -198,9 +205,10 @@ void helper_store_slb(CPUPPCState *env, target_ulong rb, target_ulong rs)
target_ulong helper_load_slb_esid(CPUPPCState *env, target_ulong rb) target_ulong helper_load_slb_esid(CPUPPCState *env, target_ulong rb)
{ {
PowerPCCPU *cpu = ppc_env_get_cpu(env);
target_ulong rt = 0; target_ulong rt = 0;
if (ppc_load_slb_esid(env, rb, &rt) < 0) { if (ppc_load_slb_esid(cpu, rb, &rt) < 0) {
helper_raise_exception_err(env, POWERPC_EXCP_PROGRAM, helper_raise_exception_err(env, POWERPC_EXCP_PROGRAM,
POWERPC_EXCP_INVAL); POWERPC_EXCP_INVAL);
} }
@ -209,9 +217,10 @@ target_ulong helper_load_slb_esid(CPUPPCState *env, target_ulong rb)
target_ulong helper_load_slb_vsid(CPUPPCState *env, target_ulong rb) target_ulong helper_load_slb_vsid(CPUPPCState *env, target_ulong rb)
{ {
PowerPCCPU *cpu = ppc_env_get_cpu(env);
target_ulong rt = 0; target_ulong rt = 0;
if (ppc_load_slb_vsid(env, rb, &rt) < 0) { if (ppc_load_slb_vsid(cpu, rb, &rt) < 0) {
helper_raise_exception_err(env, POWERPC_EXCP_PROGRAM, helper_raise_exception_err(env, POWERPC_EXCP_PROGRAM,
POWERPC_EXCP_INVAL); POWERPC_EXCP_INVAL);
} }
@ -222,9 +231,10 @@ target_ulong helper_load_slb_vsid(CPUPPCState *env, target_ulong rb)
* 64-bit hash table MMU handling * 64-bit hash table MMU handling
*/ */
static int ppc_hash64_pte_prot(CPUPPCState *env, static int ppc_hash64_pte_prot(PowerPCCPU *cpu,
ppc_slb_t *slb, ppc_hash_pte64_t pte) ppc_slb_t *slb, ppc_hash_pte64_t pte)
{ {
CPUPPCState *env = &cpu->env;
unsigned pp, key; unsigned pp, key;
/* Some pp bit combinations have undefined behaviour, so default /* Some pp bit combinations have undefined behaviour, so default
* to no access in those cases */ * to no access in those cases */
@ -274,12 +284,12 @@ static int ppc_hash64_pte_prot(CPUPPCState *env,
return prot; return prot;
} }
static int ppc_hash64_amr_prot(CPUPPCState *env, ppc_hash_pte64_t pte) static int ppc_hash64_amr_prot(PowerPCCPU *cpu, ppc_hash_pte64_t pte)
{ {
CPUPPCState *env = &cpu->env;
int key, amrbits; int key, amrbits;
int prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC; int prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;
/* Only recent MMUs implement Virtual Page Class Key Protection */ /* Only recent MMUs implement Virtual Page Class Key Protection */
if (!(env->mmu_model & POWERPC_MMU_AMR)) { if (!(env->mmu_model & POWERPC_MMU_AMR)) {
return prot; return prot;
@ -348,23 +358,24 @@ void ppc_hash64_stop_access(uint64_t token)
} }
} }
static hwaddr ppc_hash64_pteg_search(CPUPPCState *env, hwaddr hash, static hwaddr ppc_hash64_pteg_search(PowerPCCPU *cpu, hwaddr hash,
bool secondary, target_ulong ptem, bool secondary, target_ulong ptem,
ppc_hash_pte64_t *pte) ppc_hash_pte64_t *pte)
{ {
CPUPPCState *env = &cpu->env;
int i; int i;
uint64_t token; uint64_t token;
target_ulong pte0, pte1; target_ulong pte0, pte1;
target_ulong pte_index; target_ulong pte_index;
pte_index = (hash & env->htab_mask) * HPTES_PER_GROUP; pte_index = (hash & env->htab_mask) * HPTES_PER_GROUP;
token = ppc_hash64_start_access(ppc_env_get_cpu(env), pte_index); token = ppc_hash64_start_access(cpu, pte_index);
if (!token) { if (!token) {
return -1; return -1;
} }
for (i = 0; i < HPTES_PER_GROUP; i++) { for (i = 0; i < HPTES_PER_GROUP; i++) {
pte0 = ppc_hash64_load_hpte0(env, token, i); pte0 = ppc_hash64_load_hpte0(cpu, token, i);
pte1 = ppc_hash64_load_hpte1(env, token, i); pte1 = ppc_hash64_load_hpte1(cpu, token, i);
if ((pte0 & HPTE64_V_VALID) if ((pte0 & HPTE64_V_VALID)
&& (secondary == !!(pte0 & HPTE64_V_SECONDARY)) && (secondary == !!(pte0 & HPTE64_V_SECONDARY))
@ -400,10 +411,11 @@ static uint64_t ppc_hash64_page_shift(ppc_slb_t *slb)
return epnshift; return epnshift;
} }
static hwaddr ppc_hash64_htab_lookup(CPUPPCState *env, static hwaddr ppc_hash64_htab_lookup(PowerPCCPU *cpu,
ppc_slb_t *slb, target_ulong eaddr, ppc_slb_t *slb, target_ulong eaddr,
ppc_hash_pte64_t *pte) ppc_hash_pte64_t *pte)
{ {
CPUPPCState *env = &cpu->env;
hwaddr pte_offset; hwaddr pte_offset;
hwaddr hash; hwaddr hash;
uint64_t vsid, epnshift, epnmask, epn, ptem; uint64_t vsid, epnshift, epnmask, epn, ptem;
@ -436,7 +448,7 @@ static hwaddr ppc_hash64_htab_lookup(CPUPPCState *env,
" vsid=" TARGET_FMT_lx " ptem=" TARGET_FMT_lx " vsid=" TARGET_FMT_lx " ptem=" TARGET_FMT_lx
" hash=" TARGET_FMT_plx "\n", " hash=" TARGET_FMT_plx "\n",
env->htab_base, env->htab_mask, vsid, ptem, hash); env->htab_base, env->htab_mask, vsid, ptem, hash);
pte_offset = ppc_hash64_pteg_search(env, hash, 0, ptem, pte); pte_offset = ppc_hash64_pteg_search(cpu, hash, 0, ptem, pte);
if (pte_offset == -1) { if (pte_offset == -1) {
/* Secondary PTEG lookup */ /* Secondary PTEG lookup */
@ -446,7 +458,7 @@ static hwaddr ppc_hash64_htab_lookup(CPUPPCState *env,
" hash=" TARGET_FMT_plx "\n", env->htab_base, " hash=" TARGET_FMT_plx "\n", env->htab_base,
env->htab_mask, vsid, ptem, ~hash); env->htab_mask, vsid, ptem, ~hash);
pte_offset = ppc_hash64_pteg_search(env, ~hash, 1, ptem, pte); pte_offset = ppc_hash64_pteg_search(cpu, ~hash, 1, ptem, pte);
} }
return pte_offset; return pte_offset;
@ -493,7 +505,7 @@ int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr,
} }
/* 2. Translation is on, so look up the SLB */ /* 2. Translation is on, so look up the SLB */
slb = slb_lookup(env, eaddr); slb = slb_lookup(cpu, eaddr);
if (!slb) { if (!slb) {
if (rwx == 2) { if (rwx == 2) {
@ -515,7 +527,7 @@ int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr,
} }
/* 4. Locate the PTE in the hash table */ /* 4. Locate the PTE in the hash table */
pte_offset = ppc_hash64_htab_lookup(env, slb, eaddr, &pte); pte_offset = ppc_hash64_htab_lookup(cpu, slb, eaddr, &pte);
if (pte_offset == -1) { if (pte_offset == -1) {
if (rwx == 2) { if (rwx == 2) {
cs->exception_index = POWERPC_EXCP_ISI; cs->exception_index = POWERPC_EXCP_ISI;
@ -537,8 +549,8 @@ int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr,
/* 5. Check access permissions */ /* 5. Check access permissions */
pp_prot = ppc_hash64_pte_prot(env, slb, pte); pp_prot = ppc_hash64_pte_prot(cpu, slb, pte);
amr_prot = ppc_hash64_amr_prot(env, pte); amr_prot = ppc_hash64_amr_prot(cpu, pte);
prot = pp_prot & amr_prot; prot = pp_prot & amr_prot;
if ((need_prot[rwx] & ~prot) != 0) { if ((need_prot[rwx] & ~prot) != 0) {
@ -581,7 +593,7 @@ int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr,
} }
if (new_pte1 != pte.pte1) { if (new_pte1 != pte.pte1) {
ppc_hash64_store_hpte(env, pte_offset / HASH_PTE_SIZE_64, ppc_hash64_store_hpte(cpu, pte_offset / HASH_PTE_SIZE_64,
pte.pte0, new_pte1); pte.pte0, new_pte1);
} }
@ -595,8 +607,9 @@ int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr,
return 0; return 0;
} }
hwaddr ppc_hash64_get_phys_page_debug(CPUPPCState *env, target_ulong addr) hwaddr ppc_hash64_get_phys_page_debug(PowerPCCPU *cpu, target_ulong addr)
{ {
CPUPPCState *env = &cpu->env;
ppc_slb_t *slb; ppc_slb_t *slb;
hwaddr pte_offset; hwaddr pte_offset;
ppc_hash_pte64_t pte; ppc_hash_pte64_t pte;
@ -606,12 +619,12 @@ hwaddr ppc_hash64_get_phys_page_debug(CPUPPCState *env, target_ulong addr)
return addr & 0x0FFFFFFFFFFFFFFFULL; return addr & 0x0FFFFFFFFFFFFFFFULL;
} }
slb = slb_lookup(env, addr); slb = slb_lookup(cpu, addr);
if (!slb) { if (!slb) {
return -1; return -1;
} }
pte_offset = ppc_hash64_htab_lookup(env, slb, addr, &pte); pte_offset = ppc_hash64_htab_lookup(cpu, slb, addr, &pte);
if (pte_offset == -1) { if (pte_offset == -1) {
return -1; return -1;
} }
@ -619,11 +632,11 @@ hwaddr ppc_hash64_get_phys_page_debug(CPUPPCState *env, target_ulong addr)
return ppc_hash64_pte_raddr(slb, pte, addr) & TARGET_PAGE_MASK; return ppc_hash64_pte_raddr(slb, pte, addr) & TARGET_PAGE_MASK;
} }
void ppc_hash64_store_hpte(CPUPPCState *env, void ppc_hash64_store_hpte(PowerPCCPU *cpu,
target_ulong pte_index, target_ulong pte_index,
target_ulong pte0, target_ulong pte1) target_ulong pte0, target_ulong pte1)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
if (kvmppc_kern_htab) { if (kvmppc_kern_htab) {
kvmppc_hash64_write_pte(env, pte_index, pte0, pte1); kvmppc_hash64_write_pte(env, pte_index, pte0, pte1);
@ -633,9 +646,10 @@ void ppc_hash64_store_hpte(CPUPPCState *env,
pte_index *= HASH_PTE_SIZE_64; pte_index *= HASH_PTE_SIZE_64;
if (env->external_htab) { if (env->external_htab) {
stq_p(env->external_htab + pte_index, pte0); stq_p(env->external_htab + pte_index, pte0);
stq_p(env->external_htab + pte_index + HASH_PTE_SIZE_64/2, pte1); stq_p(env->external_htab + pte_index + HASH_PTE_SIZE_64 / 2, pte1);
} else { } else {
stq_phys(cs->as, env->htab_base + pte_index, pte0); stq_phys(CPU(cpu)->as, env->htab_base + pte_index, pte0);
stq_phys(cs->as, env->htab_base + pte_index + HASH_PTE_SIZE_64/2, pte1); stq_phys(CPU(cpu)->as,
env->htab_base + pte_index + HASH_PTE_SIZE_64 / 2, pte1);
} }
} }

View File

@ -4,12 +4,13 @@
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
#ifdef TARGET_PPC64 #ifdef TARGET_PPC64
void dump_slb(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env); void ppc_hash64_check_page_sizes(PowerPCCPU *cpu, Error **errp);
int ppc_store_slb (CPUPPCState *env, target_ulong rb, target_ulong rs); void dump_slb(FILE *f, fprintf_function cpu_fprintf, PowerPCCPU *cpu);
hwaddr ppc_hash64_get_phys_page_debug(CPUPPCState *env, target_ulong addr); int ppc_store_slb(PowerPCCPU *cpu, target_ulong rb, target_ulong rs);
hwaddr ppc_hash64_get_phys_page_debug(PowerPCCPU *cpu, target_ulong addr);
int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw, int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw,
int mmu_idx); int mmu_idx);
void ppc_hash64_store_hpte(CPUPPCState *env, target_ulong index, void ppc_hash64_store_hpte(PowerPCCPU *cpu, target_ulong index,
target_ulong pte0, target_ulong pte1); target_ulong pte0, target_ulong pte1);
#endif #endif
@ -85,31 +86,31 @@ extern bool kvmppc_kern_htab;
uint64_t ppc_hash64_start_access(PowerPCCPU *cpu, target_ulong pte_index); uint64_t ppc_hash64_start_access(PowerPCCPU *cpu, target_ulong pte_index);
void ppc_hash64_stop_access(uint64_t token); void ppc_hash64_stop_access(uint64_t token);
static inline target_ulong ppc_hash64_load_hpte0(CPUPPCState *env, static inline target_ulong ppc_hash64_load_hpte0(PowerPCCPU *cpu,
uint64_t token, int index) uint64_t token, int index)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
uint64_t addr; uint64_t addr;
addr = token + (index * HASH_PTE_SIZE_64); addr = token + (index * HASH_PTE_SIZE_64);
if (env->external_htab) { if (env->external_htab) {
return ldq_p((const void *)(uintptr_t)addr); return ldq_p((const void *)(uintptr_t)addr);
} else { } else {
return ldq_phys(cs->as, addr); return ldq_phys(CPU(cpu)->as, addr);
} }
} }
static inline target_ulong ppc_hash64_load_hpte1(CPUPPCState *env, static inline target_ulong ppc_hash64_load_hpte1(PowerPCCPU *cpu,
uint64_t token, int index) uint64_t token, int index)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUPPCState *env = &cpu->env;
uint64_t addr; uint64_t addr;
addr = token + (index * HASH_PTE_SIZE_64) + HASH_PTE_SIZE_64/2; addr = token + (index * HASH_PTE_SIZE_64) + HASH_PTE_SIZE_64/2;
if (env->external_htab) { if (env->external_htab) {
return ldq_p((const void *)(uintptr_t)addr); return ldq_p((const void *)(uintptr_t)addr);
} else { } else {
return ldq_phys(cs->as, addr); return ldq_phys(CPU(cpu)->as, addr);
} }
} }

View File

@ -1298,7 +1298,7 @@ void dump_mmu(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env)
case POWERPC_MMU_2_06a: case POWERPC_MMU_2_06a:
case POWERPC_MMU_2_07: case POWERPC_MMU_2_07:
case POWERPC_MMU_2_07a: case POWERPC_MMU_2_07a:
dump_slb(f, cpu_fprintf, env); dump_slb(f, cpu_fprintf, ppc_env_get_cpu(env));
break; break;
#endif #endif
default: default:
@ -1440,12 +1440,12 @@ hwaddr ppc_cpu_get_phys_page_debug(CPUState *cs, vaddr addr)
case POWERPC_MMU_2_06a: case POWERPC_MMU_2_06a:
case POWERPC_MMU_2_07: case POWERPC_MMU_2_07:
case POWERPC_MMU_2_07a: case POWERPC_MMU_2_07a:
return ppc_hash64_get_phys_page_debug(env, addr); return ppc_hash64_get_phys_page_debug(cpu, addr);
#endif #endif
case POWERPC_MMU_32B: case POWERPC_MMU_32B:
case POWERPC_MMU_601: case POWERPC_MMU_601:
return ppc_hash32_get_phys_page_debug(env, addr); return ppc_hash32_get_phys_page_debug(cpu, addr);
default: default:
; ;
@ -1511,6 +1511,7 @@ static int cpu_ppc_handle_mmu_fault(CPUPPCState *env, target_ulong address,
int rw, int mmu_idx) int rw, int mmu_idx)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUState *cs = CPU(ppc_env_get_cpu(env));
PowerPCCPU *cpu = POWERPC_CPU(cs);
mmu_ctx_t ctx; mmu_ctx_t ctx;
int access_type; int access_type;
int ret = 0; int ret = 0;
@ -1612,9 +1613,9 @@ static int cpu_ppc_handle_mmu_fault(CPUPPCState *env, target_ulong address,
tlb_miss: tlb_miss:
env->error_code |= ctx.key << 19; env->error_code |= ctx.key << 19;
env->spr[SPR_HASH1] = env->htab_base + env->spr[SPR_HASH1] = env->htab_base +
get_pteg_offset32(env, ctx.hash[0]); get_pteg_offset32(cpu, ctx.hash[0]);
env->spr[SPR_HASH2] = env->htab_base + env->spr[SPR_HASH2] = env->htab_base +
get_pteg_offset32(env, ctx.hash[1]); get_pteg_offset32(cpu, ctx.hash[1]);
break; break;
case POWERPC_MMU_SOFT_74xx: case POWERPC_MMU_SOFT_74xx:
if (rw == 1) { if (rw == 1) {
@ -2102,7 +2103,7 @@ void helper_store_sr(CPUPPCState *env, target_ulong srnum, target_ulong value)
/* flags = flags */ /* flags = flags */
rs |= ((value >> 27) & 0xf) << 8; rs |= ((value >> 27) & 0xf) << 8;
ppc_store_slb(env, rb, rs); ppc_store_slb(cpu, rb, rs);
} else } else
#endif #endif
if (env->sr[srnum] != value) { if (env->sr[srnum] != value) {