summaryrefslogtreecommitdiff
path: root/util/checkpoint-aggregator.py
blob: f3c5eb5beb140503151eb912db1d96b87c972765 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
#! /usr/bin/env python2.6

from ConfigParser import ConfigParser
import gzip

import sys, re, optparse, os

class myCP(ConfigParser):
    def __init__(self):
        ConfigParser.__init__(self)

    def optionxform(self, optionstr):
        return optionstr

def aggregate(options, args):
    merged = myCP()
    page_ptr = 0

    allfiles = os.listdir(os.getcwd())
    cpts = []
    for arg in args:
        found = False
        for f in allfiles:
            if re.compile("cpt." + arg + ".\d+").search(f):
                found = True
                cpts.append(f)
                break
        if not found:
            print "missing checkpoint: ", arg
            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)

    myfile = open(fullpath + "/system.physmem.physmem", "wb+")
    merged_mem = gzip.GzipFile(fileobj=myfile, mode="wb")

    max_curtick = 0
    when = 0
    for (i, arg) in enumerate(args):
        config = myCP()
        config.readfp(open(cpts[i] + "/m5.cpt"))

        for sec in config.sections():
            if re.compile("cpu").search(sec):
                newsec = re.sub("cpu", "cpu" + str(i), sec)
                merged.add_section(newsec)

                items = config.items(sec)
                for item in items:
                    if item[0] == "ppn":
                        if config.getint(sec, "tag") != 0:
                            merged.set(newsec, item[0], int(item[1]) + page_ptr)
                            continue
                    elif item[0] == "asn":
                        tmp = re.compile("(.*).Entry(\d+)").search(sec).groups()
                        if config.has_option(tmp[0], "nlu"):
                            size = config.getint(tmp[0], "nlu")
                            if int(tmp[1]) < size:
                                merged.set(newsec, item[0], i)
                                continue
                        else:
                            merged.set(newsec, item[0], i)
                            continue
                    merged.set(newsec, item[0], item[1])
            elif sec == "system":
                pass
            elif sec == "Globals":
                tick = config.getint(sec, "curTick")
                if tick > max_curtick:
                    max_curtick = tick
                    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])
                        if item[0] == "curtick":
                            merged.optionxform(str("curTick"))
                        elif item[0] == "numevents":
                            merged.optionxform(str("numEvents"))

        page_ptr = page_ptr + int(config.get("system", "page_ptr"))

        ### 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)

        gf.close()
        f.close()

    merged.add_section("system")
    merged.set("system", "page_ptr", page_ptr)
    print "WARNING: "
    print "Make sure the simulation using this checkpoint has at least "
    if page_ptr > (1<<20):
        print "8G ",
    elif page_ptr > (1<<19):
        print "4G ",
    elif page_ptr > (1<<18):
        print "2G ",
    elif page_ptr > (1<<17):
        print "1G ",
    elif page_ptr > (1<<16):
        print "512KB ",
    else:
        print "this is a small sim, you're probably fine",
    print "of memory."

    merged.add_section("Globals")
    merged.set("Globals", "curTick", max_curtick)

    for i in xrange(len(args)):
        merged.set("system.cpu" + str(i) + ".tickEvent", "_when", when)

    merged.write(file(fullpath + "/m5.cpt", "wb"))
    merged_mem.close()
    myfile.close()

if __name__ == "__main__":

    parser = optparse.OptionParser()
    parser.add_option("--prefix", type="string", default="agg")

    (options, args) = parser.parse_args()

    aggregate(options, args)