summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--arch/alpha/ev5.cc6
-rw-r--r--arch/alpha/ev5.hh2
-rw-r--r--arch/alpha/isa_desc18
-rw-r--r--sim/sim_events.cc5
-rw-r--r--sim/sim_events.hh2
5 files changed, 18 insertions, 15 deletions
diff --git a/arch/alpha/ev5.cc b/arch/alpha/ev5.cc
index 7330d7ce0..ff1ecc4bf 100644
--- a/arch/alpha/ev5.cc
+++ b/arch/alpha/ev5.cc
@@ -54,12 +54,6 @@ AlphaISA::initCPU(RegFile *regs)
regs->npc = regs->pc + sizeof(MachInst);
}
-void
-m5_exit()
-{
- static SimExitEvent event("m5_exit instruction encountered");
-}
-
////////////////////////////////////////////////////////////////////////
//
// alpha exceptions - value equals trap address, update with MD_FAULT_TYPE
diff --git a/arch/alpha/ev5.hh b/arch/alpha/ev5.hh
index 921aeb12d..aa3d7e226 100644
--- a/arch/alpha/ev5.hh
+++ b/arch/alpha/ev5.hh
@@ -9,8 +9,6 @@
#include "targetarch/isa_traits.hh"
-void m5_exit();
-
////////////////////////////////////////////////////////////////////////
//
//
diff --git a/arch/alpha/isa_desc b/arch/alpha/isa_desc
index 89ec05c0e..ac6934fac 100644
--- a/arch/alpha/isa_desc
+++ b/arch/alpha/isa_desc
@@ -18,17 +18,17 @@ let {{
#include <fenv.h>
#endif
-#include "cpu/static_inst.hh"
#include "base/cprintf.hh"
#include "base/misc.hh"
-#include "cpu/full_cpu/op_class.hh"
-
#include "cpu/exec_context.hh"
-#include "cpu/simple_cpu/simple_cpu.hh"
-#include "cpu/full_cpu/spec_state.hh"
-#include "cpu/full_cpu/full_cpu.hh"
#include "cpu/exetrace.hh"
+#include "cpu/full_cpu/full_cpu.hh"
+#include "cpu/full_cpu/op_class.hh"
+#include "cpu/full_cpu/spec_state.hh"
+#include "cpu/simple_cpu/simple_cpu.hh"
+#include "cpu/static_inst.hh"
#include "sim/annotation.hh"
+#include "sim/sim_events.hh"
#ifdef FULL_SYSTEM
#include "targetarch/ev5.hh"
@@ -2356,6 +2356,10 @@ decode OPCODE default Unknown::unknown() {
#else
0x00: decode PALFUNC {
format EmulatedCallPal {
+ 0x00: halt ({{
+ if (!xc->misspeculating())
+ SimExit("halt instruction encountered");
+ }});
0x83: callsys({{ xc->syscall(); }});
// Read uniq reg into ABI return value register (r0)
0x9e: rduniq({{ R0 = Runiq; }});
@@ -2414,7 +2418,7 @@ decode OPCODE default Unknown::unknown() {
}}, No_OpClass);
0x20: m5exit({{
if (!xc->misspeculating())
- m5_exit();
+ SimExit("m5_exit instruction encountered");
}}, No_OpClass);
0x30: initparam({{ Ra = xc->cpu->system->init_param; }});
0x40: resetstats({{
diff --git a/sim/sim_events.cc b/sim/sim_events.cc
index b622cb14d..5f24de516 100644
--- a/sim/sim_events.cc
+++ b/sim/sim_events.cc
@@ -63,6 +63,11 @@ SimExitEvent::description()
return "simulation termination";
}
+void
+SimExit(const char *message)
+{
+ static SimExitEvent event(message);
+}
//
// constructor: automatically schedules at specified time
diff --git a/sim/sim_events.hh b/sim/sim_events.hh
index b1ae7793a..0029a8404 100644
--- a/sim/sim_events.hh
+++ b/sim/sim_events.hh
@@ -66,6 +66,8 @@ class SimExitEvent : public Event
virtual const char *description();
};
+void SimExit(const char *message);
+
//
// Event class to terminate simulation after 'n' related events have
// occurred using a shared counter: used to terminate when *all*