dol: initial dol commit
[jump.git] / dol / src / dol / visitor / hdsd / scd / fsm / scd_sts_base.cpp
diff --git a/dol/src/dol/visitor/hdsd/scd/fsm/scd_sts_base.cpp b/dol/src/dol/visitor/hdsd/scd/fsm/scd_sts_base.cpp
new file mode 100644 (file)
index 0000000..b4d0af0
--- /dev/null
@@ -0,0 +1,81 @@
+#include "fsm/scd_sts_base.h"
+
+#include "scd_logging.h"
+#include "scd_exception.h"
+#include "scd_cont_man_slave.h"
+#include "scd_command.h"
+#include "scd_cont_man.h"
+
+
+
+scd_sts_base::scd_sts_base(scd_simulator& sim, scd_cont_man_slave& fsm):
+    scd_cont_state(sim), _fsm(fsm),
+    _st_init(fsm._st_init), _st_busy(fsm._st_busy), _st_idle(fsm._st_idle),
+    _st_done(fsm._st_done), _st_time_ack(fsm._st_time_ack),
+    _st_time(fsm._st_time), _st_term_ack(fsm._st_term_ack),
+    _st_terminated(fsm._st_terminated), _st_fail(fsm._st_fail),
+    _st_failed(fsm._st_failed),
+    _writer(fsm._writer), _reader(fsm._reader), _connector(fsm._connector)
+{
+}
+
+
+void scd_sts_base::set_failed()
+{
+    _sim.get_poller().remove_handler(_fsm);
+    _sim.get_chan_man().close();
+    _fsm.set_state(_st_failed);
+}
+
+
+void scd_sts_base::recv_time_req()
+{
+    scd_command* cmd = new scd_command(SCD_CM_CONTROL, SCD_CM_TIME_NACK);
+    _fsm.send_command(cmd);
+}
+
+
+void scd_sts_base::recv_time(const sc_core::sc_time& time)
+{
+    scd_warn("received time message in wrong state");
+}
+
+
+void scd_sts_base::recv_term_req()
+{
+    scd_command* cmd = new scd_command(SCD_CM_CONTROL, SCD_CM_TERM_NACK);
+    _fsm.send_command(cmd);
+}
+
+
+void scd_sts_base::recv_term()
+{
+    scd_warn("received terminate message in wrong state");
+}
+
+
+void scd_sts_base::set_fail()
+{
+    scd_command* cmd = new scd_command(SCD_CM_CONTROL, SCD_CM_FAILED);
+    _fsm.send_command(cmd);
+    _fsm.set_state(_st_fail);
+}
+
+
+bool scd_sts_base::active() const { return true; }
+
+
+bool scd_sts_base::busy() const { return false; }
+
+
+bool scd_sts_base::failed() const { return false; }
+
+
+bool scd_sts_base::advance_time() const { return false; }
+
+
+const sc_core::sc_time& scd_sts_base::get_time_step()
+{
+    scd_warn("illegal call to get_time_step()");
+    throw scd_exception("illegal call");
+}