Skip to content

Commit

Permalink
Generate HTML Cov report in DSim
Browse files Browse the repository at this point in the history
Signed-off-by: Maciej Dudek <[email protected]>
  • Loading branch information
mtdudek authored and mkurc-ant committed Nov 6, 2024
1 parent 6348a1c commit 5473f00
Showing 1 changed file with 33 additions and 13 deletions.
46 changes: 33 additions & 13 deletions dsim/defs.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -70,9 +70,22 @@ def _dsim_run(ctx):
if ctx.attr.code_coverage_type in ["toggle", "all"]:
command += " +acc+b "
command += " -code-cov " + ctx.attr.code_coverage_type
if ctx.attr.code_coverage_scope != "":
scope_file = ctx.actions.declare_file("{}.scope".format(ctx.label.name))
ctx.actions.write(
output = scope_file,
content = "path {} +".format(ctx.attr.code_coverage_scope),
)
command += " -code-cov-scope-specs {}".format(scope_file.path)
inputs.append(scope_file)
outputs.append(dsim_cov)
generated_files.append(dsim_cov)

if ctx.attr.code_coverage_report:
dsim_report = ctx.actions.declare_directory("{}_report".format(ctx.label.name))
command += " && dcreport -out_dir {} {}".format(dsim_report.path, dsim_cov.path)
outputs.append(dsim_report)
generated_files.append(dsim_report)

ctx.actions.run_shell(
outputs = outputs,
Expand All @@ -91,14 +104,17 @@ def _dsim_run(ctx):
dsim_run = rule(
implementation = _dsim_run,
attrs = {
"module": attr.label(
doc = "The top level build.",
providers = [VerilogInfo],
mandatory = True,
"code_coverage_report": attr.bool(
doc = "Run dcreport after dsim run",
default = False,
),
"module_top": attr.string(
doc = "The name of the top level verilog module.",
mandatory = True,
"code_coverage_scope": attr.string(
doc = "Select coverage scope using hierarchical path",
default = "",
),
"code_coverage_type": attr.string(
doc = "Select coverage type: block, expression, toggle or all",
default = "all",
),
"dsim_env": attr.label(
doc = "A shell script to source the DSIM environment and " +
Expand All @@ -110,17 +126,21 @@ dsim_run = rule(
doc = "Gather simulation coverage",
default = False,
),
"code_coverage_type": attr.string(
doc = "Select coverage type: block, expression, toggle or all",
default = "all",
"module": attr.label(
doc = "The top level build.",
providers = [VerilogInfo],
mandatory = True,
),
"outs": attr.output_list(
doc = "List of simulation products",
"module_top": attr.string(
doc = "The name of the top level verilog module.",
mandatory = True,
),
"opts": attr.string_list(
doc = "Additional command line options to pass to DSIM",
default = [],
),
"outs": attr.output_list(
doc = "List of simulation products",
),
},
)

0 comments on commit 5473f00

Please sign in to comment.