

# **Specification Coverage - Quick Reference**

**UVVM Support VIP** 

The Specification Coverage feature (aka Requirements Coverage) is an efficient method for verifying the requirement specification.

Note: The first page of this QuickRef is just for syntax reference. For an introduction to the Specification Coverage concept, please see page 2.

### 1 UVVM VHDL Methods - see Table 2 for details.

| Procedure            | Parameters                                                                          | Examples                                                                      |
|----------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| initialize_req_cov() | testcase (string), req_list_file (string), partial_cov_file (string)                | initialize_req_cov("tc_base_func", "uart_req_list.csv", "base_func_cov.csv"); |
|                      | testcase (string), partial_cov_file (string) (→ Note: No spec coverage)             | initialize_req_cov("tc_base_func", "base_func_cov.csv");                      |
| tick_off_req_cov()   | requirement (string) [,testcase (string)] [,FAIL (t_test_status) [, msg [, scope]]] | tick_off_req_cov("UART_REQ_4");                                               |
| finalize_req_cov()   | VOID                                                                                | finalize_req_cov(VOID);                                                       |

# 2 Script Usage - run\_spec\_cov.py

Call the run\_spec\_cov.py from a terminal, using e.g.: python run\_spec\_cov.py <see Table 6 for script arguments>

# 3 Formats of Input and Intermediate Files

| File    | Requirement list file ('req_list'), CSV           | Partial coverage file ('part_cov'), CSV                   |
|---------|---------------------------------------------------|-----------------------------------------------------------|
| Info    | Input to testcase and run_spec_cov.py             | Output from testcase, and input to run_spec_cov.py        |
| Layout  | "Requirement label", "Description" [, "Testcase"] | "Requirement", "Testcase", PASS   FAIL                    |
|         |                                                   | Preceded by header and succeeded by footer as shown below |
| Example | FPGA_REQ_1, Baudrate 9k6, TC_UART_1               | NOTE: <note></note>                                       |
|         | FPGA_REQ_2, Baudrate 19k2, TC_UART_1              | TESTCASE_NAME: <name></name>                              |
|         | etc.                                              | DELIMITER: <single character="" delimiter=""></single>    |
|         |                                                   | FPGA_REQ_1, TC_UART_1, PASS                               |
|         |                                                   | FPGA_REQ_2, TC_UART_2, FAIL                               |
|         |                                                   | etc.                                                      |
|         |                                                   | SUMMARY, <testcase-name>, PASS FAIL</testcase-name>       |

| File    | Optional: Requirement map file ('req_map'), CSV                       | Optional: Partial coverage list file ('part_cov_list'), TXT | Optional: Script config file, TXT          |
|---------|-----------------------------------------------------------------------|-------------------------------------------------------------|--------------------------------------------|
| Info    | Optional input to run_spec_cov.py                                     | Optional input to run_spec_cov.py                           | Optional input to run_spec_cov.py          |
| Layout  | Alt a) "Requirement label", "mapped req label" [, "mapped req label"] | "path to a Partial coverage file"                           | argument value OR -a value                 |
|         | Alt b) "Requirement label", "sub-req label", "sub-req label",         | "path to another Partial coverage file"                     | etc.                                       |
|         |                                                                       | etc.                                                        |                                            |
| Example | FPGA_REQ_1, FPGA_REQ_1.a, FPGA_REQ_1.b                                | pc_base_func.csv                                            | requirement_list path/requirement_list.csv |
|         |                                                                       | /my_sim_dir/pc_reset.csv                                    | -p partial coverage files.txt              |
|         |                                                                       | cov_corner_cases.csv                                        | -s spec_cov.csv                            |
|         |                                                                       |                                                             | strictness 1                               |

NOTE: The CSV separator may be set to any separator character. Default is ',' but may be changed in VHDL (see ch 9.2). Delimiter is written to partial coverage file.





### 4 Definitions used in this document

### 4.1 Testcase

- A scenario or sequence of actions controlled by the test sequencer.
- May test one or multiple features/requirements.
- Typically testing of related functionality, or a logical sequence of events, or an efficient sequence of events
- Important: The minimum sequence of events possible to run in a single simulation execution. Thus if there is an option to run one of multiple test sequences (A or B or C), a set of test sequences (A and B) or all sequences (A+B+C), then all of A, B and C are defined as individual testcases.

