From: "Alex Bennée" <alex.bennee@linaro.org>
To: Julian Ganz <neither@nut.email>
Cc: qemu-devel@nongnu.org,
Richard Henderson <richard.henderson@linaro.org>,
Song Gao <gaosong@loongson.cn>
Subject: Re: [PATCH v7 10/25] target/loongarch: call plugin trap callbacks
Date: Tue, 14 Oct 2025 11:55:26 +0100 [thread overview]
Message-ID: <87347ln469.fsf@draig.linaro.org> (raw)
In-Reply-To: <21a5bf2e810e2c1a3d278ba3ed98f4d4491763cb.1759744337.git.neither@nut.email> (Julian Ganz's message of "Mon, 6 Oct 2025 11:57:05 +0200")
Julian Ganz <neither@nut.email> writes:
> We recently introduced API for registering callbacks for trap related
> events as well as the corresponding hook functions. Due to differences
> between architectures, the latter need to be called from target specific
> code.
>
> This change places hooks for loongarch targets. This architecture
> has one special "exception" for interrupts and no host calls.
>
> Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
> Signed-off-by: Julian Ganz <neither@nut.email>
> ---
> target/loongarch/cpu.c | 4 ++++
> 1 file changed, 4 insertions(+)
This fails to apply now - I think because the TCG functions have moved
to target/loongarch/tcg/tcg_cpu.c
>
> diff --git a/target/loongarch/cpu.c b/target/loongarch/cpu.c
> index 993602fb8c..a8299dfee6 100644
> --- a/target/loongarch/cpu.c
> +++ b/target/loongarch/cpu.c
> @@ -32,6 +32,7 @@
> #include "accel/tcg/cpu-ldst.h"
> #include "accel/tcg/cpu-ops.h"
> #include "tcg/tcg.h"
> +#include "qemu/plugin.h"
> #endif
> #include "tcg/tcg_loongarch.h"
>
> @@ -172,6 +173,7 @@ static void loongarch_cpu_do_interrupt(CPUState *cs)
> int cause = -1;
> bool tlbfill = FIELD_EX64(env->CSR_TLBRERA, CSR_TLBRERA, ISTLBR);
> uint32_t vec_size = FIELD_EX64(env->CSR_ECFG, CSR_ECFG, VS);
> + uint64_t last_pc = env->pc;
>
> if (cs->exception_index != EXCCODE_INT) {
> qemu_log_mask(CPU_LOG_INT,
> @@ -282,6 +284,7 @@ static void loongarch_cpu_do_interrupt(CPUState *cs)
> __func__, env->pc, env->CSR_ERA,
> cause, env->CSR_BADV, env->CSR_DERA, vector,
> env->CSR_ECFG, env->CSR_ESTAT);
> + qemu_plugin_vcpu_interrupt_cb(cs, last_pc);
> } else {
> if (tlbfill) {
> set_pc(env, env->CSR_TLBRENTRY);
> @@ -300,6 +303,7 @@ static void loongarch_cpu_do_interrupt(CPUState *cs)
> tlbfill ? env->CSR_TLBRBADV : env->CSR_BADV,
> env->CSR_BADI, env->gpr[11], cs->cpu_index,
> env->CSR_ASID);
> + qemu_plugin_vcpu_exception_cb(cs, last_pc);
> }
> cs->exception_index = -1;
> }
--
Alex Bennée
Virtualisation Tech Lead @ Linaro
next prev parent reply other threads:[~2025-10-14 10:56 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-10-06 9:56 [PATCH v7 00/25] tcg-plugins: add hooks for discontinuities Julian Ganz
2025-10-06 9:56 ` [PATCH v7 01/25] plugins: add types for callbacks related to certain discontinuities Julian Ganz
2025-10-14 11:06 ` Alex Bennée
2025-10-06 9:56 ` [PATCH v7 02/25] plugins: add API for registering discontinuity callbacks Julian Ganz
2025-10-14 11:06 ` Alex Bennée
2025-10-06 9:56 ` [PATCH v7 03/25] plugins: add hooks for new discontinuity related callbacks Julian Ganz
2025-10-06 9:56 ` [PATCH v7 04/25] contrib/plugins: add plugin showcasing new dicontinuity related API Julian Ganz
2025-10-14 11:08 ` Alex Bennée
2025-10-06 9:57 ` [PATCH v7 05/25] target/alpha: call plugin trap callbacks Julian Ganz
2025-10-06 9:57 ` [PATCH v7 06/25] target/arm: " Julian Ganz
2025-10-06 22:32 ` Richard Henderson
2025-10-06 9:57 ` [PATCH v7 07/25] target/avr: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 08/25] target/hppa: " Julian Ganz
2025-10-06 22:38 ` Richard Henderson
2025-10-07 13:29 ` Julian Ganz
2025-10-07 14:56 ` Richard Henderson
2025-10-06 9:57 ` [PATCH v7 09/25] target/i386: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 10/25] target/loongarch: " Julian Ganz
2025-10-14 10:55 ` Alex Bennée [this message]
2025-10-14 14:02 ` Julian Ganz
2025-10-06 9:57 ` [PATCH v7 11/25] target/m68k: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 12/25] target/microblaze: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 13/25] target/mips: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 14/25] target/openrisc: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 15/25] target/ppc: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 16/25] target/riscv: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 17/25] target/rx: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 18/25] target/s390x: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 19/25] target/sh4: " Julian Ganz
2025-10-06 9:57 ` [PATCH v7 20/25] target/sparc: " Julian Ganz
2025-10-06 9:59 ` [PATCH v7 21/25] target/tricore: " Julian Ganz
2025-10-06 9:59 ` [PATCH v7 22/25] target/xtensa: " Julian Ganz
2025-10-07 11:59 ` Philippe Mathieu-Daudé
2025-10-06 9:59 ` [PATCH v7 23/25] tests: add plugin asserting correctness of discon event's to_pc Julian Ganz
2025-10-06 9:59 ` [PATCH v7 24/25] tests: add test for double-traps on rv64 Julian Ganz
2025-10-09 2:49 ` Alistair Francis
2025-10-06 9:59 ` [PATCH v7 25/25] tests: add test with interrupted memory accesses " Julian Ganz
2025-10-14 12:47 ` Alex Bennée
2025-10-14 14:17 ` Julian Ganz
2025-10-14 12:52 ` [PATCH v7 00/25] tcg-plugins: add hooks for discontinuities Alex Bennée
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=87347ln469.fsf@draig.linaro.org \
--to=alex.bennee@linaro.org \
--cc=gaosong@loongson.cn \
--cc=neither@nut.email \
--cc=qemu-devel@nongnu.org \
--cc=richard.henderson@linaro.org \
/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).