mirror of
https://github.com/qemu/qemu.git
synced 2025-01-06 05:33:26 +08:00
target/ppc: Avoid taking "env" parameter to mmu-hash64 functions
In most cases we prefer to pass a PowerPCCPU rather than the (embedded) CPUPPCState. For ppc_hash64_update_{rmls,vrma}() change to take "cpu" instead of "env". For ppc_hash64_set_{dsi,isi}() remove the redundant "env" parameter. In theory this makes more work for the functions, but since "cs", "cpu" and "env" are related by at most constant offsets, the compiler should be able to optimize out the difference at effectively zero cost. helper_*() functions are left alone - since they're more closely tied to the TCG generated code, passing "env" is still the standard there. While we're there, fix an incorrect indentation. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Reviewed-by: Greg Kurz <groug@kaod.org> Reviewed-by: Cédric Le Goater <clg@kaod.org>
This commit is contained in:
parent
644a2c99a9
commit
8fe08fac19
@ -633,9 +633,9 @@ unsigned ppc_hash64_hpte_page_shift_noslb(PowerPCCPU *cpu,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ppc_hash64_set_isi(CPUState *cs, CPUPPCState *env,
|
static void ppc_hash64_set_isi(CPUState *cs, uint64_t error_code)
|
||||||
uint64_t error_code)
|
|
||||||
{
|
{
|
||||||
|
CPUPPCState *env = &POWERPC_CPU(cs)->env;
|
||||||
bool vpm;
|
bool vpm;
|
||||||
|
|
||||||
if (msr_ir) {
|
if (msr_ir) {
|
||||||
@ -659,9 +659,9 @@ static void ppc_hash64_set_isi(CPUState *cs, CPUPPCState *env,
|
|||||||
env->error_code = error_code;
|
env->error_code = error_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ppc_hash64_set_dsi(CPUState *cs, CPUPPCState *env, uint64_t dar,
|
static void ppc_hash64_set_dsi(CPUState *cs, uint64_t dar, uint64_t dsisr)
|
||||||
uint64_t dsisr)
|
|
||||||
{
|
{
|
||||||
|
CPUPPCState *env = &POWERPC_CPU(cs)->env;
|
||||||
bool vpm;
|
bool vpm;
|
||||||
|
|
||||||
if (msr_dr) {
|
if (msr_dr) {
|
||||||
@ -741,13 +741,13 @@ int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, vaddr eaddr,
|
|||||||
} else {
|
} else {
|
||||||
/* The access failed, generate the approriate interrupt */
|
/* The access failed, generate the approriate interrupt */
|
||||||
if (rwx == 2) {
|
if (rwx == 2) {
|
||||||
ppc_hash64_set_isi(cs, env, SRR1_PROTFAULT);
|
ppc_hash64_set_isi(cs, SRR1_PROTFAULT);
|
||||||
} else {
|
} else {
|
||||||
int dsisr = DSISR_PROTFAULT;
|
int dsisr = DSISR_PROTFAULT;
|
||||||
if (rwx == 1) {
|
if (rwx == 1) {
|
||||||
dsisr |= DSISR_ISSTORE;
|
dsisr |= DSISR_ISSTORE;
|
||||||
}
|
}
|
||||||
ppc_hash64_set_dsi(cs, env, eaddr, dsisr);
|
ppc_hash64_set_dsi(cs, eaddr, dsisr);
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -783,7 +783,7 @@ skip_slb_search:
|
|||||||
|
|
||||||
/* 3. Check for segment level no-execute violation */
|
/* 3. Check for segment level no-execute violation */
|
||||||
if ((rwx == 2) && (slb->vsid & SLB_VSID_N)) {
|
if ((rwx == 2) && (slb->vsid & SLB_VSID_N)) {
|
||||||
ppc_hash64_set_isi(cs, env, SRR1_NOEXEC_GUARD);
|
ppc_hash64_set_isi(cs, SRR1_NOEXEC_GUARD);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -791,13 +791,13 @@ skip_slb_search:
|
|||||||
ptex = ppc_hash64_htab_lookup(cpu, slb, eaddr, &pte, &apshift);
|
ptex = ppc_hash64_htab_lookup(cpu, slb, eaddr, &pte, &apshift);
|
||||||
if (ptex == -1) {
|
if (ptex == -1) {
|
||||||
if (rwx == 2) {
|
if (rwx == 2) {
|
||||||
ppc_hash64_set_isi(cs, env, SRR1_NOPTE);
|
ppc_hash64_set_isi(cs, SRR1_NOPTE);
|
||||||
} else {
|
} else {
|
||||||
int dsisr = DSISR_NOPTE;
|
int dsisr = DSISR_NOPTE;
|
||||||
if (rwx == 1) {
|
if (rwx == 1) {
|
||||||
dsisr |= DSISR_ISSTORE;
|
dsisr |= DSISR_ISSTORE;
|
||||||
}
|
}
|
||||||
ppc_hash64_set_dsi(cs, env, eaddr, dsisr);
|
ppc_hash64_set_dsi(cs, eaddr, dsisr);
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -824,7 +824,7 @@ skip_slb_search:
|
|||||||
if (PAGE_EXEC & ~amr_prot) {
|
if (PAGE_EXEC & ~amr_prot) {
|
||||||
srr1 |= SRR1_IAMR; /* Access violates virt pg class key prot */
|
srr1 |= SRR1_IAMR; /* Access violates virt pg class key prot */
|
||||||
}
|
}
|
||||||
ppc_hash64_set_isi(cs, env, srr1);
|
ppc_hash64_set_isi(cs, srr1);
|
||||||
} else {
|
} else {
|
||||||
int dsisr = 0;
|
int dsisr = 0;
|
||||||
if (need_prot[rwx] & ~pp_prot) {
|
if (need_prot[rwx] & ~pp_prot) {
|
||||||
@ -836,7 +836,7 @@ skip_slb_search:
|
|||||||
if (need_prot[rwx] & ~amr_prot) {
|
if (need_prot[rwx] & ~amr_prot) {
|
||||||
dsisr |= DSISR_AMR;
|
dsisr |= DSISR_AMR;
|
||||||
}
|
}
|
||||||
ppc_hash64_set_dsi(cs, env, eaddr, dsisr);
|
ppc_hash64_set_dsi(cs, eaddr, dsisr);
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -942,8 +942,9 @@ void ppc_hash64_tlb_flush_hpte(PowerPCCPU *cpu, target_ulong ptex,
|
|||||||
cpu->env.tlb_need_flush = TLB_NEED_GLOBAL_FLUSH | TLB_NEED_LOCAL_FLUSH;
|
cpu->env.tlb_need_flush = TLB_NEED_GLOBAL_FLUSH | TLB_NEED_LOCAL_FLUSH;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ppc_hash64_update_rmls(CPUPPCState *env)
|
void ppc_hash64_update_rmls(PowerPCCPU *cpu)
|
||||||
{
|
{
|
||||||
|
CPUPPCState *env = &cpu->env;
|
||||||
uint64_t lpcr = env->spr[SPR_LPCR];
|
uint64_t lpcr = env->spr[SPR_LPCR];
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -976,8 +977,9 @@ void ppc_hash64_update_rmls(CPUPPCState *env)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ppc_hash64_update_vrma(CPUPPCState *env)
|
void ppc_hash64_update_vrma(PowerPCCPU *cpu)
|
||||||
{
|
{
|
||||||
|
CPUPPCState *env = &cpu->env;
|
||||||
const struct ppc_one_seg_page_size *sps = NULL;
|
const struct ppc_one_seg_page_size *sps = NULL;
|
||||||
target_ulong esid, vsid, lpcr;
|
target_ulong esid, vsid, lpcr;
|
||||||
ppc_slb_t *slb = &env->vrma_slb;
|
ppc_slb_t *slb = &env->vrma_slb;
|
||||||
@ -1002,7 +1004,7 @@ void ppc_hash64_update_vrma(CPUPPCState *env)
|
|||||||
vsid |= (vrmasd << 4) & (SLB_VSID_L | SLB_VSID_LP);
|
vsid |= (vrmasd << 4) & (SLB_VSID_L | SLB_VSID_LP);
|
||||||
esid = SLB_ESID_V;
|
esid = SLB_ESID_V;
|
||||||
|
|
||||||
for (i = 0; i < PPC_PAGE_SIZES_MAX_SZ; i++) {
|
for (i = 0; i < PPC_PAGE_SIZES_MAX_SZ; i++) {
|
||||||
const struct ppc_one_seg_page_size *sps1 = &env->sps.sps[i];
|
const struct ppc_one_seg_page_size *sps1 = &env->sps.sps[i];
|
||||||
|
|
||||||
if (!sps1->page_shift) {
|
if (!sps1->page_shift) {
|
||||||
@ -1028,6 +1030,7 @@ void ppc_hash64_update_vrma(CPUPPCState *env)
|
|||||||
|
|
||||||
void helper_store_lpcr(CPUPPCState *env, target_ulong val)
|
void helper_store_lpcr(CPUPPCState *env, target_ulong val)
|
||||||
{
|
{
|
||||||
|
PowerPCCPU *cpu = ppc_env_get_cpu(env);
|
||||||
uint64_t lpcr = 0;
|
uint64_t lpcr = 0;
|
||||||
|
|
||||||
/* Filter out bits */
|
/* Filter out bits */
|
||||||
@ -1089,6 +1092,6 @@ void helper_store_lpcr(CPUPPCState *env, target_ulong val)
|
|||||||
;
|
;
|
||||||
}
|
}
|
||||||
env->spr[SPR_LPCR] = lpcr;
|
env->spr[SPR_LPCR] = lpcr;
|
||||||
ppc_hash64_update_rmls(env);
|
ppc_hash64_update_rmls(cpu);
|
||||||
ppc_hash64_update_vrma(env);
|
ppc_hash64_update_vrma(cpu);
|
||||||
}
|
}
|
||||||
|
@ -17,8 +17,8 @@ void ppc_hash64_tlb_flush_hpte(PowerPCCPU *cpu,
|
|||||||
target_ulong pte0, target_ulong pte1);
|
target_ulong pte0, target_ulong pte1);
|
||||||
unsigned ppc_hash64_hpte_page_shift_noslb(PowerPCCPU *cpu,
|
unsigned ppc_hash64_hpte_page_shift_noslb(PowerPCCPU *cpu,
|
||||||
uint64_t pte0, uint64_t pte1);
|
uint64_t pte0, uint64_t pte1);
|
||||||
void ppc_hash64_update_vrma(CPUPPCState *env);
|
void ppc_hash64_update_vrma(PowerPCCPU *cpu);
|
||||||
void ppc_hash64_update_rmls(CPUPPCState *env);
|
void ppc_hash64_update_rmls(PowerPCCPU *cpu);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -8975,8 +8975,8 @@ void cpu_ppc_set_papr(PowerPCCPU *cpu, PPCVirtualHypervisor *vhyp)
|
|||||||
env->spr[SPR_AMOR] = amor->default_value = 0xffffffffffffffffull;
|
env->spr[SPR_AMOR] = amor->default_value = 0xffffffffffffffffull;
|
||||||
|
|
||||||
/* Update some env bits based on new LPCR value */
|
/* Update some env bits based on new LPCR value */
|
||||||
ppc_hash64_update_rmls(env);
|
ppc_hash64_update_rmls(cpu);
|
||||||
ppc_hash64_update_vrma(env);
|
ppc_hash64_update_vrma(cpu);
|
||||||
|
|
||||||
/* Tell KVM that we're in PAPR mode */
|
/* Tell KVM that we're in PAPR mode */
|
||||||
if (kvm_enabled()) {
|
if (kvm_enabled()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user