Go to the documentation of this file.
45 #include "config/the_isa.hh"
46 #include "debug/TimeSync.hh"
61 : statistics::
Group(nullptr),
63 "Number of seconds simulated"),
65 "Number of ticks simulated"),
67 "Number of ticks from beginning of simulation "
68 "(restored from checkpoints and never reset)"),
70 statistics::units::
Tick, statistics::units::Second>::get(),
71 "The number of ticks per simulated second"),
73 "Real time elapsed on the host"),
74 ADD_STAT(hostTickRate, statistics::units::Rate<
75 statistics::units::
Tick, statistics::units::Second>::get(),
76 "The number of ticks simulated per host second (ticks/s)"),
77 ADD_STAT(hostMemory, statistics::units::Byte::get(),
78 "Number of bytes of host memory used"),
132 DPRINTF(TimeSync,
"Sleeping to sync with real time.\n");
138 }
while (diff < period);
183 _period.setTick(
p.time_sync_period);
184 _spinThreshold.setTick(
p.time_sync_spin_threshold);
186 assert(_root == NULL);
209 std::string isa = THE_ISA_STR;
227 RootParams::create()
const
229 static bool created =
false;
231 panic(
"only one root object allowed!");
238 return new Root(*
this, 0);
void timeSyncEnable(bool en)
Enable or disable time syncing.
Tick curTick()
The universal simulation clock.
statistics::Formula hostTickRate
const Time timeSyncPeriod() const
Retrieve the period for the sync event.
statistics::Value & simFreq
std::vector< EventQueue * > mainEventQueue
Array for main event queues.
void sleep(const Time &time)
Root::RootStats & rootStats
Global simulator statistics that are not associated with a specific SimObject.
void serializeSection(CheckpointOut &cp, const char *name) const
Serialize an object into a new section.
Tick Frequency
The simulated frequency of curTick(). (In ticks per second)
bool timeSyncEnabled() const
Check whether time syncing is enabled.
void schedule(Event &event, Tick when)
virtual void resetStats()
Callback to reset stats.
statistics::Value hostSeconds
Tick getTick() const
Get the current time from a value measured in Ticks.
statistics::Value simTicks
statistics::Value hostMemory
unsigned int FullSystemInt
In addition to the boolean flag we make use of an unsigned int since the CPU instruction decoder make...
void resetStats() override
Callback to reset stats.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void startup() override
Schedule the timesync event at startup().
static RootStats instance
void setCurTick(Tick newVal)
void unserializeSection(CheckpointIn &cp, const char *name)
Unserialize an a child object.
const Params & params() const
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
uint64_t memUsage()
Determine the simulator process' total virtual memory usage.
uint64_t Tick
Tick count type.
void setTimer()
Use this to set time for the purposes of time measurement (use a monotonic clock if it is available.
Tick simQuantum
Simulation Quantum for multiple eventq simulation.
statistics::Value finalTick
Derived & functor(const T &func)
Abstract superclass for simulation objects.
const Time timeSyncSpinThreshold() const
Retrieve the threshold for time remaining to spin wait.
Derived & precision(int _precision)
Set the precision and marks this stat to print at the end of simulation.
const std::string & name()
#define SERIALIZE_SCALAR(scalar)
EventFunctionWrapper syncEvent
void deschedule(Event &event)
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
Root(const Params &p, int)
statistics::Formula simSeconds
statistics::Value simFreq
Derived & prereq(const Stat &prereq)
Set the prerequisite stat and marks this stat to print at the end of simulation.
uint32_t numMainEventQueues
Current number of allocated main event queues.
statistics::Formula & simSeconds
Derived & scalar(T &value)
std::ostream CheckpointOut
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
statistics::Value & hostSeconds
void serialize(CheckpointOut &cp) const override
Serialize an object.
statistics::Value & simTicks
#define panic(...)
This implements a cprintf based panic() function.
Generated on Wed Jul 28 2021 12:10:29 for gem5 by doxygen 1.8.17