

SC-HEAP\_E3 : Bus I/F TLM timing specification

Renesas Electronics Corporation MCU Software Division

2012/4/9

RENESAS Group CONFIDENTIAL

# Purpose of the document

The document describes the communication timing of bus I/F applied to SC-HEAP\_E3.

The document is for the developer of the bus master IP or bus slave IP.



The bus modeling outline in OSCI TLM2.0



# Time which can be set in AT 2phase of OSCI TLM 2.0 and IP to set the time

It's possible to set time to spend with argument of nb\_transport\_fw and nb\_transport\_bw in AT 2phase. It's also possible to add time to spend between bw from fw.



| Time | IP to set | meaning                             |
|------|-----------|-------------------------------------|
| t1   | Initiator | Time until the transaction starting |
| t2   | Target    | Time until the request completion   |
| t3   | Target    | The internal processing time        |
| t4   | Target    | Time until the response starting    |
| t5   | Initiator | Time until the response completion  |

fw : nb\_transport\_fw
bw : nb transport bw



# Time which can be set in LT of OSCI TLM 2.0 and IP to set the time

It is possible to set time to spend with argument of b\_transport in LT. Initiator can set time to spend at b\_transport calling. Target adds time to spend for transmission and returns it to initiator.



# Bus modeling policy using AT 2phase of OSCI TLM 2.0

- Model consists of I/F and core, and time is sent at I/F or core.
- Initiator set time until a request is acquired (t1p). It is set by initiator core.
- t2 is set by target I/F and consists of time for transmission(t2) and latency(t2p). t2p is a parameter of I/F, and variable.
- Target core set inner spending time(t3c).
- Target set time until the response acquisition(t4p). It's a parameter of I/F, and variable.

t5 is set by initiator, and consists of time for transmission(t5p) and latency(t5). t5p is variable

by a parameter of I/F.

| Бу                                                                                                                                                                        |                                          |                  | Time  | IP to set   | meaning                               | value                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|------------------|-------|-------------|---------------------------------------|------------------------|
| Initiator.                                                                                                                                                                | Initiator. Target.                       |                  | t1p   | Ini IF      | Time before request acquisition*1     | Depend on core         |
| Core. I                                                                                                                                                                   | /F I/F                                   | Core.            | t2    | Tgt IF      | Transfer time for request phase       | Depend on transmission |
|                                                                                                                                                                           | t1p<br>fw (t1p)                          |                  | t2p   | Tgt IF      | Request phase latency                 | Parameter              |
| <b>4</b>                                                                                                                                                                  | •                                        | +t2,+t2p         | t3c   | Tgt core    | Response Readiness time               | Depend on core         |
|                                                                                                                                                                           | t1p+t2+t2p <t1p>↓</t1p>                  | +t3c             | t4p   | Tgt IF      | Time before response acquisition      | Parameter              |
|                                                                                                                                                                           | <t2+t2p+t3c></t2+t2p+t3c>                |                  | t5    | Ini IF      | Transfer time for Response phase      | Depend on transmission |
|                                                                                                                                                                           | .                                        |                  | t5p   | Ini IF      | Response phase latency *1             | Parameter              |
| +t5,+t5p                                                                                                                                                                  | bw (t4p)                                 | t4p              | *     | 1: not sup  | ported by this I/F                    |                        |
|                                                                                                                                                                           |                                          |                  |       |             | explanation of subscript of t         |                        |
| <t4p+t5+t5p< td=""><td>&gt; t4p+t5+t5p</td><td></td><td>n</td><td>o subscript</td><td>Time to consume in IF (time to sper</td><td>nd for bus protocol)</td></t4p+t5+t5p<> | > t4p+t5+t5p                             |                  | n     | o subscript | Time to consume in IF (time to sper   | nd for bus protocol)   |
|                                                                                                                                                                           | fw : nh transport fw                     |                  |       | р           | Time to spend in IF (time to set by p | parameter)             |
| 6 RENES                                                                                                                                                                   | fw:nb_transport_fw<br>bw:nb_transport_bw | © 2012 Renesas E | lectr | С           | Time to spend in core                 |                        |

