

# UVM-FJFO



Abdelrahman Hatem Nasr

# CONTENTS

| 1.Verification plan                        | 3  |
|--------------------------------------------|----|
| 2.UVM Structure                            | 4  |
| a.top module:                              | 4  |
| b.interface:                               | 4  |
| c.monitorig:                               | 5  |
| d.scoreboard:                              | 7  |
| e.coverage:                                | 7  |
| f.environment:                             | 8  |
| g.test:                                    | 9  |
| h.assertions:                              | 9  |
| 3.Code coverage                            | 10 |
| 4.Functional coverage                      | 14 |
| 5.Sequential domain coverage               | 16 |
| 6.Bugs report                              | 17 |
| Snippets of write only sequence wave form: | 20 |
| Snippets of read only sequence wave form:  | 20 |
| Snippets of read write sequence wave form: | 21 |
| 7.Features check                           | 22 |
| 8.Design & Testbench files                 | 24 |
| 1-DESIGN CODE                              | 24 |
| 2-INTERFACE                                | 25 |
| 3-SEQUENCE ITEM                            | 26 |
| 4-CONFIGURATION OBJECT                     | 27 |
| 5-DRIVER                                   | 27 |
| 6-MONITOR                                  | 28 |
| 7-SCOREBOARD                               | 29 |
| 8-COVERAGE                                 | 31 |
| 9-SEQUENCER                                | 31 |
| 10-MAIN SEQUENCE                           | 32 |
| 11-RESET SEQUENCE                          | 34 |
| 12-AGENT                                   | 34 |

| 13-ENVIRONMENT | 35 |
|----------------|----|
| 14-ASSERTIONS  | 36 |
|                |    |
|                |    |
| 16-TOP MODULE  |    |
| 17-DO FILE     | 41 |
| 18-SOURCE LIST | 41 |
| 19-Github Link | 41 |

## \*Verification Plan\*

| Label   | Description                                                                                                   | Stimulus Generation                                                                                                                  | Functional Coverage                                                                                | Functionality Check                                                               |
|---------|---------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| FIFO_1  | when the reset is asserted all flags registers , write and read pointers should be low                        | directed at the start of<br>simulation ,then randomized<br>under constraints which<br>make reset to be<br>deasserted at most of time |                                                                                                    | immediate assertions to check for async reset functionallity                      |
| FIFO_2  | when read enable is asserted and the fifo<br>is not empty ,the fifo should be popped<br>with correct data out | randomization under<br>constraints on read enable<br>to be high 30% most of the<br>time                                              | cover values of read<br>enable,write enable and almost<br>empty,underflow                          | golden model to check the output data out                                         |
| FIFO_3  | when write enable is asserted and the fifo is not full ,the fifo should be pushed with correct data in        | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and almost<br>full,overflow                            | golden model to check the output data out which reflect the good asserted data in |
| FIFO_4  | wr_ack' should be asserted when write occurs and FIFO is not full                                             | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and wr_ack                                             | concuurent assertion to check the wr ack                                          |
| FIFO_5  | full flag should be asserted when fifo is full                                                                | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and full flag                                          | concuurent assertion to check the full flag                                       |
| FIFO_6  | empty flag should be asserted when fifo is empty                                                              |                                                                                                                                      | cover values of write<br>enable,read enable and empty<br>flag                                      | concuurent assertion to check the empty flag                                      |
| FIFO_7  | almostfull flag should be asserted when fifo count is fifo depth - 1                                          | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,readd enable and<br>almost full flag                               | concuurent assertion to check the almost full flag                                |
| FIFO_8  | almostempty flag should be asserted when fifo count is 1                                                      | randomization under<br>constraints on read enable<br>to be high 30% most of the<br>time                                              | cover values of write<br>enable,read enable and almost<br>empty flag                               | concuurent assertion to check the almost empty flag                               |
| FIFO_9  | overflow flag if full and wr_en it should be assertd                                                          | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and<br>overflow flag                                   | concuurent assertion to check the overflow flag                                   |
| FIFO_10 | underflow flag if empty and rd_en it should be assertd                                                        | randomization under<br>constraints on read enable<br>to be high 30% most of the<br>time                                              | cover values of write<br>enable,read enable and<br>underflow flag                                  | concuurent assertion to check the underflow flag                                  |
| FIFO_11 | count shouldn't be higher than fifo depth                                                                     | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and full flag                                          | concuurent assertion to check if count overflow                                   |
| FIFO_12 | write pointer shouldn't be higher than fifo depth                                                             | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable, read enable and full flag                                         | concuurent assertion to check if write pointer overflow                           |
| FIFO_13 | read pointer shouldn't be higher than fifo depth                                                              | randomization under<br>constraints on read enable<br>to be high 30% most of the<br>time                                              | cover values of write<br>enable,read enable and empty<br>flag                                      | concuurent assertion to check if read pointer underflow                           |
| FIFO_14 | count' when wr_en is high and rd_en is low it should increased                                                | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and wr_ack                                             | concuurent assertion to check if count increased                                  |
| FIFO_15 | count' when wr_en is low and rd_en is high it should decreased                                                | randomization under<br>constraints on read enable<br>to be high 30% most of the<br>time                                              | cover values of write<br>enable,read enable and<br>almostempty,empty and<br>underflow flags        | concuurent assertion to check if count decreased                                  |
| FIFO_16 | if rd_en is high and fifo is not empty rd_ptr<br>should increased                                             |                                                                                                                                      | cover values of write<br>enable, read enable and<br>almostempty, empty and<br>underflow flags      | concuurent assertion to check if rd_ptr increased                                 |
| FIFO_17 | if wr_en is high and fifo is not full wr_ptr<br>should increased                                              | randomization under<br>constraints on write enable<br>to be high 70% most of the<br>time                                             | cover values of write<br>enable,read enable and<br>wr_ack, overflow ,full and<br>almost full flags | concuurent assertion to check if wr_ptr increased                                 |

## \*UVM Structure\*



## 1.Top module

It generates the clock signal, Instantiate the interface and fifo design file ,then pass the clk to the interface and pass this interface to the dut ,the it binds the fifo and assertions file for check output functionality and then it sets the interface as a virtual interface into database to make it be able to accessed by another uvm components and run the test to start the testbench.



### 2.Interface

It is the intelligent bundle of wires ,it connect the design to testbench blocks monitor and driver the fifo interface define the signals and has a clock as a separate port as it is generated in top module.

### 3. Monitoring

### a.Fifo monitor:

fifo monitor monitors the activity of fifo interface, and check the functionality/coverage it translates the pin-level signals into sequence items to broadcast them to fifo scoreboard to check the functionality of the design and fifo coverage through analysis port connects analysis exports.



### b.Fifo agent:

fifo agent encapsulates the sequencer ,that manages the transfer of sequence items between reset,write only,read only ,read write sequences and the driver it acts as a fifo the sequence push data to sequencer then driver pop from this fifo then the driver drives the interface as a virtual interface by those sequences.

Agent has a configuration object to retrieve the virtual interface handle and then connects the virtual interface of the driver and monitor.



### 4.Scoreboard

The fifo scoreboard compares the behavior of a FIFO against a reference model. It tracks errors and correctness and provides a mechanism to connect with a monitor through TLM interfaces. The scoreboard verifies that the DUT correctly implements FIFO behavior based on input control signals and compares the design's outputs to the expected results.

The monitor will use the "write" method of the analysis\_port to broadcast the sequence item to the scoreboard, the "uvm\_tlm\_analysis\_fifo" receives the sequence item from analysis port through analysis export connected to it.



## 5.Coverage collector

The fifo coverage class capture functional coverage data for a FIFO design. It monitors various control signals and status conditions to assess the behavior of the FIFO during simulation. By defining both individual coverpoints and cross coverage between important signals, this coverage component helps identify how thoroughly the FIFO has been exercised in the testbench.



### 6.Environment

The fifo\_environment class instantiates the the agent, scoreboard, and coverage components during the build phase and establishes their connections during the connect phase. The environment is critical in orchestrating the interaction between stimulus generation, monitoring, and verification, thus ensuring comprehensive testing of the FIFO design, it also connects the agent to scoreboard and coverage collector.



#### 7.Test

The fifo\_test class imports necessary packages, including those for environment setup, configuration objects, and different sequences for resetting, writing, reading, and reading/writing sequences. In its constructor, it initializes the test name and parent component. During the build\_phase, the class creates instances of the FIFO environment and various sequences, while also attempting to retrieve a virtual interface for the FIFO design from the UVM configuration database. If the retrieval fails, it issues a fatal error message. The run\_phase starts by raising an objection to prevent simulation termination until all operations are complete. It then sequentially starts the reset sequence, write sequence, read sequence, and finally the read/write sequence, logging information at each step to indicate the sequence status. After completing all sequences, it drops the objection to allow the simulation to proceed.



### 8. Assertions

The assertions are introduced in a separate file to check the values of fifo flags it is bined with design in the top module, The code includes fatal assertions that trigger errors if any property fails during simulation, ensuring comprehensive verification of the FIFO's behavior.

## \*Code Coverage\*

-----Toggle Details-----

Enabled Coverage
Bins Hits Misses Coverage
Toggles

86
86
0
100.00%

Toggle Coverage for instance /top\_module/fifo\_interface\_instance --

| Node           | 1H->0L | 0L->1H | "Coverage" |
|----------------|--------|--------|------------|
|                |        |        |            |
| almostempty    | 1      | 1      | 100.00     |
| almostfull     | 1      | 1      | 100.00     |
| clk            | 1      | 1      | 100.00     |
| data_in[15-0]  | 1      | 1      | 100.00     |
| data_out[15-0] | 1      | 1      | 100.00     |
| empty          | 1      | 1      | 100.00     |
| full           | 1      | 1      | 100.00     |
| overflow       | 1      | 1      | 100.00     |
| rd_en          | 1      | 1      | 100.00     |
| rst_n          | 1      | 1      | 100.00     |
| underflow      | 1      | 1      | 100.00     |
| wr_ack         | 1      | 1      | 100.00     |
| wr_en          | 1      | 1      | 100.00     |

Total Node Count = 43
Toggled Node Count = 43
Untoggled Node Count = 0

Toggle Coverage = 100.00% (86 of 86 bins)