### 4.2 Specification coverage

 A summary of how all the requirements in a complete Requirement Specification have been covered by the test suite (the complete verification environment)

# 4.3 Partial coverage

 In this VIP a summary of how some (or all) requirements for a DUT have been covered by one specific testcase. There may be one or more testcases and partial coverage summaries for a DUT depending on complexity and approach.



Figure 1: Workflow: Specification coverage vs Partial Coverage. Details in Figure 2:

The accumulation (or merger) of all partial coverage summaries will yield the Specification coverage.
 I.e. Testcase partial specification coverage → 'Partial Coverage', and Test suite overall specification coverage → 'Specification coverage'

# **5** Specification Coverage Concept

An important step of design verification is to check that all requirements have been met. Requirements can be defined very differently depending on application, project management, quality requirements, etc. In some projects, requirements barely exist, and the functionality is based on a brief description. However, in projects where safety and reliability are key the requirement handling is an essential part of the project management flow. In some development standards the requirements and the corresponding testcases that verify the requirements need to be defined, reviewed and accepted by a third-party assessor before even starting the verification flow.

This UVVM Verification IP is intended for projects where requirements are essential in the workflow but may also be used in a very simple way for projects with lower requirements. Examples of requirements can be seen in Table 1. It is in general a good idea to label the various requirements, and in many projects this would be mandatory. The example in Table 1 shows of course only a subset of all the requirements.

| Requirement Label | Description                                                     |
|-------------------|-----------------------------------------------------------------|
| UART_REQ_1        | The device UART interface shall accept a baud rate of 9600kbps. |
| UART_REQ_2        | The device UART interface shall accept a baud rate of 19k2 bps. |
| UART_REQ_3        | The device UART interface shall accept an odd parity            |
| UART_REQ_4        | The device reset shall be active low.                           |

Table 1 Requirement examples. (Requirement labels are defined by the user)

There are lots of acceptable approaches with respect to how much functionality is verified in each testcase and how these are organised. This VIP will allow various approaches from dead simple to advanced. In order to explain the concepts, we start with the simplest case and add step-by-step on that until we have built a full advanced specification coverage system.



# Conceptual introduction and the Simplest possible usage, with a single testcase

For any FPGA / ASIC it is always important to properly specify the design requirements and check that they have all been tested. Normally it is often just ticked off somewhere that a particular requirement is tested - often only once during the development phase, and sometimes just as a mental exercise. It is always better to use a written, repeatable and automated approach. This VIP significantly simplifies such an approach.

When feasible, the simplest structured approach would be to test all requirements in one single self-checking testcase. If so – all you want to do is the following – as illustrated in Figure 2.

- 1. List all DUT requirements in a requirement list CSV file. (RL). This could mean anything from just writing down the requirements directly, to a fully automated requirement extraction from an existing Requirement Specification. NOTE: For specification coverage this list is mandatory, but a simplified mode of pure test reporting without the need for a prior listing of the requirements is available (see more info in section 7.1).
- 2. Implement your testcase (T) with all tests required to verify the DUT. (see section 9.1) The test sequencer should initiate coverage using initialize reg cov() (T1), then for each verified requirement call tick off reg cov() (T2) and then finalise coverage reporting using finalize reg cov() (T3).
- When the testcase is executed (run), initialize reg cov() (T1) (see section 9.1) will read the given requirement list file (RL), the new partial coverage file (PC) is created, and the testcase name is stored. The header of the partial coverage file – with NOTE, testcase-name and delimiter is written. The header is not shown in any of the examples, but is shown in the front page file formats. Then for each tick off reg cov() (T2) a separate line is written into the partial coverage file with a) the given requirement label, b) the name of the testcase, and c) the result of the test. The result of the test will be PASS - unless marked as FAIL in the procedure call or unexpected serious alerts (>= ERROR / TB ERROR) have occurred, in which case it will be marked as FAIL. Finally when finalize reg cov() (T3) is executed, a closing check of the alert counters is made. If ok, then 'SUMMARY, <Testcase name>, PASS' is written at the end of the Partial coverage file. Otherwise FAIL rather than PASS (provided testcase does not stop on the alert). If a testcase fails before reaching finalize reg cov(), then no SUMMARY line will be written. This is interpreted as FAIL. Note that a given requirement may be tested and reported several times, so that for instance UART REQ 3 may be listed multiple times in the Partial coverage file (PC).
- After the testcase has been executed, the overall Specification coverage (SC) can be found by executing the Python script run spec cov.py (section 10). This script traverses the requirement list (RL) and Partial coverage file (PC) and from that generates the specification coverage (SC). Each requirement is listed in the specification coverage file. If a requirement has one or more FAIL in a Partial coverage file, the result is NON\_COMPLIANT for that requirement. For a simple scenario with a single testcase, the partial coverage (PC) file and the specification coverage file (SC) yield the same information, but the specification coverage potentially with fewer lines.



