diff options
author | Andreas Sandberg <Andreas.Sandberg@ARM.com> | 2013-01-07 13:05:42 -0500 |
---|---|---|
committer | Andreas Sandberg <Andreas.Sandberg@ARM.com> | 2013-01-07 13:05:42 -0500 |
commit | 17b47d35e1d0dedca7a3336f1193b1a502bcd78b (patch) | |
tree | 3b37175b174a2cdad1020ff6dd917f32c1c10907 /src/arch/x86 | |
parent | 7eb0fb8b6ebffcb39b61964d4c7387455c262aae (diff) | |
download | gem5-17b47d35e1d0dedca7a3336f1193b1a502bcd78b.tar.xz |
arch: Move the ISA object to a separate section
After making the ISA an independent SimObject, it is serialized
automatically by the Python world. Previously, this just resulted in
an empty ISA section. This patch moves the contents of the ISA to that
section and removes the explicit ISA serialization from the thread
contexts, which makes it behave like a normal SimObject during
serialization.
Note: This patch breaks checkpoint backwards compatibility! Use the
cpt_upgrader.py utility to upgrade old checkpoints to the new format.
Diffstat (limited to 'src/arch/x86')
-rw-r--r-- | src/arch/x86/isa.cc | 5 | ||||
-rw-r--r-- | src/arch/x86/isa.hh | 5 |
2 files changed, 4 insertions, 6 deletions
diff --git a/src/arch/x86/isa.cc b/src/arch/x86/isa.cc index 852ce6bc8..381dc5999 100644 --- a/src/arch/x86/isa.cc +++ b/src/arch/x86/isa.cc @@ -370,14 +370,13 @@ ISA::setMiscReg(int miscReg, MiscReg val, ThreadContext * tc) } void -ISA::serialize(EventManager *em, std::ostream & os) +ISA::serialize(std::ostream & os) { SERIALIZE_ARRAY(regVal, NumMiscRegs); } void -ISA::unserialize(EventManager *em, Checkpoint * cp, - const std::string & section) +ISA::unserialize(Checkpoint * cp, const std::string & section) { UNSERIALIZE_ARRAY(regVal, NumMiscRegs); updateHandyM5Reg(regVal[MISCREG_EFER], diff --git a/src/arch/x86/isa.hh b/src/arch/x86/isa.hh index 39ed68ea5..7c5330ca3 100644 --- a/src/arch/x86/isa.hh +++ b/src/arch/x86/isa.hh @@ -85,9 +85,8 @@ namespace X86ISA return reg; } - void serialize(EventManager *em, std::ostream &os); - void unserialize(EventManager *em, Checkpoint *cp, - const std::string §ion); + void serialize(std::ostream &os); + void unserialize(Checkpoint *cp, const std::string §ion); }; } |