# Modeling policy of a bus using a letter telegram of OSCI/TLM 2.0

- Model consists of I/F and core, and time is sent at I/F or core.
- Initiator sets time to spend in in initiator at b calling. (t1p+t5p)
- t2p is set by target IF as a parameter. t3c is time to spend in target core.

T40 is set by target. But t4p is included in tp2 because there is no phase which can set t4p

in LT.

| Initiator |                                                                                         | Targ     | get         |    |
|-----------|-----------------------------------------------------------------------------------------|----------|-------------|----|
|           |                                                                                         |          |             | H  |
| ,         | \<br>/E                                                                                 | ,<br>т/⊏ | ,           |    |
| core I,   | /F                                                                                      | I/F      | core        |    |
|           | t1p+t5p b(t1p+t5p)                                                                      | +(t2+    | t5+t4p+)t2p | ig |
|           | S(CIP+CSP)                                                                              | <b>-</b> | +t3c        |    |
|           | t1p+t5p+(t2+t5+t4                                                                       | p+)t2p+  | t3c         |    |
|           | <t1p+t5p+(t2+t5+< td=""><td>t4n+)t2n</td><td>0+t3c&gt;</td><td></td></t1p+t5p+(t2+t5+<> | t4n+)t2n | 0+t3c>      |    |
|           | (22)                                                                                    | C 1      |             |    |
| <b>1</b>  |                                                                                         |          |             | _  |
| ◀         |                                                                                         |          |             |    |
| l         | b: b_transpo                                                                            | ort      | ı           |    |

| Time | IP to set | meaning                           | value                  |
|------|-----------|-----------------------------------|------------------------|
| t1p  | Ini IF    | Time before request acquisition*1 | Depend on core         |
| t2   | Tgt IF    | Transfer time for request phase   | Depend on transmission |
| t2p  | Tgt IF    | Request phase latency             | Parameter              |
| t3c  | Tgt core  | Response Readiness time           | Depend on core         |
| t4p  | Tgt IF    | Time before response acquisition  | Parameter              |
| t5   | Tgt IF *2 | Transfer time for Response phase  | Depend on transmission |
| t5p  | Ini IF    | Response phase latency *1         | Parameter              |

st1: not supported by this I/F

\*2: notice that IP which set it is different from AT

|                         | explanation of subscript of t                          |  |  |  |  |
|-------------------------|--------------------------------------------------------|--|--|--|--|
| no subscript            | Time to consume in IF (time to spend for bus protocol) |  |  |  |  |
| р                       | Time to spend in IF (time to set by parameter)         |  |  |  |  |
| c Time to spend in core |                                                        |  |  |  |  |

**APB** 



# Time to spend in APB



| time | meaning                                                          | IP to set | number of cycles |
|------|------------------------------------------------------------------|-----------|------------------|
| t2   | Target acquires the address.                                     | -         | fixed to 1       |
| t3c  | Preparation time for data acquisition or data output for target. | Tgt       | >= 0             |
| t5   | Time for data acquisition or data output for target.             | -         | fixed to 1       |

# Mapping to OSCI/TLM2.0 AT 2phase

Timing specification details



There is no time to express at t1p and t4p in APB/AT, so t1p and t4p are fixed to 0.

- 1. Initiator core calls API in initiator I/F.
- 2. Initiator I/F calls fw(0), and target I/F returns the value (t2+t2p) to initiator I/F. Target I/F calls API in target core with time (t2+t2p).
- 3. Target core returns t2+t2p+t3c to target I/F, and target I/F spends the time.
- 4. After target I/F spends the time, bw (0) is called.
- 5. Initiator I/F returns the value(t5) to target I/F and spend the time.

# Mapping to OSCI/TLM2.0 LT

Timing specification details



There is no time to express in t1p by APB/LT, so t1p is fixed to 0.

