44 #include "debug/Drain.hh" 64 "Trying to drain a drained system\n");
67 "Drain counter must be zero at the start of a drain cycle\n");
76 DPRINTF(Drain,
"Failed to drain %s\n", temp->
name());
82 DPRINTF(Drain,
"Drain done.\n");
86 DPRINTF(Drain,
"Need another drain cycle. %u/%u objects not ready.\n",
96 "Trying to resume a system that is already running\n");
99 "Resuming a system that isn't fully drained, this is untested and " 100 "likely to break\n");
103 "Resuming a system that is already trying to resume. This should " 107 "Resume called in the middle of a drain cycle. %u objects " 108 "left to drain.\n",
_count);
123 obj->dmDrainResume();
135 "preCheckpointRestore() called on a system that isn't in the " 138 DPRINTF(Drain,
"Applying pre-restore fixes to %u objects.\n",
178 if (obj->drainState() !=
state)
196 _drainState(_drainManager.
state())
222 "Trying to resume an object that hasn't been drained\n");
virtual DrainState drain()=0
Notify an object that it needs to drain its state.
virtual void drainResume()
Resume execution after a successful drain.
DrainManager & _drainManager
Convenience reference to the drain manager.
bool tryDrain()
Try to drain the system.
size_t drainableCount() const
Thread-safe helper function to get the number of Drainable objects in a system.
DrainState
Object drain/handover states.
Interface for objects that might require draining before checkpointing.
DrainState state() const
Get the simulators global drain state.
Draining buffers pending serialization/handover.
void dmDrainResume()
DrainManager interface to request a resume operation.
std::atomic_uint _count
Number of objects still draining.
DrainState dmDrain()
DrainManager interface to request a drain operation.
This class coordinates draining of a System.
#define warn_if(cond,...)
Conditional warning macro that checks the supplied condition and only prints a warning if the conditi...
std::vector< Drainable * > _allDrainable
Set of all drainable objects.
void unregisterDrainable(Drainable *obj)
static DrainManager _instance
Singleton instance of the drain manager.
void resume()
Resume normal simulation in a Drained system.
std::mutex globalLock
Lock protecting the set of drainable objects.
virtual const std::string name() const
void exitSimLoop(const std::string &message, int exit_code, Tick when, Tick repeat, bool serialize)
Schedule an event to exit the simulation loop (returning to Python) at the end of the current cycle (...
bool allInState(DrainState state) const
Helper function to check if all Drainable objects are in a specific state.
void registerDrainable(Drainable *obj)
static DrainManager & instance()
Get the singleton DrainManager instance.
Buffers drained, ready for serialization/handover.
void preCheckpointRestore()
Run state fixups before a checkpoint restore operation.
void signalDrainDone()
Notify the DrainManager that a Drainable object has finished draining.
DrainState _state
Global simulator drain state.
DrainState _drainState
Current drain state of the object.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Abstract superclass for simulation objects.