# ARM<sup>®</sup> CoreSight<sup>®</sup> ETM-R5

Revision: r0p0

**Technical Reference Manual** 



Copyright © 2010, 2013 ARM. All rights reserved. DDI0469B (ID081513)

### ARM CoreSight ETM-R5 Technical Reference Manual

Copyright © 2010, 2013 ARM. All rights reserved.

#### **Release Information**

The following changes have been made to this book.

|                |       |                  | Change history           |
|----------------|-------|------------------|--------------------------|
| Date           | Issue | Confidentiality  | Change                   |
| 03 August 2010 | А     | Confidential     | First release for r0p0.  |
| 26 July 2013   | В     | Non-Confidential | Second release for r0p0. |

#### **Proprietary Notice**

Words and logos marked with \* or \* are registered trademarks or trademarks of ARM in the EU and other countries, except as otherwise stated below in this proprietary notice. Other brands and names mentioned herein may be the trademarks of their respective owners.

Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder.

The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by ARM in good faith. However, all warranties implied or expressed, including but not limited to implied warranties of merchantability, or fitness for purpose, are excluded.

This document is intended only to assist the reader in the use of the product. ARM shall not be liable for any loss or damage arising from the use of any information in this document, or any error or omission in such information, or any incorrect use of the product.

Where the term ARM is used it means "ARM or any of its subsidiaries as appropriate".

#### **Confidentiality Status**

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by ARM and the party that ARM delivered this document to.

#### **Product Status**

The information in this document is final, that is for a developed product.

#### Web Address

http://www.arm.com

# Contents ARM CoreSight ETM-R5 Technical Reference Manual

| Preface         |    |
|-----------------|----|
| About this book | vi |

-11- - -1

|              | Feedback               | IX   |
|--------------|------------------------|------|
| Chapter 1 In | troduction             |      |
| - 1.         | 1 About the product    | 1-2  |
| 1.:          | 2 Compliance           | 1-4  |
| 1.3          |                        |      |
| 1.4          | 4 Interfaces           | 1-7  |
| 1.           | 5 Configurable options | 1-8  |
| 1.0          | - · ·                  |      |
| 1.1          |                        |      |
| 1.           | 8 Product revisions    | 1-12 |
| Chapter 2 F  | unctional Description  |      |
| • 2.         | •                      |      |
| 2.5          |                        |      |
| 2.3          |                        |      |
| 2.4          | •                      |      |
| 2.           |                        |      |
| Chapter 3 P  | rogrammers Model       |      |
| 3.           | •                      |      |
| 3.           |                        |      |
| 3.3          |                        |      |
| 3.4          | •                      |      |

|            | 3.5    | Register descriptions                                      | 3-16 |
|------------|--------|------------------------------------------------------------|------|
| Appendix A | Signal | Descriptions                                               |      |
|            | A.1    | Signal descriptions                                        | A-2  |
|            | A.2    | Clocks and resets                                          | A-4  |
|            | A.3    | Processor trace interface                                  | A-5  |
|            | A.4    | APB interface                                              | A-6  |
|            | A.5    | ATB interface                                              | A-7  |
|            | A.6    | ETM-R5 macrocell sharing signals                           | A-9  |
|            | A.7    | Test interface                                             | A-10 |
| Appendix B | AC Ch  | aracteristics                                              |      |
|            | B.1    | ETM-R5 macrocell input and output signal timing parameters | B-2  |
| Appendix C | Revisi | ons                                                        |      |

# Preface

This preface introduces the *ARM*<sup>®</sup> *CoreSight*<sup>®</sup> *ETM-R5 Technical Reference Manual*. It contains the following sections:

- *About this book* on page vi.
- *Feedback* on page ix.

### About this book

This book is for the CoreSight *Embedded Trace Macrocell* (ETM) for the Cortex<sup>®</sup>-R5 and Cortex-R5F processors, the CoreSight ETM-R5 macrocell.

You implement the ETM-R5 macrocell with the Cortex-R5 processor or the Cortex-R5F processor. In this manual, in general:

- Reference to the processor applies to the Cortex-R5 processor or the Cortex-R5F processor.
- Reference to the Cortex-R5 processor applies also to the Cortex-R5F processor.

The context makes it clear if information applies to only one of the processor options.

#### **Product revision status**

| The rnpn identifier indicates the revision status of the product described in this book, where: |                                                                      |  |  |
|-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|--|--|
| r <i>n</i>                                                                                      | <b>rn</b> Identifies the major revision of the product.              |  |  |
| р <i>п</i>                                                                                      | Identifies the minor revision or modification status of the product. |  |  |

#### Intended audience

This book is written for:

- Designers of development tools providing support for ETM-R5 macrocell functionality. Implementation-specific behavior is described in this document. You can find complementary information in the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.
- Hardware and software engineers integrating the macrocell into an ASIC that includes a Cortex-R5 processor. You can find complementary information in the ARM<sup>®</sup> CoreSight<sup>™</sup> ETM-R5 Integration Manual.

#### Using this book

This book is organized into the following chapters:

#### **Chapter 1** Introduction

Read this for an introduction to the functionality of the macrocell.

#### **Chapter 2** Functional Description

Read this for a description of the interfaces, operation, clocking and resets of the macrocell.

#### **Chapter 3** Programmers Model

Read this for a description of the programmers model for the macrocell.

#### **Appendix A Signal Descriptions**

Read this for a description of the signals used in the macrocell.

#### **Appendix B** AC Characteristics

Read this for a description of the instruction cycle timing and instruction interlocks.

#### Appendix C Revisions

Read this for a description of the technical changes between released issues of this book.

#### Glossary

The *ARM Glossary* is a list of terms used in ARM documentation, together with definitions for those terms. The *ARM Glossary* does not contain terms that are industry standard unless the ARM meaning differs from the generally accepted meaning.

See ARM Glossary, http://infocenter.arm.com/help/topic/com.arm.doc.aeg0014-/index.html.

#### Conventions

This book uses the conventions that are described in:

- Typographical conventions.
- Signals.

#### **Typographical conventions**

The following table describes the typographical conventions:

#### **Typographical conventions**

| Style             | Purpose                                                                                                                                                                                                          |  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| italic            | Introduces special terminology, denotes cross-references, and citations.                                                                                                                                         |  |
| bold              | Highlights interface elements, such as menu names. Denotes signal names. Also used for terms in descriptive lists, where appropriate.                                                                            |  |
| monospace         | Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.                                                                                                      |  |
| <u>mono</u> space | Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.                                                                          |  |
| monospace italic  | Denotes arguments to monospace text where the argument is to be replaced by a specific value.                                                                                                                    |  |
| monospace bold    | Denotes language keywords when used outside example code.                                                                                                                                                        |  |
| <and></and>       | Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example: MRC p15, 0 <rd>, <crn>, <crm>, <opcode_2></opcode_2></crm></crn></rd>                                  |  |
| SMALL CAPITALS    | Used in body text for a few terms that have specific technical meanings, that are defined in the <i>ARM glossary</i> . For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE. |  |

#### Signals

The signal conventions are:

| Signal level | The level of an asserted signal depends on whether the signal is active-HIGH or active-LOW. Asserted means: |  |
|--------------|-------------------------------------------------------------------------------------------------------------|--|
|              | • HIGH for active-HIGH signals.                                                                             |  |
|              | • LOW for active-LOW signals.                                                                               |  |
| Lowercase n  | At the start or end of a signal name denotes an active-LOW signal.                                          |  |

#### Additional reading

This section lists publications by ARM and by third parties.

See Infocenter, http://infocenter.arm.com, for access to ARM documentation.

#### **ARM** publications

This book contains information that is specific to this product. See the following documents for other relevant information:

- ARM<sup>®</sup> Embedded Trace Macrocell Architecture Specification (ARM IHI 0014).
- ARM<sup>®</sup> CoreSight<sup>™</sup> Components Technical Reference Manual (ARM DDI 0314).
- ARM<sup>®</sup> Cortex<sup>™</sup>-R5 Technical Reference Manual (ARM DDI 0460).
- ARM<sup>®</sup> CoreSight<sup>™</sup> Technology System Design Guide (ARM DGI 0012).
- ARM<sup>®</sup> AMBA<sup>®</sup> APB Protocol Specification v2.0 (ARM IHI 0024).
- ARM<sup>®</sup> AMBA<sup>®</sup> 4 ATB Protocol Specification ATBv1.0 and ATBv1.1 (ARM IHI 0032).

The following confidential books are only available to licensees:

- *ARM<sup>®</sup> CoreSight<sup>™</sup> ETM-R5 Configuration and Sign-off Guide (ARM DII 0262).*
- ARM<sup>®</sup> CoreSight<sup>™</sup> ETM-R5 Integration Manual (ARM DIT 0019).
- *ARM*<sup>®</sup> *CoreSight*<sup>™</sup> *Design Kit for Cortex-R5*<sup>™</sup> *and Cortex-R5F*<sup>™</sup> *Integration Manual* (ARM DIT 0020).
- ARM <sup>®</sup> CoreSight<sup>™</sup> Architecture Specification v2.0 (ARM IHI 0029).

# Feedback

ARM welcomes feedback on this product and its documentation.

#### Feedback on this product

If you have any comments or suggestions about this product, contact your supplier and give:

- The product name.
- The product revision or version.
- An explanation with as much information as you can provide. Include symptoms and diagnostic procedures if appropriate.

#### Feedback on content

If you have comments on content then send an e-mail to errata@arm.com. Give:

- The title.
- The number, DDI0469B.
- The page numbers to which your comments apply.
- A concise explanation of your comments.

ARM also welcomes general suggestions for additions and improvements.

#### \_\_\_\_\_ Note \_\_\_\_\_

ARM tests the PDF only in Adobe Acrobat and Acrobat Reader, and cannot guarantee the quality of the represented document when used with any other PDF reader.

# Chapter 1 Introduction

This chapter introduces the ETM-R5 macrocell. It contains the following sections:

- *About the product* on page 1-2.
- *Compliance* on page 1-4.
- *Features* on page 1-5.
- *Interfaces* on page 1-7.
- *Configurable options* on page 1-8.
- *Test features* on page 1-9.
- *Product documentation, design flow, and architecture* on page 1-10.
- *Product revisions* on page 1-12.

# 1.1 About the product

The ETM-R5 macrocell provides real-time instruction trace and data trace for the Cortex-R5 microprocessor. The ETM-R5 macrocell generates information that trace software tools use to reconstruct the execution of all or part of a program.

For full reconstruction of program execution, the ETM-R5 macrocell is able to trace:

- All instructions, including condition code pass/fail and dual issue information.
- Load/store address and data values.
- Data values used in coprocessor register transfers.
- Values of context-ID changes.
- Target addresses of taken direct and indirect branch operations.
- Exceptions.
- Changes in processor instruction set state.
- Entry to and return from Debug state when Halting Debug-mode is enabled.
- Cycle counts between executed instructions.

The ETM-R5 macrocell contains logic, known as resources, that enables you to control tracing by specifying the exact set of triggering and filtering conditions required for a particular application. Resources include address comparators and data value comparators, counters, and sequencers.

The ETM-R5 macrocell is a CoreSight component, and is an integral part of the ARM Real-time Debug solution, RealView<sup>®</sup>. See the ARM <sup>®</sup> CoreSight<sup>TM</sup> Technology System Design Guide for more information about CoreSight. See the ARM<sup>®</sup> Embedded Trace Macrocell Architecture Specification for more information about the ETM architecture.

#### 1.1.1 The CoreSight debug environment

The ETM-R5 macrocell is designed for use with CoreSight, an extensible, system-wide debug and trace architecture from ARM.

A software debugger provides the user interface to the ETM-R5 macrocell. You can use this interface to:

- Configure ETM-R5 macrocell facilities such as filtering.
- Configure optional trace features such as cycle accurate tracing.
- Configure the other CoreSight components such as the Trace Port Interface Unit (TPIU).
- Access the processor debug and performance monitor units.

A CoreSight system can provide memory-mapped access from the processor to its own debug and trace components.

The ETM-R5 macrocell outputs its trace stream to the AMBA 3 *Advanced Trace Bus* (ATB) interface. The CoreSight infrastructure provides the following options:

- Export the trace information through a trace port. An external *Trace Port Analyzer* (TPA) captures the trace information as Figure 1-1 on page 1-3 shows.
- Write the trace information directly to an on-chip *Embedded Trace Buffer* (ETB). You can read out the trace at low speed using a JTAG or Serial Wire interface when the trace capture is complete as Figure 1-1 on page 1-3 shows.

The debugger extracts the captured trace information from the TPA or ETB and decompresses it to provide full disassembly, with symbols, of the code that was executed. The trace information generated by the ETM-R5 macrocell gives the debugger the capability to link this data back to the original high-level source code, to provide a visualization of how the code was executed on the Cortex-R5 processor.

Figure 1-1 shows how the ETM-R5 macrocell fits into a CoreSight debug environment to provide full trace capabilities in a single processor system. The external debug software configures the trace and debug components through the *Debug Access Port* (DAP). The ROM table contains a unique identification code for the *System on Chip* (SoC) and the base addresses of the components connected to the debug APB. The trace stream from the ETM-R5 macrocell is replicated to provide on-chip storage using the CoreSight ETB or output off-chip using the TPIU. Cross-triggering operates through the *Cross-Trigger Interface* (CTI)s and the cross-trigger matrix.



- Note -

#### Figure 1-1 ETM-R5 macrocell system diagram

In Figure 1-1, the arrows on the thick lines show the transaction direction on busses, from master to slave port. Each bus contains individual signals that go from master to slave and other signals that go from slave to master.

# 1.2 Compliance

ETM-R5 macrocell is compatible with the CoreSight architecture.

ETM-R5 macrocell implements version 3.3 of the ETM architecture, ETMv3.3. See the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification* for more information.

For more information about architectural compliance, see *Architecture and protocol information* on page 1-11.

# 1.3 Features

The ETM-R5 macrocell supports tracing of 32-bit ARM instructions, and 16-bit and 32-bit Thumb instructions.

See the ARM® Embedded Trace Macrocell Architecture Specification for information about:

- The trace protocol.
- The features of ETMv3.3.
- Controlling tracing using triggering and filtering resources.
- ETM sharing.

Table 1-1 lists the features of the ETM-R5 macrocell that are implementation-defined, in terms of either:

- The number of times the feature is implemented.
- The size of the feature.

#### Table 1-1 ETM-R5 macrocell features with implementation-defined number of instances or size

| Feature                               | ETM-R5 macrocell value | Notes                                      |
|---------------------------------------|------------------------|--------------------------------------------|
| Address comparators                   | 4 pairs                | See bits[3:0] of the ETMCCR <sup>a</sup>   |
| Data value comparators                | 2                      | See bits[7:4] of the ETMCCR <sup>a</sup>   |
| EmbeddedICE watchpoint comparators    | Not implemented        | Not supported in ETMv3.3                   |
| Context ID comparators                | 1                      | See bits[25:24] of the ETMCCR <sup>a</sup> |
| Counters                              | 2                      | See bits[15:13] of the ETMCCR <sup>a</sup> |
| Sequencer                             | 1                      | See bit[16] of the ETMCCR. <sup>a</sup>    |
| Memory Map decoder inputs             | Not implemented        | See bits[12:8] of the ETMCCR <sup>a</sup>  |
| External inputs                       | 0-4                    | See bits[19:17] of the ETMCCR <sup>a</sup> |
| External outputs                      | 0-2                    | See bits[22:20] of the ETMCCR <sup>a</sup> |
| Extended external input bus width     | 47                     | See bits[10:3] of the ETMCCER <sup>b</sup> |
| Extended external input selectors     | 2                      | See bits[2:0] of the ETMCCER <sup>b</sup>  |
| Instrumentation resources             | Not implemented        | Not supported in ETMv3.3                   |
| Trace port size                       | 32-bit                 | See bits[21,6:4] of the ETMCR <sup>c</sup> |
| FIFO size                             | 144 bytes              | -                                          |
| ASICCTL general-purpose bus interface | 8-bit                  | See ETMASICCR <sup>d</sup>                 |

