aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sim/common/sim-core.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/sim/common/sim-core.c b/sim/common/sim-core.c
index 1a01359..c140dd6 100644
--- a/sim/common/sim-core.c
+++ b/sim/common/sim-core.c
@@ -108,16 +108,19 @@ sim_core_signal (SIM_DESC sd,
sim_core_signals sig)
{
const char *copy = (transfer == read_transfer ? "read" : "write");
+ /* The CIA could either be a struct or a simple type. Regardless,
+ the address of the instruction is found in the first word. */
+ address_word ip = *(address_word*)&cia;
switch (sig)
{
case sim_core_unmapped_signal:
- sim_io_eprintf (sd, "core: %d byte %s to unmaped address 0x%lx\n",
- nr_bytes, copy, (unsigned long) addr);
+ sim_io_eprintf (sd, "core: %d byte %s to unmaped address 0x%lx at 0x%lx\n",
+ nr_bytes, copy, (unsigned long) addr, (unsigned long) ip);
sim_engine_halt (sd, cpu, NULL, cia, sim_signalled, SIGSEGV);
break;
case sim_core_unaligned_signal:
- sim_io_eprintf (sd, "core: %d byte misaligned %s to address 0x%lx",
- nr_bytes, copy, (unsigned long) addr);
+ sim_io_eprintf (sd, "core: %d byte misaligned %s to address 0x%lx at 0x%lx\n",
+ nr_bytes, copy, (unsigned long) addr, (unsigned long) ip);
sim_engine_halt (sd, cpu, NULL, cia, sim_signalled, SIGBUS);
break;
default: