diff options
author | Lisa Hsu <Lisa.Hsu@amd.com> | 2010-06-03 10:34:40 -0700 |
---|---|---|
committer | Lisa Hsu <Lisa.Hsu@amd.com> | 2010-06-03 10:34:40 -0700 |
commit | aeb6e2e3ec920f8590f36bdb33c03c2968ab5dde (patch) | |
tree | 38e13eb6990c8983dd18044c9467ddd577fe24dc /util | |
parent | d2186857b15ccdfe58b6d9e1369946253c28fb02 (diff) | |
download | gem5-aeb6e2e3ec920f8590f36bdb33c03c2968ab5dde.tar.xz |
utils: checkpoint aggregator: some physmem files are too big to read at once,
break it up into reading one page at a time. Also, avoid redoing a aggregating a checkpoint that's
already done.
--HG--
rename : util/checkpoint-aggregator.py => util/checkpoint_aggregator.py
Diffstat (limited to 'util')
-rwxr-xr-x | util/checkpoint_aggregator.py (renamed from util/checkpoint-aggregator.py) | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/util/checkpoint-aggregator.py b/util/checkpoint_aggregator.py index 6e40db01e..acfbca0d0 100755 --- a/util/checkpoint-aggregator.py +++ b/util/checkpoint_aggregator.py @@ -56,12 +56,15 @@ def aggregate(options, args): sys.exit(1) dirname = "-".join([options.prefix, "cpt"]) - print dirname agg_name = "-".join(args) print agg_name fullpath = os.path.join("..", dirname, "cpt." + agg_name + ".10000") if not os.path.isdir(fullpath): os.system("mkdir -p " + fullpath) + elif os.path.isfile(fullpath + "/system.physmem.physmem"): + if os.path.isfile(fullpath + "/m5.cpt"): + print fullpath, " already done" + return myfile = open(fullpath + "/system.physmem.physmem", "wb+") merged_mem = gzip.GzipFile(fileobj=myfile, mode="wb") @@ -69,6 +72,7 @@ def aggregate(options, args): max_curtick = 0 when = 0 for (i, arg) in enumerate(args): + print arg config = myCP() config.readfp(open(cpts[i] + "/m5.cpt")) @@ -105,7 +109,6 @@ def aggregate(options, args): when = config.getint("system.cpu.tickEvent", "_when") else: if i == 0: - print sec merged.add_section(sec) for item in config.items(sec): merged.set(sec, item[0], item[1]) @@ -119,11 +122,14 @@ def aggregate(options, args): ### memory stuff f = open(cpts[i] + "/system.physmem.physmem", "rb") gf = gzip.GzipFile(fileobj=f, mode="rb") - bytes = int(config.get("system", "page_ptr")) << 13 - print "bytes to be read: ", bytes - - bytesRead = gf.read(int(config.get("system", "page_ptr")) << 13) - merged_mem.write(bytesRead) + pages = int(config.get("system", "page_ptr")) + print "pages to be read: ", pages + + x = 0 + while x < pages: + bytesRead = gf.read(1 << 13) + merged_mem.write(bytesRead) + x += 1 gf.close() f.close() |