# **Final Project**

### Project (3)-SPI-Wrapper:

### 1. Verification plan

- a)Reset functionality should clear the flag, counter, rx\_valid and MISO.
- b)Check Starting communication phase when SS\_n gets low.
- c) Testing next state choice after current state is check command according to flag & MOSI.
- d) Verify the serial to parallel conversion operation after 10 clock cycles after its start.
- e)Checking the address is updated after the rx\_valid is asserted in WRITE and READ\_ADD cases.
- f) Verifying the Read\_data process.
- g)Check End communication transition when master makes SS\_n high.

#### Note:

- In Constraining and debugging the possibility of the master delaying the end communication signal (SS\_n) was not taken in consideration for example if the master is writing in the RAM the high SS\_n signal will come right after 11 clock cycles from starting the communication.
- In this DUT: dividing the inter tasks (counter, PISO, SIPO) in the SPI module resulted in inevitable delays that are not specified in the specs to correct these delays we would have to tear down the whole design. So, we just test for basic functionality neglecting timing specially in READ DATA case as it clearly has a problem.
- We adjusted the testbench to match the design delays in order to check for the delayed output each clock cycle.

## 2. Verification Document

| Label   | Description                                                                                                                                                                                                                                               | Stimulus Generation                                                                                                                                                              | Functional Coverage                                                                                                                              | Functionality Check                                     |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| SLAVE_1 | in case of rst_n the all rx_valid,rx_data,MISO will be equal zero                                                                                                                                                                                         | Randomization under constraints that reset_n is high most of the time                                                                                                            | included the cover point of rst_n<br>(rst_n_cp)and cross coverage with<br>rx_valid (rx_valid_with_rst)and also<br>with rx_data(rx_data_with_rst) |                                                         |
| SLAVE_2 | In case that the first 3 values of mosi after beginning communication are (000 or 001 or 110 or 111) the only valid squences to make a communication which is represent read (address(110) /data(111)) and write (address (000)/data(001))                | randmisation of the mosi squence<br>constrainting that the first 3 values<br>inside the valid squences                                                                           | coverpoint of rx_data(rx_data_cp) and cross coverage with the reset(rx_data_with_rst) and with SS_n(rx_data_with_SS_N)                           | checking by using behavioral<br>moddel for spi protocol |
| SLAVE_3 | SS_n is the key which strartts and ends the communication which means if I have raised SS_n during the anny part at the FSM the slave return to the idle state and not continue the communication                                                         | randomization constrainting that SS_n is low the most of time at the first simulation and at the end of the 10 clok cyle I forced ts value to 1 to end communication as expected | coverpoint of SS_n(SS_n_cp) and cross coverage with rx_valid(rx_valid_with_SS_N) and rx_data(rx_data_with_SS_N)                                  | checking by using behavioral<br>moddel for spi protocol |
| wrapper | the wapper must be act accroding spectification if it have an correct squences of mosies entered in the expected clock cycles in case that read data squence entered I expect the MISO give me data serially in 8 clk cycles after the squence is entered | randomisation of rst_n constrainting<br>that its high most of time and the<br>mosi squences to get the valid<br>squences only                                                    | coverpoint mosi squence<br>((the_command_cover) )and the<br>rst_n(reset_coverage) which is<br>called (reset_and_instructions)                    | checking by using behavioral<br>moddel for spi wrapper  |

# 3. Coverage reports:

