diff --git a/src/arch/x86/X86TLB.py b/src/arch/x86/X86TLB.py index b652118ce..7f195f233 100644 --- a/src/arch/x86/X86TLB.py +++ b/src/arch/x86/X86TLB.py @@ -54,6 +54,6 @@ class X86TLB(BaseTLB): type = 'X86TLB' cxx_class = 'X86ISA::TLB' cxx_header = 'arch/x86/tlb.hh' - size = Param.Int(64, "TLB size") + size = Param.Unsigned(64, "TLB size") walker = Param.X86PagetableWalker(\ X86PagetableWalker(), "page table walker") diff --git a/src/arch/x86/pagetable.cc b/src/arch/x86/pagetable.cc index 40d5e0984..a9ef18129 100644 --- a/src/arch/x86/pagetable.cc +++ b/src/arch/x86/pagetable.cc @@ -70,25 +70,14 @@ TlbEntry::unserialize(Checkpoint *cp, const std::string §ion) { UNSERIALIZE_SCALAR(paddr); UNSERIALIZE_SCALAR(vaddr); - // - // The logBytes scalar variable replaced the previous size variable. - // The following code maintains backwards compatibility with previous - // checkpoints using the old size variable. - // - if (UNSERIALIZE_OPT_SCALAR(logBytes) == false) { - int size; - UNSERIALIZE_SCALAR(size); - logBytes = log2(size); - } + UNSERIALIZE_SCALAR(logBytes); UNSERIALIZE_SCALAR(writable); UNSERIALIZE_SCALAR(user); UNSERIALIZE_SCALAR(uncacheable); UNSERIALIZE_SCALAR(global); UNSERIALIZE_SCALAR(patBit); UNSERIALIZE_SCALAR(noExec); - if (UNSERIALIZE_OPT_SCALAR(lruSeq) == false) { - lruSeq = 0; - } + UNSERIALIZE_SCALAR(lruSeq); } } diff --git a/src/arch/x86/tlb.cc b/src/arch/x86/tlb.cc index 52cc3e0ee..087cfbadf 100644 --- a/src/arch/x86/tlb.cc +++ b/src/arch/x86/tlb.cc @@ -439,11 +439,42 @@ TLB::getWalker() void TLB::serialize(std::ostream &os) { + // Only store the entries in use. + uint32_t _size = size - freeList.size(); + SERIALIZE_SCALAR(_size); + SERIALIZE_SCALAR(lruSeq); + + uint32_t _count = 0; + + for (uint32_t x = 0; x < size; x++) { + if (tlb[x].trieHandle != NULL) { + os << "\n[" << csprintf("%s.Entry%d", name(), _count) << "]\n"; + tlb[x].serialize(os); + _count++; + } + } } void TLB::unserialize(Checkpoint *cp, const std::string §ion) { + // Do not allow to restore with a smaller tlb. + uint32_t _size; + UNSERIALIZE_SCALAR(_size); + if (_size > size) { + fatal("TLB size less than the one in checkpoint!"); + } + + UNSERIALIZE_SCALAR(lruSeq); + + for (uint32_t x = 0; x < _size; x++) { + TlbEntry *newEntry = freeList.front(); + freeList.pop_front(); + + newEntry->unserialize(cp, csprintf("%s.Entry%d", name(), x)); + newEntry->trieHandle = trie.insert(newEntry->vaddr, + TlbEntryTrie::MaxBits - newEntry->logBytes, newEntry); + } } BaseMasterPort * diff --git a/src/arch/x86/tlb.hh b/src/arch/x86/tlb.hh index 4f0d58d5c..ea2d50ec2 100644 --- a/src/arch/x86/tlb.hh +++ b/src/arch/x86/tlb.hh @@ -95,12 +95,11 @@ namespace X86ISA void demapPage(Addr va, uint64_t asn); protected: - int size; + uint32_t size; TlbEntry * tlb; EntryList freeList; - EntryList entryList; TlbEntryTrie trie; uint64_t lruSeq; diff --git a/src/sim/serialize.hh b/src/sim/serialize.hh index e523e68a5..aedb2d1ae 100644 --- a/src/sim/serialize.hh +++ b/src/sim/serialize.hh @@ -57,7 +57,7 @@ class SimObject; * SimObject shouldn't cause the version number to increase, only changes to * existing objects such as serializing/unserializing more state, changing sizes * of serialized arrays, etc. */ -static const uint64_t gem5CheckpointVersion = 0x0000000000000005; +static const uint64_t gem5CheckpointVersion = 0x0000000000000006; template void paramOut(std::ostream &os, const std::string &name, const T ¶m); diff --git a/util/cpt_upgrader.py b/util/cpt_upgrader.py index e1f56b3ba..623c9b297 100755 --- a/util/cpt_upgrader.py +++ b/util/cpt_upgrader.py @@ -193,7 +193,21 @@ def from_4(cpt): del mr[137] cpt.set(sec, 'miscRegs', ' '.join(str(x) for x in mr)) +# Version 6 of the checkpoint format adds tlb to x86 checkpoints +def from_5(cpt): + if cpt.get('root','isa') == 'x86': + for sec in cpt.sections(): + import re + # Search for all ISA sections + if re.search('.*sys.*\.cpu.*\.dtb$', sec): + cpt.set(sec, '_size', '0') + cpt.set(sec, 'lruSeq', '0') + if re.search('.*sys.*\.cpu.*\.itb$', sec): + cpt.set(sec, '_size', '0') + cpt.set(sec, 'lruSeq', '0') + else: + print "ISA is not x86" migrations = [] migrations.append(from_0) @@ -201,6 +215,7 @@ migrations.append(from_1) migrations.append(from_2) migrations.append(from_3) migrations.append(from_4) +migrations.append(from_5) verbose_print = False