a. See Configuration Code Register on page 3-20.

b. See Configuration Code Extension Register on page 3-24.

c. See Main Control Register on page 3-16.

d. See ASIC Control Register on page 3-22

Table 1-2 lists which optional features of the ETM architecture the ETM-R5 macrocell implements.

| Feature                                      | Implemented? | Notes                                                |
|----------------------------------------------|--------------|------------------------------------------------------|
| FIFOFULL control                             | No           | See bit[23] of the ETMCCR <sup>a</sup>               |
| Trace Start/Stop block                       | Yes          | See bit[26] of the ETMCCR <sup>a</sup>               |
| Trace all branches                           | Yes          | See bit[8] of the ETMCR <sup>b</sup>                 |
| Cycle-accurate trace                         | Yes          | See bit[12] of the ETMCR <sup>b</sup>                |
| Data trace options                           |              |                                                      |
| Data address tracing                         | Yes          | See bits[3:2] of the ETMCR <sup>b</sup>              |
| Data value tracing                           | Yes          | See bits[3:2] of the ETMCR <sup>b</sup>              |
| Data-only tracing                            | Yes          | See bit[20] of the ETMCR <sup>b</sup>                |
| CPRT tracing                                 | Yes          | See bits[19, 1] of the ETMCR <sup>b</sup>            |
| Data address comparison                      | Yes          | Bit[12] of the ETMCCER <sup>c</sup> reads-as-zero    |
| EmbeddedICE behavior control                 | No           | Not supported in ETMv3.3                             |
| EmbeddedICE inputs to Trace Start/Stop block | No           | Not supported in ETMv3.3                             |
| Alternative address compression              | No           | Not supported in ETMv3.3                             |
| OS Lock mechanism                            | No           | Not implemented                                      |
| Secure non-invasive debug                    | No           | Cortex-R5 does not implement the Security Extensions |
| Context ID tracing                           | Yes          | See bits[15:14] of the ETMCR <sup>b</sup>            |
| Trace output                                 | Yes          | ATB                                                  |

#### Table 1-2 ETM-R5 macrocell implementation of optional features

a. See Configuration Code Register on page 3-20.

b. See Main Control Register on page 3-16.

c. See Configuration Code Extension Register on page 3-24.

See Appendix A Signal Descriptions for information about the macrocell signals.

# 1.4 Interfaces

The ETM-R5 macrocell has the following main interfaces:

- Processor trace.
- ATB.
- Advanced Peripheral Bus (APB) Debug.
- Test.

Interfaces on page 2-4 describes the ETM-R5 macrocell interfaces in more detail.

# 1.5 Configurable options

The ETM-R5 macrocell includes the following configuration inputs:

- MAXEXTOUT[1:0] determines the maximum number of external outputs.
- MAXEXTIN[2:0] determines the maximum number of external inputs.
- **MAXCORES**[2:0] determines the number of processors that share the ETM.

You can read the MAXEXTOUT and MAXEXTIN values from bits[22:17] of the ETMCCR, see *Configuration Code Register* on page 3-20. You can read the MAXCORES value from bits[14:12] of the ETMSCR. See *System Configuration Register* in the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.

# 1.6 Test features

The ETM-R5 macrocell provides the SE and RSTBYPASS inputs for testing the implemented device.

See also *Integration Test Registers* on page 3-30 for information about the integration test registers, provided for testing the ETM-R5 macrocell implementation in an SoC.

# 1.7 Product documentation, design flow, and architecture

This section describes the CoreSight ETM-R5 macrocell books, how they relate to the design flow, and the relevant architectural standards and protocols.

See *Additional reading* on page viii for more information about the books described in this section.

#### 1.7.1 Documentation

The CoreSight ETM-R5 macrocell documentation is as follows:

#### **Technical Reference Manual**

The *Technical Reference Manual* (TRM) describes the functionality and the effects of functional options on the behavior of the ETM-R5 macrocell. It is required at all stages of the design flow. Some behavior described in the TRM might not be relevant because of the way that the ETM-R5 macrocell is implemented and integrated.

#### **Configuration and Sign-Off Guide**

The *Configuration and Sign-Off Guide* (CSG) describes the processes to test and sign off the implemented design.

The ARM product deliverables include reference scripts and information about using them to implement your design. Reference methodology documentation from your *Electronic Design Automation* (EDA) tools vendor complements the CSG.

The CSG is a confidential book that is only available to licensees.

#### **Integration Manual**

The *Integration Manual* (IM) describes how to integrate the ETM-R5 macrocell into a SoC. It includes a description of the pins that the integrator must tie off, to configure the macrocell for the required integration.

The IM is a confidential book that is only available to licensees.

### 1.7.2 Design flow

The ETM-R5 macrocell is delivered as synthesizable *Register Transfer Level* (RTL) code. Before it can be used in a product, it must go through the following process:

- 1. Implementation. The implementer synthesizes the RTL, then places and routes the netlist to produce a hard macrocell.
- 2. Integration. The integrator instantiates the ETM into a SoC. This also tests its integration with the processor and the other SoC components that it is connected to.
- 3. Programming. The debug software developer programs the ETM and tests any trace software required for use with a SoC.

Each stage of the process:

- Can be performed by a different party.
- Can include options that affect the behavior and features at the next stage:

#### **Build configuration**

The ETM-R5 macrocell has no implementer defined options.

#### **Configuration inputs**

The integrator configures some features of the ETM-R5 macrocell by tying inputs to specific values. These configurations affect the start-up behavior before any software configuration is made. They can also limit the options available to the software.

#### Software configuration

The programmer configures the ETM-R5 macrocell by programming values into software-visible registers. This affects the behavior of the ETM.

See Chapter 3 Programmers Model for information on the ETM-R5 macrocell registers.

— Note ———

References to a feature that is included mean that the appropriate configuration inputs have been selected, while references to an enabled feature mean one that has also been configured by software.

#### 1.7.3 Architecture and protocol information

The ETM-R5 macrocell complies with, or implements, the specifications described in:

- Trace macrocell.
- Advanced Microcontroller Bus Architecture.

This TRM complements architecture reference manuals, architecture specifications, protocol specifications, and relevant external standards. It does not duplicate information from these sources.

#### **Trace macrocell**

The ETM-R5 macrocell implements the ETM architecture version 3.3. See *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.

#### **Advanced Microcontroller Bus Architecture**

This ETM-R5 macrocell complies with the *Advanced Microcontroller Bus Architecture* (AMBA) *Advanced Peripheral Bus* (APB) and *Advanced Trace Bus* (ATB) protocols. See *ARM*<sup>®</sup> *AMBA*<sup>®</sup> *APB Protocol Specification v2.0* and *ARM*<sup>®</sup> *AMBA*<sup>®</sup> *4 ATB Protocol Specification ATBv1.0* and *ATBv1.1*.

# 1.8 Product revisions

This section describes the differences in functionality between product revisions:

r0p0 First release.

There are no technical changes since the first release.

# Chapter 2 Functional Description

This chapter describes the interfaces, operation, clocking and resets of the ETM-R5 macrocell. It contains the following sections:

- *About the functions* on page 2-2.
- *Interfaces* on page 2-4.
- *Clocking and resets* on page 2-6.
- *Operation* on page 2-7.
- Constraints and limitations of use on page 2-10.

# 2.1 About the functions



Figure 2-1 shows the main functional blocks and clock domains of the macrocell.

Figure 2-1 ETM-R5 macrocell block diagram

#### 2.1.1 Processor interface

This block connects to the Cortex-R5 ETM interface. It pipelines the signals from the processor, decodes the control signals and passes on the information to the internal interfaces.

#### 2.1.2 Trace generator

This block generates the trace packets that are a compressed form of the execution information provided by the Cortex-R5 processor trace generation. The trace packets are then passed to the FIFO.

#### 2.1.3 FIFO

This block buffers bursts of trace packets and manages the transfer of them into the ATCLK domain. Up to 23 bytes of trace packet information can be written into the FIFO in one cycle and four bytes can be read out.

#### 2.1.4 Resources

These blocks contain various comparators and state machines that are programmed by trace software to trigger and filter the trace information. They start and stop trace generation, depending on the conditions that have been set.

#### 2.1.5 ATB Interface

This block reads up to four bytes of packet information from the FIFO and sends them over the ATB interface. It is also responsible for the insertion of flush, alignment synchronization and trigger information into the trace stream.

#### 2.1.6 Asynchronous APB interface

This block implements the interface to the APB, that provides access to the programmable registers. It provides address decoding and pipelining of the address and data to and from the APB. The programmable registers reside in the CLK, ATCLK and PCLKDBG clock domains and so this block manages the synchronization of the access from the APB PCLKDBG clock domain to the other two clock domains.

### 2.2 Interfaces

The ETM-R5 macrocell has the following interfaces:

**ATB** A 32-bit wide ATB, used for trace output from the macrocell. Up to four bytes of trace packet information can be transferred over the bus in one clock cycle. This interface has hand shaking signals that indicate when trace data is valid and when the receiving component is ready to accept data. There are also signals to request and acknowledge a flush of the trace information and to indicate when a trigger condition has occurred.

See the *ARM*<sup>®</sup> *AMBA*<sup>®</sup> *4 ATB Protocol Specification ATBv1.0 and ATBv1.1* for more information about this interface.

APB An APB that provides access to the programmable registers in the ETM-R5 macrocell and connects to the system Debug APB. This interface configures the ETM-R5 macrocell for a trace session.

See the *ARM*<sup>®</sup> *AMBA*<sup>®</sup> *APB Protocol Specification v2.0* for more information about this interface.

#### **Processor trace**

The Cortex-R5 passes its execution information to ETM-R5 macrocell over this interface. This interface is divided into two main sections for instruction and data execution information.

The instruction section contains instruction address and control information. The information carried on the control bus includes:

- The number of instructions executed in the same cycle.
- Changes in program flow.
- The current processor instruction state.
- Condition code evaluation.
- Exception information.

The data section contains address, data and control information. The address bus carries the addresses of memory locations accessed by load and store instructions. The data bus is 64-bits wide and carries the data values transferred by load, store and coprocessor register transfer instructions. The information carried by the control bus includes the type, direction and size of a data transfer. There is also a context ID bus that indicates the current context ID value of the processor.

This interface also includes:

- The 55-bit wide Event Bus, **EVNTBUS**[54:0]. See Interaction with the *Performance Monitoring Unit (PMU)* on page 2-9.
- Debug state request/acknowledge signals.
- Wait for interrupt handshaking signals.
- A signal from the ETM to power up the interface.

#### Miscellaneous

The ETM-R5 macrocell has other interface signals that:

- Configure the ETM. See *Configurable options* on page 1-8.
- Input and output external resource information that controls triggering and filtering of the trace stream.
- Control which processor is enabled, as the trace source, on the processor trace interface of the ETM.
- Enable invasive and non-invasive debug.

**Test** This interface contains the scan enable and reset bypass signals used in production testing of the ETM-R5 macrocell.

# 2.3 Clocking and resets

The following sections describe the ETM-R5 macrocell clocks, clock enables and clock resets:

- ETM-R5 macrocell clock signals.
- ETM-R5 macrocell clock enable signals.
- ETM-R5 macrocell resets.

#### 2.3.1 ETM-R5 macrocell clock signals

.

The ETM-R5 macrocell has the following clocks:

| CLK                                               | This is the main clock for the ETM-R5 macrocell and must be the same clock as that wired to the <b>CLKIN</b> input of the Cortex-R5 processor. It can be asynchronous to <b>PCLKDBG</b> and <b>ATCLK</b> .              |  |
|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PCLKDBG                                           | This is the Debug APB interface clock for the ETM-R5 macrocell. It can be asynchronous to CLK. The ARM <sup>®</sup> CoreSight <sup>™</sup> Technology System Design Guide requires PCLKDBG and ATCLK to be synchronous. |  |
| ATCLK                                             | This is the ATB interface clock. It can be asynchronous to CLK. The ARM<br><sup>®</sup> CoreSight <sup><math>\mathbb{T}</math></sup> Technology System Design Guide requires PCLKDBG and ATCLK to be synchronous.       |  |
| Figure 2-1 on page 2-2 shows these clock domains. |                                                                                                                                                                                                                         |  |

\_\_\_\_\_ Note \_\_\_\_\_

Typically, in a SoC, you drive PCLKDBG at half the frequency of ATCLK.

#### 2.3.2 ETM-R5 macrocell clock enable signals

The ETM-R5 macrocell has the following clock enable signals:

| ATCLKEN   | This is the ATB clock enable. It can slow down ATCLK.                           |
|-----------|---------------------------------------------------------------------------------|
| PCLKENDBG | This is the Debug APB interface clock enable. It can slow down <b>PCLKDBG</b> . |

#### 2.3.3 ETM-R5 macrocell resets

The ETM-R5 macrocell has the following resets:

nSYSPORESET This signal is the main powerup reset. It resets all the registers in the ETM-R5 macrocell. It is active-LOW.
 PRESETDBGn This signal is the Debug APB interface reset. It resets all the registers in the ETM-R5 macrocell. It is active-LOW.

# 2.4 Operation

This section describes the implementation-defined features of the operation of the ETM-R5 macrocell. It contains the following sections:

- Implementation-defined registers.
- *Precise TraceEnable events* on page 2-8.
- *Parallel instruction execution* on page 2-8.
- Context ID tracing on page 2-8.
- *Trace and Comparator features* on page 2-8.
- Interaction with the Performance Monitoring Unit (PMU) on page 2-9.
- Other implementation-defined features of the macrocell on page 2-9.

See the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification* for more information about the operation of the ETM-R5 macrocell.

#### 2.4.1 Implementation-defined registers

There are two groups of ETM registers:

- Registers that are completely defined by the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.
- Registers that are at least partly implementation-defined.

Chapter 3 Programmers Model gives more information about the ETM registers, in the sections:

- *Register summary* on page 3-5.
- *Register descriptions* on page 3-16.

In Chapter 3 *Programmers Model*, the following sections describe each of the implementation-defined registers:

- Main Control Register on page 3-16.
- *Configuration Code Register* on page 3-20.
- ASIC Control Register on page 3-22.
- *ID Register* on page 3-23.
- *Configuration Code Register* on page 3-20.
- Extended External Input Selection Register on page 3-25.
- Power-Down Status Register on page 3-26.
- The Integration test registers:
  - Processor-ETM Interface Register on page 3-32.
  - *Miscellaneous Outputs Register* on page 3-34.
  - *Miscellaneous Inputs Register* on page 3-35.
  - Trigger Acknowledge Register on page 3-36.
  - *Trigger Request Register* on page 3-37.
  - ATB Data Register 0 on page 3-38.
  - *ATB Control Register 0* on page 3-41.
  - *ATB Control Register 1* on page 3-40.
  - ATB Control Register 2 on page 3-39.
  - Peripheral Identification Registers on page 3-26.

#### ETM Component Identification Registers on page 3-29.

#### 2.4.2 Precise TraceEnable events

The *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification* states that **TraceEnable** is imprecise under certain conditions, with some implementation-defined exceptions. When the enabling event selects the following resources, it does not cause **TraceEnable** to be imprecise, provided that the resources are themselves precise:

- Single address comparators.
- Address range comparators.

#### 2.4.3 Parallel instruction execution

The Cortex-R5 processor supports parallel instruction execution. This means the macrocell is capable of tracing two instructions per cycle.

Although the trace start/stop block is evaluated for each instruction as required, the macrocell cannot trace one instruction without the other. This means if one instruction is traced, the instruction it is paired with is always traced as well. If **ViewData** is active, any data associated with the paired instruction is also traced.

#### 2.4.4 Context ID tracing

The macrocell detects the MCR instruction that changes the context ID, and traces the appropriate number of bytes as a context ID packet instead of a normal data packet. This means that if context ID tracing is enabled, an MCR instruction that changes the context ID does not have its data traced separately.

#### 2.4.5 Trace and Comparator features

In ETM Architecture v3.3, it is implementation-defined whether an ETM supports a number of Trace and Comparator features. This section specifies the implementation of these features on the CoreSight ETM-R5 macrocell:

