Go to the documentation of this file.
45 #include "config/the_isa.hh"
46 #include "debug/TimeSync.hh"
56 :
Stats::Group(nullptr),
60 "Number of ticks from beginning of simulation "
61 "(restored from checkpoints and never reset)"),
63 "The number of ticks per simulated second"),
67 "The number of ticks simulated per host second (ticks/s)"),
122 DPRINTF(TimeSync,
"Sleeping to sync with real time.\n");
128 }
while (diff < period);
173 _period.setTick(
p.time_sync_period);
174 _spinThreshold.setTick(
p.time_sync_spin_threshold);
176 assert(_root == NULL);
199 std::string isa = THE_ISA_STR;
208 RootParams::create()
const
210 static bool created =
false;
212 panic(
"only one root object allowed!");
219 return new Root(*
this, 0);
Root(const Params &p, int)
Derived & scalar(T &value)
Stats::Formula simSeconds
void timeSyncEnable(bool en)
Enable or disable time syncing.
Derived & functor(const T &func)
uint64_t Tick
Tick count type.
void deschedule(Event &event)
Tick Frequency
The simulated frequency of curTick(). (In ticks per second)
virtual void resetStats()
Callback to reset stats.
Stats::Formula hostTickRate
void schedule(Event &event, Tick when)
Derived & prereq(const Stat &prereq)
Set the prerequisite stat and marks this stat to print at the end of simulation.
bool timeSyncEnabled() const
Check whether time syncing is enabled.
const Time timeSyncPeriod() const
Retrieve the period for the sync event.
void sleep(const Time &time)
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
void startup() override
Schedule the timesync event at startup().
const Time timeSyncSpinThreshold() const
Retrieve the threshold for time remaining to spin wait.
Stats::Value & hostSeconds
unsigned int FullSystemInt
In addition to the boolean flag we make use of an unsigned int since the CPU instruction decoder make...
Stats::Formula & simSeconds
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
Tick getTick() const
Get the current time from a value measured in Ticks.
Root::RootStats & rootStats
Global simulator statistics that are not associated with a specific SimObject.
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
void resetStats() override
Callback to reset stats.
#define UNIT_RATE(T1, T2)
EventFunctionWrapper syncEvent
void setTimer()
Use this to set time for the purposes of time measurement (use a monotonic clock if it is available.
Derived & precision(int _precision)
Set the precision and marks this stat to print at the end of simulation.
Tick simQuantum
Simulation Quantum for multiple eventq simulation.
std::ostream CheckpointOut
static RootStats instance
Tick curTick()
The universal simulation clock.
uint64_t memUsage()
Determine the simulator process' total virtual memory usage.
const Params & params() const
void serialize(CheckpointOut &cp) const override
Serialize an object.
#define panic(...)
This implements a cprintf based panic() function.
Abstract superclass for simulation objects.
Generated on Tue Mar 23 2021 19:41:28 for gem5 by doxygen 1.8.17