Figure 2: Simplest possible specification coverage (note that partial coverage files only show the actual requirement coverage lines)



# 7 Simple usage

### 7.1 Shortcut with no requirement list

A shortcut is supported to allow all tested requirements to be reported to the Partial coverage file – without the need for a prior listing of the requirements. This shortcut does of course not yield any specification coverage, as no specification is given, but could be useful for scenarios or early testing where only a list of executed tests is wanted. This shortcut mode is automatically applied when no requirement list is provided as an input to the initialize req cov() VHDL command in the test sequencer. If so, the partial coverage files will be generated, but no specification coverage file (the Python script) shall be run.

# 7.2 Simple usage, with multiple testcases

Many verification systems will have multiple testcases per DUT. If so, the above simplest approach is not possible.

However, if your tests are split on multiple testcases, but with no requirement as to which testcase tests what, then you can apply almost the same simple approach as the simplest case above.

For this scenario, there will be two or more testcases, and so you will have to run all relevant testcases. There will of course still be only a single Requirement list.

For every single testcase the same set of commands will be applied – with initialize\_req\_cov(), one or more tick\_off\_req\_cov(), and finalize\_req\_cov(). The only thing to remember here is that initialize\_req\_cov() has to specify separate Partial coverage files for each testcase. Hence, after simulation you should end up with as many Partial coverage files as testcases

Note: tick\_off\_req\_cov() will as default use the testcase name specified with initialize\_req\_cov() when writing to the partial coverage file. It is however possible to specify a dedicated testcase name as a parameter to tick\_off\_req\_cov(). If this testcase name is different from the testcase name already specified by initialize\_req\_cov(), then this testcase name is used when logging that specific requirement to the partial coverage file. All following tick\_off\_req\_cov() with no testcase name specified will again use the name given with initialize\_req\_cov(). The partial coverage file may in other words include references to both itself and other testcase names. It is also possible inside a test sequencer to execute initialize\_req\_cov() multiple times, but only when the previous initialize\_req\_cov() has been terminated with finalize\_req\_cov(). If multiple initialize... & finalize... these should operate on different partial coverage files to avoid overwriting the previous section.

The Python script run\_spec\_cov.py will be run in the same way as before, but needs to be given a list of all the relevant Partial coverage files. Then the Specification coverage is generated exactly as before.

### 7.3 Multiple testcases – with strict requirement vs testcase relation

For most applications where high quality and confidence is required it is mandatory to specify up front in which testcase a given requirement will be tested. In these cases, the requirement list must be extended to include the testcase in which a requirement will be tested, - as shown to the right. The example now shows more testcases than just to basic.

```
Requirement list, CSV

<Req. Label>, <Description>[, <Testcase-name>]

<Req. Label>, <Description>[, <Testcase-name>]

........
```

Requirement list, CSV

UART\_REQ\_1, Baudrate 9k6, tc\_basic

UART\_REQ\_2, Baudrate 19k2, tc\_19k2

UART\_REQ\_3, Odd parity, tc\_basic

UART\_REQ\_4, Active low reset, tc\_reset,

Specifying a testcase name in the requirement list will however not force a requirement vs testcase check by itself. In order to check that a requirement is tested in the specified testcase the switch '-strictness 1' must be used when calling run\_spec\_cov.py as described in section 10.1. If strictness is set to 1 then for example the requirement 'UART REQ 3, Odd parity, to basic will be:

- a) marked as COMPLIANT in the specification coverage file if UART\_REQ\_3 is checked positive in testcase tc\_basic. UART\_REQ\_3 may additionally also be checked elsewhere.
- b) Will be marked as NON-COMPLIANT in the specification coverage file if UART\_REQ\_3 is not checked in testcase tc\_basic (but for instance only in tc\_19k2).