- Trace features.
- Comparator features.

#### **Trace features**

The ETM-R5 macrocell implements all of the ETMv3.3 trace features. This means it supports:

- Data value and data address tracing.
- Data suppression.
- Cycle-accurate tracing.

For descriptions of these features see the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.

#### **Comparator features**

The CoreSight ETM-R5 macrocell implements data address comparison. For a description of data address comparison see the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.

#### 2.4.6 Interaction with the Performance Monitoring Unit (PMU)

The Cortex-R5 processor includes a PMU that enables events, such as cache misses and instructions executed, to be counted over a period of time. The macrocell can still use these events by means of the extended external input facility. Each bit in the **EVNTBUS**[54:0] input is mapped to the corresponding extended external input. See the *ARM*<sup>®</sup> *Cortex*<sup>TM</sup>-*R5 Technical Reference Manual* for details of the mapping of events to bits within this bus.

Some events use two bits. Two of these events can occur in a cycle. They must be dealt with separately if they are to be properly counted.

The Cortex-R5 PMU can count the two external outputs as additional events. These events are not provided back to the macrocell as extended external inputs.

These facilities enable additional filtering of the system events using ETM resources, such as instruction address ranges or the start/stop resource, before they are passed back to the PMU for counting. To do this:

- Configure the ETM extended external input selectors to the system events you want to count.
- Configure the required ETM filtering resource as appropriate.
- Configure the ETM external outputs to extended external input selector and the required ETM filtering resource.
- Select the ETM external outputs as the events to be counted in the Cortex-R5 PMU.

#### 2.4.7 Other implementation-defined features of the macrocell

The following implementation-defined features of the macrocell do not affect the descriptions of the features given in the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*:

- Bits[1:0] of the Synchronization Frequency Register are reserved, RAZ, WI.
- Value Not Traced packets are not output in data-only mode. When data address tracing is enabled in the data-only mode, the data transfer trace output can include an address packet. This occurs when the traced data transfer addresses are non-sequential between successive transfers.

# 2.5 Constraints and limitations of use

٠

This section describes the constraints and limitations of use that apply to the ETM-R5 macrocell. It contains the following sections:

- Trace limitations.
  - PortMode and PortSize.

#### 2.5.1 Trace limitations

There are no trace limitations.

#### 2.5.2 PortMode and PortSize

The macrocell only supports a 32-bit port size, and only supports the dynamic port mode.

In the ETMCR, at offset 0x0, from reset:

- The PortSize bits, bits[21, 6:4], take the value b0100, indicating a 32-bit port.
- The PortMode bits, bits[13, 17:16], take the value b000, indicating dynamic port mode.

For more information see Main Control Register on page 3-16.

# Chapter 3 Programmers Model

This chapter describes the programmers model. It contains the following sections:

- *About the programmers model* on page 3-2.
- *Modes of operation and execution* on page 3-3.
- *Memory model* on page 3-4.
- *Register summary* on page 3-5.
- *Register descriptions* on page 3-16.

# 3.1 About the programmers model

This chapter describes the mechanisms for programming the registers that set up the trace and triggering facilities of the macrocell. The programmers model enables you to use the ETM registers to control the macrocell.

The following sections describe the programmers model:

- *Controlling ETM programming* on page 3-3.
- *Programming and reading ETM registers* on page 3-3.
- *Register summary* on page 3-5.
- *Register descriptions* on page 3-16.

# 3.2 Modes of operation and execution

The following sections describes how you control ETM programming.

#### 3.2.1 Controlling ETM programming

When programming the ETM registers you must enable all the changes at the same time. For example, if the counter is reprogrammed, it might start to count based on incorrect events, before the trigger condition has been correctly set up.

You can use the ETM programming bit in the ETMCR to disable all trace operations during programming. See *Main Control Register* on page 3-16. To do this follow the procedure shown in Figure 3-1.



#### Figure 3-1 Programming ETM registers

The processor does not have to be in the debug state while you program the ETM registers.

#### 3.2.2 Programming and reading ETM registers

You program and read the ETM registers using the Debug APB interface. This provides a direct method of programming:

- A stand-alone macrocell.
- A macrocell in a CoreSight system.

# 3.3 Memory model

See the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification* for descriptions of the trace packet formats generated by the ETM-R5 macrocell.

# 3.4 Register summary

This section summarizes the ETM registers. For full descriptions of the ETM registers, see:

- *Register descriptions* on page 3-16, for the implementation-defined registers.
- The ARM<sup>®</sup> Embedded Trace Macrocell Architecture Specification, for the other registers.

Table 3-1 lists all of the registers, and tells you where each register is described in detail. The registers are listed in register number order.

The macrocell registers are listed by functional group in the section *Functional grouping of registers* on page 3-10. The functional group register tables include additional information about each register:

- The register access type. This is read-only, write-only or read/write.
- The clock domain of the register.
- The base offset address of the register. The base address of a register is always four times its register number.
- Additional information about the implementation of the register, where appropriate.

— Note —

- Registers not listed here are not implemented. Reading a non-implemented register address returns 0. Writing to a non-implemented register address has no effect.
- In Table 3-1:
  - The Reset column shows the value of the register immediately after an ETM reset.
    For read-only registers, every read of the register returns this value.
  - The listed Functional group table gives more information about the register, including its clock domain.
  - Access type is described as follows:
    - **RW** Read and write.
    - **RO** Read only.
    - **WO** Write only.

All ETM registers are 32-bits wide.

#### Table 3-1 ETM-R5 macrocell register summary

| Register<br>number | Name        | Туре | Reset                   | Group <sup>a</sup> | Description                                                                                           |
|--------------------|-------------|------|-------------------------|--------------------|-------------------------------------------------------------------------------------------------------|
| 0x000              | ETMCR       | RW   | 0x00000441              | 1                  | Main Control Register on page 3-16                                                                    |
| 0x001              | ETMCCR      | RO   | 0x8D014024 <sup>b</sup> | 1                  | Configuration Code Register on page 3-20                                                              |
| 0x002              | ETMTRIGGER  | RW   | _c                      | 4                  | Trigger Event Register in the ARM <sup>®</sup> Embedded Trace<br>Macrocell Architecture Specification |
| 0x003              | ETMASICCTLR | RW   | 0x00000000              | 1                  | ASIC Control Register on page 3-22                                                                    |
| 0x004              | ETMSR       | RW   | _ c                     | 1                  | ETM Status Register in the ARM <sup>®</sup> Embedded Trace<br>Macrocell Architecture Specification    |
# Table 3-1 ETM-R5 macrocell register summary (continued)

| Register<br>number | Name                  | Туре | Reset                   | Group <sup>a</sup> | Description                                                                                                                                  |
|--------------------|-----------------------|------|-------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0x005              | ETMSCR                | RO   | 0x00020C0C <sup>d</sup> | 1                  | System Configuration Register in the ARM®<br>Embedded Trace Macrocell Architecture<br>Specification                                          |
| 0x006              | ETMTSSCR              | RW   | _c                      | 2                  | TraceEnable Start/Stop Control Register in the ARM®<br>Embedded Trace Macrocell Architecture<br>Specification                                |
| 0x007              | ETMTECR2              | RW   | _c                      | 2                  | TraceEnable Control 2 Register in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                             |
| 0x008              | ETMTEEVR              | RW   | _c                      | 2                  | TraceEnable Event Register in the ARM® Embedded<br>Trace Macrocell Architecture Specification                                                |
| 0x009              | ETMTECR1              | RW   | _c                      | 2                  | <i>TraceEnable Control 1 Register</i> in the <i>ARM</i> <sup>®</sup><br><i>Embedded Trace Macrocell Architecture</i><br><i>Specification</i> |
| 0x00B              | ETMFFLR <sup>e</sup>  | RW   | _c                      | 1                  | FIFOFULL Level Register in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                                       |
| 0x00C              | ETMVDEVR              | RW   | _c                      | 2                  | ViewData Event Register in the ARM® Embedded<br>Trace Macrocell Architecture Specification                                                   |
| 0x00D              | ETMVDCR1              | RW   | _c                      | 2                  | ViewData Control 1 Register in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                                   |
| 0x00F              | ETMVDCR3              | RW   | _c                      | 2                  | ViewData Control 3 Register in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                                   |
| 0x010 to<br>0x017  | ETMACVR1-8            | RW   | _c                      | 3                  | Address Comparator Value Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                         |
| 0x020 to<br>0x027  | ETMACTR1-8            | RW   | _c                      | 3                  | Address Comparator Access Type Registers in the<br>ARM <sup>®</sup> Embedded Trace Macrocell Architecture<br>Specification                   |
| 0x030 <sup>f</sup> | ETMDCVR1 <sup>f</sup> | RW   | _c                      | 3                  | Data Comparator Value Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                            |
| 0x032 <sup>f</sup> | ETMDCVR3 <sup>f</sup> | RW   | _c                      | 3                  | Data Comparator Value Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                            |
| 0x040 <sup>f</sup> | ETMDCMR1 <sup>f</sup> | RW   | _c                      | 3                  | Data Comparator Mask Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                             |
| 0x042 <sup>f</sup> | ETMDCMR3 <sup>f</sup> | RW   | _c                      | 3                  | Data Comparator Mask Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                             |

# Table 3-1 ETM-R5 macrocell register summary (continued)

| Register<br>number | Name            | Туре            | Reset                   | Group <sup>a</sup> | Description                                                                                                                                    |  |
|--------------------|-----------------|-----------------|-------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0x050,<br>0x051    | ETMCNTRLDVR1-2  | RW              | _c                      | 4                  | Counter Reload Value Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                               |  |
| 0x054,<br>0x055    | ETMCNTENR1-2    | RW              | _c                      | 4                  | Counter Enable Registers in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                                        |  |
| 0x058,<br>0x059    | ETMCNTRLDEVR1-2 | RW              | _c                      | 4                  | Counter Reload Event Registers in the ARM®<br>Embedded Trace Macrocell Architecture<br>Specification                                           |  |
| 0x05C,<br>0x05D    | ETMCNTVR1-2     | RW              | _c                      | 4                  | Counter Value Registers in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                                         |  |
| 0x060 to<br>0x065  | ETMSQEVR        | RW              | _c                      | 4                  | Sequencer State Transition Event Registers in the<br>ARM <sup>®</sup> Embedded Trace Macrocell Architecture<br>Specification                   |  |
| 0x067              | ETMSQR          | RW              | _c                      | 4                  | <i>Current Sequencer State Register</i> in the <i>ARM</i> <sup>®</sup><br><i>Embedded Trace Macrocell Architecture</i><br><i>Specification</i> |  |
| 0x068,<br>0x069    | ETMEXTOUTEVR1-2 | RW              | _c                      | 4                  | External Output Event Registers in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                              |  |
| 0x06C              | ETMCIDCVR       | RW              | _c                      | 3                  | Context ID Comparator Value Registers in the ARM®<br>Embedded Trace Macrocell Architecture<br>Specification                                    |  |
| 0x06F              | ETMCIDCMR       | RW              | _c                      | 3                  | Context ID Comparator Mask Register in the ARM®<br>Embedded Trace Macrocell Architecture<br>Specification                                      |  |
| 0x078              | ETMSYNCFR       | RW              | 0x00000400              | 1                  | Synchronization Frequency Register in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification                           |  |
| 0x079              | ETMIDR          | RO              | 0x4104F23x <sup>g</sup> | 1                  | ID Register on page 3-23                                                                                                                       |  |
| 0x07A              | ETMCCER         | RO              | 0x000009BA              | 1                  | Configuration Code Extension Register on page 3-24                                                                                             |  |
| 0x07B              | ETMEXTINSELR    | RW              | _ c                     | 4                  | Extended External Input Selection Register on page 3-25                                                                                        |  |
| 0x080              | ETMTRACEIDR     | RW              | 0x00000000              | 1                  | CoreSight Trace ID Register in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                                     |  |
| 0x0C5              | ETMPDSR         | RO              | _c                      | 1                  | Power-Down Status Register on page 3-26                                                                                                        |  |
| 0x3B6              | ITETMIF         | RO <sup>h</sup> | _i                      | 6                  | Processor-ETM Interface Register on page 3-32                                                                                                  |  |
| 0x3B7              | ITMISCOUT       | WO              | n/a <sup>j</sup>        | 6                  | Miscellaneous Outputs Register on page 3-34                                                                                                    |  |
| 0x3B8              | ITMISCIN        | RO <sup>h</sup> | _i                      | 6                  | Miscellaneous Inputs Register on page 3-35                                                                                                     |  |
| 0x3B9              | ITTRIGGERACK    | RO <sup>h</sup> | _i                      | 6                  | Trigger Acknowledge Register on page 3-36                                                                                                      |  |
| 0x3BA              | ITTRIGGERREQ    | WO              | n/a <sup>j</sup>        | 6                  | Trigger Request Register on page 3-37                                                                                                          |  |
|                    |                 |                 |                         |                    |                                                                                                                                                |  |

| Register<br>number | Name          | Туре            | Reset                    | Group <sup>a</sup> | Description                                                                                                               |
|--------------------|---------------|-----------------|--------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| Øx3BB              | ITATBDATA0    | WO              | n/a <sup>j</sup>         | 6                  | ATB Data Register 0 on page 3-38                                                                                          |
| 0x3BC              | ITATBCTR2     | RO <sup>h</sup> | _i                       | 6                  | ATB Control Register 2 on page 3-39                                                                                       |
| Øx3BD              | ITATBCTR1     | WO              | n/a <sup>j</sup>         | 6                  | ATB Control Register 1 on page 3-40                                                                                       |
| 0x3BE              | ITATBCTR0     | WO              | n/a <sup>j</sup>         | 6                  | ATB Control Register 0 on page 3-41                                                                                       |
| 0x3C0              | ETMITCTRL     | RW              | 0x00000000               | 5                  | Integration Mode Control Register in the Embedded<br>Trace Macrocell Architecture Specification                           |
| 0x3E8              | ETMCLAIMSET   | RW              | 0x000000FF               | 5                  | Claim Tag Set Register in the ARM® Embedded Trace<br>Macrocell Architecture Specification                                 |
| 0x3E9              | ETMCLAIMCLR   | RW              | 0x00000000               | 5                  | Claim Tag Clear Register in the ARM <sup>®</sup> Embedded<br>Trace Macrocell Architecture Specification                   |
| 0x3EC              | ETMLAR        | WO              | n/a <sup>jk</sup>        | 5                  | Lock Access Register in the ARM <sup>®</sup> Embedded Trace<br>Macrocell Architecture Specification                       |
| 0x3ED              | ETMLSR        | RO              | 0x00000003 <sup>kl</sup> | 5                  | Lock Status Register in the ARM <sup>®</sup> Embedded Trace<br>Macrocell Architecture Specification                       |
| 0x3EE              | ETMAUTHSTATUS | RO              | _i                       | 5                  | Authentication Status Register in the ARM®<br>Embedded Trace Macrocell Architecture<br>Specification                      |
| 0x3F2              | ETMDEVID      | RO              | 0×00000000               | 5                  | CoreSight Device Configuration Register in the<br>ARM <sup>®</sup> Embedded Trace Macrocell Architecture<br>Specification |
| 0x3F3              | ETMDEVTYPE    | RO              | 0x00000013               | 5                  | CoreSight Device Type Register in the ARM <sup>®</sup><br>Embedded Trace Macrocell Architecture<br>Specification          |
| 0x3F4 to<br>0x3F7  | ETMPIDR5-7    | RO              | _i                       | 5                  | Peripheral Identification Registers on page 3-26                                                                          |
| 0x3F8 to<br>0x3FB  | EETMPIDR0-3   | RO              | _i                       | -                  | -                                                                                                                         |
| 0x3FC to<br>0x3FF  | ETMCIDR0-3    | RO              | _i                       | 5                  | <i>ETM Component Identification Registers</i> on page 3-29                                                                |

#### Table 3-1 ETM-R5 macrocell register summary (continued)

a. Functional group. For more information, see:

For Group 1, General control and ID registers on page 3-10, Table 3-2 on page 3-10.

For Group 2, TraceEnable and ViewData registers on page 3-11, Table 3-3 on page 3-11.

