Checkpoints: Change Simulation.py to not go crazy if the simulation ends before the number of checkpoints requested are created.

--HG--
extra : convert_revision : 865179134a219b34dbbba698e1fa0da7c452e074
This commit is contained in:
Ali Saidi 2007-10-25 22:20:00 -04:00
parent fddfa71658
commit 51345d7324

View file

@ -192,7 +192,7 @@ def run(options, root, testsys, cpu_class):
sim_ticks = when sim_ticks = when
exit_cause = "maximum %d checkpoints dropped" % max_checkpoints exit_cause = "maximum %d checkpoints dropped" % max_checkpoints
while num_checkpoints < max_checkpoints and \ while num_checkpoints < max_checkpoints and \
exit_event.getCause() != "user interrupt received": exit_event.getCause() == "simulate() limit reached":
if (sim_ticks + period) > maxtick: if (sim_ticks + period) > maxtick:
exit_event = m5.simulate(maxtick - sim_ticks) exit_event = m5.simulate(maxtick - sim_ticks)
exit_cause = exit_event.getCause() exit_cause = exit_event.getCause()
@ -206,7 +206,7 @@ def run(options, root, testsys, cpu_class):
m5.checkpoint(root, joinpath(cptdir, "cpt.%d")) m5.checkpoint(root, joinpath(cptdir, "cpt.%d"))
num_checkpoints += 1 num_checkpoints += 1
if exit_event.getCause() == "user interrupt received": if exit_event.getCause() != "simulate() limit reached":
exit_cause = exit_event.getCause(); exit_cause = exit_event.getCause();