Default strictness is –strictness 0, i.e. neither of the above strict checking. See section 10.1 for various strictness settings.

Testcase names and Requirement labels are not case sensitive for any comparison. For any output report the names and labels from the requirement list will be used if available. If not provided via the requirement list, then testcase name is taken from the initialize reg cov() and the requirement label from the tick off reg cov().



# Advanced usage

### 8.1 Advanced usage - Only one of multiple testcases for a given requirement must pass

In the previous example all tests in all testcases had to pass for the overall specification coverage to pass.

There may however be situations where a given requirement is tested in multiple testcases and it is sufficient that only any one of these pass – given of course that none of the others have failed, but just haven't been executed. A fail in any executed testcase will always result in a summary fail,

This approach could for instance be used to qualify for a lab test release.

A requirement for this approach to work is to remove all old partial coverage files before running your test suite generating new partial coverage files. The run spec cov.py option -clean may be used for this.

```
Requirement list, CSV
Requirement list, CSV
<Reg. Label>, <Description> [, <Testcase-name>, <Testcase-name>, ...]
                                                                                       UART REQ 1, Baudrate 9k6, tc basic
<Req. Label>, <Description> [, <Testcase-name>, <Testcase-name>, <Testcase-name>, ...]
                                                                                       UART REQ 2, Baudrate 19k2, tc 19k2
                                                                                       UART REQ 3. Odd parity.
                                                                                                                   tc basic tc 19k2
                                                                                      UART REQ 4, Active low reset, to reset, to basic, to 19k2
```

The example above shows that UART REQ 3 is covered by both testcases to basic and to 19k2, and that UART REQ 4 may in fact be tested by any of the three testcases.

This example also shows that testcase to reset is not required to be executed in order for all requirements to be tested. This \*could\* be a sign that to reset should be removed (optimized away), but given that to reset is required for some special reason, then it could for instance be left out of from a reduced test suite to gualify for lab test only.

# 8.2 Advanced usage - All (or some) of multiple testcases for a given requirement must pass

This is basically the opposite of the above and is easy to achieve by just adding lines in the requirement list for all wanted combinations of requirements and testcases. The example to the right states that UART REQ 3 must pass in both tc basic and tc 19k2.



(RL



# 8.3 Advanced usage – Requirement mapping

Requirement mapping just maps one or more requirements to another requirement. This is intended for two different use cases:

#### 8.3.1 Mapping of project requirements to IP or legacy requirements

Assuming you already have a UART IP, that has been properly verified, and the provided UART testbench already has full UVVM specification coverage support, with a requirement list file and testcases generating Partial coverage files.

Assuming you then have a project with its own UART requirements, that hopefully more or less matches that of the IP, but the requirement labels and combinations may be different. Then you don't want to modify the provided UART testbench in order just to get the "right" requirement labels.

A much better approach is to map the project requirements to the UART IP requirements.

#### From the UART IP

```
Requirement list, CSV

UART_REQ_1, Baudrate 9k6, tc_basic

UART_REQ_2, Baudrate 19k2, tc_19k2

UART_REQ_3, Odd parity, tc_basic

UART_REQ_4, Active low reset, tc_reset
```

#### From the PROJECT requirements



Now assume the already shown UART requirement list is that of the IP, and that we have similar project UART requirements, we may have a scenario as shown above.

Here we can see that UART\_REQ\_B of the project matches that of UART\_REQ\_3 of the UART IP, and that UART\_REQ\_A of the project is actually not covered by any single UART IP requirement, but in fact must include both UART\_REQ\_1 and UART\_REQ\_2. The map would for this case be as shown to the right.



Making the requirement map file is of course a manual job, which could be simple or complex depending on how much the two requirement lists differ in structure.

The requirement map file is only used as an input to the run\_spec\_cov.py Python script, as is also the Partial coverage file from the UART IP verification using the IP (or legacy) testbench. The Python script will check that

- For project requirement UART REQ A, both UART REQ 1 and UART REQ 2 have passed
- For project requirement UART\_REQ\_B, UART\_REQ\_3 has passed
- Etc...

The report from run\_spec\_cov.py will show compliancy for the project requirement (e.g.UART\_REQ\_A), but also for the "sub-requirement(s)" (e.g. UART\_REQ\_1 and UART\_REQ\_2).



#### 8.3.2 Mapping of requirements to multiple sub-requirements

Often the original requirements are too complex (or compound), so that it is difficult to tick off a requirement as checked until a whole lot of different things are tested. An example of that could be a UART requirement like the one shown to the right – with a single UART REQ GENERAL requirement.

\_\_\_\_\_ ons listed

Requirement list, CSV UART\_REQ\_GENERAL, Baudrates 9k6 and 19k2, odd and even parity

If you want to split this into more specific requirements you have several options, with some potential options listed below and illustrated to the right.

- a) Rename the requirements
- b) Extend the names
- c) Extend the names using a record like notation

