gem5
v19.0.0.0
|
Basic support for object serialization. More...
#include <serialize.hh>
Classes | |
class | ScopedCheckpointSection |
Scoped checkpoint section helper class. More... | |
Public Member Functions | |
Serializable () | |
virtual | ~Serializable () |
virtual void | serialize (CheckpointOut &cp) const =0 |
Serialize an object. More... | |
virtual void | unserialize (CheckpointIn &cp)=0 |
Unserialize an object. More... | |
void | serializeSection (CheckpointOut &cp, const char *name) const |
Serialize an object into a new section. More... | |
void | serializeSection (CheckpointOut &cp, const std::string &name) const |
void | unserializeSection (CheckpointIn &cp, const char *name) |
Unserialize an a child object. More... | |
void | unserializeSection (CheckpointIn &cp, const std::string &name) |
Static Public Member Functions | |
static const std::string & | currentSection () |
Get the fully-qualified name of the active section. More... | |
static void | serializeAll (const std::string &cpt_dir) |
static void | unserializeGlobals (CheckpointIn &cp) |
Static Public Attributes | |
static int | ckptCount = 0 |
static int | ckptMaxCount = 0 |
static int | ckptPrevCount = -1 |
Static Private Attributes | |
static std::stack< std::string > | path |
Basic support for object serialization.
Objects that support serialization should derive from this class. Such objects can largely be divided into two categories: 1) True SimObjects (deriving from SimObject), and 2) child objects (non-SimObjects).
SimObjects are serialized automatically into their own sections automatically by the SimObject base class (see SimObject::serializeAll().
SimObjects can contain other serializable objects that are not SimObjects. Much like normal serialized members are not serialized automatically, these objects will not be serialized automatically and it is expected that the objects owning such serializable objects call the required serialization/unserialization methods on child objects. The preferred method to serialize a child object is to call serializeSection() on the child, which serializes the object into a new subsection in the current section. Another option is to call serialize() directly, which serializes the object into the current section. The latter is not recommended as it can lead to naming clashes between objects.
Definition at line 153 of file serialize.hh.
Serializable::Serializable | ( | ) |
Definition at line 167 of file serialize.cc.
|
virtual |
Definition at line 171 of file serialize.cc.
|
static |
Get the fully-qualified name of the active section.
Definition at line 244 of file serialize.cc.
References CheckpointIn::baseFilename, and CheckpointIn::currentDirectory.
Referenced by arrayParamIn(), ArmSemihosting::FileBase::create(), Serializable::ScopedCheckpointSection::nameOut(), objParamIn(), optParamIn(), paramIn(), Globals::unserialize(), HDLcd::unserialize(), and GicV2::unserialize().
|
pure virtual |
Serialize an object.
Output an object's state into the current checkpoint section.
cp | Checkpoint state |
Implemented in BaseCache, iGbReg::Regs, ArmISA::ISA, System, DistIface, VirtIODeviceBase, IGbE, IGbE::TxDescCache, GicV2, GenericISA::DelaySlotUPCState< MachInst >, DistIface::RecvScheduler, ArmISA::PMU::CounterState, Event, BaseCPU, IGbE::RxDescCache, HDLcd::DmaEngine, Pl111, IdeDisk, NSGigE, DistIface::RecvScheduler::Desc, GenericISA::DelaySlotPCState< MachInst >, DmaReadFifo, X86ISA::PCState, IGbE::DescCache< T >, IGbE::DescCache< iGbReg::TxDesc >, IGbE::DescCache< iGbReg::RxDesc >, Gicv3CPUInterface, GenericTimerMem, VirtQueue, ArmISA::TlbEntry, Sinic::Device, X86ISA::Interrupts, DistIface::SyncSwitch, MultiLevelPageTable< EntryTypes >, ArmISA::Interrupts, BasePixelPump::PixelEvent, GenericISA::UPCState< MachInst >, SparcISA::Interrupts, BaseTrafficGen, ClockedObject, PhysicalMemory, SrcClockDomain, X86ISA::GpuTLB, DistIface::SyncNode, Gicv3Distributor, DistEtherLink, ArmSemihosting::File, GenericTimer, PciDevice, Gicv3Redistributor, VirtIO9PProxy, DeviceFDEntry, SimObject, ArmSemihosting::FileFeatures, RealViewOsc, VGic, CopyEngine, GicV2::BankedRegs, DistIface::Sync, CopyEngineReg::ChanRegs, EtherSwitch, CpuLocalTimer, SMMUv3, ArchTimer, SparcISA::TLB, RealViewCtrl, PipeFDEntry, UFSHostDevice, TickedObject, CheckerCPU, DVFSHandler, PowerISA::TLB, A9GlobalTimer, SparcISA::ISA, EtherSwitch::Interface::PortFifo, ThermalModel, Sp804, SimpleThread, EmulationPageTable, IdeController, X86ISA::TLB, EtherLink, BasePixelPump, Gicv3Its, EtherTapStub, I2CBus, AlphaISA::TlbEntry, MinorCPU, CpuLocalTimer::Timer, X86ISA::I8042, Iob, Ticked, TsunamiIO, X86ISA::ISA, FileFDEntry, A9GlobalTimer::Timer, Pl050, MaltaCChip, CowDiskImage, RiscvISA::Interrupts, EnergyCtrl, TrafficGen, TsunamiCChip, MaltaIO, ArmSemihosting::FileBase, Malta, ThermalReference, VoltageDomain, PL031, CopyEngineReg::Regs, X86ISA::I8259, Gicv3, AlphaISA::Interrupts, Sp804::Timer, X86ISA::I8254, O3ThreadState< Impl >, AlphaBackdoor, AlphaISA::TLB, GenericISA::PCStateBase, X86ISA::TlbEntry, EtherSwitch::Interface::PortFifoEntry, X86ISA::I82094AA, CopyEngine::CopyEngineChannel, MipsISA::Interrupts, MipsISA::TLB, Root, RiscvISA::TLB, SystemCounter, ArmISA::PMU, Random, Uart8250, GpuDispatcher, HDLcd, X86ISA::Cmos, ThermalDomain, DistEtherLink::Link, AlphaISA::ISA, AlphaISA::Kernel::Statistics, ThermalCapacitor, LocalSimLoopExitEvent, MemState, EtherSwitch::Interface, Tsunami, Globals, RubySystem, FrameBuffer, ArmSemihosting, AlphaBackdoor::Access, TsunamiPChip, X86ISA::Speaker, Sinic::Base, Process, EtherTapBase, PS2Mouse, FlashDevice, ThermalResistor, ThreadState, DisplayTimings, DumbTOD, PS2TouchKit, PS2Keyboard, MmDisk, FDEntry, PollEvent, Pl011, Kernel::Statistics, X86ISA::I8237, NoMaliGpu, Sp805, and PS2Device.
|
static |
Definition at line 190 of file serialize.cc.
References CheckpointIn::baseFilename, fatal, SimObject::serializeAll(), serializeSection(), CheckpointIn::setDir(), and ArmISA::t.
Referenced by debug_serialize(), and pybind_init_core().
void Serializable::serializeSection | ( | CheckpointOut & | cp, |
const char * | name | ||
) | const |
Serialize an object into a new section.
This method creates a new section in a checkpoint and calls serialize() to serialize the current object into that section. The name of the section is appended to the current checkpoint path.
cp | Checkpoint state |
name | Name to append to the active path |
Definition at line 176 of file serialize.cc.
References serialize().
Referenced by EtherSwitch::Interface::serialize(), ArmISA::PMU::serialize(), AlphaISA::TLB::serialize(), Gicv3::serialize(), Sp804::serialize(), CpuLocalTimer::serialize(), CopyEngine::serialize(), VGic::serialize(), GenericTimer::serialize(), DistEtherLink::serialize(), GenericTimerMem::serialize(), IGbE::serialize(), VirtIODeviceBase::serialize(), DistIface::serialize(), System::serialize(), SimObject::serializeAll(), and serializeAll().
|
inline |
Definition at line 237 of file serialize.hh.
|
pure virtual |
Unserialize an object.
Read an object's state from the current checkpoint section.
cp | Checkpoint state |
Implemented in BaseCache, iGbReg::Regs, ArmISA::ISA, System, DistIface, VirtIODeviceBase, IGbE, IGbE::TxDescCache, GicV2, GenericISA::DelaySlotUPCState< MachInst >, DistIface::RecvScheduler, ArmISA::PMU::CounterState, BaseCPU, Event, IGbE::RxDescCache, HDLcd::DmaEngine, Pl111, IdeDisk, GenericISA::DelaySlotPCState< MachInst >, NSGigE, DistIface::RecvScheduler::Desc, X86ISA::PCState, DmaReadFifo, IGbE::DescCache< T >, IGbE::DescCache< iGbReg::TxDesc >, IGbE::DescCache< iGbReg::RxDesc >, Gicv3CPUInterface, ArmISA::TlbEntry, GenericTimerMem, VirtQueue, Sinic::Device, X86ISA::Interrupts, MultiLevelPageTable< EntryTypes >, DistIface::SyncSwitch, ArmISA::Interrupts, GenericISA::UPCState< MachInst >, BasePixelPump::PixelEvent, SparcISA::Interrupts, PhysicalMemory, BaseTrafficGen, ClockedObject, SrcClockDomain, X86ISA::GpuTLB, DistIface::SyncNode, Gicv3Distributor, DistEtherLink, PciDevice, ArmSemihosting::File, GenericTimer, Gicv3Redistributor, VirtIO9PProxy, DeviceFDEntry, SimObject, ArmSemihosting::FileFeatures, RealViewOsc, CopyEngineReg::ChanRegs, VGic, CopyEngine, GicV2::BankedRegs, DistIface::Sync, EtherSwitch, CpuLocalTimer, SMMUv3, ArchTimer, SparcISA::TLB, RealViewCtrl, PipeFDEntry, UFSHostDevice, TickedObject, CheckerCPU, DVFSHandler, PowerISA::TLB, A9GlobalTimer, SparcISA::ISA, EtherSwitch::Interface::PortFifo, ThermalModel, Sp804, SimpleThread, EmulationPageTable, IdeController, X86ISA::TLB, EtherLink, BasePixelPump, Gicv3Its, EtherTapStub, I2CBus, AlphaISA::TlbEntry, MinorCPU, CpuLocalTimer::Timer, X86ISA::I8042, Iob, RiscvISA::Interrupts, Ticked, TsunamiIO, X86ISA::ISA, FileFDEntry, A9GlobalTimer::Timer, Pl050, MaltaCChip, CowDiskImage, EnergyCtrl, CopyEngineReg::Regs, TrafficGen, TsunamiCChip, MaltaIO, ArmSemihosting::FileBase, Malta, ThermalReference, AlphaISA::Interrupts, O3ThreadState< Impl >, VoltageDomain, PL031, X86ISA::I8259, Gicv3, GenericISA::PCStateBase, Sp804::Timer, X86ISA::I8254, AlphaBackdoor, AlphaISA::TLB, X86ISA::TlbEntry, EtherSwitch::Interface::PortFifoEntry, X86ISA::I82094AA, MipsISA::Interrupts, CopyEngine::CopyEngineChannel, MipsISA::TLB, RiscvISA::TLB, SystemCounter, ArmISA::PMU, Random, Uart8250, GpuDispatcher, MemState, HDLcd, X86ISA::Cmos, ThermalDomain, DistEtherLink::Link, AlphaISA::ISA, AlphaISA::Kernel::Statistics, ThermalCapacitor, LocalSimLoopExitEvent, EtherSwitch::Interface, Tsunami, Globals, RubySystem, FrameBuffer, ArmSemihosting, AlphaBackdoor::Access, TsunamiPChip, X86ISA::Speaker, Sinic::Base, Process, EtherTapBase, PS2Mouse, FlashDevice, ThreadState, ThermalResistor, DisplayTimings, DumbTOD, PS2TouchKit, PS2Keyboard, FDEntry, PollEvent, Pl011, Kernel::Statistics, X86ISA::I8237, NoMaliGpu, Sp805, PS2Device, and AlphaProcess.
|
static |
Definition at line 209 of file serialize.cc.
References ArmISA::i, mainEventQueue, numMainEventQueues, Globals::unserializedCurTick, and unserializeSection().
Referenced by pybind_init_core().
void Serializable::unserializeSection | ( | CheckpointIn & | cp, |
const char * | name | ||
) |
Unserialize an a child object.
This method loads a child object from a checkpoint. The object name is appended to the active path to form a fully qualified section name and unserialize() is called.
cp | Checkpoint state |
name | Name to append to the active path |
Definition at line 183 of file serialize.cc.
References unserialize().
Referenced by SimObject::loadState(), EtherSwitch::Interface::unserialize(), ArmISA::PMU::unserialize(), Gicv3::unserialize(), X86ISA::TLB::unserialize(), Sp804::unserialize(), EtherSwitch::Interface::PortFifo::unserialize(), CpuLocalTimer::unserialize(), CopyEngine::unserialize(), GenericTimer::unserialize(), DistEtherLink::unserialize(), GenericTimerMem::unserialize(), DistIface::RecvScheduler::unserialize(), IGbE::unserialize(), VirtIODeviceBase::unserialize(), DistIface::unserialize(), System::unserialize(), and unserializeGlobals().
|
inline |
Definition at line 253 of file serialize.hh.
|
static |
Definition at line 260 of file serialize.hh.
|
static |
Definition at line 261 of file serialize.hh.
|
static |
Definition at line 262 of file serialize.hh.
|
staticprivate |
Definition at line 267 of file serialize.hh.
Referenced by Process::checkPathRedirect(), Iris::CPU< CortexA76TC >::CPU(), MathExprPowerModel::MathExprPowerModel(), ArmSemihosting::readString(), FastModel::CortexA76::set_evs_param(), MPP_TAGE::updatePathAndGlobalHistory(), and TAGE_SC_L_TAGE::updatePathAndGlobalHistory().