For Group 3, Comparator registers on page 3-12, Table 3-4 on page 3-12.

For Group 4, Counter, Sequencer and other resource registers on page 3-13, Table 3-5 on page 3-13.

For Group 5, CoreSight Management registers on page 3-14, Table 3-6 on page 3-14.

For Group 6, Integration Test registers on page 3-15, Table 3-7 on page 3-15.

b. Default value when MAXEXTOUT[1:0] and MAXEXTIN[2:0] are all tied LOW (0), see the register description for more information.

c. The register is not reset by a reset of the macrocell. Therefore, it does not have a specific default value, and its reset value is Unknown.

d. Bits[14:12] of the System Configuration Register are tied to the MAXCORES[2:0] signals. If a MAXCORES bit is High then the corresponding bit in the System Configuration Register is set to 1, for example if MAXCORES[0] is tied HIGH then bit[12] is set to 1. The default value given is for all MAXCORES signals tied LOW, bits[14:12] = b000.

For more information about the MAXCORES[2:0] signals, see Appendix A Signal Descriptions.

- e. Although the macrocell does not include **FIFOFULL** logic, the FIFOFULL Level Register controls the FIFO level that data suppression occurs. For more information see the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.
- f. In the Data Comparator register area, even number registers are reserved. For the CoreSight ETM-R5, reserved areas are:
  - Register 0x031, Data Comparator Value 1, at offset 0x0C4.
  - Register 0x033, Data Comparator Value 3, at offset 0x0CC.
  - Register 0x041, Data Comparator Mask 1, at offset 0x104.
  - Register 0x043, Data Comparator Mask 3, at offset 0x10C.
  - You must not write to these reserved register addresses. Reads from these addresses are Unpredictable.
- g. The value of bits[3:0] of the ETMIDR depend on the macrocell revision, see *ID Register* on page 3-23 for more information.
- h. The values of the read-only Integration Test registers are valid only when the macrocell is in Integration Test mode. If you read one of these registers when the macrocell is in normal operating mode the result returned is Unknown.
- i. See the register description for details.
- j. Not applicable. These are write-only registers.
- k. This register is only present and visible when the **PADDRDBG31** input signal is at logic LOW. This occurs when the ETM-R5 macrocell is accessed by software, see *APB interface* on page A-6.
- 1. When **PADDRDBG31** input signal is at logic HIGH, that is when the ETM-R5 macrocell is accessed by a debugger, the register reads as 0x00000000.

# 3.4.1 Functional grouping of registers

This section lists the macrocell registers by functional group, as follows:

- General control and ID registers.
- TraceEnable and ViewData registers.
- *Comparator registers* on page 3-12.
- Counter, Sequencer and other resource registers on page 3-13.
- *CoreSight Management registers* on page 3-14.
- *Integration Test registers* on page 3-15.

These functional groups include all of the registers.

## **General control and ID registers**

Table 3-2 lists the general control and ID registers in register number order.

|                    |                              |                |                 | 0                                                                        |
|--------------------|------------------------------|----------------|-----------------|--------------------------------------------------------------------------|
| Register<br>number | Name                         | Base<br>offset | Clock<br>domain | Description                                                              |
| 0x000              | ETM Control                  | 0x000          | CLK             | Main Control Register on page 3-16                                       |
| 0x001              | Configuration Code           | 0x004          | CLK             | Configuration Code Register on page 3-20                                 |
| 0x003              | ASIC Control                 | 0x00C          | CLK             | ASIC Control Register on page 3-22                                       |
| 0x004              | ETM Status                   | 0x010          | CLK             | ARM® Embedded Trace Macrocell Architecture<br>Specification              |
| 0x005              | System Configuration         | 0x014          | CLK             | ARM® Embedded Trace Macrocell Architecture<br>Specification              |
| 0x00B              | FIFOFULL Level <sup>a</sup>  | 0x02C          | CLK             | ARM® Embedded Trace Macrocell Architecture<br>Specification              |
| 0x078              | Synchronization Frequency    | 0x1E0          | CLK             | ARM® Embedded Trace Macrocell Architecture<br>Specification <sup>b</sup> |
| 0x079              | ETM ID                       | 0x1E4          | CLK             | ID Register on page 3-23                                                 |
| 0x07A              | Configuration Code Extension | 0x1E8          | CLK             | <i>Configuration Code Extension Register</i> on page 3-24                |
| 0x080              | CoreSight Trace ID           | 0x200          | ATCLK           | ARM® Embedded Trace Macrocell Architecture<br>Specification              |
| 0x0C5              | Power-Down Status            | 0x314          | CLK             | Power-Down Status Register on page 3-26                                  |

#### Table 3-2 General control and ID registers

a. Although the macrocell does not include **FIFOFULL** logic, the FIFOFULL Level Register controls the FIFO level that data suppression occurs. For more information see the *ARM*<sup>®</sup> *Embedded Trace Macrocell Architecture Specification*.

b. Only bits[11:2] of the Synchronization Frequency Register are implemented. Bits[1:0] Read-As-Zero.

#### TraceEnable and ViewData registers

Table 3-3 on page 3-11 lists the TraceEnable and ViewData registers in register number order.

| Register<br>number | Name                                    | Base<br>offset | Clock<br>domain | Description                                                             |
|--------------------|-----------------------------------------|----------------|-----------------|-------------------------------------------------------------------------|
| 0x006              | TraceEnable Start/Stop Resource control | 0x018          | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x007              | TraceEnable Control 2                   | 0x01C          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x008              | TraceEnable Event                       | 0x020          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x009              | TraceEnable Control 1                   | 0x024          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x00C              | ViewData Event                          | 0x030          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x00D              | ViewData Control 1                      | 0x034          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x00F              | ViewData Control 3                      | 0x03C          | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |

### **Comparator registers**

Table 3-4 lists the Comparator registers in register number order. These control the Address, Data and Context ID comparators.

| Register<br>number | Name                                  | Base offset        | Clock<br>domain | Description                                                             |
|--------------------|---------------------------------------|--------------------|-----------------|-------------------------------------------------------------------------|
| 0x010 to 0x017     | Address Comparator Value 1-8          | 0x040 to 0x05F     | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x020 to 0x027     | Address Comparator Access<br>Type 1-8 | 0x080 to 0x09F     | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specificationª            |
| 0x030 <sup>b</sup> | Data Comparator Value 1 <sup>b</sup>  | 0x0C0 <sup>b</sup> | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x032 <sup>b</sup> | Data Comparator Value 3 <sup>b</sup>  | 0x0C8 <sup>b</sup> | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x040 <sup>b</sup> | Data Comparator Mask 1 <sup>b</sup>   | 0x100 <sup>b</sup> | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x042 <sup>b</sup> | Data Comparator Mask 3 <sup>b</sup>   | 0x108 <sup>b</sup> | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x06C              | Context ID Comparator Value           | 0x1B0              | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x06F              | Context ID Comparator Mask            | 0x1BC              | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |

#### **Table 3-4 Comparator registers**

a. Because the Cortex-R5 processor does not implement the Security Extensions, only bits[9:0] of the Address Comparator Access Type Registers are implemented.

 b. In the Data Comparator register area, even number registers are reserved. For the CoreSight ETM-R5, reserved areas are: Register 0x031, Data Comparator Value 1, at offset 0x0C4 Register 0x033, Data Comparator Value 3, at offset 0x0CC.
 Register 0x041, Data Comparator Mask 1, at offset 0x104 Register 0x043, Data Comparator Mask 3, at offset 0x10C.
 You must not write to these reserved register addresses. The value of a reads from these addresses is Unknown.

# Counter, Sequencer and other resource registers

Table 3-5 lists the Counter, Sequencer and other resource registers in register number order. These control:

- The two Counters, and associated events.
- The Sequencer, and associated state change events.
- Trigger events.
- EXTOUT (External Output) events.
- Extended External Input selection.

#### Table 3-5 Counter, Sequencer and other resource registers

| Register<br>number | Name                              | Base offset    | Clock<br>domain | Description                                                             |  |
|--------------------|-----------------------------------|----------------|-----------------|-------------------------------------------------------------------------|--|
| 0x002              | Trigger Event                     | 0x008          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |  |
| 0x050, 0x051       | Counter Reload Value 1-2          | 0x140, 0x144   | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |  |
| 0x054, 0x055       | Counter Enable Event 1-2          | 0x150, 0x154   | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |  |
| 0x058, 0x059       | Counter Reload Event 1-2          | 0x160, 0x164   | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |  |
| 0x05C, 0x05D       | Counter Value 1-2                 | 0x170, 0x174   | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |  |
| 0x060 to 0x065     | Sequencer State Transition Events | 0x180 to 0x194 | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |  |
| 0x067              | Current Sequencer State           | 0x19C          | CLK             | ARM® Embedded Trace Macrocell<br>Architecture Specification             |  |
| 0x068, 0x069       | External Output Event 1-2         | 0x1A0, 0x1A4   | CLK             | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |  |
| 0x07B              | Extended External Input Selector  | 0x1EC          | CLK             | Extended External Input Selection<br>Register on page 3-25              |  |

# **CoreSight Management registers**

Table 3-6 lists the CoreSight Management registers in register number order.

## Table 3-6 CoreSight Management registers

| Register<br>number | Name                     | Base offset    | Clock<br>domain | Description                                                             |
|--------------------|--------------------------|----------------|-----------------|-------------------------------------------------------------------------|
| 0x3C0              | Integration Mode Control | 0xF00          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3E8              | Claim Tag Set            | 0xFA0          | PCLKDBG         | ARM® Embedded Trace Macrocell<br>Architecture Specification             |
| 0x3E9              | Claim Tag Clear          | 0xFA4          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3EC              | Lock Access              | 0xFB0          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3ED              | Lock Status              | 0xFB4          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3EE              | Authentication Status    | 0xFB8          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3F2              | Device Configuration     | 0xFC8          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3F3              | Device Type              | 0xFCC          | PCLKDBG         | ARM <sup>®</sup> Embedded Trace Macrocell<br>Architecture Specification |
| 0x3F4 to 0x3F7     | Peripheral ID4 to 7      | 0xFD0 to 0xFDC | PCLKDBG         | Peripheral Identification Registers on                                  |
| 0x3F8 to 0x3FB     | Peripheral ID0 to 3      | 0xFE0 to 0xFEC | PCLKDBG         | page 3-26                                                               |
| 0x3FC to 0x3FF     | Component ID0 to 3       | 0xFF0 to 0xFFC | PCLKDBG         | <i>ETM Component Identification Registers</i> on page 3-29              |

# Integration Test registers

Table 3-7 lists the Integration Test registers in register number order.

## Table 3-7 Integration Test registers

| Register<br>number | Name         | Base<br>offset | Clock Description domain |                                               |
|--------------------|--------------|----------------|--------------------------|-----------------------------------------------|
| 0x3B6              | ITETMIF      | 0xED8          | CLK                      | Processor-ETM Interface Register on page 3-32 |
| 0x3B7              | ITMISCOUT    | 0xEDC          | CLK                      | Miscellaneous Outputs Register on page 3-34   |
| 0x3B8              | ITMISCIN     | 0xEE0          | CLK                      | Miscellaneous Inputs Register on page 3-35    |
| 0x3B9              | ITTRIGGERACK | 0xEE4          | ATCLK                    | Trigger Acknowledge Register on page 3-36     |
| 0x3BA              | ITTRIGGERREQ | 0xEE8          | ATCLK                    | Trigger Request Register on page 3-37         |
| 0x3BB              | ITATBDATA0   | 0xEEC          | ATCLK                    | ATB Data Register 0 on page 3-38              |
| 0x3BC              | ITATBCTR2    | 0xEF0          | ATCLK                    | ATB Control Register 2 on page 3-39           |
| 0x3BD              | ITATBCTR1    | 0xEF4          | ATCLK                    | ATB Control Register 1 on page 3-40           |
| 0x3BE              | ITATBCTR0    | 0xEF8          | ATCLK                    | ATB Control Register 0 on page 3-41           |

# 3.5 Register descriptions

The following sections describe the implementation-defined CoreSight ETM-R5 macrocell registers:

- Main Control Register.
- Configuration Code Register on page 3-20.
- ASIC Control Register on page 3-22.
- *ID Register* on page 3-23.
- *Configuration Code Extension Register* on page 3-24.
- *Extended External Input Selection Register* on page 3-25.
- *Power-Down Status Register* on page 3-26.
- *Peripheral Identification Registers* on page 3-26.
- ETM Component Identification Registers on page 3-29.
- *Integration Test Registers* on page 3-30.

The *ARM*® *Embedded Trace Macrocell Architecture Specification* describes the other CoreSight ETM-R5 macrocell registers.

## 3.5.1 Main Control Register

The ETMCR characteristics are:

| Purpose           | Controls general operation of the ETM, such as whether tracing is enabled or coprocessor data is traced. |
|-------------------|----------------------------------------------------------------------------------------------------------|
| Usage constraints | There are no usage constraints.                                                                          |
| Configurations    | Available in all configurations.                                                                         |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-2 on page 3-10.                            |

Figure 3-2 shows the ETMCR bit assignments.



Figure 3-2 ETMCR bit assignments

#### Table 3-8 ETMCR bit assignments

| Bit     | Function                                        | Access | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved                                        | RW     | Must be written as 0.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [27:25] | Core select                                     | RW     | If an ETM is shared between multiple CPUs, selects which CPU to trace. For<br>the maximum value permitted, see bits[14:12] of the System Configuration<br>Register. See the <i>ARM® Embedded Trace Macrocell Architecture Specification</i><br>for more information.<br>To guarantee that the ETM is correctly synchronized to the new CPU, you must<br>update these bits as follows:<br>1. Set bit[10], ETM programming, and bit[0], ETM power down, to 1. |
|         |                                                 |        | 2. Change the core select bits.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |                                                 |        | 3. Clear bit[0], ETM power down, to 0.                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |                                                 |        | <ol> <li>Perform other programming required as normal.</li> <li>On an ETM reset this field is zero.</li> </ol>                                                                                                                                                                                                                                                                                                                                              |
|         |                                                 |        | On an E 1 M reset uns field is zero.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [24]    | Instrumentation<br>resources access<br>control  | RO     | The ETM-R5 macrocell does not implement any instrumentation resources and therefore this bit is RAZ.                                                                                                                                                                                                                                                                                                                                                        |
| [23]    | Disable<br>software writes                      | RO     | The ETM-R5 macrocell does not support this feature and therefore this bit is RAZ.                                                                                                                                                                                                                                                                                                                                                                           |
| [22]    | Disable register<br>writes from the<br>debugger | RO     | The ETM-R5 macrocell does not support this feature and therefore this bit is RAZ.                                                                                                                                                                                                                                                                                                                                                                           |
| [21]    | Port size[3]                                    | RW     | Use this bit in conjunction with bits[6:4].                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         |                                                 |        | On an ETM reset this bit is 0, corresponding to the 32-bit port size.                                                                                                                                                                                                                                                                                                                                                                                       |
| [20]    | Data-only mode                                  | RW     | The possible values of this bit are:                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |                                                 |        | 0 Instruction trace enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         |                                                 |        | 1 Instruction trace disabled. Data-only tracing is possible in this mode.                                                                                                                                                                                                                                                                                                                                                                                   |
|         |                                                 |        | On an ETM reset this bit is 0.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [19]    | Filter (CPRT)                                   | RW     | Use this bit in conjunction with bit[1], the MonitorCPRT bit. For details see Filter Coprocessor Register Transfers (CPRT) in ETMv3.0 and later in the <i>ARM® Embedded Trace Macrocell Architecture Specification</i> . On an ETM reset this bit is 0.                                                                                                                                                                                                     |
| [18]    | Suppress data                                   | RW     | Use this bit with bit[7] to suppress data. For details see Data suppression in the                                                                                                                                                                                                                                                                                                                                                                          |
| [-•]    | PP                                              |        | ARM <sup>®</sup> Embedded Trace Macrocell Architecture Specification.                                                                                                                                                                                                                                                                                                                                                                                       |
|         |                                                 |        | On an ETM reset this bit is 0.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [17:16] | Port mode[1:0]                                  | RW     | These bits are used, in conjunction with bit[13], to set the trace port clocking mode. The ETM-R5 macrocell supports only dynamic mode, corresponding to the value b000, but you can write other values to these bits, and a read of the register returns the value written. Writing another value to these bits has no effect on the ETM.                                                                                                                  |
|         |                                                 |        | Bit[11] of the System Configuration Register indicates if these bits are set to select a supported clocking mode.                                                                                                                                                                                                                                                                                                                                           |
|         |                                                 |        | On an ETM reset these bits are zero.                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |                                                 |        | For more information about trace port clocking modes see the ARM <sup>®</sup> Embedded Trace Macrocell Architecture Specification.                                                                                                                                                                                                                                                                                                                          |

