diff -r cba0f26038b4 -r 9141d87c7f71 src/sim/serialize.hh --- a/src/sim/serialize.hh Mon Jun 01 19:44:19 2015 +0100 +++ b/src/sim/serialize.hh Mon Jun 01 18:05:11 2015 -0500 @@ -59,7 +59,7 @@ * 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 = 0x000000000000000d; +static const uint64_t gem5CheckpointVersion = 0x000000000000000e; template void paramOut(std::ostream &os, const std::string &name, const T ¶m); diff -r cba0f26038b4 -r 9141d87c7f71 util/cpt_upgrader.py --- a/util/cpt_upgrader.py Mon Jun 01 19:44:19 2015 +0100 +++ b/util/cpt_upgrader.py Mon Jun 01 18:05:11 2015 -0500 @@ -602,6 +602,18 @@ cpt.set(sec, 'intRegs', ' '.join(intRegs)) cpt.set(sec, 'ccRegs', ' '.join(ccRegs)) +# Checkpoint version E adds the ARM CONTEXTIDR_EL2 miscreg. +def from_D(cpt): + if cpt.get('root','isa') == 'arm': + for sec in cpt.sections(): + import re + # Search for all ISA sections + if re.search('.*sys.*\.cpu.*\.isa$', sec): + miscRegs = cpt.get(sec, 'miscRegs').split() + # CONTEXTIDR_EL2 defaults to 0b11111100000000000001 + miscRegs[599:599] = [0xFC001] + cpt.set(sec, 'miscRegs', ' '.join(str(x) for x in miscRegs)) + migrations = [] migrations.append(from_0) migrations.append(from_1) @@ -616,6 +628,7 @@ migrations.append(from_A) migrations.append(from_B) migrations.append(from_C) +migrations.append(from_D) verbose_print = False