[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-ppc] [PATCH 3/4] target/ppc: improve performance of large BAT
From: |
David Gibson |
Subject: |
Re: [Qemu-ppc] [PATCH 3/4] target/ppc: improve performance of large BAT invalidations |
Date: |
Mon, 15 Apr 2019 10:20:47 +1000 |
User-agent: |
Mutt/1.11.3 (2019-02-01) |
On Fri, Apr 12, 2019 at 11:06:17PM +0200, Artyom Tarasenko wrote:
> Performing a complete flush is ~ 100 times faster than flushing
> 256MiB of 4KiB pages. Set a limit of 1024 pages and perform a complete
> flush afterwards.
>
> This patch significantly speeds up AIX 5.1 and NetBSD-ofppc.
>
> Signed-off-by: Artyom Tarasenko <address@hidden>
LGTM, applied to ppc-for-4.1.
> ---
> target/ppc/mmu_helper.c | 7 +++++++
> 1 file changed, 7 insertions(+)
>
> diff --git a/target/ppc/mmu_helper.c b/target/ppc/mmu_helper.c
> index 4a6be4d..d7eed3a 100644
> --- a/target/ppc/mmu_helper.c
> +++ b/target/ppc/mmu_helper.c
> @@ -1809,6 +1809,13 @@ static inline void do_invalidate_BAT(CPUPPCState *env,
> target_ulong BATu,
>
> base = BATu & ~0x0001FFFF;
> end = base + mask + 0x00020000;
> + if (((end - base) >> TARGET_PAGE_BITS) > 1024) {
> + /* Flushing 1024 4K pages is slower than a complete flush */
> + LOG_BATS("Flush all BATs\n");
> + tlb_flush(CPU(cs));
> + LOG_BATS("Flush done\n");
> + return;
> + }
> LOG_BATS("Flush BAT from " TARGET_FMT_lx " to " TARGET_FMT_lx " ("
> TARGET_FMT_lx ")\n", base, end, mask);
> for (page = base; page != end; page += TARGET_PAGE_SIZE) {
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
signature.asc
Description: PGP signature