diff options
author | Leandro Lupori <leandro.lupori@eldorado.org.br> | 2022-10-25 17:24:24 -0300 |
---|---|---|
committer | Daniel Henrique Barboza <danielhb413@gmail.com> | 2022-10-28 13:15:23 -0300 |
commit | eeaaefe9fa8b95a7ed39ee86257f3bf1af751804 (patch) | |
tree | 68aae0fe616f09eb7060a4573a6069307bd34957 /target/ppc/helper.h | |
parent | 8b3d1c49a9f0f315d2b292c1791430c0f382afa4 (diff) | |
download | qemu-eeaaefe9fa8b95a7ed39ee86257f3bf1af751804.zip qemu-eeaaefe9fa8b95a7ed39ee86257f3bf1af751804.tar.gz qemu-eeaaefe9fa8b95a7ed39ee86257f3bf1af751804.tar.bz2 |
target/ppc: Increment PMC5 with inline insns
Profiling QEMU during Fedora 35 for PPC64 boot revealed that
6.39% of total time was being spent in helper_insns_inc(), on a
POWER9 machine. To avoid calling this helper every time PMCs had
to be incremented, an inline implementation of PMC5 increment and
check for overflow was developed. This led to a reduction of
about 12% in Fedora's boot time.
Signed-off-by: Leandro Lupori <leandro.lupori@eldorado.org.br>
Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
Message-Id: <20221025202424.195984-4-leandro.lupori@eldorado.org.br>
Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com>
Diffstat (limited to 'target/ppc/helper.h')
-rw-r--r-- | target/ppc/helper.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/target/ppc/helper.h b/target/ppc/helper.h index 25533b8..8dd22a3 100644 --- a/target/ppc/helper.h +++ b/target/ppc/helper.h @@ -30,6 +30,7 @@ DEF_HELPER_2(store_mmcr1, void, env, tl) DEF_HELPER_3(store_pmc, void, env, i32, i64) DEF_HELPER_2(read_pmc, tl, env, i32) DEF_HELPER_2(insns_inc, void, env, i32) +DEF_HELPER_1(handle_pmc5_overflow, void, env) #endif DEF_HELPER_1(check_tlb_flush_local, void, env) DEF_HELPER_1(check_tlb_flush_global, void, env) |