mirror of
https://git.sr.ht/~kivikakk/niar
synced 2024-12-22 23:42:23 +00:00
build: include timing info in output info.
This commit is contained in:
parent
ef5d43b417
commit
445d0ed0c1
|
@ -92,17 +92,36 @@ def main(np: Project, args):
|
||||||
with logtime(logging.DEBUG, "programming"):
|
with logtime(logging.DEBUG, "programming"):
|
||||||
platform.toolchain_program(products, np.name)
|
platform.toolchain_program(products, np.name)
|
||||||
|
|
||||||
|
yosys_report = np.path.build(subdir, f"{np.name}.rpt")
|
||||||
heading = re.compile(r"^\d+\.\d+\. Printing statistics\.$", flags=re.MULTILINE)
|
heading = re.compile(r"^\d+\.\d+\. Printing statistics\.$", flags=re.MULTILINE)
|
||||||
next_heading = re.compile(r"^\d+\.\d+\. ", flags=re.MULTILINE)
|
next_heading = re.compile(r"^\d+\.\d+\. ", flags=re.MULTILINE)
|
||||||
log_file_between(logging.INFO, np.path.build(subdir, f"{np.name}.rpt"), heading, next_heading)
|
log_file_between(logging.INFO, yosys_report, heading, next_heading)
|
||||||
|
|
||||||
|
nextpnr_report = np.path.build(subdir, f"{np.name}.tim")
|
||||||
logger.info("Device utilisation:")
|
logger.info("Device utilisation:")
|
||||||
heading = re.compile(r"^Info: Device utilisation:$", flags=re.MULTILINE)
|
heading = re.compile(r"^Info: Device utilisation:$", flags=re.MULTILINE)
|
||||||
next_heading = re.compile(r"^Info: Placed ", flags=re.MULTILINE)
|
next_heading = re.compile(r"^Info: Placed ", flags=re.MULTILINE)
|
||||||
log_file_between(
|
log_file_between(logging.INFO, nextpnr_report, heading, next_heading, prefix="Info: ")
|
||||||
logging.INFO, np.path.build(subdir, f"{np.name}.tim"), heading, next_heading, prefix="Info: "
|
|
||||||
)
|
|
||||||
|
|
||||||
|
timing_report = None
|
||||||
|
max_freq = re.compile(r"^Info: Max frequency for clock '", flags=re.MULTILINE)
|
||||||
|
slack_histo = re.compile(r"^Info: Slack histogram:", flags=re.MULTILINE)
|
||||||
|
with open(nextpnr_report, "r") as f:
|
||||||
|
for line in f:
|
||||||
|
if max_freq.match(line):
|
||||||
|
timing_report = [line]
|
||||||
|
elif timing_report is not None:
|
||||||
|
timing_report.append(line)
|
||||||
|
|
||||||
|
if timing_report is None:
|
||||||
|
logger.warn("Couldn't extract timing information from nextpnr log")
|
||||||
|
else:
|
||||||
|
for line in timing_report:
|
||||||
|
if slack_histo.match(line):
|
||||||
|
break
|
||||||
|
line = line.rstrip()
|
||||||
|
line = line.removeprefix("Info: ")
|
||||||
|
logger.log(logging.INFO, line)
|
||||||
|
|
||||||
def construct_top(np: Project, platform: Platform, **kwargs):
|
def construct_top(np: Project, platform: Platform, **kwargs):
|
||||||
sig = inspect.signature(np.top)
|
sig = inspect.signature(np.top)
|
||||||
|
|
Loading…
Reference in a new issue