X-Git-Url: http://sraa.de/git/?a=blobdiff_plain;f=dol%2Fsrc%2Fdol%2Fvisitor%2Fhdsd%2Fscd%2Ffsm%2Fscd_sts_base.cpp;fp=dol%2Fsrc%2Fdol%2Fvisitor%2Fhdsd%2Fscd%2Ffsm%2Fscd_sts_base.cpp;h=b4d0af00d4613bb5092d48d851362f1e5497d05b;hb=8c411cf24ed0eb889191aaeafd8fa1e69081df42;hp=0000000000000000000000000000000000000000;hpb=dea7a4fb1ed110d3ce6e6d9255103d724bd66c0e;p=jump.git 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 index 0000000..b4d0af0 --- /dev/null +++ b/dol/src/dol/visitor/hdsd/scd/fsm/scd_sts_base.cpp @@ -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"); +}