

MARIAM MOHAMED MARZOUK

# ASSIGNMENT\_3

Q2. Verify the functionality of the following counter:

- **Parameters:**

1. WIDTH: width of the data\_load and count\_out ports (Valid values: 4, 6, 8, default: 4)

- **Inputs:**

1. clk
2. rst\_n (active low sync rst)
3. load\_n (active low load)
4. up\_down (When the input is high then increment counter, else decrement the counter)
5. ce (enable signal to increment or decrement the counter depending on the up\_down)
6. data\_load (load data to count\_out output when the load signal is asserted)

- **Outputs:**

1. count\_out (counter output)
2. max\_count (When the counter reaches the maximum value, this signal is high, else low)
3. zero (When the counter reaches the minimum value, this signal is high, else low)

**Requirements:**

1. Create a verification plan document based on your verification plan items to support your verification planning, an example of the document can be found in the link [here](#). Please copy this document to have your own version
2. Create a package that has a class with the following constraints

- a. Constraint the reset to be deactivated most of the time
- b. Constraint the load signal to be active 70% of the time
- c. Constraint the enable signal to be active 70% of the time
3. Create a testbench that randomize the data in a repeat block or for loop using the class object to use the above constraints. Make the testbench self-checking.

You are free to add more constraints to enrich your verification to reach 100% code coverage.

# Question 1

## I. Verification plan

---

| <b>Label</b> | <b>Design Requirement Description</b>                                                                                           | <b>Stimulus Generation</b>                                                                              | <b>Functional Coverage</b>                                                                            | <b>Functionality Check</b>                                                                                                        |
|--------------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| COUNTER_1    | When reset (rst_n) is asserted, the counter output count_out should reset to zero.                                              | Randomize rst_n signal, and apply during the simulation to test the reset functionality.                | Ensure transitions of rst_n are covered, and the reset condition is observed.                         | Check if count_out is set to zero when rst_n is low.                                                                              |
| COUNTER_2    | When load_n is asserted, the counter should load the value of data_load into count_out.                                         | Randomized values for load_n and data_load are generated and applied.                                   | Ensure all values of data_load are covered, and the load operation is validated.                      | A checker verifies if count_out matches data_load when load_n is low.                                                             |
| COUNTER_3    | When up_down is high, the counter should increment; when up_down is low, the counter should decrement.                          | Randomize up_down signal and apply during the test to simulate both increment and decrement operations. | Ensure functional coverage for both increment and decrement scenarios, including boundary conditions. | A checker verifies the correct increment and decrement of count_out based on the value of up_down.                                |
| COUNTER_4    | The counter should wrap around to zero after reaching its maximum value, and wrap to max value after reaching zero (underflow). | Randomize ce, up_down, and allow count_out to increment or decrement beyond the boundary conditions.    | Validate functional coverage for both overflow and underflow conditions.                              | A checker ensures count_out wraps around to zero when it reaches the maximum value, and to max value when decrementing from zero. |
| COUNTER_5    | When ce (count enable) is low, the counter should not increment or decrement, and count_out should remain constant.             | Randomize ce signal to enable and disable counting operations during the test.                          | Ensure all scenarios for counting enabled and disabled conditions are covered.                        | A checker ensures count_out remains constant when ce is low and increments or decrements when ce is high.                         |
| COUNTER_6    | Correctness of max_count and zero flags based on the counter's state.                                                           | Randomize count_out to test the flags when the counter is at maximum value or zero.                     | Ensure functional coverage for max_count and zero flag transitions.                                   | A checker ensures the max_count flag is set when the counter reaches its maximum value, and the zero flag when it reaches zero.   |

## II. RTL Design

---

```
1 //////////////////////////////////////////////////////////////////
2 // Author: Kareem Waseem
3 // Course: Digital Verification using SV & UVM
4 //
5 // Description: Counter Design
6 //
7 //////////////////////////////////////////////////////////////////
8 module counter (clk ,rst_n, load_n, up_down, ce, data_load, count_out, max_count, zero);
9 parameter WIDTH = 4;
10 input clk;
11 input rst_n;
12 input load_n;
13 input up_down;
14 input ce;
15 input [WIDTH-1:0] data_load;
16 output reg [WIDTH-1:0] count_out;
17 output max_count;
18 output zero;
19
20 always @ (posedge clk) begin
21     if (!rst_n)
22         count_out <= 0;
23     else if (!load_n)
24         count_out <= data_load;
25     else if (ce)
26         if (up_down)
27             count_out <= count_out + 1;
28         else
29             count_out <= count_out - 1;
30 end
31
32 assign max_count = (count_out == {WIDTH{1'b1}})? 1:0;
33 assign zero = (count_out == 0)? 1:0;
34
35 endmodule
```

### III. Print



```
# DUT Output: count_out = 6, Expected Output: count_out_exp = 6
# DUT Output: count_out = 0, Expected Output: count_out_exp = 0
# DUT Output: count_out = 11, Expected Output: count_out_exp = 11
# DUT Output: count_out = 11, Expected Output: count_out_exp = 11
# DUT Output: count_out = 10, Expected Output: count_out_exp = 10
# DUT Output: count_out = 14, Expected Output: count_out_exp = 14
# DUT Output: count_out = 5, Expected Output: count_out_exp = 5
# DUT Output: count_out = 6, Expected Output: count_out_exp = 6
# DUT Output: count_out = 6, Expected Output: count_out_exp = 6
# DUT Output: count_out = 2, Expected Output: count_out_exp = 2
# DUT Output: count_out = 3, Expected Output: count_out_exp = 3
# DUT Output: count_out = 9, Expected Output: count_out_exp = 9
# DUT Output: count_out = 0, Expected Output: count_out_exp = 0
# DUT Output: count_out = 6, Expected Output: count_out_exp = 6
# DUT Output: count_out = 6, Expected Output: count_out_exp = 6
# DUT Output: count_out = 11, Expected Output: count_out_exp = 11
# DUT Output: count_out = 11, Expected Output: count_out_exp = 11
# DUT Output: count_out = 12, Expected Output: count_out_exp = 12
# DUT Output: count_out = 7, Expected Output: count_out_exp = 7
# DUT Output: count_out = 7, Expected Output: count_out_exp = 7
# DUT Output: count_out = 12, Expected Output: count_out_exp = 12
# DUT Output: count_out = 4, Expected Output: count_out_exp = 4
# DUT Output: count_out = 4, Expected Output: count_out_exp = 4
# DUT Output: count_out = 0, Expected Output: count_out_exp = 0
# DUT Output: count_out = 15, Expected Output: count_out_exp = 15
# DUT Output: count_out = 13, Expected Output: count_out_exp = 13
# DUT Output: count_out = 3, Expected Output: count_out_exp = 3
# DUT Output: count_out = 1, Expected Output: count_out_exp = 1
# DUT Output: count_out = 5, Expected Output: count_out_exp = 5
# DUT Output: count_out = 5, Expected Output: count_out_exp = 5
# DUT Output: count_out = 13, Expected Output: count_out_exp = 13
# DUT Output: count_out = 2, Expected Output: count_out_exp = 2
# DUT Output: count_out = 3, Expected Output: count_out_exp = 3
# DUT Output: count_out = 2, Expected Output: count_out_exp = 2
# DUT Output: count_out = 1, Expected Output: count_out_exp = 1
# DUT Output: count_out = 12, Expected Output: count_out_exp = 12
# Total Correct Count = 1000, Total Errors = 0
```

## IV. Package

```
1 package PCK;
2 parameter WIDTH = 4;
3 localparam ZERO = 0;
4 localparam MAX_COUNT = {WIDTH{1'b1}};
5
6 class E2;
7     rand bit rst_n_c, load_n_c, ce_c, up_down_c;
8     rand bit [WIDTH-1:0] data_load_c;
9     logic [WIDTH-1:0] count_out_c;
10
11    // Constraints for the random variables
12    constraint c_RST {
13        rst_n_c dist {
14            0 := 5,
15            1 := 95
16        };
17    }
18    constraint c_load {
19        load_n_c dist {
20            0 := 70,
21            1 := 30
22        };
23    }
24    constraint c_enable {
25        ce_c dist {
26            0 := 30,
27            1 := 70
28        };
29    }
30    covergroup cg;
31        load_cp: coverpoint data_load_c iff (!load_n_c);
32        count_up_c1: coverpoint count_out_c iff (rst_n_c && ce_c && up_down_c);
33        count_up_c2: coverpoint count_out_c iff (rst_n_c && ce_c && up_down_c) {
34            bins trans_overflow = (MAX_COUNT => ZERO);
35        }
36        count_down_c1: coverpoint count_out_c iff (rst_n_c && ce_c && !up_down_c);
37        count_down_c2: coverpoint count_out_c iff (rst_n_c && ce_c && !up_down_c) {
38            bins trans_underflow = (ZERO => MAX_COUNT);
39        }
40    endgroup
41    function new;
42        cg = new();
43    endfunction
44
45
46    endclass
47 endpackage
```

## V. Test bench

```
1 import PCK::*;
2 module counter_tb;
3 // Parameter
4 parameter WIDTH = 4;
5 // Input and output declaration
6 logic clk, rst_n, load_n, up_down, ce;
7 logic [WIDTH-1:0] data_load;
8 logic [WIDTH-1:0] count_out;
9 logic max_count, zero;
10 logic [WIDTH-1:0] count_out_exp; // Expected value for output count
11 // Counters declaration
12 int correct_count, error_count;
13 // DUT Instantiation
14 counter #(
15     .WIDTH(WIDTH)
16 ) DUT (
17     .clk(clk),
18     .rst_n(rst_n),
19     .load_n(load_n),
20     .up_down(up_down),
21     .ce(ce),
22     .data_load(data_load),
23     .count_out(count_out),
24     .max_count(max_count),
25     .zero(zero)
26 );
27 // Clock generation
28 initial begin
29     clk = 0;
30     forever #25 clk = ~clk; // Clock period is 50 time units
31 end
32 // Define the randomization object
33 E2 object1;
34 initial begin
35     // Initialize variables
36     object1 = new();
37     correct_count = 0;
38     error_count = 0;
39     count_out_exp = 0;
40     // Run the test for a number of iterations
41     repeat (1000) begin
42         // Randomize the test object
43         assert (object1.randomize());
44         // Apply randomized values
45         rst_n = object1.rst_n_c;
46         load_n = object1.load_n_c;
47         up_down = object1.up_down_c;
48         ce = object1.ce_c;
49         data_load = object1.data_load_c;
50         @(negedge clk);
51         object1.count_out_c = count_out;
52         object1.cg.sample();
53         self_check();
54     end
55 end
```

```

55 // Final results
56 $display("Total Correct Count = %0d, Total Errors = %0d", correct_count, error_count);
57 $stop;
58 end
59 // Task to check the DUT output
60 task self_check();
61     // Calculate the expected value
62     if (!rst_n) begin
63         count_out_exp = 0;
64     end else if (!load_n) begin
65         count_out_exp = data_load;
66     end else if (ce) begin
67         // Update count_out_exp based on direction
68         if (up_down) begin
69             if (count_out_exp == {WIDTH{1'b1}}) count_out_exp = 0; // Wrap around
70             else count_out_exp = count_out_exp + 1;
71         end else begin
72             if (count_out_exp == 0) count_out_exp = {WIDTH{1'b1}}; // Wrap around
73             else count_out_exp = count_out_exp - 1;
74         end
75     end
76     // Display
77     $display("DUT Output: count_out = %0d, Expected Output: count_out_exp = %0d", count_out,
78             count_out_exp);
79     if (count_out != count_out_exp) begin
80         $display("Error: Expected count_out = %0d, but got count_out = %0d", count_out_exp,
81                 count_out);
82         error_count++;
83     end else begin
84         correct_count++;
85     end
86 endtask
87 endmodule

```

## VI. Do file

---

```

vlib work
vlog counter.v package.svh counter_tb.svh +cover -covercells
vsim -voptargs=+acc work.counter_tb -cover
add wave *
coverage save counter_tb.ucdb -onexit
run -all

```

## VII. Waveform



## VIII. Functional Coverage Report

```
Coverage Report by instance with details
```

```
=====  
== Instance: /PCK  
== Design Unit: work.PCK  
=====
```

```
Covergroup Coverage:
```

|                     |    |    |    |         |
|---------------------|----|----|----|---------|
| Covergroups         | 1  | na | na | 100.00% |
| Coverpoints/Crosses | 5  | na | na | na      |
| Covergroup Bins     | 50 | 50 | 0  | 100.00% |

| Covergroup                       | Metric  | Goal | Bins | Status  |
|----------------------------------|---------|------|------|---------|
| TYPE /PCK/E2/cg                  | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 50      | 50   | -    |         |
| missing/total bins:              | 0       | 50   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint load_cp               | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_up_c1           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_up_c2           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 1       | 1    | -    |         |
| missing/total bins:              | 0       | 1    | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_down_c1         | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_down_c2         | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 1       | 1    | -    |         |
| missing/total bins:              | 0       | 1    | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Covergroup instance \PCK::E2::cg | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 50      | 50   | -    |         |
| missing/total bins:              | 0       | 50   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint load_cp               | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| bin auto[0]                      | 50      | 1    | -    | Covered |
| bin auto[1]                      | 36      | 1    | -    | Covered |
| bin auto[2]                      | 43      | 1    | -    | Covered |
| bin auto[3]                      | 48      | 1    | -    | Covered |
| bin auto[4]                      | 50      | 1    | -    | Covered |
| bin auto[5]                      | 48      | 1    | -    | Covered |
| bin auto[6]                      | 50      | 1    | -    | Covered |
| bin auto[7]                      | 42      | 1    | -    | Covered |
| bin auto[8]                      | 40      | 1    | -    | Covered |
| bin auto[9]                      | 50      | 1    | -    | Covered |
| bin auto[10]                     | 47      | 1    | -    | Covered |
| bin auto[11]                     | 45      | 1    | -    | Covered |
| bin auto[12]                     | 44      | 1    | -    | Covered |
| bin auto[13]                     | 42      | 1    | -    | Covered |
| bin auto[14]                     | 35      | 1    | -    | Covered |

```

bin auto[15]                                45      1      -  Covered
Coverpoint count_up_c1                      100.00% 100      -  Covered
  covered/total bins:                      16      16      -
  missing/total bins:                      0       16      -
  % Hit:                                 100.00% 100      -
bin auto[0]                                  18      1      -  Covered
bin auto[1]                                  25      1      -  Covered
bin auto[2]                                  18      1      -  Covered
bin auto[3]                                  26      1      -  Covered
bin auto[4]                                  26      1      -  Covered
bin auto[5]                                  18      1      -  Covered
bin auto[6]                                  26      1      -  Covered
bin auto[7]                                  23      1      -  Covered
bin auto[8]                                  21      1      -  Covered
bin auto[9]                                  27      1      -  Covered
bin auto[10]                                 24      1      -  Covered
bin auto[11]                                 17      1      -  Covered
bin auto[12]                                 23      1      -  Covered
bin auto[13]                                 28      1      -  Covered
bin auto[14]                                 15      1      -  Covered
bin auto[15]                                 20      1      -  Covered
Coverpoint count_up_c2                      100.00% 100      -  Covered
  covered/total bins:                      1       1      -
  missing/total bins:                      0       1      -
  % Hit:                                 100.00% 100      -
    bin trans_overflow                     1       1      -  Covered
Coverpoint count_down_c1                    100.00% 100      -  Covered
  covered/total bins:                      16      16      -
  missing/total bins:                      0       16      -
  % Hit:                                 100.00% 100      -
bin auto[0]                                 23      1      -  Covered
bin auto[1]                                 16      1      -  Covered
bin auto[2]                                 26      1      -  Covered
bin auto[3]                                 24      1      -  Covered
bin auto[4]                                 15      1      -  Covered
bin auto[5]                                 24      1      -  Covered
bin auto[6]                                 19      1      -  Covered
bin auto[7]                                 13      1      -  Covered
bin auto[8]                                 18      1      -  Covered
bin auto[9]                                 20      1      -  Covered
bin auto[10]                                18      1      -  Covered
bin auto[11]                                18      1      -  Covered
bin auto[12]                                22      1      -  Covered
bin auto[13]                                15      1      -  Covered
bin auto[14]                                18      1      -  Covered
bin auto[15]                                34      1      -  Covered
Coverpoint count_down_c2                    100.00% 100      -  Covered
  covered/total bins:                      1       1      -
  missing/total bins:                      0       1      -
  % Hit:                                 100.00% 100      -
    bin trans_underflow                   5       1      -  Covered

```

#### COVERGROUP COVERAGE:

| Covergroup | Metric | Goal | Bins | Status |
|------------|--------|------|------|--------|
|------------|--------|------|------|--------|

|                                         |         |     |   |         |
|-----------------------------------------|---------|-----|---|---------|
| TYPE /PCK/E2/cg                         | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 50      | 50  | - |         |
| missing/total bins:                     | 0       | 50  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Coverpoint load_cp</u>               | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 16      | 16  | - |         |
| missing/total bins:                     | 0       | 16  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Coverpoint count_up_c1</u>           | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 16      | 16  | - |         |
| missing/total bins:                     | 0       | 16  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Coverpoint count_up_c2</u>           | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 1       | 1   | - |         |
| missing/total bins:                     | 0       | 1   | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Coverpoint count_down_c1</u>         | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 16      | 16  | - |         |
| missing/total bins:                     | 0       | 16  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Coverpoint count_down_c2</u>         | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 1       | 1   | - |         |
| missing/total bins:                     | 0       | 1   | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Covergroup instance \PCK::E2::cg</u> | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 50      | 50  | - |         |
| missing/total bins:                     | 0       | 50  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| <u>Coverpoint load_cp</u>               | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 16      | 16  | - |         |
| missing/total bins:                     | 0       | 16  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| bin auto[0]                             | 50      | 1   | - | Covered |
| bin auto[1]                             | 36      | 1   | - | Covered |
| bin auto[2]                             | 43      | 1   | - | Covered |
| bin auto[3]                             | 48      | 1   | - | Covered |
| bin auto[4]                             | 50      | 1   | - | Covered |
| bin auto[5]                             | 48      | 1   | - | Covered |
| bin auto[6]                             | 50      | 1   | - | Covered |
| bin auto[7]                             | 42      | 1   | - | Covered |
| bin auto[8]                             | 40      | 1   | - | Covered |
| bin auto[9]                             | 50      | 1   | - | Covered |
| bin auto[10]                            | 47      | 1   | - | Covered |
| bin auto[11]                            | 45      | 1   | - | Covered |
| bin auto[12]                            | 44      | 1   | - | Covered |
| bin auto[13]                            | 42      | 1   | - | Covered |
| bin auto[14]                            | 35      | 1   | - | Covered |
| bin auto[15]                            | 45      | 1   | - | Covered |
| <u>Coverpoint count_up_c1</u>           | 100.00% | 100 | - | Covered |
| covered/total bins:                     | 16      | 16  | - |         |
| missing/total bins:                     | 0       | 16  | - |         |
| % Hit:                                  | 100.00% | 100 | - |         |
| bin auto[0]                             | 18      | 1   | - | Covered |
| bin auto[1]                             | 25      | 1   | - | Covered |
| bin auto[2]                             | 18      | 1   | - | Covered |
| bin auto[3]                             | 26      | 1   | - | Covered |
| bin auto[4]                             | 26      | 1   | - | Covered |
| bin auto[5]                             | 18      | 1   | - | Covered |
| bin auto[6]                             | 26      | 1   | - | Covered |
| bin auto[7]                             | 23      | 1   | - | Covered |
| bin auto[8]                             | 21      | 1   | - | Covered |
| bin auto[9]                             | 27      | 1   | - | Covered |

|                                 |                |            |   |         |
|---------------------------------|----------------|------------|---|---------|
| bin auto[8]                     | 40             | 1          | - | Covered |
| bin auto[9]                     | 50             | 1          | - | Covered |
| bin auto[10]                    | 47             | 1          | - | Covered |
| bin auto[11]                    | 45             | 1          | - | Covered |
| bin auto[12]                    | 44             | 1          | - | Covered |
| bin auto[13]                    | 42             | 1          | - | Covered |
| bin auto[14]                    | 35             | 1          | - | Covered |
| bin auto[15]                    | 45             | 1          | - | Covered |
| <b>Coverpoint count_up_c1</b>   | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 16             | 16         | - |         |
| missing/total bins:             | 0              | 16         | - |         |
| % Hit:                          | 100.00%        | 100        | - |         |
| bin auto[0]                     | 18             | 1          | - | Covered |
| bin auto[1]                     | 25             | 1          | - | Covered |
| bin auto[2]                     | 18             | 1          | - | Covered |
| bin auto[3]                     | 26             | 1          | - | Covered |
| bin auto[4]                     | 26             | 1          | - | Covered |
| bin auto[5]                     | 18             | 1          | - | Covered |
| bin auto[6]                     | 26             | 1          | - | Covered |
| bin auto[7]                     | 23             | 1          | - | Covered |
| bin auto[8]                     | 21             | 1          | - | Covered |
| bin auto[9]                     | 27             | 1          | - | Covered |
| bin auto[10]                    | 24             | 1          | - | Covered |
| bin auto[11]                    | 17             | 1          | - | Covered |
| bin auto[12]                    | 23             | 1          | - | Covered |
| bin auto[13]                    | 28             | 1          | - | Covered |
| bin auto[14]                    | 15             | 1          | - | Covered |
| bin auto[15]                    | 20             | 1          | - | Covered |
| <b>Coverpoint count_up_c2</b>   | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 1              | 1          | - |         |
| missing/total bins:             | 0              | 1          | - |         |
| % Hit:                          | 100.00%        | 100        | - |         |
| bin trans_overflow              | 1              | 1          | - | Covered |
| <b>Coverpoint count_down_c1</b> | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 16             | 16         | - |         |
| missing/total bins:             | 0              | 16         | - |         |
| % Hit:                          | 100.00%        | 100        | - |         |
| bin auto[0]                     | 23             | 1          | - | Covered |
| bin auto[1]                     | 16             | 1          | - | Covered |
| bin auto[2]                     | 26             | 1          | - | Covered |
| bin auto[3]                     | 24             | 1          | - | Covered |
| bin auto[4]                     | 15             | 1          | - | Covered |
| bin auto[5]                     | 24             | 1          | - | Covered |
| bin auto[6]                     | 19             | 1          | - | Covered |
| bin auto[7]                     | 13             | 1          | - | Covered |
| bin auto[8]                     | 18             | 1          | - | Covered |
| bin auto[9]                     | 20             | 1          | - | Covered |
| bin auto[10]                    | 18             | 1          | - | Covered |
| bin auto[11]                    | 18             | 1          | - | Covered |
| bin auto[12]                    | 22             | 1          | - | Covered |
| bin auto[13]                    | 15             | 1          | - | Covered |
| bin auto[14]                    | 18             | 1          | - | Covered |
| bin auto[15]                    | 34             | 1          | - | Covered |
| <b>Coverpoint count_down_c2</b> | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 1              | 1          | - |         |
| missing/total bins:             | 0              | 1          | - |         |
| % Hit:                          | 100.00%        | 100        | - |         |
| bin trans_underflow             | 5              | 1          | - | Covered |

TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1

Total Coverage By Instance (filtered view): 100.00%

|                                 |                |            |   |         |
|---------------------------------|----------------|------------|---|---------|
| bin auto[8]                     | 40             | 1          | - | Covered |
| bin auto[9]                     | 50             | 1          | - | Covered |
| bin auto[10]                    | 47             | 1          | - | Covered |
| bin auto[11]                    | 45             | 1          | - | Covered |
| bin auto[12]                    | 44             | 1          | - | Covered |
| bin auto[13]                    | 42             | 1          | - | Covered |
| bin auto[14]                    | 35             | 1          | - | Covered |
| bin auto[15]                    | 45             | 1          | - | Covered |
| <b>Coverpoint count_up_c1</b>   | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 16             | 16         | - |         |
| missing/total bins:             | 0              | 16         | - |         |
| % Hit:                          | <b>100.00%</b> | <b>100</b> | - |         |
| bin auto[0]                     | 18             | 1          | - | Covered |
| bin auto[1]                     | 25             | 1          | - | Covered |
| bin auto[2]                     | 18             | 1          | - | Covered |
| bin auto[3]                     | 26             | 1          | - | Covered |
| bin auto[4]                     | 26             | 1          | - | Covered |
| bin auto[5]                     | 18             | 1          | - | Covered |
| bin auto[6]                     | 26             | 1          | - | Covered |
| bin auto[7]                     | 23             | 1          | - | Covered |
| bin auto[8]                     | 21             | 1          | - | Covered |
| bin auto[9]                     | 27             | 1          | - | Covered |
| bin auto[10]                    | 24             | 1          | - | Covered |
| bin auto[11]                    | 17             | 1          | - | Covered |
| bin auto[12]                    | 23             | 1          | - | Covered |
| bin auto[13]                    | 28             | 1          | - | Covered |
| bin auto[14]                    | 15             | 1          | - | Covered |
| bin auto[15]                    | 20             | 1          | - | Covered |
| <b>Coverpoint count_up_c2</b>   | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 1              | 1          | - |         |
| missing/total bins:             | 0              | 1          | - |         |
| % Hit:                          | <b>100.00%</b> | <b>100</b> | - |         |
| bin trans_overflow              | 1              | 1          | - | Covered |
| <b>Coverpoint count_down_c1</b> | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 16             | 16         | - |         |
| missing/total bins:             | 0              | 16         | - |         |
| % Hit:                          | <b>100.00%</b> | <b>100</b> | - |         |
| bin auto[0]                     | 23             | 1          | - | Covered |
| bin auto[1]                     | 16             | 1          | - | Covered |
| bin auto[2]                     | 26             | 1          | - | Covered |
| bin auto[3]                     | 24             | 1          | - | Covered |
| bin auto[4]                     | 15             | 1          | - | Covered |
| bin auto[5]                     | 24             | 1          | - | Covered |
| bin auto[6]                     | 19             | 1          | - | Covered |
| bin auto[7]                     | 13             | 1          | - | Covered |
| bin auto[8]                     | 18             | 1          | - | Covered |
| bin auto[9]                     | 20             | 1          | - | Covered |
| bin auto[10]                    | 18             | 1          | - | Covered |
| bin auto[11]                    | 18             | 1          | - | Covered |
| bin auto[12]                    | 22             | 1          | - | Covered |
| bin auto[13]                    | 15             | 1          | - | Covered |
| bin auto[14]                    | 18             | 1          | - | Covered |
| bin auto[15]                    | 34             | 1          | - | Covered |
| <b>Coverpoint count_down_c2</b> | <b>100.00%</b> | <b>100</b> | - | Covered |
| covered/total bins:             | 1              | 1          | - |         |
| missing/total bins:             | 0              | 1          | - |         |
| % Hit:                          | <b>100.00%</b> | <b>100</b> | - |         |
| bin trans_underflow             | 5              | 1          | - | Covered |

TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1

Total Coverage By Instance (filtered view): 100.00%

## IX. Coverage report

```
Coverage Report by instance with details

=====
== Instance: /counter_tb/DUT
== Design Unit: work.counter
=====

Branch Coverage:
  Enabled Coverage      Bins      Hits      Misses   Coverage
  -----      -----      -----      -----
  Branches          10       10        0    100.00%
=====

=====Branch Details=====

Branch Coverage for instance /counter_tb/DUT

  Line      Item      Count      Source
  -----  -----
  File counter.v
  -----IF Branch-----
  21           999      Count coming in to IF
  21           61
  23           662
  25           204
  25           72      All False Count
Branch totals: 4 hits of 4 branches = 100.00%
  -----IF Branch-----
  26           204      Count coming in to IF
  26           107
  28           97
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  32           871      Count coming in to IF
  32           65
  32           806
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  33           871      Count coming in to IF
  33           102
  33           769
Branch totals: 2 hits of 2 branches = 100.00%

Condition Coverage:
  Enabled Coverage      Bins      Covered      Misses   Coverage
  -----      -----      -----      -----
  Conditions          2         2        0    100.00%
=====

=====Condition Details=====

Condition Coverage for instance /counter_tb/DUT --

  File counter.v
  -----Focused Condition View-----
Line      32 Item      1  (count_out == {4{{1}}})
Condition totals: 1 of 1 input term covered = 100.00%
  Input Term      Covered      Reason for no coverage      Hint
  -----      -----      -----
  (count_out == {4{{1}}})          Y
  Rows:      Hits      FEC Target      Non-masking condition(s)
  -----      -----
  Row 1:          1  (count_out == {4{{1}}})_0  -
  Row 2:          1  (count_out == {4{{1}}})_1  -
  -----Focused Condition View-----
Line      33 Item      1  (count_out == 0)
Condition totals: 1 of 1 input term covered = 100.00%
  Input Term      Covered      Reason for no coverage      Hint
  -----      -----
  (count_out == 0)          Y
```

| Input Term       | Covered | Reason for no coverage | Hint                     |
|------------------|---------|------------------------|--------------------------|
| (count_out == 0) | Y       |                        |                          |
| Rows:            | Hits    | FEC Target             | Non-masking condition(s) |
| Row 1:           | 1       | (count_out == 0)_0     | -                        |
| Row 2:           | 1       | (count_out == 0)_1     | -                        |

**Statement Coverage:**

| Enabled Coverage | Bins | Hits | Misses | Coverage |
|------------------|------|------|--------|----------|
| Statements       | 7    | 7    | 0      | 100.00%  |

=====Statement Details=====

Statement Coverage for instance /counter\_tb/DUT --

| Line           | Item | Count | Source |
|----------------|------|-------|--------|
| File counter.v |      |       |        |
| 20             | 1    | 999   |        |
| 22             | 1    | 61    |        |
| 24             | 1    | 662   |        |
| 27             | 1    | 107   |        |
| 29             | 1    | 97    |        |
| 32             | 1    | 872   |        |
| 33             | 1    | 872   |        |

Toggle Coverage:

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

=====Toggle Details=====

Toggle Coverage for instance /counter\_tb/DUT --

| Node           | 1H->0L | 0L->1H | "Coverage" |
|----------------|--------|--------|------------|
| ce             | 1      | 1      | 100.00     |
| clk            | 1      | 1      | 100.00     |
| count_out[3:0] | 1      | 1      | 100.00     |
| data_load[0:3] | 1      | 1      | 100.00     |
| load_n         | 1      | 1      | 100.00     |
| max_count      | 1      | 1      | 100.00     |
| rst_n          | 1      | 1      | 100.00     |
| up_down        | 1      | 1      | 100.00     |
| zero           | 1      | 1      | 100.00     |

Total Node Count = 15  
Toggled Node Count = 15  
Untoggled Node Count = 0

Toggle Coverage = 100.00% (30 of 30 bins)

=====

== Instance: /counter\_tb  
== Design Unit: work.counter\_tb

=====

Assertion Coverage:

| Assertions | 1 | 1 | 0 | 100.00% |
|------------|---|---|---|---------|
|------------|---|---|---|---------|

Name File(Line) Failure Count Pass Count

|                                        |                    |   |   |  |
|----------------------------------------|--------------------|---|---|--|
| /counter_tb/#ublk#95084642#39/immed_41 | counter_tb.svh(41) | 0 | 1 |  |
|----------------------------------------|--------------------|---|---|--|

Branch Coverage:

| Enabled Coverage | Bins | Hits | Misses | Coverage |
|------------------|------|------|--------|----------|
| Branches         | 12   | 11   | 1      | 91.66%   |

=====Branch Details=====

Branch Coverage for instance /counter\_tb

| Line                                          | Item | Count   | Source                |
|-----------------------------------------------|------|---------|-----------------------|
| File counter_tb.svh                           |      |         |                       |
|                                               |      |         | -----                 |
|                                               |      |         | IF Branch             |
| 60                                            |      | 1000    | Count coming in to IF |
| 60                                            | 1    | 61      |                       |
| 62                                            | 1    | 663     |                       |
| 64                                            | 1    | 204     |                       |
|                                               |      | 72      | All False Count       |
| Branch totals: 4 hits of 4 branches = 100.00% |      |         |                       |
|                                               |      |         | -----                 |
|                                               |      |         | IF Branch             |
| 66                                            |      | 204     | Count coming in to IF |
| 66                                            | 1    | 107     |                       |
| 71                                            | 1    | 97      |                       |
| Branch totals: 2 hits of 2 branches = 100.00% |      |         |                       |
|                                               |      |         | -----                 |
|                                               |      |         | IF Branch             |
| 67                                            |      | 107     | Count coming in to IF |
| 67                                            | 1    | 4       |                       |
| 69                                            | 1    | 103     |                       |
| Branch totals: 2 hits of 2 branches = 100.00% |      |         |                       |
|                                               |      |         | -----                 |
|                                               |      |         | IF Branch             |
| 72                                            |      | 97      | Count coming in to IF |
| 72                                            | 1    | 20      |                       |
| 74                                            | 1    | 77      |                       |
| Branch totals: 2 hits of 2 branches = 100.00% |      |         |                       |
|                                               |      |         | -----                 |
|                                               |      |         | IF Branch             |
| 80                                            |      | 1000    | Count coming in to IF |
| 80                                            | 1    | ***0*** |                       |
| 83                                            | 1    | 1000    |                       |
| Branch totals: 1 hit of 2 branches = 50.00%   |      |         |                       |

Condition Coverage:

| Enabled Coverage | Bins | Covered | Misses | Coverage |
|------------------|------|---------|--------|----------|
| Conditions       | ---  | ---     | ---    | ---      |

=====Condition Details=====

Condition Coverage for instance /counter\_tb --

| File                                                                                                                                                                                                                                                                                                                            | counter_tb.svh | Focused Condition View                             |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------|--------------------------|---------|------------------------|--------------------------|------------------------------------------|---|--------------------------------------------|---|--------|---|--------------------------------------------|---|
| Line                                                                                                                                                                                                                                                                                                                            | 67             | Item 1 ( <code>count_out_exp == {4{1}}</code> )    |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Condition totals:                                                                                                                                                                                                                                                                                                               | 1              | of 1 input term covered = 100.00%                  |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| <table><thead><tr><th>Input Term</th><th>Covered</th><th>Reason for no coverage</th><th>Hint</th></tr></thead><tbody><tr><td>(<code>count_out_exp == {4{1}}</code>)</td><td>Y</td><td></td><td></td></tr></tbody></table>                                                                                                       |                |                                                    | Input Term               | Covered | Reason for no coverage | Hint                     | ( <code>count_out_exp == {4{1}}</code> ) | Y |                                            |   |        |   |                                            |   |
| Input Term                                                                                                                                                                                                                                                                                                                      | Covered        | Reason for no coverage                             | Hint                     |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| ( <code>count_out_exp == {4{1}}</code> )                                                                                                                                                                                                                                                                                        | Y              |                                                    |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| <table><thead><tr><th>Rows:</th><th>Hits</th><th>FEC Target</th><th>Non-masking condition(s)</th></tr></thead><tbody><tr><td>Row 1:</td><td>1</td><td>(<code>count_out_exp == {4{1}}</code>)_0</td><td>-</td></tr><tr><td>Row 2:</td><td>1</td><td>(<code>count_out_exp == {4{1}}</code>)_1</td><td>-</td></tr></tbody></table> |                |                                                    | Rows:                    | Hits    | FEC Target             | Non-masking condition(s) | Row 1:                                   | 1 | ( <code>count_out_exp == {4{1}}</code> )_0 | - | Row 2: | 1 | ( <code>count_out_exp == {4{1}}</code> )_1 | - |
| Rows:                                                                                                                                                                                                                                                                                                                           | Hits           | FEC Target                                         | Non-masking condition(s) |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Row 1:                                                                                                                                                                                                                                                                                                                          | 1              | ( <code>count_out_exp == {4{1}}</code> )_0         | -                        |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Row 2:                                                                                                                                                                                                                                                                                                                          | 1              | ( <code>count_out_exp == {4{1}}</code> )_1         | -                        |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Focused Condition View                                                                                                                                                                                                                                                                                                          |                |                                                    |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Line                                                                                                                                                                                                                                                                                                                            | 72             | Item 1 ( <code>count_out_exp == 0</code> )         |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Condition totals:                                                                                                                                                                                                                                                                                                               | 1              | of 1 input term covered = 100.00%                  |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| <table><thead><tr><th>Input Term</th><th>Covered</th><th>Reason for no coverage</th><th>Hint</th></tr></thead><tbody><tr><td>(<code>count_out_exp == 0</code>)</td><td>Y</td><td></td><td></td></tr></tbody></table>                                                                                                            |                |                                                    | Input Term               | Covered | Reason for no coverage | Hint                     | ( <code>count_out_exp == 0</code> )      | Y |                                            |   |        |   |                                            |   |
| Input Term                                                                                                                                                                                                                                                                                                                      | Covered        | Reason for no coverage                             | Hint                     |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| ( <code>count_out_exp == 0</code> )                                                                                                                                                                                                                                                                                             | Y              |                                                    |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| <table><thead><tr><th>Rows:</th><th>Hits</th><th>FEC Target</th><th>Non-masking condition(s)</th></tr></thead><tbody><tr><td>Row 1:</td><td>1</td><td>(<code>count_out_exp == 0</code>)_0</td><td>-</td></tr><tr><td>Row 2:</td><td>1</td><td>(<code>count_out_exp == 0</code>)_1</td><td>-</td></tr></tbody></table>           |                |                                                    | Rows:                    | Hits    | FEC Target             | Non-masking condition(s) | Row 1:                                   | 1 | ( <code>count_out_exp == 0</code> )_0      | - | Row 2: | 1 | ( <code>count_out_exp == 0</code> )_1      | - |
| Rows:                                                                                                                                                                                                                                                                                                                           | Hits           | FEC Target                                         | Non-masking condition(s) |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Row 1:                                                                                                                                                                                                                                                                                                                          | 1              | ( <code>count_out_exp == 0</code> )_0              | -                        |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Row 2:                                                                                                                                                                                                                                                                                                                          | 1              | ( <code>count_out_exp == 0</code> )_1              | -                        |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Focused Condition View                                                                                                                                                                                                                                                                                                          |                |                                                    |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Line                                                                                                                                                                                                                                                                                                                            | 80             | Item 1 ( <code>count_out != count_out_exp</code> ) |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |
| Condition totals:                                                                                                                                                                                                                                                                                                               | 0              | of 1 input term covered = 0.00%                    |                          |         |                        |                          |                                          |   |                                            |   |        |   |                                            |   |

| Input Term                   | Covered | Reason for no coverage         | Hint                     |
|------------------------------|---------|--------------------------------|--------------------------|
| (count_out != count_out_exp) | N       | '_1' not hit                   | Hit '_1'                 |
| Rows:                        | Hits    | FEC Target                     | Non-masking condition(s) |
| Row 1:                       | 1       | (count_out != count_out_exp)_0 | -                        |
| Row 2:                       | ***0*** | (count_out != count_out_exp)_1 | -                        |

Statement Coverage:

| Enabled Coverage | Bins | Hits | Misses | Coverage |
|------------------|------|------|--------|----------|
| Statements       | 30   | 28   | 2      | 93.33%   |

#### =====Statement Details=====

Statement Coverage for instance /counter\_tb --

| Line | Item | Count   | Source |
|------|------|---------|--------|
| 27   | 1    | 1       |        |
| 28   | 1    | 1       |        |
| 28   | 2    | 2001    |        |
| 28   | 3    | 2000    |        |
| 34   | 1    | 1       |        |
| 35   | 1    | 1       |        |
| 36   | 1    | 1       |        |
| 37   | 1    | 1       |        |
| 39   | 1    | 1000    |        |
| 43   | 1    | 1000    |        |
| 44   | 1    | 1000    |        |
| 45   | 1    | 1000    |        |
| 46   | 1    | 1000    |        |
| 47   | 1    | 1000    |        |
| 48   | 1    | 1000    |        |
| 49   | 1    | 1000    |        |
| 50   | 1    | 1000    |        |
| 51   | 1    | 1000    |        |
| 54   | 1    | 1       |        |
| 55   | 1    | 1       |        |
| 61   | 1    | 61      |        |
| 63   | 1    | 663     |        |
| 68   | 1    | 4       |        |
| 70   | 1    | 103     |        |
| 73   | 1    | 20      |        |
| 75   | 1    | 77      |        |
| 79   | 1    | 1000    |        |
| 81   | 1    | ***0*** |        |
| 82   | 1    | ***0*** |        |
| 84   | 1    | 1000    |        |

Toggle Coverage:

| Enabled Coverage | Bins | Hits | Misses | Coverage |
|------------------|------|------|--------|----------|
| Toggles          | 166  | 57   | 109    | 34.33%   |

#### =====Toggle Details=====

Toggle Coverage for instance /counter\_tb --

| Node                 | 1H->0L | 0L->1H | "Coverage" |
|----------------------|--------|--------|------------|
| ce                   | 1      | 1      | 100.00     |
| clk                  | 1      | 1      | 100.00     |
| correct_count[0-8]   | 1      | 1      | 100.00     |
| correct_count[9]     | 0      | 1      | 50.00      |
| correct_count[10-31] | 0      | 0      | 0.00       |
| count_out[0-3]       | 1      | 1      | 100.00     |
| count_out_exp[0-3]   | 1      | 1      | 100.00     |
| data_load[0-3]       | 1      | 1      | 100.00     |
| error_count[0-31]    | 0      | 0      | 0.00       |
| load_n               | 1      | 1      | 100.00     |
| max_count            | 1      | 1      | 100.00     |
| rst_n                | 1      | 1      | 100.00     |
| up_down              | 1      | 1      | 100.00     |
| zero                 | 1      | 1      | 100.00     |

```

Total Node Count      =      83
Toggled Node Count   =      28
Untoggled Node Count =      55

Toggle Coverage      =      34.33% (57 of 166 bins)

=====
--- Instance: /PCK
--- Design Unit: work.PCK
=====

Covergroup Coverage:
  Covergroups          1      na      na  100.00%
  Coverpoints/Crosses  5      na      na      na
  Covergroup Bins     50      50      0   100.00%



| Covergroup                       | Metric  | Goal | Bins | Status  |
|----------------------------------|---------|------|------|---------|
| TYPE /PCK/E2/cg                  | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 50      | 50   | -    |         |
| missing/total bins:              | 0       | 50   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint load_cp               | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_up_c1           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_up_c2           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 1       | 1    | -    |         |
| missing/total bins:              | 0       | 1    | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_down_c1         | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_down_c2         | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 1       | 1    | -    |         |
| missing/total bins:              | 0       | 1    | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Covergroup instance \PCK::E2::cg | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 50      | 50   | -    |         |
| missing/total bins:              | 0       | 50   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint load_cp               | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| bin auto[0]                      | 50      | 1    | -    | Covered |
| bin auto[1]                      | 36      | 1    | -    | Covered |
| bin auto[2]                      | 43      | 1    | -    | Covered |
| bin auto[3]                      | 48      | 1    | -    | Covered |
| bin auto[4]                      | 50      | 1    | -    | Covered |
| bin auto[5]                      | 48      | 1    | -    | Covered |
| bin auto[6]                      | 50      | 1    | -    | Covered |
| bin auto[7]                      | 42      | 1    | -    | Covered |
| bin auto[8]                      | 40      | 1    | -    | Covered |
| bin auto[9]                      | 50      | 1    | -    | Covered |
| bin auto[10]                     | 47      | 1    | -    | Covered |
| bin auto[11]                     | 45      | 1    | -    | Covered |
| bin auto[12]                     | 44      | 1    | -    | Covered |
| bin auto[13]                     | 42      | 1    | -    | Covered |
| bin auto[14]                     | 35      | 1    | -    | Covered |
| bin auto[15]                     | 45      | 1    | -    | Covered |
| Coverpoint count_up_c1           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| bin auto[0]                      | 18      | 1    | -    | Covered |
| bin auto[1]                      | 25      | 1    | -    | Covered |
| bin auto[2]                      | 18      | 1    | -    | Covered |
| bin auto[3]                      | 26      | 1    | -    | Covered |
| bin auto[4]                      | 26      | 1    | -    | Covered |
| bin auto[5]                      | 18      | 1    | -    | Covered |
| bin auto[6]                      | 26      | 1    | -    | Covered |


```

```

Total Node Count      =       83
Toggled Node Count   =       28
Untoggled Node Count =       55

Toggle Coverage      =     34.33% (57 of 166 bins)

=====
== Instance: /PCK
== Design Unit: work.PCK
=====

Covergroup Coverage:
  Covergroups          1      na      na  100.00%
    Coverpoints/Crosses 5      na      na   na
      Covergroup Bins  50      50      0  100.00%



| Covergroup                       | Metric  | Goal | Bins | Status  |
|----------------------------------|---------|------|------|---------|
| TYPE /PCK/E2/cg                  | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 50      | 50   | -    |         |
| missing/total bins:              | 0       | 50   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint load_cp               | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_up_c1           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_up_c2           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 1       | 1    | -    |         |
| missing/total bins:              | 0       | 1    | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_down_c1         | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint count_down_c2         | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 1       | 1    | -    |         |
| missing/total bins:              | 0       | 1    | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Covergroup instance \PCK::E2::cg | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 50      | 50   | -    |         |
| missing/total bins:              | 0       | 50   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| Coverpoint load_cp               | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| bin auto[0]                      | 50      | 1    | -    | Covered |
| bin auto[1]                      | 36      | 1    | -    | Covered |
| bin auto[2]                      | 43      | 1    | -    | Covered |
| bin auto[3]                      | 48      | 1    | -    | Covered |
| bin auto[4]                      | 50      | 1    | -    | Covered |
| bin auto[5]                      | 48      | 1    | -    | Covered |
| bin auto[6]                      | 50      | 1    | -    | Covered |
| bin auto[7]                      | 42      | 1    | -    | Covered |
| bin auto[8]                      | 40      | 1    | -    | Covered |
| bin auto[9]                      | 50      | 1    | -    | Covered |
| bin auto[10]                     | 47      | 1    | -    | Covered |
| bin auto[11]                     | 45      | 1    | -    | Covered |
| bin auto[12]                     | 44      | 1    | -    | Covered |
| bin auto[13]                     | 42      | 1    | -    | Covered |
| bin auto[14]                     | 35      | 1    | -    | Covered |
| bin auto[15]                     | 45      | 1    | -    | Covered |
| Coverpoint count_up_c1           | 100.00% | 100  | -    | Covered |
| covered/total bins:              | 16      | 16   | -    |         |
| missing/total bins:              | 0       | 16   | -    |         |
| % Hit:                           | 100.00% | 100  | -    |         |
| bin auto[0]                      | 18      | 1    | -    | Covered |
| bin auto[1]                      | 25      | 1    | -    | Covered |
| bin auto[2]                      | 18      | 1    | -    | Covered |
| bin auto[3]                      | 26      | 1    | -    | Covered |
| bin auto[4]                      | 26      | 1    | -    | Covered |
| bin auto[5]                      | 18      | 1    | -    | Covered |
| bin auto[6]                      | 26      | 1    | -    | Covered |


```

|                                 |                |            |        |          |
|---------------------------------|----------------|------------|--------|----------|
| bin auto[1]                     | 23             | 1          | -      | Covered  |
| bin auto[8]                     | 21             | 1          | -      | Covered  |
| bin auto[9]                     | 27             | 1          | -      | Covered  |
| bin auto[10]                    | 24             | 1          | -      | Covered  |
| bin auto[11]                    | 17             | 1          | -      | Covered  |
| bin auto[12]                    | 23             | 1          | -      | Covered  |
| bin auto[13]                    | 28             | 1          | -      | Covered  |
| bin auto[14]                    | 15             | 1          | -      | Covered  |
| bin auto[15]                    | 20             | 1          | -      | Covered  |
| <b>Coverpoint count_up_c2</b>   | <b>100.00%</b> | <b>100</b> | -      | Covered  |
| covered/total bins:             | 1              | 1          | -      |          |
| missing/total bins:             | 0              | 1          | -      |          |
| % Hit:                          | 100.00%        | 100        | -      |          |
| bin trans_overflow              | 1              | 1          | -      | Covered  |
| <b>Coverpoint count_down_c1</b> | <b>100.00%</b> | <b>100</b> | -      | Covered  |
| covered/total bins:             | 16             | 16         | -      |          |
| missing/total bins:             | 0              | 16         | -      |          |
| % Hit:                          | 100.00%        | 100        | -      |          |
| bin auto[0]                     | 23             | 1          | -      | Covered  |
| bin auto[1]                     | 16             | 1          | -      | Covered  |
| bin auto[2]                     | 26             | 1          | -      | Covered  |
| bin auto[3]                     | 24             | 1          | -      | Covered  |
| bin auto[4]                     | 15             | 1          | -      | Covered  |
| bin auto[5]                     | 24             | 1          | -      | Covered  |
| bin auto[6]                     | 19             | 1          | -      | Covered  |
| bin auto[7]                     | 13             | 1          | -      | Covered  |
| bin auto[8]                     | 18             | 1          | -      | Covered  |
| bin auto[9]                     | 20             | 1          | -      | Covered  |
| bin auto[10]                    | 18             | 1          | -      | Covered  |
| bin auto[11]                    | 18             | 1          | -      | Covered  |
| bin auto[12]                    | 22             | 1          | -      | Covered  |
| bin auto[13]                    | 15             | 1          | -      | Covered  |
| bin auto[14]                    | 18             | 1          | -      | Covered  |
| bin auto[15]                    | 34             | 1          | -      | Covered  |
| <b>Coverpoint count_down_c2</b> | <b>100.00%</b> | <b>100</b> | -      | Covered  |
| covered/total bins:             | 1              | 1          | -      |          |
| missing/total bins:             | 0              | 1          | -      |          |
| % Hit:                          | 100.00%        | 100        | -      |          |
| bin trans_underflow             | 5              | 1          | -      | Covered  |
| <b>Statement Coverage:</b>      |                |            |        |          |
| Enabled Coverage                | Bins           | Hits       | Misses | Coverage |
| -----                           | -----          | -----      | -----  | -----    |
| Statements                      | 1              | 1          | 0      | 100.00%  |

#### =====Statement Details=====

Statement Coverage for instance /PCK --

| Line             | Item  | Count | Source |
|------------------|-------|-------|--------|
| -----            | ----- | ----- | -----  |
| File package.svh |       |       |        |
| 25               | 1     | 1     |        |

COVERGROUP COVERAGE:

| Covergroup                      | Metric         | Goal       | Bins  | Status  |
|---------------------------------|----------------|------------|-------|---------|
| -----                           | -----          | -----      | ----- | -----   |
| TYPE /PCK/E2/cg                 | 100.00%        | 100        | -     | Covered |
| covered/total bins:             | 50             | 50         | -     |         |
| missing/total bins:             | 0              | 50         | -     |         |
| % Hit:                          | 100.00%        | 100        | -     |         |
| <b>Coverpoint load_cp</b>       | <b>100.00%</b> | <b>100</b> | -     | Covered |
| covered/total bins:             | 16             | 16         | -     |         |
| missing/total bins:             | 0              | 16         | -     |         |
| % Hit:                          | 100.00%        | 100        | -     |         |
| <b>Coverpoint count_up_c1</b>   | <b>100.00%</b> | <b>100</b> | -     | Covered |
| covered/total bins:             | 16             | 16         | -     |         |
| missing/total bins:             | 0              | 16         | -     |         |
| % Hit:                          | 100.00%        | 100        | -     |         |
| <b>Coverpoint count_up_c2</b>   | <b>100.00%</b> | <b>100</b> | -     | Covered |
| covered/total bins:             | 1              | 1          | -     |         |
| missing/total bins:             | 0              | 1          | -     |         |
| % Hit:                          | 100.00%        | 100        | -     |         |
| <b>Coverpoint count_down_c1</b> | <b>100.00%</b> | <b>100</b> | -     | Covered |
| covered/total bins:             | 16             | 16         | -     |         |
| missing/total bins:             | 0              | 16         | -     |         |
| % Hit:                          | 100.00%        | 100        | -     |         |
| <b>Coverpoint count_down_c2</b> | <b>100.00%</b> | <b>100</b> | -     | Covered |
| covered/total bins:             | 1              | 1          | -     |         |

```

% Hit:                                100.00%
bin auto[0]                            50      1      -      Covered
bin auto[1]                            36      1      -      Covered
bin auto[2]                            43      1      -      Covered
bin auto[3]                            48      1      -      Covered
bin auto[4]                            50      1      -      Covered
bin auto[5]                            48      1      -      Covered
bin auto[6]                            50      1      -      Covered
bin auto[7]                            42      1      -      Covered
bin auto[8]                            40      1      -      Covered
bin auto[9]                            50      1      -      Covered
bin auto[10]                           47      1      -      Covered
bin auto[11]                           45      1      -      Covered
bin auto[12]                           44      1      -      Covered
bin auto[13]                           42      1      -      Covered
bin auto[14]                           35      1      -      Covered
bin auto[15]                           45      1      -      Covered
Coverpoint count_up_c1                100.00%   100      -      Covered
covered/total bins:                  16       16      -      -
missing/total bins:                 0        16      -      -
% Hit:                                100.00%
bin auto[0]                            18      1      -      Covered
bin auto[1]                            25      1      -      Covered
bin auto[2]                            18      1      -      Covered
bin auto[3]                            26      1      -      Covered
bin auto[4]                            26      1      -      Covered
bin auto[5]                            18      1      -      Covered
bin auto[6]                            26      1      -      Covered
bin auto[7]                            23      1      -      Covered
bin auto[8]                            21      1      -      Covered
bin auto[9]                            27      1      -      Covered
bin auto[10]                           24      1      -      Covered
bin auto[11]                           17      1      -      Covered
bin auto[12]                           23      1      -      Covered
bin auto[13]                           28      1      -      Covered
bin auto[14]                           15      1      -      Covered
bin auto[15]                           20      1      -      Covered
Coverpoint count_up_c2                100.00%   100      -      Covered
covered/total bins:                  1        1      -      -
missing/total bins:                 0        1      -      -
% Hit:                                100.00%
bin trans_overflow                   1        1      -      Covered
Coverpoint count_down_c1              100.00%   100      -      Covered
covered/total bins:                  16       16      -      -
missing/total bins:                 0        16      -      -
% Hit:                                100.00%
bin auto[0]                            23      1      -      Covered
bin auto[1]                            16      1      -      Covered
bin auto[2]                            26      1      -      Covered
bin auto[3]                            24      1      -      Covered
bin auto[4]                            15      1      -      Covered
bin auto[5]                            24      1      -      Covered
bin auto[6]                            19      1      -      Covered
bin auto[7]                            13      1      -      Covered
bin auto[8]                            18      1      -      Covered
bin auto[9]                            20      1      -      Covered
bin auto[10]                           18      1      -      Covered
bin auto[11]                           18      1      -      Covered
bin auto[12]                           22      1      -      Covered
bin auto[13]                           15      1      -      Covered
bin auto[14]                           18      1      -      Covered
bin auto[15]                           34      1      -      Covered
Coverpoint count_down_c2              100.00%   100      -      Covered
covered/total bins:                  1        1      -      -
missing/total bins:                 0        1      -      -
% Hit:                                100.00%
bin trans_underflow                  5        1      -      Covered

```

TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1

ASSERTION RESULTS:

| Name                                   | File(Line)         | Failure Count | Pass Count |
|----------------------------------------|--------------------|---------------|------------|
| /counter_tb/#ublk#95084642#39/immed_41 | counter_tb.svh(41) | 0             | 1          |

Total Coverage By Instance (filtered view): 85.76%

- 2) ALSU is a logic unit that can perform logical, arithmetic, and shift operations on input ports
- Input ports A and B have various operations that can take place depending on the value of the opcode.
  - Each input bit except for the clk and rst will be sampled at the rising edge before any processing so a D-FF is expected for each input bit at the design entry.
  - The output of the ALSU is registered and is available at the rising edge of the clock.