- 1. Initiator core calls API in initiator I/F.
- 2. Initiator I/F calls b(0), and target I/F calls API in target core with (t2+t5+)t2p. t2p is set with a parameter of target IF. Default value of t2p is 0.
- 3. Target core returns (t2+t5+)t2p+t3c to target I/F, and target I/F returns to initiator I/F with the return value(t2+t5+t2p+t3c).
- 4. Initiator I/F spend the time(t2+t5+t2p+t3c).
- 5. After the time spending Initiator I/F return API of initiator core.

# Mapping to OSCI/TLM2.0

- The timing specification which is not supported
  - AT none
  - LT none



**AHB** 



# Time to spend in AHB



| time | meaning                                                          | IP to set | number of cycles |
|------|------------------------------------------------------------------|-----------|------------------|
| t2   | A target acquires the address.                                   | -         | fixed to 1       |
| t3c  | Preparation time for data acquisition or data output for target. | Tgt       | >= 0             |
| t4p  | 4p Preparation time for next data output for target.             |           | >= 0             |
| t5   | Time for data acquisition or data output for target.             | -         | fixed to 1       |

# Mapping to OSCI/TLM2.0 AT 2phase



# Mapping to OSCI/TLM2.0 LT



### Mapping to OSCI/TLM2.0

- The timing specification which is not supported
  - AT

Split transaction (SPLIT transmission and RETRY transmission)

LT

Split transaction (SPLIT transmission and RETRY transmission)



AXI



# Time to spend at read in AXI



| time         | meaning                                              | IP to set | number of cycles |
|--------------|------------------------------------------------------|-----------|------------------|
| t2p          | Preparation time for data acquisition for target.    | Tgt       | >= 0             |
| t2           | Time for address acquisition for target fixed to     |           | fixed to 1       |
| t3c          | Preparation time for data output for target.         | Tgt       | >= 0             |
| t4p <i>i</i> | Preparation time for next data output for target.    | Tgt       | >= 0             |
| t5p <i>i</i> | Preparation time for data acquisition for initiator. | Ini       | fixed to 0*      |
| t5 <i>i</i>  | Time for data acquisition for initiator.             |           | 1 fixing         |

# Time to spend at write in AXI



| time         | meaning                                                       | IP to set | number of cycles |
|--------------|---------------------------------------------------------------|-----------|------------------|
| t2p <i>i</i> | Preparation time for address and data acquisition for target. | Tgt       | >= 0             |
| t2 <i>i</i>  | Time for address and data acquisition for target fixed to 1   |           |                  |
| t1pi         | Preparation time for next data output for initiator. Ini      |           | fixed to 0       |
| t3c          | Preparation time for response output for target.              |           | >= 0             |
| t5p          | Preparation time for response acquisition for initiator.      | Ini       | fixed to 0*      |
| t5           | Time for response acquisition for initiator fixed to          |           | fixed to 1       |



# Mapping /Read to OSCI/TLM2.0 AT 2phase

Timing specification details T2 T3 T4 T10 Ini Tqt name address **ADDR AVALID AREADY** data1 data2 **RDATA RVLAID** RDC  $\mathsf{t}_{\mathsf{51}}$ **RREADY** Initiator  $+\Sigma t_5$  $\Sigma t_{4p} + \Sigma t_5$  $t_2 + t_{2p} + t_{3c}$  $\Sigma t_{4p}$ bw +t<sub>3c</sub> Initiator calculates the spending time per 1 data with  $\{(\sum t4p+\sum t5)/transmitted\ data$ © 2012 Renesas Electronics (number) after completion notification reception.

# Mapping / Write to OSCI/TLM2.0 AT 2phase

#### Timing specification details



# Mapping /Read to OSCI/TLM2.0 LT

Timing specification details T2 T3 T4 T10 Ini Tgt name address **ADDR AVALID AREADY** data1 data2 **RDATA** RDC **RVLAID RREADY** Initiator  $(t_2 + \Sigma t_5 +) t_{2p} + \Sigma t_{4p} + t_{3c}$ b  $+(t_2 + \Sigma t_5 +) t_{2p} + \Sigma t_{4p}$  $+t_{3c}$ 

# Mapping / Write to OSCI/TLM2.0 LT

#### Timing specification details



#### Mapping to OSCI/TLM2.0

- The timing specification which is not supported
  - AT
    - Pipeline treatment of WAC WDC (The output order that WDC is output behind t2p after WAC, is fixed.)
  - LT
    - Pipeline treatment of RAC RDC.
    - Pipeline treatment of WAC WDC WRC.



# Parameterization of latency



# Parameterization of latency

- Each of read/write has 1 parameter in APB.
- Each of read/write has 3 parameters in AHB and AXI.

| latency setting API      | APB             | АНВ                       | AXI                                           |
|--------------------------|-----------------|---------------------------|-----------------------------------------------|
| SetReadLatency           | t <sub>2p</sub> | -                         | -                                             |
| SetWriteLatency          | t <sub>2p</sub> | -                         | -                                             |
| SetReadInitialLatency    | -               | t <sub>2p</sub>           | t <sub>2p0</sub> of read address channel      |
| SetWriteInitialLatency   | -               | t <sub>2p</sub>           | t <sub>2p0</sub> of write address channel     |
| SetReadFirstDataLatency  | -               | t <sub>4p1</sub> *        | t <sub>2p</sub> of first read data channel    |
| SetWriteFirstDataLatency | -               | t <sub>4p1</sub> *        | t <sub>2p1</sub> of first write data channel  |
| SetReadNextDataLatency   | -               | t <sub>4pn</sub> (n>=2)*  | $t_{4pn}$ of next read data channel (n>=1)    |
| SetWriteNextDataLatency  | -               | t <sub>4pn</sub> (n>=2) * | t <sub>2pn</sub> of write data channel (n>=2) |

<sup>\*:</sup> Latency of FirstData and NextData is usually same value in AHB.



# APB (read/write)

- $\blacksquare$   $t_{2p}$  is parameterized in APB.
- One of read is set with setReadLatency function, one of write is set with setWriteLatency function.



# AHB (read/write commonness)

- $\blacksquare$   $t_{2p}$ ,  $t_{4p1}$  and  $t_{4pn}$  (n>=2) are parameterized.
- $\blacksquare$   $t_{4p0}$  is set with setReadInitialLatency/setWriteInitialLatency function.
- $\blacksquare$   $t_{4p1}$  is set with setReadFirstDataLatency/setWriteFirstDataLatency function.
- $t_{4pn}$  (n>=2) is set with setReadNextDataLatency/setWriteNextDataLatency function.



# AXI (Read)

- $t_{2p}$  of read address channel and  $t_{4p1}$ ,  $t_{4pn}$ (n>=2) of read data channel are parameterized.
- $\blacksquare$   $t_{2p}$  of read address channel is set with setReadInitialLatency function.
- $\blacksquare$   $t_{4p1}$  of read data channel is set with setReadFirstDataLatency function.
- $\blacksquare$   $t_{4pn}$  of read data channel (n>=2) is set with setReadNextDataLatency function.



### AXI (Write)

- $\mathbf{I}_{2p0}$  of write address channel and t2p1, t2pn(n>=2) of write data channel are parameterized.
- $\blacksquare$   $t_{2p0}$  of write address channel is set with setWriteInitialLatency function.
- $\blacksquare$   $t_{2p1}$  of write data channel is set with setWriteFirstDataLatency function.
- $\blacksquare$   $t_{2pn}$  of write data channel (n>=2) is set with setWriteNextDataLatency function.



WAC: write address channel

WDC:write data channel

#### Restriction

- ■AHB.
  - Split transaction (SPLIT transmission and RETRY transmission)
- **AXI.** 
  - ■Pipeline treatment of WAC WDC at AT (The output order that WDC is output behind t2p after WAC, is fixed.)
  - ■Pipeline treatment of RAC RDC at LT
  - ■Pipeline treatment of WAC WDC WRC at LT

