sim: Add support for notifying Drainable objects of a fork

When forking a gem5 process, some objects need to clean up resources
(mainly file descriptions) shared between the child and the parent of
the fork. This changeset adds the notifyFork() method to Drainable,
which is called in the child process.

Signed-off-by: Andreas Sandberg <andreas@sandberg.pp.se>
[sascha.bischoff@arm.com: Rebased patches onto a newer gem5 version]
Signed-off-by: Sascha Bischoff <sascha.bischoff@arm.com>
Signed-off-by: Andreas Sandberg <andreas.sandberg@arm.com>
This commit is contained in:
Andreas Sandberg 2015-11-26 10:03:43 +00:00
parent 5383e1ada4
commit 738d71f6a9
2 changed files with 18 additions and 0 deletions

View file

@ -308,4 +308,8 @@ def switchCpus(system, cpuList, verbose=True):
for old_cpu, new_cpu in cpuList: for old_cpu, new_cpu in cpuList:
new_cpu.takeOverFrom(old_cpu) new_cpu.takeOverFrom(old_cpu)
def notifyFork(root):
for obj in root.descendants():
obj.notifyFork()
from internal.core import disableAllListeners from internal.core import disableAllListeners

View file

@ -275,6 +275,20 @@ class Drainable
/** Return the current drain state of an object. */ /** Return the current drain state of an object. */
DrainState drainState() const { return _drainState; } DrainState drainState() const { return _drainState; }
/**
* Notify a child process of a fork.
*
* When calling fork in gem5, we need to ensure that resources
* shared between the parent and the child are consistent. This
* method is intended to be overloaded to handle that. For
* example, an object could use this method to re-open input files
* to get a separate file description with a private file offset.
*
* This method is only called in the child of the fork. The call
* takes place in a drained system.
*/
virtual void notifyFork() {};
private: private:
/** DrainManager interface to request a drain operation */ /** DrainManager interface to request a drain operation */
DrainState dmDrain(); DrainState dmDrain();