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