From 5a1ad990a64adccaa6116288771628103e47157c Mon Sep 17 00:00:00 2001 From: Gabe Black Date: Tue, 11 Sep 2018 20:14:22 -0700 Subject: systemc: Implement the sc_*_resolved classes. Change-Id: Ib595da10e0f900ee4cc1847d41d29251dacb55d7 Reviewed-on: https://gem5-review.googlesource.com/c/12620 Reviewed-by: Gabe Black Maintainer: Gabe Black --- src/systemc/channel/sc_inout_resolved.cc | 35 ++++++++++++++++++++------------ 1 file changed, 22 insertions(+), 13 deletions(-) (limited to 'src/systemc/channel/sc_inout_resolved.cc') diff --git a/src/systemc/channel/sc_inout_resolved.cc b/src/systemc/channel/sc_inout_resolved.cc index 71cece846..8355a8847 100644 --- a/src/systemc/channel/sc_inout_resolved.cc +++ b/src/systemc/channel/sc_inout_resolved.cc @@ -29,6 +29,8 @@ #include "base/logging.hh" #include "systemc/ext/channel/sc_inout_resolved.hh" +#include "systemc/ext/channel/sc_signal_resolved.hh" +#include "systemc/ext/utils/sc_report_handler.hh" namespace sc_core { @@ -41,45 +43,52 @@ sc_inout_resolved::sc_inout_resolved(const char *name) : sc_inout_resolved::~sc_inout_resolved() {} -void sc_inout_resolved::end_of_elaboration() {} +void +sc_inout_resolved::end_of_elaboration() +{ + sc_inout::end_of_elaboration(); + if (!dynamic_cast(get_interface())) { + std::string msg = csprintf("%s (%s)", name(), kind()); + SC_REPORT_ERROR("(E117) resolved port not bound to resolved signal", + msg.c_str()); + } +} sc_inout_resolved & -sc_inout_resolved::operator = (const sc_dt::sc_logic &) +sc_inout_resolved::operator = (const sc_dt::sc_logic &l) { - warn("%s not implemented.\n", __PRETTY_FUNCTION__); + (*this)->write(l); return *this; } sc_inout_resolved & -sc_inout_resolved::operator = (const sc_signal_in_if &) +sc_inout_resolved::operator = (const sc_signal_in_if &i) { - warn("%s not implemented.\n", __PRETTY_FUNCTION__); + (*this)->write(i.read()); return *this; } sc_inout_resolved & sc_inout_resolved::operator = ( - const sc_port, 1> &) + const sc_port, 1> &p) { - warn("%s not implemented.\n", __PRETTY_FUNCTION__); + (*this)->write(p->read()); return *this; } sc_inout_resolved & sc_inout_resolved::operator = ( - const sc_port, 1> &) + const sc_port, 1> &p) { - warn("%s not implemented.\n", __PRETTY_FUNCTION__); + (*this)->write(p->read()); return *this; } sc_inout_resolved & -sc_inout_resolved::operator = (const sc_inout_resolved &) +sc_inout_resolved::operator = (const sc_inout_resolved &p) { - warn("%s not implemented.\n", __PRETTY_FUNCTION__); + (*this)->write(p->read()); return *this; } -const char *sc_inout_resolved::kind() const { return "sc_inout_resolved"; } - } // namespace sc_core -- cgit v1.2.3