| anch Coverage:                                         |           | _                              |         |                           |                 |                           |
|--------------------------------------------------------|-----------|--------------------------------|---------|---------------------------|-----------------|---------------------------|
| Enabled Coverage                                       |           | Bins                           | Н       | its                       | Misse           | s Coverage                |
| Branches                                               |           | 2                              |         | 2                         |                 | 0 100.00%                 |
|                                                        | .======   | =Branch                        | Detail  | s===                      | .======         |                           |
|                                                        |           | bi dileli                      | becarr  | _                         |                 |                           |
| erage Report by insta                                  | nco with  | dotaile                        |         |                           |                 |                           |
| erage Report by 1113ta                                 | iice with | uecaiis                        |         |                           |                 |                           |
| Instance //wannen                                      |           |                                |         |                           |                 |                           |
| <pre>Instance: /\wrapper_ Design Unit: work.SI</pre>   |           | spisiave                       | /sni+t_ | reg                       |                 |                           |
|                                                        |           |                                |         |                           |                 |                           |
| nch Coverage:<br>Enabled Coverage                      |           | Bins                           | USA     | s                         | Missos          | Coverage                  |
|                                                        |           | DIIIS                          | пт      | . >                       | 1.1T22G2        | COVELAGE                  |
|                                                        |           |                                |         |                           |                 |                           |
| Branches                                               |           | 2                              |         |                           | 0               | 100.00%                   |
|                                                        | ======[   | 2                              |         | 2                         | 0               | 100.00%                   |
| Branches                                               | ======    | 2                              |         | 2                         | 0               | 100.00%                   |
| Branchesement Coverage:                                | ======    | 2<br>Branch D                  | etails= | 2<br>                     | 0               | 100.00%                   |
| Branches  ement Coverage: Enabled Coverage             | ======[   | 2                              |         | 2<br>                     | 0               | 100.00%                   |
| Branches  ement Coverage: Enabled Coverage             | =====[    | 2<br>Branch D                  | etails= | 2                         | 0               | 100.00%                   |
| Branches  ement Coverage: Enabled Coverage             |           | 2<br>Branch D<br>Bins<br><br>2 | etails= | 2<br>                     | 0<br>Misses<br> | 100.00%  Coverage 100.00% |
| Branches  ement Coverage: Enabled Coverage  Statements |           | 2<br>Branch D<br>Bins<br><br>2 | etails= | 2<br>                     | 0<br>Misses<br> | 100.00%  Coverage 100.00% |
| Branches  ement Coverage: Enabled Coverage  Statements |           | 2<br>Branch D<br>Bins<br><br>2 | etails= | 2<br>=====<br>5<br>-<br>2 | 0<br>Misses<br> | 100.00%  Coverage 100.00% |

| Node         | 1H->0L | 0L->1H | "Coverage" |
|--------------|--------|--------|------------|
| MOSI         | 1      | 1      | 100.00     |
| SS_n         | 1      | 1      | 100.00     |
| clk          | 1      | 1      | 100.00     |
| rx_data[0-9] | 1      | 1      | 100.00     |

| Enabled Coverage                                                                      | Bins                              | Hits                                                                    |                                         | Coverage                                   |                     |                                      |
|---------------------------------------------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------|-----------------------------------------|--------------------------------------------|---------------------|--------------------------------------|
| Toggles                                                                               |                                   |                                                                         |                                         | 100.00%                                    |                     |                                      |
|                                                                                       | ====Toggle [                      | etails===                                                               |                                         | =======                                    |                     |                                      |
| oggle Coverage for instance                                                           | /\wrapper_t                       | tb#DUT /sp                                                              | islave/co                               | unter                                      |                     |                                      |
|                                                                                       |                                   | Nod                                                                     | e 1H                                    | ->0L 0L                                    | ->1H                | "Covera                              |
|                                                                                       |                                   | cl                                                                      | .k                                      | 1                                          | 1                   | 100                                  |
|                                                                                       | co                                | ounter[0-3                                                              | ]                                       | 1                                          | 1                   | 100                                  |
|                                                                                       | count                             | ter_up[3-0                                                              | ]                                       | 1                                          | 1                   | 100                                  |
|                                                                                       |                                   | rst_                                                                    | 'n                                      | 1                                          | 1                   | 100                                  |
| ======================================                                                | _tb#DUT /s<br>[SO                 | pislave,                                                                | /shift_r                                | egII                                       |                     |                                      |
| Enabled Coverage                                                                      |                                   | Bins                                                                    | Hits                                    |                                            | Coverage            |                                      |
|                                                                                       |                                   |                                                                         |                                         |                                            |                     |                                      |
| Branches                                                                              | B                                 | 4<br>ranch De                                                           | 4<br>etails==                           |                                            |                     | =====                                |
|                                                                                       | B                                 |                                                                         | etails==                                |                                            |                     |                                      |
| atement Coverage:<br>Enabled Coverage                                                 | -====B                            | ranch De<br>Bins                                                        | etails==<br>Hits                        | Misses                                     | Coverage            | =====                                |
| atement Coverage:<br>Enabled Coverage                                                 | -====B                            | ranch De<br>Bins                                                        | etails==<br>Hits                        | Misses                                     |                     | =====                                |
| atement Coverage:<br>Enabled Coverage<br><br>Statements                               |                                   | Bins                                                                    | etails==<br>Hits<br>                    | Misses                                     | Coverage<br>100.00% |                                      |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage         | S<br>Bins                         | Bins<br><br>4<br>Statement                                              | Hits  t Detail                          | Misses                                     | Coverage<br>100.00% |                                      |
| atement Coverage: Enabled Coverage Statements  gle Coverage:                          | ======S<br>Bins<br>               | Bins<br><br>4<br>Statement                                              | Hits  t Detail                          | Misses                                     | Coverage<br>100.00% |                                      |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage         | Bins<br><br>46                    | Bins<br><br>4<br>tatement                                               | Hits  ### Detail  Misses  0             | Misses Coverage 100.00%                    | Coverage<br>100.00% |                                      |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage         | Bins<br><br>46<br>==Toggle Det    | Bins 4 Statement                                                        | Hits  ### Detail  Misses 0              | Misses S==============================     | Coverage<br>100.00% |                                      |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage Toggles | Bins<br><br>46<br>==Toggle Det    | Bins 4 Statement                                                        | Hits  ### Detail  Misses 0              | Misses                                     | Coverage 100.00%    | <b>=====</b><br>"Coverage            |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage Toggles | Bins<br><br>46<br>==Toggle Det    | Bins 4 Statement Hits 46 tails=====                                     | Hits  Hits  Detail  Misses 0 lave/shift | Misses                                     | Coverage<br>100.00% | <b>=====</b><br>"Coverage            |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage Toggles | Bins<br><br>46<br>==Toggle Det    | Bins 4 Statement Hits 46 Stails=====                                    | Hits  Hits  Detail  Misses 0 lave/shift | Misses  Serverage  100.00%  t_regII        | Coverage 100.00%    | =======<br>"Coverage                 |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage Toggles | Bins 46 ==Toggle Det              | Bins 4 Statement Hits 46 Stails===== #DUT /spis Node clk nter[0-3] dout | Hits  ### Detail  Misses 0  lave/shift  | Coverage 100.00% 1 0L 0L->1 1 1            | Coverage 100.00%    | "Coverage<br>100.0<br>100.0<br>100.0 |
| atement Coverage: Enabled Coverage Statements  gle Coverage: Enabled Coverage Toggles | Bins 46 ==Toggle Det \wrapper_tb# | Bins 4 Statement Hits 46 stails===== #DUT /spis Node clk                | Hits  ### Detail  Misses 0  lave/shift  | Misses  .s================================ | Coverage 100.00%    | "Coverage<br>100.0                   |

| Summary             | Bins         | Hits     | Misses | Coverage |  |
|---------------------|--------------|----------|--------|----------|--|
|                     |              |          |        |          |  |
| FSM States          | 5            | 5        | 0      | 100.00%  |  |
| FSM Transitions     | 8            | 8        | 0      | 100.00%  |  |
| Statement Coverage: |              |          |        |          |  |
| Enabled Coverage    | Bins         | Hits     | Misses | Coverage |  |
|                     |              |          |        |          |  |
| Statements          | 35           | 35       | 0      | 100.00%  |  |
|                     | ===Statement | Details= |        |          |  |
| Toggle Coverage:    |              |          |        |          |  |
| Enabled Coverage    | Bins         | Hits     | Misses | Coverage |  |
|                     |              |          |        |          |  |
| Toggles             | 96           | 96       | 0      | 100.00%  |  |
|                     |              |          |        |          |  |

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

------

=== Instance: /\wrapper\_tb#DUT === Design Unit: work.spi\_wrapper

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

Toggle Coverage:

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

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

Toggle Coverage for instance /\wrapper\_tb#DUT --

| Node         | 1H->0L | 0L->1H | "Coverage" |
|--------------|--------|--------|------------|
| clk          | 1      | 1      | 100.00     |
| miso         | 1      | 1      | 100.00     |
| mosi         | 1      | 1      | 100.00     |
| rst_n        | 1      | 1      | 100.00     |
| rx data[0-9] | 1      | 1      | 100.00     |
| rx_valid     | 1      | 1      | 100.00     |
| ss n         | 1      | 1      | 100.00     |
| tx_data[0-7] | 1      | 1      | 100.00     |
| tx_valid     | 1      | 1      | 100.00     |

Total Node Count = 25 Toggled Node Count = 25 Untoggled Node Count = 0

Toggle Coverage = 100.00% (50 of 50 bins)

Total Coverage By Instance (filtered view): 96.52%

Note: Coverage didn't reach 100% because of conditional coverage the all-false term.

#### Function Coverage:



### 4. Bugs report:

- a) Timing delays in the SPI wrapper operations specially in READ\_DATA case.
- b) In case of active reset rx\_valid does not change (remains the same).



Snippet shows the stability of the rx\_valid flag even during active reset

c) During asserted reset the flag which indicates that an address was sent does not get cleared.



Snippet shows the stability of the address flag even during active reset

d) If the current state is WRITE and master ends the communication the flag is cleared. Which causes a problem in the next READ operation induces wrong READ\_ADD operation.



