From: Richard Henderson <richard.henderson@linaro.org>
To: "Alex Bennée" <alex.bennee@linaro.org>, qemu-devel@nongnu.org
Cc: Pierrick Bouvier <pierrick.bouvier@linaro.org>,
Paolo Bonzini <pbonzini@redhat.com>,
Riku Voipio <riku.voipio@iki.fi>
Subject: Re: [RFC PATCH] accel/tcg: add tracepoints for cpu_loop_exit_atomic
Date: Fri, 4 Oct 2024 07:34:39 -0700 [thread overview]
Message-ID: <1de09840-4689-47d1-bc26-47f19e050a08@linaro.org> (raw)
In-Reply-To: <20241004135226.903570-1-alex.bennee@linaro.org>
On 10/4/24 06:52, Alex Bennée wrote:
> We try to avoid using cpu_loop_exit_atomic as it brings in an all-core
> sync point. However on some cpu/kernel/benchmark combinations it is
> starting to show up in the performance profile. To make it easier to
> see whats going on add tracepoints for the slow path so we can see
> what is triggering the wait.
>
> It seems for a modern CPU it can be quite a bit, for example:
>
> ./qemu-system-aarch64 \
> -machine type=virt,virtualization=on,pflash0=rom,pflash1=efivars,gic-version=max \
> -smp 4 \
> -accel tcg \
> -device virtio-net-pci,netdev=unet \
> -device virtio-scsi-pci \
> -device scsi-hd,drive=hd \
> -netdev user,id=unet,hostfwd=tcp::2222-:22 \
> -blockdev driver=raw,node-name=hd,file.driver=host_device,file.filename=/dev/zen-ssd2/trixie-arm64,discard=unmap \
> -serialmon:stdio \
> -blockdev node-name=rom,driver=file,filename=(pwd)/pc-bios/edk2-aarch64-code.fd,read-only=true \
> -blockdev node-name=efivars,driver=file,filename=$HOME/images/qemu-arm64-efivars \
> -m 8192 \
> -object memory-backend-memfd,id=mem,size=8G,share=on \
> -kernel /home/alex/lsrc/linux.git/builds/arm64/arch/arm64/boot/Image -append "root=/dev/sda2 console=ttyAMA0 systemd.unit=benchmark-stress-ng.service" \
> -display none -dtrace:load_atom\*_fallback,trace:store_atom\*_fallback
>
> With:
>
> -cpu neoverse-v1,pauth-impdef=on => 2203343
>
> With:
>
> -cpu cortex-a76 => 0
>
> Signed-off-by: Alex Bennée<alex.bennee@linaro.org>
> Cc: Pierrick Bouvier<pierrick.bouvier@linaro.org>
> ---
> accel/tcg/user-exec.c | 2 +-
> accel/tcg/ldst_atomicity.c.inc | 9 +++++++++
> accel/tcg/trace-events | 12 ++++++++++++
> 3 files changed, 22 insertions(+), 1 deletion(-)
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
r~
next prev parent reply other threads:[~2024-10-04 14:35 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-10-04 13:52 [RFC PATCH] accel/tcg: add tracepoints for cpu_loop_exit_atomic Alex Bennée
2024-10-04 14:34 ` Richard Henderson [this message]
2024-10-05 0:09 ` Pierrick Bouvier
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1de09840-4689-47d1-bc26-47f19e050a08@linaro.org \
--to=richard.henderson@linaro.org \
--cc=alex.bennee@linaro.org \
--cc=pbonzini@redhat.com \
--cc=pierrick.bouvier@linaro.org \
--cc=qemu-devel@nongnu.org \
--cc=riku.voipio@iki.fi \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).