# Question 2

## I. Verification plan

| Label  | Design Requirement Description                                                                         | Stimulus Generation                                                                                                      | Functional Coverage                                                              | Functionality Check                                                                                  |
|--------|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| ALSU_1 | When reset is asserted, the outputs out and leds should be zero.                                       | Reset is asserted randomly during simulation, with constraints that drive it to be off 90% of the time.                  | Check all transitions of out and leds under reset condition.                     | A checker in the testbench ensures that out and leds are zero when reset is high.                    |
| ALSU_2 | When reset is deasserted, the output should match the operation defined by opcode with inputs A and B. | Randomized values of A, B, and opcode under constraints, with reset deasserted 90% of the time.                          | Cover all values and transitions of A, B, opcode, out, and leds.                 | A checker in the testbench ensures that out matches the expected operation result.                   |
| ALSU_3 | Ensure that the ALSU produces correct results for all operations (OR, XOR, ADD, MULT, SHIFT, ROTATE).  | Fully randomize inputs A, B, opcode, and control signals for multiple cycles.                                            | Cover all operations based on opcodes and ensure transition coverage.            | A checker in the testbench ensures the correctness of each operation based on opcode.                |
| ALSU_4 | Ensure correct handling of bypass_A and bypass_B, which should bypass inputs A and B respectively.     | Randomize bypass_A, bypass_B signals and check if the inputs are bypassed or processed according to the control signals. | Functional coverage of bypass scenarios with A and B.                            | A checker ensures that the output behaves correctly when either or both bypass signals are asserted. |
| ALSU_5 | Ensure correct handling of reduction operations on A and B using red_op_A and red_op_B.                | Randomly toggle reduction operation signals red_op_A and red_op_B and monitor the effect on the output.                  | Cover all possible combinations of reduction operations for inputs A and B.      | A checker ensures that reduction operations produce the correct results.                             |
| ALSU_6 | Test ALSU functionality under high toggle rates of clock and inputs (A, B, opcode, etc.).              | Rapidly toggle clock, inputs, and control signals to stress-test the ALSU's performance under frequent changes.          | Functional coverage for frequent changes in inputs and impact on output signals. | A checker ensures the design works reliably under rapid input and clock changes.                     |
| ALSU_7 | Ensure the correct behavior of the full adder when FULL_ADDER parameter is enabled/disabled.           | Enable and disable the full adder randomly during tests                                                                  | Ensure coverage of both FULL_ADDER on and off scenarios.                         | A checker ensures that carry is correctly handled when FULL_ADDER is enabled, and ignored otherwise. |
| ALSU_8 | Verify the ALSU's performance in handling overflow and underflow conditions in arithmetic operations.  | Randomize A and B values to stress-test for overflow and underflow in addition and multiplication operations.            | Cover all corner cases of overflow and underflow for arithmetic operations.      | A checker ensures that overflow/underflow conditions are handled correctly without errors.           |

## II. RTL design

```
1 module ALSU(A, B, cin, serial_in, red_op_A, red_op_B, opcode, bypass_A, bypass_B, clk, rst, direction, leds, out);
2 parameter INPUT_PRIORITY = "A";
3 parameter FULL_ADDER = "ON";
4 input clk, rst, red_op_A, red_op_B, bypass_A, bypass_B, direction, serial_in;
5 input [2:0] opcode;
6 input signed cin;
7 input signed [2:0] A, B;
8 output reg [15:0] leds;
9 output reg signed [5:0] out;
10
11 reg red_op_A_reg, red_op_B_reg, bypass_A_reg, bypass_B_reg, direction_reg, serial_in_reg;
12 reg [2:0] opcode_reg;
13 reg signed [2:0] A_reg, B_reg;
14 reg signed cin_reg ;
15
16 wire invalid_red_op, invalid_opcode, invalid;
17
18 //Invalid handling
19 assign invalid_red_op = (red_op_A_reg | red_op_B_reg) & (opcode_reg[1] | opcode_reg[2]);
20 assign invalid_opcode = opcode_reg[1] & opcode_reg[2];
21 assign invalid = invalid_red_op | invalid_opcode;
22
23 //Registering input signals
24 always @(posedge clk or posedge rst) begin
25   if(rst) begin
26     cin_reg <= 0;
27     red_op_B_reg <= 0;
28     red_op_A_reg <= 0;
29     bypass_B_reg <= 0;
30     bypass_A_reg <= 0;
31     direction_reg <= 0;
32     serial_in_reg <= 0;
33     opcode_reg <= 0;
34     A_reg <= 0;
35     B_reg <= 0;
36   end else begin
37     cin_reg <= cin;
38     red_op_B_reg <= red_op_B;
39     red_op_A_reg <= red_op_A;
40     bypass_B_reg <= bypass_B;
41     bypass_A_reg <= bypass_A;
42     direction_reg <= direction;
43     serial_in_reg <= serial_in;
44     opcode_reg <= opcode;
45     A_reg <= A;
46     B_reg <= B;
47   end
48 end
49
50 //leds output blinking
51 always @(posedge clk or posedge rst) begin
52   if(rst) begin
53     leds <= 0;
54   end else begin
55     if (invalid)
56       leds <= ~leds;
57   end
58 end
```

```

59     | end
60   end
61
62   //ALSU output processing
63   always @(posedge clk or posedge rst) begin
64     if(rst) begin
65       out <= 0;
66     end
67     else begin
68       if (invalid)
69         out <= 0;
70       else if (bypass_A_reg && bypass_B_reg)
71         out <= (INPUT_PRIORITY == "A")? A_reg: B_reg;
72       else if (bypass_A_reg)
73         out <= A_reg;
74       else if (bypass_B_reg)
75         out <= B_reg;
76       else begin
77         case (opcode)
78           3'h0: begin
79             if (red_op_A_reg && red_op_B_reg)
80               out <= (INPUT_PRIORITY == "A") ? |A_reg : |B_reg;
81             else if (red_op_A_reg)
82               out <= |A_reg;
83             else if (red_op_B_reg)
84               out <= |B_reg;
85             else
86               out <= A_reg | B_reg;
87           end
88           3'h1: begin
89             if (red_op_A_reg && red_op_B_reg)
90               out <= (INPUT_PRIORITY == "A") ? ^A_reg : ^B_reg;
91             else if (red_op_A_reg)
92               out <= ^A_reg;
93             else if (red_op_B_reg)
94               out <= ^B_reg;
95             else
96               out <= A_reg ^ B_reg;
97           end
98           3'h2: begin
99             if (FULL_ADDER == "ON")
100               out <= A_reg + B_reg + cin_reg;
101             else out <= A_reg + B_reg;
102           end
103           3'h3: out <= A_reg * B_reg;
104           3'h4: begin
105             if (direction_reg)
106               out <= {out[4:0], serial_in_reg};
107             else
108               out <= {serial_in_reg, out[5:1]};
109           end
110           3'h5: begin
111             if (direction_reg)
112               out <= {out[4:0], out[5]};
113             else
114               out <= {out[0], out[5:1]};
115           end
116           default : out <= 0;
117
118         endcase
119       end
120     end
121   end
122
123 endmodule

```

### III. Golden Model

```
1 module ALSU_GM(A, B, cin, serial_in, red_op_A, red_op_B, opcode, bypass_A, bypass_B, clk, rst, direction, leds_expected, out_expected);
2 input clk, rst, red_op_A, red_op_B, bypass_A, bypass_B, direction, serial_in;
3 input [2: 0] opcode;
4 input signed cin;
5 input signed [2: 0] A, B;
6 output reg [15: 0] leds_expected;
7 output reg signed [5: 0] out_expected;
8 reg red_op_A_reg, red_op_B_reg, bypass_A_reg, bypass_B_reg, direction_reg, serial_in_reg;
9 reg [2: 0] opcode_reg;
10 reg signed [2: 0] A_reg,B_reg;
11 reg signed cin_reg;
12 wire invalid_red_op, invalid_opcode, invalid;
13 assign invalid_red_op = (red_op_A_reg | red_op_B_reg) & (opcode_reg[1] | opcode_reg[2]);
14 assign invalid_opcode = opcode_reg[1] & opcode_reg[2];
15 assign invalid = invalid_red_op | invalid_opcode;
16 always @(posedge clk or posedge rst) begin
17 if(rst) begin
18   cin_reg <= 0;
19   red_op_B_reg <= 0;
20   red_op_A_reg <= 0;
21   bypass_B_reg <= 0;
22   bypass_A_reg <= 0;
23   direction_reg <= 0;
24   serial_in_reg <= 0;
25   opcode_reg <= 0;
26   A_reg <= 0;
27   B_reg <= 0;
28 end else begin
29   cin_reg <= cin;
30   red_op_B_reg <= red_op_B;
31   red_op_A_reg <= red_op_A;
32   bypass_B_reg <= bypass_B;
33   bypass_A_reg <= bypass_A;
34   direction_reg <= direction;
35   serial_in_reg <= serial_in;
36   opcode_reg <= opcode;
37   A_reg <= A;
38   B_reg <= B;
39 end
40 end
41 always @(posedge clk or posedge rst) begin
42 if(rst) begin
43   leds_expected <= 0;
44 end else begin
45   if (invalid)
46     leds_expected <= ~leds_expected;
47   else
48     leds_expected <= 0;
49 end
50 end
51 always @(posedge clk or posedge rst) begin
52 if(rst) begin
53   out_expected <= 0;
54 end
55 else begin
56   if (invalid)
57     out_expected <= 0;
58   else if (bypass_A_reg && bypass_B_reg)
59     out_expected <= A_reg ;
60   else if (bypass_A_reg)
```

```
61  out_expected <= A_reg ;
62  else if (bypass_B_reg)
63  out_expected <= B_reg ;
64  else begin
65    case (opcode)
66      3'h0:
67        if (red_op_A_reg && red_op_B_reg)
68          out_expected = |A_reg;
69        else if (red_op_A_reg)
70          out_expected <= |A_reg;
71        else if (red_op_B_reg)
72          out_expected <= |B_reg;
73        else
74          out_expected <= A_reg | B_reg;
75      3'h1:
76        if (red_op_A_reg && red_op_B_reg)
77          out_expected <= ^A_reg;
78        else if (red_op_A_reg)
79          out_expected <= ^A_reg;
80        else if (red_op_B_reg)
81          out_expected <= ^B_reg;
82        else
83          out_expected <= A_reg ^ B_reg;
84      3'h2: out_expected <= A_reg + B_reg + cin_reg ;
85      3'h3: out_expected <= A_reg * B_reg;
86      3'h4:
87        if (direction_reg)
88          out_expected <= {out_expected[4: 0], serial_in_reg};
89        else
90          out_expected <= {serial_in_reg, out_expected[5: 1]};
91      3'h5:
92        if (direction_reg)
93          out_expected <= {out_expected[4: 0], out_expected[5]};
94        else
95          out_expected <= {out_expected[0], out_expected[5: 1]};
96      default: out_expected <= 0 ;
97    endcase
98  end
99  end
100 end
101 endmodule
102
```

## IV. Package

---

```
1 package pck;
2 typedef enum bit [2: 0] {OR, XOR, ADD, MULT, SHIFT,ROTATE,INVALID_6,INVALID_7} opcode_e ;
3 typedef enum bit [2: 0] {Or, Xor, Add, Mult, Shift,Rotate} opcode_valid_e ;
4
5 localparam MAXPOS = 3 ;
6 localparam MAXNEG = -4 ;
7 localparam ZERO = 0 ;
8 class Z;
9 rand bit rst_c , red_op_A_c , red_op_B_c , cin_c , serial_in_c , direction_c , bypass_A_c , bypass_B_c ;
10 rand bit signed [2: 0] A_c , B_c ;
11
12 rand opcode_e opcode_c;
13 rand opcode_valid_e array[6];
14 constraint c_RST {rst_c dist {0:/90 , 1:/10};}
15 constraint c_input_A {
16     if (opcode_c == ADD || opcode_c == MULT) {
17         A_c dist {
18             MAXPOS / 25,
19             MAXNEG / 25,
20             ZERO / 25,
21             {3'b001, 3'b010, 3'b101, 3'b110, 3'b111} / 25
22         };} else if ((opcode_c == OR || opcode_c == XOR) && red_op_A_c == 1) {B_c == 0;
23         A_c dist {
24             {3'b001, 3'b010, 3'b100} := 80,
25             {3'b000, 3'b011, 3'b101, 3'b110, 3'b111} := 20
26         };} else {
27             A_c inside {[MAXNEG: MAXPOS]};}}
28 constraint c_input_B {
29     if (opcode_c == ADD || opcode_c == MULT) {
30         B_c dist {
31             MAXPOS / 25,
32             MAXNEG / 25,
33             ZERO / 25,
34             {3'b001, 3'b010, 3'b101, 3'b110, 3'b111} / 25};
35     } else if ((opcode_c == OR || opcode_c == XOR) && red_op_A_c == 1) {
36         A_c == 0;
37         B_c dist {
38             {3'b001, 3'b010, 3'b100} := 80,
39             {3'b000, 3'b011, 3'b101, 3'b110, 3'b111} := 20 };}
40     else {B_c inside {[MAXNEG: MAXPOS]};}}
41 constraint c_opcode { opcode_c dist { [0: 5]:/90 ,[6: 7]:/10 }; };
42 constraint c_bypass_signals {bypass_A_c dist { 0:/90 , 1:/10 };bypass_B_c dist { 0:/90 , 1:/10 };};
43 // Additional constraints to ensure all branches are covered
44 constraint all_branches {
45     // Test all combinations for bypass signals and red_op signals
46     if (opcode_c == ADD || opcode_c == MULT) {
47         red_op_A_c dist {0:/50, 1:/50};
48         red_op_B_c dist {0:/50, 1:/50};}
49     // For OR and XOR operations
50     if (opcode_c == OR || opcode_c == XOR) {
```

