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>
This commit is contained in:
parent
01f0738c57
commit
8a315a788a
2 changed files with 17 additions and 0 deletions
|
|
@ -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]);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -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…
Add table
Add a link
Reference in a new issue