All of these and more are of course possible, but the problem is that they don't show the relation to the original requirement.

a) Potential new Requirement list, CSV UART\_REQ\_BR\_A, Baudrate 9k6 UART\_REQ\_BR\_B, Baudrate 19k2 UART\_REQ\_ODD, Odd parity UART\_REQ\_EVEN, Even parity

b) Potential new Requirement list, CSV
UART\_REQ\_GENERAL\_BR\_A, Baudrate 9k6
UART\_REQ\_GENERAL\_BR\_B, Baudrate 19k2
UART\_REQ\_GENERAL\_ODD, Odd parity
UART\_REQ\_GENERAL\_EVEN, Even parity

c) Potential new Requirement list, CSV
UART\_REQ\_GENERAL.BR\_A, Baudrate 9k6
UART\_REQ\_ GENERAL.BR\_B, Baudrate 19k2
UART\_REQ\_ GENERAL.ODD, Odd parity
UART\_REQ\_ GENERAL.EVEN, Even parity

Showing this relationship is quite simple in UVVM, by using exactly the same mechanism as for the IP or legacy scenario in the previous example. Thus all you have to do is to make your own requirement list and then map the original requirement to a set of requirements in your new list.

#### Requirement map file, CSV

UART\_REQ\_GENERAL, UART\_REQ\_GENERAL.BR\_A, UART\_REQ\_GENERAL.BR\_B, UART\_REQ\_GENERAL.ODD, UART\_REQ\_GENERAL.EVEN

- Or even simpler just name the subrequirements A,B,C,....

#### Requirement map file, CSV

UART REQ GENERAL, UART REQ GENERAL.A, UART REQ GENERAL.B, UART REQ GENERAL.C, UART REQ GENERAL.D

As for the IP scenario this approach allows the report to show both the original requirement and its new sub-requirements.



# 9 VHDL Package

