



# Automated Flow to Maintaining Consistency in Parallel Design Representations Using Cross-Level Verification

Javier Castillo, Mohammad Badawi, Jan-Hendrik Oetjens



# Development Flow: Individual Verification

ECU Development Flow



ASIC Development Flow



Huge risks on TTM

- SW operating on VP must operate faultlessly on end-product
- Time needed to fix the problems?

Time-to-Market

# Development Flow: Cross-level Verification

ECU Development Flow



ASIC Development Flow



Test case Generator



Time-to-Market

- Early discovery of bugs.
- Fewer and shorter iterations
- Reduce effort:
  - RTL development
  - RTL verification

Shift Left

# Development Flow: Cross-level Verification

ECU Development Flow

Specification

VP Dev.

SW Dev.

SW Verification

VP + SW  
iterations

SW  
Qualification

Operability: End-product must perform as expected using real-life test cases, i.e., end-product SW.

Consistency: Same behavior between different design representations

As

RTL Dev.

RTL Verification

RTL  
Iterations

Sample

fewer bugs.  
shorter iterations

development  
verification

Shift Left

Time-to-Market

# Approach: Automating Cross-Level Verification



- Higher to lower abstraction (VP Waveform to RTL Test Case) → Refinement required
- Lower to higher abstraction (RTL Waveform to VP Test Case) → Ignore certain detail
- Overcome: Different expertise (SW, HW, FW) & confidentiality issues

# Test Case Generator: Overview



# Test Case Generator: VCD Parsing

- Validate VCD
  - All configured signals should exist



# Test Case Generator: Timing Constraints

- Ensure timing followed for certain signals.
  - E.g., start, end and duration of TLM transactions in VP vs bus protocols in RTL
  - Prevent overlapping of transactions



# Test Case Generator: Mapping Signal Activity

- Dictates what code to generate in the test case file



# Test Case Generator: Time Adjustment

- Abstraction causes differences in timing
- Flexibility required:
  - Stimulation/inspection commands issued at the right time
  - Time-based adjustment
  - Event-based adjustment (circular dependency)



# Test Case Generator: Resolving Circular Dependency

- Ensure a stable solution and successful generation of a test case
- Detect and handle circular dependency
  - Directed graph
  - Depth First Search Algorithm
  - User-specified number of iterations



# Test Case Generator: Complete Steps



# Case Study: ASIC for Automotive Application

ECU Development Flow

Specification



VP Dev.

SW Dev.

SW Verification

VP + SW iterations



SW Qualification

Trace.vcd

TestCaseConstraints.json

MappingGuidelines.json

TimingOffset.json

Parsing VCD

Applying Constraints

Mapping Stimulation & Inspection Commands

Adjusting Timing

Generated Test Case

**VP to RTL Test Case Generation**

ASIC Development Flow

RTL Dev.

RTL Verification

RTL Iterations

Sample



# Results: Cross-Level Verification

| Property                           | Automatic Test Case Generation                                 | Manual Test Case Generation                                        |
|------------------------------------|----------------------------------------------------------------|--------------------------------------------------------------------|
| Quality: consistency & operability | <input checked="" type="checkbox"/> Ensured at early stage     | <input type="checkbox"/> Only possible at later stages             |
| Bug detection                      | <input checked="" type="checkbox"/> Discovered early           | <input type="checkbox"/> Would have been discovered late           |
| Misinterpreted spec.               | <input checked="" type="checkbox"/> Resolved early             | <input type="checkbox"/> Discovered late                           |
| Dev. iterations                    | <input checked="" type="checkbox"/> Fewer and shorter          | <input type="checkbox"/> More and longer                           |
| Collaboration between teams        | <input checked="" type="checkbox"/> Expertise is not a barrier | <input type="checkbox"/> Developers from HW, SW and FW required    |
| Effort                             | <input checked="" type="checkbox"/> Tests generated in seconds | <input type="checkbox"/> Manual test generation demands days/weeks |
| Risks and Costs                    | <input checked="" type="checkbox"/> Low                        | <input type="checkbox"/> High                                      |

# Summary

- Cross-level verification flow
  - Bridges the gaps during ECU and ASIC development
  - Enhances collaboration without the need for expertise (SW, HW, FW)
- Real automotive application was used as case study
- Improved quality of spec. and design representations (VP and RTL)
- Ensured operability & consistency
  - End-product test cases verified on all design representations
- Reduced efforts, risks and costs

# Questions



## Acknowledgement

The TRISTAN project, nr. 101095947 is supported by Chips Joint Undertaking (CHIPS-JU) and its members Austria, Belgium, Bulgaria, Croatia, Cyprus, Czechia, Germany, Denmark, Estonia, Greece, Spain, Finland, France, Hungary, Ireland, Israel, Iceland, Italy, Lithuania, Luxembourg, Latvia, Malta, Netherlands, Norway, Poland, Portugal, Romania, Sweden, Slovenia, Slovakia, Turkey and including top-up funding by Federal Ministry of Education and Research, BMBF (Germany).