| Instance:<br>Design Uni | /top_module/<br>t: work.FIFO | DUT             |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------|------------------------------|-----------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Branch Coverag          | ė:                           |                 |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Enabled Co              |                              | Bins            | Hits         | NISSES COVERAGE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Branches                |                              | 23              | 23           | 0 100.00X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                         |                              | =====Branch De  | tails        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Branch Coverag          | e for instan                 | ce /top_module/ | DUT          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Line                    | Item                         |                 | Count        | Source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| File FIFO.sv            |                              |                 |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 18                      |                              | IF Br           | anch<br>8120 | Count coming in to IF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18                      | 1                            |                 | 2508         | if ( fifo_interface_imstance.rst_m) begin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 23                      | 1                            |                 | 3825         | else if (fifo_interface_instance.wr_en && count < fifo_interface_instance.FIFo_DEPTH) begin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 28                      | 1                            |                 | 1787         | else begin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Branch totals:          | 3 hits of 3                  | branches = 100  | .00%         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |                              | IF Br           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30<br>30                | 1                            |                 | 1787<br>760  | Count coming in to IF  (fifu_interface_instance,full && fifo_interface_instance.wr_en)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 32                      | 1                            |                 | 1027         | else                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Branch totals:          | 2 hits of 2                  | branches - 100  | .00%         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |                              | TE BO           | anch         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 38<br>38                | •                            |                 | 8120<br>2508 | <pre>count coming in to IF If (#Feo_interface_instance.rst.m) begin</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 42                      | 1                            |                 | 163          | at (franceine inserinamente at all of the franceine at a franceine |
| 46                      | 1                            |                 | 5449         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |                              |                 |              | else begin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                         |                              | branches = 100  |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 47                      |                              | IF Br           | anch         | Court coming in to IF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 47                      | 1                            |                 | 849          | If (fifo_interface_instance.empty && fifo_interface_instance.rd_en)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 49                      | 1                            |                 | 4600         | else                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Branch totals:          | 2 hits of 2                  | branches = 100  | .00%         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |                              | IF Br           |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 55<br>55                | 1                            |                 | 6689<br>2266 | Count coming in to IF if (ifie) intrinsec_instance.rst_n) begin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 58                      | 1                            |                 | 4343         | else begin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Branch totals:          | 2 hits of 2                  | branches = 100  | .00%         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                         |                              | IF Br           | anch         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 59<br>59                | 1                            | -               | 4343<br>3715 | Count coming in to IF ((((fife_interface_instance.wr_en, fife_interface_instance.rd_en) + 2'bio) && ((fife_interface_instance.wr_en, fife_interface_instance.wr_en, fife_interface_instance.rd_en) + 2'bio) && (fife_interface_instance.rd_interface_instance.wr_en, fife_interface_instance.rd_en) + 2'bio) && (fife_interface_instance.rd_interface_instance.wr_en, fife_interface_instance.wr_en, fife_interface |
| 61                      | 1                            |                 | 53           | else if ((((fifo_interface_instance.wr_en, fifo_interface_instance.rd_en) 2'b01) && (fifo_interface_instance.empty)    (((fifo_interface_instance.wr_en, fifo_interface_instance.rd_en) 2'b11) && (fifo_interface_instance.full)))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                         |                              |                 | 575          | All False Count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Branch totals:          | 3 hits of 3                  | branches = 100  |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

```
-----IF Branch-----
                                                Count coming in to IF assign fifo_interface_instance.full = (count == fifo_interface_instance.FIFO_DEPTH)? 1 : 0;
                                        4687
                                                assign fifo_interface_instance.full = (count == fifo_interface_instance.FIFO_DEPTH)? 1 : 0;
   66
                 2
                                        4508
Branch totals: 2 hits of 2 branches = 100.00%
-----TF Branch-----
                                                Count coming in to IF assign fifo_interface_instance.empty = (count == 0)? 1 : 0;
   67
                                        943
   67
                 2
                                        3744
                                                assign fifo_interface_instance.empty = (count == 0)? 1 : 0;
Branch totals: 2 hits of 2 branches = 100.00%
-----IF Branch-----
                                                Count coming in to IF assign fifo_interface_instance.almostfull = (count == fifo_interface_instance.FIFO_DEPTH-1)? 1 : 0;
                                                assign fifo interface instance.almostfull = (count == fifo interface instance.FIFO DEPTH-1)? 1:0:
   68
                 2
                                        4455
Branch totals: 2 hits of 2 branches = 100.00%
-----IF Branch------
                                                Count coming in to IF assign fifo_interface_instance.almostempty = (count == 1)? 1 : 0;
                                        4687
                 1
   69
                                        952
   69
                 2
                                       3735
                                                assign fifo_interface_instance.almostempty = (count == 1)? 1 : 0;
Branch totals: 2 hits of 2 branches = 100.00%
Statement Coverage:
   Enabled Coverage
                               Bins
                                         Hits
                                               Misses Coverage
                                                    0 100.00%
                                 25
                                          25
   Statements
-----Statement Details-----
Statement Coverage for instance /top_module/DUT --
   Line
               Item
                                        Count
                                                 Source
 File FIFO.sv
                                                 module FIFO(FIFO_INT.DUT fifo_interface_instance);
   9
                                                 localparam max fifo addr = $clog2(fifo interface instance.FIFO DEPTH);
   10
   11
   12
                                                 reg [fifo_interface_instance.FIFO_WIDTH-1:0] mem [fifo_interface_instance.FIFO_DEPTH-1:0];
   14
                                                 reg [max_fifo_addr-1:0] wr_ptr, rd_ptr;
                                                 reg [max fifo addr:0] count;
   15
   16
                                                 always @(posedge fifo_interface_instance.clk or negedge fifo_interface_instance.rst_n) begin
   17
                  1
                                         8120
                                                    if (!fifo_interface_instance.rst_n) begin
   19
                   1
                                         2508
                                                           wr_ptr <= 0;
                                                            fifo_interface_instance.overflow <= 0;</pre>
   20
                  1
                                         2508
   21
                                         2508
                                                            fifo_interface_instance.wr_ack <= 0;
   22
                                                    end
   23
                                                    else if (fifo_interface_instance.wr_en && count < fifo_interface_instance.FIFO_DEPTH) begin
   24
                   1
                                         3825
                                                            mem[wr_ptr] <= fifo_interface_instance.data_in;</pre>
                                                            fifo_interface_instance.wr_ack <= 1;</pre>
   25
                   1
                                         3825
   26
                                         3825
                                                           wr_ptr <= wr_ptr + 1;
                                                    end
   27
   28
                                                    else begin
   29
                  1
                                         1787
                                                            fifo_interface_instance.wr_ack <= 0;
                                                            if (fifo_interface_instance.full && fifo_interface_instance.wr_en)
   30
   31
                                          760
                                                                   fifo_interface_instance.overflow <= 1;
   32
                                                            else
   33
                                         1027
                                                                   fifo_interface_instance.overflow <= 0;</pre>
   34
                                                    end
   35
                                                 end
```

#### Toggle Coverage:

| Enabled Coverage | Bins | Hits | Misses | Coverage |
|------------------|------|------|--------|----------|
|                  |      |      |        |          |
| Toggles          | 20   | 20   | 0      | 100.00%  |

-----Toggle Details-----

Toggle Coverage for instance /top\_module/DUT --

| Node        | 1H->0L | 0L->1H | "Coverage" |
|-------------|--------|--------|------------|
| count[3-0]  | 1      | 1      | 100.00     |
| rd_ptr[2-0] | 1      | 1      | 100.00     |
| wr_ptr[2-0] | 1      | 1      | 100.00     |

Total Node Count = 10
Toggled Node Count = 10
Untoggled Node Count = 0

Toggle Coverage = 100.00% (20 of 20 bins)

# \*Functional Coverage\*

\_\_\_\_\_

=== Instance: /UVM\_FIFO\_coverage\_pkg

=== Design Unit: work.UVM\_FIFO\_coverage\_pkg

\_\_\_\_\_\_

Covergroup Coverage:

oup Coverage:
ergroups 1 na na 100.00%
Coverpoints/Crosses 16 na na na Covergroups

| cover politics/crosses 10                   | IIa | IIa     | IIa     |     |      |         |
|---------------------------------------------|-----|---------|---------|-----|------|---------|
| Covergroup Bins 74                          | 74  |         | 100.00% |     |      |         |
| overgroup                                   |     | Metric  |         | oal | Bins | Status  |
| TYPE /UVM_FIFO_coverage_pkg/fifo_coverage/c |     | 100.00% |         | 100 |      | Covered |
| covered/total bins:                         | _6- | 74      |         | 74  | _    |         |
| missing/total bins:                         |     | 0       | )       | 74  | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | -    |         |
| Coverpoint cp rd en                         |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    |         |
| missing/total bins:                         |     | 0       | )       | 2   | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | _    |         |
| bin auto[0]                                 |     | 5711    |         | 1   | _    | Covered |
| bin auto[1]                                 |     | 1290    | )       | 1   | _    | Covered |
| Coverpoint cp_wr_en                         |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    |         |
| missing/total bins:                         |     | 0       | )       | 2   | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | _    |         |
| bin auto[0]                                 |     | 1317    | r       | 1   | _    | Covered |
| bin auto[1]                                 |     | 5684    |         | 1   | _    | Covered |
| Coverpoint cp_wr_ack                        |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    |         |
| missing/total bins:                         |     | 0       |         | 2   | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | _    |         |
| bin auto[0]                                 |     | 3176    |         | 1   | _    | Covered |
| bin auto[1]                                 |     | 3825    |         | 1   | _    |         |
| Coverpoint cp_overflow                      |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    |         |
| missing/total bins:                         |     | 0       | )       | 2   | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | _    |         |
| bin auto[0]                                 |     | 6241    |         | 1   | _    | Covered |
| bin auto[1]                                 |     | 760     |         | 1   | _    | Covered |
| Coverpoint cp_full                          |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    |         |
| missing/total bins:                         |     | 0       |         | 2   | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | _    |         |
| bin auto[0]                                 |     | 6062    |         | 1   | _    | Covered |
| bin auto[1]                                 |     | 938     |         | 1   | _    | Covered |
| Coverpoint cp_empty                         |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    |         |
| missing/total bins:                         |     | 0       | )       | 2   | _    |         |
| % Hit:                                      |     | 100.00% | (       | 100 | _    |         |
| bin auto[0]                                 |     | 4728    |         | 1   | _    | Covered |
| bin auto[1]                                 |     | 2272    |         | 1   | _    | Covered |
| Coverpoint cp_almostfull                    |     | 100.00% |         | 100 | _    | Covered |
| covered/total bins:                         |     | 2       |         | 2   | _    | 22.2.29 |
| missing/total bins:                         |     | 9       |         | 2   | _    |         |
| % Hit:                                      |     | 100.00% |         | 100 | _    |         |
| bin auto[0]                                 |     | 6764    |         | 1   | _    | Covered |
| bin auto[1]                                 |     | 0.01    |         | _   |      |         |

| Coverpoint cp_almostempty 100.00% 100 - Covered covered/total bins: 2 2 2 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Covered/total bins:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Shift:   100.00%   100   -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| bin auto[0]   5956                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Din auto[1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Coverpoint to punderflow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| covered/total bins:         2         2           missing/total bins:         0         2           % Hit:         100.00%         100           bin auto[0]         6139         1         Covered           bin auto[1]         862         1         Covered           Cross #cross_0#         100.00%         100         -         Covered           covered/total bins:         8         8         -         -           missing/total bins:         0         8         8         -           % Hit:         100.00%         100         -         Covered           Auto, Default and User Defined Bins:         0         8         -         -           bin <auto[1],auto[1],auto[1]>         112         1         Covered         Covered         bin <auto[0],auto[1],auto[1]>         48         1         Covered         Covered         bin <auto[0],auto[0],auto[1]< td="">         124         1         Covered         covered         bin <auto[1],auto[1],auto[0]< td="">         92         1         Covered         bin <auto[1],auto[1],auto[0]< td="">         1939         1         Covered         bin <auto[1],auto[1],auto[0]< td="">         100         -         Covered         covered         bin <auto[0],auto[1],auto[0]< td="">         100         &lt;</auto[0],auto[1],auto[0]<></auto[1],auto[1],auto[0]<></auto[1],auto[1],auto[0]<></auto[1],auto[1],auto[0]<></auto[0],auto[0],auto[1]<></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| missing/total bins:         0         2         -         S         Hit:         100.00%         100         -         Covered         bin auto[0]         6139         1         -         Covered         bin auto[1]         862         1         -         Covered         Covered         Covered         100.00%         100         -         Covered         Covered         Covered         -         Covered         -         Covered         -         -         Covered         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Hit:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bin auto[0]         6139         1         - Covered Lovered                        |
| bin auto[1]         862         1         Covered           Cross #cross_0#         100.00%         100         - Covered           covered/total bins:         8         8         -           missing/total bins:         0         8         -           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         -         -         -           bin <auto[1],auto[1],auto[1]< td="">         3541         1         -         Covered           bin <auto[1],auto[0],auto[1]< td="">         48         1         -         Covered           bin <auto[1],auto[0],auto[1]< td="">         124         1         -         Covered           bin <auto[1],auto[0],auto[1]< td="">         92         1         -         Covered           bin <auto[0],auto[1],auto[0]< td="">         1939         1         -         Covered           bin <auto[1],auto[0],auto[0]< td="">         1038         1         -         Covered           bin <auto[1],auto[0],auto[0],auto[0]< td="">         107         1         -         Covered           covered/total bins:         8         8         8         -           missing/total bins:         8         8         -         -           Auto,</auto[1],auto[0],auto[0],auto[0]<></auto[1],auto[0],auto[0]<></auto[0],auto[1],auto[0]<></auto[1],auto[0],auto[1]<></auto[1],auto[0],auto[1]<></auto[1],auto[0],auto[1]<></auto[1],auto[1],auto[1]<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Cross #cross_0#                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| covered/total bins:         8         8         -           missing/total bins:         0         8         -           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         -         -         -           bin (auto[1],auto[1],auto[1])         3541         1         -         Covered           bin (auto[0],auto[0],auto[1])         48         1         -         Covered           bin (auto[0],auto[0],auto[0])         92         1         -         Covered           bin (auto[0],auto[1],auto[0])         1939         1         -         Covered           bin (auto[0],auto[0],auto[0])         107         1         -         Covered           bin (auto[0],auto[0],auto[0])         107         1         -         Covered           bin (auto[0],auto[0],auto[0],auto[0])         100         -         Covered           covered/total bins:         8         8         -           missing/total bins:         8         8         -           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         0         8         -           bin (auto[1],auto[1],auto[1])         1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| missing/total bins:         0         8         -           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         bin <auto[1],auto[1],auto[1]>         112         1         Covered           bin <auto[0],auto[1],auto[1]>         3541         1         Covered           bin <auto[0],auto[0],auto[1]>         48         1         Covered           bin <auto[1],auto[0],auto[0]>         124         1         Covered           bin <auto[1],auto[1],auto[0]>         1939         1         Covered           bin <auto[0],auto[0],auto[0]>         1938         1         Covered           bin <auto[0],auto[0],auto[0]>         107         1         Covered           bin <auto[0],auto[0],auto[0]>         107         1         Covered           covered/total bins:         8         8         -           missing/total bins:         0         8         8           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         1         Covered           bin <auto[1],auto[1],auto[1]>         756         1         Covered           bin <auto[0],auto[0],auto[0]>         2         1         Covered</auto[0],auto[0],auto[0]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[1],auto[1],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| # Hit:  Auto, Default and User Defined Bins:  bin (auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Auto, Default and User Defined Bins:     bin (auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Din (auto[1],auto[1],auto[1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| bin <auto[0],auto[1],auto[1]>         3541         1         - Covered bin <auto[1],auto[0],auto[1]>         48         1         - Covered bin <auto[0],auto[1],auto[0]>         124         1         - Covered bin <auto[1],auto[1],auto[0]>         92         1         - Covered bin <auto[1],auto[1],auto[0]>         1939         1         - Covered bin <auto[0],auto[0],auto[0]>         1939         1         - Covered bin <auto[0],auto[0],auto[0]>         1038         1         - Covered bin <auto[0],auto[0],auto[0]>         107         1         - Covered Covered bin <auto[0],auto[0],auto[0]>         109         - Covered bin <auto[0],auto[0],auto[0]>         100         - Covered <auto-covered <auto[0],auto[0],auto[0]="" bin="">         100         - Covered <auto-covered <auto[0],auto[1],auto[1]="" bin="">         1         1         - Covered <auto-covered <auto[0],auto[0],auto[1]="" bin="">         1         1         - Covered <auto-covered <auto[0],auto[0],auto[0]="" bin="">         1         - Covered <auto-covered <auto[0],auto[0],auto[0]="" bin="">         203         1         - Covered <auto-covered <auto[0],auto[0],auto[0]="" bin="">         229         1         - Covered <auto-covered <auto[0],auto[0],auto[0]="" bin="">         229         1         - Covered <auto-covered <<="" td=""></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto-covered></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]></auto[0],auto[1],auto[0]></auto[1],auto[0],auto[1]></auto[0],auto[1],auto[1]>     |
| bin ⟨auto[1],auto[0],auto[1]⟩   48                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bin ⟨auto[0],auto[0],auto[1]⟩   124                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| bin <auto[1],auto[1],auto[0]>         92         1         - Covered bin <auto[0],auto[1],auto[0]>         1939         1         - Covered bin <auto[0],auto[0],auto[0]>         1038         1         - Covered bin <auto[0],auto[0],auto[0]>         107         1         - Covered Co</auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[1],auto[1],auto[0]> |
| bin <auto[0],auto[1],auto[0]< td=""></auto[0],auto[1],auto[0]<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| bin <auto[1],auto[0],auto[0]>         1038         1         - Covered           bin <auto[0],auto[0],auto[0]>         107         1         - Covered           Cross #cross_1#         100.00%         100         - Covered           covered/total bins:         8         8         -           missing/total bins:         0         8         -           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         -         -         -           bin <auto[1],auto[1],auto[1]>         1         1         -         Covered           bin <auto[0],auto[1],auto[1]>         1         1         -         Covered           bin <auto[0],auto[1],auto[0]>         203         1         -         Covered           bin <auto[0],auto[1],auto[0]>         4724         1         -         Covered           bin <auto[0],auto[0],auto[0]>         1085         1         -         Covered           covered/total bins:         8         8         -           missing/total bins:         8         8         -           missing/total bins:         0         8         -           whit:         100.00%         100         -</auto[0],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| bin <auto[0],auto[0],auto[0]>         107         1         - Covered           Cross #cross_1#         100.00%         100         - Covered           covered/total bins:         8         8         -           missing/total bins:         0         8         -           % Hit:         100.00%         100         -           Auto, Default and User Defined Bins:         -         -         -           bin <auto[1],auto[1],auto[1]>         1         1         -         Covered           bin <auto[0],auto[1],auto[1]>         1         1         -         Covered           bin <auto[0],auto[0],auto[1]>         2         1         -         Covered           bin <auto[0],auto[1],auto[0]>         203         1         -         Covered           bin <auto[0],auto[1],auto[0]>         4724         1         -         Covered           bin <auto[0],auto[0],auto[0]>         229         1         -         Covered           covered/total bins:         8         8         -           missing/total bins:         0         8         -           missing/total bins:         0         8         -           Mit:         100.00%         100         <td< td=""></td<></auto[0],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Cross #cross_1#       100.00%       100       - Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       -       -         bin <auto[1],auto[1],auto[1]>       1       1       -       Covered         bin <auto[0],auto[0],auto[1]>       1       1       -       Covered         bin <auto[1],auto[0],auto[0]>       203       1       -       Covered         bin <auto[0],auto[1],auto[0]>       203       1       -       Covered         bin <auto[1],auto[0],auto[0]>       4724       1       -       Covered         bin <auto[0],auto[0],auto[0]>       1085       1       -       Covered         bin <auto[0],auto[0],auto[0]>       229       1       -       Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         Mit:       100.00%       100       -         Auto, Default and User Defined Bins:       -       -       -       -         bin <auto[0],auto[1],auto[1]>       3</auto[0],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[0],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| covered/Total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       -       -         bin (auto[1],auto[1],auto[1])       1       1       -       Covered         bin (auto[0],auto[1],auto[1])       756       1       -       Covered         bin (auto[1],auto[0],auto[1])       1       1       -       Covered         bin (auto[0],auto[0],auto[0])       203       1       -       Covered         bin (auto[0],auto[1],auto[0])       4724       1       -       Covered         bin (auto[1],auto[0],auto[0])       1085       1       -       Covered         bin (auto[0],auto[0],auto[0])       229       1       -       Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         missing/total bins:       0       8       -         Auto, Default and User Defined Bins:       -       -         bin (auto[1],auto[1],auto[1])       3       1       -       Covered         bin (auto[0],auto[1],auto[1])       933                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       bin <auto[1],auto[1],auto[1]>       1       1       -       Covered Covered Din <auto[0],auto[1],auto[1]< td="">       1       1       -       Covered Din <auto[0],auto[0],auto[1]< td="">       1       1       -       Covered Din <auto[0],auto[1],auto[0]< td="">       2       1       -       Covered Din <auto[0],auto[1],auto[0]< td="">       203       1       -       Covered Din <auto[0],auto[0],auto[0]< td="">       4724       1       -       Covered Din <auto[0],auto[0],auto[0]< td="">       1085       1       -       Covered Din <auto[0],auto[0],auto[0]< td="">       229       1       -       Covered Covered Din <auto[0],auto[1],auto[0]< td="">       229       1       -       Covered Covered Din <auto[0],auto[1],auto[1]< td="">       8       8       -       -       -       Auto, Default and User Defined Bins:       0       8       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -</auto[0],auto[1],auto[1]<></auto[0],auto[1],auto[0]<></auto[0],auto[0],auto[0]<></auto[0],auto[0],auto[0]<></auto[0],auto[0],auto[0]<></auto[0],auto[1],auto[0]<></auto[0],auto[1],auto[0]<></auto[0],auto[0],auto[1]<></auto[0],auto[1],auto[1]<></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| <pre>% Hit: Auto, Default and User Defined Bins: bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]></pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Auto, Default and User Defined Bins:  bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bin <auto[0],auto[1],auto[1]>       756       1       - Covered         bin <auto[1],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       2       1       - Covered         bin <auto[1],auto[1],auto[0]>       203       1       - Covered         bin <auto[1],auto[1],auto[0]>       4724       1       - Covered         bin <auto[1],auto[0],auto[0]>       1085       1       - Covered         bin <auto[0],auto[0],auto[0]>       229       1       - Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         Mit:       100.00%       100       -         Auto, Default and User Defined Bins:       0       8       -         bin <auto[1],auto[1],auto[1]>       3       1       - Covered         bin <auto[0],auto[1],auto[1]>       933       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[0]< td="">       1       1       - Covered</auto[0],auto[0],auto[0]<></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]></auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]></auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]></auto[0],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bin <auto[1],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       2       1       - Covered         bin <auto[1],auto[1],auto[0]>       203       1       - Covered         bin <auto[0],auto[1],auto[0]>       4724       1       - Covered         bin <auto[1],auto[0],auto[0]>       1085       1       - Covered         covered bin <auto[0],auto[0],auto[0]>       229       1       - Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       0       8       -         bin <auto[1],auto[1],auto[1]>       3       1       - Covered         bin <auto[0],auto[1],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered</auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[1],auto[1],auto[0]></auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| bin <auto[0],auto[0],auto[1]>       2       1       - Covered         bin <auto[1],auto[1],auto[0]>       203       1       - Covered         bin <auto[0],auto[1],auto[0]>       4724       1       - Covered         bin <auto[1],auto[0],auto[0]>       1085       1       - Covered         bin <auto[0],auto[0],auto[0]>       229       1       - Covered         Cross #cross_2#       100.00%       100       - Covered         covered/total bins:       8       8       - Minimizer         missing/total bins:       0       8       - Minimizer         % Hit:       100.00%       100       - Covered         Auto, Default and User Defined Bins:       - Covered       - Covered         bin <auto[1],auto[1],auto[1]>       3       1       - Covered         bin <auto[0],auto[1],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered</auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[1],auto[1],auto[0]></auto[0],auto[0],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| bin <auto[1],auto[1],auto[0]>       203       1       - Covered         bin <auto[0],auto[1],auto[0]>       4724       1       - Covered         bin <auto[1],auto[0],auto[0]>       1085       1       - Covered         bin <auto[0],auto[0],auto[0]>       229       1       - Covered         Cross #cross_2#       100.00%       100       - Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       0       100       -         bin <auto[1],auto[1],auto[1]>       3       1       - Covered         bin <auto[0],auto[1],auto[1]>       933       1       - Covered         bin <auto[1],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered</auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]></auto[0],auto[1],auto[0]></auto[1],auto[1],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| bin <auto[0],auto[1],auto[0]>       4724       1       - Covered         bin <auto[0],auto[0],auto[0]>       1085       1       - Covered         bin <auto[0],auto[0],auto[0]>       229       1       - Covered         Cross #cross_2#       100.00%       100       - Covered         covered/total bins:       8       8       - Missing/total bins:       9       8       - Missing/total bins:       - Missing/to</auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]></auto[0],auto[1],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| bin <auto[1],auto[0],auto[0]>       1085       1       - Covered         bin <auto[0],auto[0],auto[0]>       229       1       - Covered         Cross #cross_2#       100.00%       100       - Covered         covered/total bins:       8       8       - Feet and the covered         missing/total bins:       0       8       - Feet and the covered         % Hit:       100.00%       100       - Feet and the covered         Auto, Default and User Defined Bins:       Feet and the covered       Feet and the covered         bin <auto[1],auto[1],auto[1]>       3       1       - Covered         bin <auto[0],auto[1],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered</auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| bin <auto[0],auto[0],auto[0]>       229       1       - Covered         Cross #cross_2#       100.00%       100       - Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       -       -         bin <auto[1],auto[1],auto[1]>       3       1       -       Covered         bin <auto[0],auto[1],auto[1]>       933       1       -       Covered         bin <auto[1],auto[0],auto[1]>       1       1       -       Covered         bin <auto[0],auto[0],auto[1]>       1       1       -       Covered</auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]></auto[0],auto[0],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Cross #cross_2#       100.00%       100       - Covered         covered/total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       -       Covered         bin <auto[1],auto[1],auto[1]>       3       1       -       Covered         bin <auto[0],auto[1],auto[1]>       933       1       -       Covered         bin <auto[0],auto[0],auto[1]>       1       1       -       Covered         bin <auto[0],auto[0],auto[1]>       1       1       -       Covered</auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| covered/Total bins:       8       8       -         missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       5       5       5       -       Covered         bin <auto[1],auto[1],auto[1]>       3       1       -       Covered       -       Covered       -       -       Covered       -       -       Covered       -       -       -       -       Covered       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -</auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| missing/total bins:       0       8       -         % Hit:       100.00%       100       -         Auto, Default and User Defined Bins:       5       5       5       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| <pre>% Hit:</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Auto, Default and User Defined Bins:  bin <auto[1],auto[1]> 3 1 - Covered bin <auto[0],auto[1]> 933 1 - Covered bin <auto[1],auto[0],auto[1]> 1 1 - Covered bin <auto[0],auto[0],auto[1]> 1 1 - Covered</auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]></auto[0],auto[1]></auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| bin <auto[1],auto[1],auto[1]>       3       1       - Covered         bin <auto[0],auto[1],auto[1]>       933       1       - Covered         bin <auto[1],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered</auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]></auto[0],auto[1],auto[1]></auto[1],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bin <auto[0],auto[1],auto[1]>       933       1       - Covered         bin <auto[1],auto[0],auto[1]>       1       1       - Covered         bin <auto[0],auto[0],auto[1]>       1       1       - Covered</auto[0],auto[0],auto[1]></auto[1],auto[0],auto[1]></auto[0],auto[1],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| $bin < auto[1], auto[0], auto[1]> 1 1 - Covered \\ bin < auto[0], auto[0], auto[1]> 1 1 - Covered$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bin <auto[0],auto[0],auto[1]> 1 1 - Covered</auto[0],auto[0],auto[1]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| bin <auto[1],auto[0]> 201 1 - Covered</auto[1],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bin <auto[0], auto[0]=""> 4547 1 - Covered</auto[0],>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| bin <auto[1],auto[0],auto[0]> 1085 1 - Covered<br/>bin <auto[0],auto[0],auto[0]> 229 1 - Covered</auto[0],auto[0],auto[0]></auto[1],auto[0],auto[0]>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| στη καατοίο],αατοίο],αατοίο],                                      | 227        | _      |   | COVETCU            |
|--------------------------------------------------------------------|------------|--------|---|--------------------|
| Cross #cross 3#                                                    | 100.00%    | 100    | _ | Covered            |
| covered/total bins:                                                | 8          | 8      | - |                    |
| missing/total bins:                                                | 0          | 8      | - |                    |
| % Hit:                                                             | 100.00%    | 100    | - |                    |
| Auto, Default and User Defined Bins:                               |            |        |   |                    |
| <pre>bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]></pre> | 61         | 1      | - | Covered            |
| bin <auto[0],auto[1],auto[1]></auto[0],auto[1],auto[1]>            | 1119       | 1      | - | Covered            |
| <pre>bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]></pre> | 1020       | 1      | - | Covered            |
| bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]>            | 72         | 1      | - | Covered            |
| <pre>bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]></pre> | 143        | 1      | - | Covered            |
| bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>            | 4361       | 1      | - | Covered            |
| bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>            | 66         | 1      | - | Covered            |
| bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>            | 158        | 1      | - | Covered            |
| Cross #cross 4#                                                    | 100.00%    | 100    | - | Covered            |
| covered/total bins:                                                | 8          | 8      | - |                    |
| missing/total bins:                                                | 0          | 8      | - |                    |
| % Hit:                                                             | 100.00%    | 100    | - |                    |
| Auto, Default and User Defined Bins:                               |            |        |   |                    |
| bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>            | 3          | 1      | - | Covered            |
| <pre>bin <auto[0],auto[1],auto[1]></auto[0],auto[1],auto[1]></pre> | 224        | 1      | - | Covered            |
| <pre>bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]></pre> | 3          | 1      | - | Covered            |
| bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]>            | 6          | 1      | - | Covered            |
| <pre>bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]></pre> | 201        | 1      | - | Covered            |
| bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>            | 5256       | 1      | - | Covered            |
| bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>            | 1083       | 1      | - | Covered            |
| bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>            | 224        | 1      | - | Covered            |
| Cross #cross_5#                                                    | 100.00%    | 100    | - | Covered            |
| covered/total bins:                                                | 8          | 8      | - |                    |
| missing/total bins:                                                | 0          | 8      | - |                    |
| % Hit:                                                             | 100.00%    | 100    | - |                    |
| Auto, Default and User Defined Bins:                               |            |        |   |                    |
| <pre>bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]></pre> | 61         | 1      | - | Covered            |
| bin <auto[0],auto[1],auto[1]></auto[0],auto[1],auto[1]>            | 899        | 1      | - | Covered            |
| <pre>bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]></pre> | 29         | 1      | - | Covered            |
| <pre>bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]></pre> | 55         | 1      | - | Covered            |
| <pre>bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]></pre> | 143        | 1      | - | Covered            |
| bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]>            | 4581       | 1      | - | Covered            |
| bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>            | 1057       | 1      | - | Covered            |
| bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>            | 175        | 1      | - | Covered            |
| Cross #cross6#                                                     | 100.00%    | 100    | - | Covered            |
| covered/total bins:                                                | 8          | 8      | - |                    |
| missing/total bins:                                                | 0          | 8      | - |                    |
| % Hit:                                                             | 100.00%    | 100    | - |                    |
| Auto, Default and User Defined Bins:                               |            |        |   |                    |
| bin <auto[1],auto[1],auto[1]></auto[1],auto[1],auto[1]>            | 12         | 1      | - | Covered            |
| bin <auto[0],auto[1],auto[1]></auto[0],auto[1],auto[1]>            | 32         | 1      | - | Covered            |
| bin <auto[1],auto[0],auto[1]></auto[1],auto[0],auto[1]>            | 790        | 1      | - | Covered            |
| bin <auto[0],auto[0],auto[1]></auto[0],auto[0],auto[1]>            | 28         | 1      | - | Covered            |
| bin <auto[1],auto[1],auto[0]></auto[1],auto[1],auto[0]>            | 192        | 1      | - | Covered            |
| <pre>bin <auto[0],auto[1],auto[0]></auto[0],auto[1],auto[0]></pre> | 5448       | 1      | - | Covered            |
| bin <auto[1],auto[0],auto[0]></auto[1],auto[0],auto[0]>            |            |        |   |                    |
| bin <auto[0],auto[0],auto[0]></auto[0],auto[0],auto[0]>            | 296<br>203 | 1<br>1 | - | Covered<br>Covered |