```

51 // Test if red_op_A_c is true
52 if (red_op_A_c == 1) {
53     | A_c dist { {3'b001, 3'b010, 3'b100} := 80, {3'b000, 3'b011, 3'b101, 3'b110, 3'b111} := 20 };B_c == 0;}
54 // Test if red_op_B_c is true
55 if (red_op_B_c == 1) (B_c dist { {3'b001, 3'b010, 3'b100} := 80, {3'b000, 3'b011, 3'b101, 3'b110, 3'b111} := 20 }; A_c == 0;))
56 constraint c_array {foreach (array[i]) {foreach (array[j]) {if (i != j) {array[i] != array[j];}}}}
57
58 covergroup cg ;
59 A_cp: coverpoint A_c
60 {
61 bins data_0 = {ZERO};
62 bins data_max = {MAXPOS};
63 bins data_min = {MAXNEG};
64 bins data_walkingones = {3'b001,3'b010,3'b100};
65 bins data_default = default ;
66 }
67 B_cp: coverpoint B_c
68 {
69 bins data_0 = {ZERO};
70 bins data_max = {MAXPOS};
71 bins data_min = {MAXNEG};
72 bins data_walkingones = {3'b001,3'b010,3'b100};
73 bins data_default = default ;
74 }
75 ALU_cp: coverpoint opcode_c
76 {
77 bins Bins_shift[] = {SHIFT, ROTATE};
78 bins Bins_arith[] = {ADD, MULT};
79 bins Bins_bitwise[] = {OR, XOR};
80 illegal_bins Bins_invalid = {INVALID_6,INVALID_7};
81 bins Bins_trans = (OR => XOR => ADD => MULT => SHIFT => ROTATE);
82 }
83
84 endgroup
85 function new();
86     cg = new();
87 endfunction
88 endclass
89
90 endpackage
91

```

## V. Test Bench

```
1 import pck::*;

2 
3 module ALSU_TB;
4     // Parameters declaration
5     parameter INPUT_PRIORITY = "A";
6     parameter FULL_ADDER = "ON";

7 
8     // Inputs/Outputs declaration
9     logic clk, rst, cin, red_op_A, red_op_B, bypass_A, bypass_B, direction, serial_in;
10    logic [2:0] opcode;
11    logic signed [2:0] A, B;
12    logic [15:0] leds;
13    logic signed [5:0] out;
14    logic signed [5:0] out_expected;
15    logic [15:0] leds_expected;
16    opcode_valid_e opvalid[6];

17 
18     // Create object from the class
19     Z obj;
20     int error_count, correct_count;

21 
22     // Module instantiation for Design and Golden Model
23     ALSU #(.INPUT_PRIORITY(INPUT_PRIORITY), .FULL_ADDER(FULL_ADDER)) DUT (.*);
24     ALSU_GM DUT2(.*);

25 
26     // Clock generation
27 initial begin
28     clk = 0;
29     forever #25 clk = ~clk;
30 end

31 
32     // Main program block
33 initial begin
34     obj = new();
35     error_count = 0;
36     correct_count = 0;

37 
38     // First part with loop
39     obj.c_array.constraint_mode(0);
40     for(int i = 0; i < 10000; i++) begin
41         @ (negedge clk);
42         assert(obj.randomize());
43         rst = obj.rst_c;
44         cin = obj.cin_c;
45         red_op_A = obj.red_op_A_c;
46         red_op_B = obj.red_op_B_c;
47         bypass_A = obj.bypass_A_c;
48         bypass_B = obj.bypass_B_c;
49         direction = obj.direction_c;
50         serial_in = obj.serial_in_c;
51         opcode = obj.opcode_c;
52         A = obj.A_c;
53         B = obj.B_c;
54         sample_data();
55         golden_model();
56     end

```

```

58 // Second part with loop
59 obj.constraint_mode(0);
60 obj.c_array.constraint_mode(1);
61
62 // Force reduction operation and bypass to zeros
63 red_op_A = 0;
64 red_op_B = 0;
65 bypass_A = 0;
66 bypass_B = 0;
67
68 for(int i = 0; i < 10000; i++) begin
69     @(negedge clk);
70     assert(obj.randomize());
71     rst = obj.rst_c;
72     cin = obj.cin_c;
73     red_op_A = obj.red_op_A_c;
74     red_op_B = obj.red_op_B_c;
75     bypass_A = obj.bypass_A_c;
76     bypass_B = obj.bypass_B_c;
77     direction = obj.direction_c;
78     serial_in = obj.serial_in_c;
79     A = obj.A_c;
80     B = obj.B_c;
81
82 for(int j = 0; j < 6; j++) begin
83     opvalid[j] = obj.array[j];
84     opcode = opvalid[j];
85     #25 sample_data();
86     end
87     sample_data();
88     golden_model();
89 end
90 // Direct case to hit the transition bin
91 // Initialize coverage collection
92 obj.cg.start();
93
94 // Test transitions from opcode 0 to 5
95 obj.opcode_c = opcode_e'(3'b000); // OR
96 opcode = 3'b000;
97 @(negedge clk);
98 #25; // Wait for half a clock period
99 obj.cg.sample();
100
101 obj.opcode_c = opcode_e'(3'b001); // XOR
102 opcode = 3'b001;
103 @(negedge clk);
104 #25;
105 obj.cg.sample();
106
107 obj.opcode_c = opcode_e'(3'b010); // ADD
108 opcode = 3'b010;
109 @(negedge clk);
110 #25;
111 obj.cg.sample();

```

```

11    obj.cg.sample();
12
13    obj.opcode_c = opcode_e'(3'b011); // MULT
14    opcode = 3'b011;
15    @ (negedge clk);
16    #25;
17    obj.cg.sample();
18
19    obj.opcode_c = opcode_e'(3'b100); // SHIFT
20    opcode = 3'b100;
21    @ (negedge clk);
22    #25;
23    obj.cg.sample();
24
25    obj.opcode_c = opcode_e'(3'b101); // ROTATE
26    opcode = 3'b101;
27    @ (negedge clk);
28    #25;
29    obj.cg.sample();
30    $display("correct counter = %0d , error counter = %0d", correct_count, error_count);
31    $stop;
32 end
33
34 task sample_data();
35   if (rst == 1 || bypass_A == 1 || bypass_B == 1) begin
36     obj.cg.stop();
37   end else begin
38     obj.cg.start();
39     obj.cg.sample();
40   end
41 endtask
42
43 task golden_model();
44   @ (negedge clk);
45   if (out != out_expected || leds != leds_expected) begin
46     $display("Incorrect result!! A=%0d, B=%0d, opcode=%0b, out=%0d, out_expected=%0d, leds=%0b, leds_expected=%0b", A, B, opcode, out, out_expected, leds, leds_expected);
47     error_count++;
48   end else begin
49     correct_count++;
50   end
51 endtask
52
53 endmodule
54
55

```

## VI. Print

---

```

** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1820.
Time: 2303075 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1821.
Time: 2303100 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1822.
Time: 2303125 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1823.
Time: 2303150 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1824.
Time: 2303175 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1825.
Time: 2303200 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1826.
Time: 2303225 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1827.
Time: 2307575 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1828.
Time: 2307600 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1829.
Time: 2307625 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1830.
Time: 2307650 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1831.
Time: 2307675 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1832.
Time: 2307700 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1833.
Time: 2307725 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1834.
Time: 2315325 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1835.
Time: 2315350 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1836.
Time: 2315375 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1837.
Time: 2315400 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1838.
Time: 2315425 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1839.
Time: 2315450 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1840.
Time: 2315475 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1841.
Time: 2364325 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\pck::Z::cg .ALU_cp.Bins_invalid' is 1842.
Time: 2364350 ns Iteration: 0 Instance: /ALSU_TB

```

```

** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1797.
Time: 2280950 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1798.
Time: 2280950 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1799.
Time: 2282575 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1800.
Time: 2282600 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1801.
Time: 2282625 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1802.
Time: 2282650 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1803.
Time: 2282675 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1804.
Time: 2282700 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1805.
Time: 2282700 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1806.
Time: 2297325 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1807.
Time: 2297350 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1808.
Time: 2297375 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1809.
Time: 2297400 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1810.
Time: 2297425 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1811.
Time: 2297450 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_6. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1812.
Time: 2297450 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1813.
Time: 2301325 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1814.
Time: 2301350 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1815.
Time: 2301375 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1816.
Time: 2301400 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1817.
Time: 2301425 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1818.
Time: 2301450 ns Iteration: 0 Instance: /ALSU_TB
** Error: (vsim-8565) Illegal state bin was hit at value=INVALID_7. The bin counter for the illegal bin '\/pck::Z::cg .ALU_cp.Bins_invalid' is 1819.

```

## VII. Do file

---

```

1 vlib work
2 vlog ALSU.v Package.sv ALSU_GM.svh ALSU_TB.sv +cover -covercells
3 vsim -voptargs=+acc work.ALSU_TB -cover
4 add wave *
5 coverage save ALSU_TB.ucdb -onexit -du work.ALSU
6 run -all

```

## VIII. Waveform



## IX. Functional Coverage Report

```
|Coverage Report by instance with details
=====
== Instance: /pck
== Design Unit: work.pck
=====

Covergroup Coverage:
  Covergroups      1      na      na  100.00%
  Coverpoints/Crosses  3      na      na      na
  Covergroup Bins   15      15      0  100.00%

Covergroup          Metric    Goal     Bins  Status
-----
```

| Covergroup                                                | Metric  | Goal | Bins | Status   |
|-----------------------------------------------------------|---------|------|------|----------|
| TYPE /pck/Z/cg                                            | 100.00% | 100  | -    | Covered  |
| covered/total bins:                                       | 15      | 15   | -    |          |
| missing/total bins:                                       | 0       | 15   | -    |          |
| % Hit:                                                    | 100.00% | 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:                                       | 7       | 7    | -    |          |
| missing/total bins:                                       | 0       | 7    | -    |          |
| % Hit:                                                    | 100.00% | 100  | -    |          |
| Covergroup instance \/pck::Z::cg                          | 100.00% | 100  | -    | Covered  |
| covered/total bins:                                       | 15      | 15   | -    |          |
| missing/total bins:                                       | 0       | 15   | -    |          |
| % Hit:                                                    | 100.00% | 100  | -    |          |
| Coverpoint A_cp                                           | 100.00% | 100  | -    | Covered  |
| covered/total bins:                                       | 4       | 4    | -    |          |
| missing/total bins:                                       | 0       | 4    | -    |          |
| % Hit:                                                    | 100.00% | 100  | -    |          |
| bin data_0                                                | 3913    | 1    | -    | Covered  |
| bin data_max                                              | 1928    | 1    | -    | Covered  |
| bin data_min                                              | 1761    | 1    | -    | Covered  |
| bin data_walkingones                                      | 3529    | 1    | -    | Covered  |
| default bin data_default                                  | 5231    | -    | -    | Occurred |
| Coverpoint B_cp                                           | 100.00% | 100  | -    | Covered  |
| covered/total bins:                                       | 4       | 4    | -    |          |
| missing/total bins:                                       | 0       | 4    | -    |          |
| % Hit:                                                    | 100.00% | 100  | -    |          |
| bin data_0                                                | 3964    | 1    | -    | Covered  |
| bin data_max                                              | 1739    | 1    | -    | Covered  |
| bin data_min                                              | 1786    | 1    | -    | Covered  |
| bin data_walkingones                                      | 3321    | 1    | -    | Covered  |
| default bin data_default                                  | 5632    | -    | -    | Occurred |
| Coverpoint ALU_cp                                         | 100.00% | 100  | -    | Covered  |
| covered/total bins:                                       | 7       | 7    | -    |          |
| missing/total bins:                                       | 0       | 7    | -    |          |
| % Hit:                                                    | 100.00% | 100  | -    |          |
| illegal_bin Bins_invalid                                  | 2939    | -    | -    | Occurred |
| bin Bins_shift[SHIFT]                                     | 2238    | 1    | -    | Covered  |
| bin Bins_shift[ROTATE]                                    | 2144    | 1    | -    | Covered  |
| bin Bins_arith[ADD]                                       | 2209    | 1    | -    | Covered  |
| bin Bins_arith[MULT]                                      | 2390    | 1    | -    | Covered  |
| bin Bins_bitwise[OR]                                      | 2240    | 1    | -    | Covered  |
| bin Bins_bitwise[XOR]                                     | 2202    | 1    | -    | Covered  |
| bin Bins_trans                                            | 1       | 1    | -    | Covered  |
| COVERGROUP COVERAGE:                                      |         |      |      |          |
| Covergroup          Metric    Goal     Bins  Status ----- |         |      |      |          |
| TYPE /pck/Z/cg                                            | 100.00% | 100  | -    | Covered  |
| covered/total bins:                                       | 15      | 15   | -    |          |
| missing/total bins:                                       | 0       | 15   | -    |          |
| % Hit:                                                    | 100.00% | 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:                                       | 7       | 7    | -    |          |
| missing/total bins:                                       | 0       | 7    | -    |          |
| % Hit:                                                    | 100.00% | 100  | -    |          |

