gem5: restore works now
The function restore(PATH) can now be used to restore a checkpoint. Change-Id: I25faf9f6335261d2b3ade4185eae93983ece9f97
This commit is contained in:
@ -289,21 +289,21 @@ AtomicSimpleCPU::readMem(Addr addr, uint8_t * data,
|
||||
}
|
||||
dcache_access = true;
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_TRAP
|
||||
if(pkt.isError()) {
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onTrap(cpu, 0);
|
||||
}
|
||||
#endif
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_TRAP
|
||||
if(pkt.isError()) {
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onTrap(cpu, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
assert(!pkt.isError());
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_MEMREAD
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onMemoryAccess(cpu, pkt.getAddr(), pkt.getSize(), false, instAddr());
|
||||
#endif
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_MEMREAD
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onMemoryAccess(cpu, pkt.getAddr(), pkt.getSize(), false, instAddr());
|
||||
#endif
|
||||
|
||||
if (req->isLLSC()) {
|
||||
TheISA::handleLockedRead(thread, req);
|
||||
@ -404,22 +404,22 @@ AtomicSimpleCPU::writeMem(uint8_t *data, unsigned size,
|
||||
dcache_latency += dcachePort.sendAtomic(&pkt);
|
||||
}
|
||||
dcache_access = true;
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_TRAP
|
||||
if(pkt.isError()) {
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onTrap(cpu, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_TRAP
|
||||
if(pkt.isError()) {
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onTrap(cpu, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
assert(!pkt.isError());
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_MEMWRITE
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onMemoryAccess(cpu, pkt.getAddr(), pkt.getSize(), true, instAddr());
|
||||
#endif
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_MEMWRITE
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onMemoryAccess(cpu, pkt.getAddr(), pkt.getSize(), true, instAddr());
|
||||
#endif
|
||||
|
||||
if (req->isSwap()) {
|
||||
assert(res);
|
||||
@ -486,6 +486,18 @@ AtomicSimpleCPU::tick()
|
||||
bool needToFetch = !isRomMicroPC(pcState.microPC()) &&
|
||||
!curMacroStaticInst;
|
||||
if (needToFetch) {
|
||||
//DanceOS
|
||||
#if defined(CONFIG_EVENT_BREAKPOINTS) || defined(CONFIG_EVENT_BREAKPOINTS_RANGE)
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.setMnemonic("This feature is not implemented for gem5.");
|
||||
fail::simulator.onBreakpoint(cpu, instAddr(), -1);
|
||||
#endif
|
||||
|
||||
//DanceOS
|
||||
if(fail::simulator.isRestoreRequest()) {
|
||||
fail::simulator.onRestore();
|
||||
}
|
||||
|
||||
setupFetchRequest(&ifetch_req);
|
||||
fault = thread->itb->translateAtomic(&ifetch_req, tc,
|
||||
BaseTLB::Execute);
|
||||
@ -513,22 +525,22 @@ AtomicSimpleCPU::tick()
|
||||
else
|
||||
icache_latency = icachePort.sendAtomic(&ifetch_pkt);
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_TRAP
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_TRAP
|
||||
if(ifetch_pkt.isError())
|
||||
{
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onTrap(cpu, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
assert(!ifetch_pkt.isError());
|
||||
{
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onTrap(cpu, 0);
|
||||
}
|
||||
#endif
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_MEMREAD
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onMemoryAccess(cpu, ifetch_pkt.getAddr(), ifetch_pkt.getSize(), false, instAddr());
|
||||
#endif
|
||||
assert(!ifetch_pkt.isError());
|
||||
|
||||
// FAIL*
|
||||
#ifdef CONFIG_EVENT_MEMREAD
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.onMemoryAccess(cpu, ifetch_pkt.getAddr(), ifetch_pkt.getSize(), false, instAddr());
|
||||
#endif
|
||||
|
||||
// ifetch_req is initialized to read the instruction directly
|
||||
// into the CPU object's inst field.
|
||||
|
||||
@ -401,13 +401,6 @@ BaseSimpleCPU::preExecute()
|
||||
//fetch beyond the MachInst at the current pc.
|
||||
instPtr = decoder->decode(pcState);
|
||||
|
||||
// FAIL*
|
||||
#if defined(CONFIG_EVENT_BREAKPOINTS) || defined(CONFIG_EVENT_BREAKPOINTS_RANGE)
|
||||
fail::ConcreteCPU* cpu = &fail::simulator.getCPU(cpuId());
|
||||
fail::simulator.setMnemonic(instPtr->getName());
|
||||
fail::simulator.onBreakpoint(cpu, instAddr(), -1);
|
||||
#endif
|
||||
|
||||
if (instPtr) {
|
||||
stayAtPC = false;
|
||||
thread->pcState(pcState);
|
||||
|
||||
@ -512,6 +512,13 @@ Serializable::unserializeGlobals(Checkpoint *cp)
|
||||
globals.unserialize(cp, globals.name());
|
||||
}
|
||||
|
||||
//DanceOS
|
||||
void
|
||||
Serializable::loadStateAll(Checkpoint *cp)
|
||||
{
|
||||
SimObject::loadStateAll(cp);
|
||||
}
|
||||
|
||||
void
|
||||
debug_serialize(const string &cpt_dir)
|
||||
{
|
||||
|
||||
@ -170,6 +170,7 @@ class Serializable
|
||||
static int ckptPrevCount;
|
||||
static void serializeAll(const std::string &cpt_dir);
|
||||
static void unserializeGlobals(Checkpoint *cp);
|
||||
static void loadStateAll(Checkpoint *cp); //DanceOS
|
||||
};
|
||||
|
||||
//
|
||||
|
||||
@ -130,6 +130,21 @@ SimObject::serializeAll(ostream &os)
|
||||
}
|
||||
}
|
||||
|
||||
//DanceOS
|
||||
// static function: loadState all SimObjects.
|
||||
//
|
||||
void
|
||||
SimObject::loadStateAll(Checkpoint *cp)
|
||||
{
|
||||
SimObjectList::iterator ri = simObjectList.begin();
|
||||
SimObjectList::iterator rend = simObjectList.end();
|
||||
|
||||
for (; ri != rend; ++ri) {
|
||||
SimObject *obj = *ri;
|
||||
obj->loadState(cp);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
#ifdef DEBUG
|
||||
//
|
||||
|
||||
@ -139,6 +139,7 @@ class SimObject : public EventManager, public Serializable
|
||||
|
||||
// static: call nameOut() & serialize() on all SimObjects
|
||||
static void serializeAll(std::ostream &);
|
||||
static void loadStateAll(Checkpoint *cp); //DanceOS
|
||||
|
||||
// Methods to drain objects in order to take checkpoints
|
||||
// Or switch from timing -> atomic memory model
|
||||
|
||||
Reference in New Issue
Block a user