46 #ifndef __SIM_OBJECT_HH__ 47 #define __SIM_OBJECT_HH__ 53 #include "params/SimObject.hh" 129 virtual const std::string
name()
const {
return params()->name; }
254 static void debugObjectBreak(
const std::string &objs);
283 virtual SimObject *resolveSimObject(
const std::string &
name) = 0;
287 void debugObjectBreak(
const char *objs);
290 #endif // __SIM_OBJECT_HH__ virtual void memInvalidate()
Invalidate the contents of memory buffers.
static SimObject * find(const char *name)
Find the SimObject with the given name and return a pointer to it.
Ports are used to interface objects to each other.
virtual void regProbeListeners()
Register probe listeners for this object.
const PortID InvalidPortID
virtual void memWriteback()
Write back dirty buffers to memory using functional writes.
virtual void initState()
initState() is called on each SimObject when not restoring from a checkpoint.
static void serializeAll(CheckpointOut &cp)
Serialize all SimObjects in the system.
ProbeManager is a conduit class that lives on each SimObject, and is used to match up probe listeners...
virtual ~SimObjectResolver()
Base class to wrap object resolving functionality.
DrainState
Object drain/handover states.
Interface for objects that might require draining before checkpointing.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Draining buffers pending serialization/handover.
virtual void startup()
startup() is the final initialization call before simulation.
virtual Port & getPort(const std::string &if_name, PortID idx=InvalidPortID)
Get a port with a given name and index.
static SimObjectList simObjectList
List of all instantiated simulation objects.
ProbeManager * probeManager
Manager coordinates hooking up probe points with listeners.
const Params * params() const
std::vector< SimObject * > SimObjectList
Basic support for object serialization.
virtual void regProbePoints()
Register probe points for this object.
ProbeManager * getProbeManager()
Get the probe manager for this object.
virtual const std::string name() const
std::ostream CheckpointOut
SimObject(const Params *_params)
const SimObjectParams * _params
Cached copy of the object parameters.
virtual void loadState(CheckpointIn &cp)
loadState() is called on each SimObject when restoring from a checkpoint.
DrainState drain() override
Provide a default implementation of the drain interface for objects that don't need draining...
void unserialize(CheckpointIn &cp) override
Unserialize an object.
virtual void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
int16_t PortID
Port index/ID type, and a symbolic name for an invalid port id.
Abstract superclass for simulation objects.