28#ifndef __SIM_SIGNAL_HH__
29#define __SIM_SIGNAL_HH__
39template <
typename State>
40class SignalSourcePort;
42template <
typename State>
58 set(
const State &new_state)
81 "incompatible pin %s",
name(), peer.
name());
92template <
typename State>
105 set(
const State &new_state)
108 sink->set(new_state);
118 "incompatible pin %s",
name(), peer.
name());
Ports are used to interface objects to each other.
const std::string name() const
Return port name (for DPRINTF).
virtual void unbind()
Dettach from a peer port.
virtual void bind(Port &peer)
Attach to a peer port.
std::function< void(const State &new_val)> OnChangeFunc
const State & state() const
void onChange(OnChangeFunc func)
void set(const State &new_state)
void bind(Port &peer) override
Attach to a peer port.
SignalSourcePort< State > * _source
SignalSinkPort(const std::string &_name, PortID _id=InvalidPortID)
void unbind() override
Dettach from a peer port.
void bind(Port &peer) override
Attach to a peer port.
const State & state() const
void unbind() override
Dettach from a peer port.
SignalSourcePort(const std::string &_name, PortID _id=InvalidPortID)
SignalSinkPort< State > * sink
void set(const State &new_state)
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const PortID InvalidPortID
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.