| Bit Function Access Description |                           |    | Description                                                                                                                                                                                                                                                                |  |  |
|---------------------------------|---------------------------|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [15:14]                         | Context ID size           | RW | The possible values of this field are:b00No Context ID tracing.                                                                                                                                                                                                            |  |  |
|                                 |                           |    | <b>b01</b> Context ID bits[7:0] traced.                                                                                                                                                                                                                                    |  |  |
|                                 |                           |    | <b>b10</b> Context ID bits[15:0] traced.                                                                                                                                                                                                                                   |  |  |
|                                 |                           |    | <b>b11</b> Context ID bits[31:0] traced.                                                                                                                                                                                                                                   |  |  |
|                                 |                           |    | Note                                                                                                                                                                                                                                                                       |  |  |
|                                 |                           |    | Only the number of bytes specified are traced even if the new value is larger than this.                                                                                                                                                                                   |  |  |
|                                 |                           |    | On an ETM reset this field is zero.                                                                                                                                                                                                                                        |  |  |
| [13]                            | Port mode[2]              | RW | See the description of bits[17:16].                                                                                                                                                                                                                                        |  |  |
|                                 |                           |    | On an ETM reset this bit is 0.                                                                                                                                                                                                                                             |  |  |
| [12]                            | Cycle-accurate<br>tracing | RW | Set this bit to 1 if you want the trace to include a precise cycle count of executed instructions. This is achieved by adding extra information into the trace, giving cycle counts even when <b>TraceEnable</b> is inactive.<br>On an ETM reset this bit is 0.            |  |  |
| [11]                            | ETM port selection        | RW | This bit controls an external output, ETMEN. The possible values are:0ETMEN is LOW.                                                                                                                                                                                        |  |  |
|                                 |                           |    | <b>1 ETMEN</b> is HIGH.                                                                                                                                                                                                                                                    |  |  |
|                                 |                           |    | You can use the <b>ETMEN</b> signal to control the routing of trace port signals to shared GPIO pins on your SoC, under the control of logic external to the ETM. Trace software tools must set this bit to 1 to ensure that trace output is enabled from this ETM.        |  |  |
|                                 |                           |    | On an ETM reset this bit is 0.                                                                                                                                                                                                                                             |  |  |
| [10]                            | ETM<br>programming        | RW | When set to 1, the ETM is being programmed. For more information, see ETM Programming bit and associated state in the <i>ARM® Embedded Trace Macrocell Architecture Specification</i> .<br>On an ETM reset this bit is set to 1.                                           |  |  |
|                                 |                           |    | On an E1M reset this bit is set to 1.                                                                                                                                                                                                                                      |  |  |
| [9]                             | Debug request control     | RW | If you set this bit to 1, when the trigger event occurs, the <b>DBGRQ</b> output is asserted until <b>DBGACK</b> is observed. This enables the ARM processor to be forced into Debug state.                                                                                |  |  |
|                                 |                           |    | On an ETM reset this bit is 0.                                                                                                                                                                                                                                             |  |  |
| [8]                             | Branch output             | RW | Set this bit to 1 if you want the ETM to output all branch addresses, even if the branch is because of a direct branch instruction. Setting this bit to 1 enables reconstruction of the program flow without having access to the memory image of the code being executed. |  |  |
|                                 |                           |    | On an ETM reset this bit is 0.                                                                                                                                                                                                                                             |  |  |
| [7]                             | Stall processor           | RO | The ETM-R5 macrocell does not implement <b>FIFOFULL</b> stalling of the processor, and therefore this bit is RAZ.                                                                                                                                                          |  |  |

## Table 3-8 ETMCR bit assignments (continued)

#### Table 3-8 ETMCR bit assignments (continued)

| Bit   | Function          | Access | Description                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|-------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6:4] | Port size[2:0]    | RW     | Use this field with bit[21] to specify the port size.                                                                                                                                                                                                                                                                                                                                               |
|       |                   |        | The port size determines how many external pins are available to output the trace information on <b>ATDATA[31:0]</b> . The ETM-R5 macrocell supports only the 32-bit port size, corresponding to a port size[2:0] value of b0100, but you can write other values to these bits, and a read of the register returns the value written. Writing another value to these bits has no effect on the ETM. |
|       |                   |        | Bit[10] of the System Configuration Register indicates if these bits are set to select an unsupported port size.                                                                                                                                                                                                                                                                                    |
|       |                   |        | For more information see the <i>ARM</i> <sup>®</sup> <i>Embedded Trace Macrocell Architecture Specification</i> .                                                                                                                                                                                                                                                                                   |
|       |                   |        | On an ETM reset this field is b100, corresponding to the 32-bit port size.                                                                                                                                                                                                                                                                                                                          |
| [3:2] | Data access       | RW     | This field configures the data tracing mode. The possible values are:                                                                                                                                                                                                                                                                                                                               |
|       |                   |        | b00 No data tracing.                                                                                                                                                                                                                                                                                                                                                                                |
|       |                   |        | <b>b01</b> Trace only the data portion of the access.                                                                                                                                                                                                                                                                                                                                               |
|       |                   |        | <b>b10</b> Trace only the address portion of the access.                                                                                                                                                                                                                                                                                                                                            |
|       |                   |        | <b>b11</b> Trace both the address and the data of the access.                                                                                                                                                                                                                                                                                                                                       |
|       |                   |        | On an ETM reset this field is 0.                                                                                                                                                                                                                                                                                                                                                                    |
| [1]   | MonitorCPRT       | RW     | This field controls whether CPRTs are traced. The possible values are:                                                                                                                                                                                                                                                                                                                              |
|       |                   |        | 0 CPRTs not traced.                                                                                                                                                                                                                                                                                                                                                                                 |
|       |                   |        | 1 CPRTs traced.                                                                                                                                                                                                                                                                                                                                                                                     |
|       |                   |        | This bit is used with bit[19]. For details see Filter Coprocessor Register Transfers (CPRT) in ETMv3.0 and later in the <i>ARM® Embedded Trace Macrocell Architecture Specification</i> .                                                                                                                                                                                                           |
|       |                   |        | On an ETM reset this bit is 0.                                                                                                                                                                                                                                                                                                                                                                      |
| [0]   | ETM power<br>down | RW     | A pin controlled by this bit enables the ETM power to be controlled externally, see <i>Control of ETM power down</i> . The sense of this bit is inverted, and drives the <b>ETMPWRUP</b> signal.                                                                                                                                                                                                    |
|       |                   |        | This bit must be cleared by the trace software tools at the beginning of a debug session.                                                                                                                                                                                                                                                                                                           |
|       |                   |        | When this bit is set to 1, ETM tracing is disabled and accesses to any registers other than this register and the Lock Access Register are ignored.                                                                                                                                                                                                                                                 |
|       |                   |        | On an ETM reset this bit is set to 1.                                                                                                                                                                                                                                                                                                                                                               |
|       |                   |        | See <i>Control of ETM power down</i> for additional information on controlling ETM power down.                                                                                                                                                                                                                                                                                                      |

#### Control of ETM power down

You can use the **ETMPWRUP** signal, controlled by the ETM power down bit of the ETMCR, to gate the clock to the logic in the ETM interface of the processor, to save power. Also, when you set the ETM power down bit to 1, the clock to most of the logic in the ETM is gated, disabling ETM tracing and leaving the ETM block operating in a low-power mode.

—— Note ———

You must not use the **ETMEN** signal to gate the ETM clock or any other functionality required for basic operation. You can use the **ETMEN** signal to control functionality that is required only for off-chip tracing, such as multiplexing between two ETMs. Use the **ETMPWRUP** signal to control basic operation of the ETM.

# 3.5.2 Configuration Code Register

The ETMCCR characteristics are:

| Purpose           | Indicates the configuration of the ETM-R5 macrocell.                                                                |
|-------------------|---------------------------------------------------------------------------------------------------------------------|
| Usage constraints | There are no usage constraints.                                                                                     |
| Configurations    | Available in all configurations.                                                                                    |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-2 on page 3-10.                                       |
|                   | If the <b>MAXEXTOUT[1:0]</b> and <b>MAXEXTIN[2:0]</b> signals are all tied LOW the ETMCCR has the value 0x8D014024. |

Figure 3-3 shows the ETMCCR bit assignments.



#### Figure 3-3 ETMCCR bit assignments

Table 3-9 lists the ETMCCR bit assignments

Table 3-9 ETMCCR bit assignments

| Bits    | Value | Function                                                                                                                                                                                                                     |
|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | 1     | ETMIDR present.                                                                                                                                                                                                              |
| [30:28] | b000  | Reserved. Read-As-Zero (RAZ).                                                                                                                                                                                                |
| [27]    | 1     | Software access is supported.                                                                                                                                                                                                |
| [26]    | 1     | Trace start/stop block is present.                                                                                                                                                                                           |
| [25:24] | b01   | Number of Context ID comparators.                                                                                                                                                                                            |
| [23]    | 0     | FIFOFULL logic absent.                                                                                                                                                                                                       |
| [22]    | 0     | Reserved, Read-As-Zero.<br>The <i>ARM</i> ® <i>Embedded Trace Macrocell Architecture Specification</i> defines this as the most significant bit of the Number of external outputs field, see the description of bits[21:20]. |
| [21:20] | -     | Number of external outputs. Determined by the <b>MAXEXTOUT[1:0]</b> inputs.<br>The maximum value of this field is 2, because CoreSight ETM-R5 supports a maximum of two external outputs.                                    |

## Table 3-9 ETMCCR bit assignments (continued)

| Bits    | Value | Function                                                                                                                                                                                 |
|---------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [19:17] | -     | Number of external inputs. Determined by the <b>MAXEXTIN</b> [2:0] inputs.<br>The maximum value of this field is 4, because CoreSight ETM-R5 supports a maximum of four external inputs. |
| [16]    | 1     | The sequencer is present.                                                                                                                                                                |
| [15:13] | 2     | Number of counters.                                                                                                                                                                      |
| [12:8]  | 0     | Number of memory map decoders.                                                                                                                                                           |
| [7:4]   | 2     | Number of data comparators.                                                                                                                                                              |
| [3:0]   | 4     | Number of pairs of address comparators.                                                                                                                                                  |

# 3.5.3 ASIC Control Register

The ETMASICCR characteristics are:

| Purpose           | Controls the ASICCTL[7:0] signal.                                             |
|-------------------|-------------------------------------------------------------------------------|
| Usage constraints | There are no usage constraints.                                               |
| Configurations    | Available in all configurations.                                              |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-2 on page 3-10. |

Figure 3-4 shows the ETMASICCR bit assignments.

| 31 |  |          |  | 8 7 |         | 0 |
|----|--|----------|--|-----|---------|---|
|    |  | Reserved |  |     | ASICCTL |   |

## Figure 3-4 ETMASICCR bit assignments

Table 3-10 lists the ETMASICCR bit assignments.

# Table 3-10 ETMASICCR bit assignments

| Bits   | Function                                                                                                                                                                                                                         |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved.                                                                                                                                                                                                                        |
| [7:0]  | ASICCTL[7:0]:<br>When a bit in this field is set to 0 the corresponding bit of ASICCTL[7:0] is LOW.<br>When a bit in this field is set to 1 the corresponding bit of ASICCTL[7:0] is HIGH.<br>On an ETM reset, these bits are 0. |

# 3.5.4 ID Register

The ETMIDR characteristics are:

| Purpose           | Identifies the implementation of ETM-R5 macrocell.                                                                                                                                                                                                                                         |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Usage constraints | There are no usage constraints.                                                                                                                                                                                                                                                            |  |
| Configurations    | Available in all configurations.                                                                                                                                                                                                                                                           |  |
| Attributes        | This register has the value 0x4104F23x, where x depends on the release version of the macrocell, see the Implementation revision field description in <i>ETMIDR bit assignments</i> for more information.<br>See the register summary in Table 3-1 on page 3-5 and Table 3-2 on page 3-10. |  |

Figure 3-5 shows the ETMIDR bit assignments.



## Figure 3-5 ETMIDR bit assignments

Table 3-11 lists the ETMIDR bit assignments.

#### Table 3-11 ETMIDR bit assignments

| Bit numbers | Value | Function                                                                                                                                                                                                                  |
|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24]     | 0x41  | Implementer = A (for ARM).                                                                                                                                                                                                |
| [23:20]     | b0000 | Reserved.                                                                                                                                                                                                                 |
| [19]        | 0     | Security Extensions support. This bit is set to 1 if the processor supports the ARMv7 architecture Security Extensions.<br>On the macrocell, this bit is not set (0), meaning that the ETM behaves as if the processor is |
|             |       | in Secure state at all times.                                                                                                                                                                                             |
| [18]        | 1     | Thumb-2 support. This bit is set to 1 if the processor supports the Thumb-2 architectural extensions.                                                                                                                     |
|             |       | On the macrocell, this bit is set to 1, meaning that all 32-bit Thumb instructions are traced as a single instruction, including BL and BLX immediate.                                                                    |
| [17]        | 0     | Reserved.                                                                                                                                                                                                                 |
| [16]        | 0     | If set to 1, load PC first.                                                                                                                                                                                               |
|             |       | On the macrocell, this bit is not set (0), meaning that on an LSM <sup>a</sup> load operation with the PC included in the load list, the PC is <i>not</i> loaded first.                                                   |
| [15:12]     | b1111 | ARM processor family.<br>The value of b1111 means that the processor family is defined elsewhere.                                                                                                                         |

#### Table 3-11 ETMIDR bit assignments (continued)

| Bit numbers | Value | Function                                                                                                                                                       |
|-------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11:8]      | b0010 | Major ETM architecture version number. A value of 0 in this field indicates ETMv1.<br>For ETMv3.x, this field is set to 2.                                     |
| [7:4]       | b0011 | Minor ETM architecture version number.<br>For ETMvx.3, this field is set to 3.                                                                                 |
| [3:0]       | b0010 | Implementation revision. Value given is for the r2p0 release of the macrocell.<br>For release r0p0 the value is b0000.<br>For release r1p0 the value is b0001. |

a. See the ARM® Embedded Trace Macrocell Architecture Specification for a definition and list of LSM operations.

### 3.5.5 Configuration Code Extension Register

The ETMCCER characteristics are:

| Purpose           | Indicates the configuration of the extended external input bus.               |
|-------------------|-------------------------------------------------------------------------------|
| Usage constraints | There are no usage constraints.                                               |
| Configurations    | Available in all configurations.                                              |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-2 on page 3-10. |

Figure 3-6 shows the ETMCCER bit assignments.



#### Figure 3-6 ETMCCER bit assignments

Table 3-12 lists the ETMCCER bit assignments.

#### Table 3-12 ETMCCER bit assignments

| Bit numbers | Value | Function                                                                                                                                                                  |
|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12]     | 0     | Reserved, RAZ.                                                                                                                                                            |
| [11]        | 1     | All registers, except some integration test registers, are readable.<br>See Table 3-7 on page 3-15 for details of the access to integration test registers <sup>a</sup> . |
| [10:3]      | 55    | Size of extended external input bus.                                                                                                                                      |
| [2:0]       | b010  | Number of extended external input selectors.                                                                                                                              |
| D           | 1.4   |                                                                                                                                                                           |

a. Registers with names that start with IT are the Integration Test Registers, for example ITATBCTR1.