# \*Sequential Domain Coverage\*

=== Instance: /top/DUT/FIFO\_SVA === Design Unit: work.SVA

\_\_\_\_\_\_

| Assertion Coverage:<br>Assertions |                         | 17         | 17   | 0                | 100.00%       |
|-----------------------------------|-------------------------|------------|------|------------------|---------------|
| Name                              | File(Line)              |            |      | Failure<br>Count | Pass<br>Count |
| /top/DUT/FIFO_SVA/a               |                         |            |      | 0                | 1             |
| /top/DUT/FIFO_SVA/b               | _reset<br>UVM_FIFO_asse | ertions.sv | (60) | 0                | 1             |
| /top/DUT/FIFO_SVA/c               | _reset<br>UVM_FIFO_asse | ertions.sv | (61) | 0                | 1             |
| /top/DUT/FIFO_SVA/d               | _reset<br>UVM_FIFO_asse | ertions.sv | (62) | 0                | 1             |
| /top/DUT/FIFO_SVA/e               | _reset<br>UVM_FIFO_asse | ertions.sv | (63) | 0                | 1             |
| /top/DUT/FIFO_SVA/f               | _reset<br>UVM_FIFO_asse | ertions.sv | (64) | 0                | 1             |
| /top/DUT/FIFO_SVA/a               | st1<br>UVM_FIFO_asse    | ertions.sv | (68) | 0                | 1             |
| /top/DUT/FIFO_SVA/as              | st2<br>UVM_FIFO_asse    | ertions.sv | (70) | 0                | 1             |
| /top/DUT/FIFO_SVA/a               | UVM_FIFO_asse           | ertions.sv | (72) | 0                | 1             |
| /top/DUT/FIFO_SVA/a               | UVM_FIFO_asse           | ertions.sv | (74) | 0                | 1             |
| /top/DUT/FIFO_SVA/as              | UVM_FIFO_asse           | ertions.sv | (76) | 0                | 1             |
| /top/DUT/FIFO_SVA/as              | UVM_FIFO_asse           | ertions.sv | (78) | Ø                | 1             |
| /top/DUT/FIFO_SVA/as              | UVM_FIFO_asse           | ertions.sv | (80) | 0                | 1             |
| /top/DUT/FIFO_SVA/as              | UVM_FIFO_asse           | ertions.sv | (82) | 0                | 1             |
| /top/DUT/FIFO_SVA/as              | UVM_FIFO_asse           | ertions.sv | (84) | 0                | 1             |
| /top/DUT/FIFO_SVA/as              | UVM_FIFO_asse           | ertions.sv | (86) | 0                | 1             |
| /top/DUT/FIFO_SVA/a               | st11<br>UVM_FIFO_asse   | ertions.sv | (88) | 0                | 1             |

