2018-07-07 17:04:56 +08:00
|
|
|
import sys, os, tokenize
|
2015-08-31 01:23:16 +08:00
|
|
|
from pythonparser import diagnostic
|
2016-07-08 18:47:36 +08:00
|
|
|
from ...language.environment import ProcessArgumentManager
|
|
|
|
from ...master.databases import DeviceDB, DatasetDB
|
|
|
|
from ...master.worker_db import DeviceManager, DatasetManager
|
2015-11-26 10:23:59 +08:00
|
|
|
from ..module import Module
|
2015-08-31 01:23:16 +08:00
|
|
|
from ..embedding import Stitcher
|
2021-11-08 13:00:26 +08:00
|
|
|
from ..targets import RV32GTarget
|
2015-08-31 01:23:16 +08:00
|
|
|
from . import benchmark
|
|
|
|
|
2017-05-18 23:14:20 +08:00
|
|
|
|
2015-08-31 01:23:16 +08:00
|
|
|
def main():
|
|
|
|
if not len(sys.argv) == 2:
|
|
|
|
print("Expected exactly one module filename", file=sys.stderr)
|
|
|
|
exit(1)
|
|
|
|
|
|
|
|
def process_diagnostic(diag):
|
|
|
|
print("\n".join(diag.render()), file=sys.stderr)
|
|
|
|
if diag.level in ("fatal", "error"):
|
|
|
|
exit(1)
|
|
|
|
|
|
|
|
engine = diagnostic.Engine()
|
|
|
|
engine.process = process_diagnostic
|
|
|
|
|
2018-07-07 17:04:56 +08:00
|
|
|
with tokenize.open(sys.argv[1]) as f:
|
2015-08-31 01:23:16 +08:00
|
|
|
testcase_code = compile(f.read(), f.name, "exec")
|
|
|
|
testcase_vars = {'__name__': 'testbench'}
|
|
|
|
exec(testcase_code, testcase_vars)
|
|
|
|
|
2017-05-18 23:14:20 +08:00
|
|
|
device_db_path = os.path.join(os.path.dirname(sys.argv[1]), "device_db.py")
|
2016-07-08 18:47:36 +08:00
|
|
|
device_mgr = DeviceManager(DeviceDB(device_db_path))
|
|
|
|
|
|
|
|
dataset_db_path = os.path.join(os.path.dirname(sys.argv[1]), "dataset_db.pyon")
|
|
|
|
dataset_mgr = DatasetManager(DatasetDB(dataset_db_path))
|
|
|
|
|
|
|
|
argument_mgr = ProcessArgumentManager({})
|
2015-08-31 01:23:16 +08:00
|
|
|
|
|
|
|
def embed():
|
2016-07-08 18:47:36 +08:00
|
|
|
experiment = testcase_vars["Benchmark"]((device_mgr, dataset_mgr, argument_mgr))
|
2015-08-31 01:23:16 +08:00
|
|
|
|
2016-07-08 18:47:36 +08:00
|
|
|
stitcher = Stitcher(core=experiment.core, dmgr=device_mgr)
|
|
|
|
stitcher.stitch_call(experiment.run, (), {})
|
2015-08-31 01:23:16 +08:00
|
|
|
stitcher.finalize()
|
|
|
|
return stitcher
|
|
|
|
|
|
|
|
stitcher = embed()
|
|
|
|
module = Module(stitcher)
|
2021-11-08 13:00:26 +08:00
|
|
|
target = RV32GTarget()
|
2016-07-12 01:55:18 +08:00
|
|
|
llvm_ir = target.compile(module)
|
|
|
|
elf_obj = target.assemble(llvm_ir)
|
2016-10-17 00:24:25 +08:00
|
|
|
elf_shlib = target.link([elf_obj])
|
2015-08-31 01:23:16 +08:00
|
|
|
|
|
|
|
benchmark(lambda: embed(),
|
|
|
|
"ARTIQ embedding")
|
|
|
|
|
|
|
|
benchmark(lambda: Module(stitcher),
|
|
|
|
"ARTIQ transforms and validators")
|
|
|
|
|
2016-07-12 01:55:18 +08:00
|
|
|
benchmark(lambda: target.compile(module),
|
|
|
|
"LLVM optimizations")
|
|
|
|
|
|
|
|
benchmark(lambda: target.assemble(llvm_ir),
|
|
|
|
"LLVM machine code emission")
|
|
|
|
|
2016-10-17 00:24:25 +08:00
|
|
|
benchmark(lambda: target.link([elf_obj]),
|
2016-07-12 01:55:18 +08:00
|
|
|
"Linking")
|
|
|
|
|
|
|
|
benchmark(lambda: target.strip(elf_shlib),
|
|
|
|
"Stripping debug information")
|
2015-08-31 01:23:16 +08:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|