Browse Source

target/sparc: call plugin trap callbacks

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 SPARC (32bit and 64bit) targets. We treat
any interrupt other than EXTINT and IVEC as exceptions as they appear to
be synchroneous events.

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Julian Ganz <neither@nut.email>
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Message-ID: <20251027110344.2289945-27-alex.bennee@linaro.org>
Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
pull/307/head
Julian Ganz 5 months ago
committed by Alex Bennée
parent
commit
8a315a788a
  1. 7
      target/sparc/int32_helper.c
  2. 10
      target/sparc/int64_helper.c

7
target/sparc/int32_helper.c

@ -24,6 +24,7 @@
#include "accel/tcg/cpu-ldst.h"
#include "exec/log.h"
#include "system/runstate.h"
#include "qemu/plugin.h"
static const char * const excp_names[0x80] = {
[TT_TFAULT] = "Instruction Access Fault",
@ -174,4 +175,10 @@ void sparc_cpu_do_interrupt(CPUState *cs)
env->qemu_irq_ack(env, intno);
}
#endif
if (intno == TT_EXTINT) {
qemu_plugin_vcpu_interrupt_cb(cs, env->regwptr[9]);
} else {
qemu_plugin_vcpu_exception_cb(cs, env->regwptr[9]);
}
}

10
target/sparc/int64_helper.c

@ -24,6 +24,7 @@
#include "exec/helper-proto.h"
#include "exec/log.h"
#include "trace.h"
#include "qemu/plugin.h"
#define DEBUG_PCALL
@ -256,6 +257,15 @@ void sparc_cpu_do_interrupt(CPUState *cs)
}
env->npc = env->pc + 4;
cs->exception_index = -1;
switch (intno) {
case TT_EXTINT:
case TT_IVEC:
qemu_plugin_vcpu_interrupt_cb(cs, tsptr->tpc);
break;
default:
qemu_plugin_vcpu_exception_cb(cs, tsptr->tpc);
}
}
trap_state *cpu_tsptr(CPUSPARCState* env)

Loading…
Cancel
Save