## \*Bug Report\*

a.

### 1-Description:

Almostfull occurs when count equals to fifo depth - 1

2-Before:

```
assign almostfull = (count == FIFO_DEPTH-2)? 1 : 0;
```

3-After:

```
assign almostfull = (count == FIFO_DEPTH-1)? 1 : 0;
```

b.

### 1-Description:

Underflow flag is a sequential signal so it should be triggered with posedge of clk in always block not continuous assign

2-Before:

```
assign underflow = (empty && rd_en)? 1 : 0;
```

3-After:

```
if (empty & rd_en)
    underflow <= 1;
else
    underflow <= 0;</pre>
```

C.

### 1-Description:

Registers of the design should be low when reset is asserted

2-Before:

```
if (!fifo_interface_instance.rst_n) begin
  wr_ptr <= 0;</pre>
```

3-After:

```
if (!fifo_interface_instance.rst_n) begin
  wr_ptr <= 0;
  fifo_interface_instance.overflow <= 0;
  fifo_interface_instance.wr_ack <= 0;
end</pre>
```

d.

### 1-Description:

Underflow is a sequential signal should be low when reset is asserted

### 2-Before:

```
if (!fifo_interface_instance.rst_n) begin
  rd_ptr <= 0;</pre>
```

### 3-After:

```
if (!fifo_interface_instance.rst_n) begin
    rd_ptr <= 0;
    fifo_interface_instance.underflow <= 0;</pre>
```

e.

### 1-Description:

Count is increased or decreased at some extreme cases when rd\_en and wr\_en are both high

### 2-Before:

### 3-After:

```
e_instance.full)) || (({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en} == 2'b11) && (fifo_interface_instance.empty)))
face_instance.empty)) || (({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en} == 2'b11) && (fifo_interface_instance.full)))
```

f.

### 1-Description:

& will work correctly in this case because the signals are 1-bit, it is better to use && for clarity, readability, and to align with common design practices.

```
if (fifo_interface_instance.full && fifo_interface_instance.wr_en)
    fifo_interface_instance.overflow <= 1;
else
    fifo_interface_instance.overflow <= 0;</pre>
```

## \*Questasim Snippets\*



## Snippets of write only sequence wave form:



# Snippets of read only sequence wave form:





# Snippets of read write sequence wave form:



## \*Assertions\*

| Feature                                                                                                   | Assertion                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 'wr_ack' should be asserted when write occurs and FIFO is not full                                        | <pre>@(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n) (fifo_interface_instance.wr_en &amp;&amp; !fifo_interface_instance.full)  =&gt;</pre>                                                                                                                                                                                                                                                                                  |
| 'full' flag should be asserted when fifo_count = depth  'empty' flag should be asserted when fifo_count = | <pre>fifo_interface_instance.wr_ack @(posedge fifo_interface_instance.clk) (DUT.count == fifo_interface_instance.FIFO_DEPTH)  -&gt; fifo_interface_instance.full == 1 @(posedge fifo_interface_instance.clk)</pre>                                                                                                                                                                                                                                             |
| 'almostfull' flag should be asserted when fifo_count = depth-1                                            | <pre>(DUT.count == 0)  -&gt; fifo_interface_instance.empty == 1 @(posedge fifo_interface_instance.clk) (DUT.count == fifo_interface_instance.FIFO_DEPTH-1)  -&gt;</pre>                                                                                                                                                                                                                                                                                        |
| 'almostempty' flag should be asserted when fifo_count = 1                                                 | <pre>fifo_interface_instance.almostfull @(posedge fifo_interface_instance.clk) (DUT.count == 1)  -&gt; fifo_interface_instance.almostempty</pre>                                                                                                                                                                                                                                                                                                               |
| 'overflow' flag if full and wr_en it should be assertd                                                    | <pre>@(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n) (fifo_interface_instance.full &amp;&amp; fifo_interface_instance.wr_en)  =&gt; fifo_interface_instance.overflow</pre>                                                                                                                                                                                                                                                  |
| 'underflow' flag if empty and rd_en it should be assertd                                                  | @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n) (fifo_interface_instance.empty && fifo_interface_instance.rd_en )  => fifo_interface_instance.underflow                                                                                                                                                                                                                                                                     |
| 'count' when wr_en is high and rd_en is low it<br>should increased or both are high anf fifo is<br>empty  | <pre>@(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n) (   (({fifo_interface_instance.wr_en,     fifo_interface_instance.rd_en} == 2'b10) &amp;&amp;     (!fifo_interface_instance.full))        (({fifo_interface_instance.wr_en,     fifo_interface_instance.wr_en,     fifo_interface_instance.rd_en} == 2'b11) &amp;&amp;     (fifo_interface_instance.empty)))  =&gt; DUT.count     == \$past(DUT.count) + 4'b0001</pre> |
| 'count' when wr_en is low and rd_en is high it should decreased or both are high and fifo is full         | <pre>@(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)(   (({fifo_interface_instance.wr_en,   fifo_interface_instance.rd_en} == 2'b01) &amp;&amp;</pre>                                                                                                                                                                                                                                                                       |

```
(!fifo_interface_instance.empty)) ||
                                                   (({fifo_interface_instance.wr_en,
                                                   fifo_interface_instance.rd_en} == 2'b11) &&
                                                   (fifo_interface_instance.full))) |=> DUT.count
                                                   == $past(DUT.count) - 4'b0001
'rd ptr' should increased when rd en is asserted
                                                   @(posedge fifo_interface_instance.clk) disable
and fifo is not empty
                                                   iff(!fifo_interface_instance.rst_n)
                                                   (fifo_interface_instance.rd_en &&
                                                   !fifo_interface_instance.empty) |=> DUT.rd_ptr
                                                    == $past(DUT.rd_ptr)+3'b001
'wr_ptr' should increased when wr_en is asserted
                                                   @(posedge fifo_interface_instance.clk) disable
and fifo is not full
                                                   iff(!fifo_interface_instance.rst_n)
                                                   (fifo_interface_instance.wr_en &&
                                                   !fifo_interface_instance.full) |=> DUT.wr_ptr ==
                                                   $past(DUT.wr_ptr)+3'b001
When reset n is asserted
                                                       always_comb begin
count,overflow,underflow,rd_ptr,wr_ptr and
                                                           if(!fifo_interface_instance.rst_n) begin
wr_Ack should be low
                                                           a reset:
                                                   assert final(DUT.count == 0);
                                                           b_reset:
                                                   assert final(fifo_interface_instance.overflow ==
                                                   0);
                                                           c_reset:
                                                   assert final(fifo_interface_instance.underflow
                                                   == 0);
                                                           d_reset:
                                                   assert final(DUT.wr_ptr == 0);
                                                           e reset:
                                                   assert final(DUT.rd_ptr == 0);
                                                           f_reset:
                                                   assert final(fifo_interface_instance.wr_ack ==
                                                   0);
```

## \*Code files\*

### 1-DESIGN CODE

```
// Author: Kareem Waseem
  Course: Digital Verification using SV & UVM
// Description: FIFO Design
module FIFO(FIFO_INT.DUT fifo_interface_instance);
localparam max_fifo_addr = $clog2(fifo_interface_instance.FIFO_DEPTH);
reg [fifo_interface_instance.FIFO_WIDTH-1:0] mem [fifo_interface_instance.FIFO_DEPTH-1:0];
reg [max_fifo_addr-1:0] wr_ptr, rd_ptr;
reg [max_fifo_addr:0] count;
always @(posedge fifo_interface_instance.clk or negedge fifo_interface_instance.rst_n) begin
    if (!fifo_interface_instance.rst_n) begin
        wr_ptr <= 0;
        fifo_interface_instance.overflow <= 0;</pre>
        fifo_interface_instance.wr_ack <= 0;</pre>
    end
    else if (fifo_interface_instance.wr_en && count < fifo_interface_instance.FIFO_DEPTH) begin
        mem[wr_ptr] <= fifo_interface_instance.data_in;</pre>
        fifo_interface_instance.wr_ack <= 1;</pre>
        wr_ptr <= wr_ptr + 1;</pre>
    end
    else begin
        fifo_interface_instance.wr_ack <= 0;</pre>
        if (fifo_interface_instance.full && fifo_interface_instance.wr_en)
             fifo_interface_instance.overflow <= 1;</pre>
        else
             fifo_interface_instance.overflow <= 0;</pre>
    end
end
always @(posedge fifo_interface_instance.clk or negedge fifo_interface_instance.rst_n) begin
    if (!fifo_interface_instance.rst_n) begin
        rd_ptr <= 0;
        fifo_interface_instance.underflow <= 0;</pre>
    else if (fifo_interface_instance.rd_en && count != 0) begin
        fifo_interface_instance.data_out <= mem[rd_ptr];</pre>
        rd_ptr <= rd_ptr + 1;
```

```
end
    else begin
        if (fifo_interface_instance.empty && fifo_interface_instance.rd_en)
            fifo_interface_instance.underflow <= 1;</pre>
        else
            fifo_interface_instance.underflow <= 0;</pre>
    end
end
always @(posedge fifo_interface_instance.clk or negedge fifo_interface_instance.rst_n) begin
    if (!fifo_interface_instance.rst_n) begin
        count <= 0;
    end
    else begin
        if ((({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en} == 2'b10) &&
(!fifo_interface_instance.full)) || (({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en}
== 2'b11) && (fifo_interface_instance.empty)))
            count <= count + 1;</pre>
        else if ((({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en} == 2'b01) &&
(!fifo_interface_instance.empty)) || (({fifo_interface_instance.wr_en,
fifo_interface_instance.rd_en} == 2'b11) && (fifo_interface_instance.full)))
            count <= count - 1;</pre>
    end
end
assign fifo interface instance.full = (count == fifo interface instance.FIFO DEPTH)? 1 : 0;
assign fifo_interface_instance.empty = (count == 0)? 1 : 0;
assign fifo_interface_instance.almostfull = (count == fifo_interface_instance.FIFO_DEPTH-1)? 1 : 0;
assign fifo_interface_instance.almostempty = (count == 1)? 1 : 0;
endmodule
```

## 2-INTERFACE

```
interface FIFO_INT(clk);
  input clk;
  parameter FIFO_WIDTH = 16;
  parameter FIFO_DEPTH = 8;
  logic [FIFO_WIDTH-1:0] data_in;
  logic rst_n, wr_en, rd_en;
  logic [FIFO_WIDTH-1:0] data_out;
  logic wr_ack, overflow;
  logic full, empty, almostfull, almostempty, underflow;

modport DUT (
    input clk,data_in,rst_n,wr_en,rd_en,output
data_out,wr_ack,overflow,full,empty,almostfull,almostempty,underflow
);
```

## 3-SEQUENCE ITEM

```
package sequence_item_pkg;
import uvm_pkg::*;
`include "uvm_macros.svh"
class fifo sequence item extends uvm sequence item;
    `uvm_object_utils(fifo_sequence_item)
   parameter WIDTH_F = 16;
   parameter DEPTH F = 8;
   parameter RD_EN_ON_DIST = 30;
   parameter WR_EN_ON_DIST = 70;
   rand logic [WIDTH_F-1:0] data_in;
   rand logic rst_n, wr_en, rd_en;
    logic [WIDTH_F-1:0] data_out;
   logic wr_ack, overflow;
    logic full, empty, almostfull, almostempty, underflow;
    function new(string name = "fifo_sequence_item");
        super.new(name);
    endfunction
   function string convert2string();
        return $sformatf("%s rst_n = 0b%b , data_in = 0b%b , wr_en = 0b%b , rd_en = 0b%b , data_out
= 0b%b , wr_ack = 0b%b , overflow = 0b%b
         , underflow = 0b\%b , full = 0b\%b , empty = 0b\%b , almostfull = 0b\%b , almostempty =
0b%b",super.convert2string(),
         rst_n,data_in,wr_en,rd_en,data_out,wr_ack,overflow,underflow,full,empty,almostfull,almostem
pty);
    endfunction
    function string convert2string_stimulus();
        return $sformatf("rst_n = 0b%b , data_in = 0b%b , wr_en = 0b%b , rd_en =
0b%b",rst n,data in,wr en,rd en);
    endfunction
    constraint reset_n {
       rst n dist {
            0 := 20,
            1 := 80
        };
    constraint write_enable {
        wr_en dist {
            0 := 100 - WR_EN_ON_DIST,
           1 := WR_EN_ON_DIST
```

```
};
}

constraint read_enable {
    rd_en dist {
         0 := 100 - RD_EN_ON_DIST,
         1 := RD_EN_ON_DIST
    };
}
endclass
endpackage
```

## 4-CONFIGURATION OBJECT

```
package configuration_object_pkg;
  import uvm_pkg::*;
  `include "uvm_macros.svh"
  class fifo_configuration_object extends uvm_object;
      `uvm_object_utils(fifo_configuration_object)
      virtual FIFO_INT fifo_vif;
      function new(string name = "fifo_configuration_object");
            super.new(name);
      endfunction
  endclass
endpackage
```

## 5-DRIVER

```
package driver_pkg;
    import configuration_object_pkg::*;
    import sequence_item_pkg::*;
    import uvm_pkg::*;
    `include "uvm_macros.svh"
    class fifo_driver extends uvm_driver #(fifo_sequence_item);
        `uvm_component_utils(fifo_driver);
        virtual FIFO_INT fifo_vif;
        fifo_sequence_item fifo_seq_item;
        function new(string name = "fifo_driver",uvm_component parent = null);
            super.new(name,parent);
        endfunction
        task run_phase(uvm_phase phase);
            super.run_phase(phase);
            forever begin
                fifo_seq_item = fifo_sequence_item::type_id::create("fifo_seq_item");
                seq item port.get next item(fifo seq item);
```

```
@(negedge fifo_vif.clk);
    fifo_vif.rst_n = fifo_seq_item.rst_n;
    fifo_vif.wr_en = fifo_seq_item.wr_en;
    fifo_vif.rd_en = fifo_seq_item.rd_en;
    fifo_vif.data_in = fifo_seq_item.data_in;
    seq_item_port.item_done();
    `uvm_info("run_phase",fifo_seq_item.convert2string_stimulus(),UVM_HIGH)
    end
    endtask
    endclass
endpackage
```

### 6-MONITOR

```
package monitor_pkg;
    import sequence_item_pkg::*;
    import uvm_pkg::*;
    `include"uvm_macros.svh"
    class fifo_monitor extends uvm_monitor;
        `uvm_component_utils(fifo_monitor)
       virtual FIFO_INT fifo_vif;
        fifo_sequence_item fifo_seq_item;
        uvm_analysis_port #(fifo_sequence_item) mon_ap;
        function new(string name = "fifo_monitor",uvm_component parent = null);
            super.new(name,parent);
        endfunction
        function void build_phase (uvm_phase phase);
            super.build phase(phase);
            mon_ap = new("mon_ap",this);
        endfunction
        task run_phase(uvm_phase phase);
            super.run_phase(phase);
            forever begin
                fifo_seq_item = fifo_sequence_item::type_id::create("fifo_seq_item");
                @(negedge fifo_vif.clk);
                fifo_seq_item.rst_n
                                        = fifo_vif.rst_n;
                fifo seq item.data in = fifo vif.data in;
                fifo_seq_item.wr_en
                                        = fifo_vif.wr_en;
                fifo_seq_item.rd_en
                                        = fifo_vif.rd_en;
                fifo_seq_item.data_out = fifo_vif.data_out;
                fifo_seq_item.wr_ack
                                        = fifo_vif.wr_ack;
                fifo_seq_item.full
                                         = fifo_vif.full;
                                         = fifo_vif.empty;
                fifo_seq_item.empty
                fifo_seq_item.almostfull = fifo_vif.almostfull;
                fifo_seq_item.almostempty = fifo_vif.almostempty;
```

```
fifo_seq_item.overflow = fifo_vif.overflow;
    fifo_seq_item.underflow = fifo_vif.underflow;
    mon_ap.write(fifo_seq_item);
    `uvm_info("run_phase", fifo_seq_item.convert2string(),UVM_HIGH)
    end
    endtask
    endclass
endpackage
```

## 7-SCOREBOARD

```
package scoreboard pkg;
    import sequence_item_pkg::*;
    import uvm_pkg::*;
    `include "uvm_macros.svh"
    class fifo_scoreboard extends uvm_scoreboard;
        `uvm_component_utils(fifo_scoreboard)
        parameter WIDTH = 16;
        parameter DEPTH = 8;
        static int error_count = 0;
        static int correct count = 0;
        logic [WIDTH-1:0] data out ref;
        parameter max_fifo_addr_ref = $clog2(DEPTH);
        uvm_analysis_export #(fifo_sequence_item) sc_export;
        uvm_tlm_analysis_fifo #(fifo_sequence_item) fifo_sc;
        fifo_sequence_item item;
        logic [WIDTH-1:0] fifo_ref [DEPTH-1:0]; // memory for the FIFO reference
        bit [max_fifo_addr_ref : 0] fifo_count_ref; // Reference count of items in the FIFO
        bit [max_fifo_addr_ref-1:0] write_pointer_ref; // Reference write pointer
        bit [max_fifo_addr_ref-1:0] read_pointer_ref; // Reference read pointer
         function new(string name = "fifo_scoreboard",uvm_component parent = null);
            super.new(name,parent);
            write_pointer_ref= 0;
            read pointer ref = 0;
            fifo count ref = 0;
        endfunction
        function void build_phase (uvm_phase phase);
            super.build_phase(phase);
            sc_export = new("sc_export",this);
            fifo_sc = new("fifo_sc",this);
        endfunction
        function void connect_phase (uvm_phase phase);
            super.connect_phase(phase);
            sc_export.connect(fifo_sc.analysis_export);
        endfunction
```

```
task run_phase (uvm_phase phase);
             super.run_phase(phase);
             forever begin
                 fifo_sc.get(item);
                 ref_model(item);
                 if(item.data_out != data_out_ref) begin
                     `uvm_error("run_phase",$sformatf("error encoutered expected out = 0b%b , design
stimulus and output : %s",data_out_ref,item.convert2string()))
                     error_count++;
                 end
                 else begin
                     `uvm_info("run_phase",$sformatf("correct output :
%s",item.convert2string()),UVM_HIGH)
                     correct_count++;
                 end
             end
        endtask
        function void report_phase(uvm_phase phase);
             super.report_phase(phase);
             `uvm_info("report_phase",$sformatf("correct cases : %d",correct_count),UVM_MEDIUM)
             `uvm_info("report_phase",$sformatf("error cases : %d",error_count),UVM_MEDIUM)
        endfunction
        function void ref_model(fifo_sequence_item item);
             if(!item.rst_n) begin
                write_pointer_ref<= 0;</pre>
                 read_pointer_ref <= 0;</pre>
                 fifo_count_ref <= 0;</pre>
             end
             else begin
                 fork
                    begin
                       // Write operation logic
                       if (item.wr_en && !item.full) begin
                          fifo_ref[write_pointer_ref] <= item.data_in;</pre>
                          write_pointer_ref <= write_pointer_ref + 1;</pre>
                       end
                    end
                    begin
                       // Read operation logic
                       if (item.rd_en && !item.empty) begin
                          data_out_ref <= fifo_ref[read_pointer_ref];</pre>
                          read_pointer_ref <= read_pointer_ref + 1;</pre>
                       end
                    end
                    begin
```

## 8-COVERAGE

```
package coverage_pkg;
    import sequence_item_pkg::*;
    import uvm_pkg::*;
    `include "uvm_macros.svh"
    class fifo coverage extends uvm component;
        `uvm component utils(fifo coverage)
        uvm_analysis_export #(fifo_sequence_item) cov_export;
        uvm_tlm_analysis_fifo #(fifo_sequence_item) fifo_cov;
        fifo_sequence_item cov_item;
        covergroup cvr_gb;
            cp_rd_en:
                            coverpoint cov_item.rd_en;
                            coverpoint cov_item.wr_en;
            cp_wr_en:
                           coverpoint cov_item.wr_ack;
            cp_wr_ack:
                            coverpoint cov_item.overflow;
            cp_overflow:
            cp_full:
                            coverpoint cov_item.full;
            cp_empty:
                            coverpoint cov_item.empty;
            cp almostfull: coverpoint cov item.almostfull;
            cp_almostempty: coverpoint cov_item.almostempty;
            cp_underflow: coverpoint cov_item.underflow;
            cross cp_rd_en, cp_wr_en, cp_wr_ack;
            cross cp_rd_en, cp_wr_en, cp_overflow;
            cross cp_rd_en, cp_wr_en, cp_full;
            cross cp_rd_en, cp_wr_en, cp_empty;
            cross cp_rd_en, cp_wr_en, cp_almostfull;
            cross cp_rd_en, cp_wr_en, cp_almostempty;
            cross cp_rd_en, cp_wr_en, cp_underflow;
      endgroup
```

```
function new(string name = "fifo_coverage",uvm_component parent = null);
           super.new(name,parent);
           cvr_gb = new();
       endfunction
       function void build_phase (uvm_phase phase);
           super.build_phase(phase);
           cov_export = new("cov_export",this);
           fifo_cov = new("fifo_cov",this);
       endfunction
       function void connect_phase (uvm_phase phase);
           super.connect_phase(phase);
           cov_export.connect(fifo_cov.analysis_export);
       endfunction
       task run_phase (uvm_phase phase);
           super.run_phase(phase);
           forever begin
               fifo_cov.get(cov_item);
               cvr_gb.sample();
           end
       endtask
   endclass
endpackage
```

## 9-SEQUENCER

```
package sequencer_pkg;
  import sequence_item_pkg::*;
  import uvm_pkg::*;
  `include "uvm_macros.svh"
  class fifo_sequencer extends uvm_sequencer #(fifo_sequence_item);
    `uvm_component_utils(fifo_sequencer);
    function new(string name = "fifo_sequencer",uvm_component parent = null);
        super.new(name,parent);
    endfunction
  endclass
endpackage
```

## 10-MAIN SEQUENCE

```
package read_only_sequence_pkg;
  import sequence_item_pkg::*;
  import uvm_pkg::*;
  `include "uvm_macros.svh"
```

```
class fifo_read_only_sequence extends uvm_sequence #(fifo_sequence_item);
        `uvm_object_utils(fifo_read_only_sequence)
        fifo_sequence_item seq_item;
        function new(string name = "fifo_read_only_sequence");
            super.new(name);
        endfunction
        task body;
            repeat(1000) begin
                seq_item = fifo_sequence_item::type_id::create("seq_item");
                start item(seq item);
                assert(seq_item.randomize() with {wr_en == 0; rd_en == 1;});
                finish_item(seq_item);
            end
        endtask
    endclass
endpackage
package write_only_sequence_pkg;
import sequence_item_pkg::*;
import uvm_pkg::*;
 include "uvm_macros.svh"
class fifo_write_only_sequence extends uvm_sequence #(fifo_sequence_item);
    `uvm_object_utils(fifo_write_only_sequence)
    fifo_sequence_item seq_item;
    function new(string name = "fifo_write_only_sequence");
        super.new(name);
    endfunction
    task body;
        repeat(5000) begin
            seq_item = fifo_sequence_item::type_id::create("seq_item");
            start_item(seq_item);
            assert(seq_item.randomize() with {wr_en == 1; rd_en == 0;});
            finish_item(seq_item);
        end
    endtask
endclass
endpackage
package read_write_sequence_pkg;
    import sequence_item_pkg::*;
    import uvm_pkg::*;
    `include "uvm_macros.svh"
    class fifo read write_sequence extends uvm_sequence #(fifo_sequence_item);
        `uvm_object_utils(fifo_read_write_sequence)
        fifo_sequence_item seq_item;
```

## 11-RESET SEQUENCE

```
package reset_sequence_pkg;
    import sequence_item_pkg::*;
    import uvm_pkg::*;
    `include "uvm_macros.svh"
    class fifo_reset_sequence extends uvm_sequence #(fifo_sequence_item);
        `uvm_object_utils(fifo_reset_sequence)
        fifo_sequence_item seq_item;
        function new(string name = "fifo_reset_sequence");
            super.new(name);
        endfunction
        task body;
                seq_item = fifo_sequence_item::type_id::create("seq_item");
                start_item(seq_item);
                seq_item.rst_n = 0;
                seq_item.data_in = 0;
                seq item.rd en = 0;
                seq_item.wr_en = 0;
                finish_item(seq_item);
        endtask
    endclass
endpackage
```

## 12-AGENT

```
package agent_pkg;
import configuration_object_pkg::*;
import driver_pkg::*;
import monitor_pkg::*;
```

```
import sequence_item_pkg::*;
   import reset_sequence_pkg::*;
   import read_only_sequence_pkg::*;
   import write_only_sequence_pkg::*;
   import read_write_sequence_pkg::*;
   import sequencer_pkg::*;
   import uvm_pkg::*;
   `include "uvm macros.svh"
   class fifo_agent extends uvm_agent;
       `uvm_component_utils(fifo_agent);
       fifo_driver drv;
       fifo sequencer sqr;
       fifo monitor mtr;
       fifo_configuration_object obj;
       uvm_analysis_port #(fifo_sequence_item) agent_conn;
       function new(string name = "fifo_agent" , uvm_component parent = null);
           super.new(name,parent);
       endfunction
       function void build_phase (uvm_phase phase);
           super.build_phase(phase);
           if(!uvm_config_db#(fifo_configuration_object)::get(this,"","FIFO_CONFIG_OBJ",obj)) begin
                `uvm_fatal("build phase","Unable to get the configuration object");
           drv = fifo_driver::type_id::create("drv",this);
           sqr = fifo_sequencer::type_id::create("sqr",this);
           mtr = fifo_monitor::type_id::create("mtr",this);
           agent_conn = new("agent_conn",this);
       endfunction
       function void connect_phase (uvm_phase phase);
           super.connect_phase(phase);
           drv.fifo_vif = obj.fifo_vif;
           mtr.fifo_vif = obj.fifo_vif;
           drv.seq_item_port.connect(sqr.seq_item_export);
           mtr.mon_ap.connect(agent_conn);
       endfunction
   endclass
endpackage
```

## 13-ENVIRONMENT

```
package environment_pkg;
  import sequence_item_pkg::*;
  import reset_sequence_pkg::*;
  import read_only_sequence_pkg::*;
  import write_only_sequence_pkg::*;
```

```
import read_write_sequence_pkg::*;
   import sequencer_pkg::*;
   import agent_pkg::*;
   import coverage_pkg::*;
   import scoreboard_pkg::*;
   import uvm_pkg::*;
   `include "uvm_macros.svh"
   class fifo_environment extends uvm_env;
       `uvm_component_utils(fifo_environment)
       fifo_agent fifo_agent_env;
       fifo scoreboard fifo sc;
       fifo_coverage fifo_cvr;
       function new(string name = "fifo_environment", uvm_component parent = null);
           super.new(name, parent);
       endfunction
       function void build_phase(uvm_phase phase);
           super.build_phase(phase);
           fifo_agent_env=fifo_agent::type_id::create("fifo_agent_env",this);
           fifo_sc=fifo_scoreboard::type_id::create("fifo_sc",this);
           fifo_cvr=fifo_coverage::type_id::create("fifo_cvr",this);
       endfunction
       function void connect_phase (uvm_phase phase);
           super.connect_phase(phase);
           fifo_agent_env.agent_conn.connect(fifo_sc.sc_export);
           fifo_agent_env.agent_conn.connect(fifo_cvr.cov_export);
       endfunction
   endclass
endpackage
```

## 14-ASSERTIONS

```
module SVA (FIFO_INT.DUT fifo_interface_instance);
   `ifdef SIM

property write_acknowledge;
   @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)
(fifo_interface_instance.wr_en && !fifo_interface_instance.full) |=> fifo_interface_instance.wr_ack endproperty

property full_flag;
   @(posedge fifo_interface_instance.clk) (DUT.count == fifo_interface_instance.FIFO_DEPTH) |-> fifo_interface_instance.full == 1
```

```
endproperty
    property empty_flag;
    @(posedge fifo_interface_instance.clk) (DUT.count == 0) |-> fifo_interface_instance.empty == 1
    endproperty
    property almostfull flag;
    @(posedge fifo_interface_instance.clk) (DUT.count == fifo_interface_instance.FIFO_DEPTH-1) |->
fifo_interface_instance.almostfull
    endproperty
    property almostempty_flag;
    @(posedge fifo_interface_instance.clk) (DUT.count == 1) |-> fifo_interface_instance.almostempty
    property overflow flag;
    @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)
(fifo_interface_instance.full && fifo_interface_instance.wr_en) |=> fifo_interface_instance.overflow
    endproperty
    property underflow_flag;
    @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)
(fifo_interface_instance.empty && fifo_interface_instance.rd_en ) |=>
fifo_interface_instance.underflow
    endproperty
    property counter_operation_up;
    @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n) (
(({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en} == 2'b10) &&
(!fifo_interface_instance.full)) || (({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en}
== 2'b11) && (fifo_interface_instance.empty))) |=> DUT.count == $past(DUT.count) + 4'b0001
    endproperty
    property counter_operation_down;
    @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)(
(({fifo_interface_instance.wr_en, fifo_interface_instance.rd_en} == 2'b01) &&
(!fifo_interface_instance.empty)) || (({fifo_interface_instance.wr_en,
fifo_interface_instance.rd_en} == 2'b11) && (fifo_interface_instance.full))) |=> DUT.count ==
$past(DUT.count) - 4'b0001
    endproperty
    property read pointer operation;
```

```
@(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)
(fifo_interface_instance.rd_en && !fifo_interface_instance.empty) |=> DUT.rd_ptr ==
$past(DUT.rd_ptr)+3'b001
    endproperty
    property write_pointer_operatrion;
    @(posedge fifo_interface_instance.clk) disable iff(!fifo_interface_instance.rst_n)
(fifo interface instance.wr en && !fifo interface instance.full) |=> DUT.wr ptr ==
$past(DUT.wr ptr)+3'b001
    endproperty
    always comb begin
        if(!fifo_interface_instance.rst_n) begin
        a_reset: assert final(DUT.count == 0);
        b_reset: assert final(fifo_interface_instance.overflow == 0);
        c_reset: assert final(fifo_interface_instance.underflow == 0);
        d_reset: assert final(DUT.wr_ptr == 0);
        e_reset: assert final(DUT.rd_ptr == 0);
        f_reset: assert final(fifo_interface_instance.wr_ack == 0);
        end
    end
    ast1 : assert property(write acknowledge)
                                                   else $fatal("Assertion failed: 'wr ack' should
be asserted when write occurs and FIFO is not full!");
   cvr1 : cover property(write_acknowledge);
                                                   else $fatal("Assertion failed: 'full' flag
    ast2 : assert property(full_flag)
mismatch with fifo_count!");
    cvr2 : cover property(full_flag);
    ast3 : assert property(empty_flag)
                                                     else $fatal("Assertion failed: 'empty' flag
mismatch with fifo_count!");
    cvr3 : cover property(empty_flag);
    ast4 : assert property(almostfull_flag)
                                                   else $fatal("Assertion failed: 'almostfull'
flag mismatch with fifo_count!");
    cvr4 : cover property(almostfull_flag);
    ast5 : assert property(almostempty_flag)
                                                  else $fatal("Assertion failed: 'almostempty'
flag mismatch with fifo count!");
    cvr5 : cover property(almostempty_flag);
    ast6 : assert property(overflow_flag)
                                                     else $fatal("Assertion failed: 'overflow' flag
mismatch if full and wr_en it should be assertd!");
    cvr6 : cover property(overflow_flag);
    ast7 : assert property(underflow_flag)
                                                     else $fatal("Assertion failed: 'underflow'
flag mismatch if empty and rd_en it should be assertd!");
    cvr7 : cover property(underflow_flag);
    ast8 : assert property(counter_operation_up)
                                                    else $fatal("Assertion failed: 'count' when
wr_en is high and rd_en is low it should increased!");
    cvr8 : cover property(counter_operation_up);
    ast9 : assert property(counter_operation_down) else $fatal("Assertion failed: 'count' when
 r en is low and rd en is high it should decreased!");
```

### 15-TEST

```
package test_pkg;
    import configuration_object_pkg::*;
    import environment_pkg::*;
    import reset_sequence_pkg::*;
    import write_only_sequence_pkg::*;
    import read_only_sequence_pkg::*;
    import read_write_sequence_pkg::*;
    import uvm_pkg::*;
    `include "uvm macros.svh"
    class fifo test extends uvm test;
        `uvm_component_utils(fifo_test)
        fifo_configuration_object fifo_config_obj_test;
        fifo environment env;
        virtual FIFO_INT fifo_vif;
        fifo_reset_sequence reset_seq;
        fifo_write_only_sequence write_seq;
        fifo_read_only_sequence read_seq;
        fifo_read_write_sequence read_write_seq;
        function new(string name = "fifo_test",uvm_component parent = null);
            super.new(name,parent);
        endfunction
        function void build phase(uvm phase phase);
            super.build phase(phase);
            env=fifo_environment::type_id::create("env",this);
            fifo_config_obj_test =
fifo_configuration_object::type_id::create("fifo_config_obj_test");
            reset_seq = fifo_reset_sequence::type_id::create("reset_seq");
            write_seq = fifo_write_only_sequence::type_id::create("write_seq");
            read_seq = fifo_read_only_sequence::type_id::create("read_seq");
            read_write_seq = fifo_read_write_sequence::type_id::create("read_write_seq");
            if(!uvm_config_db#(virtual
FIFO_INT)::get(this,"","FIFO_INTERFACE",fifo_config_obj_test.fifo_vif))
                `uvm_fatal("build phase","Unable to get the virtual interface");
```

```
uvm_config_db#(fifo_configuration_object)::set(null, "*", "FIFO_CONFIG_OBJ", fifo_config_ob
j test);
        endfunction
        task run_phase(uvm_phase phase);
            super.run_phase(phase);
            phase.raise_objection(this);
            `uvm_info("run phase","Reset asserted",UVM_LOW)
            reset_seq.start(env.fifo_agent_env.sqr);
            `uvm_info("run phase", "Reset deasserted", UVM_LOW)
            `uvm_info("run phase","write sequence asserted",UVM_LOW)
            write_seq.start(env.fifo_agent_env.sqr);
            `uvm_info("run phase","write sequence deasserted",UVM_LOW)
            `uvm_info("run phase","read sequence asserted",UVM_LOW)
            read_seq.start(env.fifo_agent_env.sqr);
            `uvm_info("run phase","read sequence deasserted",UVM_LOW)
            `uvm_info("run phase","read write sequence asserted",UVM_LOW)
            read_write_seq.start(env.fifo_agent_env.sqr);
            `uvm_info("run phase","read sequence deasserted",UVM_LOW)
            phase.drop_objection(this);
        endtask
    endclass
endpackage
```

### **16-TOP MODULE**

```
import test_pkg::*;
import environment_pkg::*;
import uvm_pkg::*;
 include "uvm macros.svh";
module top_module;
    bit clk;
    initial begin
        clk = 0;
        forever #1 clk = ~clk;
    end
    FIFO_INT fifo_interface_instance (clk);
    FIFO DUT (fifo_interface_instance);
    bind FIFO SVA FIFO_SVA (fifo_interface_instance);
    initial begin
        uvm_config_db#(virtual
FIFO_INT)::set(null, "uvm_test_top", "FIFO_INTERFACE", fifo_interface_instance);
        run_test("fifo_test");
    end
```

## 17-DO FILE

vlib work
vlog -f src\_files.list -define SIM +cover -covercells
vsim -voptargs=+acc work.top\_module -cover
add wave /top\_module/fifo\_interface\_instance/\*
coverage save top\_module.ucdb -onexit
run -all
#quit -sim
#vcover report top\_module.ucdb -details -all -annotate -output coverage\_report\_fifo\_uvm.txt

## 18-SOURCE LIST

FIFO.sv FIFO\_INT.sv UVM\_FIFO\_configuration\_object.sv UVM\_FIFO\_Sequence\_item.sv **UVM FIFO Reset sequence.sv** UVM\_FIFO\_Write\_only\_sequence.sv UVM\_FIFO\_Read\_only\_sequence.sv UVM\_FIFO\_Read\_write\_sequence.sv **UVM FIFO sequencer.sv** UVM\_FIFO\_driver.sv UVM\_FIFO\_monitor.sv UVM\_FIFO\_agent.sv UVM\_FIFO\_coverage.sv **UVM FIFO scoreboard.sv** UVM\_FIFO\_environment.sv UVM\_FIFO\_test.sv top\_module.sv

## 19-GITHUB LINK

### repo