Snippet shows the false clear of the flag after WRITE operation

- e) Checking to clear the counter in the design takes place on the current state which makes the counter clears but the next clock cycle instead it should check for the next state if it is equal CHK\_CMD to clear the counter right away and be able to assert rx\_valid and access memory before the communication ends.
  - 5. Code snippets
  - a) Coverage & cover points:

```
SS_N_cp:coverpoint SS_n{
     bins high={1};
     bins low={0};
  rst_n_cp:coverpoint rst_n{
     bins active={0};
     bins non_active={1};
  rx_data_cp:coverpoint rx_data[9:8]
oins write_address={2'b00};
pins write_data={2'b01};
bins read addr={2'b10};
bins read_data={2'b11};
 rx valid cp:coverpoint rx valid{
     bins high={1};
     bins low={0};
x_valid_with_rst: cross rx_valid_cp,rst_n_cp{    ignore_bins rx_valid_activated_rst=binsof(rx_valid_cp.high)&&binsof(rst_n_cp.active);
rx_data_with_rst: cross rx_data_cp,rst_n_cp{
     ignore bins rx data with activated rst=binsof(rx data cp)&&binsof(rst n cp.active);
rx_data_with_SS_N: cross rx_data_cp,SS_N_cp;
x valid with SS N: cross rx valid cp,SS N cp;
```