## 3.5.6 Extended External Input Selection Register

The ETMEXTINSELR Register characteristics are:

| Purpose           | Specifies the extended external inputs, see the <i>ARM</i> <sup>®</sup> <i>Embedded Trace Macrocell Architecture Specification</i> for more information. |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | There are no usage constraints.                                                                                                                          |
| Configurations    | Available in all configurations.                                                                                                                         |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-5 on page 3-13.                                                                            |

Figure 3-7 shows the ETMEXTINSELR bit assignments.

| 31 |          | 16 15 |            | 8 | 7 | 0                       |  |
|----|----------|-------|------------|---|---|-------------------------|--|
|    | Reserved |       | cond exter |   |   | ktended<br>put selector |  |

# Figure 3-7 ETMEXTINSELR bit assignments

Table 3-13 lists the ETMEXTINSELR bit assignments.

#### Table 3-13 ETMEXTINSELR bit assignments

| Bits    | Description                               |                                                                                               |  |  |  |
|---------|-------------------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved, SB                              | Reserved, SBZP.                                                                               |  |  |  |
| [15:8]  | Second exten<br>Bits[15,14]<br>Bits[13:8] | ded external input selector:<br>Reserved, SBZP.<br>Selection value for second external input. |  |  |  |
| [7:0]   | First extended<br>Bits[7,6]<br>Bits[5:0]  | d external input selector:<br>Reserved, SBZP.<br>Selection value for first external input.    |  |  |  |

## 3.5.7 Power-Down Status Register

The ETMPDSR characteristics are:

| Purpose           | Indicates the powerdown status of the ETM.                                    |
|-------------------|-------------------------------------------------------------------------------|
| Usage constraints | There are no usage constraints.                                               |
| Configurations    | Available in all configurations.                                              |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-2 on page 3-10. |

Figure 3-8 shows the ETMPDSR bit assignments.

| 31 |  |   |          |  |                               | 2 1 | 0 |
|----|--|---|----------|--|-------------------------------|-----|---|
|    |  | R | Reserved |  |                               |     |   |
|    |  |   |          |  | register stat<br>// powered u |     |   |

#### Figure 3-8 ETMPDSR bit assignments

Table 3-14 lists the ETMPDSR bit assignments.

#### Table 3-14 ETMPDSR bit assignments

| Bit numbers | Value | Function                                                                                                                                                      |
|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2]      | 0     | Reserved, RAZ.                                                                                                                                                |
| [1]         | 0     | Sticky Register State. The ETM-R5 macrocell does not support multiple power domains so this bit is RAZ.                                                       |
| [0]         | 1     | ETM Powered Up. The ETM Trace registers are accessible. The ETM-R5 macrocell does not support multiple power domains so this bit is <i>Read-As-One</i> (RAO). |

# 3.5.8 Peripheral Identification Registers

The ETMPIDR0-ETMPIDR7 characteristics are:

| Purpose           | Provides the standard Peripheral ID required by all CoreSight components, see the <i>ARM</i> ® <i>Embedded Trace Macrocell Architecture Specification</i> for more information. |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | Only bits[7:0] of each register are used. This means that ETMPIDR0-ETMPIDR7 define a single 64-bit <i>Peripheral ID</i> , as Figure 3-9 on page 3-27 shows.                     |
| Configurations    | Available in all configurations.                                                                                                                                                |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-6 on page 3-14.                                                                                                   |
|                   |                                                                                                                                                                                 |

Figure 3-9 on page 3-27 shows the mapping between ETMPIDR0-ETMPIDR7 and the single 64-bit *Peripheral ID* value.

|      |                  |          | Ac       | tual Periphera | I ID register fie | lds      |          |          |
|------|------------------|----------|----------|----------------|-------------------|----------|----------|----------|
| ETMF | PIDR7 I          | ETMPIDR6 | ETMPIDR5 | ETMPIDR4       | ETMPIDR3          | ETMPIDR2 | ETMPIDR1 | ETMPIDR0 |
|      | $\sim \sim \sim$ |          | <u></u>  | <u></u>        | <u>۲</u>          | ۲        | ۲        | <u>۲</u> |
| 7    | 07               | 0        | 7 0      | 7 0            | 7 0               | 7 0      | 7 0      | 7 0      |
|      |                  |          |          |                |                   |          |          |          |
| 63   | 56 5             | 5 48     | 47 40    | 39 32          | 31 24             | 23 16    | 15 8     | 7 0      |

Conceptual 64-bit Peripheral ID

#### Figure 3-9 Mapping between ETMPIDR0-ETMPIDR7 and the Peripheral ID value

Figure 3-10 shows the Peripheral ID bit assignments in the single conceptual Peripheral ID register.

