2023-01-01 15:18:39 +00:00
|
|
|
.. Copyright 2003-2023 by Wilson Snyder.
|
2021-04-11 22:55:06 +00:00
|
|
|
.. SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
|
|
|
|
|
|
|
verilator_coverage
|
|
|
|
==================
|
|
|
|
|
|
|
|
Verilator_coverage processes Verilated model-generated coverage reports.
|
|
|
|
|
2023-02-09 01:15:11 +00:00
|
|
|
With `--annotate`, it reads the specified coverage data file and generates
|
|
|
|
annotated source code with coverage metrics annotated. With
|
|
|
|
`--annotate-points` the coverage points corresponding to each line are also
|
|
|
|
shown.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
Additional Verilog-XL-style standard arguments specify the search paths
|
2022-12-11 01:09:47 +00:00
|
|
|
necessary to find the source code on which the coverage analysis was
|
|
|
|
performed.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
To filter those items to be included in coverage, you may read
|
|
|
|
logs/coverage.dat into an editor and do a M-x keep-lines to include only
|
|
|
|
those statistics of interest and save to a new .dat file.
|
|
|
|
|
|
|
|
For Verilog conditions that should never occur, either add a $stop
|
|
|
|
statement to the appropriate statement block, or see
|
|
|
|
:option:`/*verilator&32;coverage_off*/`. This will remove the coverage
|
|
|
|
points after the model is re-Verilated.
|
|
|
|
|
2022-12-11 01:09:47 +00:00
|
|
|
For an overview of the use of verilator_coverage, see :ref:`Coverage Analysis`.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
verilator_coverage Example Usage
|
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
..
|
|
|
|
|
|
|
|
verilator_coverage --help
|
|
|
|
verilator_coverage --version
|
|
|
|
|
|
|
|
verilator_coverage --annotate <obj>
|
|
|
|
|
|
|
|
verilator_coverage -write merged.dat -read <datafiles>...
|
|
|
|
|
|
|
|
verilator_coverage -write-info merged.info -read <datafiles>...
|
|
|
|
|
|
|
|
|
|
|
|
verilator_coverage Arguments
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
.. program:: verilator_coverage
|
|
|
|
|
|
|
|
.. option:: <filename>
|
|
|
|
|
|
|
|
Specifies the input coverage data file. Multiple filenames may be provided
|
2022-12-11 01:09:47 +00:00
|
|
|
to read multiple inputs. If no data file is specified, by default,
|
2021-04-11 22:55:06 +00:00
|
|
|
"coverage.dat" will be read.
|
|
|
|
|
|
|
|
.. option:: --annotate <output_directory>
|
|
|
|
|
2022-12-11 01:09:47 +00:00
|
|
|
Specifies the directory name to which source files with annotated coverage
|
|
|
|
data should be written.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
2023-02-09 01:15:11 +00:00
|
|
|
Converting from the Verilator coverage data format to the info format is
|
|
|
|
lossy; the info will have all forms of coverage merged line coverage, and
|
|
|
|
if there are multiple coverage points on a single line they will merge.
|
|
|
|
The minimum coverage across all merged points will be used to report
|
|
|
|
coverage of the line.
|
|
|
|
|
|
|
|
The first character of the line shows a summary of the coverage; this
|
|
|
|
allows use of grep to filter the report. `%` indicates at least one point
|
|
|
|
on the line was below the coverage limit. `+` indicates an
|
|
|
|
:option:`--annotate-points` point was at or above the limit, and `-` that
|
|
|
|
the point was below the limit.
|
|
|
|
|
2021-04-11 22:55:06 +00:00
|
|
|
.. option:: --annotate-all
|
|
|
|
|
|
|
|
Specifies all files should be shown. By default, only those source files
|
2022-12-11 01:09:47 +00:00
|
|
|
with low coverage are written to the output directory.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
.. option:: --annotate-min <count>
|
|
|
|
|
|
|
|
Specifies if the coverage point does not include the count number of
|
|
|
|
coverage hits, then the coverage point will be considered above the
|
2022-02-27 10:01:44 +00:00
|
|
|
threshold, and the coverage report will put a "%" to indicate the coverage
|
2022-12-11 01:09:47 +00:00
|
|
|
is insufficient. Defaults to 10.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
2023-02-09 01:15:11 +00:00
|
|
|
.. option:: --annotate-points
|
|
|
|
|
|
|
|
Specifies all coverage points should be shown after each line of text. By
|
|
|
|
default, only source lines are shown.
|
|
|
|
|
|
|
|
with low coverage are written to the output directory.
|
|
|
|
|
2021-04-11 22:55:06 +00:00
|
|
|
.. option:: --help
|
|
|
|
|
|
|
|
Displays a help summary, the program version, and exits.
|
|
|
|
|
|
|
|
.. option:: --rank
|
|
|
|
|
|
|
|
Prints an experimental report listing the relative importance of each test
|
|
|
|
in covering all of the coverage points. The report shows "Covered" which
|
2022-12-11 01:09:47 +00:00
|
|
|
indicates the number of points the test covers; a test is considered to
|
2021-04-11 22:55:06 +00:00
|
|
|
cover a point if it has a bucket count of at least 1. The "rank" column has
|
2022-12-11 01:09:47 +00:00
|
|
|
a higher number t indicate the test is more critical, and rank 0 means the
|
2021-04-11 22:55:06 +00:00
|
|
|
test does not need to be run to cover the points. "RankPts" indicates the
|
|
|
|
number of coverage points this test will contribute to overall coverage if
|
2022-12-11 01:09:47 +00:00
|
|
|
all tests are run in the order of highest to the lowest rank.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
.. option:: --unlink
|
|
|
|
|
|
|
|
With :option:`--write`, unlink all input files after the output
|
|
|
|
has been successfully created.
|
|
|
|
|
|
|
|
.. option:: --version
|
|
|
|
|
|
|
|
Displays program version and exits.
|
|
|
|
|
|
|
|
.. option:: --write <filename>
|
|
|
|
|
|
|
|
Specifies the aggregate coverage results, summed across all the files,
|
|
|
|
should be written to the given filename in verilator_coverage data format.
|
2022-12-11 01:09:47 +00:00
|
|
|
This is useful in scripts to combine many coverage data files (likely
|
|
|
|
generated from random test runs) into one master coverage file.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
.. option:: --write-info <filename.info>
|
|
|
|
|
|
|
|
Specifies the aggregate coverage results, summed across all the files,
|
|
|
|
should be written to the given filename in :command:`lcov` .info format.
|
|
|
|
This may be used to feed into :command:`lcov` to aggregate or generate
|
|
|
|
reports.
|
|
|
|
|
2022-12-11 01:09:47 +00:00
|
|
|
Converting from the Verilator coverage data format to the info format is
|
|
|
|
lossy; the info will have all forms of coverage merged line coverage, and
|
|
|
|
if there are multiple coverage points on a single line they will merge.
|
|
|
|
The minimum coverage across all merged points will be used to report
|
|
|
|
coverage of the line.
|