

# Application Note for Complex Trigger Language

Release 09.2023



| TRACE32 Online Help                                        |    |
|------------------------------------------------------------|----|
| TRACE32 Directory                                          |    |
| TRACE32 Index                                              |    |
| TRACE32 Documents                                          | þ  |
| Complex Trigger Language                                   | Þ  |
| Application Note for Complex Trigger Language              | 1  |
| History                                                    | 5  |
| Introduction                                               | 6  |
| Basic Structure of CTL Programs                            | 7  |
| Complex Statements                                         | 8  |
| Agents                                                     | 9  |
| Core Agents                                                | 9  |
| Bus Monitors                                               | 11 |
| Default Agent                                              | 11 |
| State Machines                                             | 12 |
| Using CTL State Machines                                   | 12 |
| Multiple State Machines                                    | 13 |
| TRACE32 Commands Using CTL Programs                        | 14 |
| CTL Onchip Triggers Logic                                  | 14 |
| CTL for Trace Find                                         | 14 |
| CTL Streaming Trace Trigger                                | 15 |
| CTL for Onchip Triggers Logic                              | 16 |
| CTL for TriCore MCDS                                       | 17 |
| Supported Targets                                          | 17 |
| Multicore Support                                          | 17 |
| Selective Bus Trace                                        | 17 |
| Automatic Configuration of the Trace Source Multiplexers   | 18 |
| TriCore Data Trace: COREx Vs. SRI-CPUx                     | 18 |
| Limitations                                                | 19 |
| Examples                                                   | 20 |
| CTL for Arm ETM                                            | 31 |
| Examples for CTL Trace Find                                | 32 |
| Use case 1: Checking Variable Access                       | 32 |
| Use case 2: Checking Timing Constraints - Address Duration | 34 |
| Use case 3: Checking Timing Constraints - Address Distance | 36 |
| Keyword Reference: CTL Conditions/Triggers                 | 38 |

BREAKPOINT ABCDE breakpoint BusTrigger Incoming trigger signal BMC Benchmark counter event COUNT Trigger on event counter CLOCKS Trigger on clock cycles counter CTM Cross trigger **EXTIN** External input FALSE Never condition FI AG Flag status MACHINE Machine comparator Program Program access comparator ProgramFail Conditional instruction execution **ProgramPass** Conditional instruction execution Read Read access ReadWrite Read or write access SingleShot Single shot comparators SingleShot.Program Single shot program execution SingleShot.ProgramFail Single shot conditional execution SingleShot.ProgramPass Single shot conditional execution SingleShot.Read Single shot read access SingleShot.ReadWrite Single shot read or write access SingleShot.Write Single shot write access NoSingleShot Non single shot comparators NoSingleShot.Program Non single shot program execution Non single shot conditional execution NoSingleShot.ProgramFail NoSingleShot.ProgramPass Non single shot conditional execution NoSingleShot.Read Non single shot read access NoSingleShot.ReadWrite Non single shot read or write access NoSingleShot.Write Non single shot write access STATE.LEAVE Leave the state transition (edge sensitive) STATE.ENTER Enter the state transition (edge sensitive) STATE.TRACEON Active state of a TraceON action TASK Task comparator TIME Time counter comparator TRUE Always condition Var Specify HLL expressions Var.Program Flat function execution Variable read access Var.Read Variable read or write access Var.ReadWrite Var.status tbd. Var.Write Variable write access Write Write access ZONE Zone comparator

38

38

38

38

39

39

39

40

40

40

41 41

42

42

43 44

44 44

45

45

46

46

47 47

47

48

48

48

49

50

50

51

51

51

52

53 53

53

54 54

54

55

55

| Keyword Reference: CTL A | ctions                                               | 56 |
|--------------------------|------------------------------------------------------|----|
| Break                    | Stop the program execution                           | 56 |
| BusCLOCKS                | tbd.                                                 | 56 |
| BusCount                 | tbd.                                                 | 56 |
| BusTIME                  | tbd.                                                 | 56 |
| BusTrigger               | tbd.                                                 | 57 |
| CLEAR                    | Clear flag                                           | 57 |
| CTM                      | Cross trigger                                        | 57 |
| ENABLE                   | Enable counter                                       | 58 |
| EVENT                    | Trace event                                          | 58 |
| EXTOUT                   | External output                                      | 59 |
| FOUND                    | Add the trace sample to the search items result      | 59 |
| GOTO                     | Change active state                                  | 59 |
| INCrement                | Increment counter                                    | 60 |
| RELOAD                   | Reload counter                                       | 60 |
| SET                      | Set flag                                             | 61 |
| Spot                     | Shortly stop the program execution                   | 61 |
| TraceData                | Sample specified data event                          | 62 |
| TraceEnable              | Enable the trace on the specified event              | 63 |
| TraceOFF                 | Switch OFF the trace sampling                        | 64 |
| TraceON                  | Switch ON the trace sampling                         | 65 |
| TraceTIME                | tbd.                                                 | 65 |
| TraceTrigger             | Stop sampling to the trace buffer on specified event | 65 |
| CTL Programming Errors   |                                                      | 66 |

# **Application Note for Complex Trigger Language**

Version 09-Oct-2023

# History

15-Feb-2023 Added onchip CTL support for miniMCDS.

29-Jun-2022 Initial version.

NOTE: This manual is still under construction.

Complex Trigger Language (CTL) is a high-level parallel programming language. The main idea behind CTL is to offer TRACE32 users a simple and powerful interface to debug and trace complex scenarios without any specific knowledge about the low-level onchip triggers logic. The language is defined to grant a fine control of the debug logic and trace sources. CTL enables the user to fully benefit from the debug and trace capabilities offered by the target while keeping the entire focus on debugging and testing.

Additionally to onchip triggers logic, CTL supports **Trace.Find** as a target. This empowers TRACE32 with an advanced trace find feature. When operating in SPY mode, the trace find results could be used as a test vehicle for onchip triggers. This enables CTL for targets that do not provide any hardware support to implement complex triggers.

This document is divided into the following sections:

- 1. Basic Structure of CTL Programs
- 2. TRACE32 Commands Using CTL Programs
- 3. CTL for Onchip Triggers Logic

Separate sub-sections discuss peculiarities of each implementation for onchip CTL and present selected use cases with example CTL programs:

- CTL for TriCore MCDS
- CTL for Arm ETM
- 4. Examples for CTL Trace Find
- 5. Keyword Reference: CTL Conditions/Triggers
- 6. Keyword Reference: CTL Actions
- 7. CTL programming errors

NOTE:In this document, simple triggers refer to breakpoints that are enabled via<br/>Break.Set commands.<br/>CTL is not intended to replace simple triggers, although most breakpoints could<br/>be easily written in CTL as well. The reason is that the onchip trigger unit<br/>programmed by CTL might behave differently from the trigger logic<br/>programmed by simple triggers. E.g. for TriCore the stopping breakpoints set<br/>via simple triggers are programmed to OCDS (break-before-make breakpoints).<br/>While the CTL Break actions are programmed to MCDS (the cores are stopped<br/>a few instructions after the trigger event).

CTL makes an abstraction of the target architecture whenever possible. Apart from a few exceptions, e.g. special bus agents, the syntax is architecture-independent and valid for all CTL targets.

Following is the list of elements composing CTL programs:

- Complex statements
- Agents (optional)
- Levels (optional)
- Comments (start with // or ; and end with the next line break).

CTL is **not** white space sensitive, but it is recommended to use indentations for better readability of the program.

CTL keywords are not case-sensitive. The following examples of CTL programs are similar:

```
if var.program(sieve)
    traceenable program
```

```
IF Var.Program(sieve)
TraceEnable Program
```

Upper case letters indicate the short forms of CTL keywords and must not be omitted. All lower case letters can be omitted. Following is a short form of the above example program:

if v.p(sieve) te p Complex statements are the basic elements of any CTL program.

Each complex statement is composed of:

- One condition
- One or multiple action(s) to be performed when the condition is satisfied

A CTL condition starts with the keyword IF followed by a logical combination of one or more subexpressions. The condition's sub-expressions could be issued from different or similar qualifier types (program comparators, memory address comparators, access types,...).

A line break separates the condition from its associated action(s).

Multiple actions of a complex statement must be separated by line breaks.

#### Example:

```
// Enable program trace for the first instruction of the function sieve
IF Program(ENTRY:sieve)
TraceEnable Program
```

Details about CTL conditions and actions are provided in the following sections:

- Keyword Reference: CTL Conditions/Triggers
- Keyword Reference: CTL Actions

 NOTE:
 Given that CTL is a parallel programming language, the order in which the complex statements appear in a CTL program is not important. All the complex statements are evaluated in parallel.

 If the CTL program is implementing a state machine, all the complex statements belonging to the active state are evaluated in parallel. Complex statements belonging to the inactive levels of the state machine are not evaluated.

# Agents

Each CTL condition is evaluated for a specified agent, and likewise, each CTL action is to be performed by a specified agent. The syntax to specify an agent is as follows:

<agent\_name>::

The CTL syntax allows using agents with global scopes or local scopes.

Local scope agents are to be specified as prefixes to the associated actions and/or sub-expressions of the CTL conditions.

#### Example:

An agent that is not prefixing any action or condition's sub-expression is a global scope agent.

The scope of a global agent starts from the specification of the agent name and ends with the specification of another global scope agent name.

#### Example:

```
CORE0::

IF Program(sieve0)

TraceEnable Program

IF Var.Write(mstatic1)

TraceEnable Write Address Data

CORE1::

IF Var.Program(func2)

TraceEnable Write Address Data
```

Two types of agents are to be distinguished:

- Core agents
- Bus agents/monitors

#### **Core Agents**

The syntax to specify a core agent is as follows:

CORE<n>::

The index *n* refers to the logical core number controlled by the TRCAE32 PowerView instance.

SplitCORE:: and JoinCORE:: are multicore agents. These are used to specify that a complex statement is to be evaluated for all the cores that are assigned to the PowerView instance (except for limitations from the target). The difference between SplitCORE:: and JoinCORE:: is as follows:

- SplitCORE:: specifies that each statement is to be evaluated for each core separately.
- JoinCORE:: specifies that all cores collaborate to evaluate a statement.

#### Example 1:

The TRACE32 PowerView instance is controlling 2 cores of the target CPU (CORE.ASSIGN 1. 2.).

In the following CTL program CORE1:: is used as global scope agent:

```
CORE1::
IF Var.Write(mstatic)
TraceEnable Program
```

This enables program flow trace of the second core if write access to the variable mstatic is performed by the same core.

#### Example 2:

The TRACE32 PowerView instance is controlling 2 cores of the target CPU (CORE.ASSIGN 1.2.).

In the following CTL program SplitCORE: : is used as a global scope agent:

```
SplitCORE::
IF Var.Write(mstatic)
TraceEnable Program
```

When loading this CTL program, the complex statements is programmed for both cores separately. This means that:

- The program flow trace of the first core is enabled when the latter performs a write access to the variable mstatic.
- The program flow trace of the second core is enabled when the latter performs a write access to the variable mstatic.

#### Example 3:

The TRACE32 PowerView instance is controlling 2 cores of the target CPU (CORE.ASSIGN 1. 2.).

In the following CTL program JoinCORE: : is used as global scope agent:

```
JoinCORE::
IF Var.Write(mstatic)
TraceEnable Program
```

When loading this CTL program, both cores collaborate to evaluate the complex statement. This means that the program flow trace of both cores is enabled when one of both cores performs a write access to the variable mstatic.

## **Bus Monitors**

When using bus agents the trace sources are observed at the level of bus transactions. Thus, no program trace or program triggers are available for bus agents.

The list of bus agents is architecture-dependent. The list of available agents varies also depending on the target CPU.

In some cases, the bus name is used as the CTL agent. In other cases, bus agents refer either to bus masters initiating the transaction (e.g. DMA) or bus slaves incurring the transaction (e.g. memory units).

#### Examples of bus agents:

- SPB:: is to be used for observing the transactions on the Shared Peripheral Bus (SPB) of a TriCore AURIX device.
- SRI-LMU: : is to be used for observing accesses to Local Memory Unit and EMEM of an AURIX TC2x device via the Shared Resource Interface (SRI) fabric.
- SRI-DMA:: is to be used for observing DMA transactions on AURIX TC3x device via the SRI fabric.

## **Default Agent**

If no agent is specified, SplitCORE: : is used as the default agent.

In the following example, both CTL programs are equivalent.

#### Example:

```
IF Var.Program(sieve)
TraceEnable Program
```

#### SplitCORE::

```
IF Var.Program(sieve)
TraceEnable Program
```

## Using CTL State Machines

State machines could be used for debugging sequential events. The syntax to specify levels of state machines is as follows:

<level\_name>:

The scope of a state machine level starts from the specification of the level name and ends with the specification of another level name.

The complex statements belonging to the scope of a state machine level are only evaluated when the level is active.

The first level specified in a CTL program is handled as the start level.

Transitions between different levels of a state machine are to be specified using GOTO <target\_level> actions.

#### Example:

```
CORE0::
start:
    // transition to level1 statement
    IF Program(ENTRY:sieve)
        GOTO level1
level1:
    // transition back to start level
    IF Program(RETURN:sieve)
        GOTO start
    // stopping statement
    IF Var.Write(mstatic1==2)
        Break
```

In this example, the CTL program implements a state machine with 2 levels/states.

The state machine is initially at the start state. As soon as core0 executes the entry point of sieve() function, a state transition to level1 occurs. When executing the return instruction of the function sieve(), a state transition back to the level start occurs.

This implicates that level1 is active as long as core0 is executing the function sieve() or one of its nested functions. The level start is active otherwise.

Only when level1 is active the stopping statement is evaluated.

Activating this CTL program will cause the target to **Break** when the following conditions are fulfilled:

- The agent core0 is executing the function sieve() or one of its nested functions.
- The agent core0 writes the value 2 to the variable mstatic1.

If initially, core0 is already in sieve(), the stopping statement would not be evaluated until the next execution of sieve(), triggering a state machine transition to level1.

## **Multiple State Machines**

CTL allows programming multiple state machines. Levels that belong to a state machine are to be prefixed by the state machine name as follows:

```
<state_machine>.<level_name>:
```

#### Example:

In the following CTL program m1 and m2 are independent state machines:

- m1 specifies that the target is to be stopped if func1() is called by func9() or one of its nested functions.
- m2 specifies that the target is to be stopped if the variable mstatic1 is written outside func2() or one of its nested functions.

```
//------
// implementation of the state machine m1
m1.start:
   IF Program(ENTRY:func9)
      GOTO m1.level1
m1.level1:
   IF Program(RETURN:func9)
      GOTO m1.start
   IF Program(ENTRY:func1)
      Break
//-----
// implementation of the state machine m2
//-----
          _____
m2.level0:
   IF Program(ENTRY:func2)
      GOTO m2.level1
   IF Var.Write(mstatic1)
      Break
m2.level1:
   IF Program(RETURN:func2)
      GOTO m2.level0
```

CTL could be used with different targets:

- CTL for Onchip Triggers Logic
- CTL for Trace Find
- CTL Streaming Trace Trigger

This section presents different CTL targets and their corresponding TRACE32 commands.

# **CTL Onchip Triggers Logic**

CTL for onchip trigger logic (or Onchip CTL) requires that the target CPU provides the onchip logic to implement complex triggers. While the complexity level is limited by the onchip resources provided by the trigger unit, onchip CTL has the fastest response time compared to other CTL targets.

The following table recapitulates the list of TRACE32 commands that are used for onchip CTL.

| Break.Program     | Opens interactive softkey-driven editor for CTL programs                                           |
|-------------------|----------------------------------------------------------------------------------------------------|
| Break.ReProgram   | Activates existing program file                                                                    |
| Break.ViewProgram | Opens a window that shows the state of the CTL trigger unit                                        |
| Break.CLEAR       | Resets onchip trigger logic that is programmed by CTL. This command doesn't reset simple triggers. |

More information about CTL onchip triggers can be found in the chapter CTL for Onchip Triggers Logic.

# **CTL for Trace Find**

Using CTL for trace find allows searching for the occurrence(s) of complex events in the trace recording, e.g. sequential events happening in a specific or even arbitrary order.

After the CTL program for trace find is activated, the commands **Trace.Find** and **Trace.FindAll** are to be used to find the matching items in the trace recording that are fulfilling the complex search criteria as specified by the CTL program.

CTL for trace find does not require any onchip triggering logic. Thus, CTL for trace find has unlimited complexity and can be used with any target providing trace capabilities.

When using <trace>.Mode STREAM, it is possible to analyze trace results while streaming using the option /SPY:

Trace.FindAll /SPY

The search result could be used as a test vehicle for onchip triggers: The trace stream file is processed and analyzed at runtime (while the target is running and the trace is armed) to search for items fulfilling the complex search criteria as specified by the CTL program. The target and/or the trace recording could be stopped (**Break** or **TraceTrigger**) when the scenario of interest is recorded and detected.

Compared to Onchip CTL, CTL for Trace Find has a longer response time. The response time is affected by:

- The processing capacity of the host computer.
- The bandwidth of the whole trace transmission chain (from TRACE32 debug and trace tool to the hard drive of the host computer).

The following table recapitulates the list of the TRACE32 commands that are used for CTL Trace Find.

| Trace.FindProgram     | Opens interactive softkey-driven editor for trace find CTL programs |
|-----------------------|---------------------------------------------------------------------|
| Trace.FindReProgram   | Activates existing program file for trace find target               |
| Trace.FindViewProgram | Opens a window that shows the state of the CTL trace find program   |

# **CTL Streaming Trace Trigger**

tbd.

| RTS.Program     | tbd. |
|-----------------|------|
| RTS.ReProgram   | tbd. |
| RTS.ViewProgram | tbd. |
| RTS.CLEAR       | tbd. |

To use onchip CTL, the target CPU must provide hardware support to implement complex triggers.

The following subsections are independent. Each is discussing onchip CTL implementation for a specific target architecture. Selected use cases and example CTL programs are presented.

- CTL for TriCore MCDS
- CTL for Arm ETM

# Supported Targets

Onchip CTL is only supported for AURIX devices with available MCDS modules (MCDS, MCDSlight, or miniMCDS). CTL support for miniMCDS requires TRACE32 release 2023/02 or newer.

The PRACTICE function MCDS.Module.NAME() could be used to check the name of the MCDS module for the selected CPU.

## **Multicore Support**

The MCDS module of TriCore devices is restricted to generating trace and trigger information for a limited number of cores. The consequence is that the multicore agents are restricted to the TriCore cores that are assigned to the PowerView instance, and that are selected as core agents via the MCDS window or using the commands MCDS.ProgramTrace.Agents and MCDS.DataTrace.Agents.

## Selective Bus Trace

CTL provides a simple interface for selective bus trace. The complex statements are to be assigned to the appropriate bus agents.

- The agent SPB: : is to be used for tracing and triggering over the System Peripheral Bus (SPB).
- The TriCore MCDS module is using trace multiplexers to select which trace sources are to be observed on the Shared Resource Interconnect (SRI) fabric. SRI agent names are formed by the SRI- prefix, followed by the name of the trace source as defined by Trace Source Multiplexer setting options in the Infineon documentation. Following are some examples:
  - SRI-LMU:: AURIX TC2x agent name to observe access to LMU SRAM and EMEM via SRI.
  - SRI-OLDA: : AURIX TC3x agent name to observe access to Online Data Acquisition via SRI.
  - SRI-DMA: : AURIX TC3x agent name to observe DMA transactions via SRI.
  - SRI-CPU1:: AURIX TC2x/TC3x agent name to observe access to TriCore1 local memories via SRI.

Not all trace sources are available for all target CPUs. The exhaustive list of available bus agents for each CPU selection could be displayed by clicking on the advanced button of the MCDS window.

When activating a CTL program, an automatic configuration of the MCDS trace source multiplexers is performed. TRACE32 combines the list of agents issued from the following configurations and configures the trace source multiplexers accordingly:

- The list of agents that are used by the compiled CTL program.
- The list of core agents that are selected by the commands MCDS.ProgramTrace.Agents and MCDS.DataTrace.Agents
- The list of bus trace agents that are selected by the command MCDS.BusTrace.Agents
- The status of the peripheral trace that is configured by the command MCDS.PERipheralTrace

An error is thrown if there is no valid MCDS configuration to observe all the selected agents at the same time. The user must decide which agents are most important to be observed for his use case.



When a CTL program is activated, the configuration of the trace source multiplexers performed by the same PowerView instance via the commands **MCDS.SOURCE.Set** is discarded.

# TriCore Data Trace: COREx Vs. SRI-CPUx

Using the MCDS module of AURIX devices there are 2 options to observe memory accesses relatively to a TriCore core:

- Observe the read/write accesses performed by the core (e.g. when executing a load or store instruction). In this configuration, the TriCore core is observed as a bus master.
- Observe the read/write accesses to the core local memories via the SRI fabric. In this configuration, the TriCore core is observed as a bus slave incurring the access.

Different CTL agents are to be used in both cases.

#### Example:

CORE0:: is used to observe the first core assigned to the PowerView instance as a master. In this case, memory accesses performed by the core are to be observed.

SRI-CPU0:: is used to observe TriCore0 as an SRI slave. In this case, accesses to the core local memories via SRI are to be observed. The agents are distinguished by the physical index of the TriCore cores (SRI-CPU1:: refers to TriCore1, ..., SRI-CPU5:: refers to TriCore5).

MCDS module of AURIX TC2x allows a selected TriCore to be observed as a core (read/write accesses generated by the core are observed) and SRI slave at the same time. E.g. a CPU source Multiplexer could be configured to observe the core accesses, and a SRI source multiplexer could be configured to observe the same core as SRI slave.

As opposed to AURIX TC2x, MCDS module of AURIX TC3x only allows the core to be observed either as a master or as an SRI slave but not both at the same time. CTL throws an error when a user program causing such a conflict is enabled.

## Limitations

- The current implementation of onchip CTL for TriCore doesn't support complex statements that combine conditions and actions issued from different agents.
- JointCORE: : agent is currently not supported by onchip CTL for TriCore.
- Due to known behavior of the MCDS module, there is a dead time of up to 2 MCDS clock cycles during counters, flags, and state changes. This must be considered by the user when writing CTL programs or analyzing the test results.

In this section, selected CTL use-cases for TriCore MCDS are presented.

#### Use case 1: Debug Memory Overwrite

#### User Story - Part 1:

In this example, an AURIX TC3x emulation device is used (e.g. TC397XE)

The user expects the variable vdouble to be only changed by the function func2c. But this gets overwritten by other values than the function func2c is expected to write.

As a first test, the following CTL program is used to check if TriCore0 is performing any write access to vdouble from outside the function func2c.

#### CTL Program:

```
CORE0::
IF Var.Write(vdouble)&&!Var.Program(func2c)
TraceEnable Program
```

By prefixing a qualifier with "Var.", the address range of the specified HLL expression is used.

#### **Results:**

The test shows that the startup code \_c\_init\_entry and other functions (WorkSieve and func7) are also writing to vdouble (see the trace chart in the following screenshot).

| TRACE32 PowerView for TriCore                                                                                                                                                                                                                                                   | -            |            | ×        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------|----------|
| <u>File Edit View Var Break Run CPU Misc Trace Perf Cov TC39x Window H</u>                                                                                                                                                                                                      | <u>l</u> elp |            |          |
| N M 🗛   ↓ 🗸 Ċ   ▶ II   🕮   ? 🌾   🌚   📰 🎟 🛄 🐼 🐼 🚳 関 :                                                                                                                                                                                                                            | 1 🖉          |            |          |
| [B::Break.Program]             Ø Setup         Save         Save         Save          Save As         B Quit         Pi Find         O         ¶         ±         ±         U         CORE0::         IF Var.Write(vdouble)&&!Var.Program(func2c)         TraceEnable Program |              | VenProgram |          |
| [ok] DEFault ALL Program Read Write other                                                                                                                                                                                                                                       | previ        | ous        | <b>,</b> |
| Harrace.Chart.sYmbol /CORE 0.                                                                                                                                                                                                                                                   | _            |            | 23       |
| <pre>     Setup iii Groups. :: Config Q Goto Q Goto iii Find D In PD Out [</pre>                                                                                                                                                                                                |              | 0.         | • • •    |
| B::                                                                                                                                                                                                                                                                             |              |            |          |
| Components         trace         Data         Var         List         PERF         SYStem           embedded indemo ctl.cmm, line 23   mode: CTL (EDITED)   line: 4   col 0         stopped                                                                                    | other        | previo     | _        |

#### User Story - Part 2:

The variable vdouble is located in the DSPR of TriCore0. The user requirement is to check that no other TriCore cores or bus agents are also writing to this variable. To achieve this, TriCore0 is to be observed as SRI slave using the agent SRI-CPU0::

Considering that the write access might be part of a 64-bit burst write, the address range needs to be extended to cover a 64-bit aligned range. PRACTICE functions and other arithmetic calculations could be invoked by the CTL program. In this example the PRACTICE function **ADDRESS.OFFSET()** is used to retrieve the variable address in-order to calculate the 64-bit address range to be observed.

#### CTL Program:

```
SRI-CPU0::
    IF Write((Address.OFFSET(vdouble)&(~0x7))++0x7)
        TraceEnable Write Address Data
```

#### **Results:**

This second test proves that no other write access to vdouble is performed by any agent other than TriCore0: The resulting Trace.List window in the following screen shot is empty.



In this example, an AURIX TC3x emulation device is used (e.g. TC397XE)

#### User Story:

In the used test application the variable <code>mcount</code> is incremented each iteration of the function <code>mainloop</code>. The user needs to measure the runtime of the function <code>sieve</code> which is called once by <code>mainloop</code> iteration. Runtime measurement is to be started after a specified number of iterations.

The user requirements for this test case are as follows:

- Trace all write accesses to mcount (the address and the write values are to be sampled).
- Starting from the iteration number 20000 of the function mainloop, the entry and return instructions of the function sieve are to be traced.
- The measurements are to be stopped after collecting 1000 runtime samples.

#### CTL Program:

CTL flags can be used to implement the test requirements:

```
IF Var.Write(mcount)
   TraceEnable Write Address Data
IF Var.Write(mcount==20000.)
   SET myFlag
IF (Program(ENTRY:sieve)||Program(RETURN:sieve))&&FLAG(myFlag)
   TraceEnable Program
IF Var.Write(mcount==21000.)
   Break
```

#### **Results:**

The **Trace.List** window shows that program trace (for the entry and return instructions of the function sieve) is started after the value 20000 (0x4E20) is written to mcount.

| B::Trace.Li | ist 😐                                                                                                                                        | • × |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Setup       | 🔡 Config 📭 Goto 🏥 Find 🙌 Chart 🛛 🌉 Profile 🔛 MIPS 🔷 More 🛛 🗶 Less                                                                            |     |
|             | run laddress cycle data symbol ti,back                                                                                                       |     |
| 00035538    | D:70000030 wr-data 00004E13c39x_sieve_intmem\taskc\mcount 30.300us                                                                           | ^   |
| 00035523    | D:70000030 wr-data 00004E14c39x_sieve_intmem\taskc\mcount 30.380us                                                                           |     |
| 00035509    | D:70000030 wr-data 00004E15c39x_sieve_intmem\taskc\mcount 30.410us                                                                           | =   |
| 00035494    | D:70000030 wr-data 00004E16c39x_sieve_intmem\taskc\mcount 30.380us                                                                           |     |
| 00035479    | D:70000030 wr-data 00004E17 .c39x_sieve_intmem\taskc\mcount 30.320us                                                                         |     |
| 00035465    | D:70000030 wr-data 00004E18c39x_sieve_intmem\taskc\mcount 30.300us                                                                           | '   |
| 00035451    | D:70000030 wr-data 00004E19 .c39x_sieve_intmem\taskc\mcount 30.380us<br>D:70000030 wr-data 00004E1A .c39x_sieve_intmem\taskc\mcount 30.410us |     |
| 00035437    | D:70000030 wr-data 00004E1Ac39x_sieve_intmem\taskc\mcount 30.410us<br>D:70000030 wr-data 00004E1Bc39x_sieve_intmem\taskc\mcount 30.380us     |     |
| 00035407    | D:70000030 wr-data 00004E1BC39X_SIEVe_Intmem\taskc\mcount 30.380us                                                                           |     |
| 00035392    | D:70000030 wr-data 00004E1CC39X_Sieve_intmem\taskc\mcount 30.320us                                                                           |     |
| 00035378    | D:70000030 wr-data 00004EIE .c39x_sieve_intemen\taskc\mcount 30.380us                                                                        |     |
| 00035364    | D:70000030 wr-data 00004E1Fc39x_sieve_intmem\taskc/mcount 30.410us                                                                           |     |
| 00035349    | D:70000030 wr-data 00004E20c39x_sieve_intmem\taskc\mcount 30.380us                                                                           |     |
| 00035338    | P:70100BE4 ptrace .tc39x_sieve_intmem\taskc\sieve 25.040us                                                                                   |     |
|             | #define MAX_SIZE 128                                                                                                                         |     |
|             | <pre>char flags[MAX_SIZE+1];</pre>                                                                                                           |     |
|             | <pre>static int sieve(void)  /* sieve of erathostenes */ {</pre>                                                                             |     |
|             | register int i, prime, k;<br>int count:                                                                                                      |     |
| 771         | int size = ((mcount)%20000) ? (MAX_SIZE>>3) : MAX_SIZE;                                                                                      |     |
| +           | ld.w d15,0x70000030 ; d15,mcount                                                                                                             |     |
|             | mov d0,#0x4E20                                                                                                                               |     |
| 0035324     | TRACE ENABLE                                                                                                                                 |     |
| 790         | }                                                                                                                                            |     |
|             | ret16                                                                                                                                        |     |
| 0035319     | P:70100B7A ptraceve_intmem\taskc\mainloop+0x23A 0.000us                                                                                      |     |
| 728         | datas.b[0] = 0x12;                                                                                                                           |     |
|             | mov16 d15,#0x12                                                                                                                              |     |
|             | st.b 0x70000004,d15 ; datas,d15                                                                                                              |     |
| 0035311     | D:70000030 wr-data 00004E21c39x_sieve_intmem\taskc\mcount 0.590us                                                                            |     |
| 0035 300    | P:70100BE4 ptracetc39x_sieve_intmem\taskc\sieve 25.020us                                                                                     |     |
|             | #define MAX_SIZE 128                                                                                                                         |     |
|             | <pre>char flags[MAX_SIZE+1];</pre>                                                                                                           |     |
|             | <pre>static int sieve(void)  /* sieve of erathostenes */ {</pre>                                                                             |     |
|             | register int i, prime, k;                                                                                                                    |     |
|             | int count;                                                                                                                                   |     |
| 771         | <pre>int size = ((mcount)%20000) ? (MAX_SIZE&gt;&gt;3) : MAX_SIZE;</pre>                                                                     |     |
|             | ld.w d15,0x70000030 ; d15,mcount                                                                                                             |     |
|             | mov d0,#0x4E20<br>TRACE ENABLE                                                                                                               |     |
| 0035290     | P:70100C54 ptrace                                                                                                                            |     |
|             | a_steve_tremem(cuske(steve+0x/0 4//500s                                                                                                      |     |
|             |                                                                                                                                              |     |

The window **Trace.STATistic.AddressDURation** shows that 1000 runtime measurements of the function sieve are recorded (samples: 1000). In a single iteration, the execution time of sieve took longer time (max: 36.12µs) than in usual runs (avr:4.741µs)

| Ļ | Setup                | 🛛 Chart 🛛 🏮 | Zoom 📮    | Zoom | 🗘 Full  |      |           |        |         |     |   |
|---|----------------------|-------------|-----------|------|---------|------|-----------|--------|---------|-----|---|
|   |                      | samples:    | 1000.     | avr: | 4.741us | min: | 4.710us   |        | 6.120us |     |   |
|   |                      | total: (    | 538.195ms | in:  | 4.741ms | out: | 633.453ms | ratio: | 0.742%  |     |   |
|   | up to                | count       |           | 1%   | 2%      | 5%   | 10%       | 20%    | 50%     | 100 |   |
|   | 4.000us              | 0.          | 0.000%    |      |         |      |           |        |         |     | 1 |
|   | 6.000us              | 999.        | 99.900%   |      |         |      |           |        |         | _   |   |
|   | 8.000us              | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 10.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 12.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 14.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 16.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 18.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 20.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 22.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 24.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 26.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 28.000us<br>30.000us | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 32.000us             |             | 0.000%    |      |         |      |           |        |         |     |   |
|   | 34.000us             | 0.<br>0.    | 0.000%    |      |         |      |           |        |         |     |   |
|   | 36.000us             | 0.          | 0.000%    |      |         |      |           |        |         |     |   |
|   | 30.000us             | 1.          | 0.100%    | 4    |         |      |           |        |         |     |   |

#### User Story:

In the used test application the variable mcount is incremented each iteration of the main loop.

The user needs to start sampling the program flow after a given number of iterations. The user requirements for this test case are as follows:

- Trace all write accesses to mcount (the address and the write values are to be sampled).
- Starting from the 5<sup>th</sup> iteration of the main loop, the program flow trace is to be enabled.
- The target is to be stopped after the 10<sup>th</sup> iteration of the main loop.

#### CTL Program:

In the following example program, a CTL counter "mycounter" is used to count the number of write access to the variable mcount.

```
IF Var.Write(mcount)
    TraceEnable Write Address Data
    INCrement mycounter
IF COUNT(mycounter>=5.)
    TraceEnable Program
IF COUNT(mycounter>=10.)
    Break
```

#### **Results:**

Test results shown in the following screenshot could be interpreted as follows:

- A The status bar shows the state "stopped by MCDS". This indicates that an MCDS trigger has stopped the target.
- **B** The trace find window shows that the target executed the main loop for exactly 10 iterations (10 writes to mcount are recorded).
- **C** The trace list window shows that the program flow trace was enabled starting from the 5<sup>th</sup> iteration.
- **D** The trace chart shows that the program trace was enabled during the last 5 iterations: The leaf function sieve which is called once per main loop was called exactly 5 times.

| TRACE32 PowerView for TriCore         File Edit View Var Break Run CPU Misc Trace Perf Cov TC39x Window Help         N H L L +        L L +          Setup       Save As         Setup       Save As         BeBreak.Program       Image: Save As         If F Var.Write(scount)       TraceEnable Write Address Data         If Count(mycounter>>5.)       TraceEnable Program         If Count(mycounter>>5.)       If Count(mycounter>>5.)         TraceEnable Program         If Count(mycounter)         Break         Jif Save As         Jif Count         If Count         Break         Jif Save As         Jif Save As         Jif Count         Jif Co                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | → □ ×<br>B<br>3 B: Trace FindAll , Address mount CYcle Write<br>0 runn address cover the data 00000000 statistic (weamt<br>0 000003458 D: 70000010 wr-data 00000000 statistic (weamt<br>0 000003451 D: 70000010 wr-data 00000000 statistic (weamt<br>0 000003452 D: 70000010 wr-data 00000000 statistic (weamt<br>0 000003452 D: 70000010 wr-data 00000000 statistic (weamt<br>0 000003452 D: 70000010 wr-data 00000000 statistic (weamt<br>0 00000345 D: 70000010 wr-data 00000000 statistic (weamt<br>0 00000345 D: 70000010 wr-data 00000000 statistic (weamt<br>0 00000000 statistic (weamt<br>0 0000000 statistic (weamt<br>0 000000 statistic (weamt<br>0 00000 statistic |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| B:ThraceList     Image: Control of the second | BiThaceChart.Ymbol/Thack                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| B::<br>components trace Data Var List PERF SYStem Step Go<br>C.T:-00005449                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Break sYmbol Frame Register FPU MMU TRANSlaton Mr previous<br>stopped by MCDS S MDX UP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### User Story:

In a real-time context, the execution time of the function mainloop must not exceed a maximum specified time of 35 µs. In rare cases, it happens that the execution time exceeds 60 µs.

An AURIX TC3x emulation device is used, but the target board doesn't provide an AGBT interface. Only an onchip trace buffer of 2MBytes is available. The user estimates that, when the error case occurs, the program flow history available in the onchip trace buffer should be enough to track down the issue. The requirements are as follows:

- Unconditional program flow trace must be enabled.
- To track the number of execution loops, all write accesses to the variable mcount must be recorded.
- When detecting the error case (i.e. the execution time of the function mainloop exceeds a maximum specified duration of 35 µs) the trace recording must be kept enabled till the next return of the function mainloop is executed.

## CTL Program:

```
//----
// State independent complex statements
//----
// Enable unconditional program flow trace
IF TRUE()
   TraceEnable Program
// Sample all write access to mcount
IF Var.Write(mcount)
   TraceData
//-----
// State Machine implementation to stop
// tracing and Break if the mainloop
// execution time exceeds 35µs.
//-----
level0:
   IF Program(ENTRY:mainloop)
       GOTO level1
level1:
   // Restart the timer at entry to level1
   IF STATE.ENTER()
       RELOAD task timer
   // Keep counting as long as level1 is active
   IF TRUE()
       ENABLE task timer
   // mainloop return with no timeout detected
   // => Go back to level0
   IF Program(RETURN:mainloop)
       GOTO level0
   // A timeout is detected => Go to level3
   IF TIME(task timer>=35.us)
       GOTO level3
level3:
    // level3 is only reached if a time-out is detected
   // => Stop tracing and break at return of the mainloop
   IF Program(RETURN:mainloop)
       TraceTrigger
       Break
```

#### **Results:**



- A The status bar shows the state "stopped by MCDS". This indicates that an MCDS trigger has stopped the target.
- **B** The Trace.STATistic.AddressDURation window shows that the execution time of the function mainloop has once exceeded the duration of 35 μs.
- C The maximum measured duration of mainloop is 61.660  $\mu s.$
- **D** The **Trace.Chart.sYmbol** window shows that the function sieve took a longer execution time than the usual runs. The user must examine the program flow trace and focus his analysis on the function sieve.

#### User Story:

In a real time context, a function func10 must be called at least once every 35  $\mu$ s. In rare cases, the time distance between 2 consecutive calls exceeds 60  $\mu$ s.

An onchip trace configuration on AURIX TC3x emulation device is used. The user needs to examine the program flow trace when the timing constraint is violated. The requirements are as follows:

- Unconditional program flow must be enabled.
- When the timing constraint is violated, the program flow recording is to be kept enabled until the next call of func10 is executed.

#### CTL Program:

```
// Enable unconditional program flow trace
IF TRUE()
   TraceEnable Program
// Set monitoring flag and reload the distance timer at every
// execution of the func10 entry
IF Program(ENTRY:func10)
   SET monitoring flag
   RELOAD distance tmr
// Keep incrementing the distance timer as long as the monitoring
// flag is set
IF FLAG(monitoring flag)
   ENABLE distance tmr
// Set a time-out flag when the value of the distance monitoring
// timer exceeds 35 µs
IF Time(distance tmr>35.us)
   SET timeout flag
// Stop trace recording at the first execution of func10 entry
// following a time-out
IF FLAG(timeout flag)&&Program(ENTRY:func10)
   TraceTrigger
```

| Results:                                                                                                                                                                                                                                         |                      |       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------|
| TRACE32 PowerView for TriCore -                                                                                                                                                                                                                  |                      | ×     |
| File Edit View Var Break Run CPU Misc Trace Perf Cov TC39x CTL Demo Wir                                                                                                                                                                          | ndow Help            |       |
| <u>  Ŋ ⋫ ₩   ↑ ヘ Ϛ   ▶ Ⅱ      5 ₭;   ◎     圖   ௸ &amp;                                </u>                                                                                                                                                       | 1 2                  |       |
| B:: Trace. STATistic. Address DIStance func10                                                                                                                                                                                                    |                      | 8     |
| 🌽 Setup 📊 Chart ♀ Zoom ♀ Zoom                                                                                                                                                                                                                    |                      |       |
| samples: 1208. avr: 30.269us min: 30.170us max: 60.<br>total: 36.585ms in: 36.565ms out: 19.660us                                                                                                                                                | 860us                | В     |
| up to count ratio 1% 2% 5% 10% 20%                                                                                                                                                                                                               | 50% 100              |       |
| 35.000us 1207. 99.917%<br>40.000us 0. 0.000%                                                                                                                                                                                                     |                      |       |
| 45.000us 0. 0.000%<br>50.000us 0. 0.000%<br>55.000us 0. 0.000%                                                                                                                                                                                   |                      |       |
| 65.000us 1. 0.082% +                                                                                                                                                                                                                             |                      | A     |
|                                                                                                                                                                                                                                                  |                      | >     |
|                                                                                                                                                                                                                                                  |                      |       |
|                                                                                                                                                                                                                                                  |                      | ×     |
|                                                                                                                                                                                                                                                  | i.back               | ess   |
| 364 $v17 = 0;$<br>mov16 d2,#0x0                                                                                                                                                                                                                  |                      |       |
| 365 for ( i = 0 ; i < 3 ; i++ )<br>mov16 d15,#0x0                                                                                                                                                                                                |                      | ×     |
| watchpoint TraceTrigger                                                                                                                                                                                                                          | 0.050us              | ^ C   |
| -00000006<br>-00000004 P:70100072 ptraceem\sieve\func10+0x0A                                                                                                                                                                                     | 0.000us              | ~     |
|                                                                                                                                                                                                                                                  |                      | > .:: |
| B::Trace.FindAll , Address func10 CYcle Program           1209  run  address          cycle   data          symbol                                                                                                                               | ti.back              |       |
| 1209         run         address         cycle         data         symbol           -00015609         P:70100068         ptrace        e_intmem\sieve\func10           -00013867         P:70100068         ptrace        e_intmem\sieve\func10 | 30.270us<br>30.320us |       |
| -00012141 P:70100068 ptracee_intmem\sieve\func10<br>-00010402 P:70100068 ptracee_intmem\sieve\func10                                                                                                                                             | 30.270us<br>30.210us | 5 =   |
| -00008678 P:70100068 ptracee_intmem\sieve\func10<br>-00006952 P:70100068 ptracee_intmem\sieve\func10                                                                                                                                             | 30.190us<br>30.270us | s D   |
| -00005210 P:70100068 ptracee_intmem\sieve\func10                                                                                                                                                                                                 | 30.320us             | 5     |
| -00003484 - P:70100068-ptracee_intmem\sieve\func10<br>-00000010 P:70100068 ptracee_intmem\sieve\func10                                                                                                                                           | 30.270us<br>60.860us |       |
|                                                                                                                                                                                                                                                  |                      |       |
| р<br> В::                                                                                                                                                                                                                                        |                      |       |
|                                                                                                                                                                                                                                                  |                      |       |
| components trace Data Var List PERF other                                                                                                                                                                                                        | previo               | us    |
| running Off                                                                                                                                                                                                                                      | MIX U                | P     |

- A The Trace.STATistic.AddressDIStance window shows that, over 1208 recorded trace samples, the timing constraint is violated once.
- **B** The maximum recorded time distance between consecutive calls of func10 is 60.86  $\mu$ s.
- C The watchpoint mark the occurrence of the TraceTrigger action
- D The column "ti.back" shows that the distance between the last 2 calls of func10 exceeds 35  $\mu s$  for the first time.

# **Use case 1: Checking Variable Access**

#### User Story:

The user needs to find all write access to a variable vlong from outside the function main.

Trace Find Program: vlong\_access.ct

```
IF Var.Write(vlong)&&!Var.Program(main)
    FOUND
```

#### **Results:**

The results could be explored using the TRACE32 PowerView:

- 1. Click on the compile button in the CTL Trace Find editor.
- 2. Open a trace chart window with the /Track option by executing the command Trace.Chart.sYmbol /Track
- Navigate through the matching items using the button Find. Each time the trace chart window will be updated; the function that is performing the access is highlighted. Alternatively, the FindAll button could be used to list all the matching items in the Trace.FindAll window.

| Setup                                                                  | Save Save                                                                                                                | Save As                                                                                                              | 🔮 Quit 👘 Find                                                                                                                                                    | 🖍 🔍 🖣 🚉 i                                                                                                                         | 🛓 Compile 🏾 🏥 Find                                                                                                  | FindAll      | /iewProgram |
|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--------------|-------------|
|                                                                        | 1<br>2 IE Var.Wri                                                                                                        | te(vlong)&&!Va                                                                                                       | r.Program(main)                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
|                                                                        |                                                                                                                          | UND                                                                                                                  |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              | _           |
|                                                                        | <                                                                                                                        |                                                                                                                      |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              | >           |
|                                                                        | IF                                                                                                                       | GOTO REL                                                                                                             | OAD INCrement EN                                                                                                                                                 | NABLE CLEAR                                                                                                                       | SET ot                                                                                                              | her previous |             |
| PuTrace Cha                                                            | rt.sYmbol /Track                                                                                                         |                                                                                                                      |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
|                                                                        |                                                                                                                          |                                                                                                                      |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
| Setup 1                                                                | I Groups 📲 Co                                                                                                            | onfig 📭 Goto                                                                                                         |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
|                                                                        |                                                                                                                          | address                                                                                                              | +13300                                                                                                                                                           | +13350                                                                                                                            | +13400                                                                                                              | +13450       | !           |
|                                                                        | eve_intmem\t                                                                                                             |                                                                                                                      |                                                                                                                                                                  | ! _ !                                                                                                                             |                                                                                                                     |              |             |
|                                                                        | eve_intmem\t                                                                                                             |                                                                                                                      |                                                                                                                                                                  | · · · ·                                                                                                                           |                                                                                                                     |              | ·           |
|                                                                        | ve_intmem\ta                                                                                                             |                                                                                                                      |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
|                                                                        | ve_intmem\ta                                                                                                             |                                                                                                                      |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
| \tc39x sie                                                             | ve intmem\ta                                                                                                             |                                                                                                                      |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
|                                                                        | ve_intmem\tas<br>ve_intmem\tas                                                                                           | skc\func2d                                                                                                           |                                                                                                                                                                  |                                                                                                                                   |                                                                                                                     |              |             |
|                                                                        |                                                                                                                          | skc\func2d                                                                                                           | III > <                                                                                                                                                          |                                                                                                                                   |                                                                                                                     |              | >           |
| \tc39x_sie                                                             | ve_intmem\ta                                                                                                             | skc\func2d                                                                                                           | m > <                                                                                                                                                            | : : : : :                                                                                                                         |                                                                                                                     |              |             |
| S::Trace.Find                                                          | ve_intmem\ta<br>All<br>n  address                                                                                        | cycle dat                                                                                                            | a symb                                                                                                                                                           |                                                                                                                                   |                                                                                                                     |              |             |
| \tc39x_sie                                                             | All<br>n address<br>D:7000002                                                                                            | skc\func2din<br><<br>cycledat<br>20 wr-data                                                                          | a symb<br>00BC614Etc3                                                                                                                                            | 9x_sieve_intmer                                                                                                                   |                                                                                                                     |              |             |
| <pre>\tc39x_sie B::Trace.Find 18200  rui 0000711 0000716 0000725</pre> | All<br>n address<br>D:700000<br>D:700000<br>D:700000                                                                     | skc\func2dig<br><<br>cycle dat<br>cowr-data<br>20 wr-data<br>20 wr-data                                              | a symb<br>00BC614E .tc3<br>B541B341 .tc3<br>1E4C5727 .tc3                                                                                                        | 9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer                                                                             | n\taskc\vlong<br>n\taskc\vlong                                                                                      |              |             |
| \tc39x_sie                                                             | All<br>n <u>Jaddress</u><br>D:700000<br>D:700000<br>D:700000<br>D:700000                                                 | skc\func2dig<br>cycle dat<br>cowr-data<br>cowr-data<br>cowr-data<br>cowr-data                                        | a symb<br>00BC614E .tc3<br>B541B341 .tc3<br>1E4C5727 .tc3<br>3BDC4D00 .tc3                                                                                       | 9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer                                                          | n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong                                                                     |              |             |
| \tc39x_sie                                                             | All<br>D:700000<br>D:700000<br>D:700000<br>D:700000<br>D:700000<br>D:700000                                              | skc\func2dig<br><<br>cycle dat<br>cowr-data<br>20 wr-data<br>20 wr-data                                              | a [symb)<br>008C614E .tc3<br>8541B341 .tc3<br>1E4C5727 .tc3<br>3BDC4D00 .tc3<br>0DF194CC .tc3                                                                    | 9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer                                                                             | n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong                                   |              |             |
| \tc39x_sie                                                             | All<br>D:700000<br>D:700000<br>D:700000<br>D:700000<br>D:700000<br>D:700000<br>D:700000                                  | skc\func2dB<br>cycle  dat<br>0 wr-data<br>0 wr-data<br>0 wr-data<br>0 wr-data<br>0 wr-data<br>0 wr-data<br>0 wr-data | a  symb<br>00BC614Etc3<br>B541B341tc3<br>3BDC4000tc3<br>0DF194CCtc3<br>0DF194CCtc3<br>0DF194CCtc3                                                                | 9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer | Ntaskc/vlong<br>Ntaskc/vlong<br>Ntaskc/vlong<br>Ntaskc/vlong<br>Ntaskc/vlong                                        |              |             |
| ) B::Trace.Find                                                        | All<br>n address<br>D:700000;<br>D:700000;<br>D:700000;<br>D:700000;<br>D:700000;<br>D:700000;<br>D:700000;<br>D:700000; | cycle dat<br>cowr-data<br>cowr-data<br>cowr-data<br>cowr-data<br>cowr-data<br>cowr-data<br>cowr-data                 | a symb<br>008C614E .tc3<br>B541B341 .tc3<br>1E4C5727 .tc3<br>3BDC4000 .tc3<br>0DF194Cc .tc3<br>0DF194Cc .tc3<br>0DF194Cc .tc3<br>0DF194Cs .tc3<br>0DF128AA5 .tc3 | 9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer<br>9x_sieve_intmer                    | n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong<br>n\taskc\vlong |              |             |

A scripting approach could also be used. The following PRACTICE script prints the names of matching items' functions to the message area window.

```
// activate the CTL find program from the file vlong_access.ct
Trace.FindReProgram ~~~~/vlong_access.ct
// search for the first trace record fulfilling the CTL program search
// criteria
Trace.Find
WHILE FOUND()
(
    // print the name of the matching item's function to the area window
    PRINT sYmbol.FUNCTION(TRACK.ADDRESS.PROG())
    // search for the next trace record fulfilling the CTL program search
    // criteria
    Trace.Find
)
```

#### User Story:

The user needs to perform post-mortem analysis of a trace recording. The trace is loaded to a TRACE32 Instruction Set Simulator. The user needs to verify that the execution time of the function mainloop does not exceed a specified time of 35  $\mu$ s.

#### Trace Find Program: check\_address\_duration.ct

```
start level:
    // Detected Entry of the main loop
   IF Program(ENTRY:mainloop)
        GOTO check level
check level:
    // Reset the task_timer
   IF STATE.ENTER()
       RELOAD task timer
    // Enable the task timer as long as check_level is active
    IF TRUE()
        ENABLE task timer
    // Go back to start_level at Return from the function
    // mainloop
   IF Program(RETURN:mainloop)
       GOTO start_level
    // task timer exceeds 35 us
    // => a timout is detected
    IF TIME(task timer>=35.us)
       GOTO timout level
timout level:
    // Search for the next return from mainloop and
    // mark it as FOUND and go back to start_level to
    // continue the test
    IF Program(RETURN:mainloop)
        FOUND
        GOTO start_level
```

A PRACTICE script could be used to set bookmarks for all the trace records breaking the timing constraint.

#### Script:

```
PRIVATE & index
Trace.FindReProgram ~~~~/check address duration.ct
BookMark.RESet
&index=1.
// Find the first trace record matching the CTL find program criteria
Trace.Find
WHILE FOUND()
(
   // Compose a unique bookmark name
   &bookmark="BM "+"&index"
   // Set a bookmark for the FOUND trace record
  Trace.Bookmark "&bookmark" TRACK.RECORD()
   &index=&index+1.
   // Find the next trace record matching the CTL find program criteria
  Trace.Find
)
```

#### **Results:**

In this example, the timing constraint was broken four times. These are identified by the bookmarks "BM\_1", "BM\_2", "BM\_3", and "BM\_4".

| B::Trace.STATistic.AddressDURation mainloop sYmbol.EXIT(mainloop)         Setup         Local Chart         Zoom         Full                                                 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 🔑 Setup 📠 Chart 🏮 Zoom 📮 Zoom                                                                                                                                                 |
|                                                                                                                                                                               |
| samples: 69999. avr: 30.280us min: 30.210us max: 61.680us                                                                                                                     |
| total: 2.126s in: 2.120s out: 6.449ms ratio: 99.696%                                                                                                                          |
| up to count   ratio   1% 2% 5% 10% 20% 50% 100                                                                                                                                |
| < 30.000us 0. 0.000%                                                                                                                                                          |
| 40.000us 69995. 99.994%                                                                                                                                                       |
| 60.000us 0. 0.000%                                                                                                                                                            |
| 70.000us 4. 0.005% +                                                                                                                                                          |
| 80.000us 0. 0.000%                                                                                                                                                            |
| LOAD                                                                                                                                                                          |
|                                                                                                                                                                               |
| B::BookMark.List                                                                                                                                                              |
|                                                                                                                                                                               |
| 💥 Delete All 😰 Store 😤 Load 🧗 Create                                                                                                                                          |
| bookmark         addr/record         symbol/time         source           "BM_1."         15263161.         0.267361080s         Analyzer                                     |
| "BM_2." 49953799. 0.874756170s Analyzer                                                                                                                                       |
| "BM_3." 84644436. 1.482151260s Analyzer                                                                                                                                       |
| BM_4."  119335075. 2.089546350s  Analyzer                                                                                                                                     |
|                                                                                                                                                                               |
|                                                                                                                                                                               |
| 🖬 B:: Trace. Chart. Func / Track                                                                                                                                              |
| 🔑 Setup 🏥 Groups 🔡 Config 📭 Goto 📭 Goto 🙌 Find 🕩 In 🕨 Out 💷 Full                                                                                                              |
| 1.482000000s 1.48250                                                                                                                                                          |
| range                                                                                                                                                                         |
| ieve_intmem\taskc\func2                                                                                                                                                       |
| ieve_intmem\taskc\func131101010101010101010101010101010101010                                                                                                                 |
|                                                                                                                                                                               |
| eve_intmem\taskc\func2ag                                                                                                                                                      |
| eve_intmem\taskc\ <b>func2b</b>                                                                                                                                               |
| eve_intmem\taskc\func26@<br>eve_intmem\taskc\func26@<br>eve_intmem\taskc\func2d@                                                                                              |
| eve_intmem\taskc\func2bs<br>eve_intmem\taskc\func2cs<br>eve_intmem\taskc\func2ds<br>em\taskc\initLinkedLists<br>ieve_intmem\taskc\func2ds                                     |
| eve_intmem\taskc\func2000<br>eve_intmem\taskc\func2000<br>eve_intmem\taskc\func2000<br>em\taskc\initLinkedList000<br>ieve_intmem\taskc\func3000<br>ieve_intmem\taskc\func3000 |
| eve_intmem\taskc\func2bB<br>eve_intmem\taskc\func2cB<br>eve_intmem\taskc\func2dB<br>em\taskc\initLinkedListB<br>ieve_intmem\taskc\func4B                                      |

#### User Story:

Runtime analysis of the user application program flow using **Trace.STATistic.AddressDIStance** shows that a function classifyAbs is called at least once each 1 ms. In some cases (3 times/4095 samples) the time distance between consecutive calls of classifyAbs exceeds 6 ms. A trace find program can be used to locate the trace samples where the timing constraint gets violated.

Trace Find Program: check\_address\_distance.ct

```
// For each trace sample corresponding to the entry of the function
// classifyAbs:
// + Set a flag "monitoring flag"
  + Reload the distance monitoring timer "distance_tmr"
11
IF Program(ENTRY:classifyAbs)
   SET monitoring flag
   RELOAD distance tmr
// As long as the monitoring flag is set, keep incrementing
// the distance monitoring timer
IF FLAG(monitoring_flag)
   ENABLE distance tmr
// In case the monitoring timer exceeds a limit of 1 ms
// + The timout flag is set
   + The monitoring flag is cleared
11
// + The distance timer is reset
IF Time(distance_tmr>1.0ms)
   SET timeout flag
   CLEAR monitoring flag
   RELOAD distance tmr
// The next trace sample representing the entry of the function
// classifyAbs with the timeout flag set is added to the trace find
// results of interest (FOUND)
// The timeout flag is cleared for processing the rest of the trace
// samples
IF Program(ENTRY:classifyAbs)&&FLAG(timeout_flag)
   FOUND
   CLEAR timeout_flag
```

The trace find program could compiled/activated via the command **Trace.FindReProgram**. Trace samples of interest can be listed using the command **Trace.FindAll** e.g. as follows:

```
// Activate the trace find program
Trace.FindReProgram ~~~~/check_address_distance.ct
// Display the trace find results
Trace.FindAll
```

### **Results:**

| TRACE32 PowerView for TriCore - 🗆 🗙                                                                                                        | 1 |
|--------------------------------------------------------------------------------------------------------------------------------------------|---|
|                                                                                                                                            |   |
| N N 44 ↓ ✓ C   > II   122   ? ½   ◎   Ξ Ξ Ξ   ◎   85 68 68   69 ± 20                                                                       |   |
| E B::Trace.STATistic.AddressDIStance classifyAbs                                                                                           |   |
| 🌽 Setup 📠 Chart ♀ Zoom ♀ Zoom ♀ Full                                                                                                       |   |
| samples: 4095. avr: 5.320us min: 0.620us max: 6.265ms<br>total: 32.031ms in: 21.787ms out: 10.245ms                                        | B |
| up to count ratio 1% 2% 5% 10% 20% 50% 100                                                                                                 |   |
| < 0.000us 0. 0.000%<br>1.000ms 4092, 99.926%                                                                                               |   |
| 2.000ms 0. 0.000%<br>3.000ms 0. 0.000%                                                                                                     |   |
| 4.000ms 0. 0.000%<br>5.000ms 0. 0.000%                                                                                                     |   |
|                                                                                                                                            | Δ |
| 7.000ms 3. 0.073% +                                                                                                                        |   |
| > 0. 0.000%   / /   /   /   /   /   /   /   /   /                                                                                          |   |
|                                                                                                                                            |   |
| 🛉 B:: Trace. FindAll                                                                                                                       |   |
| 3 run address cycle data symbol :i.back a<br>+00343619 0 P:701009F0 ptrace .classifyAbs                                                    | C |
| +00583786 0 P:701009F0 ptraceclassifyAbs 7.064ms ≡<br>+00824157 0 P:701009F0 ptraceclassifyAbs 7.067ms                                     |   |
|                                                                                                                                            |   |
|                                                                                                                                            |   |
| #)     B::Trace.FindAll , Address classifyAbs CYcle Program /Track       4096  run  address     cycle       data     [symbo]       ti.back |   |
| +00627522 0 P:701009F0 ptrace .classifyAbs 0.820us                                                                                         |   |
| +00627566 0 P:701009F0 ptraceclassifyAbs 0.820us<br>+00627609 0 P:701009F0 ptraceclassifyAbs 0.820us ≡                                     |   |
| +00627696 0 P:701009F0 ptraceclassifyAbs 0.820us                                                                                           |   |
| +00824157 0 P:701009F0 ptraceclassifyAbs 6.265ms                                                                                           |   |
| +00824236 0 P:701009F0 ptraceclassifyAbs 0.720us<br>+00824276 0 P:701009F0 ptraceclassifyAbs 0.720us                                       |   |
| +00824315 0 P:701009F0 ptraceclassifyAbs 0.720us<br>+00824359 0 P:701009F0 ptraceclassifyAbs 0.800us                                       |   |
| +00824403 0 P:701009F0 ptraceClassifyAbs 0.820us<br>+00824446 0 P:701009F0 ptraceclassifyAbs 0.800us                                       |   |
| +00824490 0 P:701009F0 ptraceclassifyAbs 0.820us Y                                                                                         |   |
|                                                                                                                                            |   |
| B::                                                                                                                                        |   |
|                                                                                                                                            |   |
| components trace Data Var List PERF other previous                                                                                         |   |
| C-T: +00824157 25.845ms   C-Z: +25.845ms 0 stopped by MCDS   HLL UP                                                                        |   |

- A The Trace.STATistic.AddressDIStance window shows that, over 4095 recorded trace samples, the timing constraint is violated 3 times.
- **B** The maximum recorded time distance between consecutive calls of classifyAbs is 6.265 ms.
- **C** The time displayed in ti.back column of **Trace.FindAll** window is not corresponding to the time distance between 2 consecutive calls of classifyAbs. Actually, this represents the time distance between 2 samples of classifyAbs violating the timing constraint.
- **D** The window Trace.FindAll, Address classifyAbs CYcle Program **/Track** is to be used to examine the maximum time distance between 2 consecutive calls of classifyAbs

# BREAKPOINT

### ABCDE breakpoint

| Format:        | BREAKPOINT ( <type>)</type>  |  |
|----------------|------------------------------|--|
| <type>:</type> | Alpha   Beta   Charly   Echo |  |

# BusTrigger

Incoming trigger signal

Format:

BusTrigger (<channel>)

### BMC

Benchmark counter event

| Format: | BMC ( <event>)</event> |  |
|---------|------------------------|--|
| Format: | BMC ( <event>)</event> |  |

This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM) and BenchMark Counters. Refer to the corresponding "Processor Architecture Manuals".

### Example:

IF BMC(dcachemiss) INCrement counter1

### COUNT

Trigger on event counter

Format:

COUNT (<name/count>)

# CLOCKS

Format:

CLOCKS (<name/count>)

### Example:

Enable program trace for 100 clock cycles starting from the execution of the first instruction of the sieve function.

```
start:
    IF Program(ENTRY:sieve)
        GOTO level1
level1:
    // Reset the clock counter at state change to level1
    IF STATE.ENTER()
        RELOAD clock_counter
    // Enable Program trace and clock_counter as long as
    // level1 is active
    IF TRUE()
        TraceEnable Program
        ENABLE clock_counter
    // Stop tracing when the clock_counter reach the limit of 100 cycles
    IF CLOCKS(clock_counter>=100.)
        TraceTrigger
```

### СТМ

Cross trigger

Format:

CTM (<channel>)

This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM) and a CoreSight Trigger Matrix (CTM).

### EXTIN

External input

Format:

EXTIN (<channel>)

This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM).

FALSE

Format: FALS

# FLAG

Format: FLAG (<name/value>)

### Example:

Enable program trace for the address range of the function sieve if the variable mstatic1 has a value of 2:

```
IF Var.Write(mstatic1==2)
SET myflag
```

IF Var.Write(mstatic1!=2)
 CLEAR myflag

```
IF Var.Program(sieve)&&FLAG(myflag)
TraceEnable Program
```

### MACHINE

Machine comparator

| 40

Application Note for Complex Trigger Language

Format: MACHINE (<machine>)

This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM) and hypervisor extensions.

Flag status

FALSE ()

### Program

| Format:                                  | Program ( <item>)</item>                                                                   |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

| ENTRY:  | Address of the function entry point.             |
|---------|--------------------------------------------------|
| RETURN: | Address of the function exit (function epilogue) |
| RANGE:  | Function address range                           |

If nothing is specified in front of a function name, ENTRY is default.

### Example:

IF Program(ENTRY:sieve) TraceON Program

IF Program(RETURN:sieve) TraceOFF Program

# ProgramFail

### Conditional instruction execution

| Format:                                  | ProgramFail ( <item>)</item>                                                               |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

# ProgramPass

| Format:                                  | ProgramPass ( <item>)</item>                                                               |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

### Read

**Read access** 

| Format:                                  | Read ( <item>)</item>                                          |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

### Example:

IF Read(flags) TraceEnable ALL

# **ReadWrite**

| Format:                                  | ReadWrite ( <item>)</item>                                     |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

### Example 1:

```
IF ReadWrite(mstatic1)
TraceData DEFault
```

### Example 2:

```
IF ReadWrite(vint==1000)
SET myFlag
```

IF FLAG(myFlag)&&Program(ENTRY:sieve)
 Break

The SingleShot conditions are only supported if the target processor provides an Embedded Trace Macrocell with a single shot comparator (e.g. ETMv4).

# SingleShot.Program

### Single shot program execution

| Format:                                  | SingleShot.Program ( <item>)</item>                                                        |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

### Example:

```
IF SingleShot.Program(ENTRY:sieve)
TraceEnable Program
```

# SingleShot.ProgramFail

# Single shot conditional execution

| Format:                                  | SingleShot.ProgramFail ( <item>)</item>                                                    |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

| Format:                                  | SingleShot.ProgramPass ( <item>)</item>                                                    |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

# SingleShot.Read

Single shot read access

| Format:                                  | SingleShot.Read ( <item>)</item>                               |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

### Example:

IF SingleShot.Read(mstatic1) TraceData Read Address Data

| Format:                                  | SingleShot.ReadWrite ( <item>)</item>                          |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

### Example:

```
IF SingleShot.ReadWrite(mstatic1)
TraceData DEFault
```

# SingleShot.Write

# Single shot write access

| Format:                                  | SingleShot.Write ( <item>)</item>                              |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

### Example:

IF SingleShot.Write(flags) TraceEnable ALL The NoSingleShot conditions are only supported if the target processor provides an Embedded Trace Macrocell with a single shot comparator (e.g. ETMv4).

| NoSingleShot.Program | Non single shot program execution |
|----------------------|-----------------------------------|
|----------------------|-----------------------------------|

| Format:                                  | NoSingleShot.Program ( <item>)</item>                                                      |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

### Example:

```
IF NoSingleShot.Program(ENTRY:sieve)
TraceEnable Program
```

# NoSingleShot.ProgramFail Non single shot conditional execution

| Format:                                  | NoSingleShot.ProgramFail ( <item>)</item>                                                  |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

| Format:                                  | NoSingleShot.ProgramPass ( <item>)</item>                                                  |
|------------------------------------------|--------------------------------------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                              |

# NoSingleShot.Read

# Non single shot read access

| Format:                                  | NoSingleShot.Read ( <item>)</item>                             |
|------------------------------------------|----------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

# NoSingleShot.ReadWrite

# Non single shot read or write access

| Format:                                  | NoSingleShot.ReadWrite ( <item>)</item>                        |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

| Format:                                  | NoSingleShot.Write ( <item>)</item>                            |
|------------------------------------------|----------------------------------------------------------------|
| <item>:</item>                           | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

# STATE.LEAVE

Format: STATE.LEAVE ()

### **Example:**

```
start:
IF Program(ENTRY:sieve)
GOTO level1
```

IF STATE.LEAVE() RELOAD blink\_counter

level1:

```
IF Program(RETURN:sieve)
GOTO start
```

```
IF Program(ENTRY:Blink)
INCrement blink_counter
```

```
IF COUNT(blink_counter>2)
Break
```

## STATE.ENTER

### Enter the state transition (edge sensitive)

Format:

STATE.ENTER ()

### **Example:**

```
start:
    IF Program(ENTRY:sieve)
        GOTO level1
level1:
    IF STATE.ENTER()
        RELOAD blink_counter
    IF Program(RETURN:sieve)
        GOTO start
    IF Program(ENTRY:Blink)
        INCrement blink_counter
```

```
IF COUNT(blink_counter>2)
Break
```

# STATE.TRACEON

# Format: STATE.TRACEON () This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM) versions older than ETMv4. TASK

Format: TASK (<task>)

This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM).

### TIME

Time counter comparator

Format:

TIME (<name/time>)

### Example:

```
start:
    IF Program(ENTRY:sieve)
        GOTO level1
level1:
    IF ENTRY()
        RELOAD sievetimer
    TraceON Program
    IF TRUE()
        ENABLE sievetimer
    IF Program(RETURN:sieve)
        TraceOFF Program
        GOTO start
    IF TIME(sievetimer>200.us)
        Break
```

### TRUE

Format: TRUE ()

### Example:

```
start:
    IF Program(ENTRY:sieve)
        GOTO level1
level1:
    IF TRUE()
        TraceEnable Program
```

IF Program(RETURN:sieve) GOTO start Var prefix allows to specify the HLL expression in the syntax of the used programming language (e.g. C, C++).

Then condition will consider the full function/variable range.

### Var.Program

Flat function execution

| Format:                                  | Var.Program ( <item>)</item>                                                             |
|------------------------------------------|------------------------------------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] [ENTRY:   RETURN:   RANGE:] <var data=""></var></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                                            |

### Example:

 $\ensuremath{{\prime}}\xspace$  // Trace all write access when executing instructions in the sieve

- // function address range
- IF Var.Program(sieve)
  - TraceData Write Address Data

# Var.Read

# Variable read access

| Format:                                  | Var.Read ( <item>)</item>                                    |
|------------------------------------------|--------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <var data=""></var></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                |

# Var.ReadWrite

| Format:                                  | Var.ReadWrite ( <item>)</item>                               |
|------------------------------------------|--------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <var data=""></var></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                |

### Var.status

tbd.

| Format:                                  | Var.status ( <item>)</item>                          |
|------------------------------------------|------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <var></var></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                        |

# Var.Write

Variable write access

| Format:                                  | Var.Write ( <item>)</item>                                   |
|------------------------------------------|--------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <var data=""></var></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                |

### Example:

IF Var.Write(vint==1000) SET myflag

### Write

| Format:                                  | Write ( <item>)</item>                                         |
|------------------------------------------|----------------------------------------------------------------|
| <i><item></item></i> :                   | [ <logical_operator>] <addr data=""></addr></logical_operator> |
| <logical_<br>operator&gt;:</logical_<br> | ~   ==   !=   <   <=   >=   >                                  |

### Example:

IF Write(0x70001000!=0x55) TraceEnable ALL

# ZONE

Zone comparator

Format: ZONE (<zone>)

This condition is only supported if target processor provides an Embedded Trace Macrocell (ETM).

tbd.**if** ((EMU\_ArmHypervisor || EMU\_ArmSecure || EMU\_EtmV4)) && ! EMU\_EtmWithoutProgramAddressComparators).

### Stop the program execution

Format: Break

### **Example:**

**Break** 

### **BusCLOCKS**

Format:

BusCLOCKS <counter>

### **BusCount**

Format:

BusCount <counter>

### BusTIME

Format:

BusTIME <counter>

tbd.

tbd.

tbd.

### BusTrigger

Format: BusTrigger [DEFault | 0 | 1]

This action is only supported if the target processor provides an Embedded Trace Macrocell (ETM) and a CoreSight Trigger Matrix (CTM).

| DEFault | tbd. |
|---------|------|
| 0       | tbd. |
| 1       | tbd. |

### **CLEAR**

Clear flag

Format: CLEAR <flag>

### Example:

IF Program(ENTRY:sieve) SET flag\_sieve

IF Program(RETURN:sieve) CLEAR flag\_sieve

IF Var.Write(mstatic1)&&!FLAG(flag\_sieve) TRACEENABLE Program Write Address Data

### СТМ

Cross trigger

Format: CTM [0 | 1 | 2 | 3]

This condition is only supported if the target processor provides an Embedded Trace Macrocell (ETM) and a CoreSight Trigger Matrix (CTM).

| 0 | tbd. |
|---|------|
| 1 | tbd. |
| 2 | tbd. |
| 3 | tbd. |

### ENABLE

Enable counter

| Format: | ENABLE <counter>   <timer></timer></counter> |  |
|---------|----------------------------------------------|--|
|---------|----------------------------------------------|--|

Enable counting while the condition is verified.

### Example:

```
IF Program(ENTRY:sieve)
SET flag_sieve
```

- IF Program(RETURN:sieve) CLEAR flag\_sieve
- IF FLAG(flag\_sieve) ENABLE timer\_sieve TRACEENABLE Program

```
IF TIME(timer_sieve>10.us)
TraceTrigger
```

### **EVENT**

Trace event

Format:

EVENT [0 | 1 | 2 | 3]

# EXTOUT

| Format: | EXTOUT [0   1   2   3] |
|---------|------------------------|
|         |                        |
| 0       | tbd.                   |
| 1       | tbd.                   |
| 2       | tbd.                   |
| 3       | tbd.                   |
|         |                        |

### FOUND

### Add the trace sample to the search items result

| Format:  | FOUND |  |
|----------|-------|--|
| Example: |       |  |

IF Program(ENTRY:sieve) FOUND

### GOTO

Change active state

Format: GOTO <state>

### Example:

start: IF Program(ENTRY:sieve) GOTO level1 level1: IF Program(RETURN:sieve) GOTO start IF Var.Write(mstatic1) TraceData Write Address Data

### **INCrement**

Increment counter

 

 Format
 INCrement <counter>

 Example:

 IF Program(ENTRY:sieve) INCrement sieve\_cnt TraceEnable Program

IF COUNT(sieve\_cnt==10.) Break

### RELOAD

Reload counter

| IF Program(ENTRY:sieve)<br>GOTO level1             |
|----------------------------------------------------|
|                                                    |
| IF Program(RETURN:sieve)<br>GOTO start             |
| IF Program(ENTRY:Blink)<br>INCrement blink_counter |
| IF STATE.ENTER()<br>RELOAD blink_counter           |
| IF COUNT(blink_counter>2)<br>Break                 |
|                                                    |

Format SET <flag>

### Example:

IF Var.Write(mstatic1) Set myflag

IF Program(ENTRY:sieve)&&FLAG(myflag)
 Break

# Spot

# Shortly stop the program execution

Format Spot

IF Program(ENTRY:sieve) Spot

### TraceData

| Format | TraceData [DEFault   Read   Write   ReadWrite   Address   Data] |
|--------|-----------------------------------------------------------------|
|        |                                                                 |

| DEFault   | Is equivalent to ReadWrite Address Data. |
|-----------|------------------------------------------|
| Read      | Sample read cycles.                      |
| Write     | Sample write cycles.                     |
| ReadWrite | Sample read and write cycles.            |
| Address   | Sample cycle address.                    |
| Data      | Sample cycle data.                       |

| NOTE: | TraceData [Read   Write   ReadWrite] without specifying Address or Data will |
|-------|------------------------------------------------------------------------------|
|       | sample cycle address and data.                                               |

### Example:

// Trace all the write cycles that are performed by the instructions
// in the address range of the function sieve
IF Var.Program(sieve)
TraceData Write Address Data

By using the action TraceData, the status of unconditional program trace is not changed. E.g. if unconditional program trace is enabled, the resulting trace recording will contain unconditional program trace additionally to the selective data trace for the specified events.

### TraceEnable

| Format                   | TraceEnable <parameter></parameter>                                   |
|--------------------------|-----------------------------------------------------------------------|
| <parameter>:</parameter> | [DEFault   ALL   Program   Read   Write   ReadWrite   Address   Data] |

| DEFault   | Sample the event depending on the condition. e.g. if the condition is a program condition the program cycles are sampled. |
|-----------|---------------------------------------------------------------------------------------------------------------------------|
| ALL       | Sample program, read, and write cycles. For the read and write cycles, the sample address and data are included.          |
| Program   | Sample program cycles.                                                                                                    |
| Read      | Sample read cycles.                                                                                                       |
| Write     | Sample write cycles.                                                                                                      |
| ReadWrite | Sample read and write cycles.                                                                                             |
| Address   | Sample cycle address.                                                                                                     |
| Data      | Sample cycle data.                                                                                                        |

| NOTE: | TraceEnable [Read   Write   ReadWrite] without specifying Address or Data |
|-------|---------------------------------------------------------------------------|
|       | will sample cycle address and data.                                       |

### Example 1:

// Trace program and all the write cycles that are performed by the // instructions in the address range of the function sieve IF Var.Program(sieve) TraceEnable Program Write Address Data

### Example 2:

// Trace all the write cycles to mstatic1

```
IF Var.Write(mstatic1)
TraceEnable DEFault
```

# TraceOFF

| Format                   | TraceOFF <parameter></parameter>                                      |
|--------------------------|-----------------------------------------------------------------------|
| <parameter>:</parameter> | [DEFault   ALL   Program   Read   Write   ReadWrite   Address   Data] |

| DEFault   | tbd.                                                 |
|-----------|------------------------------------------------------|
| ALL       | Switch off sampling program, read, and write cycles. |
| Program   | Switch off sampling program cycles.                  |
| Read      | Switch off sampling read cycles.                     |
| Write     | Switch off sampling write cycles.                    |
| ReadWrite | Switch off sampling read and write cycles.           |
| Address   | Switch off sampling cycle address.                   |
| Data      | Switch off sampling cycle data.                      |

### TraceON

| Format                   | TraceON <parameter></parameter>                                       |
|--------------------------|-----------------------------------------------------------------------|
| <parameter>:</parameter> | [DEFault   ALL   Program   Read   Write   ReadWrite   Address   Data] |
|                          |                                                                       |
| DEFault                  | tbd.                                                                  |
| ALL                      | Switch on sampling program, read, and write cycles.                   |
| Program                  | Switch on sampling program cycles.                                    |

| <b>Read</b> Switch on sampling read cycles. |
|---------------------------------------------|
|---------------------------------------------|

- Write Switch on sampling write cycles.
- ReadWrite Switch on sampling read and write cycles.
- Address Switch on sampling cycle address.
- Data Switch on sampling cycle data.

### TraceTIME

tbd.

Format TraceTIME

# TraceTrigger

# Stop sampling to the trace buffer on specified event

Format

TraceTrigger <cycles> | <percent>

A trigger delay could be specified in number of cycles or percentage of the trace buffer size.