

# Simulator for Arm and XSCALE

MANUAL

[TRACE32 Online Help](#)

[TRACE32 Directory](#)

[TRACE32 Index](#)

[TRACE32 Documents](#) .....



[TRACE32 Instruction Set Simulators](#) .....



[Simulator for Arm and XSCALE](#) .....

1

[Introduction](#) .....

5

    TRACE32 Simulator License

5

    Brief Overview of Documents for New Users

5

    Demo and Start-up Scripts

6

[Quick Start of the Simulator](#) .....

7

[Peripheral Simulation](#) .....

9

[Troubleshooting](#) .....

9

[FAQ](#) .....

9

    Memory Classes

10

    Virtual Terminal

11

    Semihosting

11

    Coprocessors

12

[ARM specific SYStem Commands](#) .....

13

    SYStem.CPU

        Select the used CPU

13

    SYStem.CONFIG

        Configure debugger according to target topology

13

    SYStem.CONFIG.SMMU

        Internal use

14

    SYStem.Mode

        Establish the communication with the simulator

15

    SYStem.Option.Alignment

        Enable alignment exceptions

16

    SYStem.Option.BigEndian

        Define byte order (endianness)

16

    SYStem.Option.DisMode

        Define disassembler mode

16

    SYStem.Option.DUALPORT

        Implicitly use run-time memory access

17

    SYStem.Option.IMASKASM

        Disable interrupts while single stepping

17

    SYStem.Option.IMASKHLL

        Disable interrupts while HLL single stepping

18

    SYStem.Option.MACHINESPACES

        Address extension for guest OSes

19

    SYStem.Option.MMUSPACES

        Separate address spaces by space IDs

20

    SYStem.Option.OVERLAY

        Enable overlay support

21

    SYStem.Option.REALTIME

        Stall the simulator if faster than real processor

21

    SYStem.Option.ZoneSPACES

        Enable symbol management for Arm zones

22

        Overview of Debugging with Zones

23

        Operation System Support - Defining a Zone-specific OS Awareness

26

|                                                      |                                              |           |
|------------------------------------------------------|----------------------------------------------|-----------|
| SYStem.RESetOut                                      | CPU reset command                            | 28        |
| SYStem.state                                         | Display SYStem.state window                  | 28        |
| <b>ARM Specific TrOnchip Commands</b>                |                                              | <b>29</b> |
| TrOnchip.RESet                                       | Reset on-chip trigger settings               | 29        |
| TrOnchip.Set                                         | Set bits in the vector catch register        | 29        |
| TrOnchip.StepVector                                  | Step into exception handler                  | 30        |
| TrOnchip.StepVectorResume                            | Catch exceptions and resume single step      | 30        |
| TrOnchip.state                                       | Display on-chip trigger window               | 31        |
| <b>CPU specific MMU Commands</b>                     |                                              | <b>32</b> |
| MMU.DUMP                                             | Page wise display of MMU translation table   | 32        |
| MMU.List                                             | Compact display of MMU translation table     | 36        |
| MMU.SCAN                                             | Load MMU table from CPU                      | 38        |
| <b>CPU specific SMMU Commands</b>                    |                                              | <b>40</b> |
| SMMU                                                 | Hardware system MMU (SMMU)                   | 40        |
| SMMU.ADD                                             | Define a new hardware system MMU             | 50        |
| SMMU.Clear                                           | Delete an SMMU                               | 52        |
| SMMU.CtxtDescTable                                   | List a context descriptor table              | 52        |
| SMMU.DumpQueue.<queue>                               | Dump entries of a queue                      | 53        |
| SMMU.DumpQueue.CMD                                   | Dump cmd queue entries                       | 55        |
| SMMU.DumpQueue.Event                                 | Dump event queue entries                     | 56        |
| SMMU.Register                                        | Peripheral registers of an SMMU              | 57        |
| SMMU.Register.ContextBank                            | Display registers of context bank            | 58        |
| SMMU.Register.Global                                 | Display global registers of SMMU             | 59        |
| SMMU.Register.MMUregs                                | Display MMU specific registers               | 59        |
| SMMU.Register.S1Context                              | Display stage 1 context descriptor registers | 60        |
| SMMU.Register.StreamTblEntry                         | Display stream table entry registers         | 60        |
| SMMU.Register.StreamMapRegGrp                        | Display registers of an SMRG                 | 61        |
| SMMU.RESet                                           | Delete all SMMU definitions                  | 62        |
| SMMU.SSDtable                                        | Display security state determination table   | 63        |
| SMMU.StreamMapRegGrp                                 | Access to stream map table entries           | 64        |
| SMMU.StreamMapRegGrp.ContextReg                      | Display context bank registers               | 65        |
| SMMU.StreamMapRegGrp.Dump                            | Page-wise display of SMMU page table         | 67        |
| SMMU.StreamMapRegGrp.list                            | List page table entries                      | 69        |
| SMMU.StreamTable                                     | Display a stream table                       | 70        |
| Display of Global Faults or Global Errors in an SMMU |                                              | 81        |
| Finding streams which are in a fault / error state   |                                              | 82        |
| SMMU.StreamTblEntry                                  | Access to a stream table entry               | 82        |
| SMMU.StreamTblEntry.Dump                             | Page-wise display of SMMU page table         | 84        |
| SMMU.StreamTblEntry.list                             | List page table entries                      | 85        |
| SMMU.StreamTblEntry.Register                         | Display STE or CD registers                  | 86        |

## Simulator for Arm and XSCALE

Version 06-Jun-2024



This document describes the processor-specific settings and features for the TRACE32 Instruction Set Simulator for ARM.

All general commands are described in the “[PowerView Command Reference](#)” (ide\_ref.pdf) and “[General Commands Reference](#)”.

## TRACE32 Simulator License

---

[build 68859 - DVD 02/2016]

The extensive use of the TRACE32 Instruction Set Simulator requires a *TRACE32 Simulator License*.

For more information, see [www.lauterbach.com/sim\\_license.html](http://www.lauterbach.com/sim_license.html).

## Brief Overview of Documents for New Users

---

### Architecture-independent information:

- “[Training Basic Debugging](#)” (training\_debugger.pdf): Get familiar with the basic features of a TRACE32 debugger.
- “[T32Start](#)” (app\_t32start.pdf): T32Start assists you in starting TRACE32 PowerView instances for different configurations of the debugger. T32Start is only available for Windows.
- “[General Commands](#)” (general\_ref\_<x>.pdf): Alphabetic list of debug commands.

### Architecture-specific information:

- “[Processor Architecture Manuals](#)”: These manuals describe commands that are specific for the processor architecture supported by your debug cable. To access the manual for your processor architecture, proceed as follows:
  - Choose **Help** menu > **Processor Architecture Manual**.
- “[OS Awareness Manuals](#)” (rtos\_<os>.pdf): TRACE32 PowerView can be extended for operating system-aware debugging. The appropriate OS Awareness manual informs you how to enable the OS-aware debugging.



## Demo and Start-up Scripts

To search for PRACTICE scripts, do one of the following in TRACE32 PowerView:

- Type at the command line: [WELCOME.SCRIPTS](#)
- or choose **File** menu > **Search for Script**.

You can now search the demo folder and its subdirectories for PRACTICE start-up scripts (\*.cmm) and other demo software.



You can also manually navigate in the `~/demo/arm/` subfolder of the system directory of TRACE32.

# Quick Start of the Simulator

## To start the simulator, proceed as follows:

1. Select the device prompt for the Simulator and reset the system.

```
B:::  
RESet
```

The device prompt B:: is normally already selected in the [TRACE32 command line](#). If this is not the case, enter B:: to set the correct device prompt. The [RESet](#) command is only necessary if you do not start directly after booting TRACE32.

2. Specify the CPU specific settings.



```
SYStem.CPU <cpu_name>
```

The default values of all other options are set in such a way that it should be possible to work without modification. Please consider that this is probably not the best configuration for your target.

3. Enter debug mode.

```
SYStem.Up
```

This command resets the CPU and enters debug mode. After this command is executed it is possible to access memory and registers.

4. Load the program.

```
Data.LOAD.<file_format> <file> ; load program and symbols
```

See the **Data.LOAD** command reference for a list of supported file formats. If uncertain about the required format, try **Data.LOAD.auto**.

A detailed description of the **Data.LOAD** command and all available options is given in the reference guide.

5. Start-up example

A typical start sequence is shown below. This sequence can be written to a PRACTICE script file (\*.cmm, ASCII format) and executed with the command **DO <file>**.

```
B::: ; Select the ICD device prompt

WinCLEAR ; Clear all windows

SYStem.CPU <cpu_name> ; Select CPU type

SYStem.Up ; Reset the target and enter
           ; debug mode

Data.LOAD.<file_format> <file> ; Load the application

Register.Set pc main ; Set the PC to function main

PER.view ; Show clearly arranged
          ; peripherals in window *) */

List.Mix ; Open source code window *) */

Register.view /SpotLight ; Open register window *) */

Frame.view /Locals /Caller ; Open the stack frame with
                            ; local variables *) */

Var.Watch %Spotlight flags ast ; Open watch window for
                                ; variables *) */
```

\*) These commands open windows on the screen. The window position can be specified with the **WinPOS** command.

# Peripheral Simulation

---

For more information, see “[API for TRACE32 Instruction Set Simulator](#)” (simulator\_api.pdf).

## Troubleshooting

---

No information available.

## FAQ

---

Please refer to <https://support.lauterbach.com/kb>.

# Memory Classes

---

The following ARM specific memory classes are available.

| Memory Class | Description                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------|
| P            | Program Memory                                                                                         |
| D            | Data Memory                                                                                            |
| SP           | Supervisor Program Memory (privileged access)                                                          |
| UP           | User Program Memory (non-privileged access)                                                            |
| SR           | Supervisor ARM Memory (privileged access)                                                              |
| ST           | Supervisor Thumb Memory (privileged access)                                                            |
| UR           | User ARM Memory (non-privileged access)                                                                |
| UT           | User Thumb Memory (non-privileged access)                                                              |
| U            | User Memory (non-privileged access)                                                                    |
| S            | Supervisor Memory (privileged access)                                                                  |
| R            | ARM Memory                                                                                             |
| T            | Thumb Memory                                                                                           |
| ICE          | ICE Breaker Register (debug register; ARM7, ARM9)                                                      |
| C14          | Coprocessor 14 Register (debug register; ARM10, ARM11)                                                 |
| C15          | Coprocessor 15 Register (if implemented)                                                               |
| ETM          | Embedded Trace Macrocell Registers (if implemented)                                                    |
| VM           | Virtual Memory (memory on the debug system)                                                            |
| USR          | Access to Special Memory via User-Defined Access Routines                                              |
| E            | Run-time memory access<br>(see <a href="#">SYStem.CpuAccess</a> and <a href="#">SYStem.MemAccess</a> ) |

To access a memory class, write the class in front of the address.

## Example:

```
Data.dump ICE:0--3
```

Normally there is no need to use the following memory classes: P, D, SP, UP, SR, ST, UR, UT, U, S, R, or T. The memory class is set automatically depending on the setting of [SYStem.Option.DisMode](#).

The command **TERM** opens a terminal window which allows to communicate with the ARM core over the ICEbreaker Debug Communications Channel (DCC). All data received from the comms channel are displayed and all data inputs to this window are sent to the comms channel. Communication occurs byte wide or up to four bytes per transfer. The four bytes ASCII mode (**DCC4A**) does not allow to transfer the byte 00. Each non-zero byte of the 32bit word is a character in this mode. The four byte binary mode (**DCC4B**) can be used to transfer non-ASCII 32bit data (e.g. to or from a file). The three bytes mode (**DCC3**) allows binary transfers of up to 3 bytes per DCC transfer. The upper byte defines how many bytes are transferred (0=one byte, 1= two bytes, 2=three bytes). This is the preferred mode of operation, as it combines arbitrary length messages with high bandwidth. The **TERM.METHOD** command selects which mode is used (**DCC**, **DCC3**, **DCC4A** or **DCC4B**).

The communication mechanism is described e.g. in the ARM7TDMI data sheet in chapter 9.11. Only three move to/from coprocessor 14 instructions are necessary.

The TRACE32 `~/demo/etc/terminal/serial` directory contains the file `TERM.CMM` which demonstrates how the communication works.

## Semihosting

---

The command **TERM.GATE** opens a terminal window which allows to support ARM compatible semihosting. The communication can either be done by stopping the target at the SWI or by using the DCC interface channel - which provides non-stop operation of the target.

The SWI emulation mode requires to stop the target at the SWI exception vector. On ARM7 this can be done only with an on-chip or software breakpoint at location 8. On other ARM cores it can be done by enabling the ICEbreaker breakpoint at the SWI vector (**TrOnchip.Set SWI ON**). The terminal must be set to the **ARMSWI** method (**TERM.METHOD ARMSWI**). The handling of the SWI is only active when the **TERM.GATE** window is existing. An example can be found in `~/demo/arm/etc/semihosting_arm_emulation/swisoft_<x>.cmm`.

The DCC communication mode requires an target agent for the SWI. The communication is done in the **DCC3** method of the **TERM** command. An example and the source of the SWI agent can be found in `~/demo/arm/etc/semihosting_arm_dcc/swidcc_arm7_arm9.cmm`.

It is not possible to access coprocessors which are not included in an ARM macrocell from debug mode. This means all coprocessors which are added to ARM cores by customers cannot be accessed from debug mode.

## The following coprocessors can be accessed if available in the processor:

Coprocessor 14. Please refer to the chapter [Virtual Terminal](#) and to your ARM documentation for details.

Coprocessor 15, which allows the control of basic CPU functions. This coprocessor can be accessed with the access class C15. For the detailed definition of the CP15 registers please refer to the ARM data sheet. The CP15 registers can also be controlled in the [PER](#) window.

The TRACE32 address is composed of the CRn, CRm, op1, op2 fields of the corresponding coprocessor register command

<MCR | MRC> p15, <op1>, Rd, CRn, CRm, <op2>

BIT0-3:CRn, BIT4-7:CRm, BIT8-10:<op2>, BIT12-14:<op1>

is the corresponding TRACE32 address (one nibble for each field)

## SYStem.CPU

Select the used CPU

---

Format: **SYStem.CPU <cpu>**

<cpu>: **ARM7TDMI | ARM740TD | ... (JTAG Debugger ARM7)**

**ARM9TDMI | ARM920T | ARM940T | ... (JTAG Debugger ARM9)**

**ARM1020E | ARM1022E | ARM1026EJ | ... (JTAG Debugger ARM10)**

**ARM1136J | ARM1136JF | ... (JTAG Debugger ARM11)**

**JANUS2 (JTAG Debugger Janus)**

Selects the processor type. If your ASIC is not listed, select the type of the integrated ARM core.

## SYStem.CONFIG

Configure debugger according to target topology

---

The **SYStem.CONFIG** commands have no effect on the simulator. They are only provided to allow the user to run PRACTICE scripts written for the debugger within the simulator without modifications.

Format: **SYStem.CONFIG.SMMU<x> <sub\_cmd>**

<x>: 1 ... 20

<sub\_cmd>: **Base <base\_address>**  
**Type MMU400 | MMU401 | MMU500**  
**Name "<name>"**  
**RESet**

For some CPUs with SMMUs, TRACE32 configures the SMMUs parameters *automatically* after you have selected a CPU with the **SYStem.CPU** command.

**NOTE:** For a *manual* SMMU configuration, use the **SMMU.ADD** command.

You can access the automatically configured SMMUs through the **CPU** menu > **SMMU** submenu in TRACE32. The individual SMMU configurations can be viewed in the **SYStem.CONFIG.state /COpnent** window.



|                        |                                                                                                     |
|------------------------|-----------------------------------------------------------------------------------------------------|
| <code>&lt;x&gt;</code> | Serial number of the SMMU.                                                                          |
| <b>Base</b>            | Logical or physical base address of the memory-mapped SMMU register space.                          |
| <b>Type</b>            | Defines the type of the Arm system MMU IP block: <b>MMU400</b> , <b>MMU401</b> , or <b>MMU500</b> . |
| <b>Name</b>            | Assigns a user-defined name to an SMMU.                                                             |
| <b>RESet</b>           | Resets the configuration of an SMMU specified with <code>&lt;x&gt;</code> .                         |

## SYStem.Mode

## Establish the communication with the simulator

|                             |                                                                                                |
|-----------------------------|------------------------------------------------------------------------------------------------|
| Format:                     | <b>SYStem.Mode</b> <code>&lt;mode&gt;</code>                                                   |
|                             | <b>SYStem.Down</b> (alias for SYStem.Mode Down)<br><b>SYStem.Up</b> (alias for SYStem.Mode Up) |
| <code>&lt;mode&gt;</code> : | <b>Down</b><br><b>NoDebug</b><br><b>Go</b><br><b>Up</b>                                        |

Default: Down.

Selects the target operating mode.

|                |                                                                                                                                                                |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Down</b>    | The CPU is in reset. Debug mode is not active. Default state and state after fatal errors.                                                                     |
| <b>NoDebug</b> | The CPU is running. Debug mode is not active. Debug port is tristate. In this mode the target should behave as if the debugger is not connected.               |
| <b>Go</b>      | The CPU is running. Debug mode is active. After this command the CPU can be stopped with the break command or if any break condition occurs.                   |
| <b>Up</b>      | The CPU is not in reset but halted. Debug mode is active. In this mode the CPU can be started and stopped. This is the most typical way to activate debugging. |

If the mode **Go** is selected, this mode will be entered, but the control button in the **SYStem.state** window jumps to the mode **Up**.

## **SYStem.Option.Alignment**

Enable alignment exceptions

|         |                                |
|---------|--------------------------------|
| Format: | <b>SYStem.Option.Alignment</b> |
|---------|--------------------------------|

Causes the processor to go into a DAbort exception for any unaligned access. Otherwise the data will be handled according to the ARM core specification.

## **SYStem.Option.BigEndian**

Define byte order (endianness)

|         |                                           |
|---------|-------------------------------------------|
| Format: | <b>SYStem.Option.BigEndian [ON   OFF]</b> |
|---------|-------------------------------------------|

Default: OFF.

Selects the byte ordering mechanism. For correct operation the following settings must correspond:

- This option
- The compiler setting (-li or -bi compiler option)

## **SYStem.Option.DisMode**

Define disassembler mode

|         |                                             |
|---------|---------------------------------------------|
| Format: | <b>SYStem.Option.DisMode &lt;option&gt;</b> |
|---------|---------------------------------------------|

|           |                                                            |
|-----------|------------------------------------------------------------|
| <option>: | <b>AUTO</b><br><b>ACCESS</b><br><b>ARM</b><br><b>THUMB</b> |
|-----------|------------------------------------------------------------|

Default: AUTO.

Specifies the selected disassembler.

|               |                                                                                                                                                                                            |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>AUTO</b>   | The information provided by the compiler output file is used for the disassembler selection. If no information is available it has the same behavior as the option ACCESS.                 |
| <b>ACCESS</b> | The selected disassembler depends on the T bit in the CPSR or on the selected access class. (e.g. <code>Data.List SR:0</code> for ARM mode or <code>Data.List ST:0</code> for THUMB mode). |
| <b>ARM</b>    | Only the ARM disassembler is used (highest priority).                                                                                                                                      |
| <b>THUMB</b>  | Only the THUMB disassembler is used (highest priority).                                                                                                                                    |

## SYStem.Option.DUALPORT

Implicitly use run-time memory access

Format: **SYStem.Option.DUALPORT [ON | OFF]**

All TRACE32 windows that display memory are updated while the processor is executing code (e.g. [Data.dump](#), [Data.List](#), [PER.view](#), [Var.View](#)). This setting has no effect if [SYStem.MemAccess](#) is disabled.

If only selected memory windows should update their content during runtime, leave **SYStem.Option.DUALPORT OFF** and use the access class prefix **E** or the format option **%E** for the specific windows.

## SYStem.Option.IMASKASM

Disable interrupts while single stepping

[\[SYStem.state window > IMASKASM\]](#)

Format: **SYStem.Option.IMASKASM [ON | OFF]**

Default: OFF.

If enabled, the interrupt mask bits of the CPU will be set during assembler single-step operations. The interrupt routine is not executed during single-step operations. After a single step, the interrupt mask bits are restored to the value before the step.

Format: **SYStem.Option.IMASKHLL [ON | OFF]**

Default: OFF.

If enabled, the interrupt mask bits of the CPU will be set during HLL single-step operations. The interrupt routine is not executed during single-step operations. After a single step, the interrupt mask bits are restored to the value before the step.

|         |                                                           |
|---------|-----------------------------------------------------------|
| Format: | <b>SYStem.Option.MACHINESPACES [ON   OFF   HOSTREMAP]</b> |
|---------|-----------------------------------------------------------|

Default: OFF

Enables the TRACE32 support for debugging virtualized systems. Virtualized systems are systems running under the control of a hypervisor.

After loading a Hypervisor Awareness, TRACE32 is able to access the context of each guest machine. Both currently active and currently inactive guest machines can be debugged.

|                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ON</b>                             | Addresses are extended with an identifier called <a href="#">machine ID</a> . The machine ID clearly specifies to which host or guest machine the address belongs.<br>The host machine always uses machine ID 0. Guests have a machine ID larger than 0. TRACE32 currently supports machine IDs up to 30.<br>The debugger address translation ( <a href="#">MMU</a> and <a href="#">TRANSlation</a> command groups) can be individually configured for each virtual machine.<br>Individual symbol sets can be loaded for each virtual machine.                                                    |
| <b>OFF</b>                            | The machine ID support is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>HOSTREMAP</b><br>Hypervisor FIASCO | <b>HOSTREMAP</b> is only relevant for a hypervisor where: <ul style="list-style-type: none"> <li>The hypervisor itself uses tasks and</li> <li>The tasks behave like virtual machines.</li> </ul> If <b>SYStem.Option.MACHINESPACES</b> is set to <b>HOSTREMAP</b> , then such hypervisor tasks are assigned <a href="#">space IDs</a> instead of machine IDs, whereas the real guest machines are assigned machine IDs. <p><b>NOTE:</b> This option requires a suitable Hypervisor Awareness which supports <b>HOSTREMAP</b>. You must also set <b>SYStem.Option.MMUSPACES</b> to <b>ON</b>.</p> |

## Machine IDs (0 and > 0)

- On Arm CPUs with hardware virtualization, guest machines are running in the non-secure zone (N:) and use machine IDs > 0.
- The hypervisor functionality is usually running in the hypervisor zone (H:) and uses machine ID 0.
- Software running in the secure monitor mode (Z: for Arm32) or EL3 mode (M: for Arm64) is also using machine ID 0.

Format:

**SYStem.Option.MMUSPACES [ON | OFF]**  
**SYStem.Option.MMUspace [ON | OFF]** (deprecated)  
**SYStem.Option.MMU [ON | OFF]** (deprecated)

Default: OFF.

Enables the use of [space IDs](#) for logical addresses to support **multiple** address spaces.

For an explanation of the TRACE32 concept of [address spaces](#) (zone spaces, MMU spaces, and machine spaces), see “[TRACE32 Concepts](#)” (trace32\_concepts.pdf).

**NOTE:** **SYStem.Option.MMUSPACES** should not be set to **ON** if only one translation table is used on the target.

If a debug session requires space IDs, you must observe the following sequence of steps:

1. Activate **SYStem.Option.MMUSPACES**.
2. Load the symbols with [Data.LOAD](#).

Otherwise, the internal symbol database of TRACE32 may become inconsistent.

### Examples:

```
; Dump logical address 0xC00208A belonging to memory space with
; space ID 0x012A:
Data.dump D:0x012A:0xC00208A
```

```
; Dump logical address 0xC00208A belonging to memory space with
; space ID 0x0203:
Data.dump D:0x0203:0xC00208A
```

Format: **SYStem.Option.OVERLAY [ON | OFF | WithOVS]**

Default: OFF.

|                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ON</b>      | Activates the overlay extension and extends the address scheme of the debugger with a 16 bit virtual overlay ID. Addresses therefore have the format <code>&lt;overlay_id&gt;:&lt;address&gt;</code> . This enables the debugger to handle overlaid program memory.                                                                                                                                                                                                                                           |
| <b>OFF</b>     | Disables support for code overlays.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| <b>WithOVS</b> | Like option <b>ON</b> , but also enables support for software breakpoints. This means that TRACE32 writes software breakpoint opcodes to both, the <i>execution area</i> (for active overlays) and the <i>storage area</i> . This way, it is possible to set breakpoints into inactive overlays. Upon activation of the overlay, the target's runtime mechanisms copies the breakpoint opcodes to the execution area. For using this option, the storage area must be readable and writable for the debugger. |

**Example:**

```
SYStem.Option.OVERLAY ON
Data.List 0x2:0x11c4 ; Data.List <overlay_id>:<address>
```

**SYStem.Option.REALTIME**

Stall the simulator if faster than real processor

Format: **SYStem.Option.REALTIME [ON | OFF]**

Default: OFF.

Prevents the simulator from running faster than the frequency set with **VCO.Frequency** (default: 10MHz).

Format: **SYStem.Option.ZoneSPACES [ON | OFF]**

Default: OFF.

The **SYStem.Option.ZoneSPACES** command must be set to **ON** if an Arm CPU with TrustZone or VirtualizationExtension is debugged. In these Arm CPUs, the processor has two or more CPU operation modes called:

- Non-secure mode
- Secure mode
- Hypervisor mode
- 64-bit EL3/Monitor mode (Armv8-A only)

Within TRACE32, these CPU operation modes are referred to as [zones](#).

**NOTE:** For an explanation of the TRACE32 concept of address spaces ([zone spaces](#), [MMU spaces](#), and [machine spaces](#)), see [“TRACE32 Concepts”](#) ([trace32\\_concepts.pdf](#)).

In each CPU operation mode (zone), the CPU uses separate MMU translation tables for memory accesses and separate register sets. Consequently, in each zone, different code and data can be visible on the same logical addresses.

To ease debug-scenarios where the CPU operation mode switches between non-secure, secure or hypervisor mode, it is helpful to load symbol sets for each used zone.

|            |                                                                                                                                                                                                                                                                       |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>OFF</b> | TRACE32 does not separate symbols by access class. Loading two or more symbol sets with overlapping address ranges will result in unpredictable behavior. Loaded symbols are independent of Arm zones.                                                                |
| <b>ON</b>  | Separate symbol sets can be loaded for each zone, even with overlapping address ranges. Loaded symbols are specific to one of the Arm zones - each symbol carries one of the access classes N:, Z:, H: or M:<br>For details and examples, see <a href="#">below</a> . |

## Overview of Debugging with Zones

If **SYStem.Option.ZoneSPACES** is enabled (**ON**), TRACE32 enforces any memory address specified in a TRACE32 command to have an access class which clearly indicates to which zone the memory address belongs. The following access classes are supported:

|                          |                                                                  |
|--------------------------|------------------------------------------------------------------|
| <b>N</b>                 | Non-secure mode<br>Example: Linux user application               |
| <b>Z</b>                 | Secure mode<br>Example: Secure crypto routine                    |
| <b>H</b>                 | Hypervisor mode<br>Example: XEN hypervisor                       |
| <b>M</b><br>Armv8-A only | 64-bit EL3/Monitor mode<br>Example: Trusted boot stage / monitor |

If an address specified in a command is not clearly attributed to N: Z: H: or M:, the access class of the current PC context is used to complete the addresses' access class.

Every loaded symbol is attributed to either non-secure (N:), secure (Z:), hypervisor (H:) or EL3/monitor (M:) zone. If a symbol is referenced by name, the associated access class (N:, Z:, H: or M:) will be used automatically, so that the memory access is done within the correct CPU mode context. As a result, the symbol's logical address will be translated to the physical address with the correct MMU translation table.

**NOTE:** The loaded symbols and their associated access class can be examined with command **sYmbol.List** or **sYmbol.Browse** or **sYmbol.INFO**.

## Example: Symbols Loading

---

```
SYStem.Option.ZoneSPACES ON

; 1. Load the vmlinux symbols for non-secure mode (access classes N:, NP:
; and ND: are used for the symbols) with offset 0x0:
Data.LOAD.Elf vmlinux N:0x0 /NoCODE

; 2. Load the sysmon symbols for secure mode (access classes Z:, ZP: and
; ZD: are used for the symbols) with offset 0x0:
Data.LOAD.Elf sysmon Z:0x0 /NoCODE

; 3. Load the xen-syms symbols for hypervisor mode (access classes H:,
; HP: and HD: are used for the symbols) but without offset:
Data.LOAD.Elf xen-syms H: /NoCODE

; 4. Load the sieve symbols without specification of a target access
; class and address:
Data.LOAD.Elf sieve /NoCODE
; Assuming that the current CPU mode is non-secure in this example, the
; symbols of sieve will be assigned the access classes N:, NP: and ND:
; during loading.
```

## Example: Symbolic Memory Access

---

```
; dump the address on symbol swapper_pg_dir which belongs
; to the non-secure symbol set "vmlinux" we have loaded above:
Data.dump swapper_pg_dir

; This will automatically use access class N: for the memory access,
; even if the CPU is currently not in non-secure mode.
```

## Example: Deleting Zone-specific Symbols

---

To delete a complete symbol set belonging to a specific zone, e.g. the non-secure zone, use the following command to delete all symbols in the specified address range.

```
sYmbol.Delete N:0x0--0xffffffff ; non-secure mode (access classes N:)
```

## Example: Zone-specific Debugger Address Translation Setup

---

If the option **ZoneSPACES** is enabled and the debugger address translation is used (**TRANSLATION** commands), a strict zone separation of the address translations is enforced. Also, common address ranges created with **TRANSLATION.COMMON** will always be specific for a certain zone.

This script shows how to define separate translations for the zones **N:** and **H:**

```
SYStem.Option.ZoneSPACES ON

Data.LOAD.Elf sysmon  Z:0 /NoCODE
Data.LOAD.Elf usermode N:0 /NoCODE /NoClear

; set up address translation for secure mode
TRANSLATION.Create Z:0xC0000000++0xffffffff A:0x10000000

; set up address translation for non-secure mode
TRANSLATION.Create N:0xC0000000++0xffffffff A:0x40000000

; enable address translation and table walk
TRANSLATION.ON

; check the complete translation setup
TRANSLATION.List
```

If the CPU's virtualization extension is used to virtualize one or more guest systems, the hypervisor always runs in the CPU's hypervisor mode (zone H:), and the current guest system (if a ready-to-run guest is configured at all by the hypervisor) will run in the CPU's non-secure mode (zone N:).

Often, an operation system (such as a Linux kernel) runs in the context of the guest system.

In such a setup with hypervisor and guest OS, it is possible to load both the hypervisor symbols to H: and all OS-related symbols to N:

A TRACE32 OS Awareness can be loaded in TRACE32 to support the work with the OS in the guest system. This is done as follows:

1. Configure the OS Awareness as for a non-virtualized system. See:
  - [“Training Linux Debugging”](#) (training\_rtos\_linux.pdf)
  - [TASK.CONFIG](#) command
2. Additionally set the default access class of the OS Awareness to the non-secure zone:

```
TASK.ACCESS N:
```

The TRACE32 OS Awareness is now configured to find guest OS kernel symbols in the **non-secure** zone.

**NOTE:** This debugger setup, which is based on the option **ZoneSPACES**, allows work with only one guest system simultaneously.

If the hypervisor has configured more than one guest, only the guest that is active in the non-secure CPU mode is visible.

To work with another guest, the system must continue running until an inactive guest becomes the active guest.

With **SYStem.Option.MACHINESPACES** enabled, TRACE32 also supports concurrent debugging of a virtualized system with hypervisor and multiple guests.

the CPU specific zones N: Z: H: and M: will be extended by machine specific zones. Each of these zones is identified by a [machine ID](#). Each guest has its own zone because it uses a separate translation table and a separate register set.

## Example: Setup for a Guest OS and a Hypervisor

In this script, the hypervisor is configured to run in zone **H:** and a Linux kernel with OS Awareness as current guest OS in zone **N:**

```
SYStem.Option.ZoneSPACES ON

; within the OS Awareness we need the space ID to separate address spaces
; of different processes / tasks
SYStem.Option.MMUSPACES ON

; here we let the target system boot the hypervisor. The hypervisor will
; set up the guest and boot Linux on the guest system.
...

; load the hypervisor symbols
Data.LOAD.Elf xen-syms H:0 /NoCODE
Data.LOAD.Elf usermode N:0 /NoCODE /NoClear

; set up the Linux OS Awareness
TASK.CONFIG      ~/demo/arm/kernel/linux/linux-3.x/linux3.t32
MENU.ReProgram ~/demo/arm/kernel/linux/linux-3.x/linux.men

; instruct the OS Awareness to access all OS-related symbols with
; access class N:
TASK.ACCESS N:

; set up the debugger address translation for the guest OS

; Note that the default address translation in the following command
; defines a translation of the logical kernel addresses range
; N:0xC0000000++0xFFFFFFF to the intermediate address range
; starting at I:0x40000000
MMU.FORMAT linux swapper_pg_dir N:0xC0000000++0xFFFFFFF I:0x40000000

; define the common address range for the guest kernel symbols
TRANSLATION.COMMON N:0xC0000000--0xFFFFFFF

; enable the address translation and the table walk
TRANSLATION.TableWalk ON
TRANSLATION.ON
```

**NOTE:**

If **SYStem.Option.MMUSPACES ON** is used, all addresses for all zones will show a space ID (such as **N:0x024A:0x00320100**), even if the OS Awareness runs only in one zone (as defined with command **TASK.ACCESS**).

Any task-related command, such as **MMU.List.TaskPageTable <task\_name>**, will automatically refer to tasks running in the same zone as the OS Awareness.

The command asserts nRESET on the JTAG connector in the TRACE32 In-Circuit Debugger (ICD) but is ignored by the TRACE32 Instruction Set Simulator. However, the command is allowed in the simulator so that you can run scripts which have actually been made for the debugger. For more information about the effect in the debugger, refer to your [Processor Architecture Manual](#) (debugger\_<arch>.pdf).

**SYStem.state**

Display SYStem.state window

|         |                     |
|---------|---------------------|
| Format: | <b>SYStem.state</b> |
|---------|---------------------|

Displays the **SYStem.state** window.

## TrOnchip.RESet

Reset on-chip trigger settings

Format: **TrOnchip.RESet**

Resets all TrOnchip settings.

## TrOnchip.Set

Set bits in the vector catch register

Format: **TrOnchip.Set <item> [ON | OFF]**

<item>: ARM9, ARM11, Cortex-A/R:  
[**FIQ | IRQ | DABORT | PABORT | SWI | UNDEF | RESET**]

Devices having TrustZone (ARM1176, Cortex-A) additionally:  
[**NFIQ | NIRQ | NDABORT | NPABORT | NSWI | NUNDEF |  
SFIQ | SIRQ | SDABORT | SPABORT | SSWI | SUNDEF | SRESET |  
MFIQ | MIRQ | MDABORT | MPABORT | MSWI**]

Devices having a Hypervisor mode (e.g. Cortex-A7, -A15) additionally:  
[**HFIQ | HIRQ | HDABORT | HPABORT | HSWI | HUNDEF | HENTRY**]

Cortex-M devices:  
[**SFERR | HARDERR | INTERR | BUSERR | STATERR | CHKERR |  
NOCPERR | MMERR | CORERESET**]

### ALIGNMENT

Default: DABORT, PABORT, UNDEF, RESET ON, others OFF.

On devices having TrustZone you can specify for most exceptions if the vector catch shall take effect only in non-secure (N...), secure (S...) or monitor mode (M...), on devices having a Hypervisor mode also in hypervisor mode (H...).

**FIQ, ...** Sets/resets the corresponding bits in the vector catch register of the core. If the bit of a vector is set and the corresponding exception occurs, the processor enters debug state as if there had been a breakpoint set on an instruction fetch from that exception vector.

**SFERR** Debug trap on secure fault.

|                                   |                                                                                                                            |
|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| <b>HARDERR</b>                    | Debug trap on hard fault.                                                                                                  |
| <b>INTERR</b>                     | Debug trap on interrupt/exception service errors. These are a subset of other faults and catches before BUSERR or HARDERR. |
| <b>BUSERR</b>                     | Debug trap on normal bus error.                                                                                            |
| <b>STATERR</b>                    | Debug trap on usage fault state errors.                                                                                    |
| <b>CHKERR</b>                     | Debug trap on usage fault enabled checking errors.                                                                         |
| <b>NOCPERR</b>                    | Debug trap on usage fault access to coprocessor which is not present or marked as not present in CAR register.             |
| <b>MMERR</b>                      | Debug trap on memory management faults.                                                                                    |
| <b>CORERESET</b>                  | Reset vector catch. Halt running system if core reset occurs.                                                              |
| <b>StepVector</b><br>(deprecated) | Please see <a href="#">TrOnchip.StepVector</a> .                                                                           |
| <b>ALIGNMENT</b>                  | Stops the program execution on unaligned accesses.                                                                         |

## TrOnchip.StepVector

Step into exception handler

Format: **TrOnchip.StepVector [ON | OFF]**

Default: OFF.

**ON** Step into exception handler.

**OFF** Step over exception handler.

## TrOnchip.StepVectorResume

Catch exceptions and resume single step

Format: **TrOnchip.StepVector [ON | OFF]**

Default: OFF.

When this command is set to ON, the debugger will catch exceptions and resume the single step.

Format: **TrOnchip.state**

Opens the **TrOnchip.state** window.

# CPU specific MMU Commands

## MMU.DUMP

### Page wise display of MMU translation table

|           |                                                                                                                                                     |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Format:   | <b>MMU.DUMP</b> <table> [<range>   <address>   <range> <root>   <address> <root>] [/<option>]<br><b>MMU.&lt;table&gt;.dump</b> (deprecated)         |
| <table>:  | <b>PageTable</b><br><b>KernelPageTable</b><br><b>TaskPageTable</b> <task_magic>   <task_id>   <task_name>   <space_id>:0x0<br><cpu_specific_tables> |
| <option>: | <b>MACHINE</b> <machine_magic>   <machine_id>   <machine_name><br><b>Fulltranslation</b>                                                            |

Displays the contents of the CPU specific MMU translation table.

- If called without parameters, the complete table will be displayed.
- If the command is called with either an address range or an explicit address, table entries will only be displayed if their **logical** address matches with the given parameter.

|                        |                                                                                                                                                                                                                                                                                                                                               |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <root>                 | The <root> argument can be used to specify a page table base address deviating from the default page table base address. This allows to display a page table located anywhere in memory.                                                                                                                                                      |
| <range><br><address>   | Limit the address range displayed to either an address range or to addresses larger or equal to <address>.<br><br>For most table types, the arguments <range> or <address> can also be used to select the translation table of a specific process or a specific machine if a <b>space ID</b> and/or a <b>machine ID</b> is given.             |
| <b>PageTable</b>       | Displays the entries of an MMU translation table. <ul style="list-style-type: none"><li>• if &lt;range&gt; or &lt;address&gt; have a space ID and/or machine ID: displays the translation table of the specified process and/or machine</li><li>• else, this command displays the table the CPU currently uses for MMU translation.</li></ul> |
| <b>KernelPageTable</b> | Displays the MMU translation table of the kernel.<br>If specified with the <b>MMU FORMAT</b> command, this command reads the MMU translation table of the kernel and displays its table entries.                                                                                                                                              |

|                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TaskPageTable</b><br><i>&lt;task_magic&gt;  </i><br><i>&lt;task_id&gt;  </i><br><i>&lt;task_name&gt;  </i><br><i>&lt;space_id&gt;:0x0</i> | <p>Displays the MMU translation table entries of the given process. Specify one of the <b>TaskPageTable</b> arguments to choose the process you want. In MMU-based operating systems, each process uses its own MMU translation table. This command reads the table of the specified process, and displays its table entries.</p> <ul style="list-style-type: none"> <li>For information about the first three parameters, see “<a href="#">What to know about the Task Parameters</a>” (general_ref_t.pdf).</li> <li>See also the appropriate <a href="#">OS Awareness Manuals</a>.</li> </ul> |
| <b>MACHINE</b><br><i>&lt;machine_magic&gt;  </i><br><i>&lt;machine_id&gt;  </i><br><i>&lt;machine_name&gt;</i>                               | <p>The following options are only available if <b>SYStem.Option.MACHINESPACES</b> is set to <b>ON</b>.</p> <p>Dumps a page table of a virtual machine. The <b>MACHINE</b> option applies to <b>PageTable</b> and <b>KernelPageTable</b> and some <i>&lt;cpu_specific_tables&gt;</i>.</p> <p>The parameters <i>&lt;machine_magic&gt;</i>, <i>&lt;machine_id&gt;</i> and <i>&lt;machine_name&gt;</i> are displayed in the <a href="#">TASK.List.MACHINES</a> window.</p>                                                                                                                          |
| <b>Fulltranslation</b>                                                                                                                       | <p>For page tables of guest machines both the <a href="#">intermediate address</a> and the physical address is displayed in the <b>MMU.DUMP</b> window.</p> <p>The physical address is derived from a table walk using the guest's intermediate page table.</p>                                                                                                                                                                                                                                                                                                                                 |

## CPU specific Tables for MMU.DUMP <table>

---

|                        |                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ITLB</b>            | <p>Displays the contents of the Instruction Translation Lookaside Buffer.</p>                                                                                                                                                                                                                                                                                                           |
| <b>DTLB</b>            | <p>Displays the contents of the Data Translation Lookaside Buffer.</p>                                                                                                                                                                                                                                                                                                                  |
| <b>TLB</b>             | <p>Displays the contents of the Translation Lookaside Buffer.</p>                                                                                                                                                                                                                                                                                                                       |
| <b>TLB0</b>            | <p>Displays the contents of the Translation Lookaside Buffer 0.</p>                                                                                                                                                                                                                                                                                                                     |
| <b>TLB1</b>            | <p>Displays the contents of the Translation Lookaside Buffer 1.</p>                                                                                                                                                                                                                                                                                                                     |
| <b>NonSecPageTable</b> | <p>Displays the translation table used if the CPU is in non-secure mode and in privilege level PL0 or PL1. This is the table pointed to by MMU registers TTBR0 and TTBR1 in non-secure mode. This option is only visible if the CPU has the TrustZone and/or Virtualization Extension.</p> <p>In ARMv8 this option is only enabled if Exception levels EL0 or EL1 use AArch32 mode.</p> |
| <b>SecPageTable</b>    | <p>Displays the translation table used if the CPU is in secure mode. This is the table pointed to by MMU registers TTBR0 and TTBR1 in secure mode. This option is only visible if the CPU has the TrustZone Extension.</p>                                                                                                                                                              |

|                          |                                                                                                                                                                                                                                                                                         |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>HypPageTable</b>      | Displays the translation table used by the MMU when the CPU is in HYP mode. This is the table pointed to by MMU register HTTBR. This table is only available in CPUs with Virtualization Extension.                                                                                     |
| <b>IntermedPageTable</b> | Displays the translation table used by the MMU for the second stage translation of a guest machine ( <a href="#">intermediate address</a> to physical address). This is the table pointed to by MMU register VTTBR. This table is only available in CPUs with Virtualization Extension. |

## Examples for Page Tables in Virtualized Systems

---

### Example 1:

```
SYStem.Option.MACHINESPACES ON

; your code to load Hypervisor Awareness and define guest machine setup.

;                                     <machine_id>
MMU.DUMP.PageTable /MACHINE      2.

;

;                                     <machine_name>
MMU.DUMP.PageTable /MACHINE      "Dom0"
```

### Example 2:

```
SYStem.Option.MACHINESPACES ON

; your code to load Hypervisor Awareness and define guest machine setup.

;                                     <machine_name>:::<task_name>
MMU.DUMP.TaskPageTable           "Dom0:::swapper"
```

### Example 3:

```
SYStem.Option.MACHINESPACES ON

;your code to load Hypervisor Awareness and define guest machine setup.

;a) dumps the current guest page table of the current machine, showing
;   the intermediate addresses.
;   Without the option /Fulltranslation the column "physical" is hidden.
MMU.DUMP.PageTable 0x400000

;b) With the option /Fulltranslation the intermediate addresses
;   are translated to physical addresses and shown in column "physical"
MMU.DUMP.PageTable 0x400000 /Fulltranslation

;c) dumps the current page table of machine 2
;   <machine_id>
MMU.DUMP.PageTable /MACHINE 2. /Fulltranslation
```

### Results for 3 a) and 3 b)

| logical                       | intermediate             | physical | sec | d | size     | permissions |
|-------------------------------|--------------------------|----------|-----|---|----------|-------------|
| N:2:::0000:00400000--00400FFF | I:2:::411EB000--411EBFFF |          | ns  |   | 00001000 | P:readonly  |
| N:2:::0000:00401000--00401FFF | I:2:::411EC000--411ECFFF |          | ns  |   | 00001000 | P:readonly  |
| N:2:::0000:00402000--00402FFF | I:2:::411ED000--411EDFFF |          | ns  |   | 00001000 | P:readonly  |

| logical                       | intermediate             | physical              | sec | d | size     | permissions |
|-------------------------------|--------------------------|-----------------------|-----|---|----------|-------------|
| N:2:::0000:00400000--00400FFF | I:2:::411EB000--411EBFFF | AH:7F7EB000--7F7EBFFF | ns  |   | 00001000 | P:readonly  |
| N:2:::0000:00401000--00401FFF | I:2:::411EC000--411ECFFF | AH:7F7EC000--7F7ECFFF | ns  |   | 00001000 | P:readonly  |
| N:2:::0000:00402000--00402FFF | I:2:::411ED000--411EDFFF | AH:7F7ED000--7F7EDFFF | ns  |   | 00001000 | P:readonly  |

|           |                                                                                                                                                     |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Format:   | <b>MMU.List</b> <table> [<range>   <address>   <range> <root>   <address> <root>]<br>[<option>]<br><b>MMU.&lt;table&gt;.List</b> (deprecated)       |
| <table>:  | <b>PageTable</b><br><b>KernelPageTable</b><br><b>TaskPageTable</b> <task_magic>   <task_id>   <task_name>   <space_id>:0x0<br><cpu_specific_tables> |
| <option>: | <b>MACHINE</b> <machine_magic>   <machine_id>   <machine_name><br><b>Fulltranslation</b>                                                            |

Lists the address translation of the CPU-specific MMU table.

In contrast to **MMU.DUMP**, multiple consecutive page table entries with identical page attributes are listed as a single line, showing the total mapped address range.

- If called without address or range parameters, the complete table will be displayed.
- If called without a table specifier, this command shows the debugger-internal translation table. See **TRANSlation.List**.
- If the command is called with either an address range or an explicit address, table entries will only be displayed if their **logical** address matches with the given parameter.

|                        |                                                                                                                                                                                                                                                                                                                                        |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <root>                 | The <root> argument can be used to specify a page table base address deviating from the default page table base address. This allows to display a page table located anywhere in memory.                                                                                                                                               |
| <range><br><address>   | Limit the address range displayed to either an address range or to addresses larger or equal to <address>.<br><br>For most table types, the arguments <range> or <address> can also be used to select the translation table of a specific process or a specific machine if a <b>space ID</b> and/or a <b>machine ID</b> is given.      |
| <b>PageTable</b>       | Lists the entries of an MMU translation table. <ul style="list-style-type: none"> <li>• if &lt;range&gt; or &lt;address&gt; have a space ID and/or machine ID: list the translation table of the specified process and/or machine</li> <li>• else, this command lists the table the CPU currently uses for MMU translation.</li> </ul> |
| <b>KernelPageTable</b> | Lists the MMU translation table of the kernel.<br>If specified with the <b>MMU FORMAT</b> command, this command reads the MMU translation table of the kernel and lists its address translation.                                                                                                                                       |

|                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>TaskPageTable</b><br><code>&lt;task_magic&gt;  </code><br><code>&lt;task_id&gt;  </code><br><code>&lt;task_name&gt;  </code><br><code>&lt;space_id&gt;:0x0</code> | <p>Lists the MMU translation of the given process. Specify one of the <b>TaskPageTable</b> arguments to choose the process you want.</p> <p>In MMU-based operating systems, each process uses its own MMU translation table. This command reads the table of the specified process, and lists its address translation.</p> <ul style="list-style-type: none"> <li>For information about the first three parameters, see “<a href="#">What to know about the Task Parameters</a>” (general_ref_t.pdf).</li> <li>See also the appropriate <a href="#">OS Awareness Manuals</a>.</li> </ul> |
| <code>&lt;option&gt;</code>                                                                                                                                          | For description of the options, see <a href="#">MMU.DUMP</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## CPU specific Tables for MMU.List <table>

|                          |                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>NonSecPageTable</b>   | <p>Displays the translation table used if the CPU is in non-secure mode and in privilege level PL0 or PL1. This is the table pointed to by MMU registers TTBR0 and TTBR1 in non-secure mode. This option is only visible if the CPU has the TrustZone and/or Virtualization Extension.</p> <p>In ARMv8 this option is only enabled if Exception levels EL0 or EL1 use AArch32 mode.</p> |
| <b>SecPageTable</b>      | <p>Displays the translation table used if the CPU is in secure mode. This is the table pointed to by MMU registers TTBR0 and TTBR1 in secure mode. This option is only visible if the CPU has the TrustZone Extension.</p>                                                                                                                                                              |
| <b>HypPageTable</b>      | <p>Displays the translation table used by the MMU when the CPU is in HYP mode. This is the table pointed to by MMU register HTTBR.</p> <p>This table is only available in CPUs with Virtualization Extension.</p>                                                                                                                                                                       |
| <b>IntermedPageTable</b> | <p>Displays the translation table used by the MMU for the second stage translation of a guest machine (<a href="#">intermediate address</a> to physical address).</p> <p>This is the table pointed to by MMU register VTTBR.</p> <p>This table is only available in CPUs with Virtualization Extension.</p>                                                                             |

|           |                                                                                                                                                                   |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format:   | <b>MMU.SCAN</b> <table> [<range> <address>] [/<option>]<br><b>MMU.&lt;table&gt;.SCAN</b> (deprecated)                                                             |
| <table>:  | <b>PageTable</b><br><b>KernelPageTable</b><br><b>TaskPageTable</b> <task_magic>   <task_id>   <task_name>   <space_id>:0x0<br><b>ALL</b><br><cpu_specific_tables> |
| <option>: | <b>MACHINE</b> <machine_magic>   <machine_id>   <machine_name><br><b>Fulltranslation</b>                                                                          |

Loads the CPU-specific MMU translation table from the CPU to the debugger-internal static translation table.

- If called without parameters, the complete page table will be loaded. The list of static address translations can be viewed with **TRANSlation.List**.
- If the command is called with either an address range or an explicit address, page table entries will only be loaded if their **logical** address matches with the given parameter.

Use this command to make the translation information available for the debugger even when the program execution is running and the debugger has no access to the page tables and TLBs. This is required for the real-time memory access. Use the command **TRANSlation.ON** to enable the debugger-internal MMU table.

|                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PageTable</b>                                                                         | Loads the entries of an MMU translation table and copies the address translation into the debugger-internal static translation table. <ul style="list-style-type: none"> <li>• if &lt;range&gt; or &lt;address&gt; have a space ID and/or machine ID: loads the translation table of the specified process and/or machine</li> <li>• else, this command loads the table the CPU currently uses for MMU translation.</li> </ul>                                                                                                                                                                                              |
| <b>KernelPageTable</b>                                                                   | Loads the MMU translation table of the kernel.<br>If specified with the <b>MMU.FORMAT</b> command, this command reads the table of the kernel and copies its address translation into the debugger-internal static translation table.                                                                                                                                                                                                                                                                                                                                                                                       |
| <b>TaskPageTable</b><br><task_magic>  <br><task_id>  <br><task_name>  <br><space_id>:0x0 | Loads the MMU address translation of the given process. Specify one of the <b>TaskPageTable</b> arguments to choose the process you want.<br>In MMU-based operating systems, each process uses its own MMU translation table. This command reads the table of the specified process, and copies its address translation into the debugger-internal static translation table. <ul style="list-style-type: none"> <li>• For information about the first three parameters, see <b>“What to know about the Task Parameters”</b> (general_ref_t.pdf).</li> <li>• See also the appropriate <b>OS Awareness Manual</b>.</li> </ul> |

|                       |                                                                                                                                                                                                                                                                                                |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ALL</b>            | Loads all known MMU address translations.<br>This command reads the OS kernel MMU table and the MMU tables of all processes and copies the complete address translation into the debugger-internal static translation table.<br>See also the appropriate <a href="#">OS Awareness Manual</a> . |
| <i>&lt;option&gt;</i> | For description of the options, see <a href="#">MMU.DUMP</a> .                                                                                                                                                                                                                                 |

## CPU specific Table for MMU.SCAN <table>

---

|                        |                                                                                      |
|------------------------|--------------------------------------------------------------------------------------|
| <b>OEMAddressTable</b> | Loads the OEM Address Table from the CPU to the debugger-internal translation table. |
|------------------------|--------------------------------------------------------------------------------------|

## SMMU

## Hardware system MMU (SMMU)

---

Using the **SMMU** command group, you can analyze the current setup of up to 20 system MMU instances. Selecting a CPU with a built-in SMMU activates the **SMMU** command group.

```
SYStem.CPU CortexA53 ;for example, the 'CortexA53' CPU is SMMU-capable
SMMU.ADD ... ;you can now define an SMMU, e.g. an SMMU for a
;graphics processing unit (GPU)
```

Some SoC CPU types have already SMMUs predefined as component, visible in the **SYStem.CONFIG** component dialog window.

TRACE32 supports the SMMU types MMU-400, MMU-401 and MMU-500 (based on the Arm SMMU architecture specification v2, short SMMU-v2) and MMU-600 (based on the Arm SMMU architecture specification v3, short SMMU-v3).

The TRACE32 SMMU support visualizes most of the configuration settings of an SMMU. These visualizations include:

- The Stream Table with all Stream Map Register Groups (SMRG, for SMMU-v2) or all Stream Table Entries (STE, for SMMU-v3)
- Access to both the non-secure and the secure SMMU view
- Tabular overview over principal data of each SMRG or STE listed in the Stream Table such as
  - Stream matching register settings (for SMMU-v2)
  - Translation context type (stage 1 / stage 2 enabled / bypass / fault)
  - The context's stream world of a SMRG (HYPC and MONC flags) or STE (EL1/EL2/EL3)
  - Stage 1 / stage 2 context bank indices (for SMMU-v2)
  - The availability of stage1 and stage 2 page tables, their format and the MMU-enable/disableT state for the stage 1 and/or stage 2 address translation
  - VMID and the number of stage 1 Context Descriptors for a STE (for SMMU-v3)
- The stage 1 Context Descriptor Table for a given STE (for SMMU-v3)
- Page table lists or dumps for stage 1 and/or stage 2 address translation contexts
- A quick indication of contexts where a fault has occurred or contexts that are stalled (SMMU-v2)
- A quick indication of the global SMMU fault status
- CMD Queue and Event Queue dumps with filtering options (for SMMU-v3)

- Peripheral register view:
  - Global Configuration Registers of the SMMU
  - The SMRG / STE Registers
  - The Context Bank Registers (SMMU-v2) / Context Descriptor Registers (SMMU-v3)
  - MMU-specific Registers such as Performance Measurement Unit Registers, Translation Control Unit Registers or Translation Buffer Unit Registers (for SMMU-v3)

A good way to familiarize yourself with the **SMMU** command group is to start with:

- The **SMMU.ADD** command
- The **SMMU.StreamTable** command which offers GUI-based access to almost all SMMU data
- The guide [Overview - How To](#)
- [Glossary - SMMU](#)
- [Arguments in SMMU Commands](#)

The **SMMU.StreamTable** command and the window of the same name serve as your SMMU command and control center in TRACE32. The right-click popup menu in the **SMMU.StreamTable** window allows you to execute all frequently-used SMMU commands through the user interface TRACE32 PowerView.

The other SMMU commands are designed primarily for use in PRACTICE scripts (\*.cmm) and for users accustomed to working with the command line.

**NOTE:**

The primary table of streams is called *Stream Map Table* in the SMMU-v2 architecture specification, whereas it is called *Stream Table* in the SMMU-v3 architecture specification.

To keep the TRACE32 user interface simple, a single unified command, **SMMU.StreamTable**, is used to access the table of streams for all supported SMMU architecture versions.

**SMMU.StreamTable** replaces the deprecated command **SMMU.StreamMapTable** which was used for SMMU-v2 *Stream Map Table* access in older TRACE32 versions. However, **SMMU.StreamMapTable** remains an accepted command in scripts to preserve backward compatibility.

## Overview - How To

---

This chapter is a brief guide which commands can be used to perform common tasks. The guide is split into two parts: one for MMU-400, MMU-401 and MMU-500 which follow the SMMU-v2 specification and one for MMU-600 and newer which follow the SMMU-v3 specification.

| How To...                                                                                                                                                 | GUI action or commands                                                                                                                                                                                                                                                         |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Define a new SMMU                                                                                                                                         | <p><a href="#">SMMU.Add</a></p> <p>To get the non-secure/secure SMMU view, specify a non-secure/secure base address.</p>                                                                                                                                                       |
| <p>View the Stream Table with all <a href="#">SMRGs</a></p> <p>View the stream configurations and see the context bank indices of stage 1 and stage 2</p> | <p><a href="#">SMMU.StreamTable</a></p>                                                                                                                                                                                                                                        |
| List or dump stage 1 or stage 2 page tables of a stream                                                                                                   | <p>In <a href="#">SMMU.StreamTable</a> window: use popup menu or double click on column <b>stage 1 pagtbl. fmt</b> or <b>stage 2 pagtbl. fmt</b></p> <p><a href="#">SMMU.StreamMapRegGrp.list</a><br/><a href="#">SMMU.StreamMapRegGrp.Dump</a></p>                            |
| View a stream's <a href="#">SMRG</a> registers                                                                                                            | <p>In <a href="#">SMMU.StreamTable</a> window: use popup menu or double click on any column of <b>stream matching</b> or <b>context type</b></p> <p><a href="#">SMMU.StreamMapRegGrp.Register</a><br/><a href="#">SMMU.Register.StreamMapRegGrp</a></p>                        |
| View stage 1 or stage 2 context bank registers                                                                                                            | <p>In <a href="#">SMMU.StreamTable</a> window: use popup menu or double click on column <b>stage 1 cbndx</b> or <b>stage 2 cbndx</b></p> <p><a href="#">SMMU.StreamMapRegGrp.ContextReg</a><br/><a href="#">SMMU.Register.ContextBank</a></p>                                  |
| View global SMMU registers                                                                                                                                | <p>In <a href="#">SMMU.StreamTable</a> window: use popup menu or double click status line</p> <p><a href="#">SMMU.Register.Global</a></p>                                                                                                                                      |
| View global SMMU fault flags                                                                                                                              | <p>Fault flags are displayed in the <b>status line</b> at the bottom of the <a href="#">SMMU.StreamTable</a> window.</p> <p>Alternatively, open the global SMMU registers with <a href="#">SMMU.Register.Global</a> and view register SMMU_GFSR / SMMU_sGFSR (non-sec/sec)</p> |
| Check if an SMMU stream is in a fault state                                                                                                               | <p>Open the <a href="#">SMMU.StreamTable</a> window: Streams in fault/stall/multi state have red <b>F/S/M marks</b> in column <b>stage 1 state</b> or <b>stage 2 state</b></p>                                                                                                 |
| View <a href="#">Security State Determination Table</a> (SSD)                                                                                             | <p>In <a href="#">SMMU.StreamTable</a> window: use popup menu</p> <p><a href="#">SMMU.SSDtable</a></p>                                                                                                                                                                         |

## MMU-600 and newer:

| How To...                                                                                                                                                                                                            | GUI action or commands                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Define a new SMMU                                                                                                                                                                                                    | <p><b>SMMU.Add</b></p> <p>Use a secure base address.<br/>Default SMMU view is non-secure. Switch to secure view with option <b>/SECure</b> in most commands or use check box <b>Show secure entries</b> in the header of most SMMU windows.</p>                                                                                                                                                                                                               |
| <p>View the Stream Table with all valid <b>STEs</b></p> <p>View the stream configuration, VMID, stream world, stage 2 page table format, number of <b>CDSs</b></p>                                                   | <p><b>SMMU.StreamTable</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                |
| <p>View the <b>Context Descriptor Table</b> of a <b>STE</b> with a list of all valid substreams (<b>CDSs</b>)</p> <p>View the ASID, stage 1 page table format and TT0/TT1 translation enable state of substreams</p> | <p>In <b>SMMU.StreamTable</b> window: use popup menu or click on the STE's <b>list CDT</b> button in the <b>S1 PT fmt</b> column to open the Context Descriptor Table window.</p> <p><b>SMMU.CtxtDescTable</b></p>                                                                                                                                                                                                                                            |
| List or dump stage 2 page tables of a <b>STE</b>                                                                                                                                                                     | <p>In <b>SMMU.StreamTable</b> window: use popup menu or double click on column <b>S2 PT fmt</b> or <b>stage 2 pagtbl. fmt</b></p> <p><b>SMMU.StreamTblEntry.list</b><br/><b>SMMU.StreamTblEntry.Dump</b></p>                                                                                                                                                                                                                                                  |
| List or dump stage 1 page tables of a <b>STE/CD</b>                                                                                                                                                                  | <p>If STE has only one CD: use popup menu in <b>SMMU.StreamTable</b> window or double click on column <b>S1 PT fmt</b> to view the CD's page table.</p> <p>If STE has more than one CD: click on the STE's <b>list CDT</b> button in the <b>S1 PT fmt</b> column to open the Context Descriptor Table window. Here, use popup menu or double click on column <b>S1 PT fmt</b>.</p> <p><b>SMMU.StreamTblEntry.list</b><br/><b>SMMU.StreamTblEntry.Dump</b></p> |
| View a stream's <b>STE</b> registers                                                                                                                                                                                 | <p>In <b>SMMU.StreamTable</b> window: use popup menu or double click on column <b>configuration</b></p> <p><b>SMMU.StreamTblEntry.Register</b><br/><b>SMMU.Register.StreamTblEntry</b></p>                                                                                                                                                                                                                                                                    |

| How To...                                                                                              | GUI action or commands                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| View the stage 1 <b>CD</b> registers for a substream                                                   | <p>If <b>STE</b> has only one CD: use popup menu in <b>SMMU.StreamTable</b> window or double click on column <b>ASID</b> to view the CD registers.</p> <p>If STE has more than one CD: click on the STE's <b>list CDT</b> button in the <b>S1 PT fmt</b> column to open the Context Descriptor Table window. Here, use popup menu or double click on column <b>ASID</b>.</p> <p><b>SMMU.Register.S1Context</b></p>                                                       |
| View global SMMU registers                                                                             | <p>In <b>SMMU.StreamTable</b> window: use popup menu or double click status line</p> <p><b>SMMU.Register.Global</b></p>                                                                                                                                                                                                                                                                                                                                                  |
| View global SMMU fault flags                                                                           | <p>Fault flags are displayed in the <b>status line</b> at the bottom of the <b>SMMU.StreamTable</b> window.</p> <p>Alternatively, open the global SMMU registers with <b>SMMU.Register.Global</b> and view register <b>SMMU_GERROR / SMMU_S_GERROR</b></p>                                                                                                                                                                                                               |
| <p>Check if an SMMU stream or substream is in a fault state</p> <p>Dump Event <b>Queue</b> entries</p> | <p>In the <b>SMMU.StreamTable</b> or the <b>SMMU.CtxtDescTable</b> window:</p> <ul style="list-style-type: none"> <li>either use popup menu <b>Dump Queue Entries - Event Queue</b> to <b>dump</b> all Event Queue entries</li> <li>or, with mouse over STE or CD of interest, use popup menu <b>Dump associated Queue Entries - Event Queue</b> to <b>dump</b> Event Queue entries filtered by Stream ID and Substream ID</li> </ul> <p><b>SMMU.DumpQueue.Event</b></p> |
| Dump CMD <b>Queue</b> entries                                                                          | <p>In the <b>SMMU.StreamTable</b> or the <b>SMMU.CtxtDescTable</b> window:</p> <ul style="list-style-type: none"> <li>either use popup menu <b>Dump Queue Entries - CMD Queue</b> to <b>dump</b> all CMD Queue entries</li> <li>or, with mouse over STE or CD of interest, use popup menu <b>Dump associated Queue Entries - CMD Queue</b> to <b>dump</b> CMD Queue entries filtered by Stream ID and Substream ID</li> </ul> <p><b>SMMU.DumpQueue.CMD</b></p>           |

The following two figures illustrate a few SMMU terms. For explanations of the illustrated SMMU terms and other important SMMU terms not shown here, see below.

## MMU-400, MMU-401 and MMU-500:

**A** See [stream table](#).

**B** Each row stands for a [stream map register group \(SMRG\)](#).

**C** Index of a [translation context bank](#).

**D** Data from stream matching registers, see [stream matching](#).

## MMU-600 and newer:

**A** See [stream table](#).

**B** Each row stands for a [stream table entry \(STE\)](#).

**C** Stream configuration and stage 2 context.

**D** Substream data and either stage 1 context or button to view the STE's [Context Descriptor Table](#).

## Context Descriptor (CD)

---

*MMU-600 and newer only*

A data structure in memory containing register fields which describe a stage 1 translation context, including a pointer to the stage 1 translation table. A CD is identified by its [substream ID](#) and by the [stream ID](#) of the it belongs to.

## Context Descriptor Table (CDT)

---

*MMU-600 and newer only*

A table in memory with one or two levels which holds a number of [Context Descriptors](#). Each Context Descriptor Table belongs to one [Stream Table Entry](#).

A CDT can be displayed using command [SMMU.CtxtDescTable](#).

## Memory Transaction Stream

---

A stream of memory access transactions sent from a device through the SMMU to the system memory bus. The stream consists of the address to be accessed and a number of design specific memory attributes such as the privilege, cacheability, security attributes or other attributes.

The streams carry a stream ID which the SMMU uses to determine a translation context for the memory transaction stream. As a result, the SMMU may or may not translate the address and/or the memory attributes of the stream before it is forwarded to the system memory bus.

## Queue

---

*MMU-600 and newer only*

Data structure consisting of a circular buffer in memory which holds queue entries. Queue entries may hold commands for the SMMU (in the CMD Queue) or events generated by the SMMU (in the Event Queue). Queues can be viewed using command [SMMU.DumpQueue](#).

## Security State Determination Table (SSD Table)

---

*MMU-400, MMU-401 and MMU-500 only*

If the SMMU supports two security states (secure and non-secure) an SSD index qualifies memory transactions sent to the SMMU. The SSD index is a hardware signal which is used by the SMMU to decide whether the incoming memory transaction belongs to the secure or the non-secure domain.

The information whether a SSD index belongs to the secure or to the non-secure domain is contained in the SMMU's SSD table.

## Stream ID

---

Peripheral devices connected to an SMMU issue memory transaction streams. Every incoming memory transaction stream carries a Stream Identifier which is used by the SMMU to associate a translation context to the transaction stream. The streams are stored in the [Stream Table](#) of the SMMU.

## Stream Map Register Group (SMRG)

---

*MMU-400, MMU-401 and MMU-500 only*

A group of SMMU registers determining the translation context for a memory transaction stream. The [Stream Table](#) holds the SMRGs.

## Stream Table (ST) / Stream Mapping Table (SMT)

---

An SMMU table which describes what to do with an incoming memory transaction stream from a peripheral device. In particular, this table associates an incoming memory transaction stream with a translation context, using the stream ID of the stream as selector of a translation context.

In MMU-400, MMU-401 and MMU-500 (Arm SMMU-v2 specification based), this table of streams is referred to as *Stream Mapping Table*. In MMU-600 and newer (Arm SMMU-v3 specification based), this table of streams is referred to as *Stream Table*. The Stream (Mapping) Table is the central table of the SMMU.

- MMU-400, MMU-401 and MMU-500): each Stream Mapping Table entry consists of a group of registers, called [Stream Map Register Group](#), which describe the translation context. In case an SMMU supports *stream matching*, TRACE32 also displays the *stream matching registers* associated with an entry's stream map register group.
- MMU-600 and newer: the stream table is a data structure in memory and consists of [Stream Table Entries](#) which describe the translation context type, the stage 2 translation tables and points to a [Context Descriptor Table](#) which holds stage 1 translation contexts.

A Stream Table can be displayed using command [SMMU.StreamTable](#).

## Stream Matching

---

*MMU-400, MMU-401 and MMU-500 only*

In an SMMU which supports stream matching, the stream ID of an incoming memory transaction stream undergoes a matching process to determine which entry of the [Stream Table](#) will be used to specify the translation context for the stream.

TRACE32 displays the reference ID and the bit mask used by the SMMU to perform the *Stream ID* matching process in the [SMMU.StreamTable](#) window.

## Stream Table Entry (STE)

---

*MMU-600 and newer only*

A data structure in memory describing the translation context for each stream. This data structure register contains fields which describe the type of context, the stage 2 translation context, including a pointer to the stage 2 translation table and a pointer to a [Context Descriptor Table](#) holding stage 1 contexts. Each STE is identified by its [Stream ID](#).

Note: for MMU-400, MMU-401 and MMU-500 the entries of the Stream Table are called [Stream Map Register Group](#).

## Substream ID

---

Peripheral devices connected to an SMMU issue memory transaction streams. Every incoming memory transaction stream carries a Stream Identifier which is used by the SMMU to associate a translation context to the transaction stream. The streams are stored in the [Stream Table](#) of the SMMU.

## Translation Context

---

A translation context describes the translation process of a incoming memory transaction stream. An incoming memory transaction stream may undergo a stage 1 address translation and/or a stage 2 address translation. Further, the memory attributes of the incoming memory transaction stream may be changed. It is also possible that an incoming memory transaction stream is rendered as fault.

The [Stream Table](#) determines which translation context is applied to an incoming memory transaction stream.

## Translation Context Bank (short: Context Bank)

---

*MMU-400, MMU-401 and MMU-500 only*

A group of SMMU registers specifying the translation context for an incoming memory transaction stream. The registers carry largely the same names and contain the same information as the core's MMU registers describing the address translation process.

The registers of a translation context bank describe the translation table base address, the memory attributes to be used during the translation table walk and translation attribute remapping.

## Arguments in SMMU Commands

---

This table provides an overview of frequently-used arguments in SMMU commands. Arguments that are only used in one **SMMU** command are described together with that **SMMU** command.

|                                                   |                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>&lt;name&gt;</code>                         | User-defined name of an SMMU.<br>Use the <b>SMMU.ADD</b> command to define an SMMU and its name. This name will be used to identify an SMMU in all other <b>SMMU</b> commands.                                                                                                                                                        |
| <code>&lt;smrg_index&gt;</code>                   | Index of a stream map register group, e.g. 0x04. The indices are listed in the <b>index</b> column of the <b>SMMU.StreamTable</b> .<br>The <code>&lt;smrg_index&gt;</code> is equivalent to the <code>&lt;stream_id&gt;</code> used in MMU-600 and newer.<br><i>Only applicable for MMU-400, MMU-401 and MMU-500.</i>                 |
| <code>&lt;cbndx&gt;</code>                        | Index of a translation context bank.<br><i>Only applicable for MMU-400, MMU-401 and MMU-500.</i>                                                                                                                                                                                                                                      |
| <code>&lt;stream_id&gt;   &lt;range&gt;</code>    | Index of a StreamTable Entry or a range of Stream Table Entries. The indices are listed in the <b>index</b> column of the <b>SMMU.StreamTable</b> .<br>The <code>&lt;stream_id&gt;</code> is equivalent to the <code>&lt;smrg_index&gt;</code> used in MMU-400, MMU-401 and MMU-500.<br><i>Only applicable for MMU-600 and newer.</i> |
| <code>&lt;substream_id&gt;   &lt;range&gt;</code> | Index of a Context Descriptor Table Entry or a range of Context Descriptor Table Entries.<br><i>Only applicable for MMU-600 and newer.</i>                                                                                                                                                                                            |
| <code>&lt;address&gt;   &lt;range&gt;</code>      | Logical address or logical address range describing the start address or the address range to be displayed in the SMMU page table list or dump windows.                                                                                                                                                                               |
| <b>IntermediatePT</b>                             | Used to switch between stage 1 and stage 2 page table or register view: <ul style="list-style-type: none"><li>• Omit this option to view the translation table entries or registers of stage 1.</li><li>• Include this option to view the translation table entries or registers of stage 2.</li></ul>                                |
| <b>SECure</b>                                     | Used to switch between the non-secure and the secure SMMU content. <ul style="list-style-type: none"><li>• Omit this option to view the non-secure table entries or registers</li><li>• Include this option to view the secure table entries or registers</li></ul> <i>Only applicable for MMU-600 and newer.</i>                     |

Format: **SMMU.ADD "<name>" <smmu\_type> <base\_address>**

<smmu\_type>: **MMU400 | MMU401 | MMU500 | MMU600**

Defines a new SMMU (a hardware system MMU). A maximum of 20 SMMUs can be defined.

**NOTE:** For some CPUs with SMMUs, TRACE32 will automatically configure the SMMU parameters, so that you can immediately work with the SMMUs and do not need to manually configure them.  
After selecting the CPU type, check one of the following locations in TRACE32 to see if there are any pre-configured SMMUs:

- The **CPU** menu > **SMMU** popup menu
- The **SYStem.CONFIG.state /CComponents** window

#### Arguments:

|             |                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <name>      | User-defined name of an SMMU. The name must be unique and can be max. 9 characters long.<br><br><b>NOTE:</b> <ul style="list-style-type: none"><li>• For the <b>SMMU.ADD</b> command, the name must be quoted.</li><li>• For <i>all other SMMU</i> commands, omit the quotation marks from the name identifying an SMMU. See also PRACTICE script example below.</li></ul> |
| <smmu_type> | Defines the type of the Arm system MMU IP block: <ul style="list-style-type: none"><li>• SMMUv2 based: <b>MMU400</b>, <b>MMU401</b> or <b>MMU500</b></li><li>• SMMUv3 based: <b>MMU600</b></li></ul>                                                                                                                                                                       |

|                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <p>&lt;base_address&gt;</p> | <p>Logical or physical base address of the memory-mapped SMMU register space.</p> <p><b>NOTE for MMU400, MMU401, MMU500:</b></p> <p>If the SMMU supports two security states (secure and non-secure), not all SMMU registers are visible from the non-secure domain.</p> <ul style="list-style-type: none"> <li>• If you specify a <b>secure</b> address as the SMMU base address, you will see the secure view of the SMMU.</li> <li>• If you specify a <b>non-secure</b> address as the SMMU base address, you will only see the non-secure SMMU view. Secure SMMU registers will not be visible.</li> </ul> <p>To specify a <b>secure</b> address, precede the base address with an <a href="#">access class</a> such as AZSD: or ZSD:</p> <p>Always specify either a secure or a non-secure base address so that the SMMU security view is clearly determined.</p> <p>When executing command <b>SMMU.ADD</b>, an access class with ambiguous security status will be augmented to either secure or non-secure, according to the current CPU security status and a warning message will be printed.</p> <p>Access classes with a distinct security status will be left unchanged, e.g. the access classes NSD:, NUD:, HD: etc.</p> <p><b>NOTE for MMU600 and newer:</b></p> <p>if CPU supports two security states, always specify the SMMU base address as a secure address (e.g. ZSD: or AZSD:) so that TRACE32 can access both the secure and non-secure SMMU registers.</p> |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### Example:

```
;define a new SMMU named "myGPU" for a graphics processing unit
SMMU.ADD "myGPU" MMU600 AZSD:0x50000000

;display the stream table of the SMMU named "myGPU"
SMMU.StreamTable myGPU
```

Format: **SMMU.Clear <name>**

Deletes an SMMU definition, which was created with the **SMMU.ADD** command of TRACE32. The **SMMU.Clear** command does not affect your target SMMU.

To delete all SMMU definitions created with the **SMMU.ADD** command of TRACE32, use **SMMU.RESet**.

**Argument:**

|        |                                                           |
|--------|-----------------------------------------------------------|
| <name> | For a description of <name>, click <a href="#">here</a> . |
|--------|-----------------------------------------------------------|

**Example:**

|                                                 |
|-------------------------------------------------|
| SMMU.Clear myGPU ; deletes the SMMU named myGPU |
|-------------------------------------------------|

## SMMU.CtxtDescTable

## List a context descriptor table

MMU-600 and newer only

Format: **SMMU.CtxtDescTable <args>**

<args> : **<name> <stream\_id> [<substream\_id> | <range>] [/SECure]**

Opens a window and lists all valid stage 1 **Context Descriptors** in the **Context Descriptor Table** of the **Stream Table Entry** specified by <stream\_id>. Specify option **/SECure** to select the secure SMMU view. A description of the columns is given in [this](#) table. The status line of the window shows the **global error flags** which are currently set for the SMMU.

If you want to limit the **Substream IDs** displayed in the window, you can specify a numeric <substream\_id> as lower limit for the displayed SubstreamIDs. Alternatively, you can specify a range as <substream\_id> to set a lower and an upper limit to the displayed Substream IDs.

| substream | ASID   | S1  | PT   | fmt | state | ttbo/1 | address of context descriptor table entries |
|-----------|--------|-----|------|-----|-------|--------|---------------------------------------------|
| 00000188  | 0x7A1F | AAr | ch64 |     | on    | / on   | AZSD:00000002005E62C0                       |
| 00000761  | 0xADFC | AAr | ch64 |     | on    | / on   | AZSD:00000002005FD840                       |
| 000007D8  | 0xB85D | AAr | ch32 |     | on    | / on   | AZSD:00000002005FF600                       |
| 000009CC  | 0xE172 | AAr | ch32 |     | on    | / on   | AZSD:0000000200607300                       |
| 00000E29  | 0xCAE0 | AAr | ch64 |     | on    | / on   | AZSD:0000000200618A40                       |
| 00001029  | 0xDC22 | AAr | ch32 |     | on    | / on   | AZSD:0000000200620A40                       |
| 000011D3  | 0x12C0 | AAr | ch64 |     | on    | / on   | AZSD:00000002006274C0                       |
| 00001650  | 0xF845 | AAr | ch32 |     | on    | / on   | AZSD:0000000200639400                       |
| 000017CC  | 0x8A69 | AAr | ch64 |     | on    | / on   | AZSD:000000020063F300                       |

## Examples:

```
;define a new SMMU named "myGPU" for a graphics processing unit
SMMU.ADD "myGPU" MMU600 AZSD:0x50000000

;list the context descriptors of the stream table with Stream ID 0x6B9743
;of the SMMU named "myGPU"
SMMU.CtxtDescTable myGPU 0x6B9743

;same as above, but limit the listing to Substream IDs >= 0x1000
SMMU.CtxtDescTable myGPU 0x6B9743 0x1000

;list the context descriptors of the stream table with secure Stream ID
0x1D73D281 of the SMMU named "myGPU". List only Substream ID in the range
0x1000--0x1FFF
SMMU.CtxtDescTable myGPU 0x1D73D281 0x1000--0x1FFF /SECure
```

## SMMU.DumpQueue.<queue>

## Dump entries of a queue

MMU-600 and newer only

Using the **SMMU.DumpQueue** command group, you can dump entries of SMMU [Queues](#). Analyzing entries of the Event Queue is important to find error conditions of SMMU streams - in addition to [global error flags of the SMMU](#).

### SMMU.DumpQueue.CMD

Dump entries of the Cmd Queue

### SMMU.DumpQueue.Event

Dump entries of the Event Queue

The commands **SMMU.DumpQueue.CMD** and **SMMU.DumpQueue.Event** open a window which shows all valid entries of the queue in the sequence of their creation.



## Description of Columns and Status Line

The dump queue windows displays the following columns:

| Column                            | Description                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>index</b>                      | Index of the entry. Entries are dumped in the sequence of their creation. The oldest entry always carries index 0 in the dump window. This is the entry pointed to by the queue's Consumer Index register. The newest entry has the largest index in the dump window. This is the entry pointed to by the queue's Producer Index register. |
| <b>entry type</b>                 | Decoded type of the queue entry.                                                                                                                                                                                                                                                                                                           |
| <b>secure</b><br>(CMD queue only) | Indicates the state of the SSec bit in the queue entry. If secure is 1, the entry targets the secure SMMU view, otherwise the non-secure view.                                                                                                                                                                                             |
| <b>streamID</b>                   | Shows the content of the entry's <a href="#">Stream ID</a> field. Blank if the entry has no Stream ID field.                                                                                                                                                                                                                               |
| <b>substr.ID</b>                  | Shows the content of the entry's <a href="#">Substream ID</a> field. Blank if the entry has no Substream ID field.<br>For the CMD queue, UNKNOWN is displayed if the entry has a Substream ID field but the entry's SSV (SubStream Valid) bit is 0.                                                                                        |
| <b>additional qualifiers</b>      | Depending on the event type, additional event record fields such as addresses and flags are decoded and printed in this column.<br>Note: it is not supported to filter entries by additional qualifier fields.                                                                                                                             |
| <b>address of entry</b>           | Displays the physical address of the queue table entry record.                                                                                                                                                                                                                                                                             |

The status line of the window shows the following information:

- the number of entries the queue can hold, i.e. its size
- the number of valid entries it holds currently
- the current producer index
- the current consumer index
- if the queue is full, a message "Queue is FULL" is displayed.

**NOTE:**

Use the popup menu to quickly open [SMMU.StreamTable](#) or [SMMU.CtxtDescrTable](#) window. This conveniently allows to view the Stream Table Entry or Context Descriptor associated with the queue entry underneath the mouse pointer.

## Filter options

As queues can hold a very large number of entries, command **SMMU.DumpQueue.<queue>** offers filter options allowing dump only entries satisfying certain criteria. The following filter options are available:

| Filter option                                            | Description                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>/QETYPE &lt;qe_type&gt;</b>                           | Dump only queue entries with <a href="#">entry type &lt;qe_type&gt;</a><br>The values allowed for <qe_type> are specific to the queue type and the SMMU type.                                                                                                                                                                                                                                           |
| <b>/StreamID &lt;stream_id&gt;   &lt;range&gt;</b>       | Dump only entries with a certain <a href="#">Stream ID</a> .<br><stream_id> can either be a single numeric value or a numeric range. If it is a range, only those queue entries will be dumped if their Stream ID field falls into the specified range.                                                                                                                                                 |
| <b>/SubStreamID &lt;substream_id&gt;   &lt;range&gt;</b> | Dump only entries with a certain <a href="#">Substream ID</a> .<br><substream_id> can either be a single numeric value or a numeric range. If it is a range, only those queue entries will be dumped if their Substream ID field falls into the specified range.<br>In event queue, entries where the SSV (SubStream Valid) bit is 0 are not dumped at all if the <b>/SubStreamID</b> filter is active. |

Note that for sake of Stream ID and/or Substream ID filtering, TRACE32 evaluates the event record fields StreamID, SubStreamID and SSV regardless of the queue entry type.

## SMMU.DumpQueue.CMD

## Dump cmd queue entries

MMU-600 and newer only

Format: **SMMU.DumpQueue.CMD <name> [<entry\_idx> | <range>] [/SECure] [<filter\_opts>]**

<entry\_idx> | <range> Starts the dump with <entry\_index> or dumps only entries with index in <range>

<filter\_opts>: **[/QETYPE <qe\_type>] [/StreamID <stream\_id>] [/SubStreamID <substream\_id>]**

Opens the **SMMU.DumpQueue** window and dumps all valid entries of the non-secure or the secure Cmd [Queue](#). See [SMMU.DumpQueue](#) for a description of the dump queue window.

MMU-600 and newer only

Format: **SMMU.DumpQueue.Event** <name> [<entry\_idx> | <range>] [/SECure] [<filter\_opts>]

<entry\_idx> | <range> Starts the dump with <entry\_index> or dumps only entries with index in <range>

<filter\_opts>: [/QETYPE <qe\_type>] [/StreamID <stream\_id>] [/SubstreamID <substream\_id>]

Opens the **SMMU.DumpQueue** window and dumps all valid entries of the non-secure or the secure Event Queue. See **SMMU.DumpQueue** for a description of the dump queue window.

**Examples:**

```
;define a new SMMU named "myGPU" for a graphics processing unit
SMMU.ADD "myGPU" MMU600 AZSD:0x50000000

;open the event queue dump window for the non-secure SMMU view and dump
;all entries
SMMU.DumpQueue.Event myGPU

;open the queue dump window for the secure SMMU view and dump all entries
;starting with index 0x200
SMMU.DumpQueue.Event myGPU 0x200 /SECure

;dump only entries of type F_TRANSLATION
SMMU.DumpQueue.Event myGPU /QETYPE F_TRANSLATION

;dump only entries where the Stream ID field is in the range 0x5000--
;0x5FFF
SMMU.DumpQueue.Event myGPU /StreamID 0x5000--0x5FFF

;dump only entries where the Stream ID field is 0x6BE900 and the
;SubStream ID field is in the range 0x140--0x17F
SMMU.DumpQueue.Event myGPU /StreamID 0x6BE900 /SubStreamID 0x140--0x17F
```

Using the **SMMU.Register** command group, you can view and modify the peripheral registers of an SMMU. The command group provides the following commands:

|                                       |                                                                                                                                   |
|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| <b>SMMU.Register.Global</b>           | Display the global registers of an SMMU                                                                                           |
| <b>SMMU.Register.ContextBank</b>      | Display the registers of a context bank<br><i>MMU-400, MMU-401 and MMU-500 only.</i>                                              |
| <b>SMMU.Register.StreamMapRegGrp</b>  | Display the registers of an SMRG<br><i>MMU-400, MMU-401 and MMU-500 only.</i>                                                     |
| <b>SMMU.Register.StreamTableEntry</b> | Display the registers of a Stream Table Entry.<br><i>MMU-600 and newer only.</i>                                                  |
| <b>SMMU.Register.Stage1Context</b>    | Display the registers of a Context Descriptor Table Entry (the stage 1 context of a substream).<br><i>MMU-600 and newer only.</i> |

**Example:**

```
;open the SMMU.Register.StreamMapRegGrp window of SMMU "myGPU" and show
;the registers of Stream Table Entry with Stream ID 0x02010A
SMMU.Register.StreamTableEntry myGPU 0x02010A

;highlight changes in orange in any SMMU.Register.* window
SETUP.Var %SpotLight.on
```

MMU-400, MMU-401 and MMU-500 only

Format: **SMMU.Register.ContextBank <name> <cbndx>**

Opens the peripheral register window **SMMU.Register.ContextBank**. This window displays the registers of the specified context bank. These are listed under the section heading **Context Bank Registers**.



**A** Register name and content.

**B** Names of the register bit fields and bit field values.

**NOTE:**

The commands **SMMU.Register.ContextBank** and **SMMU.StreamMapRegGrp.ContextReg** are similar.

The difference between the two commands is:

- The first command expects a *<cbndx>* as an argument and allows to view an arbitrary context bank.
- The second command expects an *<smrg\_index>* with an optional **IntermediatePT** as arguments and displays either a stage 1 or stage 2 context bank associated with the *<smrg\_index>*.

**Argument:**

|        |                                                                 |
|--------|-----------------------------------------------------------------|
| <name> | For a description of <name>, etc., click <a href="#">here</a> . |
|--------|-----------------------------------------------------------------|

**Example:**

```
SMMU.Register.ContextBank myGPU 0x16
```

Format: **SMMU.Register.Global <name>**

Opens the peripheral register window **SMMU.Register.Global**. This window displays the global registers of the specified SMMU. These are listed under the section heading **Global Configuration Registers**.



**A** Register name and content.

**B** Names of the register bit fields and bit field values.

**Argument:**

|        |                                                           |
|--------|-----------------------------------------------------------|
| <name> | For a description of <name>, click <a href="#">here</a> . |
|--------|-----------------------------------------------------------|

**Example:**

```
SMMU.Register.Global myGPU
```

To display the global registers of an SMMU via the user interface TRACE32 PowerView:

- In the **SMMU.StreamTable** window, right-click an SMRG, and then select **Peripherals > Global Configuration Registers** from the popup menu.

MMU-600 and newer only

Format: **SMMU.Register.MMUregs <name>**

Opens the peripheral register window and shows the MMU specific register blocks which are not part of the SMMU architectural registers. Examples for MMU specific registers are registers for the SMMU Translation Control Unit (TCU), Translation Buffer Unit (TBU) and Performance Measurement Unit (PMU) described in the Arm MMU-600 specification.

MMU-600 and newer only

Format: **SMMU.Register.S1Context <args>**

<args>: **<name> <stream\_id> [/SubstreamID <substream\_id>] [/SECure]**

Opens the peripheral register window for the SMMU named <name> and displays the registers of a stage 1 [Context Descriptor](#) specified by <stream\_id> and <substream\_id>.

If the [Stream Table Entry](#) specified by <stream\_id> has only one Context Descriptor, you can omit option **/SubstreamID <substream\_id>**. In this case, the Context Descriptor with Substream ID 0 will be displayed.

Specify option **/SECure** to select the secure SMMU view.

MMU-600 and newer only

Format: **SMMU.Register.StreamTblEntry <args>**

<args> : **<name> <stream\_id> [/SECure]**

Opens the peripheral register window for the SMMU named <name> and displays the registers of the [Stream Table Entry](#) which is specified by <stream\_id>.

Specify option **/SECure** to select the secure SMMU view.

### Example:

```
;define a new SMMU named "myGPU" for a graphics processing unit
SMMU.ADD "myGPU" MMU600 AZSD:0x50000000

;list the Stream Table Entry with Stream ID 0x6B9743 from the secure
Stream Table of SMMU "myGPU"
SMMU.StreamTable myGPU 0x6B9743 /SECure
```

MMU-400, MMU-401 and MMU-500 only

Format: **SMMU.Register.StreamMapRegGrp <args>**  
**SMMU.StreamMapRegGrp.Register <args>** (as an alias)

<args>: *<name> <smrg\_index>*

Opens the peripheral register window **SMMU.Register.StreamMapRegGrp**. This window displays the registers of the specified SMRG. These are listed under the gray section heading **Stream Map Register Group**.



**A** 0x0D is the *<smrg\_index>* of the selected SMRG.

**B** Register name and content.

**C** Names of the register bit fields and bit field values.

Compare also to [SMMU.StreamMapRegGrp.ContextReg](#).

**Arguments:**

|                     |                                                                               |
|---------------------|-------------------------------------------------------------------------------|
| <i>&lt;name&gt;</i> | For a description of <i>&lt;name&gt;</i> , etc., click <a href="#">here</a> . |
|---------------------|-------------------------------------------------------------------------------|

**Example:**

```
SMMU.StreamMapRegGrp.Register      myGPU      0x06
```

## To view the registers of an SMRG via the user interface TRACE32 PowerView:

- In the **SMMU.StreamTable** window, right-click an SMRG, and then select **Peripherals > Stream Mapping Registers** from the popup menu.



## SMMU.RESet

Delete all SMMU definitions

Format: **SMMU.RESet**

Deletes all SMMU definitions created with **SMMU.ADD** from TRACE32. The **SMMU.RESet** command does not affect your target SMMU.

To delete an individual SMMU created with **SMMU.ADD**, use **SMMU.Clear**.

MMU-400, MMU-401 and MMU-500 only

Format: **SMMU.SSDtable <name> [<start\_index>]**

Displays the security state determination table (SSD table) as a bit field consisting of **s** (secure) or **ns** (non-secure) entries. If the SMMU has no SSD table defined, you receive an error message in the **AREA** window.

The screenshot shows two windows. The top window is titled 'B::SMMU.SSDtable myGPU 0x000B'. It has a table with columns for 'SSD\_index' (00 to 0F) and 'raw\_data'. A black arrow labeled 'A' points to the cell at index 0x0020, which contains '68'. A context menu is open over this cell with the options 'Security State Determination Table' and 'Dump Memory Here'. The bottom window is titled 'B::Data.dump AZSD:0x50004004 /Dialog /Byte /NoAscii'. It shows a hex dump of memory starting at address 0x50004004, with the byte at address 0x50004004 highlighted in red and labeled 'C'. A red arrow points from the 'raw\_data' cell in the SSD table to this byte in the dump.

**A** In the SSD table, the black arrow indicates the *<start\_index>*, here 0x00B

**B** Right-click to dump the SSD table raw data in memory.

For each SSD index of an incoming memory transaction stream, the SSD table indicates whether the outgoing memory transaction stream accesses the secure (**s**) or non-secure (**ns**) memory domain.

You may find the SSD table easier to interpret by reducing the width of the **SMMU.SSDtable** window. Example for the raw data 0x68 in the SSD table:

The screenshot shows the SMMU.SSDtable window with the raw data 0x68 at index 0x0020 highlighted. To the right, the raw data is shown as a bit field:  $0y \ 0 \ 1 \ 1 \ 0 \ | \ 1 \ 0 \ 0 \ 0$ . A legend indicates that 0=s and 1=ns. The 's' bits are 0, 1, 1, 0, and the 'ns' bits are 1, 0, 0, 0.

**C** In the **Data.dump** window, the black arrow indicates the dumped raw data from the SSD table.

**D** The 1st white column (00 to 07) relates to the 1st **raw data** column.

The 2nd white column (08 to 0F) relates to the 2nd **raw data** column, etc.

## Arguments:

|               |                                                                                                                                    |
|---------------|------------------------------------------------------------------------------------------------------------------------------------|
| <name>        | For a description of <name>, click <a href="#">here</a> .                                                                          |
| <start_index> | Starts the display of the SSD table at the specified SSD index.<br>See <b>SSD index</b> column in the <b>SMMU.SSDtable</b> window. |

## Example:

```
;display the SSD table starting at the SSD index 0x000B
SMMU.SSDtable    myGPU    0x000B
```

## To view the SSD table via the user interface TRACE32 PowerView:

- In the **SMMU.StreamTable** window, right-click any SMRG, and then select **Security State Determination Table (SSD)** from the popup menu.

**NOTE:** The menu item is grayed out if the SMMU does not support the two security states **s** (secure) or **ns** (non-secure).

## SMMU.StreamMapRegGrp

## Access to stream map table entries

MMU-400, MMU-401 and MMU-500 only

The **SMMU.StreamMapRegGrp** command group allows to view the details of the translation context associated with stage 1 and/or stage 2 of an SMRG. Every SMRG is identified by its [\*<smrg\\_index>\*](#).

The **SMMU.StreamMapRegGrp** command group provides the following commands:

### **SMMU.StreamMapRegGrp.ContextReg**

Shows the registers of the context bank associated with the stage 1 and/or stage 2 translation.

### **SMMU.StreamMapRegGrp.Dump**

Dumps the page table associated with the stage 1 and/or stage 2 translation page wise.

### **SMMU.StreamMapRegGrp.list**

Lists the page table entries associated with the stage 1 and/or stage 2 translation in a compact format.

MMU-400, MMU-401 and MMU-500 only

Format: **SMMU.StreamMapRegGrp.ContextReg** <args>

&lt;args&gt;: &lt;name&gt; &lt;smrg\_index&gt; [/IntermediatePT]

Opens the peripheral register window **SMMU.StreamMapRegGrp.ContextReg**, displaying the context bank registers of stage 1 or stage 2 of the specified <smrg\_index> [A]. The context bank index (cbndx) of the shown context bank registers is printed in the gray section heading **Context Bank Registers** [C].

The **cbndx** columns in the **SMMU.StreamTable** window tell you which context bank is associated with stage 1 or stage 2: If there is no context bank defined for stage 1 or stage 2, then the respective **cbndx** cell is empty. In this case, the peripheral register window **SMMU.StreamMapRegGrp.ContextReg** does not open.



**A** 0x0A is the <smrg\_index> of the selected SMRG.

**B** The option **IntermediatePT** is used to display the context bank registers of stage 2.

**C** 0x15 is the index from the **cbndx** column of a stage 2 context bank. See [example](#) below.

Compare also to [SMMU.StreamMapRegGrp.Register](#).

#### NOTE:

The commands [SMMU.Register.ContextBank](#) and [SMMU.StreamMapRegGrp.ContextReg](#) are similar.

The difference between the two commands is:

- The first command expects a <cbndx> as an argument and allows to view an arbitrary context bank.
- The second command expects an <smrg\_index> with an optional **IntermediatePT** as arguments and displays either a stage 1 or stage 2 context bank associated with the <smrg\_index>.

#### Arguments:

|        |                                                                 |
|--------|-----------------------------------------------------------------|
| <name> | For a description of <name>, etc., click <a href="#">here</a> . |
|--------|-----------------------------------------------------------------|

## PRACTICE Script Example and Illustration of the Context Bank Look-up:

```
SMMU.StreamMapRegGrp.ContextReg myGPU 0x06 /IntermediatePT
```

The screenshot shows the TRACE32 PowerView interface with two windows. The top window is titled 'B::SMMU.StreamMapRegGrp.ContextReg myGPU 0x06 /IntermediatePT' and displays 'Context Bank Attribute Registers' for 'SMMU\_CBARn' (00000000), 'IRPTNDX' (00000000), and 'TYPE' (Stage2 - txt). The bottom window is titled 'B::SMMU.StreamTable myGPU' and shows a table of stream mapping entries. A red box highlights the row for entry 0x06, which has a 'ref. id' of 0x0244, a 'stream mapping' of 0x7000, and a 'context type' of 's1 trsl - s2 trsl'. A red arrow points from the 'ContextReg myGPU 0x06 /IntermediatePT' part of the script to this row in the table.

| stream map      | reg.grp       | stream mapping | ref. id    | is mask | valid | context type                   | stage 1        | pagetbl1.   | fmt         | cbndx | state     | stage 2        | pagetbl1.   | fmt         | cbndx     | state |
|-----------------|---------------|----------------|------------|---------|-------|--------------------------------|----------------|-------------|-------------|-------|-----------|----------------|-------------|-------------|-----------|-------|
| sec/nsec        | 0x00          | 0x0EE1         | 0x7000     | yes     |       | s1 trsl - s2 trsl              | AArch64        | Long        | 0x00        |       | on        | AArch32        | Long        | 0x01        | on        |       |
| sec/nsec        | 0x01          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| sec/nsec        | 0x02          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| sec/nsec        | 0x03          | 0x0DBE         | 0x7000     | yes     |       | s1 trsl - s2 bypass            | AArch32        | Shrt        | 0x06        | F     | on        | AArch32        | Long        | 0x09        | on        |       |
| sec/nsec        | 0x04          | 0x0B78         | 0x7000     | yes     |       | s1 trsl - s2 trsl              | AArch32        | Long        | 0x08        | on    |           | AArch32        | Long        | 0x09        | on        |       |
| sec/nsec        | 0x05          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| <b>sec/nsec</b> |               |                |            |         |       |                                |                |             |             |       |           |                |             |             |           |       |
| <b>0x06</b>     | <b>0x0244</b> | <b>0x7000</b>  | <b>yes</b> |         |       | <b>s1 trsl - s2 trsl</b>       | <b>AArch32</b> | <b>Long</b> | <b>0x0C</b> |       | <b>on</b> | <b>AArch32</b> | <b>Long</b> | <b>0x0D</b> | <b>on</b> |       |
| sec/nsec        | 0x07          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| sec/nsec        | 0x08          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| sec/nsec        | 0x09          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| sec/nsec        | 0x0A          | 0x0000         | 0x0000     | no      |       | fault                          |                |             |             |       |           |                |             |             |           |       |
| sec/nsec        | 0x0B          | 0x036D         | 0x7000     | yes     |       | s1 trsl - s2 bypass            | AArch64        | Long        | 0x16        |       | on        | SMCF           |             |             |           |       |
|                 |               |                |            |         |       | MMU-500 base AZSD:0x5000000000 |                |             |             |       |           |                |             |             |           |       |
|                 |               |                |            |         |       |                                | PF             |             |             |       |           |                |             |             |           |       |

To display the context bank registers via the user interface TRACE32 PowerView:

- In the **SMMU.StreamTable** window, right-click an SMRG, and then select **Peripherals > Context Bank Registers of Stage 1 or 2** from the popup menu.

MMU-400, MMU-401 and MMU-500 only

Format: **SMMU.StreamMapRegGrp.Dump <args>**<args>: **<name> <smrg\_index> [<address> | <range> [<ttb\_address>]] [/<option>]**

Opens the **SMMU.StreamMapRegGrp.Dump** window for the specified SMRG, displaying the page table entries of the SMRG page wise. If no valid translation context is defined, the window displays the error message “register undefined”.



**A** To view the details of the page table walk, scroll to the right-most column of the window.  
For a description of the columns in the **SMMU.StreamMapRegGrp.Dump** window, click [here](#).

#### Arguments:

|                       |                                                                                                                                                                                                                        |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <name>                | For a description of <name>, etc., click <a href="#">here</a> .                                                                                                                                                        |
| <address> / <range>   | If specified, start the dump with <address> or, alternatively, limit the dumped address range to address to <range>.                                                                                                   |
| <ttb_address>         | If specified, <ttb_address> will be used as page table base address. The other page table parameters are still extracted from the SMRG context.                                                                        |
| <b>IntermediatePT</b> | Omit this option to view translation table entries of stage 1.<br>Include this option to view translation table entries of stage 2.<br><br>In SMMUs that support only stage 2 page tables, this option can be omitted. |

#### Example:

```
SMMU.StreamMapRegGrp.Dump myGPU 0x0C
```

#### To display an SMMU page table page-wise via the user interface TRACE32 PowerView:

- In the **SMMU.StreamTable** window, right-click an SMRG, and then select from the popup menu:
  - **Stage 1 Page Table > Dump** or
  - **Stage 2 Page Table > Dump**

## Description of Columns

This table describes the columns of the following windows:

- [SMMU.StreamMapRegGrp.list / SMMU.StreamTblEntry.list](#)
- [SMMU.StreamMapRegGrp.Dump / SMMU.StreamTblEntry.Dump](#)



The screenshot shows a Windows-style application window titled 'B::SMMU.StreamMapRegGrp.Dump myGPU 0x0C 0x76784000'. The window contains a table with the following columns: logical, physical, sec, d, size, and permissions. The data in the table is as follows:

| logical                                | physical                               | sec | d | size     | permissions                 |
|----------------------------------------|----------------------------------------|-----|---|----------|-----------------------------|
| C:00000000076784000--00000000076784FFF | I:00000000033A55000--00000000033A55FFF | ns  |   | 00001000 | P:readwrite U:noaccess exec |
| C:00000000076785000--00000000076785FFF | I:00000000033A56000--00000000033A56FFF | ns  |   | 00001000 | P:readwrite U:noaccess exec |
| C:00000000076786000--00000000076786FFF |                                        |     |   |          |                             |
| C:00000000076787000--00000000076787FFF |                                        |     |   |          |                             |
| C:00000000076788000--00000000076788FFF |                                        |     |   |          |                             |
| C:00000000076789000--00000000076789FFF |                                        |     |   |          |                             |
| C:0000000007678A000--0000000007678AFFF |                                        |     |   |          |                             |

| Column             | Description                                                                                                                                                                                                                                                                             |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>logical</b>     | Logical page address range                                                                                                                                                                                                                                                              |
| <b>physical</b>    | Physical page address range                                                                                                                                                                                                                                                             |
| <b>sec</b>         | Security state of entry (s=secure, ns=non-secure, sns=non-secure entry in secure page table)                                                                                                                                                                                            |
| <b>d</b>           | Domain                                                                                                                                                                                                                                                                                  |
| <b>size</b>        | Size of mapped page in bytes                                                                                                                                                                                                                                                            |
| <b>permissions</b> | Access permissions (P=privileged, U=unprivileged, exec=execution allowed)                                                                                                                                                                                                               |
| <b>glb</b>         | Global page                                                                                                                                                                                                                                                                             |
| <b>shr</b>         | Shareability (no=non-shareable, yes=shareable, inn=inner shareable, out=outer shareable)                                                                                                                                                                                                |
| <b>pageflags</b>   | Memory attributes (see <a href="#">Description of the memory attributes</a> .)                                                                                                                                                                                                          |
| <b>tablewalk</b>   | Only for <a href="#">SMMU.StreamMapRegGrp.Dump</a> : <ul style="list-style-type: none"><li>• Details of table walk for logical page address (one sub column for each table level, showing the table base address, entry index, entry width in bytes and value of table entry)</li></ul> |

MMU-400, MMU-401 and MMU-500 only

Format: **SMMU.StreamMapRegGrp.list <args>**<args>: **<name> <smrg\_index> [<address> | <range> [<ttb\_address>]] [/IntermediatePT]**

Opens the **SMMU.StreamMapRegGrp.list** window for the specified SMMU, listing the page table entries of a stream map group. If no valid translation context is defined, the window displays an error message.



| address                                | d        | size                   | permissions | g1b | shr | pageflags (remapped)    |
|----------------------------------------|----------|------------------------|-------------|-----|-----|-------------------------|
| C:0000000000000000--0000000076783FFF   | 00001000 | P:readwrite U:noaccess | exec        | yes | no  | I:w-thru/wa 0:reserved  |
| C:000000000767840000--0000000076785FFF | 00001000 | P:readwrite U:noaccess | exec        | yes | no  | I:w-thru/rwa 0:reserved |
| C:000000000767860000--0000000076805FFF | 00001000 | P:readwrite U:noaccess | exec        | yes | no  | I:w-thru/rwa 0:reserved |
| C:000000000768060000--0000000076807FFF | 00001000 | P:readwrite U:noaccess | exec        | yes | no  | I:w-thru/rwa 0:reserved |
| C:000000000768080000--FFFF19886CC91FFF | 00001000 | P:readwrite U:noaccess | exec        | yes | no  | I:w-thru/ra 0:reserved  |
| FFFF19886CC92000--FFFF19886CC93FFF     |          |                        |             |     |     | !!!                     |

For a description of the columns in the **SMMU.StreamMapRegGrp.list** window, click [here](#).

**Arguments:**

|                     |                                                                                                                                                                                                                        |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <name>              | For a description of <name>, etc., click <a href="#">here</a> .                                                                                                                                                        |
| <address> / <range> | If specified, start the page table list with <address> or, alternatively, limit the listed address range to address to <range>.                                                                                        |
| <ttb_address>       | If specified, <ttb_address> will be used as page table base address. The other page table parameters are still extracted from the SMRG context.                                                                        |
| IntermediatePT      | Omit this option to view translation table entries of stage 1.<br>Include this option to view translation table entries of stage 2.<br><br>In SMMUs that support only stage 2 page tables, this option can be omitted. |

**Example:**

```
SMMU.StreamMapRegGrp.list myGPU 0x0C
```

**To list the page table entries via the user interface TRACE32 PowerView:**

- In the [SMMU.StreamTable](#) window, right-click an SMRG, and then select from the popup menu:
  - **Stage 1 Page Table > List** or
  - **Stage 2 Page Table > List**

Format: **SMMU.StreamTable <args>**

**SMMU.StreamMapTable <args> (as an alias)**

<args>: **<name> [/StreamID <value>]**

(for MMU-400, MMU-401 and MMU-500)

**<name> [<stream\_id>] [/SECure]**

(for MMU-600 and newer)

Opens the **SMMU.StreamTable** window for the SMMU that has the specified *<name>*. The content and popup menu depends on the SMMU type for which the **SMMU.StreamTable** window is opened. The two variants of the window are described as follows:

#### MMU-400, MMU-401, MMU-500:

The window lists all **Stream Map Register Groups** of the secure or non-secure view of the SMMU. The window provides an overview of the secure or non-secure SMMU configuration.

The screenshot shows the SMMU.StreamTable window for an MMU-500. The window title is "B:SMMU.StreamTable myGPU /StreamID 0x3224A". The table lists Stream Map Register Groups. A context menu is open over the table, with "Stage 1 Page Table" and "Stage 2 Page Table" highlighted. The status bar at the bottom shows "MMU-500 base AZSD:0x50000000".

A The gray window status bar displays the *<smmu\_type>* and the SMMU *<base\_address>*. In addition, the window status bar informs you of **global faults** in the SMMU, if there are any faults.

## MMU-600 and newer:

The window lists all valid **Stream Table Entries** of either the secure or the non-secure view of the SMMU. The security status of the view can be changed using option **/SECure** or, alternatively, using the **Show secure entries** checkbox in the window header.

The **Stream ID** range displayed can be limited if argument `<stream_id>` is used. You can either specify a number as start value or a range.



**A** The gray window status bar displays the `<smmu_type>` and the SMMU `<base_address>`.  
In addition, the window status bar informs you of **global faults** in the SMMU, if there are any faults.

**B** For **STEs** with more than one substream, click the button **list CDT** to view the substreams.

## Arguments

|                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <code>&lt;name&gt;</code>                                                         | For a description of <code>&lt;name&gt;</code> , click <a href="#">here</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| <b>StreamID</b> <code>&lt;value&gt;</code><br>(MMU-400, MMU-401 and MMU-500 only) | <p>Only available for SMMUs that support stream ID matching. The <b>StreamID</b> option highlights all SMRGs in <b>yellow</b> that match the specified stream ID <code>&lt;value&gt;</code>. SMRGs highlighted in yellow help you identify incorrect settings of the stream matching registers.</p> <p>For <code>&lt;value&gt;</code>, specify the stream ID of an incoming memory transaction stream.</p> <ul style="list-style-type: none"><li>The highlighted SMRG indicates which stream map table entry will be used to translate the incoming memory transaction stream.</li><li>More than one highlighted row indicates a potential, global SMMU fault called stream match conflict fault.</li></ul> <p>The stream ID matching algorithm of TRACE32 mimics the SMMU stream matching on the real hardware.</p> <p>The reference ID, mask and validity fields of the stream match register are listed in the <b>ref. id</b>, <b>id mask</b> and <b>valid</b> columns.</p> |
| <code>&lt;stream_id&gt;</code><br>(MMU-600 and newer only)                        | Either the start point (if a single number is given) or numeric range (if a numeric range is given) of Stream IDs that are displayed in the window.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### MMU-400, MMU-401, MMU-500:

This PRACTICE script example shows how to define an SMMU with the **SMMU.ADD** command. Then the script opens the SMMU in the **SMMU.StreamTable** window, searches for the <stream\_id> 0x324A and highlights the matching SMRG 0x024A in yellow.

```
;define a new SMMU named "myGPU" for a graphics processing unit
SMMU.ADD "myGPU" MMU500 AZSD:0x50000000

;open the window and highlight the matching SMRG in yellow
SMMU.StreamTable myGPU /StreamID 0x324A
```

| stream map | reg.grp | stream | matching | ref. id | id mask | valid | context           | type |
|------------|---------|--------|----------|---------|---------|-------|-------------------|------|
| sec/nsec   | 0x04    |        |          | 0x0B78  | 0x7000  | yes   | s1 trsl - s2 trsl |      |
| sec/nsec   | 0x06    |        |          | 0x024A  | 0x7000  | yes   | fault             |      |
| sec/nsec   | 0x08    |        |          | 0x0000  | 0x0000  | no    | fault             |      |
| sec/nsec   | 0x09    |        |          | 0x0000  | 0x0000  | no    | fault             |      |
| sec/nsec   | 0x0A    |        |          | 0x0000  | 0x0000  | no    | fault             |      |

#### NOTE:

At first glance, the **Stream ID** 0x324A does not seem to match the SMRG 0x024A.

However, if you take the ID mask 0x7000 (= 0y0111\_0000\_0000\_0000) into account, the match is correct.

The row highlighted in yellow in the **SMMU.StreamTable** window is a correct match for the **Stream ID** 0x324A we searched for.

See also function **SMMU.StreamID2SMRG()** in “**General Function Reference**” (general\_func.pdf).

### MMU-600 and newer:

This PRACTICE script example shows how to define an SMMU with the **SMMU.ADD** command. Then the script opens the SMMU in the **SMMU.StreamTable** window starting with Stream ID 0x10000

```
;define a new SMMU named "myGPU" for a graphics processing unit
SMMU.ADD "myGPU" MMU600 AZSD:0x50000000

;open the Stream Table window, showing entries starting with
;Stream ID 0x10000
SMMU.StreamTable myGPU 0x10000
```

By right-clicking an entry or double-clicking certain cells of an entry, you can open additional windows to receive more information about the selected entry.

- Right-clicking opens the [Popup Menu](#).

### MMU-400, MMU-401, MMU-500:

- Double-clicking an entry in the columns **ref. id**, **id mask**, **valid**, or **context type** opens the [SMMU.StreamMapRegGrp.Register](#) window.
- Double-clicking an SMRG in the two columns **pagetbl. fmt** opens the [SMMU.StreamMapRegGrp.list](#) window, displaying the page table for stage 1 or stage 2.
- Double-clicking an SMRG in the two **cbndx** columns or the two **state** columns opens the [SMMU.StreamMapRegGrp.ContextReg](#) window, displaying the context bank registers for stage 1 or stage 2.

### MMU-600 and newer:

- Double-clicking an entry in the columns **configuration**, **VMID**, **stream world**, or **# sstrms** opens the [SMMU.StreamTblEntry.Register](#) window showing the stream entry registers.
- Double-clicking an entry in the column **S2 PT fmt** opens the [SMMU.StreamTblEntry.list](#) window, displaying the stage 2 page table.

If an entry has only one stage 1 context descriptor:

- Double-clicking valid data in columns **ASID** or **state ttb0/1** opens the [SMMU.Register.S1Context](#) window, displaying the stage 1 context registers.
- Double-clicking valid data in column **S1 PT fmt** opens the [SMMU.StreamTblEntry.list](#) window, displaying the stage 1 page table.

If an entry has more than one stage 1 context descriptor:

- Click on the list CDT button in column **S1 PT fmt** to open the [SMMU.CtxtDescTable](#) window, listing all valid Context Descriptors for the stream entry. The [SMMU.CtxtDescTable](#) window allows to view the registers and stage 1 page tables associated with each Context Descriptor.



**A** Example popup menu for MMU-400, MMU-401 and MMU-500

**B** Example popup menu for MMU-600 and newer

The entries visible in the popup menus depend on the capabilities of the SMMU such as the capability to support stage 1 or stage 2 and if the SMMU supports two security states.

The popup menu in the **SMMU.StreamTable** window provides convenient shortcuts to the following commands:

#### MMU-400, MMU-401 and MMU-500:

| Popup Menu                                                                                                                                                                                                | Command                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stage 1 Page Table ><br>Stage 2 Page Table >                                                                                                                                                              | (--)                                                                                                                                                                                                   |
| <ul style="list-style-type: none"> <li>• List</li> <li>• Dump</li> </ul>                                                                                                                                  | <ul style="list-style-type: none"> <li>• <a href="#">SMMU.StreamMapRegGrp.list</a></li> <li>• <a href="#">SMMU.StreamMapRegGrp.Dump</a></li> </ul>                                                     |
| Peripherals >                                                                                                                                                                                             | (--)                                                                                                                                                                                                   |
| <ul style="list-style-type: none"> <li>• Global Configuration Registers</li> <li>• Stream Mapping Registers</li> <li>• Context Bank Registers of Stage 1 and Context Bank Registers of Stage 2</li> </ul> | <ul style="list-style-type: none"> <li>• <a href="#">SMMU.Register.Global</a></li> <li>• <a href="#">SMMU.Register.StreamMapRegGrp</a></li> <li>• <a href="#">SMMU.Register.ContextBank</a></li> </ul> |
| Security State Determination Table (SSD)                                                                                                                                                                  | <a href="#">SMMU.SSDtable</a>                                                                                                                                                                          |

MMU-600 and newer:

| Popup Menu                                                                                                                                                                                                   | Command                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Stage 1 Context Descriptor Table                                                                                                                                                                             | <a href="#">SMMU.CtxtDescTable</a>                                                                                                                                                                                                               |
| Stage 1 Page Table ><br>Stage 2 Page Table >                                                                                                                                                                 | (--)                                                                                                                                                                                                                                             |
| <ul style="list-style-type: none"> <li>• List</li> <li>• Dump</li> </ul>                                                                                                                                     | <ul style="list-style-type: none"> <li>• <a href="#">SMMU.StreamTblEntry.list</a></li> <li>• <a href="#">SMMU.StreamTblEntry.Dump</a></li> </ul>                                                                                                 |
| Peripherals >                                                                                                                                                                                                | (--)                                                                                                                                                                                                                                             |
| <ul style="list-style-type: none"> <li>• Global Configuration Registers</li> <li>• MMU specific Registers</li> <li>• Stream Table Entry Registers</li> <li>• Stage 1 Context Descriptor Registers</li> </ul> | <ul style="list-style-type: none"> <li>• <a href="#">SMMU.Register.Global</a></li> <li>• <a href="#">SMMU.Register.MMU</a></li> <li>• <a href="#">SMMU.Register.StreamTblEntry</a></li> <li>• <a href="#">SMMU.Register.S1Context</a></li> </ul> |
| Dump Queue ><br>Dump associated Queue Entries >                                                                                                                                                              | (--)                                                                                                                                                                                                                                             |
| <ul style="list-style-type: none"> <li>• Event Queue</li> <li>• Cmd Queue</li> </ul>                                                                                                                         | <ul style="list-style-type: none"> <li>• <a href="#">SMMU.DumpQueue.Event</a></li> <li>• <a href="#">SMMU.DumpQueue.CMD</a></li> </ul>                                                                                                           |

## MMU-400, MMU-401 and MMU-500:

| Column Name                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>stream map reg. grp</b>                                       | <ul style="list-style-type: none"> <li><b>visibility:</b> The column is only visible if the SMMU supports the two security states <i>secure</i> and <i>non-secure</i>.<br/>The label <b>sec/nsec</b> indicates that the SMRG is visible to secure and non-secure accesses.<br/>The label <b>sec only</b> indicates that the SMRG is visible to secure accesses only.</li> <li><b>index:</b> The index numbers start at <b>0x00</b> and are incremented by 1 per SMRG.</li> </ul> |
| <b>stream matching</b>                                           | See description of the columns <b>ref. id</b> , <b>id mask</b> , and <b>valid</b> below.                                                                                                                                                                                                                                                                                                                                                                                         |
| <b>ref. id</b> ,<br><b>id mask</b> ,<br>and <b>valid</b>         | If the SMMU supports <i>stream matching</i> , then the following columns are visible: <b>ref. id</b> , <b>id mask</b> , and <b>valid</b> . Otherwise, these columns are hidden.                                                                                                                                                                                                                                                                                                  |
| <b>context type</b>                                              | Depending on the translation context of a stream mapping register group, the following values are displayed [Description of Values]: <ul style="list-style-type: none"> <li>s2 translation only</li> <li>s1 trsl - s2 trsl</li> <li>s1 trsl - s2 fault</li> <li>s1 trsl - s2 bypass</li> <li>fault (s1 trsl-s2 trsl)</li> <li>fault (s1 trsl-s2 flt)</li> <li>fault (s1 trsl-s2 bypass)</li> <li>fault</li> <li>bypass mode</li> <li>reserved</li> <li>HYPC or MONC</li> </ul>   |
| <b>stage 1 pagetbl. fmt</b><br>or<br><b>stage 2 pagetbl. fmt</b> | Displays the page table format of <b>stage 1</b> or <b>stage 2</b> [Description of Values]: <ul style="list-style-type: none"> <li>Short descr. (32-bit Arm architecture only)</li> <li>Long descr. (32-bit Arm architecture only)</li> <li>AArch32 Short (64-bit Arm architecture only)</li> <li>AArch32 Long (64-bit Arm architecture only)</li> <li>AArch64 Long (64-bit Arm architecture only)</li> </ul>                                                                    |
| <b>cbndx</b>                                                     | Displays the context bank index (cbndx) associated with the translation context of <b>stage 1</b> or <b>stage 2</b> .                                                                                                                                                                                                                                                                                                                                                            |

| Column Name  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>state</b> | <p>Displays whether the MMU of <b>stage 1</b> or <b>stage 2</b> is enabled (ON) or disabled (OFF) and whether a fault has occurred in a translation context bank:</p> <ul style="list-style-type: none"> <li>• <b>F</b>: any single fault</li> <li>• <b>M</b>: multiple faults</li> <li>• <b>S</b>: the SMMU is stalled</li> </ul> <p>The letters F, M, and S are highlighted in red in the <b>SMMU.StreamTable</b> window (<a href="#">example</a>).</p> <p>The information about the faults is derived from the register SMMU_CBn_FSR (fault status register of the context bank).</p> <p>Double-click the respective <b>state</b> cell to open the <b>SMMU.StreamMapRegGrp.ContextReg</b> window. The register SMMU_CBn_FSR provides details about the fault.</p> |

#### MMU-600 and newer:

| Column Name                           | Description                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>configuration</b>                  | <p>Depending on the translation context of a stream entry, the following values are displayed [<a href="#">Description of Values</a>]:</p> <ul style="list-style-type: none"> <li>• s1 translation only</li> <li>• s2 translation only</li> <li>• s1 trsl - s2 trsl</li> <li>• bypass</li> <li>• abort</li> </ul> <p>A misconfiguration of the stream entry is indicated by a display of ILLEGAL.</p> |
| <b>S2 PT fmt<br/>or<br/>S1 PT fmt</b> | <p>Displays the page table format of <b>stage 2</b> or <b>stage 1</b>:</p> <ul style="list-style-type: none"> <li>• AArch32</li> <li>• AArch64</li> </ul>                                                                                                                                                                                                                                             |
| <b>VMID</b>                           | Displays the VMID of the stream table entry stage 2 registers                                                                                                                                                                                                                                                                                                                                         |
| <b>stream world</b>                   | <p>Depending of the stream world of a stream entry, the following values are displayed:</p> <ul style="list-style-type: none"> <li>• NS-EL1</li> <li>• EL2</li> <li>• EL2-E2H</li> <li>• EL3</li> <li>• Secure</li> <li>• Reserved</li> </ul>                                                                                                                                                         |
| <b># sstrms</b>                       | Displays the max. number of stage 1 context descriptors for the stream table entry, as configured in the S1CDMAX field                                                                                                                                                                                                                                                                                |
| <b>ASID</b>                           | Displays the ASID of a stage 1 context descriptor                                                                                                                                                                                                                                                                                                                                                     |

| Column Name                                                                                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>S1 PT fmt</b>                                                                              | <p>If only a single context descriptor entry exists in the CDT associated with the stream table entry, its stage 1 page table format is displayed (AArch32 or AArch64).</p> <p>If the CDT contains more than one entry, a button labelled <i>list CDT</i> is displayed which directly opens the CDT.</p>                                                                                                                                                                                                                                                  |
| <b>state ttb0/1</b>                                                                           | <p>Displays the state of the stage 1 context <b>tt0</b> / <b>tt1</b> translation table disable bits, where</p> <p><b>tt0</b> refers to the address translation of the lower address range.</p> <p><b>tt1</b> refers to the address translation of the upper address range.</p> <p>Possible values for: <b>tt0</b> / <b>tt1</b></p> <ul style="list-style-type: none"> <li>• <b>on</b> means the translation for the tt0 / tt1 address range is enabled</li> <li>• <b>off</b> means the translation for the tt0 / tt1 address range is disabled</li> </ul> |
| <b>address of stream table entries<br/>or<br/>address of context descriptor table entries</b> | <p>Displays table walk details, i.e. the physical addresses of the level 1 and/or level 2 table entries.</p> <p>If the table has only one level, one address is displayed, for a 2-level table two addresses are displayed.</p>                                                                                                                                                                                                                                                                                                                           |

**MMU-400, MMU-401 and MMU-500:**

| Values in the Column<br>“context type” | Description                                                                                                                 |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| <b>s2 translation only</b>             | Context defines a stage 2 translation only                                                                                  |
| <b>s1 trsl - s2 trsl</b>               | Context defines a stage 1 translation, followed by a stage 2 translation (nested translation)                               |
| <b>s1 trsl - s2 fault</b>              | Context defines a stage 1 translation followed by a stage 2 fault                                                           |
| <b>s1 trsl - s2 bypass</b>             | Context defines a stage 1 translation followed by a stage 2 bypass                                                          |
| <b>fault (s1 trsl-s2 trsl)</b>         | Context defines a stage 1 translation followed by a stage 2 translation, but SMMU has no stage 1 (SMMU configuration fault) |
| <b>fault (s1 trsl-s2 fit)</b>          | Context defines a stage 1 translation followed by a stage 2 fault, but SMMU has no stage 1 (SMMU configuration fault)       |
| <b>fault (s1 trsl-s2 bypass)</b>       | Context defines a stage 1 translation followed by a stage 2 bypass, but SMMU has no stage 1 (SMMU configuration fault)      |
| <b>fault</b>                           | Context defines a fault                                                                                                     |
| <b>bypass mode</b>                     | Context defines bypass mode                                                                                                 |
| <b>reserved</b>                        | Context type is improperly defined                                                                                          |
| <b>HYPC</b>                            | Is displayed on the right-hand side of the column if the context is a hypervisor context.                                   |
| <b>MONC</b>                            | Is displayed on the right-hand side of the column if the context is a monitor context.                                      |

| Values in the Columns<br>“stage 1 pagetbl. fmt”<br>“stage 2 pagetbl. fmt” | Description                                                                    |
|---------------------------------------------------------------------------|--------------------------------------------------------------------------------|
| <b>Short descr.</b>                                                       | Page table uses the 32-bit short descriptor format (32-bit targets only)       |
| <b>Long descr.</b>                                                        | Page table uses the 32-bit long descriptor (LPAE) format (32-bit targets only) |
| <b>AArch32 Short</b>                                                      | Page table uses the 32-bit short descriptor format (64-bit targets only)       |
| <b>AArch32 Long</b>                                                       | Page table uses the 32-bit long descriptor (LPAE) format (64-bit targets only) |
| <b>AArch64 Long</b>                                                       | Page table uses the 64-bit long descriptor (LPAE) format (64-bit targets only) |

**MMU-600 and newer:**

| Values in the Column<br>“configuration” | Description                                                                                                     |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| <b>s1 translation only</b>              | Context defines a stage 1 translation only                                                                      |
| <b>s2 translation only</b>              | Context defines a stage 2 translation only                                                                      |
| <b>s1 trsl - s2 trsl</b>                | Context defines a stage 1 translation, followed by a stage 2 translation                                        |
| <b>bypass</b>                           | Context defines bypass mode, no translation is performed.                                                       |
| <b>abort</b>                            | Context defines an abort condition.                                                                             |
| <b>ILLEGAL (s1 trsl only)</b>           | Misconfiguration of the stream table entry:<br>stage 1 translation is configured but not supported              |
| <b>ILLEGAL (s2 trsl only)</b>           | Misconfiguration of the stream table entry:<br>stage 2 translation is configured but not supported              |
| <b>ILLEGAL (s1 + s2 trsl)</b>           | Misconfiguration of the stream table entry:<br>stage 1+2 translations are configured but not supported          |
| <b>ILLEGAL (secure+s2 trsl)</b>         | Misconfiguration of the stream table entry:<br>stage 2 translation is configured in a secure stream table entry |

Codes in the gray window status bar at the bottom of the **SMMU.StreamTable** window indicate the current global fault / global error status of the SMMU:

## MMU-400, MMU-401, MMU-500:

These codes for the global faults are MULTI, UUT, PF, EF, CAF, UCIF, UCBF, SMCF, USF, ICF [A]. These flags correspond to the flags of the SMMU\_sGFSR register.

To view the descriptions of the global faults, double-click the gray window status bar to open the **SMMU.Register.Global** window [A]. Scroll down to the SMMU\_sGFSR [B] or the SMMU\_GERROR register. The global faults are described in the column on the right [C].

The image shows two windows side-by-side. The top window is 'B::SMMU.StreamTable myGPU', a table showing stream mapping and fault status. The bottom window is 'B::SMMU.Register.Global myGPU', showing the SMMU\_sGFSR register and its fault descriptions. A red arrow labeled 'A' points to the status bar of the StreamTable window, which displays fault codes: MULTI, UUT, PF, EF, CAF, UCIF, UCBF, SMCF, USF, and ICF. A red arrow labeled 'B' points to the SMMU\_sGFSR row in the Register window. A red box labeled 'C' highlights the fault descriptions column in the Register window, which lists the meanings of the fault codes.

| stream   | map  | reg.grp | visibility | index | stream | matching | ref_id | id | mask | valid | context | type | stage 1 | pagetbl | fmt  | cbndx | state   | stage 2 | pagetbl | fmt  | cbndx | state |
|----------|------|---------|------------|-------|--------|----------|--------|----|------|-------|---------|------|---------|---------|------|-------|---------|---------|---------|------|-------|-------|
| sec/nsec | 0x00 | 0x0EE1  | 0x7000     | yes   |        | s1       | trs1   | -  | s2   | trs1  |         |      | AArch64 | Long    | 0x00 | on    | AArch64 | Long    | 0x01    | on   |       |       |
| sec/nsec | 0x01 | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x02 | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x03 | 0x0DBE  | 0x7000     | yes   |        | s1       | trs1   | -  | s2   | byp   |         |      | AArch32 | Shrt    | 0x06 | F     | on      | AArch32 | Long    | 0x09 | on    |       |
| sec/nsec | 0x04 | 0x0B78  | 0x7000     | yes   |        | s1       | trs1   | -  | s2   | trs1  |         |      | AArch32 | Long    | 0x08 | on    |         |         |         |      |       |       |
| sec/nsec | 0x05 | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x06 | 0x024A  | 0x7000     | yes   |        | s1       | trs1   | -  | s2   | trs1  |         |      | AArch32 | Long    | 0x0C | on    | AArch32 | Long    | 0x0D    | on   |       |       |
| sec/nsec | 0x07 | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x08 | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x09 | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x0A | 0x0000  | 0x0000     | no    |        |          |        |    |      |       |         |      |         |         |      |       |         |         |         |      |       |       |
| sec/nsec | 0x0B | 0x036D  | 0x7000     | yes   |        | s1       | trs1   | -  | s2   | byp   |         |      | AArch64 | Long    | 0x16 | on    |         |         |         |      |       |       |

MMU-500 base AZSD:0x5000

B::SMMU.Register.Global myGPU

| Register    | Value            | Major | Minor |
|-------------|------------------|-------|-------|
| SMMU_IDR7   | 00000000         | MAJOR | 0     |
| SMMU_sG FAR | 0000000000000000 |       |       |
| SMMU_sGFSR  | 800001FF         | MINOR | 0     |

**C**

|       |                                                 |
|-------|-------------------------------------------------|
| MULTI | Multiple faults occurred                        |
| UUT   | Unsupported upstream transaction fault recorded |
| PF    | Permission fault                                |
| EF    | External fault caused by an external abort      |
| CAF   | Configuration access fault                      |
| UCIF  | Unimplemented context interrupt fault           |
| UCBF  | Unimplemented context bank fault                |
| SMCF  | Stream match conflict fault                     |
| USF   | Unidentified stream fault                       |
| ICF   | Invalid context fault                           |

- A** Codes of global faults (for MMU-500 in this screen shot).
- B** The information about the global faults is derived from the register SMMU\_sGFSR (secure global fault status register).
- C** Descriptions of the global faults in the **SMMU.Register.Global** window.

## MMU-600 and newer:

These codes for the global errors are SFM, MSI\_GERROR, MSI\_PRIQ, MSI\_EVENTQ, MSI\_CMDQ, PRIQ, EVENTQ, CMDQ [A].

These flags correspond to the flags of the SMMU\_GERROR register.



| B::SMMU.Register.Global myPCIE |                  |   |                              |                              |                                            |                              |
|--------------------------------|------------------|---|------------------------------|------------------------------|--------------------------------------------|------------------------------|
| SMMU_GERROR                    | 000001FD         | C | SMM_ERR<br>MSI_PRIQ_ABRT_ERR | Occurred<br>Occurred         | MSI_GERROR_ABRT_ERR<br>MST_EVENTQ_ABRT_ERR | Occurred<br>Occurred         |
| SMMU_GERRORN                   | 00000000         |   | PRIQ_ABRT_ERR                | Occurred                     | EVENTQ_ABRT_ERR                            | Occurred                     |
|                                |                  |   | SMM_ERR<br>MSI_PRIQ_ABRT_ERR | Not occurred<br>Not occurred | MSI_GERROR_ABRT_ERR<br>MSI_EVENTQ_ABRT_ERR | Not occurred<br>Not occurred |
|                                |                  |   | PRIQ_ABRT_ERR                | Not occurred                 | EVENTQ_ABRT_ERR                            | Not occurred                 |
| .GERROR_IIRQ_CFG0              | 0000000000000000 |   | ADDR                         | 0000000000000000             |                                            |                              |
| .GERROR_IIRQ_CFG1              | 00000000         |   |                              |                              |                                            |                              |

- A** Codes of global error flags (for MMU-600 in this screen shot).
- B** The information about the global error flags set is derived from an XOR operation for the registers SMMU\_GERROR and SMMU\_GERRORN.
- C** Descriptions of the global error flags in the **SMMU.Register.Global** window.

## Finding streams which are in a fault / error state

## **MMU-400, MMU-401 and MMU-500:**

A red letter in a **stage 1 cbndx state** column or a **stage 2 state** column of the **SMMU.StreamTable** window indicates a fault in a context bank. For descriptions of these faults, see **state** column.

### MMU-600 and newer:

Use the Event Queue Window **SMMU.DumpQueue.Event** to view error events.

The command supplies options to filter and view events for a certain *<stream\_id>* and/or *<substream\_id>* range and it is possible to filter certain event types.

In **SMMU.StreamTable** or **SMMU.CtxtDescTable** window, use the popup menu entry **Dump associated Queue Entries** to dump queue entries for specific stream entry or context descriptor table entry.

## SMMU.StreamTblEntry

### Access to a stream table entry

---

MMU-600 and newer only

The **SMMU.StreamTblEntry** command group allows to view the details of the translation context associated with a [Stream Table Entry](#) and/or a stage 1 [Context Descriptor](#). Every STE is identified by its *<stream\_id>*. A CD is identified by both a *<stream\_id>* and a *<substream\_id>*. In case a stream table entry supports only a single stage 1 CD the *<substream\_id>* can be omitted.

The **SMMU.StreamTblEntry** command group provides the following commands:

|                                     |                                                                                          |
|-------------------------------------|------------------------------------------------------------------------------------------|
| <b>SMMU.StreamTblEntry.Register</b> | Shows the registers of a STE or a CD.                                                    |
| <b>SMMU.StreamTblEntry.list</b>     | Lists the page table associated with stage 1 or stage 2 translation in a compact format. |
| <b>SMMU.StreamTblEntry.Dump</b>     | Dumps the page table entries associated with stage 1 or stage 2 translation page wise.   |

The three SMMU.StreamTblEntry commands feature common options:

- **/SUBstream** *<substream\_id>*: apply the command for a CD with the *<substream\_id>*
- **/SECure**: target the secure SMMU entries with the command

MMU-600 and newer only

|         |                                                                                                                                                               |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format: | <b>SMMU.StreamTableEntry.Dump &lt;args&gt;</b>                                                                                                                |
| <args>: | <b>&lt;name&gt; &lt;stream_id&gt; [&lt;address&gt;   &lt;range&gt; [&lt;ttb_address&gt;]] [/SubStreamID &lt;substream_id&gt;] [/IntermediatePT] [/SECure]</b> |

Opens the **SMMU.StreamTblEntry.Dump** window for the specified *<stream\_id>*. This window dumps the page table content page-wise. If you prefer a compact view, use command [SMMU.StreamTblEntry.list](#)

If option **/SECure** is specified, the command targets the secure SMMU view.

You can dump any stage 1 or the stage 2 page table associated with the **STE** specified by *<stream\_id>*.

To dump the stage 2 page table of the STE, specify only option **/IntermediatePT**.

To dump the stage 1 page table defined by a **Context Descriptor** of the STE, you must additionally specify the **Substream ID** of the Context Descriptor using option **/SubStreamID <substream\_id>**.

If no valid translation context is defined, the window displays the error message “register undefined”.

For a description of the columns in the **SMMU.StreamTableEntry.Dump** window, click [here](#).

#### Arguments:

|                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>&lt;name&gt;</i>                          | For a description of <i>&lt;name&gt;</i> , etc., click <a href="#">here</a> .                                                                                                                                                                                                                                                                                                                                                   |
| <i>&lt;stream_id&gt;</i>                     | Defines the STE of which a page table has to be dumped.                                                                                                                                                                                                                                                                                                                                                                         |
| <i>&lt;address&gt;   &lt;range&gt;</i>       | If specified, start the dump with <i>&lt;address&gt;</i> or, alternatively, limit the dumped address range to address to <i>&lt;range&gt;</i> .                                                                                                                                                                                                                                                                                 |
| <i>&lt;ttb_address&gt;</i>                   | If specified, <i>&lt;ttb_address&gt;</i> will be used as page table base address. The other page table parameters are still extracted from the STE and/or CD context.                                                                                                                                                                                                                                                           |
| <b>/SubStreamID<br/>&lt;substream_id&gt;</b> | Omit this option to view translation table entries of stage 2.<br>Include this option to view the stage 1 translation table entries of the Context Descriptor with substream <i>&lt;substream_id&gt;</i> .<br><br>If the STE has only one Context Descriptor, you can omit option <b>/SubStreamID &lt;substream_id&gt;</b> . In this case, the stage 1 page table of the Context Descriptor with substream 0 will be displayed. |
| <b>IntermediatePT</b>                        | Omit this option to view translation table entries of stage 1.<br>Include this option to view translation table entries of stage 2.<br><br>In SMMUs that support only stage 2 page tables, this option can be omitted.                                                                                                                                                                                                          |

## Examples:

```
;Dump the stage 2 page table of the STE with Stream ID 0x6BE974B for SMMU
"myGPU"
SMMU.StreamTblEntry.Dump myGPU 0x6BE974B /IntermediatePE

;Dump the stage 1 page table of Substream ID 0x2 which belongs to the STE
with Stream ID 0x6BE974B.
SMMU.StreamTblEntry.Dump myGPU 0x6BE974B /SubStreamID 0x2

;As above, but start dumping at address 0x80000000
SMMU.StreamTblEntry.Dump myGPU 0x6BE974B 0x80000000 /SubStreamID 0x2
```

To display an SMMU page table page-wise via the user interface **TRACE32 PowerView**, see [here](#).

## SMMU.StreamTblEntry.list

## List page table entries

MMU-600 and newer only

|         |                                                                                                                                                                   |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Format: | <b>SMMU.StreamTableEntry.list&lt;args&gt;</b>                                                                                                                     |
| <args>: | <b>&lt;name&gt; &lt;stream_id&gt; [&lt;address&gt;   &lt;range&gt; [&lt;ttb_address&gt;]] [/SubStreamID<br/>&lt;substream_id&gt;] [/IntermediatePT] [/SECure]</b> |

Opens the **SMMU.StreamTblEntry.list** window for the specified *<stream\_id>*. This window shows a compact list of consecutive address ranges in the page table which have a uniform, valid translation.

The syntax and arguments are identical to command **SMMU.StreamTblEntry.Dump** and are described there.

MMU-600 and newer only

Format: **SMMU.Register.StreamTblEntry <args>**

<args> : **<name> <stream\_id> [/SubStreamID <substream\_id>] [/SECure]**

If specified without option **/SubStreamID <substream\_id>**, this is an alias for command **SMMU.Register.StreamTblEntry**. It opens the peripheral register window for the SMMU named **<name>** and displays the registers of the Stream Table Entry which is specified by **<stream\_id>**.

If specified with option **/SubStreamID <substream\_id>**, this command opens the peripheral register window for the SMMU named **<name>** and displays the registers of the Context Descriptor with substream **<substream\_id>**, belonging to the Stream Table Entry with **<stream\_id>**.

If option **/SECure** is specified, the command targets the secure SMMU view.

## Example:

```
;list the registers of the Stream Table Entry with Stream ID 0x6B9743
from the secure Stream Table of SMMU "myGPU"
SMMU.StreamTable myGPU 0x6B9743 /SECure

;list the registers of the Context Descriptor with Substream ID 0x3,
belonging to the secure Stream Table Entry with Stream ID 0x6B9743
SMMU.StreamTable myGPU 0x6B9743 /SubStreamID 0x3 /SECure
```