# يوسف أحمد محمد ابراهيم

# **Assignment 1**

Extra

# Question 1:

#### 1. Design:

```
module dff(clk, rst, d, q, en);
     parameter USE_EN = 1;
     input clk, rst, d, en;
     output reg q;
 5
     always @(posedge clk) begin
 6
        if (rst)
            q <= 0;
        else
            if(USE_EN) begin
10
               if (en)
11
                  q <= d;
12
13
            end
           else
14
15
              q <= d;
16
    end
17
     endmodule
18
```

#### 2. verification plan:

| 1 | Label        | Design Requirement Description                                      | Stimulus Generation                                                                                                       | <b>Functional Coverage</b> | Functionality Check                                       |
|---|--------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------------------------------|
| 2 | RESET_TEST   | When the reset is asserted, outputs $\boldsymbol{C}$ should be low. | assert_reset() task that asserts rst<br>to1, wait then deassert rst to 0 at<br>the begining and end of the<br>simulation. | 8                          | check_result() task checks that output is 0 during reset. |
| 3 | WITH_EN_TEST | Output depends on <b>en</b> value, if en = 1, <b>q = D.</b>         | Directed test at en = 0, and at en = 1                                                                                    | 6                          | check_result() checks the value of q.                     |
| 4 | WITHOUT_EN_T | OUtput <b>q = D</b> whatever the value of en is.                    | Directed test at en = 0, and at en = 1                                                                                    | te .                       | check_result() checks the value of q.                     |

#### 3. Testbench 1 (USE\_EN = 1):

```
module DFF_tb1();
    logic clk;
logic rst;
    logic d;
    logic q;
    logic en;
    logic q_exp;
    integer correct_count, error_count;
   dff dut(clk, rst, d, q, en);
    always @(posedge clk, posedge rst) begin
        if(rst)
           q_exp <= 0;
        else if(en)
            q exp = d;
   end
    initial begin
        clk = 0;
            #1 clk = -clk;
   end
   initial begin
        correct count = 0;
        error_count = 0;
       d = 0;
       en = 0;
       rst = 1;
        check_result();
       rst = 0;
       //WITH_EN check
       d = 1;
check_result();
       check_result();
       d = 0;
       check_result();
       rst = 1;
       check_result();
        rst = 0;
        $display("*** errors: %0d, success: %0d ***", error_count, correct_count);
        $stop;
   task check_result();
        @(negedge clk);
        if(q != q_exp) begin
            error_count = error_count +1;
            $display ("*** ERROR! D = %8d,en = %8d, rst = %8d, q = %8d ***", d, en, rst, q);
        end
            correct_count = correct_count +1;
    endtask
endmodule
```

#### 3. Testbench (USE\_EN = 0):

```
module DFF_tb2();
         logic clk;
logic rst;
         logic d;
         logic q;
         logic en;
         logic q_exp;
         integer correct_count, error_count;
79
         dff #(.USE_EN(0)) dut2(clk, rst, d, q, en);
         always @(posedge clk, posedge rst) begin if(rst)
                 q_exp <= 0;
                 q_exp = d;
         end
         initial begin
             clk = 0;
                  #1 clk = -clk;
         initial begin
             correct count = 0;
             error_count = 0;
             d = 0;
             en = 0;
             //reset test
             rst = 1;
             check_result();
             rst = 0;
             //WITH_EN check
             d = 1;
             check_result();
             en = 1;
             check_result();
             en = 0;
             check_result();
             rst = 1;
             check_result();
             rst = 0;
             $display("*** errors: %0d, success: %0d ***", error_count, correct_count);
             $stop;
         end
         task check_result();
             @(negedge clk);
if(q != q_exp) begin
                 error_count = error_count +1;
                 $display ("*** ERROR! D = %9d,en = %8d, rst = %8d, q = %8d ***", d, en, rst, q);
             else
                  correct_count = correct_count +1;
         endtask
     endmodule
```

4. Do file (changing vsim instance name and coverage save to the testbench to simulate):

```
vlib work
vlog DFF.v DFF_tb.sv +cover -covercells
vsim -voptargs=+acc work.DFF_tb2 -cover
add wave *
coverage save 3_ALU_tb2.ucdb -onexit -du work.dff
run -all
```

### 5. Qesta sim wave snippets (First TB):



```
# *** errors: 0, success: 5 ***
# ** Note: $stop : DFF_tb.sv(53)
# Time: 10 ns Iteration: 1 Instance: /DFF_tb1
# Break in Module DFF_tb1 at DFF_tb.sv line 53
```

#### 5. Qesta sim wave snippets (Second TB):



```
# *** errors: 0, success: 5 ***
# ** Note: $stop : DFF_tb.sv(120)
# Time: 10 ns Iteration: 1 Instance: /DFF_tb2
# Break in Module DFF_tb2 at DFF_tb.sv line 120
```

## 6. Statement coverage report :

