

# TLM 2.0 Loosely Timed (LT) System Example - Simple

Jack Donovan, Anna Keist, Charles 1862 44(r) Wr

### **AT System Example - Annotated Timing**

#### The Goal is to Illustrate:

- Application of TLM 2.0 in a real system
- Annotated non-blocking (NB) option of the non-blocking style
  - NB annotated timing has been referred to as "1 phase"
  - Simplest version of non-blocking/AT

#### Possible Applications:

- Architectural exploration
- Early software development



#### **Example Block Diagram**







#### How to run this example (Linux)

- Set SYSTEMC\_HOME
- cd examples/tlm/lt/build-unix
- make clean
- make
- make run



#### How to run this example (MSVC)

- Open a explorer window on examples/tlm/lt/build-windows
- Launch lt.sln
- Select 'Property Manager' from the 'View' menu
- Under 'It > Debug | Win32' select 'systemc'
- Select 'Properties' from the 'View' menu
- Select 'User Macros' under 'Common Properties'
- Update the 'SYSTEMC' entry and apply
- Build and run



### Expected Output (expected.log)

Info: It\_initiator.cpp: 80 ns - initiator\_thread Initiator: 101 b\_transport(GP, 0 s)

Info: report.cpp: 80 ns - print

ID: 201 COMMAND: WRITE Length: 04

Addr: 0x000000000000000 Data: 0x00000004

Info: at\_target\_1\_phase.cpp: 80 ns - b\_transport

Target: 201 returned delay of 0 s + 20 ns + 60 ns = 80 ns

Info: It\_initiator.cpp: 80 ns - initiator\_thread

Initiator: 101 b\_transport returned delay = 80 ns

Info: It\_initiator.cpp: 80 ns - initiator\_thread

Initiator: 102 b\_transport(GP, 0 s)

Info: report.cpp: 80 ns - print

ID: 201 COMMAND: WRITE Length: 04

Addr: 0x000000000000000 Data: 0x00000004

Info: at\_target\_1\_phase.cpp: 80 ns - b\_transport

Target: 201 returned delay of 0 s + 20 ns + 60 ns = 80 ns

Info: It\_initiator.cpp: 80 ns - initiator\_thread

Initiator: 102 b\_transport returned delay = 80 ns



#### **Initiator Module**



#### **TLM Interface Module**



# **Target Module (It\_target)**













## Target Module (at\_1\_phase\_target)













#### **Router Component**



## **Expected Timing**



