## **Verification Requirement Document**

| М       | U                                                                                                                                                                                  | U                                                                                                                        | U                                                                                                                           | L                                   |  |  |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|--|
| Label   | Description                                                                                                                                                                        | Stimulus<br>Generation                                                                                                   | Functional Coverage                                                                                                         | Functionality Check                 |  |  |
| ALSU_1  | Incase of invalid cases do not occur,<br>when opcode is add, then out should<br>perform the addition on ports A and B<br>taking cin if parameter FULL_ADDER is<br>high             | Randomization under<br>constraints on the A and<br>B to have the maximum,<br>minimum and zero values<br>most of the time | Included as coverpoint for A<br>and B.<br>Included with cross<br>coverage when ALU opcode<br>is addition or multiplication  | Output Checked against golden model |  |  |
| ALSU_2  | Incase of invalid cases do not occur,<br>when opcode is mult, then out should<br>perform the multiplication on ports A<br>and B                                                    | Randomization under<br>constraints on the A and<br>B to have the maximum,<br>minimum and zero values<br>most of the time | Included in coverpoint2 for A<br>and B.<br>Included with cross<br>coverage when ALU opcode<br>is addition or multiplication | Output Checked against golden model |  |  |
| ALSU_3  | When invalid cases exist, out output should be low and leds should blink                                                                                                           | Randomization under<br>constraints where invalid<br>cases do not occur as<br>frequent as valid cases                     | Included in a coverpoint for opcode. Included with cross coverage to make sure invalid cases occur                          | Output Checked against golden model |  |  |
| ALSU_4  | If invalid cases do not occur and the<br>bypass inputs are high, then the output<br>out should by bypass port A or B based<br>on the prioirty if the both bypass ports<br>are high | Randomization for bypass                                                                                                 | Included in a coverpoint for bypass                                                                                         | Output Checked against golden model |  |  |
| ALSU_5  | When rst is high the output should be grounded                                                                                                                                     | setting reset for the minor<br>percentage of the<br>simulation time                                                      | included in a constraint block                                                                                              | Output Checked against golden model |  |  |
| ALSU 6  | checking values carried by cin                                                                                                                                                     | setting a coverpoint for                                                                                                 | included in a cover group                                                                                                   | Output Checked against golden model |  |  |
| ALSU_7  | checking values carried by serial_in                                                                                                                                               | setting a coverpoint for<br>serial_in                                                                                    | included in a cover group                                                                                                   | Output Checked against golden model |  |  |
| ALSU_8  | checking values carried by direction                                                                                                                                               | setting a coverpoint for direction                                                                                       | included in a cover group                                                                                                   | Output Checked against golden model |  |  |
| ALSU_9  | checking values carried by red_A                                                                                                                                                   | setting a coverpoint<br>forred_A                                                                                         | included in a cover group                                                                                                   | Output Checked against golden model |  |  |
| ALSU_10 | checking values carried by red_B                                                                                                                                                   | setting a coverpoint for<br>red_B                                                                                        | included in a cover group                                                                                                   | Output Checked against golden model |  |  |

## Code and Functional Coverage

```
=== Instance: /alsu_tb/dut
=== Design Unit: work.ALSU
______
Branch Coverage:
  Enabled Coverage
                  Bins Hits Misses Coverage .... 232 32 0 100.00%
  -----
  Branches
-----Branch Details-----
Statement Coverage:
                 Bins Hits Misses Coverage
  Enabled Coverage
  -----
                             0 100.00%
  Statements
-----Statement Details------
Toggle Coverage:
                    Bins Hits Misses Coverage
  Enabled Coverage
                    ----
                          ----
  -----
                     118 118 0 100.00%
  Toggles
-----Toggle Details-----
```

I tried to reach 100% functional coverage but I couldn't due to the auto generated bins, I tried to cancel this but it didn't work. You can check the attached report in the same folder.

| Covergroup Coverage:           |     |         |         |        |           |         |
|--------------------------------|-----|---------|---------|--------|-----------|---------|
| Covergroups                    | 1   | na      | na      | 97.64% |           |         |
| Coverpoints/Crosses            | 15  | na      | na      | na     |           |         |
| Covergroup Bins                | 368 |         |         | 89.13% |           |         |
| Covergroup                     |     |         | Metric  | Goal   | Bins      | Status  |
| TYPE /pack_alsu/managing_input |     | 97.64%  | 100     | -      | Uncovered |         |
| covered/total bins:            | 328 | 368     | _       |        |           |         |
| missing/total bins:            | 40  | 368     | _       |        |           |         |
| % Hit:                         |     |         | 89.13%  | 100    | -         |         |
| Coverpoint A_cp                |     |         | 100.00% | 100    | -         | Covered |
| covered/total bins:            |     | 4       | 4       | -      |           |         |
| missing/total bins:            |     | 0       | 4       | -      |           |         |
| % Hit:                         |     |         | 100.00% | 100    | -         |         |
| Coverpoint B_cp                |     | 100.00% | 100     | -      | Covered   |         |
| covered/total bins:            |     | 4       | 4       | -      |           |         |
| missing/total bins:            |     | 0       | 4       | -      |           |         |
| % Hit:                         |     |         | 100.00% | 100    | -         |         |
| Coverpoint ALU_cp              |     |         | 100.00% | 100    | -         | Covered |
| covered/total bins:            |     | 8       | 8       | -      |           |         |
| missing/total bins:            |     | 0       | 8       | -      |           |         |
| % Hit:                         |     | 100.00% | 100     | -      |           |         |
| Coverpoint ALSU_6              |     |         | 100.00% | 100    | -         | Covered |
| covered/total bins:            |     |         | 1       | 1      | -         |         |
| missing/total bins:            |     |         | 0       | 1      | -         |         |
| 0/ U:+.                        |     |         | 100 00% | 100    |           |         |

## Wave form snippets showing the design bugs before correction









