mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-15 22:21:57 -06:00
target/ppc: optimize hreg_compute_pmu_hflags_value
Cache env->spr[SPR_POWER_MMCR0] in a local variable as used in multiple conditions to avoid multiple indirect accesses. Reviewed-by: Nicholas Piggin <npiggin@gmail.com> Signed-off-by: Harsh Prateek Bora <harshpb@linux.ibm.com> Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
This commit is contained in:
parent
2bbddc08bc
commit
052af14ef2
1 changed files with 5 additions and 4 deletions
|
@ -83,15 +83,16 @@ static bool hreg_check_bhrb_enable(CPUPPCState *env)
|
||||||
static uint32_t hreg_compute_pmu_hflags_value(CPUPPCState *env)
|
static uint32_t hreg_compute_pmu_hflags_value(CPUPPCState *env)
|
||||||
{
|
{
|
||||||
uint32_t hflags = 0;
|
uint32_t hflags = 0;
|
||||||
|
|
||||||
#if defined(TARGET_PPC64)
|
#if defined(TARGET_PPC64)
|
||||||
if (env->spr[SPR_POWER_MMCR0] & MMCR0_PMCC0) {
|
target_ulong mmcr0 = env->spr[SPR_POWER_MMCR0];
|
||||||
|
|
||||||
|
if (mmcr0 & MMCR0_PMCC0) {
|
||||||
hflags |= 1 << HFLAGS_PMCC0;
|
hflags |= 1 << HFLAGS_PMCC0;
|
||||||
}
|
}
|
||||||
if (env->spr[SPR_POWER_MMCR0] & MMCR0_PMCC1) {
|
if (mmcr0 & MMCR0_PMCC1) {
|
||||||
hflags |= 1 << HFLAGS_PMCC1;
|
hflags |= 1 << HFLAGS_PMCC1;
|
||||||
}
|
}
|
||||||
if (env->spr[SPR_POWER_MMCR0] & MMCR0_PMCjCE) {
|
if (mmcr0 & MMCR0_PMCjCE) {
|
||||||
hflags |= 1 << HFLAGS_PMCJCE;
|
hflags |= 1 << HFLAGS_PMCJCE;
|
||||||
}
|
}
|
||||||
if (hreg_check_bhrb_enable(env)) {
|
if (hreg_check_bhrb_enable(env)) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue