cvw/synthDC/scripts/wrapperGen.py

73 lines
1.5 KiB
Python
Raw Normal View History

#!/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
import glob
2023-08-27 21:00:10 +00:00
import os
#create argument parser
parser = argparse.ArgumentParser()
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()
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()
#print(buf)