|                                         | % Hit:  | covered/total bins: | missing/total bins: | - | -        |
|-----------------------------------------|---------|---------------------|---------------------|---|----------|
| <b>Covergroup instance \/pck::Z::cg</b> | 100.00% | 100                 | -                   | - | Covered  |
| covered/total bins:                     | 15      | 15                  | -                   | - |          |
| missing/total bins:                     | 0       | 15                  | -                   | - |          |
| % Hit:                                  | 100.00% | 100                 | -                   | - |          |
| <b>Coverpoint A_cp</b>                  | 100.00% | 100                 | -                   | - | Covered  |
| covered/total bins:                     | 4       | 4                   | -                   | - |          |
| missing/total bins:                     | 0       | 4                   | -                   | - |          |
| % Hit:                                  | 100.00% | 100                 | -                   | - |          |
| bin data_0                              | 3913    | 1                   | -                   | - | Covered  |
| bin data_max                            | 1928    | 1                   | -                   | - | Covered  |
| bin data_min                            | 1761    | 1                   | -                   | - | Covered  |
| bin data_walkingones                    | 3529    | 1                   | -                   | - | Covered  |
| default bin data_default                | 5231    | -                   | -                   | - | Occurred |
| <b>Coverpoint B_cp</b>                  | 100.00% | 100                 | -                   | - | Covered  |
| covered/total bins:                     | 4       | 4                   | -                   | - |          |
| missing/total bins:                     | 0       | 4                   | -                   | - |          |
| % Hit:                                  | 100.00% | 100                 | -                   | - |          |
| bin data_0                              | 3964    | 1                   | -                   | - | Covered  |
| bin data_max                            | 1739    | 1                   | -                   | - | Covered  |
| bin data_min                            | 1786    | 1                   | -                   | - | Covered  |
| bin data_walkingones                    | 3321    | 1                   | -                   | - | Covered  |
| default bin data_default                | 5632    | -                   | -                   | - | Occurred |
| <b>Coverpoint ALU_cp</b>                | 100.00% | 100                 | -                   | - | Covered  |
| covered/total bins:                     | 7       | 7                   | -                   | - |          |
| missing/total bins:                     | 0       | 7                   | -                   | - |          |
| % Hit:                                  | 100.00% | 100                 | -                   | - |          |
| illegal_bin Bins_invalid                | 2939    | -                   | -                   | - | Occurred |
| bin Bins_shift[SHIFT]                   | 2238    | 1                   | -                   | - | Covered  |
| bin Bins_shift[ROTATE]                  | 2144    | 1                   | -                   | - | Covered  |
| bin Bins_arith[ADD]                     | 2209    | 1                   | -                   | - | Covered  |
| bin Bins_arith[MULT]                    | 2390    | 1                   | -                   | - | Covered  |
| bin Bins_bitwise[OR]                    | 2240    | 1                   | -                   | - | Covered  |
| bin Bins_bitwise[XOR]                   | 2202    | 1                   | -                   | - | Covered  |
| bin Bins_trans                          | 1       | 1                   | -                   | - | Covered  |

TOTAL COVERGROUP COVERAGE: 100.00% COVERGROUP TYPES: 1

Total Coverage By Instance (filtered view): 100.00%

## X. Coverage Report

```
Coverage Report by instance with details

=====
== Instance: /\ALSU_TB#DUT
== Design Unit: work.ALSU
=====

Branch Coverage:
  Enabled Coverage      Bins     Hits    Misses  Coverage
  -----      -----      -----      -----
  Branches          32       32        0   100.00%
=====

=====Branch Details=====

Branch Coverage for instance /\ALSU_TB#DUT

  Line      Item      Count      Source
  ----      ----      -----      -----
  File ALSU.v
  -----IF Branch-----
  25           57411      Count coming in to IF
  25           19406
  36           38005
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  52           73450      Count coming in to IF
  52           30396
  54           43054
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  55           43054      Count coming in to IF
  55           20642
  57           22412
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  64           56742      Count coming in to IF
  64           19394
  67           37348
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  68           37348      Count coming in to IF
  68           17678
  70           2056
  72           2789
  74           2766
  76           12059
Branch totals: 5 hits of 5 branches = 100.00%
  -----CASE Branch-----
  77           12059      Count coming in to CASE
  78           2595
  88           2544
  98           1592
  103          1589
  104          1651
  110          1696
  116          392
Branch totals: 7 hits of 7 branches = 100.00%
  -----IF Branch-----
  79           2595      Count coming in to IF
  79           109
  81           106
  83           112
  85           2268
Branch totals: 4 hits of 4 branches = 100.00%
  -----IF Branch-----
  89           2544      Count coming in to IF
  89           106
  91           94
  93           77
  95           2267
Branch totals: 4 hits of 4 branches = 100.00%
  -----IF Branch-----
  105          1651      Count coming in to IF
  105          549
  107          1102
Branch totals: 2 hits of 2 branches = 100.00%
  -----IF Branch-----
  111          1696      Count coming in to IF
  111          573
  113          1123
Branch totals: 2 hits of 2 branches = 100.00%
```

```

Condition Coverage:
  Enabled Coverage      Bins   Covered   Misses   Coverage
  -----      -----   -----   -----
  Conditions          6       6        0    100.00%
=====
=====Condition Details=====
Condition Coverage for instance /\ALSU_TB#DUT --
File ALSU.v
--Focused Condition View--
Line    78 Item  1 (bypass_A_reg && bypass_B_reg)
Condition totals: 2 of 2 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----      -----   -----
  bypass_A_reg      Y
  bypass_B_reg      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----      -----
  Row  1:      1  bypass_A_reg_0      -
  Row  2:      1  bypass_A_reg_1      bypass_B_reg
  Row  3:      1  bypass_B_reg_0      bypass_A_reg
  Row  4:      1  bypass_B_reg_1      bypass_A_reg

--Focused Condition View--
Line    79 Item  1 (red_op_A_reg && red_op_B_reg)
Condition totals: 2 of 2 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----      -----   -----
  red_op_A_reg      Y
  red_op_B_reg      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----      -----
  Row  1:      1  red_op_A_reg_0      -
  Row  2:      1  red_op_A_reg_1      red_op_B_reg
  Row  3:      1  red_op_B_reg_0      red_op_A_reg
  Row  4:      1  red_op_B_reg_1      red_op_A_reg

--Focused Condition View--
Line    89 Item  1 (red_op_A_reg && red_op_B_reg)
Condition totals: 2 of 2 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----      -----   -----
  red_op_A_reg      Y
  red_op_B_reg      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----      -----
  Row  1:      1  red_op_A_reg_0      -
  Row  2:      1  red_op_A_reg_1      red_op_B_reg
  Row  3:      1  red_op_B_reg_0      red_op_A_reg
  Row  4:      1  red_op_B_reg_1      red_op_A_reg

Expression Coverage:
  Enabled Coverage      Bins   Covered   Misses   Coverage
  -----      -----   -----   -----
  Expressions          8       8        0    100.00%
=====
=====Expression Details=====
Expression Coverage for instance /\ALSU_TB#DUT --
File ALSU.v
--Focused Expression View--
Line    19 Item  1 ((red_op_A_reg | red_op_B_reg) & (opcode_reg[1] | opcode_reg[2]))
Expression totals: 4 of 4 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----      -----   -----
  red_op_A_reg      Y
  red_op_B_reg      Y
  opcode_reg[1]      Y
  opcode_reg[2]      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----      -----
  Row  1:      1  red_op_A_reg_0      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_B_reg)
  Row  2:      1  red_op_A_reg_1      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_B_reg)
  Row  3:      1  red_op_B_reg_0      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_A_reg)
  Row  4:      1  red_op_B_reg_1      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_A_reg)
  Row  5:      1  opcode_reg[1]_0     ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[2])
  Row  6:      1  opcode_reg[1]_1     ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[2])
  Row  7:      1  opcode_reg[2]_0     ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[1])
  Row  8:      1  opcode_reg[2]_1     ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[1])

```

```

Condition Coverage:
  Enabled Coverage      Bins   Covered   Misses   Coverage
  -----  -----  -----
  Conditions          6       6        0    100.00%
=====Condition Details=====
Condition Coverage for instance /\ALSU_TB#DUT --
File ALSU.v
----- Focused Condition View-----
Line    70 Item   1 (bypass_A_reg && bypass_B_reg)
Condition totals: 2 of 2 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----  -----
  bypass_A_reg      Y
  bypass_B_reg      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----  -----
  Row  1:      1  bypass_A_reg_0      -
  Row  2:      1  bypass_A_reg_1      bypass_B_reg
  Row  3:      1  bypass_B_reg_0      bypass_A_reg
  Row  4:      1  bypass_B_reg_1      bypass_A_reg

----- Focused Condition View-----
Line    79 Item   1 (red_op_A_reg && red_op_B_reg)
Condition totals: 2 of 2 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----  -----
  red_op_A_reg      Y
  red_op_B_reg      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----  -----
  Row  1:      1  red_op_A_reg_0      -
  Row  2:      1  red_op_A_reg_1      red_op_B_reg
  Row  3:      1  red_op_B_reg_0      red_op_A_reg
  Row  4:      1  red_op_B_reg_1      red_op_A_reg

----- Focused Condition View-----
Line    89 Item   1 (red_op_A_reg && red_op_B_reg)
Condition totals: 2 of 2 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----  -----
  red_op_A_reg      Y
  red_op_B_reg      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----  -----
  Row  1:      1  red_op_A_reg_0      -
  Row  2:      1  red_op_A_reg_1      red_op_B_reg
  Row  3:      1  red_op_B_reg_0      red_op_A_reg
  Row  4:      1  red_op_B_reg_1      red_op_A_reg

Expression Coverage:
  Enabled Coverage      Bins   Covered   Misses   Coverage
  -----  -----  -----
  Expressions          8       8        0    100.00%
=====Expression Details=====
Expression Coverage for instance /\ALSU_TB#DUT --
File ALSU.v
----- Focused Expression View-----
Line    19 Item   1 ((red_op_A_reg | red_op_B_reg) & (opcode_reg[1] | opcode_reg[2]))
Expression totals: 4 of 4 input terms covered = 100.00%
  Input Term  Covered  Reason for no coverage  Hint
  -----  -----
  red_op_A_reg      Y
  red_op_B_reg      Y
  opcode_reg[1]      Y
  opcode_reg[2]      Y

  Rows:      Hits  FEC Target      Non-masking condition(s)
  -----  -----
  Row  1:      1  red_op_A_reg_0      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_B_reg)
  Row  2:      1  red_op_A_reg_1      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_B_reg)
  Row  3:      1  red_op_B_reg_0      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_A_reg)
  Row  4:      1  red_op_B_reg_1      ((opcode_reg[1] | opcode_reg[2]) && ~red_op_A_reg)
  Row  5:      1  opcode_reg[1]_0      ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[2])
  Row  6:      1  opcode_reg[1]_1      ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[2])
  Row  7:      1  opcode_reg[2]_0      ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[1])
  Row  8:      1  opcode_reg[2]_1      ((red_op_A_reg | red_op_B_reg) && ~opcode_reg[1])

```

```

-----Focused Expression View-----
Line      20 Item    1 (opcode_reg[1] & opcode_reg[2])
Expression totals: 2 of 2 input terms covered = 100.00%
Input Term   Covered  Reason for no coverage   Hint
----- -----
opcode_reg[1]       Y
opcode_reg[2]       Y

Rows:     Hits  FEC Target          Non-masking condition(s)
----- -----
Row  1:      1  opcode_reg[1]_0  opcode_reg[2]
Row  2:      1  opcode_reg[1]_1  opcode_reg[2]
Row  3:      1  opcode_reg[2]_0  opcode_reg[1]
Row  4:      1  opcode_reg[2]_1  opcode_reg[1]

-----Focused Expression View-----
Line      21 Item    1 (invalid_red_op | invalid_opcode)
Expression totals: 2 of 2 input terms covered = 100.00%
Input Term   Covered  Reason for no coverage   Hint
----- -----
invalid_red_op      Y
invalid_opcode      Y

Rows:     Hits  FEC Target          Non-masking condition(s)
----- -----
Row  1:      1  invalid_red_op_0  ~invalid_opcode
Row  2:      1  invalid_red_op_1  ~invalid_opcode
Row  3:      1  invalid_opcode_0  ~invalid_red_op
Row  4:      1  invalid_opcode_1  ~invalid_red_op

Statement Coverage:
Enabled Coverage           Bins     Hits     Misses   Coverage
----- -----  -----  -----  -----
Statements                  49        49        0   100.00%
=====Statement Details=====
Statement Coverage for instance /\ALSU_TB#DUT --

Line      Item          Count   Source
----  -----
File ALSU.v
19          1        26320
20          1        24812
21          1        13629
24          1        57411
26          1        19406
27          1        19406
28          1        19406
29          1        19406
30          1        19406
31          1        19406
32          1        19406
33          1        19406
34          1        19406
35          1        19406
37          1        38005
38          1        38005
39          1        38005
40          1        38005
41          1        38005
42          1        38005
43          1        38005
44          1        38005
45          1        38005
46          1        38005
51          1        73450
53          1        30396
56          1        20642
58          1        22412
63          1        56742
65          1        19394
69          1        17678
71          1        2056
73          1        2789
75          1        2766
80          1        109
82          1        106
84          1        112
86          1        2268
90          1        106
92          1        94
94          1        77
96          1        2267
100         1        1592
103         1        1589
106         1        549
108         1        1102
112         1        573
114         1        1123
116         1        392

Toggle Coverage:
Enabled Coverage           Bins     Hits     Misses   Coverage
----- -----  -----  -----  -----

```

| Toggles                                       | 120    | 120    | 0          | 100.00% |
|-----------------------------------------------|--------|--------|------------|---------|
| =====Toggle Details=====                      |        |        |            |         |
| Toggle Coverage for instance /\ALSU_TB#DUT -- |        |        |            |         |
| Node                                          | 1H->0L | 0L->1H | "Coverage" |         |
| A[0-2]                                        | 1      | 1      | 100.00     |         |
| A_reg[2-0]                                    | 1      | 1      | 100.00     |         |
| B[0-2]                                        | 1      | 1      | 100.00     |         |
| B_reg[2-0]                                    | 1      | 1      | 100.00     |         |
| bypass_A                                      | 1      | 1      | 100.00     |         |
| bypass_A_reg                                  | 1      | 1      | 100.00     |         |
| bypass_B                                      | 1      | 1      | 100.00     |         |
| bypass_B_reg                                  | 1      | 1      | 100.00     |         |
| cin                                           | 1      | 1      | 100.00     |         |
| cin_reg[1-0]                                  | 1      | 1      | 100.00     |         |
| clk                                           | 1      | 1      | 100.00     |         |
| direction                                     | 1      | 1      | 100.00     |         |
| direction_reg                                 | 1      | 1      | 100.00     |         |
| invalid                                       | 1      | 1      | 100.00     |         |
| invalid_opcode                                | 1      | 1      | 100.00     |         |
| invalid_red_op                                | 1      | 1      | 100.00     |         |
| leds[15-0]                                    | 1      | 1      | 100.00     |         |
| opcode[0-2]                                   | 1      | 1      | 100.00     |         |
| opcode_reg[2-0]                               | 1      | 1      | 100.00     |         |
| out[5-0]                                      | 1      | 1      | 100.00     |         |
| red_op_A                                      | 1      | 1      | 100.00     |         |
| red_op_A_reg                                  | 1      | 1      | 100.00     |         |
| red_op_B                                      | 1      | 1      | 100.00     |         |
| red_op_B_reg                                  | 1      | 1      | 100.00     |         |
| rst                                           | 1      | 1      | 100.00     |         |
| serial_in                                     | 1      | 1      | 100.00     |         |
| serial_in_reg                                 | 1      | 1      | 100.00     |         |

