[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v3 02/10] target/ppc: optimize hreg_compute_pmu_hflags_value
From: |
Harsh Prateek Bora |
Subject: |
[PATCH v3 02/10] target/ppc: optimize hreg_compute_pmu_hflags_value |
Date: |
Fri, 13 Sep 2024 09:43:29 +0530 |
Cache env->spr[SPR_POWER_MMCR0] in a local variable as used in multiple
conditions to avoid multiple indirect accesses.
Signed-off-by: Harsh Prateek Bora <harshpb@linux.ibm.com>
Reviewed-by: Nicholas Piggin <npiggin@gmail.com>
---
target/ppc/helper_regs.c | 9 +++++----
1 file changed, 5 insertions(+), 4 deletions(-)
diff --git a/target/ppc/helper_regs.c b/target/ppc/helper_regs.c
index fe543ab3b8..7b23e5ef0e 100644
--- a/target/ppc/helper_regs.c
+++ b/target/ppc/helper_regs.c
@@ -83,15 +83,16 @@ static bool hreg_check_bhrb_enable(CPUPPCState *env)
static uint32_t hreg_compute_pmu_hflags_value(CPUPPCState *env)
{
uint32_t hflags = 0;
-
#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;
}
- if (env->spr[SPR_POWER_MMCR0] & MMCR0_PMCC1) {
+ if (mmcr0 & MMCR0_PMCC1) {
hflags |= 1 << HFLAGS_PMCC1;
}
- if (env->spr[SPR_POWER_MMCR0] & MMCR0_PMCjCE) {
+ if (mmcr0 & MMCR0_PMCjCE) {
hflags |= 1 << HFLAGS_PMCJCE;
}
if (hreg_check_bhrb_enable(env)) {
--
2.45.2
- [PATCH v3 00/10] misc ppc improvements/optimizations, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 01/10] target/ppc: use locally stored msr and avoid indirect access, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 03/10] target/ppc: optimize hreg_compute_pmu_hflags_value, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 04/10] target/ppc: optimize p9 exception handling routines, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 05/10] target/ppc: optimize p9 exception handling routines for lpcr, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 07/10] target/ppc: optimize p8 exception handling routines, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 02/10] target/ppc: optimize hreg_compute_pmu_hflags_value,
Harsh Prateek Bora <=
- [PATCH v3 06/10] target/ppc: reduce duplicate code between init_proc_POWER{9, 10}, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 08/10] target/ppc: optimize p7 exception handling routines, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 10/10] target/ppc: combine multiple ail checks into one, Harsh Prateek Bora, 2024/09/13
- [PATCH v3 09/10] target/ppc: simplify var usage in ppc_next_unmasked_interrupt, Harsh Prateek Bora, 2024/09/13