|                                         | Conceptual      | 64-bit Peripher | ral ID                |                   |                       |
|-----------------------------------------|-----------------|-----------------|-----------------------|-------------------|-----------------------|
| ETMPIDR7 ETMPIDR6 ETMPIDR<br>7 07 07    | 5 ETMPID        | R4 ETMPIDF      | R3 ETMPI<br>07        | DR2 ETMPII<br>07  | DR1 ETMPIDR0          |
| 000000000000000000000000000000000000000 | 0 0 0 0 0 0 1 0 | 0000000000      |                       |                   | 0 0 1 0 0 1 1 0 0 1 1 |
| 63 56 55 48 47                          | 40 39           | 32 31           | 24 23                 | 16 15             | 8 7 0                 |
| Reserved,                               |                 | RevAnd          | Revision              | JEP 106           | Part number           |
| RAZ                                     | count           |                 |                       | ID code           |                       |
|                                         |                 |                 | <br>stomer<br>odified |                   |                       |
|                                         | Continua        |                 |                       | t for the value ( | of the Revision field |

‡ See text for the value of the Revision field

#### Figure 3-10 Peripheral ID fields

 Table 3-15 lists the values of the fields when reading this set of registers. The ARM® Embedded

 Trace Macrocell Architecture Specification gives more information about many of these fields.

|          |                    |                    |        |       | Table 3-15 ETMPIDR0-ETMPIDR7 bit assignments          |
|----------|--------------------|--------------------|--------|-------|-------------------------------------------------------|
| Register | Register<br>number | Register<br>offset | Bit    | Value | Description                                           |
| ETMPIDR7 | 0x3F7              | 0xFDC              | [31:8] | -     | Unused, read undefined.                               |
|          |                    |                    | [7:0]  | 0x00  | Reserved for future use, RAZ.                         |
| ETMPIDR6 | 0x3F6              | 0xFD8              | [31:8] | -     | Unused, read undefined.                               |
|          |                    |                    | [7:0]  | 0x00  | Reserved for future use, RAZ.                         |
| ETMPIDR5 | 0x3F5              | 0xFD4              | [31:8] | -     | Unused, read undefined.                               |
|          |                    |                    | [7:0]  | 0x00  | Reserved for future use, RAZ.                         |
| ETMPIDR4 | 0x3F4              | 0xFD0              | [31:8] | -     | Unused, read undefined.                               |
|          |                    |                    | [7:4]  | 0x0   | n, where 2 <sup>n</sup> is number of 4KB blocks used. |
|          |                    |                    | [3:0]  | 0x4   | JEP 106 continuation code.                            |
| ETMPIDR3 | 0x3FB              | 0xFEC              | [31:8] | -     | Unused, read undefined.                               |
|          |                    |                    | [7:4]  | 0x0   | RevAnd (at top level). Manufacturer revision number.  |
|          |                    |                    | [3:0]  | 0x0   | Customer Modified.<br>0x0 indicates from ARM.         |

# Table 3-15 ETMPIDR0-ETMPIDR7 bit assignments

| Register | Register<br>number | Register<br>offset | Bit    | Value | Description                                                                                                                                    |
|----------|--------------------|--------------------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------|
| ETMPIDR2 | 0x3FA              | 0xFE8              | [31:8] | -     | Unused, read undefined.                                                                                                                        |
|          |                    |                    | [7:4]  | a     | Revision Number of Peripheral. This value is the same as the Implementation revision field of the ETMIDR, see <i>ID Register</i> on page 3-23. |
|          |                    |                    | [3]    | 1     | Always 1. Indicates that a JEDEC assigned value is used.                                                                                       |
|          |                    |                    | [2:0]  | b011  | JEP 106 identity code[6:4].                                                                                                                    |
| ETMPIDR1 | 0x3F9              | 0xFE4              | [31:8] | -     | Unused, read undefined.                                                                                                                        |
|          |                    |                    | [7:4]  | b0001 | JEP 106 identity code[3:0]                                                                                                                     |
|          |                    |                    | [3:0]  | 0x9   | Part Number[11:8].                                                                                                                             |
|          |                    |                    |        |       | Upper <i>Binary Coded Decimal</i> (BCD) value of Device Number.                                                                                |
| ETMPIDR0 | 0x3F8              | 0xFE0              | [31:8] | -     | Unused, read undefined.                                                                                                                        |
|          |                    |                    | [7:0]  | 0x31  | Part Number[7:0].                                                                                                                              |
|          |                    |                    |        |       | Middle and Lower BCD value of Device Number.                                                                                                   |

#### Table 3-15 ETMPIDR0-ETMPIDR7 bit assignments (continued)

a. See the Description column for details.

\_\_\_\_\_Note \_\_\_

In Table 3-15 on page 3-27, the *Peripheral Identification Registers* on page 3-26 are listed in order of register name, from most significant (ETMPIDR7) to least significant (ETMPIDR0). This does not match the order of the register offsets. Similarly, in Table 3-16 on page 3-29 the *ETM Component Identification Registers* on page 3-29 are listed in order of register name, from most significant (ETMCIDR3) to least significant (ETMCIDR0).

## 3.5.9 ETM Component Identification Registers

The ETMCIDR0-ETMCIDR3 characteristics are:

| Purpose           | Identifies the ETM as a CoreSight component. For more information, see the <i>ARM</i> ® <i>Embedded Trace Macrocell Architecture Specification</i> . |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | Only bits[7:0] of each register are used. This means that ETMCIDR0-ETMCIDR3 define a single 32-bit Component ID, as Figure 3-11 shows.               |
| Configurations    | Available in all configurations.                                                                                                                     |
| Attributes        | See the register summary in Table 3-1 on page 3-5 and Table 3-6 on page 3-14.                                                                        |

Figure 3-11 shows the mapping between ETMCIDR0-ETMCIDR3 and the single 64-bit *Component ID* value,

| Actual Component ID register fields | ETMCIDR3 | ETMCIDR2 | ETMCIDR1 | ETMCIDR0 |
|-------------------------------------|----------|----------|----------|----------|
| 7                                   | 0        | 7 0      | 7 0      | 7 0      |
|                                     |          |          |          |          |
| 31                                  | 24       | 23 16    | 15 8     | 7 0      |
|                                     |          |          |          |          |

Conceptual 32-bit component ID

Component ID

#### Figure 3-11 Mapping between ETMCIDR0-ETMCIDR3 and the Component ID value

Table 3-16 lists the Component ID bit assignments in the single conceptual Component ID register.

| Register | Register<br>number | Register<br>offset | Bit    | Value | Description                                          |
|----------|--------------------|--------------------|--------|-------|------------------------------------------------------|
| ETMCIDR3 | 0x3FF              | 0xFFC              | [31:8] | -     | Unused, read undefined.                              |
|          |                    |                    | [7:0]  | 0xB1  | Component identifier, bits[31:24].                   |
| ETMCIDR2 | 0x3FE              | 0xFF8              | [31:8] | -     | Unused, read undefined.                              |
|          |                    |                    | [7:0]  | 0x05  | Component identifier, bits[23:16].                   |
| ETMCIDR1 | 0x3FD              | 0xFF4              | [31:8] | -     | Unused, read undefined.                              |
|          |                    |                    | [7:4]  | 0x9   | Component class (component identifier, bits[15:12]). |
|          |                    |                    | [3:0]  | 0x0   | Component identifier, bits[11:8].                    |
| ETMCIDR0 | 0x3FC              | 0xFF0              | [31:8] | -     | Unused, read undefined.                              |
|          |                    |                    | [7:0]  | 0x0D  | Component identifier, bits[7:0].                     |

#### Table 3-16 ETMCIDR0-ETMCIDR3, bit assignments

# 3.5.10 Integration Test Registers

The following subsections describe the Integration Test Registers. To access these registers you must first set bit[0] of the *Integration Mode Control Register* (ETMITCTRL) to 1.

- You can use the write-only Integration Test Registers to set the outputs of some of the ETM signals. Table 3-17 lists the signals that can be controlled in this way.
- You can use the read-only Integration Test Registers to read the state of some of the ETM input signals. Table 3-18 lists the signals that can be read in this way.

See the ARM® Embedded Trace Macrocell Architecture Specification for more information.

| Signal                   | Register     | Bit   | Register description                            |
|--------------------------|--------------|-------|-------------------------------------------------|
| AFREADY                  | ITATBCTR0    | [1]   | See ATB Control Register 0 on page 3-41         |
| ATBYTES[1:0]             | ITATBCTR0    | [9:8] | See ATB Control Register 0 on page 3-41         |
| ATDATA[31, 23, 15, 7, 0] | ITATBDATA0   | [4:0] | See ATB Data Register 0 on page 3-38            |
| ATID[6:0]                | ITATBCTR1    | [6:0] | See ATB Control Register 1 on page 3-40         |
| ATVALID                  | ITATBCTR0    | [0]   | See ATB Control Register 0 on page 3-41         |
| ETMDBGRQ                 | ITMISCOUT    | [4]   | See Miscellaneous Outputs Register on page 3-34 |
| EXTOUT[1:0]              | ITMISCOUT    | [9:8] | See Miscellaneous Outputs Register on page 3-34 |
| nETMWFIREADY             | ITMISCOUT    | [5]   | See Miscellaneous Outputs Register on page 3-34 |
| TRIGGER                  | ITTRIGGERREQ | [0]   | See Trigger Request Register on page 3-37       |

Table 3-17 Output signals that the Integration Test Registers can control

#### Table 3-18 Input signals that the Integration Test Registers can read

| Signal         | Register     | Bit     | Register description                              |
|----------------|--------------|---------|---------------------------------------------------|
| AFVALID        | ITATBCTR2    | [1]     | See ATB Control Register 2 on page 3-39           |
| ATREADY        | ITATBCTR2    | [0]     | See ATB Control Register 2 on page 3-39           |
| DBGACK         | ITMISCIN     | [4]     | See Miscellaneous Inputs Register on page 3-35    |
| ETMCID[31, 0]  | ITETMIF      | [11:10] | See Processor-ETM Interface Register on page 3-32 |
| ETMDA[31, 0]   | ITETMIF      | [7:6]   | See Processor-ETM Interface Register on page 3-32 |
| ETMDCTL[11, 0] | ITETMIF      | [5:4]   | See Processor-ETM Interface Register on page 3-32 |
| ETMDD[63, 0]   | ITETMIF      | [9:8]   | See Processor-ETM Interface Register on page 3-32 |
| ETMIA[31, 1]   | ITETMIF      | [3:2]   | See Processor-ETM Interface Register on page 3-32 |
| ETMICTL[13, 0] | ITETMIF      | [1:0]   | See Processor-ETM Interface Register on page 3-32 |
| ETMWFIPENDING  | ITMISCIN     | [5]     | See Miscellaneous Inputs Register on page 3-35    |
| EVNTBUS[54, 0] | ITETMIF      | [14:12] | See Processor-ETM Interface Register on page 3-32 |
| EXTIN[3:0]     | ITMISCIN     | [3:0]   | See Miscellaneous Inputs Register on page 3-35    |
| TRIGGERACK     | ITTRIGGERACK | [0]     | See Trigger Acknowledge Register on page 3-36     |

# **Using the Integration Test Registers**

Bit[0] of the ETMITCTRL register has the following functionality:

When bit[0] of ETMITCTRL is set to 1:

- Values written to the write-only integration test registers map onto the specified outputs of the macrocell. For example, writing 0x3 to ITMISCOUT[9:8] causes **EXTOUT[1:0]** to take the value 0x3.
- Values read from the read-only integration test registers correspond to the values of the specified inputs of the macrocell. For example, if you read ITMISCIN[3:0] you obtain the value of **EXTIN[3:0**].

When bit[0] of ETMITCTRL is set to 0:

- Reading an Integration Test Register returns an Unpredictable value.
- The effect of attempting to write to an Integration Test Register, other than the read-only Integration Test Registers, is Unpredictable.

\_\_\_\_\_ Note \_\_\_\_\_

You must not attempt to write to an Integration Test Register unless you have set bit[0] of ETMITCTRL to 1.

See the *ARM*® *Embedded Trace Macrocell Architecture Specification* for more details of ETMITCTRL.

# **Processor-ETM Interface Register**

The ITETMIF characteristics are:

| Purpose           | Reads the state of the ETM input pins shown in Table 3-19.                                                                                                                 |  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The value of the register depends on the signals on the input pins when the register is read.</li> </ul> |  |
| Configurations    | Available in all configurations.                                                                                                                                           |  |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                  |  |

Figure 3-12 shows the ITETMIF bit assignments.



Figure 3-12 ITETMIF bit assignments



#### Table 3-19 ITETMIF bit assignments

| Bits    | Name        | Function                                                      |
|---------|-------------|---------------------------------------------------------------|
| [31:14] | -           | Reserved. Read undefined.                                     |
| [13]    | EVNTBUS[54] | Returns the value of the EVNTBUS[54] input pin. <sup>a</sup>  |
| [12]    | EVNTBUS[0]  | Returns the value of the EVNTBUS[0] input pin. <sup>a</sup>   |
| [11]    | ETMCID[31]  | Returns the value of the ETMCID[31] input pin <sup>a</sup> .  |
| [10]    | ETMCID[0]   | Returns the value of the ETMCID[0] input pin <sup>a</sup> .   |
| [9]     | ETMDD[63]   | Returns the value of the ETMDD[63] input pin <sup>a</sup> .   |
| [8]     | ETMDD[0]    | Returns the value of the ETMDD[0] input pin <sup>a</sup> .    |
| [7]     | ETMDA[31]   | Returns the value of the ETMDA[31] input pin <sup>a</sup> .   |
| [6]     | ETMDA[0]    | Returns the value of the ETMDA[0] input pin <sup>a</sup> .    |
| [5]     | ETMDCTL[11] | Returns the value of the ETMDCTL[11] input pin <sup>a</sup> . |
| [4]     | ETMDCTL[0]  | Returns the value of the ETMDCTL[0] input pin <sup>a</sup> .  |
| [3]     | ETMIA[31]   | Returns the value of the ETMIA[31] input pin <sup>a</sup> .   |

| Bits | Name        | Function                                                             |
|------|-------------|----------------------------------------------------------------------|
| [2]  | ETMIA[1]    | Returns the value of the <b>ETMIA[1]</b> input pin <sup>a</sup> .    |
| [1]  | ETMICTL[13] | Returns the value of the <b>ETMICTL[13]</b> input pin <sup>a</sup> . |
| [0]  | ETMICTL[0]  | Returns the value of the <b>ETMICTL[0]</b> input pin <sup>a</sup> .  |

## Table 3-19 ITETMIF bit assignments (continued)

a. When a bit is set to 0, the corresponding input pin is LOW. When a bit is set to 1, the corresponding input pin is HIGH.

The ITETMIF bit values always correspond to the physical state of the input pins.

# **Miscellaneous Outputs Register**

The ITMISCOUT characteristics are:

| Purpose           | Sets the state of the output pins shown in Table 3-20.                                                                                                                   |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The value of the register sets the signals on the output pins when the register is written.</li> </ul> |  |
| Configurations    | Available in all configurations.                                                                                                                                         |  |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                |  |

Figure 3-13 shows the ITMISCOUT bit assignments.



#### Figure 3-13 ITMISCOUT bit assignments

Table 3-20 ITMISCOUT bit assignments

Table 3-20 lists the ITMISCOUT bit assignments.

| Bits    | Name        | Function                                                 |  |  |
|---------|-------------|----------------------------------------------------------|--|--|
| [31:10] | -           | Reserved. Write as zero.                                 |  |  |
| [9:8]   | EXTOUT      | Drives the <b>EXTOUT[1:0]</b> output pins <sup>a</sup> . |  |  |
| [7:6]   | -           | Reserved. Write as zero.                                 |  |  |
| [5]     | ETMWFIREADY | Drives the <b>nETMWFIREADY</b> output pin <sup>a</sup> . |  |  |
| [4]     | ETMDBGRQ    | Drives the <b>ETMDBGRQ</b> output pin <sup>a</sup> .     |  |  |
| [3:0]   | -           | Reserved. Write as zero.                                 |  |  |
| 117     |             |                                                          |  |  |

a. When an input pin is LOW, the corresponding register bit is 0.

When an input pin is HIGH, the corresponding register bit is 1.

The ITMISCOUT bit values correspond to the physical state of the output pins.

# **Miscellaneous Inputs Register**

The ITMISCIN characteristics are:

| Purpose           | Reads the state of the input pins shown in Table 3-21.                                                                                                                          |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits depend on the signals on the input pins when the register is read.</li> </ul> |  |
| Configurations    | Available in all configurations.                                                                                                                                                |  |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                       |  |

Figure 3-14 shows the ITMISCIN bit assignments.



#### Figure 3-14 ITMISCIN bit assignments

Table 3-21 lists the ITMISCIN bit assignments.

#### Table 3-21 ITMISCIN bit assignments

| Bits   | Name                                                              | Function                                                               |  |
|--------|-------------------------------------------------------------------|------------------------------------------------------------------------|--|
| [31:6] | -                                                                 | Reserved. Read Undefined.                                              |  |
| [5]    | ETMWFIPENDING                                                     | Returns the value of the <b>ETMWFIPENDING</b> input pin <sup>a</sup> . |  |
| [4]    | DBGACK                                                            | Returns the value of the <b>DBGACK</b> input pin <sup>a</sup> .        |  |
| [3:0]  | EXTIN                                                             | Returns the value of the <b>EXTIN</b> [3:0] input pins <sup>a</sup> .  |  |
| a. V   | a. When an input pin is LOW, the corresponding register bit is 0. |                                                                        |  |

When an input pin is HIGH, the corresponding register bit is 1.

The ITMISCIN bit values always correspond to the physical state of the input pins.

# Trigger Acknowledge Register

The ITTRIGGERACK characteristics are:

| Purpose           | Reads the state of the <b>TRIGGERACK</b> input pin shown in Table 3-22.                                                                                                       |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits depend on the signal on the input pin when the register is read.</li> </ul> |
| Configurations    | Available in all configurations.                                                                                                                                              |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                     |

Figure 3-15 shows the ITTRIGGERACK bit assignments.



TRIGGERACK┘

### Figure 3-15 ITTRIGGERACK bit assignments

Table 3-22 lists the ITTRIGGERACK bit assignments.

#### Table 3-22 ITTRIGGERACK bit assignments

| Bits   | Name                                            | Function                                                                                                                                                                                   |
|--------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | -                                               | Reserved. Read Undefined.                                                                                                                                                                  |
| [0]    | TRIGGERACK                                      | Returns the value of the <b>TRIGGERACK</b> input pin <sup>a</sup> .                                                                                                                        |
| W      | hen the <b>TRIGGERAC</b><br>the ITTRIGGERACK bi | <ul> <li>K input pin is LOW, the register bit is 0.</li> <li>K input pin is HIGH, the register bit is 1.</li> <li>t value always corresponds to the physical state of the input</li> </ul> |

# **Trigger Request Register**

The ITTRIGGERREQ characteristics are:

| Purpose           | Sets the <b>TRIGGER</b> output pin shown in Table 3-23.                                                                                                                      |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits set the signals on the output pin when the register is written.</li> </ul> |
| Configurations    | Available in all configurations.                                                                                                                                             |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                    |

Figure 3-16 shows the ITTRIGGERREQ bit assignments.



TRIGGER┘

#### Figure 3-16 ITTRIGGERREQ bit assignments

Table 3-23 lists the ITTRIGGERREQ bit assignments.

#### Table 3-23 ITTRIGGERREQ bit assignments

| Bits   | Name          | Function                                                                                         |
|--------|---------------|--------------------------------------------------------------------------------------------------|
| [31:1] | -             | Reserved. Write as zero.                                                                         |
| [0]    | TRIGGER       | Drives the <b>TRIGGER</b> output pin <sup>a</sup> .                                              |
| Т      | RIGGER outpu  | GGERREQ register bit is set to 0, the<br>at pin is LOW.<br>GGERREQ register bit is set to 1, the |
|        | RIGGER output | 2 8                                                                                              |
|        | he ITTRIGGER  | REQ bit values always correspond to the he output pins.                                          |

# **ATB Data Register 0**

The ITATBDATA0 characteristics are:

| Purpose           | Sets the state of the ATDATA output pins shown in Table 3-24.                                                                                                                 |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits set the signals on the output pins when the register is written.</li> </ul> |
| Configurations    | Available in all configurations.                                                                                                                                              |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                     |

Figure 3-17 shows the ITATBDATA0 bit assignments.

| 31 |  |          |  | 5 | 4 |        | 0 |
|----|--|----------|--|---|---|--------|---|
|    |  | Reserved |  |   |   | ATDATA |   |

#### Figure 3-17 ITATBDATA0 bit assignments

Table 3-24 lists the ITATBDATA0 bit assignments.

## Table 3-24 ITATBDATA0 bit assignments

| Bits   | Name   | Function                                                       |
|--------|--------|----------------------------------------------------------------|
| [31:5] | -      | Reserved. Write as zero.                                       |
| [4:0]  | ATDATA | Drives the ATDATA[31, 23, 15, 7, 0] output pins <sup>a</sup> . |

a. When a bit is set to 0, the corresponding output pin is LOW.
 When a bit is set to 1, the corresponding output pin is HIGH.
 The ITATBDATA0 bit values always correspond to the physical state of the output pins.

# **ATB Control Register 2**

The ITATBCTR2 characteristics are:

| Purpose           | Reads the state of the <b>AFVALID</b> and <b>ATREADY</b> input pins from the ATB bus, as shown in Table 3-25.                                                                   |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits depend on the signals on the input pins when the register is read.</li> </ul> |
| Configurations    | Available in all configurations.                                                                                                                                                |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                       |

Figure 3-18 shows the ITATBCTR2 bit assignments.

| 31 |  |   |          |  | 2       | 1 | 0 |
|----|--|---|----------|--|---------|---|---|
|    |  | F | Reserved |  |         |   |   |
|    |  |   |          |  | AFVALID |   |   |
|    |  |   |          |  | ATREADY |   |   |

#### Figure 3-18 ITATBCTR2 bit assignments

Table 3-25 lists the ITATBCTR2 bit assignments.

### Table 3-25 ITATBCTR2 bit assignments

| Bits   | Name    | Function                                                         |
|--------|---------|------------------------------------------------------------------|
| [31:2] | -       | Reserved. Read undefined.                                        |
| [1]    | AFVALID | Returns the value of the <b>AFVALID</b> input pin <sup>a</sup> . |
| [0]    | ATREADY | Returns the value of the ATREADY input pin <sup>a</sup> .        |

a. When an input pin is LOW, the corresponding register bit is 0.
 When an input pin is HIGH, the corresponding register bit is 1.
 The ITATBCTR2 bit values always correspond to the physical state of the input pins.

# **ATB Control Register 1**

The ITATBCTR1 characteristics are:

| Purpose           | Sets the state of the ATID output pins shown in Table 3-26.                                                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits set the signals on the output pins when the register is written.</li> </ul> |
| Configurations    | Available in all configurations.                                                                                                                                              |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                     |

Figure 3-19 shows the ITATBCTR1 bit assignments.

| 31 |         |   | 7 | 6   | C    |
|----|---------|---|---|-----|------|
|    | Reserve | d |   | ļ , | ATID |

### Figure 3-19 ITATBCTR1 bit assignments

Table 3-26 lists the ITATBCTR1 bit assignments.

#### Table 3-26 ITATBCTR1 bit assignments

| Bits                                                            | Name                                                                                 | Function                                               |  |
|-----------------------------------------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------|--|
| [31:7]                                                          | -                                                                                    | Reserved. Write as zero.                               |  |
| [6:0]                                                           | ATID                                                                                 | Drives the <b>ATID[6:0]</b> output pins <sup>a</sup> . |  |
| a. When a bit is set to 0, the corresponding output pin is LOW. |                                                                                      |                                                        |  |
| When a bit is set to 1, the corresponding output pin is HIGH.   |                                                                                      |                                                        |  |
|                                                                 | The ITATBCTR1 bit values always correspond to the physical state of the output pins. |                                                        |  |

# **ATB Control Register 0**

The ITATBCTR0 characteristics are:

| Purpose           | Sets the state of the output pins shown in Table 3-27.                                                                                                                        |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Usage constraints | <ul> <li>Available when bit[0] of ETMITCTRL is set to 1.</li> <li>The values of the register bits set the signals on the output pins when the register is written.</li> </ul> |  |
| Configurations    | Available in all configurations.                                                                                                                                              |  |
| Attributes        | See the register summaries in Table 3-1 on page 3-5, Table 3-7 on page 3-15, and Table 3-18 on page 3-30.                                                                     |  |

Figure 3-20 shows the ITATBCTR0 bit assignments.



## Figure 3-20 ITATBCTR0 bit assignments

Table 3-27 lists the ITATBCTR0 bit assignments.

### Table 3-27 ITATBCTR0 bit assignments

| Bits    | Name    | Function                                                   |
|---------|---------|------------------------------------------------------------|
| [31:10] | -       | Reserved. Write as zero.                                   |
| [9:8]   | ATBYTES | Drives the <b>ATBYTES</b> [1:0] output pins <sup>a</sup> . |
| [7:2]   | -       | Reserved. Write as zero.                                   |
| [1]     | AFREADY | Drives the <b>AFREADY</b> output pin <sup>a</sup> .        |
| [0]     | ATVALID | Drives the <b>ATVALID</b> output pin <sup>a</sup> .        |
|         |         |                                                            |

a. When a bit is set to 0, the corresponding output pin is LOW.
 When a bit is set to 1, the corresponding output pin is HIGH.
 The ITATBCTR0 bit values always correspond to the physical state of the output pins.
# Appendix A Signal Descriptions

This appendix describes the signals used in the macrocell. It contains the following sections:

- Signal descriptions on page A-2.
- *Clocks and resets* on page A-4.
- *Processor trace interface* on page A-5.
- *APB interface* on page A-6.
- *ATB interface* on page A-7.
- *ETM-R5 macrocell sharing signals* on page A-9.
- *Test interface* on page A-10.

## A.1 Signal descriptions

Table A-1 lists the ETM-R5 macrocell signals in alphabetical order. The following sections show the signal directions and the clock domains, for each of the interfaces.

|                 | Table A-1 ETM-R5 macrocell                          |
|-----------------|-----------------------------------------------------|
| Signal name     | Description                                         |
| AFREADY         | ATB interface on page A-7                           |
| AFVALID         | ATB interface on page A-7                           |
| ASICCTL[7:0]    | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| ATBYTES[1:0]    | ATB interface on page A-7                           |
| ATCLK           | Clocks and resets on page A-4                       |
| ATCLKEN         | Clocks and resets on page A-4                       |
| ATDATA[31:0]    | ATB interface on page A-7                           |
| ATID[6:0]       | ATB interface on page A-7                           |
| ATREADY         | ATB interface on page A-7                           |
| ATVALID         | ATB interface on page A-7                           |
| CLK             | Clocks and resets on page A-4                       |
| CORESELECT[2:0] | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| DBGACK          | Processor trace interface on page A-5               |
| DBGEN           | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| ETMCID[31:0]    | Processor trace interface on page A-5               |
| ETMDA[31:0]     | Processor trace interface on page A-5               |
| ETMDBGRQ        | Processor trace interface on page A-5               |
| ETMDCTL[11:0]   | Processor trace interface on page A-5               |
| ETMDD[63:0]     | Processor trace interface on page A-5               |
| ETMEN           | ATB interface on page A-7                           |
| ETMIA[31:1]     | Processor trace interface on page A-5               |
| ETMICTL[13:0]   | Processor trace interface on page A-5               |
| CTMPWRUP        | Processor trace interface on page A-5               |
| ETMWFIPENDING   | Processor trace interface on page A-5               |
| EVNTBUS[54:0]   | Processor trace interface on page A-5               |
| EXTIN[3:0]      | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| EXTOUT[1:0]     | ETM-R5 macrocell sharing signals on                 |

#### Table A-1 ETM-R5 macrocell signals (continued)

| Signal name     | Description                                         |
|-----------------|-----------------------------------------------------|
| FIFOPEEK[6:0]   | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| MAXCORES[2:0]   | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| MAXEXTIN[2:0]   | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| MAXEXTOUT[1:0]  | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| nETMWFIREADY    | Processor trace interface on page A-5               |
| NIDEN           | <i>ETM-R5 macrocell sharing signals</i> on page A-9 |
| PADDRDBG[11:2]  | APB interface on page A-6                           |
| PADDRDBG31      | APB interface on page A-6                           |
| PCLKDBG         | Clocks and resets on page A-4                       |
| PCLKENDBG       | Clocks and resets on page A-4                       |
| PENABLEDBG      | APB interface on page A-6                           |
| PRDATADBG[31:0] | APB interface on page A-6                           |
| PREADYDBG       | APB interface on page A-6                           |
| PRESETDBGn      | Clocks and resets on page A-4                       |
| PSELDBG         | APB interface on page A-6                           |
| PWDATADBG[31:0] | APB interface on page A-6                           |
| PWRITEDBG       | APB interface on page A-6                           |
| RSTBYPASS       | Test interface on page A-10                         |
| SE              | Test interface on page A-10                         |
| nSYSPORESET     | Clocks and resets on page A-4                       |
| TRIGGER         | The trigger signals on page A-8                     |
| TRIGGERACK      | The trigger signals on page A-8                     |
| TRIGSBYPASS     | The trigger signals on page A-8                     |

## A.2 Clocks and resets

Table A-2 lists the clock and reset signals. Clock domains, where specified, give the clock that input signals must be generated and output signals sampled.

|             |       | -                                                |
|-------------|-------|--------------------------------------------------|
| Signal name | Туре  | Description                                      |
| CLK         | Input | This is the main clock for the ETM-R5 macrocell. |
| ATCLK       | Input | ATB interface clock.                             |
| ATCLKEN     | Input | Enable signal for ATCLK.                         |
| PCLKDBG     | Input | Debug APB clock.                                 |
| PCLKENDBG   | Input | Debug APB clock enable.                          |
| PRESETDBGn  | Input | Debug APB interface reset. Resets all registers. |
| nSYSPORESET | Input | Powerup (main) reset. Resets all registers.      |

#### Table A-2 Clock and reset signals

## A.3 Processor trace interface

Table A-3 lists the trace interface signals from the Cortex-R5. Clock domains, where specified, give the clock that input signals must be generated and output signals sampled.

### Table A-3 Processor trace interface signals

| Signal name   | Туре   | Description                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ETMICTL[13:0] | Input  | Instruction control signals.                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| ETMIA[31:1]   | Input  | Address for executed instruction.                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| ETMDCTL[11:0] | Input  | Data control signals.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| ETMDA[31:0]   | Input  | Address for data transfer.                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| ETMDD[63:0]   | Input  | Contains the data value for a Load, Store, MRC, or MCR instruction.                                                                                                                                                                                                                                                                                                                                           |  |  |
| ETMCID[31:0]  | Input  | Current value of the processor Context ID Register.                                                                                                                                                                                                                                                                                                                                                           |  |  |
| EVNTBUS[54:0] | Input  | Gives the status of the performance monitoring events. Used as extended external inputs.                                                                                                                                                                                                                                                                                                                      |  |  |
| ETMWFIPENDING | Input  | Indicates that the Cortex-R5 processor is about to go into Standby mode, and that the ETM must drain its FIFO.                                                                                                                                                                                                                                                                                                |  |  |
| nETMWFIREADY  | Output | Indicates that the macrocell FIFO is empty and that the Cortex-R5 processor can be put into Standby mode.                                                                                                                                                                                                                                                                                                     |  |  |
| ETMDBGRQ      | Output | Request from the macrocell for the core to enter debug state. This must be ORed with any ASIC-level <b>DBGRQ</b> signals before being connected to the core <b>EDBGRQ</b> input.                                                                                                                                                                                                                              |  |  |
| DBGACK        | Input  | Indicates that the core is in debug state.<br>This signal is connected to the core general purpose <b>DBGACK</b> output, so that it can determine<br>when <b>ETMDBGRQ</b> can be deasserted. It is also used for other purposes in the ETM, and care<br>must be taken to ensure the timing of this signal is appropriate because it does not come through<br>the main interface between the core and the ETM. |  |  |
| ETMPWRUP      | Output | <ul> <li>When HIGH, indicates that the macrocell is in use.</li> <li>When LOW:</li> <li>External logic supporting the macrocell can be clock-gated to conserve power.</li> <li>The Cortex-R5 processor disables the interface.</li> <li>Logic within the macrocell is clock-gated to conserve power.</li> </ul>                                                                                               |  |  |

## A.4 APB interface

Table A-4 lists the APB signals. Clock domains, where specified, give the clock that input signals must be generated and output signals sampled.

#### Table A-4 APB signals

| Signal name     | Туре   | Description                                                                                                                                                                                                 |
|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PADDRDBG[11:2]  | Input  | Debug APB Address Bus.                                                                                                                                                                                      |
| PADDRDBG31      | Input  | <ul> <li>Originates as an output signal from the DAP:</li> <li>PADDRDBG31 at logic 1 indicates an access from hardware (JTAG).</li> <li>PADDRDBG31 at logic 0 indicates an access from software.</li> </ul> |
| PENABLEDBG      | Input  | The Debug APB interface is enabled for a transfer.                                                                                                                                                          |
| PSELDBG         | Input  | Debug APB slave select signal.                                                                                                                                                                              |
| PREADYDBG       | Output | Extend Debug APB transfers.                                                                                                                                                                                 |
| PRDATADBG[31:0] | Output | Debug APB read data.                                                                                                                                                                                        |
| PWDATADBG[31:0] | Input  | Debug APB write data.                                                                                                                                                                                       |
| PWRITEDBG       | Input  | Debug APB transfer direction: 0 is Read, 1 is Write.                                                                                                                                                        |

# A.5 ATB interface

Table A-5 lists the ATB signals. Clock domains, where specified, give the clock that input signals must be generated and output signals sampled.

| Table | A-5         | ATB | sian  | als |
|-------|-------------|-----|-------|-----|
| Table | <b>A</b> -3 |     | Jight | ais |

| Signal name  | Туре   | Description                                                                  |
|--------------|--------|------------------------------------------------------------------------------|
| AFREADY      | Output | ATB interface FIFO flush finished.                                           |
| AFVALID      | Input  | ATB interface FIFO flush request.                                            |
| ATBYTES[1:0] | Output | Size of ATDATA.                                                              |
| ATDATA[31:0] | Output | ATB interface data.                                                          |
| ATID[6:0]    | Output | ATB interface trace source ID.                                               |
| ATREADY      | Input  | ATDATA can be accepted.                                                      |
| ATVALID      | Output | ATB interface data valid.                                                    |
| ETMEN        | Output | Enable signal for trace output from the ETM, driven by bit[11] of the ETMCR. |

### A.5.1 The trigger signals

Table A-6 lists the trigger signals. Clock domains, where specified, give the clock that input signals must be generated and output signals sampled.

\_

| Signal name | Туре   | Description                     |
|-------------|--------|---------------------------------|
| TRIGGER     | Output | Trigger request status signal.  |
| TRIGGERACK  | Input  | ATB trigger acknowledge.        |
| TRIGSBYPASS | Input  | Trigger synchronization bypass. |

#### Table A-6 Trigger signals

The **TRIGSBYPASS**, **TRIGGER**, and **TRIGGERACK** signals control trigger behavior and indicate when a trigger occurs.

TRIGSBYPASS controls whether asynchronous registering and handshaking is performed:

- When **TRIGSBYPASS** is HIGH, **TRIGGER** is asserted for one **ATCLK** cycle, and **TRIGGERACK** is ignored.
- When TRIGSBYPASS is LOW, TRIGGER is asserted, and is held until TRIGGERACK is asserted. When TRIGGERACK is asserted, TRIGGER is de-asserted.

**TRIGGERACK** is synchronized to the **ATCLK** clock domain inside the ETM, using double registers.

## A.6 ETM-R5 macrocell sharing signals

Table A-7 lists the ETM-R5 macrocell sharing signals. Clock domains, where specified, give the clock that input signals must be generated and output signals sampled.

#### Table A-7 Miscellaneous signals

| Signal name     | Туре   | Description                                                                                                                                                                                                                                                                                                    |
|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORESELECT[2:0] | Output | Where an ETM is shared between multiple CPUs, this signal specifies which CPU to trace.<br>The value appears as bits[14:12] of the System Configuration Register.                                                                                                                                              |
| MAXCORES[2:0]   | Input  | Where an ETM is shared between multiple cores, this signal specifies the number of CPUs the ETM can trace. It must be tied to the number of CPUs sharing the ETM minus 1.<br>These signals determine the value of bits[14:12] of the System Configuration register, see the footnote to Table 3-1 on page 3-5. |
| ASICCTL[7:0]    | Output | General purpose outputs controlled by the ETMASICCR. See <i>ASIC Control Register</i> on page 3-22.                                                                                                                                                                                                            |
| DBGEN           | Input  | Invasive debug enable. When HIGH indicates that invasive debug is enabled.                                                                                                                                                                                                                                     |
| NIDEN           | Input  | Non-invasive debug enable. When HIGH indicates that non-invasive debug is enabled.                                                                                                                                                                                                                             |
| EXTIN[3:0]      | Input  | External input resources.                                                                                                                                                                                                                                                                                      |
| EXTOUT[1:0]     | Output | External outputs.                                                                                                                                                                                                                                                                                              |
| MAXEXTIN[2:0]   | Input  | Number of external inputs supported by the ASIC (maximum 4).<br>These signals determine the value bits[19:17] in the ETMCCR, see <i>Configuration Code Register</i> on page 3-20.                                                                                                                              |
| MAXEXTOUT[1:0]  | Input  | Number of external outputs supported by the ASIC (maximum 2).<br>These signals determine the value bits[22:20] in the ETMCCR, see <i>Configuration Code Register</i> on page 3-20.                                                                                                                             |
| FIFOPEEK[6:0]   | Output | For validation purposes only. Indicates when various events occur before being written to the FIFO.                                                                                                                                                                                                            |

# A.7 Test interface

Table A-8 lists the scan chain signals.

| Signal name | Туре  | Description                              |
|-------------|-------|------------------------------------------|
| RSTBYPASS   | Input | Reset synchronization bypass DFT signal. |
| SE          | Input | Scan enable DFT signal.                  |

# Appendix B AC Characteristics

This appendix describes the macrocell input and output signal timing. It contains the following section:

• *ETM-R5 macrocell input and output signal timing parameters* on page B-2.

## B.1 ETM-R5 macrocell input and output signal timing parameters

Signals are classified according to the percentage of the clock period taken up by internal logic.

- For inputs this is the delay between the input port and the first register.
- For outputs this is the delay between the last register and the output port.

The timing classifications used are based on these delays:

| Early  | The delay is less than 20% of the period.       |
|--------|-------------------------------------------------|
| Middle | The delay is between 20% and 80% of the period. |
| Late   | The delay is greater than 80% of the period.    |

Table B-1 describes the ETM-R5 macrocell signal timing parameters.

#### Table B-1 ETM-R5 macrocell signal timing parameters

|                 |                       | <b>J I</b> · · · · · |
|-----------------|-----------------------|----------------------|
| Signal name     | Timing classification | Input/Output         |
| AFREADY         | Middle                | Output               |
| AFVALID         | Middle                | Input                |
| ASICCTL[7:0]    | Middle                | Output               |
| ATBYTES[1:0]    | Middle                | Output               |
| ATCLK           | -                     | Input                |
| ATCLKEN         | Middle                | Input                |
| ATDATA[31:0]    | Middle                | Output               |
| ATID[6:0]       | Middle                | Output               |
| ATREADY         | Middle                | Input                |
| ATVALID         | Middle                | Output               |
| CLK             | -                     | Input                |
| CORESELECT[2:0] | Middle                | Output               |
| DBGACK          | Middle                | Input                |
| DBGEN           | Middle                | Input                |
| ETMCID[31:0]    | Middle                | Input                |
| ETMDA[31:0]     | Middle                | Input                |
| ETMDBGRQ        | Middle                | Output               |
| ETMDD[63:0]     | Middle                | Input                |
| ETMDCTL[11:0]   | Middle                | Input                |
| ETMEN           | Middle                | Output               |
| ETMIA[31:1]     | Middle                | Input                |
| ETMICTL[13:0]   | Middle                | Input                |
| ETMPWRUP        | Middle                | Output               |
| ETMWFIPENDING   | Middle                | Input                |
| EVNTBUS[54:0]   | Middle                | Input                |
|                 |                       |                      |

|                 |                       | , ,          |
|-----------------|-----------------------|--------------|
| Signal name     | Timing classification | Input/Output |
| EXTIN[3:0]      | Middle                | Input        |
| EXTOUT[1:0]     | Middle                | Output       |
| FIFOPEEK[6:0]   | Middle                | Output       |
| MAXCORES[2:0]   | Middle                | Input        |
| MAXEXTIN[2:0]   | Middle                | Input        |
| MAXEXTOUT[1:0]  | Middle                | Input        |
| nETMWFIREADY    | Middle                | Output       |
| NIDEN           | Middle                | Input        |
| PADDRDBG[11:2]  | Middle                | Input        |
| PADDRDBG31      | Middle                | Input        |
| PCLKDBG         | Middle                | Input        |
| PCLKENDBG       | Middle                | Input        |
| PENABLEDBG      | Middle                | Input        |
| PRDATADBG[31:0] | Middle                | Output       |
| PREADYDBG       | Late                  | Output       |
| PRESETDBGn      | Late                  | Input        |
| PSELDBG         | Middle                | Input        |
| PWDATADBG[31:0] | Middle                | Input        |
| PWRITEDBG       | Middle                | Input        |
| RSTBYPASS       | Middle                | Input        |
| SE              | Middle                | Input        |
| nSYSPORESET     | Middle                | Input        |
| TRIGGER         | Middle                | Output       |
| TRIGGERACK      | Middle                | Input        |
| TRIGSBYPASS     | Middle                | Input        |
|                 |                       |              |

Table B-1 ETM-R5 macrocell signal timing parameters (continued)

#### — Note -

Actual clock frequencies and input and output timing constraints vary according to application requirements and the silicon process technologies used. The maximum operating clock frequencies change according to the constraints and the process technology you use.

# Appendix C **Revisions**

This appendix describes the technical changes between released issues of this book.

#### Table C-1 Issue A

| Change        | Location | Affects |
|---------------|----------|---------|
| First release | -        | -       |

### Table C-2 Differences between issue A and issue B

| Change                                                                                                 | Location                | Affects       |
|--------------------------------------------------------------------------------------------------------|-------------------------|---------------|
| The clock domain for the CoreSight Trace ID register was changed to <b>ATCLK</b> instead of <b>CLK</b> | Table 3-2 on page 3-10  | All revisions |
| ETMCCER reset value                                                                                    | Table 3-1 on page 3-5   | All revisions |
| ETMLSR reset value                                                                                     | Table 3-1 on page 3-5   | All revisions |
| Footnote added to clarify the register access for the ETMLSR and ETMLAR                                | Table 3-1 on page 3-5   | All revisions |
| Footnote added to clarify ETMLSR reset value                                                           | Table 3-1 on page 3-5   | All revisions |
| Bit field value [10:3] for ETMCCER changed from 47 to 55                                               | Table 3-12 on page 3-24 | All revisions |