Total Node Count = 60  
Toggled Node Count = 60  
Untoggled Node Count = 0

Toggle Coverage = 100.00% (120 of 120 bins)

Total Coverage By Instance (filtered view): 100.00%

**Q3.** The design to be tested is a synchronous single-port 8-bit x64K (512kBit) RAM. The RAM will read on the positive edge of the clock when input read =1 and write on the positive edge of the clock when input write = 1. Write enable signal has a higher priority than the read enable signal and both write and read data from the RAM is not allowed at the same time. Even parity will be calculated on data written to the RAM and placed in the 9<sup>th</sup> bit of the memory. The partially completed memory model is below (add the memory declaration)

```
module my_mem(
    input clk,
    input write,
    input read,
    input [7:0] data_in,
    input [15:0] address,
    output reg [7:0] data_out
);

// Declare a 9-bit associative array using the logic data type & the key of int datatype
<Put your declaration here>

always @(posedge clk) begin
    if (write)
        mem_array[address] = {~^data_in, data_in};
    else if (read)
        data_out = mem_array[address];
end

endmodule
```

# Question 3

## I. Verification plan

| Label | Design Requirement Description                                                                                                 | Stimulus Generation                                                                                                   | Functional Coverage                                                                                                    | Functionality Check                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| RAM_1 | During a write operation, the correct data must be written to the RAM at the specified address.                                | Randomize address and data_in during the write operation to test a variety of addresses and data values.              | Ensure all possible address ranges and data values are covered, including boundary conditions (min and max addresses). | A checker verifies that the data is correctly written into the RAM at the given address.                                         |
| RAM_2 | During a read operation, the correct data must be read from the RAM at the specified address.                                  | Randomize the address and verify the data read from the RAM matches the expected data.                                | Ensure coverage for all addresses that were written and randomize read operations for different addresses.             | A checker verifies the data read from RAM matches the expected data stored at the address.                                       |
| RAM_3 | The data read from RAM should be consistent with the data written to it, and parity bit (^data_in) should be computed.         | Randomize data_in for write operations and compute parity to compare against expected values during read operations.  | Ensure parity bit correctness is validated for different data inputs across various addresses.                         | A checker compares the actual data and parity bit read from the RAM against the expected data and parity generated during write. |
| RAM_4 | After the last write operation, ensure the last value written is correctly read from the RAM before the read operation begins. | Apply a delay after the final write to ensure timing correctness between write and read operations.                   | Ensure that both the final write and first read operations are covered, especially at the edges of the test.           | A checker ensures the last written data is stored correctly and can be read back accurately after the last write.                |
| RAM_5 | Data should remain stable when no read or write operation is triggered (read and write both set to 0).                         | Generate test cases where no read or write operation is performed and ensure data remains unchanged during this time. | Ensure coverage for cases where the RAM is idle and no read or write operation is happening.                           | A checker verifies that data_out remains stable and no unintended read or write occurs when both read and write signals are low. |

## II. RTL design

---

```
1  module RAM(
2    input clk,
3    input write,
4    input read,
5    input [7: 0] data_in,
6    input [18: 0] address,
7
8    output reg [8: 0] data_out
9  );
10
11 logic [8: 0] mem_array [bit [18: 0]] ;
12 always @(posedge clk) begin
13   if (write)
14
15     mem_array[address] = {^data_in, data_in};
16   else if (read)
17     data_out = mem_array [address];
18   end
19 endmodule
```

## III. Test bench

---

```
1  module RAM_tb;
2    // Input and Output Declaration
3    logic clk, write, read;
4    logic [7:0] data_in;
5    logic [18:0] address;
6    logic [8:0] data_out;
7
8    localparam TESTS = 100;
9    // Error & Correct Counters
10   integer error_counter, correct_counter;
11
12   bit [18:0] address_array[];
13   bit [7:0] data_to_write_array[];
14   bit [8:0] data_read_expect_assoc[bit [18:0]];
15   bit [8:0] data_read_queue[$];
16
17   //Design Module Instantiation
18   | RAM DUT(.*);
19   //CLOCK GENERATION
20   initial begin
21     clk=0;
22     forever
23       #1 clk=~clk;
24     end
25     task stimulus_gen();
26       for (int i = 0 ; i < TESTS ; i++) begin
27         address_array[i] = $random;
28         data_to_write_array[i] = $random;
29       end
30     endtask
31     task golden_model();
32       for (int i = 0 ; i < TESTS ; i++)
33         data_read_expect_assoc[address_array[i]] = {^data_to_write_array[i], data_to_write_array[i]};
34     endtask
35     // Initial Values for Inputs & Main Block Operations
36   initial begin
37     address_array = new[TESTS];
38     data_to_write_array = new[TESTS];
39     // Initialize all Counters & Inputs to ZERO
40     error_counter = 0;
```

```

40 correct_counter = 0;
41 read = 0;
42 write = 0;
43 address = 0;
44 data_in = 0;
45 // Delay 1 Clock Cycles
46 repeat(1) @(negedge clk);
47 stimulus_gen();
48 golden_model();
49 // 100 Write Operations
50 write = 1;
51 for (int i = 0 ; i < TESTS ; i++) begin
52 @(negedge clk);
53 address = address_array[i];
54 data_in = data_to_write_array[i];
55 end
56 // Delay 1 Clock Cycles to Allow final Data to be Written in RAM
57 repeat(1) @(negedge clk);
58 // 100 Read Operations
59 write = 0;
60 read = 1;
61 address_array. reverse();
62 for (int i = 0 ; i < TESTS ; i++) begin
63 @(negedge clk);
64 address = address_array[i];
65 check_result(address);
66 data_read_queue. insert(i, data_out);
67 end
68 $display("Data Read From The Queue");
69 while (data_read_queue. size())
70 $display("At %0t ns: Data Read From Queue %0d", $time, data_read_queue. pop_front());
71 read = 0;
72 repeat(2) @(negedge clk);
73 $display("%0t: At End of test error counter = %0d and correct counter = %0d", $time, error_counter, correct_counter);
74 $stop;
75 end
76 task check_result(input bit [18: 0] Expected_Address);
77 @(negedge clk);
78 if (data_read_expect_assoc.exists(Expected_Address)) begin
79 if (data_out !== data_read_expect_assoc[Expected_Address]) begin
80 $display("%0t: Error: For Read Data %0h should be equal to %0h but it is not equal",$time, data_out, data_read_expect_assoc[address_array[Expected_Address]]);
81 error_counter++;
82 end
83 else
84 correct_counter++;
85 end
86 endtask
87
88 endmodule

```

## IV. Print

---

```
# At 604 ns: Data Read From Queue 417
# At 604 ns: Data Read From Queue 353
# At 604 ns: Data Read From Queue 377
# At 604 ns: Data Read From Queue 219
# At 604 ns: Data Read From Queue 120
# At 604 ns: Data Read From Queue 476
# At 604 ns: Data Read From Queue 438
# At 604 ns: Data Read From Queue 192
# At 604 ns: Data Read From Queue 311
# At 604 ns: Data Read From Queue 282
# At 604 ns: Data Read From Queue 250
# At 604 ns: Data Read From Queue 442
# At 604 ns: Data Read From Queue 368
# At 604 ns: Data Read From Queue 317
# At 604 ns: Data Read From Queue 390
# At 604 ns: Data Read From Queue 297
# At 604 ns: Data Read From Queue 284
# At 604 ns: Data Read From Queue 46
# At 604 ns: Data Read From Queue 45
# At 604 ns: Data Read From Queue 136
# At 604 ns: Data Read From Queue 105
# At 604 ns: Data Read From Queue 260
# At 604 ns: Data Read From Queue 149
# At 604 ns: Data Read From Queue 202
# At 604 ns: Data Read From Queue 365
# At 604 ns: Data Read From Queue 77
# At 604 ns: Data Read From Queue 89
# At 604 ns: Data Read From Queue 147
# At 604 ns: Data Read From Queue 184
# At 604 ns: Data Read From Queue 312
# At 604 ns: Data Read From Queue 10
# At 604 ns: Data Read From Queue 78
# At 604 ns: Data Read From Queue 195
# At 604 ns: Data Read From Queue 154
# At 604 ns: Data Read From Queue 270
# At 604 ns: Data Read From Queue 298
# At 604 ns: Data Read From Queue 68
# At 604 ns: Data Read From Queue 479
# At 604 ns: Data Read From Queue 101
# At 604 ns: Data Read From Queue 237
# At 604 ns: Data Read From Queue 90
# At 604 ns: Data Read From Queue 459
# At 604 ns: Data Read From Queue 68
# At 604 ns: Data Read From Queue 435
# At 604 ns: Data Read From Queue 163
# At 604 ns: Data Read From Queue 294
```

```
# At 604 ns: Data Read From Queue 156
# At 604 ns: Data Read From Queue 390
# At 604 ns: Data Read From Queue 298
# At 604 ns: Data Read From Queue 329
# At 604 ns: Data Read From Queue 120
# At 604 ns: Data Read From Queue 467
# At 604 ns: Data Read From Queue 57
# At 604 ns: Data Read From Queue 126
# At 604 ns: Data Read From Queue 317
# At 604 ns: Data Read From Queue 456
# At 604 ns: Data Read From Queue 12
# At 604 ns: Data Read From Queue 337
# At 604 ns: Data Read From Queue 464
# At 604 ns: Data Read From Queue 393
# At 604 ns: Data Read From Queue 92
# At 604 ns: Data Read From Queue 183
# At 604 ns: Data Read From Queue 399
# At 604 ns: Data Read From Queue 332
# At 604 ns: Data Read From Queue 473
# At 604 ns: Data Read From Queue 277
# At 604 ns: Data Read From Queue 58
# At 604 ns: Data Read From Queue 335
# At 604 ns: Data Read From Queue 113
# At 604 ns: Data Read From Queue 298
# At 604 ns: Data Read From Queue 430
# At 604 ns: Data Read From Queue 438
# At 604 ns: Data Read From Queue 393
# At 604 ns: Data Read From Queue 216
# At 604 ns: Data Read From Queue 394
# At 604 ns: Data Read From Queue 60
# At 604 ns: Data Read From Queue 10
# At 604 ns: Data Read From Queue 207
# At 604 ns: Data Read From Queue 430
# At 604 ns: Data Read From Queue 469
# At 604 ns: Data Read From Queue 83
# At 604 ns: Data Read From Queue 275
# At 604 ns: Data Read From Queue 413
# At 604 ns: Data Read From Queue 288
# At 604 ns: Data Read From Queue 10
# At 604 ns: Data Read From Queue 101
# At 604 ns: Data Read From Queue 189
# At 604 ns: Data Read From Queue 197
# At 604 ns: Data Read From Queue 462
# At 604 ns: Data Read From Queue 399
# At 604 ns: Data Read From Queue 119
# At 604 ns: Data Read From Queue 170
```

```

# At 604 ns: Data Read From Queue 198
# At 604 ns: Data Read From Queue 396
# At 604 ns: Data Read From Queue 317
# At 604 ns: Data Read From Queue 269
# At 604 ns: Data Read From Queue 18
# At 604 ns: Data Read From Queue 141
# At 604 ns: Data Read From Queue 99
# At 604 ns: Data Read From Queue 129
# 608: At End of test error counter = 0 and correct counter = 100

```

## V. Do file

---

```

vlib work
vlog RAM.sv RAM_tb.sv +cover -covercells
vsim -voptargs=+acc work.RAM_tb -cover
add wave *
coverage save RAM_tb.ucdb -onexit -du work.RAM
run -all

```

## VI. Waveform

---



## VII. Coverage Report

```
Branch Coverage:  
Enabled Coverage  
-----  
Branches 3 3 0 100.00%  
  
=====Branch Details=====  
Branch Coverage for instance /\RAM_tb#DUT  
  
Line Item Count Source  
--- --- ---  
File RAM.sv  
-----IF Branch-  
13 304 Count coming in to IF  
13 1 101  
16 1 200  
3 All False Count  
Branch totals: 3 hits of 3 branches = 100.00%  
  
Statement Coverage:  
Enabled Coverage  
-----  
Statements 3 3 0 100.00%  
  
=====Statement Details=====  
Statement Coverage for instance /\RAM_tb#DUT --  
  
Line Item Count Source  
--- --- ---  
File RAM.sv  
12 1 304  
15 1 101  
17 1 200  
Toggle Coverage:  
Enabled Coverage  
-----  
Toggles 78 78 0 100.00%  
  
=====Toggle Details=====  
Toggle Coverage for instance /\RAM_tb#DUT --  
Node 1H->0L 0L->1H "Coverage"  
-----  
address[0-18] 1 1 100.00  
clk 1 1 100.00  
data_in[0-7] 1 1 100.00  
data_out[8-0] 1 1 100.00  
read 1 1 100.00  
write 1 1 100.00  
  
Total Node Count = 39  
Toggled Node Count = 39  
Untoggled Node Count = 0  
Toggle Coverage = 100.00% (78 of 78 bins)  
Total Coverage By Instance (filtered view): 100.00%
```