```
covergroup g;
the_command_cover:coverpoint data_holder[10:8] {
bins write_addr={3'b000};
bins write_data={3'b001};
bins read_address={3'b110};
bins read_data={3'b111};
ignore_bins invalid_data={3'b101,3'b100,3'b010,3'b011};
}
reset_coverage: coverpoint rst_n;
reset_and_instructions: cross reset_coverage,the_command_cover;
endgroup
```

#### b) Assertions file:

```
nodule spi_sva(wrapper_if.MONITOR wrap_if);
       if(!wrap_if.rst_n) begin
           P2: assert final (wrap_if.flag == 0);
P3: assert final (wrap_if.cs ==IDLE);
   property valid_clear;
       @(posedge wrap_if.clk) !wrap_if.rst_n |=> ( wrap_if.rx_valid ==0);
   property comm_end;
       @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n) (wrap_if.SS_n) |=> (wrap_if.cs == IDLE);
   property comm_start ;
      @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n) (wrap_if.cs==IDLE && ! wrap_if.SS_n ) |=> (wrap_if.cs==CHK_CMD ) ;
   property Wr_transition ;
       @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n || wrap_if.SS_n) (wrap_if.cs==CHK_CMD && !wrap_if.MOSI ) |=> (wrap_if.cs==WRITE && wrap_if.counter_out ==0)
   endproperty
   property write_inc ;
       logic [4:0] prev_count;
       @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n || wrap_if.SS_n) (wrap_if.cs==WRITE &&wrap_if.counter_out!=0 , prev_count= wrap_if.counter_out) |=>
        (wrap_if.counter_out == (prev_count+4'b0001));
   endproperty
   property write_valid;
       logic [9:0] word;
       @(posedge wrap_if.clk) disable iff (!wrap_if.rst_n || wrap_if.SS_n)
            (wrap_if.cs == WRITE && wrap_if.counter_out == 0,word= 10'b0) |=> (1,word = {word[8:0], $past(wrap_if.MOSI)}) [*0:$]
            ##2 (word == $past(wrap_if.rx_data))
   endproperty
   @(posedge wrap_if.clk) disable iff (!wrap_if.rst_n || wrap_if.SS_n)
           (wrap_if.cs == WRITE && wrap_if.counter_out == 0,word_rd= 10'b0) |=> (1,word_rd = {word_rd[8:0], $past(wrap_if.MOSI)}) [*0:$]
           ##2 (word_rd == $past(wrap_if.rx_data))
   property write_add ;
      @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n) (wrap_if.cs==WRITE && wrap_if.rx_valid && !wrap_if.rx_data[9] && !wrap_if.rx_data[8]) |=> (wrap_if.addr_wr== wrap_if.rx_data[7:0]);
   property write_data;
       @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n) (wrap_if.cs==WRITE && wrap_if.rx_valid && !wrap_if.rx_data[9] && wrap_if.rx_data[8]) |=>
| (DUT.mem.mem[wrap_if.addr_wr]== wrap_if.rx_data[7:0]) ;
   property read_add_trans ;
   @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n || wrap_if.SS_n) (wrap_if.cs== CHK_CMD && wrap_if.MOSI && !wrap_if.flag) |=> (wrap_if.cs==READ_ADD);
   property read_add ;

@(posedge wrap_if.clk) disable iff(!wrap_if.rst_n ) (wrap_if.cs==READ_ADD && wrap_if.rx_valid && wrap_if.rx_data[9] && !wrap_if.rx_data[8]) |=> (wrap_if.addr_rd== wrap_if.rx_data[7:0])
   property read data trans ;
      @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n || wrap_if.SS_n) (wrap_if.cs== CHK_CMD && wrap_if.MOSI && wrap_if.flag) |=> (wrap_if.cs==READ_DATA);
   @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n || wrap_if.SS_n) (wrap_if.cs== READ_DATA && wrap_if.counter_out==0 ) |=> ##[9:10]$rose(wrap_if.rx_valid) ##1 $rose(wrap_if.tx_valid) endproperty
   property flag_set ;
   @(posedge wrap_if.clk) disable iff(|wrap_if.rst_n ) (wrap_if.cs == READ_ADD && wrap_if.rx_valid==1) |=> $rose($past(wrap_if.flag)); endproperty
   property flag_clear;
       @(posedge wrap_if.clk) disable iff(!wrap_if.rst_n) (wrap_if.cs == READ_DATA && wrap_if.ns == IDLE ) |=> $felt($past(wrap_if.flag));
```