61 name += std::string(to ?
"_posedge_action" :
"_negedge_action");
94 sc_clock::sc_clock() :
112 "increase the period: clock '" +
113 std::string(name) +
"'";
119 "increase the period or increase the duty cycle: clock '" +
120 std::string(name) +
"'";
124 if (duty_cycle * period == period) {
126 "increase the period or decrease the duty cycle: clock '" +
127 std::string(name) +
"'";
131 _gem5UpEdge = new ::sc_gem5::ClockTick(
this,
true, period);
132 _gem5DownEdge = new ::sc_gem5::ClockTick(
this,
false, period);
145 sc_time(start_time_v, start_time_tu), posedge_first)
151 sc_time(start_time, true), posedge_first)
167 panic(
"write() called on sc_clock.");
#define panic(...)
This implements a cprintf based panic() function.
const char SC_ID_CLOCK_HIGH_TIME_ZERO_[]
const sc_time & period() const
virtual void before_end_of_elaboration()
const char * sc_gen_unique_name(const char *seed)
const char SC_ID_CLOCK_PERIOD_ZERO_[]
::sc_gem5::ClockTick * _gem5DownEdge
const char * name() const
static const sc_time & time_stamp()
const sc_time & start_time() const
ProcessMemberFuncWrapper<::sc_core::sc_clock > funcWrapper
void deschedule(ScEvent *event)
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,16,32,64}_t.
bool posedge_first() const
double duty_cycle() const
::sc_gem5::ClockTick * _gem5UpEdge
virtual void write(const bool &)
const sc_time & sc_time_stamp()
const sc_time SC_ZERO_TIME
const char SC_ID_CLOCK_LOW_TIME_ZERO_[]
ClockTick(::sc_core::sc_clock *clock, bool to, ::sc_core::sc_time _period)
#define SC_REPORT_ERROR(msg_type, msg)
void schedule(ScEvent *event, const ::sc_core::sc_time &delay)
::sc_core::sc_time _period