Go to the documentation of this file.
37 #include "debug/Checkpoint.hh"
84 DPRINTF(Checkpoint,
"unserializing\n");
89 DPRINTF(Checkpoint,
"no checkpoint section found\n");
128 fatal(
"%s does not have any port named %s\n",
name(), if_name);
143 for (;
ri != rend; ++
ri) {
156 SimObject::debugObjectBreak(
const std::string &objs)
162 for (;
i != end; ++
i) {
164 obj->doDebugBreak = match.match(obj->
name());
169 debugObjectBreak(
const char *objs)
171 SimObject::debugObjectBreak(std::string(objs));
181 for (;
i != end; ++
i) {
209 if (!cp.
find(section,
name, path)) {
210 fatal(
"Can't unserialize '%s:%s'\n", section,
name);
#define fatal(...)
This implements a cprintf based fatal() function.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
ObjectMatch contains a vector of expressions.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
virtual void initState()
initState() is called on each SimObject when not restoring from a checkpoint.
static SimObjectResolver * _objNameResolver
Helper to resolve an object given its name.
static void serializeAll(const std::string &cpt_dir)
Create a checkpoint by serializing all SimObjects in the system.
ProbeManager * probeManager
Manager coordinates hooking up probe points with listeners.
EventQueue * getEventQueue(uint32_t index)
Function for returning eventq queue for the provided index.
void serializeSection(CheckpointOut &cp, const char *name) const
Serialize an object into a new section.
static SimObject * find(const char *name)
Find the SimObject with the given name and return a pointer to it.
virtual void loadState(CheckpointIn &cp)
loadState() is called on each SimObject when restoring from a checkpoint.
virtual void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
static SimObjectResolver * getSimObjectResolver()
There is a single object name resolver, and it is only set when simulation is restoring from checkpoi...
std::vector< SimObject * > SimObjectList
Interface for things with names.
static SimObjectList simObjectList
List of all instantiated simulation objects.
void debug_serialize(const std::string &cpt_dir)
virtual std::string name() const
void unserializeSection(CheckpointIn &cp, const char *name)
Unserialize an a child object.
void objParamIn(CheckpointIn &cp, const std::string &name, SimObject *¶m)
To avoid circular dependencies the unserialization of SimObjects must be implemented here.
static void generateCheckpointOut(const std::string &cpt_dir, std::ofstream &outstream)
Generate a checkpoint file so that the serialization can be routed to it.
Abstract superclass for simulation objects.
const std::string & name()
ProbeManager is a conduit class that lives on each SimObject, and is used to match up probe listeners...
static const std::string & currentSection()
Gets the fully-qualified name of the active section.
ProbeManager * getProbeManager()
Get the probe manager for this object.
virtual void regProbeListeners()
Register probe listeners for this object.
SimObject(const Params &p)
bool sectionExists(const std::string §ion)
bool find(const std::string §ion, const std::string &entry, std::string &value)
Ports are used to interface objects to each other.
virtual void startup()
startup() is the final initialization call before simulation.
Base class to wrap object resolving functionality.
virtual void regProbePoints()
Register probe points for this object.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual SimObject * resolveSimObject(const std::string &name)=0
Find a SimObject given a full path name.
static void setSimObjectResolver(SimObjectResolver *resolver)
There is a single object name resolver, and it is only set when simulation is restoring from checkpoi...
Generated on Tue Dec 21 2021 11:34:35 for gem5 by doxygen 1.8.17