verilator/test_regress/t/t_cover_line_cc.py
2024-09-08 13:00:03 -04:00

52 lines
1.8 KiB
Python
Executable File

#!/usr/bin/env python3
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
#
# Copyright 2024 by Wilson Snyder. This program is free software; you
# can redistribute it and/or modify it under the terms of either the GNU
# Lesser General Public License Version 3 or the Perl Artistic License
# Version 2.0.
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
import vltest_bootstrap
test.scenarios('simulator')
test.top_filename = "t/t_cover_line.v"
test.golden_filename = "t/t_cover_line.out"
test.compile(verilator_flags2=['--cc --coverage-line +define+ATTRIBUTE'])
test.execute()
test.run(cmd=[os.environ["VERILATOR_ROOT"] + "/bin/verilator_coverage",
"--annotate-points",
"--annotate", test.obj_dir + "/annotated",
test.obj_dir + "/coverage.dat"],
verilator_run=True) # yapf:disable
test.files_identical(test.obj_dir + "/annotated/t_cover_line.v", test.golden_filename)
# Also try lcov
test.run(cmd=[os.environ["VERILATOR_ROOT"] + "/bin/verilator_coverage",
"--write-info", test.obj_dir + "/coverage.info",
test.obj_dir + "/coverage.dat"],
verilator_run=True) # yapf:disable
test.files_identical(test.obj_dir + "/coverage.info", "t/" + test.name + ".info.out")
# If installed
nout = test.run_capture("lcov --version", check=False)
version_match = re.search(r'version ([0-9.]+)', nout, re.IGNORECASE)
if not version_match:
test.skip("lcov or genhtml not installed")
if float(version_match.group(1)) < 1.14:
test.skip("lcov or genhtml too old (version " + version_match.group(1) +
", need version >= 1.14")
test.run(cmd=[
"genhtml", test.obj_dir + "/coverage.info", "--branch-coverage", "--output-directory " +
test.obj_dir + "/html"
])
test.passes()