

# From Platform-based Design to Transaction Level Modeling

Franco Fummi



**UNIVERSITÀ**  
**di VERONA**  
Dipartimento  
di **INFORMATICA**

Version 1.1

# Contents

- Platform Based Design
- Transaction Level Modeling (TLM)
  - Key concepts
  - First standardization
- TLM-based Design Flows
  - Refinement and abstraction steps
  - IP reuse
  - Co-design
- A complete example

# Platform Based Design

Can be applied to:  
 • SOC  
 • SoB = System on a Board

- **Definition:** *platform-based design is the creation of a stable microprocessor-based architecture that can be rapidly extended, customized for a range of applications and delivered to customers for quick deployment. (J.M. Chateau – STMicroelectronics)*



# Platform based design flow



# Platform based design flow



# Platform based design: IPs re-use



i.e., Digital Signal Processor (DSP)  
MPEG, Coder, Decoder, Filters, etc.

# Platform based design: summary

- High-level description for functional verification
- Timing estimation for performance analysis
- Hierarchy for HW/SW partitioning
- Modularity for IPs re-use and/or refinement
- Simulation speed vs. implementation details
- Synthesizable descriptions for HW modules
  - **Transaction Level Modeling (TLM)**
  - **Virtual Platform (VP)**

Mix of these two => Platform based design

# TLM: Motivations



Functional specifications failures?  
Performance expectations missing?



Main reason:  
lacking of a concretely usable view  
of the complete system before the  
tape-out phase!

# Reasons for Using TLM



# TLM: Definition

- Transaction Level is the new design and verification abstraction above RTL



# TLM: Abstraction Levels

| Level                                                      | Use                                                                                                     | Features                                                                            | Abstraction                                                                                          |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| PV<br>(Programmer's View)<br>(Loosely-timed)               | <ul style="list-style-type: none"> <li>Executable specification</li> <li>Proof of concepts</li> </ul>   | <ul style="list-style-type: none"> <li>Event-driven</li> <li>Untimed</li> </ul>     | <ul style="list-style-type: none"> <li>Data types</li> <li>Time</li> <li>Resource sharing</li> </ul> |
| PVT<br>(Programmer's View + Time)<br>(Approximately-timed) | <ul style="list-style-type: none"> <li>HW/SW partitioning</li> <li>Performance estimation</li> </ul>    | <ul style="list-style-type: none"> <li>Event-driven with time estimation</li> </ul> | <ul style="list-style-type: none"> <li>Clocks</li> <li>Protocols</li> </ul>                          |
| CA<br>(Cycle Accurate)                                     | <ul style="list-style-type: none"> <li>Detailed modeling</li> <li>Cycle accurate testbenches</li> </ul> | <ul style="list-style-type: none"> <li>Cycle accurate</li> </ul>                    | <ul style="list-style-type: none"> <li>Wires</li> <li>Registers</li> </ul>                           |
| RTL                                                        | <ul style="list-style-type: none"> <li>Signal level modeling for synthesis</li> </ul>                   | <ul style="list-style-type: none"> <li>Pin accurate</li> </ul>                      | <ul style="list-style-type: none"> <li>Gates</li> <li>Delays</li> </ul>                              |

# TLM: Advantages

- Implementation details are abstracted while preserving the behavioral aspects of the system
  - this allows a faster simulation (up to 1,000x) than at RTL
- System level design exploration and verification are simplified
  - IP components and buses can be modified and replaced in an easier way than at RTL
- An early platform for SW development can be quickly developed

# TLM: Typical Use Cases

- Represents key architectural components of hardware platform
- Architectural exploration, performance modeling
- Software execution on virtual model of hardware platform
- Golden model for hardware functional verification
- Available before RTL
- Simulates much faster than RTL

# TLM: Main Advantage

- Enabling Software development to start very early in the design flow



# TLM: Modeling Comparison

- More emphasis on the data transfer functionality
  - less on their implementation details at the early design stage

RTL

TLM

```

process(clock)
IF (clock'event and clock = '1')
THEN
CASE fsm_state IS:
  WHEN s0 =>
    request_port <= '1';
    fsm_state := s1;
  WHEN s1 =>
    IF (grant_port = '1')
      THEN
        fsm_state := s2;
  WHEN s2 =>
    data_port <= data;
    addr_port <= addr;
...
  
```


**write (data, addr);**

# TLM: Design Languages



| Simulink,<br>C/C++ | <b>SystemC</b> | VHDL,<br>Verilog | System<br>Verilog |
|--------------------|----------------|------------------|-------------------|
| ★★★★★              | ★★★★★          | --               | ★                 |
| --                 | ★★★★★          | --               | (★★) ↪            |
| --                 | ★★★            | ★★★★★            | ★★★★★             |

⇒ Extension of Verilog

# **AN EXAMPLE: THE FACE RECOGNITION**

# TLM-based Design Flow



# Example: Face recognition system

(STMicroelectronics)



**Captured Image**

**1<sup>st</sup> step**

**2<sup>nd</sup> step**

**3<sup>rd</sup> step**



# Face recognition system: PV level

## *Loosely-timed*



# TLM-based Design Flow



# PVT level: *Approximately-timed*



# TLM-based Design Flow



# Cycle-Accurate

