

Verification  
Planning Mid Pro

# Project Overview & Scope

## DUT Timer Summary

We are verifying a Timer DUT its main use is to countdown a programmable Number loaded with automatic reload operation, the Timer control is achieved with req&gt;nt interface to control registers.

## Verification Objectives

- Timing correctness
- Data integrity
- Functional accuracy behavior

## Open questions

- What is the internal register use?  
Do we need to check all the other option of the Timer?
- Does the START bit should posedge in order to restart the count?

### In Scope

- Read/Write interface operation
- Timer behavior reset/reload\_en

### Out Scope

- Power consumption
- Other corner cases not mention

# Requirements Extraction & RTM

## # Metrics for Success (Exit)

| Req ID | Requirement                     | Verification Method | Planned Artifact |
|--------|---------------------------------|---------------------|------------------|
| R1     | Write mod:<br>req -> gnt #3 clk | Assert              | Assertion        |
| R2     | Read mod:<br>Rdata -> gnt       | Assert              | Assertion        |
| R3     | Read/Write bus interface        | coverage            | Bus interface    |

## Verification

| Strategy Area          | Approach                                                                                |
|------------------------|-----------------------------------------------------------------------------------------|
| Methodology:           | SystemVerilog object-oriented testbench architecture.                                   |
| Stimulus Strategy:     | Constrained-Random, with some Directed tests for corner cases (like Loading zero).      |
| Checking Strategy:     | Data checker for the expected results and SVA for the protocol operation                |
| Coverage Strategy:     | Coverage of the input/operation mode                                                    |
| Regression/Automation: | Creating a regression/automation baselined tests                                        |
| Exit Criteria          | Code Coverage (100% line/toggle) and Functional Coverage (100% of defined coverpoints). |

# Phase 3 - TB architecture



- Sequencer - creating the transactions according to our TB scenarioes
- REF\_Model - our funvtional module that represent the behave of the DUT as we understand it from the designers.
- Driver - drives the transaction though the interface to the DUT.
- Monitor - getting the DUT outputs and convert it to transaction and pass it to the SB.
- Scoreboard - matching between the REF expected output and the actual output of the DUT.
- ~~TBmer connection between the physical and the dynamic parts.~~
- Environment - gathering all the dynamic classes into one class as properties.
- BaseTest - making test scenarios by a sequence of the sequencer methods.

# Phase 4 – covPlan & test scenarios



- START – countdown.
- Reload enable = high/low.
- Reset operation.



- Read/Write.
- Nothing.
- Unmapped address.



- Writing while reading mode.
- Reloading enable high while countdown.



- Loading zero.
- Start before countdown goes to zero.

| Test name           | Type      | Purpose                                                              |
|---------------------|-----------|----------------------------------------------------------------------|
| Basic operation     | Random    | Loading valid data and str<br>countdown should stop at the<br>end.   |
| Reset operation     | direct ed | Should stop any operation and<br>get to the ideal state              |
| Reload_en           | direct ed | Should state all over the<br>countdown at the end with STR<br>signal |
| Unmapped address    | Random    | Should continue without changing                                     |
| WR while RD mode    | direct ed | Should ignore the input data                                         |
| Loading zero        | direct ed | Should load 1 as default                                             |
| Str while countdown | direct ed | Should str the countdown all<br>over                                 |

# Phase 5 - Stimulus Planning

| Sequence name | description                     | Parameters / constraints          |
|---------------|---------------------------------|-----------------------------------|
| seq_load      | Basic Write => read transaction | Addr within valid range,<br>Wr_en |
| Seq_str_II    | STR while countdown             |                                   |
|               |                                 |                                   |
|               |                                 |                                   |
|               |                                 |                                   |

# Phase 6 - Closure & Reporting strategy

| Metric              | Target | Justification                    |
|---------------------|--------|----------------------------------|
| Code coverage       |        | Why this level is sufficient     |
| Functional coverage |        | Base on coverage goals           |
| Assertion coverage  |        | Which properties must trigger    |
| Bug rate/ severity  |        | Threshold for tape-out readiness |

## Reflection

- Which req was the hardest to make measurable?
- Where could randomization help u close coverage faster?
- What assumptions did u have to make about the DUT?