Go to the documentation of this file.
46 #ifndef __SIM_OBJECT_HH__
47 #define __SIM_OBJECT_HH__
54 #include "params/SimObject.hh"
65 class SimObjectResolver;
335 static void debugObjectBreak(
const std::string &objs);
371 #define PARAMS(type) \
372 using Params = type ## Params; \
376 return reinterpret_cast<const Params&>(_params); \
399 void debugObjectBreak(
const char *objs);
408 void objParamIn(CheckpointIn &cp,
const std::string &
name, SimObject * ¶m);
414 #endif // __SIM_OBJECT_HH__
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
virtual void initState()
initState() is called on each SimObject when not restoring from a checkpoint.
virtual void memInvalidate()
Invalidate the contents of memory buffers.
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.
const SimObjectParams & _params
Cached copy of the object parameters.
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.
const PortID InvalidPortID
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)
Basic support for object serialization.
DrainState
Object drain/handover states.
void serialize(CheckpointOut &cp) const override
Serialize an object.
virtual std::string name() const
void objParamIn(CheckpointIn &cp, const std::string &name, SimObject *¶m)
To avoid circular dependencies the unserialization of SimObjects must be implemented here.
const Params & params() const
Abstract superclass for simulation objects.
@ Drained
Buffers drained, ready for serialization/handover.
const std::string & name()
ProbeManager is a conduit class that lives on each SimObject, and is used to match up probe listeners...
virtual ~SimObjectResolver()
ProbeManager * getProbeManager()
Get the probe manager for this object.
virtual void regProbeListeners()
Register probe listeners for this object.
SimObject(const Params &p)
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.
Interface for objects that might require draining before checkpointing.
std::ostream CheckpointOut
virtual void memWriteback()
Write back dirty buffers to memory using functional writes.
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...
DrainState drain() override
Provide a default implementation of the drain interface for objects that don't need draining.
Generated on Wed Jul 28 2021 12:10:29 for gem5 by doxygen 1.8.17