sim: Add drain methods to request additional cleanup operations

This patch adds the following two methods to the Drainable base class:

memWriteback() - Write back all dirty cache lines to memory using
functional accesses.

memInvalidate() - Invalidate memory system buffers. Dirty data
won't be written back.

Specifying calling memWriteback() after draining will allow us to
checkpoint systems with caches. memInvalidate() can be used to drop
memory system buffers in preparation for switching to an accelerated
CPU model that bypasses the gem5 memory system (e.g., hardware
virtualized CPUs).

Note: This patch only adds the methods to Drainable, the code for
flushing the TLB and the cache is committed separately.
This commit is contained in:
Andreas Sandberg
2012-11-02 11:32:02 -05:00
parent aae6134b54
commit 050f24c796
2 changed files with 32 additions and 0 deletions

View File

@@ -181,6 +181,14 @@ def drain(root):
while (not all_drained):
all_drained = _drain()
def memWriteback(root):
for obj in root.descendants():
obj.memWriteback()
def memInvalidate(root):
for obj in root.descendants():
obj.memInvalidate()
def resume(root):
for obj in root.descendants(): obj.drainResume()
@@ -189,6 +197,7 @@ def checkpoint(dir):
if not isinstance(root, objects.Root):
raise TypeError, "Checkpoint must be called on a root object."
drain(root)
memWriteback(root)
print "Writing checkpoint"
internal.core.serializeAll(dir)
resume(root)