28 #ifndef __SYSTEMC_EXT_CHANNEL_SC_INOUT_HH__ 29 #define __SYSTEMC_EXT_CHANNEL_SC_INOUT_HH__ 33 #include "../core/sc_event.hh" 34 #include "../core/sc_main.hh" 35 #include "../core/sc_port.hh" 36 #include "../dt/bit/sc_logic.hh" 37 #include "../utils/sc_trace_file.hh" 114 for (
auto params: traceParamsVec)
115 sc_trace(params->tf, (*this)->read(), params->name);
117 traceParamsVec.clear();
120 const T &
read()
const {
return (*this)->read(); }
121 operator const T& ()
const {
return (*this)->read(); }
123 void write(
const T &
t) { (*this)->write(t); }
125 operator = (
const T &
t)
139 (*this)->
write(
p->read());
145 (*this)->
write(
p->read());
159 return (*this)->value_changed_event();
161 bool event()
const {
return (*this)->event(); }
164 virtual const char *
kind()
const {
return "sc_inout"; }
197 _valueChangedFinder(*this,
204 _valueChangedFinder(*this,
214 _valueChangedFinder(*this,
222 _valueChangedFinder(*this,
229 _valueChangedFinder(*this,
236 _valueChangedFinder(*this,
243 _valueChangedFinder(*this,
250 _valueChangedFinder(*this,
263 initValue =
new bool;
278 for (
auto params: traceParamsVec)
279 sc_trace(params->tf, (*this)->read(), params->name);
281 traceParamsVec.clear();
284 const bool &
read()
const {
return (*this)->read(); }
285 operator const bool& ()
const {
return (*this)->read(); }
287 void write(
const bool &
b) { (*this)->write(b); }
289 operator = (
const bool &
b)
303 (*this)->
write(
p->read());
309 (*this)->
write(
p->read());
323 return (*this)->value_changed_event();
327 bool event()
const {
return (*this)->event(); }
328 bool posedge()
const {
return (*this)->posedge(); }
329 bool negedge()
const {
return (*this)->negedge(); }
335 virtual const char *
kind()
const {
return "sc_inout"; }
360 i.add_trace(tf,
name);
367 public sc_port<sc_signal_inout_if<sc_dt::sc_logic>, 1>
372 _valueChangedFinder(*this,
380 _valueChangedFinder(*this,
391 _valueChangedFinder(*this,
400 _valueChangedFinder(*this,
409 _valueChangedFinder(*this,
418 _valueChangedFinder(*this,
427 _valueChangedFinder(*this,
436 _valueChangedFinder(*this,
456 initialize(i.
read());
468 for (
auto params: traceParamsVec)
469 sc_trace(params->tf, (*this)->read(), params->name);
471 traceParamsVec.clear();
493 (*this)->
write(
p->read());
499 (*this)->
write(
p->read());
513 return (*this)->value_changed_event();
517 bool event()
const {
return (*this)->event(); }
518 bool posedge()
const {
return (*this)->posedge(); }
519 bool negedge()
const {
return (*this)->negedge(); }
525 virtual const char *
kind()
const {
return "sc_inout"; }
552 i.add_trace(tf,
name);
559 #endif //__SYSTEMC_EXT_CHANNEL_SC_INOUT_HH__ sc_inout(const char *name, sc_port_b< sc_signal_inout_if< T > > &parent)
sc_event_finder_t< sc_signal_inout_if< T > > _valueChangedFinder
const std::string & name()
sc_inout(const char *name, const sc_signal_inout_if< T > &interface)
const sc_event & value_changed_event() const
sc_inout(const sc_signal_inout_if< sc_dt::sc_logic > &interface)
void sc_trace(sc_trace_file *tf, const sc_inout< T > &i, const std::string &name)
const sc_event & value_changed_event() const
virtual const char * kind() const
sc_event_finder & pos() const
sc_trace_params_vec traceParamsVec
virtual const T & read() const =0
const sc_event & value_changed_event() const
sc_inout(const char *name, const sc_signal_inout_if< sc_dt::sc_logic > &interface)
const bool & read() const
virtual void end_of_elaboration()
virtual const char * kind() const
virtual void end_of_elaboration()
sc_inout(const char *name)
virtual void end_of_elaboration()
void initialize(const sc_signal_in_if< T > &i)
sc_event_finder & value_changed() const
sc_event_finder & neg() const
sc_event_finder & neg() const
sc_inout(sc_port_b< sc_signal_inout_if< T > > &parent)
sc_event_finder & pos() const
const sc_event & posedge_event() const
sc_event_finder & value_changed() const
const sc_dt::sc_logic & read() const
virtual const sc_dt::sc_logic & read() const =0
void write(const bool &b)
virtual const char * kind() const
sc_inout(const char *name)
const sc_event & negedge_event() const
void sc_trace< bool >(sc_trace_file *tf, const sc_inout< bool > &i, const std::string &name)
sc_inout(sc_port< sc_signal_inout_if< T >, 1 > &parent)
sc_inout(const char *name, sc_port< sc_signal_inout_if< T >, 1 > &parent)
const sc_event & posedge_event() const
void initialize(const sc_signal_in_if< bool > &i)
void add_trace(sc_trace_file *tf, const std::string &name) const
virtual const bool & read() const =0
const sc_event & default_event() const
sc_inout(const sc_signal_inout_if< T > &interface)
void add_trace(sc_trace_file *tf, const std::string &name) const
const sc_event & default_event() const
sc_inout(const char *name, sc_port_b< sc_signal_inout_if< sc_dt::sc_logic > > &parent)
void add_trace(sc_trace_file *tf, const std::string &name) const
void write(const sc_dt::sc_logic &l)
sc_event_finder_t< sc_signal_inout_if< bool > > _posFinder
sc_event_finder_t< sc_signal_inout_if< sc_dt::sc_logic > > _valueChangedFinder
void initialize(const sc_dt::sc_logic &l)
sc_status sc_get_status()
void initialize(const bool &b)
sc_inout(const char *name, sc_port< sc_signal_inout_if< sc_dt::sc_logic >, 1 > &parent)
const sc_event & negedge_event() const
sc_event_finder & value_changed() const
sc_trace_params_vec traceParamsVec
sc_inout(sc_port< sc_signal_inout_if< sc_dt::sc_logic >, 1 > &parent)
sc_inout(sc_port_b< sc_signal_inout_if< bool > > &parent)
sc_inout(const char *name, sc_port_b< sc_signal_inout_if< bool > > &parent)
const sc_event & default_event() const
sc_event_finder_t< sc_signal_inout_if< sc_dt::sc_logic > > _negFinder
sc_inout(const char *name, sc_port< sc_signal_inout_if< bool >, 1 > &parent)
void initialize(const T &t)
sc_inout(sc_port_b< sc_signal_inout_if< sc_dt::sc_logic > > &parent)
sc_event_finder_t< sc_signal_inout_if< bool > > _valueChangedFinder
sc_event_finder_t< sc_signal_inout_if< sc_dt::sc_logic > > _posFinder
sc_inout(const char *name)
sc_inout(const sc_signal_inout_if< bool > &interface)
void initialize(const sc_signal_in_if< sc_dt::sc_logic > &i)
sc_trace_params_vec traceParamsVec
sc_dt::sc_logic * initValue
sc_event_finder_t< sc_signal_inout_if< bool > > _negFinder
sc_inout(const char *name, const sc_signal_inout_if< bool > &interface)
sc_inout(sc_port< sc_signal_inout_if< bool >, 1 > &parent)