2023-08-28 16:02:56 +00:00
|
|
|
#!/usr/bin/python3
|
2023-08-27 21:00:10 +00:00
|
|
|
"""
|
|
|
|
wrapperGen.py
|
|
|
|
|
|
|
|
kekim@hmc.edu
|
|
|
|
|
|
|
|
script that generates top-level wrappers for verilog modules to synthesize
|
|
|
|
"""
|
|
|
|
|
|
|
|
import argparse
|
2023-08-28 16:02:56 +00:00
|
|
|
import glob
|
2023-08-27 21:00:10 +00:00
|
|
|
import os
|
|
|
|
|
|
|
|
#create argument parser
|
|
|
|
parser = argparse.ArgumentParser()
|
|
|
|
|
2023-08-28 16:02:56 +00:00
|
|
|
parser.add_argument("DESIGN")
|
2023-10-31 03:57:35 +00:00
|
|
|
parser.add_argument("HDLPATH");
|
2023-08-27 21:00:10 +00:00
|
|
|
|
|
|
|
args=parser.parse_args()
|
|
|
|
|
2023-08-28 16:02:56 +00:00
|
|
|
fin_path = glob.glob(f"{os.getenv('WALLY')}/src/**/{args.DESIGN}.sv",recursive=True)[0]
|
|
|
|
|
|
|
|
fin = open(fin_path, "r")
|
2023-08-27 21:00:10 +00:00
|
|
|
|
|
|
|
lines = fin.readlines()
|
|
|
|
|
|
|
|
# keeps track of what line number the module header begins
|
|
|
|
lineModuleStart = 0
|
|
|
|
|
|
|
|
# keeps track of what line number the module header ends
|
|
|
|
lineModuleEnd = 0
|
|
|
|
|
|
|
|
# keeps track of module name
|
|
|
|
moduleName = ""
|
|
|
|
|
|
|
|
# string that will keep track of the running module header
|
2023-08-27 21:13:29 +00:00
|
|
|
buf = "import cvw::*;\n`include \"config.vh\"\n`include \"parameter-defs.vh\"\n"
|
2023-08-27 21:00:10 +00:00
|
|
|
|
|
|
|
# are we writing into the buffer
|
|
|
|
writeBuf=False
|
|
|
|
|
|
|
|
index=0
|
|
|
|
|
|
|
|
# string copy logic
|
|
|
|
for l in lines:
|
2023-10-18 21:29:46 +00:00
|
|
|
if l.lstrip().find("module") == 0:
|
2023-08-27 21:00:10 +00:00
|
|
|
lineModuleStart = index
|
|
|
|
moduleName = l.split()[1]
|
|
|
|
writeBuf = True
|
|
|
|
buf += f"module {moduleName}wrapper (\n"
|
|
|
|
continue
|
|
|
|
if (writeBuf):
|
|
|
|
buf += l
|
2023-10-18 21:29:46 +00:00
|
|
|
if l.lstrip().find (");") == 0:
|
2023-08-27 21:00:10 +00:00
|
|
|
lineModuleEnd = index
|
|
|
|
break
|
|
|
|
index+=1
|
|
|
|
|
|
|
|
# post-processing buffer: add DUT and endmodule lines
|
|
|
|
buf += f"\t{moduleName} #(P) dut(.*);\nendmodule"
|
|
|
|
|
2023-08-27 21:13:29 +00:00
|
|
|
# path to wrapper
|
2023-10-31 03:57:35 +00:00
|
|
|
wrapperPath = f"{args.HDLPATH}/{moduleName}wrapper.sv"
|
2023-08-27 21:13:29 +00:00
|
|
|
|
|
|
|
fout = open(wrapperPath, "w")
|
|
|
|
|
|
|
|
fout.write(buf)
|
|
|
|
|
|
|
|
fin.close()
|
|
|
|
fout.close()
|
|
|
|
|
2023-10-19 17:44:03 +00:00
|
|
|
#print(buf)
|