| 31 V Statement Coverage:                           |       |                                 |  |  |  |  |  |  |  |  |  |
|----------------------------------------------------|-------|---------------------------------|--|--|--|--|--|--|--|--|--|
| 32 Enabled Coverage Bins                           | Hits  | Misses Coverage                 |  |  |  |  |  |  |  |  |  |
| 33<br>34 <b>Statements 4</b>                       | 4     | 0 100.00%                       |  |  |  |  |  |  |  |  |  |
| 35                                                 |       |                                 |  |  |  |  |  |  |  |  |  |
| 36 ====================================            |       |                                 |  |  |  |  |  |  |  |  |  |
| 37 38 V Statement Coverage for instance /\work.dff |       |                                 |  |  |  |  |  |  |  |  |  |
| 39                                                 |       |                                 |  |  |  |  |  |  |  |  |  |
| 40 Line Item                                       | Count | Source                          |  |  |  |  |  |  |  |  |  |
| 41<br>42 × File DFF.v                              |       |                                 |  |  |  |  |  |  |  |  |  |
| 43 <b>1</b>                                        |       | module dff(clk, rst, d, q, en); |  |  |  |  |  |  |  |  |  |
| 44<br>45 <b>2</b>                                  |       | parameter USE_EN = 1;           |  |  |  |  |  |  |  |  |  |
| 46<br>47 <b>3</b>                                  |       | input clk, rst, d, en;          |  |  |  |  |  |  |  |  |  |
| 48<br>49 <b>4</b>                                  |       | output reg q;                   |  |  |  |  |  |  |  |  |  |
| 50<br>51 <b>5</b>                                  |       |                                 |  |  |  |  |  |  |  |  |  |
| 52                                                 |       |                                 |  |  |  |  |  |  |  |  |  |
| 53 <b>6 1</b> 54                                   | 10    | always @(posedge clk) begin     |  |  |  |  |  |  |  |  |  |
| 55 <b>7</b><br>56                                  |       | if (rst)                        |  |  |  |  |  |  |  |  |  |
| 57 <b>8 1</b>                                      | 4     | q <= θ;                         |  |  |  |  |  |  |  |  |  |
| 58<br>59 <b>9</b>                                  |       | else                            |  |  |  |  |  |  |  |  |  |
| 60<br>61 <b>10</b>                                 |       | if(USE_EN) begin                |  |  |  |  |  |  |  |  |  |
| 62<br>63 <b>11</b>                                 |       | if (en)                         |  |  |  |  |  |  |  |  |  |
| 64<br>65 <b>12 1</b>                               | 1     | q <= d;                         |  |  |  |  |  |  |  |  |  |
| 66<br>67 <b>13</b>                                 |       | end                             |  |  |  |  |  |  |  |  |  |
| 68<br>69 <b>14</b>                                 |       | else                            |  |  |  |  |  |  |  |  |  |
| 70<br>71 <b>15 1</b><br>72                         | 3     | q <= d;                         |  |  |  |  |  |  |  |  |  |

# 7. Branch coverage report :

| 7<br>8<br>9    | Branch Coverage:<br>Enabled Coverage    | Bins               | Hits       | Misses        | Coverage        |  |  |  |  |  |
|----------------|-----------------------------------------|--------------------|------------|---------------|-----------------|--|--|--|--|--|
| 10             | Branches                                | 4                  | 4          | 0             | 100.00%         |  |  |  |  |  |
| 11<br>12<br>13 | =============                           | =====Branch D      | etails==== | ======        |                 |  |  |  |  |  |
| 14<br>15       | Branch Coverage for instance /\work.dff |                    |            |               |                 |  |  |  |  |  |
| 16             | Line Item                               |                    | Count      | Source        |                 |  |  |  |  |  |
| 17             |                                         |                    |            |               |                 |  |  |  |  |  |
| 18             | File DFF.v                              |                    |            |               |                 |  |  |  |  |  |
| 19             |                                         | IF B               |            |               |                 |  |  |  |  |  |
| 20             | 7                                       |                    |            |               | coming in to IF |  |  |  |  |  |
| 21             | 7 1                                     |                    | 4          | 1†            | (rst)           |  |  |  |  |  |
| 22<br>23<br>24 | 11 1                                    |                    | 1          |               | if (en)         |  |  |  |  |  |
| 25<br>26       | 9 1                                     |                    | 3          | All Fa<br>els | lse Count<br>e  |  |  |  |  |  |
| 27<br>28       | Branch totals: 4 hits                   | of 4 branches = 10 | 0.00%      |               |                 |  |  |  |  |  |

#### 8. Toggle coverage report:

```
∨ Toggle Coverage:

       Enabled Coverage
                                        Hits
                               Bins
                                              Misses Coverage
                                 10
                                         10
       Toggles
                                                  0
                                                      100.00%
    81 \sim Toggle Coverage for instance /\work.dff ---
                                         Node
                                                 1H->0L
                                                           0L->1H "Coverage"
                                                   2
                                          c1k
                                                               2
                                                                     100.00
                                                               2
                                                                     100.00
                                            d
                                                                     100.00
                                           en
                                                                     100.00
                                           q
                                                     2
                                                                     100.00
    Total Node Count
    Toggled Node Count =
    Untoggled Node Count =
    Toggle Coverage
                          100.00% (10 of 10 bins)
    Total Coverage By Instance (filtered view): 100.00%
```