A vital part of the specification coverage concept is the VHDL testbench methods. These methods are described in Table 2. The methods are located inside the *spec\_cov\_pkg.vhd* file in the *src/* directory of this VIP.

### 9.1 VHDL Methods Details

| Procedure            | Parameters and examples                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Description                                                                                                                                                                                                                                                                                                                                    |                                                                                           |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| initialize_req_cov() | testcase (string), req_list_file (string), partial_cov_file (string)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Starts the requirer                                                                                                                                                                                                                                                                                                                            | ment coverage process in a testcase.                                                      |
|                      | or testcase (string), partial_cov_file (string)  Examples initialize_req_cov("TC_UART_9k6", "c:/my_folder/requirements.csv", "./cov_9k6.csv"); initialize_req_cov("TC_UART_9k6", "requirements.csv", "cov_9k6.csv");                                                                                                                                                                                                                                                                                                                                                 | The requirement list file is optional, but without it the specification coverage is of course not possible and run_spec_cov.py shall not be executed.  The partial_coverage_file is created – and the header is written with NOTE, Testcase-name and Delimiter on the first three lines. If file already exists, it will be overwritten.       |                                                                                           |
| tick_off_req_cov()   | requirement(string) [, testcase(string)] [, test_status(t_test_status)] or requirement(string) [, testcase(string)], test_status(t_test_status), msg [, scope]  Examples Will pass if no unexpected alert occurred tick_off_req_cov("UART_REQ_1", "TC_UART_9k6"); Will fail since passed argument is set to false tick_off_req_cov("UART_REQ_1", "TC_UART_9k6", FAIL); In order to include msg and scope test_status must be included tick_off_req_cov("UART_REQ_1", "TC_UART_9k6", NA, "my_msg"); or e.g. tick_off_req_cov("UART_REQ_1", NA, "my_msg", "my_scope"); | alert mismatch is<br>FAIL. If there are<br>explicitly set to FA<br>The result is writte<br>initialize_req_cov<br>The tick_off_req_<br>initialize_req_cov                                                                                                                                                                                       | en to both the transcript (and log) and the partial coverage file (specified in the       |
| finalize_req_cov()   | VOID(t_void)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Ends the requirement coverage process in a test.  If alert status is OK – appends a line to partial coverage file: 'SUMMARY, <testcase name="">, PASS'  If alert status is not OK – appends a line to partial coverage file: 'SUMMARY, <testcase name="">, FAIL'  This line is used later by the run_spec_cov.py script.</testcase></testcase> |                                                                                           |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                |                                                                                           |
|                      | Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                |                                                                                           |
|                      | finalize_req_cov(VOID);                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                |                                                                                           |
|                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | If simulation neve                                                                                                                                                                                                                                                                                                                             | r reached this command, e.g. if failed, then no summary line is written – indicating FAIL |

Table 2 VHDL Methods



# 9.2 Specification Coverage configuration record: shared\_spec\_cov\_config

This record is located in the local adaptation package 'bitvis\_vip\_spec\_cov/src/local\_adaptations\_pkg.vhd'
The configuration record is applied as a shared\_variable 'shared\_spec\_cov\_config' to allow different configuration for different DUTs.

Any test sequencer may then set the complete record as required – or even just parts of it like shared\_spec\_cov\_config.csv\_delimiter := ';';

| Record elements            | Туре          | Default    | Description                                                                                                                                                                                               |
|----------------------------|---------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| missing_req_label_severity | t_alert_level | TB_WARNING | Alert level used when the tick_off_req_cov() procedure does not find the specified requirement label in the requirement list, given that a requirement list is given in the initialize_req_cov() command. |
| csv_delimiter              | character     | ,          | Character used as delimiter in the CSV files. This will also be written into all partial coverage files. run_spec_cov.py will find the delimiter there.                                                   |
| max_requirements           | natural       | 1000       | Maximum number of requirements in the req_map file used in initialize_req_cov().  Increase this number if the number of requirements exceeds 1000.                                                        |
| max_testcases_per_req      | natural       | 20         | Maximum number of testcases allowed per requirement. This is applicable when one requirement is verified by one or more testcases.                                                                        |
| csv_max_line_length        | positive      | 256        | Maximum length of each line in any CSV file. (i.e. max number of characters for all values and separators in total)                                                                                       |

Table 3 Specification coverage adaptation

The specification coverage implementation uses three new message IDs, as described in the table below. All message Ids are located in uvvm\_util adaptations package. The specification coverage implementation uses the shared message id panel for all logging.

| Message Id         | Description                                                            |
|--------------------|------------------------------------------------------------------------|
| ID_FILE_OPEN_CLOSE | Id used for any file open and close operation                          |
| ID_FILE_PARSER     | Id used for CSV parser messages.                                       |
| ID_SPEC_COV        | Id used for all messages that are not directly related to CSV parsing. |

Table 4 Message ID usage



### 9.3 Additional Documentation

Additional documentation about UVVM and its features can be found under "/uvvm vvc framework/doc/".

### 9.3.1 Compilation

This VHDL package may only be compiled with VHDL 2008. It is dependent on the following libraries

- UVVM Utility Library (UVVM-Util), version 2.11.0 and up
- UVVM VVC Framework, version 2.7.0 and up

Before compiling the Specification Coverage component, make sure that uvvm\_vvc\_framework and uvvm\_util have been compiled. See UVVM Essential Mechanisms located in uvvm\_vvc\_framework/doc for information about compile scripts.

#### **Compile order for the Specification vs Verification Matrix Component:**

| Compile to library  | File                      | Comment                                            |
|---------------------|---------------------------|----------------------------------------------------|
| bitvis_vip_spec_cov | local_adaptations_pkg.vhd | Local file for user adaptations                    |
| bitvis_vip_spec_cov | csv_file_reader_pkg.vhd   | Package for reading and parsing of CSV input files |
| bitvis_vip_spec_cov | spec_cov_pkg.vhd          | Specification Coverage component implementation    |

Table 5 Compile order

### 9.3.2 Simulator compatibility and setup

See UVVM/README.md for a list of supported simulators. For required simulator setup see UVVM-Util Quick reference.



# 10 Post-processing Script

The final step of the Specification Coverage usage is to run a post-processing script to evaluate all the simulation results. This script is called *run\_spec\_cov.py*. The script requires Python 3.x. The script can be called with the arguments listed in Table 6 from the command line.

The CSV delimiter is fetched by the Python script from the partial coverage file headers.

Note: All files may be referenced with absolute paths or relative to working directory.

| Argument             | Short<br>form | Example                                                          | Description                                                                                                                                                                                                                                                                                                                                                                     |  |
|----------------------|---------------|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| requirement_list     | -r            | requirement_list path/requirements.csv                           | Points to the requirement list. This argument is mandatory.  (For the case without a requirement list – this script may not be executed and wouldn't make sense anyway.)                                                                                                                                                                                                        |  |
| partial_cov          | -p            | partial_cov my_testcase_cov.csvpartial_cov my_coverage_files.txt | Points to the partial coverage file generated by the VHDL simulation as input to the post processing.  May also point to a file list including references to multiple partial coverage files. The format of such a file would be just each file on a separate line – potentially prefixed by a relative or absolute path.                                                       |  |
| requirement_map_list | -m            | requirement_map_list path/subrequirements.csv                    | Optional: Points to the requirement map file, described in section 8.3.  If this argument is omitted, the script assumes that no sub-requirements exist.                                                                                                                                                                                                                        |  |
| spec_cov             | -s            | spec_cov uart_spec_cov.csv                                       | Name (and optional path) of the specification_coverage file name, which is used to generate the following 3 files:  •                                                                                                                                                                                                                                                           |  |
| clean                |               | clean                                                            | Will clean any/all given partial coverage files. No short form defined here - to avoid unwanted clean                                                                                                                                                                                                                                                                           |  |
| strictness           |               | strictness 1                                                     | Default strictness is 0 (when not applied). 1 is stricter and 2 is much stricter (see sections 7.3 and 10.1). No short form defined here – to avoid wrong strictness                                                                                                                                                                                                            |  |
| config               |               | config path/config_file.txt                                      | Optional configuration file where all the arguments can be placed. This argument will override all other arguments. The configuration file does not need to have the .txt extension. All arguments shall be added on a new line.  Example configuration file contents: requirement_list my_path/requirements.csv partial_cov my_testcase_cov_files.txt spec_cov my_spec_cov.csv |  |
| help                 | -h            | help                                                             | Display the script argument options.                                                                                                                                                                                                                                                                                                                                            |  |

Table 6 Script Arguments



### 10.1Strictness for requirement vs testcase relation

Strictness does not apply to VHDL testcases – only to the post processing Python script. For all strictness levels, all requirements must be compliant for the complete specification to be compliant. Default strictness is –strictness 0.

#### 10.1.1 Strictness 0

This is the least strictness possible. Focus is only on the requirements, - with no concern at all as to in which testcase the various requirements have been tested.

Any requirement is compliant if executed as PASSed in any passing testcase, and not failing anywhere. This is independent of whether one or more testcases are specified for a given requirement in the Requirement list.

#### 10.1.2 Strictness 1

For this strictness level a requirement is only compliant if executed in the testcase(s) specified in the Requirement list. The list shown here is used as example for the cases below:

- If no testcase is specified for a given requirement, this requirement may be checked anywhere. Compliant if PASSed.
- If a requirement line is specified with a single testcase, this requirement (e.g. UART\_REQ\_1) is only compliant if executed by that testcase.
- If a requirement line is specified with multiple testcases (e.g. UART\_REQ\_4), this requirement is compliant if PASS in one or more of these testcases. There can be no FAIL in other testcases.
- If a requirement line is specified multiple times (like UART\_REQ\_3), every single line is mandatory. Hence UART\_REQ\_3 must PASS in both testcases (tc\_basic and tc\_19k2)

### Requirement list, CSV

UART\_REQ\_1, Baudrate 9k6, tc\_basic UART\_REQ\_2, Baudrate 19k2, tc\_19k2 UART\_REQ\_3, Odd parity, tc\_basic UART\_REQ\_3, Odd parity, tc\_19k2

UART\_REQ\_4, Active low reset, tc\_reset, tc\_basic, tc\_19k2

- A requirement may be checked in any testcase in addition to any specified testcase(s).
- If a requirement status from any testcase is FAIL, that requirement is NON COMPLIANT, even if PASS in other testcases.

#### 10.1.3 Strictness 2

With this strictness a requirement will be NON\_COMPLIANT if it is tested in a testcase that in the Requirement list was not specified as testcase for that requirement. In that case it will be NON\_COMPLIANT even if it has passed in one or more testcases specified for that requirement.

E.g. if UART\_REQ\_1 is tested in testcase to basic, but **also** in to reset.



### 10.2Output of post-processing script - basic

The output of the post-processing script is three files with requirements and testcases listed as COMPLIANT/NON\_COMPLIANT/NOT\_TESTED and PASS/FAIL/NOT\_EXECUTED, respectively. The format of the output files is the following:

Table 7 Post-processing script output - basic

| File    | <spec_cov_file>.req_vs_single_tc.csv</spec_cov_file>                                                                                                                                   | <spec_cov_file>.req_vs_tcs.csv</spec_cov_file>                                                                                                                     | <spec_cov_file>.tc_vs_reqs.csv</spec_cov_file>                                                                                |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| Example | Requirement, Testcase, Compliance FPGA_REQ_1, TC_UART_1, COMPLIANT FPGA_REQ_2, TC_UART_1, COMPLIANT FPGA_REQ_2, TC_UART_2, COMPLIANT FPGA_REQ_3, , NOT_TESTED FPGA_REQ_4, , NOT_TESTED | Requirement, Testcase(s), Compliance FPGA_REQ_1, TC_UART_1, COMPLIANT FPGA_REQ_2, TC_UART_1 TC_UART_2, COMPLIANT FPGA_REQ_3, , NOT_TESTED FPGA_REQ_4, , NOT_TESTED | Testcase, Requirement(s), Result TC_UART_1, FPGA_REQ_1 FPGA_REQ_2, PASS TC_UART_2, FPGA_REQ_2, PASS TC_UART_5, , NOT_EXECUTED |

### 10.3 Output of post-processing script – with sub-requirements

The output of the post-processing script will include an additional list with requirement to sub-requirement mapping in the req\_vs\_single\_tc.csv and req\_vs\_tcs.csv files, when requirement mapping as given in Section 8.3 is used. Note that the testcase listing file tc\_vs\_reqs.csv does not change from the layout in Table 7.

Table 8 Post-processing script output - with sub-requirements

| File    | <spec_cov_file>.req_vs_single_tc.csv</spec_cov_file>                                                          | <spec_cov_file>.req_vs_tcs.csv</spec_cov_file>                                                                |
|---------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| Example | Requirement, Testcase, Compliance                                                                             | Requirement, Testcase(s), Compliance                                                                          |
|         | FPGA_REQ_1, TC_UART_1, COMPLIANT                                                                              | FPGA_REQ_1, TC_UART_1, COMPLIANT                                                                              |
|         | FPGA_REQ_2, TC_UART_1, COMPLIANT                                                                              | FPGA_REQ_2, TC_UART_1 TC_UART_2, COMPLIANT                                                                    |
|         | FPGA_REQ_2, TC_UART_2, COMPLIANT                                                                              | FPGA_REQ_3, , NOT_TESTED                                                                                      |
|         | FPGA REQ 3, , NOT TESTED                                                                                      | FPGA REQ 4,, NOT TESTED                                                                                       |
|         | FPGA_REQ_4, , NOT_TESTED                                                                                      |                                                                                                               |
|         | Requirement, Sub-Requirement(s), Compliance REQ_1, FPGA_REQ_1 FPGA_REQ_2 FPGA_REQ_3 FPGA_REQ_4, NON_COMPLIANT | Requirement, Sub-Requirement(s), Compliance REQ_1, FPGA_REQ_1 FPGA_REQ_2 FPGA_REQ_3 FPGA_REQ_4, NON_COMPLIANT |

# 11 Example demos

There are two example demos provided under the demo directory, one with the most basic usage and one with a more complete functionality.



Disclaimer: This IP and any part thereof are provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with this IP.