xref: /aosp_15_r20/external/llvm/examples/Kaleidoscope/MCJIT/complete/split-lib.py (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker#!/usr/bin/env python
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Workerclass TimingScriptGenerator:
4*9880d681SAndroid Build Coastguard Worker    """Used to generate a bash script which will invoke the toy and time it"""
5*9880d681SAndroid Build Coastguard Worker    def __init__(self, scriptname, outputname):
6*9880d681SAndroid Build Coastguard Worker        self.shfile = open(scriptname, 'w')
7*9880d681SAndroid Build Coastguard Worker        self.timeFile = outputname
8*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"\" > %s\n" % self.timeFile)
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker    def writeTimingCall(self, irname, callname):
11*9880d681SAndroid Build Coastguard Worker        """Echo some comments and invoke both versions of toy"""
12*9880d681SAndroid Build Coastguard Worker        rootname = irname
13*9880d681SAndroid Build Coastguard Worker        if '.' in irname:
14*9880d681SAndroid Build Coastguard Worker            rootname = irname[:irname.rfind('.')]
15*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"%s: Calls %s\" >> %s\n" % (callname, irname, self.timeFile))
16*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"\" >> %s\n" % self.timeFile)
17*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"With MCJIT\" >> %s\n" % self.timeFile)
18*9880d681SAndroid Build Coastguard Worker        self.shfile.write("/usr/bin/time -f \"Command %C\\n\\tuser time: %U s\\n\\tsytem time: %S s\\n\\tmax set: %M kb\"")
19*9880d681SAndroid Build Coastguard Worker        self.shfile.write(" -o %s -a " % self.timeFile)
20*9880d681SAndroid Build Coastguard Worker        self.shfile.write("./toy -suppress-prompts -use-mcjit=true -enable-lazy-compilation=true -use-object-cache -input-IR=%s < %s > %s-mcjit.out 2> %s-mcjit.err\n" % (irname, callname, rootname, rootname))
21*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"\" >> %s\n" % self.timeFile)
22*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"With MCJIT again\" >> %s\n" % self.timeFile)
23*9880d681SAndroid Build Coastguard Worker        self.shfile.write("/usr/bin/time -f \"Command %C\\n\\tuser time: %U s\\n\\tsytem time: %S s\\n\\tmax set: %M kb\"")
24*9880d681SAndroid Build Coastguard Worker        self.shfile.write(" -o %s -a " % self.timeFile)
25*9880d681SAndroid Build Coastguard Worker        self.shfile.write("./toy -suppress-prompts -use-mcjit=true -enable-lazy-compilation=true -use-object-cache -input-IR=%s < %s > %s-mcjit.out 2> %s-mcjit.err\n" % (irname, callname, rootname, rootname))
26*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"\" >> %s\n" % self.timeFile)
27*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"With JIT\" >> %s\n" % self.timeFile)
28*9880d681SAndroid Build Coastguard Worker        self.shfile.write("/usr/bin/time -f \"Command %C\\n\\tuser time: %U s\\n\\tsytem time: %S s\\n\\tmax set: %M kb\"")
29*9880d681SAndroid Build Coastguard Worker        self.shfile.write(" -o %s -a " % self.timeFile)
30*9880d681SAndroid Build Coastguard Worker        self.shfile.write("./toy -suppress-prompts -use-mcjit=false -input-IR=%s < %s > %s-mcjit.out 2> %s-mcjit.err\n" % (irname, callname, rootname, rootname))
31*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"\" >> %s\n" % self.timeFile)
32*9880d681SAndroid Build Coastguard Worker        self.shfile.write("echo \"\" >> %s\n" % self.timeFile)
33*9880d681SAndroid Build Coastguard Worker
34*9880d681SAndroid Build Coastguard Workerclass LibScriptGenerator:
35*9880d681SAndroid Build Coastguard Worker    """Used to generate a bash script which will invoke the toy and time it"""
36*9880d681SAndroid Build Coastguard Worker    def __init__(self, filename):
37*9880d681SAndroid Build Coastguard Worker        self.shfile = open(filename, 'w')
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Worker    def writeLibGenCall(self, libname, irname):
40*9880d681SAndroid Build Coastguard Worker        self.shfile.write("./toy -suppress-prompts -use-mcjit=false -dump-modules < %s 2> %s\n" % (libname, irname))
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Workerdef splitScript(inputname, libGenScript, timingScript):
43*9880d681SAndroid Build Coastguard Worker  rootname = inputname[:-2]
44*9880d681SAndroid Build Coastguard Worker  libname = rootname + "-lib.k"
45*9880d681SAndroid Build Coastguard Worker  irname = rootname + "-lib.ir"
46*9880d681SAndroid Build Coastguard Worker  callname = rootname + "-call.k"
47*9880d681SAndroid Build Coastguard Worker  infile = open(inputname, "r")
48*9880d681SAndroid Build Coastguard Worker  libfile = open(libname, "w")
49*9880d681SAndroid Build Coastguard Worker  callfile = open(callname, "w")
50*9880d681SAndroid Build Coastguard Worker  print "Splitting %s into %s and %s" % (inputname, callname, libname)
51*9880d681SAndroid Build Coastguard Worker  for line in infile:
52*9880d681SAndroid Build Coastguard Worker    if not line.startswith("#"):
53*9880d681SAndroid Build Coastguard Worker      if line.startswith("print"):
54*9880d681SAndroid Build Coastguard Worker        callfile.write(line)
55*9880d681SAndroid Build Coastguard Worker      else:
56*9880d681SAndroid Build Coastguard Worker        libfile.write(line)
57*9880d681SAndroid Build Coastguard Worker  libGenScript.writeLibGenCall(libname, irname)
58*9880d681SAndroid Build Coastguard Worker  timingScript.writeTimingCall(irname, callname)
59*9880d681SAndroid Build Coastguard Worker
60*9880d681SAndroid Build Coastguard Worker# Execution begins here
61*9880d681SAndroid Build Coastguard WorkerlibGenScript = LibScriptGenerator("make-libs.sh")
62*9880d681SAndroid Build Coastguard WorkertimingScript = TimingScriptGenerator("time-lib.sh", "lib-timing.txt")
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Workerscript_list = ["test-5000-3-50-50.k", "test-5000-10-100-10.k", "test-5000-10-5-10.k", "test-5000-10-1-0.k",
65*9880d681SAndroid Build Coastguard Worker               "test-1000-3-10-50.k", "test-1000-10-100-10.k", "test-1000-10-5-10.k", "test-1000-10-1-0.k",
66*9880d681SAndroid Build Coastguard Worker               "test-200-3-2-50.k", "test-200-10-40-10.k", "test-200-10-2-10.k", "test-200-10-1-0.k"]
67*9880d681SAndroid Build Coastguard Worker
68*9880d681SAndroid Build Coastguard Workerfor script in script_list:
69*9880d681SAndroid Build Coastguard Worker  splitScript(script, libGenScript, timingScript)
70*9880d681SAndroid Build Coastguard Workerprint "All done!"
71