# Arm<sup>®</sup> CoreLink<sup>™</sup> SSE-050 Subsystem Revision: r0p1

**Technical Reference Manual** 



# Arm<sup>®</sup> CoreLink<sup>™</sup> SSE-050 Subsystem

### **Technical Reference Manual**

Copyright © 2017 Arm Limited (or its affiliates). All rights reserved.

#### **Release Information**

#### **Document History**

|  | Issue         Date           0000-00         15 June 2017           0001-00         08 December 2017 |  | Confidentiality  | Change                       |  |
|--|------------------------------------------------------------------------------------------------------|--|------------------|------------------------------|--|
|  |                                                                                                      |  | Non-Confidential | First release for r0p0       |  |
|  |                                                                                                      |  | Non-Confidential | Maintenance release for r0p1 |  |

#### **Non-Confidential Proprietary Notice**

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm. **No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.** 

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, third party patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

If any of the provisions contained in these terms conflict with any of the provisions of any click through or signed written agreement covering this document with Arm, then the click through or signed written agreement prevails over and supersedes the conflicting provisions of these terms. This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with <sup>®</sup> or <sup>™</sup> are registered trademarks or trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at *http://www.arm.com/company/policies/trademarks*.

Copyright © 2017 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

LES-PRE-20349

#### **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.

Unrestricted Access is an Arm internal classification.

#### **Product Status**

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

#### Web Address

http://www.arm.com

# Contents Arm<sup>®</sup> CoreLink<sup>™</sup> SSE-050 Subsystem Technical Reference Manual

|           | Preface                |                                   |      |
|-----------|------------------------|-----------------------------------|------|
|           |                        | About this book                   | 7    |
|           |                        | Feedback                          | 10   |
| Chapter 1 | Intro                  | oduction                          |      |
|           | 1.1                    | About IoT endpoints               | 1-12 |
|           | 1.2                    | Features of the SSE-050 Subsystem | 1-14 |
|           | 1.3                    | Compliance                        | 1-16 |
|           | 1.4                    | Product revisions                 | 1-17 |
| Chapter 2 | Functional description |                                   |      |
|           | 2.1                    | System top-level partitioning     | 2-19 |
|           | 2.2                    | Cortex-M3 processor block         | 2-20 |
|           | 2.3                    | Power management                  | 2-22 |
|           | 2.4                    | Clocks                            | 2-23 |
|           | 2.5                    | Resets                            | 2-24 |
|           | 2.6                    | Timer                             | 2-25 |
|           | 2.7                    | eFlash memory subsystem           | 2-27 |
|           | 2.8                    | Banked SRAM subsystem             | 2-29 |
|           | 2.9                    | AHB and APB expansion             | 2-31 |
|           | 2.10                   | Debug and Trace                   |      |

| Chapter 3  | Programmers model   |                                                   |           |
|------------|---------------------|---------------------------------------------------|-----------|
|            | 3.1                 | About this programmers model                      | 3-36      |
|            | 3.2                 | Memory map                                        |           |
|            | 3.3                 | Interrupts                                        | 3-41      |
|            | 3.4                 | Wakeup Interrupt Controller (WIC)                 |           |
|            | 3.5                 | Timer                                             | 3-45      |
|            | 3.6                 | System registers                                  |           |
| Appendix A | Signal descriptions |                                                   |           |
|            | A.1                 | Clock and reset signals                           | Аррх-А-48 |
|            | A.2                 | Interrupt signals                                 | Аррх-А-50 |
|            | A.3                 | SRAM signals                                      | Аррх-А-51 |
|            | A.4                 | Timer signals                                     | Аррх-А-52 |
|            | A.5                 | Bus signals                                       | Аррх-А-53 |
|            | A.6                 | Debug and Trace signals                           | Аррх-А-55 |
|            | A.7                 | CPU control, status, and power management signals | Аррх-А-58 |
|            | A.8                 | Memory remap signals                              | Аррх-А-60 |
|            | A.9                 | DFT signals                                       | Аррх-А-61 |
| Appendix B | Revisions           |                                                   |           |
|            | B.1                 | Revisions                                         | Аррх-В-63 |

# Preface

This preface introduces the Arm<sup>®</sup> CoreLink<sup>™</sup> SSE-050 Subsystem Technical Reference Manual.

It contains the following:

- *About this book* on page 7.
- Feedback on page 10.

## About this book

This book is for the Arm<sup>®</sup> CoreLink<sup>™</sup>Subsystem for Embedded (SSE)-050, and referred to as the SSE-050 Subsystem. It describes architectural information that facilitates the creation of SSE-050 Subsystem software or an SoC targeted at an *Internet of Things* (IoT) application.

## **Product revision status**

The *rmpn* identifier indicates the revision status of the product described in this book, for example, r1p2, where:

- rm Identifies the major revision of the product, for example, r1.
- pn Identifies the minor revision or modification status of the product, for example, p2.

## Intended audience

This book is written for software engineers who want to work with an Arm reference platform. The manual describes the functionality of the IoT Subsystem.

### Using this book

This book is organized into the following chapters:

### **Chapter 1 Introduction**

This chapter introduces the Arm CoreLink SSE-050 Subsystem.

## **Chapter 2 Functional description**

This chapter describes the functionality of the SSE-050 Subsystem.

### **Chapter 3 Programmers model**

This chapter describes the SSE-050 Subsystem memory regions and registers, and provides information on how to program a SoC that contains an implementation of the subsystem.

#### Appendix A Signal descriptions

This chapter summarizes the interface signals present in the SSE-050 Subsystem.

#### Appendix B Revisions

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

## Glossary

The Arm<sup>®</sup> 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 the Arm<sup>®</sup> Glossary for more information.

## **Typographic conventions**

#### 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>

Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example:

```
MRC p15, 0, <Rd>, <CRn>, <CRm>, <Opcode_2>
```

SMALL CAPITALS

Used in body text for a few terms that have specific technical meanings, that are defined in the *Arm*<sup>®</sup> *Glossary*. For example, IMPLEMENTATION DEFINED, IMPLEMENTATION SPECIFIC, UNKNOWN, and UNPREDICTABLE.

### **Timing diagrams**

The following figure explains the components used in timing diagrams. Variations, when they occur, have clear labels. You must not assume any timing information that is not explicit in the diagrams.

Shaded bus and signal areas are undefined, so the bus or signal can assume any value within the shaded area at that time. The actual level is unimportant and does not affect normal operation.



#### Figure 1 Key to timing diagram conventions

## 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 book contains information that is specific to this product. See the following documents for other relevant information.

### Arm publications

- Arm<sup>®</sup> Cortex<sup>®</sup>-M System Design Kit Technical Reference Manual (Arm DDI 0479).
  - Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Devices Generic User Guide (Arm DUI 0552).
- Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Processor Technical Reference Manual (Arm 100165).
- Arm<sup>®</sup> CoreSight<sup>™</sup> SoC-400 Technical Reference Manual (Arm 100536).
- Arm<sup>®</sup> CoreSight<sup>™</sup> Components Technical Reference Manual (Arm DDI 0314).
- Arm<sup>®</sup> Debug Interface Architecture Specification, ADIv5.0 to ADIv5.2 (Arm IHI 0031).
- Arm<sup>®</sup> Embedded Trace Macrocell Architecture Specification (Arm IHI 0014).
- Arm<sup>®</sup> AMBA<sup>®</sup> APB Protocol Specification, Version 2.0 (Arm IHI 0024).
- Arm<sup>®</sup> AMBA<sup>®</sup> 3 AHB-Lite Protocol Specification (Arm IHI 0033).
- Arm<sup>®</sup> Armv7-M Architecture Reference Manual (Arm DDI 0403).

The following confidential books are only available to licensees or require registration with Arm:

• Arm<sup>®</sup> CoreLink<sup>™</sup> SSE-050 Subsystem Configuration and Integration Manual (Arm DII 0300).

Other publications

None.

# Feedback

## 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 Arm CoreLink SSE-050 Subsystem Technical Reference Manual.
- The number 100918 0001 00 en.
- If applicable, the page number(s) to which your comments refer.
- 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 Arm CoreLink SSE-050 Subsystem.

It contains the following sections:

- *1.1 About IoT endpoints* on page 1-12.
- 1.2 Features of the SSE-050 Subsystem on page 1-14.
- 1.3 Compliance on page 1-16.
- *1.4 Product revisions* on page 1-17.

# 1.1 About IoT endpoints

The SSE-050 Subsystem delivers a process and technology agnostic reference that is preintegrated, validated, and a hardware and software subsystem that can be extended to provide an IoT endpoint system.

The following figure shows an IoT system consisting of several endpoints and a shared control node.



Figure 1-1 An IoT endpoint as part of a larger control system

The following figure shows a block diagram of the hardware and software in an endpoint solution.



### Figure 1-2 IoT endpoint HW and SW solution

A complete endpoint system typically contains the following components:

#### **Compute subsystem**

The SSE-050 Subsystem consists of the Cortex-M3 processor and associated bus, debug, expansion for persistent storage, and interface logic supplied by Arm.

AHB and APB interfaces are provided for connection to a flash memory controller, allowing an implementation that matches the target process to be integrated.

#### Reference system memory and peripherals

Additional memory, control, and peripheral components beyond the minimum SSE-050 Subsystem components.

Licensees of the SSE-050 Subsystem are provided with a testbench and example integration of some base peripherals. This example integration provides the starting point for customizing an SoC.

#### **Communication interface**

The endpoint can have some way of communicating with other nodes or masters in the system. This could be WiFi, Bluetooth, or a wired connection.

The Arm Cordio<sup>®</sup> BT4 radio IP is available as an option for the SSE-050 Subsystem. The subsystem expansion ports are however technology independent and other radio devices could be used instead of the Cordio radio IP. Radio-specific interfaces such as clock, reset, and power control must be implemented at the SoC level.

#### Sensor or control component

To be useful as an endpoint, the reference design is typically extended by adding sensors or control logic, for example, temperature input or motor speed control output.

## Software development environment

Arm provides a complete software development environment which includes the Arm Mbed<sup>™</sup> operating system, Arm or GCC compilers and debuggers, and firmware.

Any custom peripherals typically require corresponding third-party firmware that can be integrated into the software stack.

# 1.2 Features of the SSE-050 Subsystem

The SSE-050 Subsystem contains the following components:

- A Cortex-M3 processor:
  - Bit banding enables using standard instructions to read or modify of individual bits. The default
    implementation includes bit banding, but this can be configured during implementation.
  - Eight Memory Protection Unit (MPU) regions (optional).
  - *Nested Vectored Interrupt Controller* (NVIC) providing deterministic, high-performance interrupt handling with a configurable number of interrupts.
  - *Wakeup Interrupt Controller* (WIC) with configurable number of WIC lines (optional). Optionally you can replace the standard Cortex-M3 WIC with a latch-based version. See the *Arm*<sup>®</sup> *CoreLink*<sup>™</sup> *SSE-050 Subsystem Configuration and Integration Manual* for more information.
  - Little-endian memory addressing only for compatibility with typical eFlash controller and eFlash cache.

For more information, see the Arm® Cortex®-M3 Processor Technical Reference Manual.

- Integrated debug and trace:
  - Standalone system with a *Trace Port Interface Unit* (TPIU) and a *Serial Wire or JTAG Debug Port* (SWJ-DP).
  - Supports instruction trace using an *Embedded Trace Macrocell* (ETM) if licensed.
- Multilayer AMBA AHB-Lite interconnect:
  - Low-latency interconnect bus matrix.
  - Two AHB-Lite slave expansion ports for external AHB masters.
  - Two AHB-Lite master expansion ports for external AHB slaves.
  - Eleven APB4 master expansion ports (each with 4KB address space) to connect APB peripherals.
- Memory system, consisting of:

- Note -

- Placeholder for embedded flash controller and optionally cache.

The SSE-050 Subsystem can support the integration of any flash controller that can be integrated to an AHB memory interface and up to two APB control interfaces. The address map is configurable for two banks of 128KB or two banks of 256KB.

- Static memory (configurable as one to four 32KB banks) is provided in the example integration layer.
- Placeholder for representing a flash-memory implementation in the integration layer.
- Two APB timers:
  - Interrupt generation when the counter reaches 0.
  - Each timer has an **TIMERnEXTIN** signal that can be used as an enable or external clock.
  - Configurable privileged access mode.
- Example integration for typical closely-coupled peripherals, using components from CMSDK:
- Watchdog timer.
- UARTs.
- Application timers.
- True Random Number Generator (TRNG).
- Real Time Clock (RTC).
- Optional Cordio BT4 Radio integration ready:
  - AHB master and slave ports.
  - Reserved interrupt ports.

— Note –

- The Cordio BT4 IP is not provided with the SSE-050 Subsystem, and must be separately licensed from Arm.
- A third-party Bluetooth solution can be connected to the AHB expansion ports. However, this
  requires customized software and firmware to support the product.

The reference system contains the peripherals that are required to support a rich OS. The components that are highlighted in the following figure are not provided by the SSE-050 Subsystem. Other peripherals not included in the SSE-050 Subsystem might be required for specific application areas.



Figure 1-3 Example of an IoT endpoint SoC

# 1.3 Compliance

The SSE-050 Subsystem complies with, or includes components that comply with, the following specifications:

- *1.3.1 Arm architecture* on page 1-16.
- 1.3.2 Interrupt controller architecture on page 1-16.
- 1.3.3 Advanced Microcontroller Bus Architecture on page 1-16.

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

## 1.3.1 Arm architecture

The SSE-050 Subsystem implements the ARMv7-M architecture, which executes the Arm ARM-v7M Thumb instruction set.

See the Arm® ARMv7-M Architecture Reference Manual for more information.

## 1.3.2 Interrupt controller architecture

The SSE-050 Subsystem implements the Arm Nested Vectored Interrupt Controller (NVIC).

See the Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Processor Technical Reference Manual for more information.

### 1.3.3 Advanced Microcontroller Bus Architecture

The SSE-050 Subsystem complies with the:

- Advanced High Performance Bus (AHB-Lite) protocol. See the Arm<sup>®</sup> AMBA<sup>®</sup> 3 AHB-Lite Protocol Specification.
- Advanced Peripheral Bus (APB) protocol. See the Arm<sup>®</sup> AMBA<sup>®</sup> APB Protocol Specification, Version 2.0.

# 1.4 **Product revisions**

This section describes the differences in functionality between product revisions:

**r0p0-r0p1** Values of revision and part number ID updated in system register.

# Chapter 2 Functional description

This chapter describes the functionality of the SSE-050 Subsystem.

It contains the following sections:

- 2.1 System top-level partitioning on page 2-19.
- 2.2 Cortex-M3 processor block on page 2-20.
- 2.3 Power management on page 2-22.
- 2.4 Clocks on page 2-23.
- 2.5 Resets on page 2-24.
- 2.6 Timer on page 2-25.
- 2.7 eFlash memory subsystem on page 2-27.
- 2.8 Banked SRAM subsystem on page 2-29.
- 2.9 AHB and APB expansion on page 2-31.
- 2.10 Debug and Trace on page 2-34.

# 2.1 System top-level partitioning

The SSE-050 Subsystem consists of partitions of smaller sub-blocks. The SSE-050 Subsystem is extended by additional components in the SoC integration layer.

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

The provided example system is for information only and Arm expects system designers to customize it for their application requirements.

The following figure shows the top-level block diagram with the AHB-Lite and APB bus interconnections.



Figure 2-1 Bus interconnections

# 2.2 Cortex-M3 processor block

The following figure shows the block diagram for the Cortex-M3 processor logic and interface.



Figure 2-2 Cortex-M3 component

The implementation integrates the TPIU and SWJ-DP from the Cortex-M3 processor package in a similar way to the standard Cortex-M3 integration level. For basic usage, there is no requirement to license the CoreSight SoC IP.

The system designer can however choose to design a system with the separately licensed CoreSight SoC and replace the integration level with the one provided by CoreSight SoC. This will require modification of the subsystem and is not supported as a validated configuration.

Note -

For more information on the Cortex-M3 and the debug and trace logic, see the following documents:

- Arm<sup>®</sup> ARMv7-M Architecture Reference Manual.
- Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Processor Technical Reference Manual.
- Arm<sup>®</sup> CoreSight<sup>™</sup> Components Technical Reference Manual.
- Arm<sup>®</sup> Debug Interface Architecture Specification, ADIv5.0 to ADIv5.2.
- Arm<sup>®</sup> Embedded Trace Macrocell Architecture Specification.

## 2.3 Power management

Low-power operation is essential for most IoT endpoint devices that typically rely on a battery or on harvested energy.

The SSE-050 Subsystem is a single power domain system and it does not support control of different power domains within the SoC. It does however define the necessary HW handshake signals that can be connected to a *Power Management Unit* (PMU) at the SoC level.

SRAM power management is not present in the SSE-050 Subsystem because SRAM models are technology-dependent and are outside of the SSE-050 Subsystem block. Memory power mode support can be implemented at SoC level.

## **Related references**

A.7 CPU control, status, and power management signals on page Appx-A-58.

# 2.4 Clocks

The SSE-050 Subsystem does not implement a clock control infrastructure. The SSE-050 Subsystem is a single clock domain system that provides inputs for the clocks. Therefore all input clocks (except for the debug clocks) are identical in frequency and phase.

The target frequencies for the SSE-050 Subsystem and associated components are:

- The typical configuration is 50MHz when using a 55nm process.
- Embedded flash might impose a minimum clock frequency.
- 20kHZ for the JTAG when using a 55nm process.
- 32kHZ low-power mode (optional). This clock can typically be integrated with an eFlash controller to reduce toggle rates.

## 2.4.1 Component clocks

The subsystem does not implement architectural clock gating other than the Cortex-M3 and ETM internal gating. The SSE-050 Subsystem is a single clock domain. The component clocks can however be gated by a custom implementation at SoC level.

For a full list of component clocks, see A.1 Clock and reset signals on page Appx-A-48.

For a list of power-management related signals, see 2.3 Power management on page 2-22.

## **Related concepts**

2.3 Power management on page 2-22.

#### **Related references**

A.1 Clock and reset signals on page Appx-A-48.

## 2.5 Resets

The SSE-050 Subsystem has no internal reset generation implemented, except that the Cortex-M3 processor can be reset by the internal AIRCR.VECTRESET register bit of the NVIC.

All component resets in the SSE-050 Subsystem are connected to the subsystem boundary and can therefore be reset using reset input signals.

------ Note -----

The SSE-050 Subsystem is not designed to handle arbitrary reset patterns. The SoC integration and software must ensure that all resets are cleanly released before functional operation and no software reset is triggered to functioning components.

All resets are active low and may be asserted asynchronously. External reset synchronization is required to guarantee the clean deassertion of the resets in synchronization with the corresponding clocks.

For a full list of component reset signals, see A.1 Clock and reset signals on page Appx-A-48.

## 2.5.1 About boot after reset

There is one Cortex-M3 processor that is integrated into the SSE-050 Subsystem. After a processor reset deassertion, the Cortex-M3 processor starts fetching the addresses on the instruction AHB as follows:

- 1. 0x00000000: Fetch the stack pointer to initialize the SP register.
- 2. 0x00000004: Fetch the reset vector and jump to the reset vector value.
- 3. *Reset vector*: Start boot code execution.

Address 0x0000000 of the SSE-050 Subsystem is mapped to the flash AHB master statically. It is therefore not possible to directly boot from ROM attached to the AHB expansion port.

When eFlash is integrated on a final device the initial reset vector, SP and boot code can be written using the debugger. Alternatively the eFlash can be pre-loaded using a DFT interface as part of the production process.

## 2.5.2 Events

The following table lists events that can be used for multiprocessor systems.

#### Table 2-1 Cortex-M3 events

| Name     | Description                                                                                                                                                                                                                                                                                                                                                               |  |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CPU0RXEV | RX event input of the Cortex-M3. Causes a wakeup from a WFE instruction.                                                                                                                                                                                                                                                                                                  |  |
|          | Connect to <b>TXEV</b> s from other processors in a multiprocessor system. Input from ORing <b>TXEV</b> signals from other processors in the system. If different processors run at different frequencies then synchronizers must be used to guarantee that <b>TXEV</b> is synchronous to this processor. TXEV must also be a single-cycle pulse.<br>Tie LOW if not used. |  |
| CPU0TXEV | TX event output of the Cortex-M3. Event transmitted as a result of SEV instruction. This is a single-cycle pulse. You can use it to implement a more power efficient spin-lock in a multiprocessor system.<br>In a multiprocessor system, <b>TXEV</b> from each processor can be broadcast to the <b>RXEV</b> input of the other processors.                              |  |

—— Note —

Where a design contains a single Cortex-M3 processor, the system designer can choose to connect the RX event port to DMA done signals, or another hardware accelerator unit.

## 2.6 Timer

The SSE-050 Subsystem includes two instances of APB timers. These are required to satisfy the Mbed OS requirements.



Figure 2-3 Timer interfaces

See also A.4 Timer signals on page Appx-A-52.

## 2.6.1 Security Extension

Privilege mode enable signals determine whether only privileged accesses or both privileged and nonprivileged accesses can write to the timer registers.

## Table 2-2 Privilege mode enable input signals

| Signal          | Clock      | Description                                                                                                                                                                                                                                                        |  |
|-----------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| TIMER0PRIVMODEN | TMER0PCLK  | <ul> <li>Defines if the timer memory mapped registers are writeable only by privileged access:</li> <li>0: Non-privileged access can write registers.</li> <li>1: Only privileged access can write registers. You must set this for Mbed compatibility.</li> </ul> |  |
| TIMER1PRIVMODEN | TIMER1PCLK | <ul> <li>K Defines if the timer memory mapped registers are writeable only by privileged acc</li> <li>0: Non-privileged access can write registers.</li> <li>1: Only privileged access can write registers. You must set this for Mbed compatibility.</li> </ul>   |  |

## **Related references**

A.4 Timer signals on page Appx-A-52.

# 2.7 eFlash memory subsystem

In the example system that is delivered, cache, and flash controller are replaced by a simplified SRAM interface and model. These connections should be made in the level above the SSE-050 Subsystem.

The following figure shows the typical connections that you require for a full embedded flash and cache implementation.



#### Figure 2-4 Example flash system

## 2.7.1 Interfaces for flash memory integration

The SSE-050 Subsystem includes an AHB master, two APB slaves, and interrupts for use with flash memory. These are the default, recommended connections. Any alternative implementation for code memory must take into account the Cortex-M3 processor boot process, which always starts by fetching from address 0x00000000.

## AHB master port

An AHB master port permits an external flash memory subsystem to be connected to the subsystem. The signals of this port are prefixed with **TARGFLASH0**. This port maps to a 256KB or 512KB memory region, depending on the configuration.

## **APB** master ports

Three APB master ports are reserved for connecting an external flash memory system to the subsystem. The signals of these ports are prefixed **APBTARGEXP<3**, **9**, **or 10>**. Port **APBTARGEXP3** should be used to control a cache if it is present in the memory system. Ports **APBTARGEXP9** and **APBTARGEXP10** should be used to access the flash which is normally arranged in two banks to permit over-the-air code download to a device.

#### Interrupt connections

There are no dedicated interrupt connections for the memory subsystem. As a result, all of the interrupt signals from the processor are exposed at the subsystem boundary. **CPU0INTISR14** and **CPU0INTISR15** are recommended for use by the memory subsystem. For more details, see *3.3.1 Interrupt signals* on page 3-41 for the suggested interrupt connections.

## 2.8 Banked SRAM subsystem

The SSE-050 Subsystem infrastructure supports up to four 32KB SRAMs. At least one 32KB SRAM must be implemented (SRAM bank 0).

If a SRAM bank is not implemented and the corresponding **MTXREMAP** bits are 1, then the corresponding address space is mapped to the AHB Slave expansion port of the interconnect.

In the following figure, the **MTXREMAP** signals from the configuration logic must be static during functional operation.

The SRAM modules are outside of the SSE-050 Subsystem. The subsystem does not implement retention or powerdown supports for the SRAMs. It is the responsibility of the SoC integrator to implement power domains for the SRAM, and control the power modes of the SRAM banks with a SoC level PMU.

The AHB2SRAM bridge always responds with OKAY to all AHB accesses, even if the connected SRAM is not functional because for example it is powered-down or in retention mode.

It is the responsibility of the software to not read or write the SRAMs when they are not functional. If the software tries to access non-accessible SRAM, the AHB2SRAM bridge implementation ensures that system does not go into a deadlock state because of a non-responsive SRAM. The read data result is implementation-specific when SRAM is not powered.



Figure 2-5 SRAM interface

## **Related references**

A.3 SRAM signals on page Appx-A-51.

# 2.9 AHB and APB expansion

The following figure shows the AHB and APB bus structure.



#### Figure 2-6 AHB and APB expansion buses

Any un-used AHB and APB buses must be tied off to the appropriate values. Synthesis flows will typically optimize away any redundant logic that remains.

See also A.5 Bus signals on page Appx-A-53.

## 2.9.1 APB slave multiplexer

The APB slave multiplexer supports 16 APB slaves in the SSE-050 Subsystem. All ports are synchronous to the AHB expansion ports. Two APB ports are used for internal peripherals, the remaining APB ports are available to the subsystem boundary and can be connected to external peripherals.

The following table shows the expected usage of the APB ports in the SSE-050 Subsystem. Only the internal connections are made directly in the subsystem, the external connections are recommended, and match the example integration provided.

#### Table 2-3 APB ports

| APB port | Connection             |             |  |
|----------|------------------------|-------------|--|
|          | Peripheral             | Location    |  |
| PORT0    | TIMER0                 | Internal    |  |
| PORT1    | TIMER1                 | Internal    |  |
| PORT2    | Dual timer             | APBTARGEXP2 |  |
| PORT3    | Flash Cache if present | APBTARGEXP3 |  |
| PORT4    | UART0                  | APBTARGEXP4 |  |

## Table 2-3 APB ports (continued)

| APB port | Connection                           |              |  |  |
|----------|--------------------------------------|--------------|--|--|
|          | Peripheral                           | Location     |  |  |
| PORT5    | UART1                                | APBTARGEXP5  |  |  |
| PORT6    | RTC                                  | APBTARGEXP6  |  |  |
| PORT7    | Spare                                | APBTARGEXP7  |  |  |
| PORT8    | Watchdog                             | APBTARGEXP8  |  |  |
| PORT9    | External Flash Controller if present | APBTARGEXP9  |  |  |
| PORT10   | Spare                                | APBTARGEXP10 |  |  |
| PORT11   | Spare                                | APBTARGEXP11 |  |  |
| PORT12   | Spare                                | APBTARGEXP12 |  |  |
| PORT13   | Spare                                | APBTARGEXP13 |  |  |
| PORT14   | Spare                                | APBTARGEXP14 |  |  |
| PORT15   | TRNG                                 | APBTARGEXP15 |  |  |

If an APB expansion interface is not used to connect a peripheral, the port must be tied off properly at the SoC integration level.

\_\_\_\_\_ Note —

The stand-alone TRNG, which is available with the SSE-050 Subsystem, can be replaced with IP from the Arm Cryptocell products, which are licensed separately.

## 2.9.2 AHB expansion

This section describes the AHB expansion features of the SSE-050 Subsystem.

## AHB slave ports

Two AHB slave ports permit external AHB masters to be connected to the subsystem. These ports are prefixed with **INITEXP<0..1>**:

- INITEXP0 port is suitable for the AHB DMA master port of a communication interface.
- **INITEXP1** port can be used to connect any additional AHB master to the system.

----- Note -----

If one of the slave ports is not used, then it must be tied off properly at the SoC integration level.

#### AHB master ports

Two AHB master ports permit external AHB masters to be connected to the subsystem. These ports are prefixed with **TARGETEXP<0..1>**:

- TARGETEXP0 port is suitable for the AHB slave port of a communication interface.
- **TARGETEXP1** port can be used to connect any additional AHB slave to the system. Arm recommends that a secondary AHB interconnect is connected here for peripherals which are not latency critical.

## — Note –

If one of the master ports is not used, then the default slave must be connected to the port.

### **Related references**

A.5 Bus signals on page Appx-A-53.

# 2.10 Debug and Trace

In the Cortex-M3 integration level, the SWJ-DP is a combined JTAG-DP and SW-DP that enables you to connect either an SWD or JTAG probe to a target. It is the standard CoreSight debug port.

To make efficient use of package pins, the JTAG pins use an auto-detect mechanism that switches between JTAG-DP and SW-DP depending on which probe is connected.

The Cortex-M3 TPIU is an optional component that acts as a bridge between the on-chip trace data from the *Embedded Trace Macrocell* (ETM) and the *Instrumentation Trace Macrocell* (ITM), with separate IDs, to a data stream. The TPIU encapsulates IDs where required, and then the data stream is captured by a *Trace Port Analyzer* (TPA). The Cortex-M3 TPIU is specially designed for low-cost debug, and should not be used in any different trace subsystem topologies.

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

The default implementation reuses the TPIU and SWJ-DP from the Cortex-M3 package. This configuration is sufficient for single processor use, where an on-chip trace buffer is not required.

For more sophisticated multiprocessor debug solution, a full CoreSight SoC IP solution can be licensed and implemented. To implement a CoreSight derived system, the Cortex-M3 integration level within the subsystem must be replaced with the version provided by CoreSight SoC.

A timestamp source is included in the example integration. This can be useful to correlate trace information between an ETM and an ITM, but is not a requirement for trace to function.

## **Related references**

A.6 Debug and Trace signals on page Appx-A-55.

# Chapter 3 Programmers model

This chapter describes the SSE-050 Subsystem memory regions and registers, and provides information on how to program a SoC that contains an implementation of the subsystem.

It contains the following sections:

- 3.1 About this programmers model on page 3-36.
- *3.2 Memory map* on page 3-37.
- 3.3 Interrupts on page 3-41.
- 3.4 Wakeup Interrupt Controller (WIC) on page 3-44.
- *3.5 Timer* on page 3-45.
- 3.6 System registers on page 3-46.

# 3.1 About this programmers model

The following information applies to all registers:

- Do not attempt to access reserved or unused address locations. Attempting to access these locations can result in UNPREDICTABLE behavior.
- Unless otherwise stated in the accompanying text:
  - Do not modify register bits that are not defined.
  - On reads, ignore register bits that are not defined.
- The following describes the access type:

| Read and write. |
|-----------------|
| Read-only.      |
| Write-only.     |
|                 |

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

The example peripherals that connect in the example integration are not documented here. For more information about the peripherals that are used in example integration, see the *Arm*<sup>®</sup> *Cortex*<sup>®</sup>-*M System Design Kit Technical Reference Manual*.

## 3.2 Memory map

The following figure shows the memory map for the SSE-050 Subsystem and the example integration level.



#### Figure 3-1 Top-level memory map

#### 3.2.1 Remap

**REMAP[0-3]** are the SSE-050 Subsystem static configuration pins. Depending on the configured implementation, the memory map takes one of several compatible layouts.

Target software has to be aware of the specific memory map in use. The remapping feature of the AHB interconnect provides the following remapping options:

#### REMAP[0]

The Embedded eFlash memory region represents the maximum supported eFlash size: 512KB. If the size of the actual eFlash banks is 256KB, the upper 256KB can be remapped to the AHB expansion port as follows:

- 0: 512KB eFlash.
- 1: 256KB eFlash upper 256Kbytes mapped to AHB expansion port TARGETEXP1.

#### REMAP[1]

If SRAM1 is not present, the corresponding memory range can be mapped to AHB expansion port as follows:

- 0: SRAM1 present
- 1: SRAM1 not available, mapped to AHB expansion port TARGETEXP1

#### REMAP[2]

If SRAM2 is not present, the corresponding memory range can be mapped to AHB expansion port as follows:

- 0: SRAM2 present
- 1: SRAM2 not available, mapped to AHB expansion port TARGETEXP1

#### REMAP[3]

If SRAM3 is not present, the corresponding memory range can be mapped to AHB expansion port as follows:

- 0: SRAM3 present
- 1: SRAM3 not available, mapped to AHB expansion port **TARGETEXP1**

The PPB address region of the Cortex-M3 memory map is not accessible from the **INITEXP0** and **INITEXP1** ports. Any access to this region returns a SLVERR response.

The following table shows the memory map for the SSE-050 Subsystem Code and RAM regions.

#### Table 3-1 Code and SRAM regions

| Region | Start      | End        | Peripheral    | Size  | AHB bus matrix | R | Remap |   |   | Comment |
|--------|------------|------------|---------------|-------|----------------|---|-------|---|---|---------|
|        | Address    | Address    | name          |       | port           | 3 | 2     | 1 | 0 |         |
| Code   | 0x00000000 | 0x0003FFFF | Code memory   | 256KB | TARG_FLASH0    | - | -     | - | - | -       |
|        | 0x00040000 | 0x0007FFFF | Code memory   | 256KB | TARG_FLASH0    | - | -     | - | 0 | -       |
|        |            |            | AHB Expansion | 256KB | TARG_EXP1      | - | -     | - | 1 | -       |
|        | 0×00080000 | 0x1FFFFFFF | AHB Expansion | -     | TARG_EXP1      | - | -     | - | - | -       |

#### Table 3-1 Code and SRAM regions (continued)

| Region | Start      | End        | Peripheral    | Size | AHB bus matrix | R | em | ар |   | Comment                                     |
|--------|------------|------------|---------------|------|----------------|---|----|----|---|---------------------------------------------|
|        | Address    | Address    | name          |      | port           | 3 | 2  | 1  | 0 |                                             |
| SRAM   | 0x20000000 | 0x20007FFF | SRAM0         | 32KB | TARG_SRAM0     | - | -  | -  | - | Bit band region                             |
|        | 0x20008000 | 0x2000FFFF | SRAM1         | 32KB | TARG_SRAM1     | - | -  | 0  | - | Bit band region                             |
|        |            |            | AHB Expansion | 32KB | TARG_EXP1      | - | -  | 1  | - | Bit band region                             |
|        | 0x20010000 | 0x20017FFF | SRAM2         | 32KB | TARG_SRAM2     | - | 0  | -  | - | Bit band region                             |
|        |            |            | AHB Expansion | 32KB | TARG_EXP1      | - | 1  | -  | - | Bit band region                             |
|        | 0x20018000 | 0x2001FFFF | SRAM          | 32KB | TARG_SRAM3     | 0 | -  | -  |   | Bit band region                             |
|        |            |            | AHB Expansion | 32KB | TARG_EXP1      | 1 | -  | -  |   | Bit band region                             |
|        | 0x20020000 | 0x21FFFFFF | AHB Expansion | 32MB | TARG_EXP1      | - | -  | -  | - | Bit band region 0x20020000 to<br>0x200FFFFF |
|        | 0x22000000 | 0x23FFFFFF | AHB Expansion | 32MB | TARG_EXP1      | - | -  | -  | - | Bit band alias                              |
|        | 0x24000000 | 0x3FFFFFFF | AHB Expansion | -    | TARG_EXP1      | - | -  | -  | - | -                                           |

Each bit in the 1MB bit band region can be accessed individually by making an access to the corresponding word in the 32MB bit band alias region. Only bit [0] is used when you make an access to the bit band alias region.

The base bit band region can be accessed directly in the same way as normal memory, using word, halfword, or byte accesses.

#### 3.2.2 Peripheral, expansion, and system regions

The following table shows the memory map for the SSE-050 Subsystem peripherals, expansion, and system regions.

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

Each bit in the 1MB bit band region can be accessed individually by making an access to the corresponding word in the 32MB bit band alias region. Only bit [0] is used when you make an access to the bit band alias region. The base bit band region can be accessed directly in the same way as normal memory, using word, halfword, or byte accesses.

| Туре       | Start      | End        | Peripheral    | Size | AHB bus matrix | Bus fabric | Comment            |
|------------|------------|------------|---------------|------|----------------|------------|--------------------|
| Peripheral | 0x40000000 | 0x40000FFF | Timer0        | 4KB  | TARG_APB0      | APB port 0 | -                  |
| Peripheral | 0x40001000 | 0x40001FFF | Timer1        | 4KB  | TARG_APB0      | APB port 1 | -                  |
| Peripheral | 0x40002000 | 0x40002FFF | APB expansion | 4KB  | TARG_APB0      | APB port 2 | Use for dual timer |
| Peripheral | 0x40003000 | 0x40003FFF | APB Expansion | 4KB  | TARG_APB0      | APB port 3 | -                  |
| Peripheral | 0x40004000 | 0x40004FFF | APB expansion | 4KB  | TARG_APB0      | APB port 4 | Use for UART0      |
| Peripheral | 0x40005000 | 0x40005FFF | APB expansion | 4KB  | TARG_APB0      | APB port 5 | Use for UART1      |
| Peripheral | 0x40006000 | 0x40006FFF | APB expansion | 4KB  | TARG_APB0      | APB port 6 | Use for RTC        |
| Peripheral | 0x40007000 | 0x40007FFF | APB expansion | 4KB  | TARG_APB0      | APB port 7 | -                  |

#### Table 3-2 Expansion and system map

## Table 3-2 Expansion and system map (continued)

| Туре       | Start      | End        | Peripheral         | Size | AHB bus matrix | Bus fabric   | Comment                |
|------------|------------|------------|--------------------|------|----------------|--------------|------------------------|
| Peripheral | 0x40008000 | 0x40008FFF | APB expansion      | 4KB  | TARG_APB0      | APB port 8   | Use for watchdog       |
| Peripheral | 0x40009000 | 0x40009FFF | APB expansion      | 4KB  | TARG_APB0      | APB port 9   | Use for flash bank 0   |
| Peripheral | 0x4000A000 | 0x4000AFFF | APB Expansion      | 2KB  | TARG_APB0      | APB port 10  | Use for flash bank 1   |
| Peripheral | 0x4000B000 | 0x4000BFFF | APB expansion      | 4KB  | TARG_APB0      | APB port 11  | -                      |
| Peripheral | 0x4000C000 | 0x4000CFFF | APB expansion      | 4KB  | TARG_APB0      | APB port 12  | -                      |
| Peripheral | 0x4000D000 | 0x4000EFFF | APB expansion      | 4KB  | TARG_APB0      | APB port 13  | -                      |
| Peripheral | 0x4000E000 | 0x4000EFFF | APB expansion      | 4KB  | TARG_APB0      | APB port 14  | -                      |
| Peripheral | 0x4000F000 | 0x4000FFFF | APB expansion      | 4KB  | TARG_APB0      | APB port 15  | Use for TRNG           |
| Peripheral | 0x40010000 | 0x400FFFFF | AHB expansion      | 1MB  | TARG_EXP1      | -            | Bit band region        |
| Peripheral | 0x40100000 | 0x41FFFFFF | AHB expansion      | 32MB | TARG_EXP1      | -            | -                      |
| Peripheral | 0x42000000 | 0x43FFFFFF | AHB expansion      | 32MB | TARG_EXP1      | -            | Bit band alias         |
| RAM        | 0x60000000 | 0x7FFFFFFF | AHB Expansion      | -    | TARG_EXP1      | -            | -                      |
| RAM        | 0x80000000 | 0x9FFFFFFF | AHB Expansion      | -    | TARG_EXP1      | -            | -                      |
| Device     | 0xA0000000 | 0xA000FFFF | AHB Expansion      | 64KB | TARG_EXP0      | -            | Use for Radio ICCC     |
| Device     | 0xA0010000 | 0xBFFFFFFF | AHB Expansion      | -    | TARG_EXP1      | -            | -                      |
| Device     | 0xC0000000 | 0xDFFFFFFF | AHB Expansion      | -    | TARG_EXP1      | -            | -                      |
| System     | 0xE0000000 | 0xE0000FFF | ITM (or reserved)  | 4KB  | Default slave  | PPB-Internal | Implementation defined |
|            | 0xE0001000 | 0xE0001FFF | DWT (or reserved)  | 4KB  | Default slave  | PPB-Internal | Implementation defined |
|            | 0xE0002000 | 0xE0002FFF | FPB (or reserved)  | 4KB  | Default slave  | PPB-Internal | Implementation defined |
|            | 0xE0003000 | 0xE000DFFF | Reserved           | -    | Default slave  | PPB-Internal | -                      |
|            | 0xE000E000 | 0xE000EFFF | SCS (or reserved)  | 4KB  | Default slave  | PPB-Internal | Implementation defined |
|            | 0xE000F000 | 0xE003FFFF | Reserved           | -    | Default slave  | PPB-Internal | -                      |
|            | 0xE0040000 | 0xE0040FFF | TPIU (or reserved) | 4KB  | Default slave  | PPB-External | Implementation defined |
|            | 0xE0041000 | 0xE0041FFF | ETM (or reserved)  | 4KB  | Default slave  | PPB-External | Implementation defined |
|            | 0xE0042000 | 0xE00FEFFF | Reserved           | -    | Default slave  | PPB-External | -                      |
|            | 0xE00FF000 | 0xE00FFFFF | ROM table          | 4KB  | Default slave  | PPB-External | -                      |
|            | 0×E0100000 | Øxfffffff  | AHB expansion      | -    | TARG_EXP1      | -            | -                      |

## 3.3 Interrupts

This section describes the (Nested Vectored Interrupt Controller) NVIC and the interrupt signal map.

The NVIC supports:

- An implementation-defined number of interrupts, in the range 4-240 interrupts.
- A programmable priority level of 0-255 for each interrupt. A higher level corresponds to a lower priority, so level 0 is the highest interrupt priority.
- Level and pulse detection of interrupt signals.
- Dynamic reprioritization of interrupts.
- Grouping of priority values into group priority and subpriority fields.
- Interrupt tail-chaining.
- An external Non-Maskable Interrupt (NMI).
- Optional WIC, providing ultra-low power sleep mode support.

This section contains the following subsections:

- 3.3.1 Interrupt signals on page 3-41.
- *3.3.2 Registers* on page 3-43.

#### 3.3.1 Interrupt signals

This section describes interrupts and exceptions that the Cortex-M3 processor handles in the SSE-050 Subsystem.

#### Table 3-3 Exceptions

| No.  | Exception type      | Priority     | Description                                                                               |
|------|---------------------|--------------|-------------------------------------------------------------------------------------------|
| 1    | Reset               | -3           | Reset is invoked on powerup or a Warm reset.                                              |
| 2    | NMI                 | -2           | CPU0INTNMI port input. Arm recommends that a watchdog drives this interrupt if present.   |
| 3    | Hard Fault          | -1           | A Hard Fault is an exception that occurs because of an error during exception processing. |
| 4    | Memory manage fault | Programmable | Exception from MPU.                                                                       |
| 5    | Bus fault           | Programmable | Bus error of bus access to the area that is not controlled by the MPU.                    |
| 6    | Use fault           | Programmable | Error about operating instruction including undefined instruction.                        |
| 7-10 | Reserved            | -            | -                                                                                         |
| 11   | SVCall              | Programmable | Call.                                                                                     |
| 12   | Debug Monitor       | Programmable | Exception that is triggered by the SVC instruction.                                       |
| 13   | Reserved            | -            |                                                                                           |
| 14   | PendSV              | Programmable | PendSV is an interrupt-driven request for system-level service.                           |
| 15   | SysTick             | Programmable | SysTick exception is an exception the system timer generates when it reaches zero.        |

Exceptions from 16 to the maximum that is configured in the processor are defined by the implementation. Arm recommends that you re-use the following connections where your peripheral types are aligned with the examples. For systems that have fewer interrupts, the low numbered interrupt connections should be maintained if possible.

The following table shows the reference interrupts.

#### Table 3-4 Interrupts

| No. | Name         | Source                    | Description                               |
|-----|--------------|---------------------------|-------------------------------------------|
| 16  | CPU0INTISR0  | UART0                     | UART0 TX and RX combined                  |
| 17  | CPU0INTISR1  | Not used                  | -                                         |
| 18  | CPU0INTISR2  | UART1                     | UART1 TX and RX combined                  |
| 19  | CPU0INTISR3  | Reserved                  | Reserved for APB slaves                   |
| 20  | CPU0INTISR4  | Reserved                  | Reserved for APB slaves                   |
| 21  | CPU0INTISR5  | RTC                       | RTC interrupt                             |
| 22  | CPU0INTISR6  | GPIO0                     | Combined                                  |
| 23  | CPU0INTISR7  | Reserved                  | Combined                                  |
| 24  | CPU0INTISR8  | Timer0                    | Timer interrupt                           |
| 25  | CPU0INTISR9  | Timer1                    | Timer interrupt                           |
| 26  | CPU0INTISR10 | Dual timer                | Combined timer interrupt                  |
| 27  | CPU0INTISR11 | Reserved                  | Reserved for APB slaves                   |
| 28  | CPU0INTISR12 | All UARTs                 | UART combined overflow                    |
| 29  | CPU0INTISR13 | Reserved                  | Reserved for APB slaves                   |
| 30  | CPU0INTISR14 | Reserved                  | Reserved for APB Slaves                   |
| 31  | CPU0INTISR15 | Reserved                  | Reserved for APB Slaves                   |
| 32  | CPU0INTISR16 | GPIO0-0                   | -                                         |
| 33  | CPU0INTISR17 | GPIO0-1                   | -                                         |
| 34  | CPU0INTISR18 | GPIO0-2                   | -                                         |
| 35  | CPU0INTISR19 | GPIO0-3                   | -                                         |
| 36  | CPU0INTISR20 | GPIO0-4                   | -                                         |
| 37  | CPU0INTISR21 | GPIO0-5                   | -                                         |
| 38  | CPU0INTISR22 | GPIO0-6                   | -                                         |
| 39  | CPU0INTISR23 | GPIO0-7                   | -                                         |
| 40  | CPU0INTISR24 | GPIO0-8                   | -                                         |
| 41  | CPU0INTISR25 | GPIO0-9                   | -                                         |
| 42  | CPU0INTISR26 | GPIO0-10                  | -                                         |
| 43  | CPU0INTISR27 | GPIO0-11                  | -                                         |
| 44  | CPU0INTISR28 | GPIO0-12                  | -                                         |
| 45  | CPU0INTISR29 | GPIO0-13                  | -                                         |
| 46  | CPU0INTISR30 | GPIO0-14                  | -                                         |
| 47  | CPU0INTISR31 | GPIO0-15                  | -                                         |
| 48  | CPU0INTISR32 | Cache controller          | Cache or memory errors                    |
| 49  | CPU0INTISR33 | Embedded flash controller | Combined interrupts from flash controller |

#### Table 3-4 Interrupts (continued)

| No.    | Name             | Source   | Description    |
|--------|------------------|----------|----------------|
| 60     | CPU0INTISR44     | TRNG     | TRNG interrupt |
| 61-255 | CPU0INTISR45-239 | Not used | -              |

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

The interrupt signals from the peripherals are not connected directly to the interrupt controller. All signals go to the integration layer and can be connected differently by the system designer. Arm recommends that you reuse the mapping shown here for easier software reuse between similar devices.

#### 3.3.2 Registers

A summary of the interrupt controller registers is listed in the following table.

| Table 3-5 | Summary | of interrupt | controller | registers |
|-----------|---------|--------------|------------|-----------|
|-----------|---------|--------------|------------|-----------|

| Address               | Name                  | Туре | Reset value | Description                        |
|-----------------------|-----------------------|------|-------------|------------------------------------|
| 0×E000E004            | ICTR                  | RO   | -           | Interrupt Controller Type Register |
| 0xE000E100-0xE000E11C | NVIC_ISER0-NVIC_ISER7 | RW   | 0           | Interrupt Set Enable Registers     |
| 0xE000E180-0xE000E19C | NVIC_ICER0-NVIC_ICER7 | RW   | 0           | Interrupt Clear Enable Registers   |
| 0xE000E200-0xE000E21C | NVIC_ISPR0-NVIC_ISPR7 | RW   | 0           | Interrupt Set Pending Registers    |
| 0xE000E280-0xE000E29C | NVIC_ICPR0-NVIC_ICPR7 | RW   | 0           | Interrupt Clear Pending Registers  |
| 0xE000E300-0xE000E31C | NVIC_IABR0-NVIC_IABR7 | RO   | 0           | Interrupt Active Bit Registers     |
| 0xE000E400-0xE000E41F | NVIC_IPRO-NVIC_IPR7   | RW   | 0           | Interrupt Priority Registers       |

For more information on the interrupt controller, see the following documents:

- Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Processor Technical Reference Manual.
- Arm<sup>®</sup> ARMv7-M Architecture Reference Manual.

## 3.4 Wakeup Interrupt Controller (WIC)

The *Wakeup Interrupt Controller* (WIC) is a peripheral that can detect an interrupt and wake the processor from deep sleep mode. The WIC is enabled only when the system is in deep sleep mode.

The WIC is not programmable, and does not have any registers or user interface. It operates entirely from hardware signals.

When the WIC is enabled and the processor enters deep sleep mode, the power management unit in the system might powerdown the Cortex-M3 processor while retaining its software context. Wakeup operation requires the WIC to be powered up. When the WIC receives an interrupt, it takes several clock cycles to wakeup the processor and restore its state to enable it to process the interrupt. Therefore, the interrupt latency is increased in deep sleep mode.

For more information on the WIC, see the following documents:

- Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Processor Technical Reference Manual.
- Arm<sup>®</sup> CoreLink<sup>™</sup> SSE-050 Subsystem Configuration and Integration Manual.

# 3.5 Timer

A summary of the registers in the timer is provided in the following table.

### Table 3-6 Summary of timer registers

| Name      | Туре | Width | Reset value | Address offset | Description                                                    |
|-----------|------|-------|-------------|----------------|----------------------------------------------------------------|
| CTRL      | RW   | 4     | 0x0         | 0x000          | 3: Interrupt enable.                                           |
|           |      |       |             |                | 2: Select external input as clock.                             |
|           |      |       |             |                | 1: Select external input as enable.                            |
|           |      |       |             |                | 0: Enable.                                                     |
| VALUE     | RW   | 32    | 0x00000000  | 0x004          | Current value                                                  |
| RELOAD    | RW   | 32    | 0×00000000  | 0x008          | Reload value. A write to this register sets the current value. |
| INTSTATUS | RO   | 1     | 0x0         | 0x00C          | Timer interrupt. A read returns the timer interrupt status.    |
| INTCLEAR  | WO   | 1     | 0x0         | 0x00C          | 0: No effect.                                                  |
|           |      |       |             |                | 1: Clears the timer interrupt.                                 |
| PID4      | RO   | 8     | 0x04        | 0xFD0          | Peripheral ID register 4                                       |
| PID5      | RO   | 8     | 0x00        | 0xFD4          | Peripheral ID register 5                                       |
| PID6      | RO   | 8     | 0x00        | 0xFD8          | Peripheral ID register 6                                       |
| PID7      | RO   | 8     | 0x00        | 0xFDC          | Peripheral ID register 7                                       |
| PID0      | RO   | 8     | 0x22        | 0xFE0          | Peripheral ID register 0                                       |
|           |      |       |             |                | [7:0] Part number[7:0].                                        |
| PID1      | RO   | 8     | 0xB8        | 0xFE4          | Peripheral ID register 1                                       |
|           |      |       |             |                | [7:4] jep106_id_3_0.                                           |
|           |      |       |             |                | [3:0] Part number[11:8].                                       |
| PID2      | RO   | 8     | 0x0B        | 0xFE8          | Peripheral ID register 2                                       |
|           |      |       |             |                | [7:4] Revision.                                                |
|           |      |       |             |                | [3] jedec_used.                                                |
|           |      |       |             |                | [2:0] jep106_id_6_4.                                           |
| PID3      | RO   | 8     | 0x00        | ØxFEC          | Peripheral ID register 3                                       |
|           |      |       |             |                | [7:4] ECO revision number.                                     |
|           |      |       |             |                | [3:0] Customer modification number.                            |
| CID0      | RO   | 8     | 0x0D        | 0xFF0          | Component ID register 0                                        |
| CID1      | RO   | 8     | 0xF0        | 0xFF4          | Component ID register 1                                        |
| CID2      | RO   | 8     | 0x05        | 0xFF8          | Component ID register 2                                        |
| CID3      | RO   | 8     | 0xB1        | ØxFFC          | Component ID register 3                                        |

## 3.6 System registers

For information on the Cortex-M3 registers, see the following documents:

- Arm<sup>®</sup> Cortex<sup>®</sup>-M System Design Kit Technical Reference Manual.
- Arm<sup>®</sup> Cortex<sup>®</sup>-M3 Processor Technical Reference Manual.
- Arm<sup>®</sup> ARMv7-M Architecture Reference Manual.

The following table lists the subsystem ROM table ID register (identical with the generic Cortex-M3 ROM table).

#### Table 3-7 Part number ID values

| Class | Part Number | Part    | Rev  | ID0  | ID1  | ID2  | ID3  | ID4  |
|-------|-------------|---------|------|------|------|------|------|------|
| 0x1   | 0x741       | SSE-050 | r0p1 | 0xC3 | 0xB4 | 0x1B | 0x00 | 0x04 |

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

The peripheral ID in the highest-level ROM table of a system should be unique to that system. This means that you should replace this Arm default ID value with your own ID as described in the CoreSight architecture specification. The only exceptions to this rule are when either:

- The processor is configured with no debug.
- There is a higher level ROM table connected. In this case, it is correct to use the ROM table ID value without modification.

# Appendix A Signal descriptions

This chapter summarizes the interface signals present in the SSE-050 Subsystem.

It contains the following sections:

- *A.1 Clock and reset signals* on page Appx-A-48.
- *A.2 Interrupt signals* on page Appx-A-50.
- A.3 SRAM signals on page Appx-A-51.
- *A.4 Timer signals* on page Appx-A-52.
- *A.5 Bus signals* on page Appx-A-53.
- A.6 Debug and Trace signals on page Appx-A-55.
- A.7 CPU control, status, and power management signals on page Appx-A-58.
- *A.8 Memory remap signals* on page Appx-A-60.
- *A.9 DFT signals* on page Appx-A-61.

## A.1 Clock and reset signals

All reset signals are active-LOW. They can be asserted asynchronously, but must be deasserted synchronous to their respective clocks. All clocks, except for **DAPSWCLKTCK** and **TRACECLKIN**, must be synchronous and balanced.

The following table lists clock and reset signals in the SSE-050 Subsystem interface.

#### Table A-1 Clocks and resets

| Name                 | Direction | Width | Description                                                                                                                                                                                                                                                                           |
|----------------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AHB2APBHCLK          | Input     | 1     | AHB to APB bridge clock.                                                                                                                                                                                                                                                              |
| CPU0DAPCLK           | Input     | 1     | A clock signal for the debug bus interface from the <i>Debug Port</i> (DP) component, for example SWJ-DP. This can be asynchronous to other clock signals.                                                                                                                            |
| CPU0DAPCLKEN         | Input     | 1     | An enable signal for CPU0DAPCLK.                                                                                                                                                                                                                                                      |
| <b>CPU0DAPRESETn</b> | Input     | 1     | Resets the debug bus connected to the AHB-AP inside the Cortex-M3 processor.                                                                                                                                                                                                          |
| CPU0FCLK             | Input     | 1     | A free-running clock. This must be active when the processor is running, for debugging, and for the <i>Nested Vectored Interrupt Controller</i> (NVIC) to detect interrupts. The SSE-050 Subsystem implements the WIC with LATCH thus during WIC-based sleep it can be gated.         |
| CPU0HCLK             | Input     | 1     | A system clock. This must be the same as <b>CPU0FCLK</b> when active. You can gate this off when the processor is in sleep.                                                                                                                                                           |
| <b>CPU0PORESETn</b>  | Input     | 1     | Power-on reset. Resets the entire Cortex-M3 system and debug components.                                                                                                                                                                                                              |
| CPU0STCALIB          | Input     | 26    | Calibration signal for alternative clock source of SysTick timer.                                                                                                                                                                                                                     |
| CPU0STCLK            | Input     | 1     | Clock enable of the alternative clock source of SysTick timer. <b>CPU0FCLK</b> is gated with this <b>CPU0STCLK</b> .                                                                                                                                                                  |
| CPU0SYSRESETn        | Input     | 1     | System Reset. Resets the processor and the WIC excluding debug logic in the NVIC, FPB, DWT, and ITM.                                                                                                                                                                                  |
| DAPNTRST             | Input     | 1     | Debug <b>nTRST</b> reset initializes the state of the SWJ-DP TAP controller. This reset is typically used by the RealView ICE module for hot-plug connection of a debugger to a system. It initializes the SWJ-DP controller without affecting the normal operation of the processor. |
| DAPSWCLKTCK          | Input     | 1     | Serial wire clock and JTAG Test clock. Can be asynchronous.                                                                                                                                                                                                                           |
| DAPNPOTRST           | Input     | 1     | Debug port power on reset. Deassertion must be synchronized to SWCLKTCK.                                                                                                                                                                                                              |
| MTXHCLK              | Input     | 1     | AHB matrix interconnect clock.                                                                                                                                                                                                                                                        |
| MTXHRESETn           | Input     | 1     | AHB matrix interconnect reset.                                                                                                                                                                                                                                                        |
| SRAM<03>HCLK         | Input     | 1     | AHB clock of the SRAM bridges.                                                                                                                                                                                                                                                        |
| TIMER0PCLK           | Input     | 1     | The free running clock used for timer operation. This must be the same frequency as, and synchronous to, the <b>TIMER0PCLKG</b> signal.                                                                                                                                               |
| TIMER0PCLKG          | Input     | 1     | This clock is for register reads and writes of APB TIMER0. It can be gated off if there is no APB activity.                                                                                                                                                                           |
| TIMER0PRESETn        | Input     | 1     | Asynchronous active low reset for APB TIMER0. Deassert the reset synchronously to <b>TIMER0PCLK</b> .                                                                                                                                                                                 |
| TIMER1PCLK           | Input     | 1     | The free running clock used for timer operation. This must be the same frequency as, and synchronous to, the <b>TIMER1PCLKG</b> signal.                                                                                                                                               |

#### Table A-1 Clocks and resets (continued)

| Name           | Direction | Width | Description                                                                                                                      |  |
|----------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------|--|
| TIMER1PCLKG    | Input     | 1     | This clock is for register reads and writes of APB TIMER1. It can be gated off if there is no APB activity.                      |  |
| TIMER1PRESETn  | Input     | 1     | Asynchronous active low reset for APB TIMER1. Deassert the reset synchronously to <b>TIMER1PCLK</b> .                            |  |
| TPIUCLK        | Input     | 1     | APB and ATB interface clock.                                                                                                     |  |
| TPIUTRACECLKIN | Input     | 1     | Trace out port source clock.                                                                                                     |  |
| TPIUCLKEN      | Input     | 1     | Clock enable for TPIUCLK.                                                                                                        |  |
| TPIUTRESETn    | Input     | 1     | Trace out port active-LOW reset. This is asynchronously asserted and must be synchronously deasserted to <b>TPIUTRACECLKIN</b> . |  |

# A.2 Interrupt signals

The following table lists clock and reset signals in the SSE-050 Subsystem interface.

#### Table A-2 Interrupt signals

| Name               | Direction | Width | Description                                                                                                                                                                                                                                                                                                                                                                                        |  |
|--------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CPU0INTISR[239:0]  | Input     | 240   | External interrupt signals. The number of functional interrupt signals depends on your implementation. The Cortex-M3 processor does not implement synchronizers for the <b>CPU0INTISR</b> input. To use asynchronous interrupts, you must implement external synchronizers to reduce the possibility of metastability issues.                                                                      |  |
| CPU0INTNMI         | Input     | 1     | Non-maskable Interrupt. The number of functional interrupt signals depends on your implementation. The Cortex-M3 processor does not implement synchronizers for the <b>CPU0INTNMI</b> input. To use asynchronous interrupts, you must implement external synchronizers to reduce the possibility of metastability issues. If the input is connected to an I/O pad, a noise filter must be applied. |  |
| CPU0CURRPRI[7:0]   | Output    | 8     | Indicates what priority interrupt, or base boost, is being used. CURRPRI represents the preemption priority, and does not indicate secondary priority.                                                                                                                                                                                                                                             |  |
| CPU0AUXFAULT[31:0] | Input     | 32    | Auxiliary fault status information from the system.                                                                                                                                                                                                                                                                                                                                                |  |

## A.3 SRAM signals

The following table lists the interface signals for the AHB2SRAM subsystem.

#### Table A-3 AHB2SRAM Interfaces

| Name          | Direction | Width | Description                          |
|---------------|-----------|-------|--------------------------------------|
| SRAM<03>RDATA | Input     | 32    | SRAM read data bus.                  |
| SRAM<03>ADDR  | Output    | 13    | SRAM address (word address).         |
| SRAM<03>WREN  | Output    | 4     | SRAM byte write enable. Active HIGH. |
| SRAM<03>WDATA | Output    | 32    | SRAM write data.                     |
| SRAM<03>CS    | Output    | 1     | SRAM chip select. Active HIGH.       |

# A.4 Timer signals

The following table lists the interface signals for the timer subsystem.

#### Table A-4 Timer

| Name            | Direction | Width | Description                                                                                                                                                                                                                            |
|-----------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIMER0EXTIN     | Input     | 1     | Timer0 external input. The external clock. This must be slower than half of the <b>TMER0PCLK</b> clock because it is sampled by a double flip-flop and then goes through edge-detection logic when the external inputs act as a clock. |
| TIMER1EXTIN     | Input     | 1     | Timer1 external input. The external clock, must be slower than half of the <b>TMER1PCLK</b> clock because it is sampled by a double flip-flop and then goes through edge-detection logic when the external inputs act as a clock.      |
| TIMER0PRIVMODEN | Input     | 1     | Defines if the timer memory mapped registers are writeable only by privileged access.                                                                                                                                                  |
| TIMER1PRIVMODEN | Input     | 1     | Defines if the timer memory mapped registers are writeable only by privileged access.                                                                                                                                                  |
| TIMER0TIMERINT  | Output    | 1     | Timer0 interrupt output.                                                                                                                                                                                                               |
| TIMER1TIMERINT  | Output    | 1     | Timer1 interrupt output.                                                                                                                                                                                                               |

## A.5 Bus signals

The following table lists the signals for the three AHB master interfaces. Not shown in the list is the **TARGEXP<0..1>** prefix before each signal name for the expansion ports, and **TARGFLASH0** suffix for the flash memory AHB master interface.

| Name      | Direction | Width | Description                                                                     |  |
|-----------|-----------|-------|---------------------------------------------------------------------------------|--|
| HSEL      | Output    | 1     | Slave Select.                                                                   |  |
| HADDR     | Output    | 32    | Address bus.                                                                    |  |
| HTRANS    | Output    | 2     | Transfer type.                                                                  |  |
| HWRITE    | Output    | 1     | Transfer direction.                                                             |  |
| HSIZE     | Output    | 3     | Transfer size.                                                                  |  |
| HBURST    | Output    | 3     | Burst type.                                                                     |  |
| HPROT     | Output    | 4     | Protection control.                                                             |  |
| HMASTER   | Output    | 4     | Master select.                                                                  |  |
| HWDATA    | Output    | 32    | Write data.                                                                     |  |
| HMASTLOCK | Output    | 1     | Locked sequence.                                                                |  |
| HREADYMUX | Output    | 1     | Transfer done.                                                                  |  |
| HAUSER    | Output    | 1     | Address <b>USER</b> signals (Not used by the subsystem Cortex-M3 processor).    |  |
| EXREQ     | Output    | 1     | Exclusive request.                                                              |  |
| MEMATTR   | Output    | 2     | Memory attributes.                                                              |  |
| HWUSER    | Output    | 4     | Write-data <b>USER</b> signals (Not used by the subsystem Cortex-M3 processor). |  |
| HRDATA    | Input     | 32    | Read data bus.                                                                  |  |
| HREADYOUT | Input     | 1     | HREADY feedback.                                                                |  |
| HRESP     | Input     | 1     | Transfer response.                                                              |  |
| HRUSER    | Input     | 3     | Read-data USER signals (Not used by the subsystem Cortex-M3 processor).         |  |
| EXRESP    | Input     | 1     | Exclusive response.                                                             |  |

#### Table A-5 External AHB master port signals

The following table lists the signals for the two AHB slave interfaces. Not shown in the list is the **INITEXP<0..1>** prefix before each signal name.

#### Table A-6 External AHB slave port signals

| Name   | Direction | Width | Description         |  |
|--------|-----------|-------|---------------------|--|
| HSEL   | Input     | 1     | Slave Select.       |  |
| HADDR  | Input     | 32    | Address bus.        |  |
| HTRANS | Input     | 2     | Transfer Type.      |  |
| HWRITE | Input     | 1     | Transfer Direction. |  |
| HSIZE  | Input     | 3     | Transfer Size.      |  |
| HBURST | Input     | 3     | Burst type.         |  |

#### Table A-6 External AHB slave port signals (continued)

| Name      | Direction | Width | Description                                                                     |  |
|-----------|-----------|-------|---------------------------------------------------------------------------------|--|
| HPROT     | Input     | 4     | Protection Control.                                                             |  |
| HMASTER   | Input     | 4     | Master Select.                                                                  |  |
| HWDATA    | Input     | 32    | Write Data.                                                                     |  |
| HMASTLOCK | Input     | 1     | Locked Sequence.                                                                |  |
| HAUSER    | Input     | 1     | Address USER signals (Not used by the subsystem Cortex-M3 processor).           |  |
| EXREQ     | Input     | 1     | Exclusive Request signal.                                                       |  |
| MEMATTR   | Input     | 2     | Memory Attribute signals.                                                       |  |
| HWUSER    | Input     | 4     | Write-data <b>USER</b> signals (Not used by the subsystem Cortex-M3 processor). |  |
| HRDATA    | Output    | 32    | Read data bus.                                                                  |  |
| HREADY    | Output    | 1     | HREADY feedback.                                                                |  |
| HRESP     | Output    | 1     | Transfer response.                                                              |  |
| HRUSER    | Output    | 3     | Read-data USER signals (Not used by the subsystem Cortex-M3 processor).         |  |
| EXRESP    | Output    | 1     | Exclusive Response.                                                             |  |

The following table lists the signals for the two APB slave interfaces. Not shown in the list is the **APBTARGETEXP**<**n**> prefix before each signal name, where **n** is in the range 2-15.

#### Table A-7 External APB target port signals

| Name    | Direction | Width | Description                                                                                                                                                                         |  |
|---------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| PSEL    | Output    | 1     | Slave select signal.                                                                                                                                                                |  |
| PENABLE | Output    | 1     | Strobe to time all accesses. Used to indicate the second cycle of an APB transfer.                                                                                                  |  |
| PADDR   | Output    | 12    | Address bus.                                                                                                                                                                        |  |
| PWRITE  | Output    | 1     | APB transfer direction.                                                                                                                                                             |  |
| PWDATA  | Output    | 32    | 32-bit write data bus.                                                                                                                                                              |  |
| PRDATA  | Input     | 32    | 32-bit read data bus.                                                                                                                                                               |  |
| PREADY  | Input     | 1     | Driven LOW if extra wait states are required to complete the transfer.                                                                                                              |  |
| PSLVERR | Input     | 1     | Indicates SLVERR response.                                                                                                                                                          |  |
| PSTRB   | Output    | 1     | Write strobes. This signal indicates which byte lanes to update during a write transfer. There is one write strobe for each eight bits of the write data bus.                       |  |
|         |           |       | <b>PSTRB</b> [ <b>n</b> ] corresponds to <b>PWDATA</b> [(8 <b>n</b> + 7):(8 <b>n</b> )].                                                                                            |  |
|         |           |       | Write strobes must not be active during a read transfer.                                                                                                                            |  |
| PPROT   | Output    | 3     | Protection type. This signal indicates the normal, privileged, or secure protection level of the transaction and whether the transaction is a data access or an instruction access. |  |

## A.6 Debug and Trace signals

This section list signals related to debug and trace.

This section contains the following subsections:

- A.6.1 JTAG and SWD signals on page Appx-A-55.
- A.6.2 CPU debug signals on page Appx-A-55.
- A.6.3 Debug authentication control on page Appx-A-55.
- *A.6.4 Trace signals* on page Appx-A-56.
- *A.6.5 HTM signals* on page Appx-A-57.

#### A.6.1 JTAG and SWD signals

The following table lists the interface signals for the JTAG and SWD subsystem.

#### Table A-8 JTAG and SW Debug access functional signals

| Name       | Direction | Width | Description                                                                |  |
|------------|-----------|-------|----------------------------------------------------------------------------|--|
| DAPSWDITMS | Input     | 1     | Debug TMS.                                                                 |  |
| DAPSWDO    | Output    | 1     | Serial Wire Data Out.                                                      |  |
| DAPSWDOEN  | Output    | 1     | Serial Wire Output Enable.                                                 |  |
| DAPTDI     | Input     | 1     | Debug TDI.                                                                 |  |
| DAPTDO     | Output    | 1     | Debug TDO.                                                                 |  |
| DAPNTDOEN  | Output    | 1     | TDO output pad control signal.                                             |  |
| DAPJTAGNSW | Output    | 1     | JTAG or Serial-Wire selection:                                             |  |
|            |           |       | 1 - JTAG mode.                                                             |  |
|            |           |       | 0 - SW mode.                                                               |  |
| DAPJTAGTOP | Output    | 1     | JTAG-DP TAP controller in one of four top states TLR, RTI, Sel-DR, Sel-IR. |  |

#### A.6.2 CPU debug signals

The following table lists the interface signals related to CPU debug.

#### Table A-9 CPU debug signals

| Name             | Direction | Width | Description                                                                                                                                        |
|------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU0EDBGRQ       | Input     | 1     | External debug request. This is combined internally with the ETM debug request. This signal must be synchronous to <b>CPU0FCLK</b> .               |
| CPU0DBGRESTART   | Input     | 1     | External restart request. The processor exits the halt state when the <b>CPU0DBGRESTART</b> signal is deasserted during 4-phase handshaking.       |
| CPU0DBGRESTARTED | Output    | 1     | Handshake for <b>CPU0DBGRESTART</b> . Devices driving <b>CPU0DBGRESTART</b> must observe this signal to generate the required 4-phase handshaking. |

#### A.6.3 Debug authentication control

The following table lists the interface signals related to debug authentication and security.

#### Table A-10 Debug authentication and security signals

| Port name         | Direction         | Width | Description                                                                                                                                                                                                                                                                |
|-------------------|-------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU0DBGEN         | CPU0DBGEN Input 1 |       | External debug enable.                                                                                                                                                                                                                                                     |
|                   |                   |       | If <b>CPU0DBGEN</b> is deasserted, the halt debugging feature of the processor is disabled.                                                                                                                                                                                |
|                   |                   |       | If <b>CPU0DBGEN</b> is asserted, you can use debug features, but you must set other enables, <b>C_DEBUGEN</b> for example, to enable debug events such as halt to occur. Either tie HIGH or connect to a debug access controller if required.                              |
| CPU0NIDEN         | Input             | 1     | Non-Invasive debug enable. <b>NIDEN</b> must be HIGH to enable the ETM trace unit to trace instructions.                                                                                                                                                                   |
| CPU0DAPEN         | Input             | 1     | Input AHB-AP enable. Enables the AHB-AP memory access functionality.                                                                                                                                                                                                       |
|                   |                   |       | In a typical arrangement, you can tie this signal HIGH. Connect HIGH when enabling debug accesses.                                                                                                                                                                         |
|                   |                   |       | If this signal is LOW, the debugger can still access registers inside the AHB-AP module inside the Cortex-M3 processor, but cannot access the memory map using the AHB interface.                                                                                          |
| CPU0FIXMASTERTYPE | Input             | 1     | The AHB-AP can issue AHB transactions with a <b>HMASTER</b> value of either 1, to indicate DAP, or 0, to indicate processor data side, depending on how the AHB-AP is configured using the MasterType bit in the AHB-AP Control and Status Word Register.                  |
|                   |                   |       | You can use <b>FIXMASTERTYPE</b> to prevent this if required. If it is tied HIGH, then the <b>HMASTER</b> that the AHB-AP issues is always 1, to indicate DAP, and it cannot imitate the processor. If it is tied LOW, then <b>HMASTER</b> can be issued as either 0 or 1. |

#### A.6.4 Trace signals

The following table lists the miscellaneous signals for the Trace subsystem.

#### Table A-11 CPU trace signals

| Name                  | Direction | Width | Description                                                  |
|-----------------------|-----------|-------|--------------------------------------------------------------|
| CPU0TSVALUEB          | Input     | 48    | Global timestamp value.                                      |
| CPU0ETMINTNUM         | Output    | 9     | Marks the interrupt number of the current execution context. |
| <b>CPU0ETMINTSTAT</b> | Output    | 3     | Interrupt status.                                            |
| CPU0ETMEXTIN          | Input     | 2     | ETM external inputs.                                         |

The following table lists the interface signals for the Trace Port Interface Unit.

#### Table A-12 External TPIU interface

| Name          | Direction | Width | Description                                                                                                                                                                                                                     |
|---------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TPIUTRACECLK  | Output    | 1     | Output clock, used by the TPA to sample the other pins of the trace out port. This runs at half the speed of <b>TPIUTRACECLKIN</b> , and data is valid on both edges of this clock (clock derived from <b>TPIUTRACECLKIN</b> ). |
| TPIUTRACEDATA | Output    | 4     | Output data. A system might not connect all the bits of this signal to the trace port pins, depending on the number of pins available and the bandwidth required to output trace.                                               |

#### Table A-12 External TPIU interface (continued)

| Name          | Direction | Width | Description                                                                                         |  |
|---------------|-----------|-------|-----------------------------------------------------------------------------------------------------|--|
| TPIUTRACESWO  | Output    | 1     | Serial Wire Viewer data.                                                                            |  |
| TPIUSWOACTIVE | Output    | 1     | Controls the multiplexor if SWO shared with TRACEDATA[0].                                           |  |
|               |           |       | Arm recommends implementing SWO shared with JTAG-TDO, therefore this pin shall be left unconnected. |  |

#### A.6.5 HTM signals

The following table lists the signals for the AHB Trace Macrocell (HTM).

#### Table A-13 HTM interface signals

| Name             | Direction | Description                                                                                          | Connection information         |
|------------------|-----------|------------------------------------------------------------------------------------------------------|--------------------------------|
| HTMDHADDR[31:0]  | Output    | 32-bit address.                                                                                      | Connect to HTM if implemented. |
| HTMDHTRANS[1:0]  | Output    | Indicates the type of the current data<br>transfer. Can be IDLE,<br>NONSEQUENTIAL, or<br>SEQUENTIAL. | Connect to HTM if implemented. |
| HTMDHSIZE[1:0]   | Output    | Indicates the size of the access. Can be 8 bits, 16 bits, or 32 bits.                                | Connect to HTM if implemented. |
| HTMDHBURST[2:0]  | Output    | Indicates if the transfer is part of a burst.                                                        | Connect to HTM if implemented. |
| HTMDHPROT[3:0]   | Output    | Provides information on the access.                                                                  | Connect to HTM if implemented. |
| HTMDHWDATA[31:0] | Output    | 32-bit write data bus.                                                                               | Connect to HTM if implemented. |
| HTMDHWRITE       | Output    | Write not read.                                                                                      | Connect to HTM if implemented. |
| HTMDHRDATA[31:0] | Output    | Read data bus.                                                                                       | Connect to HTM if implemented. |
| HTMDHREADY       | Output    | Ready signal.                                                                                        | Connect to HTM if implemented. |
| HTMDHRESP[1:0]   | Output    | The transfer response status. Can be OKAY or ERROR.                                                  | Connect to HTM if implemented. |

## A.7 CPU control, status, and power management signals

This section describes power-management and control signals. Power management requires design choices made at the SoC level.

This section contains the following subsections:

- A.7.1 CPU status and control signals on page Appx-A-58.
- *A.7.2 Power management signals* on page Appx-A-58.

#### A.7.1 CPU status and control signals

The following table lists the status and control signals for the CPU subsystem.

#### Table A-14 CPU control and status

| Name              | Direction | Width                  | Description                                                                                                                                            |
|-------------------|-----------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU0HALTED        | Output    | 1                      | In halting mode debug. HALTED remains asserted while the core is in debug.                                                                             |
| CPU0MPUDISABLE    | Input     | 1                      | If asserted the MPU is invisible and unusable. Tie HIGH to disable the MPU. Tie LOW to enable the MPU, if present.                                     |
| CPU0SLEEPING      | Output    | 1                      | Indicates that the processor is in sleep mode.                                                                                                         |
| CPU0SLEEPDEEP     | Output    | 1                      | Indicates that the processor is in deep sleep mode.                                                                                                    |
| CPU0SLEEPHOLDREQn | Input     | 1                      | Request to extend sleep. Can only be asserted when <b>CPU0SLEEPING</b> is HIGH.                                                                        |
| CPU0SLEEPHOLDACKn | Output    | 1                      | Acknowledge for CPU0SLEEPHOLDREQn.                                                                                                                     |
| CPU0WAKEUP        | Output    | 1                      | Signal to the PMU that indicates that a wake-up event has occurred<br>and the processor system domain requires its clocks and power to be<br>restored. |
| CPU0WICSENSE      | Output    | Implementation defined | These indicate the input lines that cause the WIC to generate the <b>CPU0WAKEUP</b> signal (optional, for testing).                                    |
| CPU0WICENREQ      | Input     | 1                      | Request for deep sleep to be WIC-based deep sleep. The PMU drives this signal.                                                                         |
| CPU0WICENACK      | Output    | 1                      | Acknowledge signal for <b>CPU0WICENREQ</b> . If you do not require PMU, then tie this signal HIGH to enable the WIC if the WIC is implemented.         |
| CPU0TRCENA        | Output    | 1                      | Indicates that Trace is enabled, can be used to gate <b>TPIUCLK</b> .                                                                                  |
| CPU0ETMEN         | Output    | 1                      | Indicates ETM is enabled, can be used to gate TPIUCLK.                                                                                                 |
| CPU0SYSRESETREQ   | Output    | 1                      | Processor control - system reset request. The AIRC.SYSRESETREQ register controls this signal.                                                          |
| CPU0LOCKUP        | Output    | 1                      | Indicates that the core is in lockup state.                                                                                                            |
| CPU0BRCHSTAT      | Output    | 4                      | Branch status in decode.                                                                                                                               |
| CPU0ETMTRIGOUT    | Output    | 1                      | Driven HIGH when the ETM trigger condition matches.                                                                                                    |

#### A.7.2 Power management signals

The following table lists the power management signals for the debug subsystem.

See also A.6 Debug and Trace signals on page Appx-A-55.

#### Table A-15 Debug power-management signals

| Signal name     | Direction | Width | Clock        | Description                                                                                                                                                         |
|-----------------|-----------|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DAPCDBGPWRUPREQ | Output    | 1     | DAPSWCLKTCK  | Indicates an external debugger request to the PMU to power up<br>the debug domain. This signal must be synchronized before<br>use.                                  |
| DAPCDBGPWRUPACK | Input     | 1     | Asynchronous | Indicates that the debug domain is powered up in response to <b>DAPCDBGPWRUPREQ</b> being HIGH.<br>This signal is resynchronized internally to <b>DAPSWCLKTCK</b> . |
| DAPCSYSPWRUPREQ | Output    | 1     | DAPSWCLKTCK  | Indicates an external debugger request to the PMU to power up<br>the debug domain. This signal must be synchronized before<br>use.                                  |
| DAPCSYSPWRUPACK | Input     | 1     | Asynchronous | Indicates that the debug domain is powered up in response to <b>DAPCSYSPWRUPREQ</b> being HIGH.<br>This signal is resynchronized internally to <b>DAPSWCLKTCK</b> . |
| DAPNCDBGPWRDN   | Input     | 1     | Asynchronous | Debug infrastructure powerdown control. Controls the clamps of the DAP APB interface.                                                                               |
| DAPCDBGRSTREQ   | Output    | 1     | DAPSWCLKTCK  | Indicates that an external debugger requested a debug reset to reset the controller. This signal must be synchronized before use.                                   |
| DAPCDBGRSTACK   | Input     | 1     | Asynchronous | Indicates that the debug domain reset has completed. This signal is resynchronized internally by <b>DAPSWCLKTCK</b> .                                               |

The following table lists the power-management signals for the interconnect subsystem. See also *A.5 Bus* signals on page Appx-A-53.

#### Table A-16 Interconnect power-management signals

| Signal name       | Direction | Width | Clock   | Description                                                                                                                                   |
|-------------------|-----------|-------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| APBQACTIVE        | Output    | 1     | MTXHCLK | APB bus active signal for global clock gating control of all APB peripherals attached to the SSE-050 Subsystem that supports gated APB clock. |
| TIMER0PCLKQACTIVE | Output    | 1     | MTXHCLK | APB bus active signal for clock gating control of Timer 0 APB clock <b>TIMER0PCLKG</b> (for example PSEL).                                    |
| TIMER1PCLKQACTIVE | Output    | 1     | MTXHCLK | APB bus active signal for clock gating control of Timer 1 APB clock <b>TIMER1PCLKG</b> (that is, PSEL).                                       |
| APBTARGEXPnPSEL   | Output    | 1     | MTXHCLK | External APB TARGET SEL signals from the AHB slave interface can be reused for power management.                                              |

#### **Related references**

*A.6 Debug and Trace signals* on page Appx-A-55. *A.5 Bus signals* on page Appx-A-53.

## A.8 Memory remap signals

The **MTXREMAP** signals control the remapping of the boot memory range.

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

When reset is not asserted, you must ensure that the memory remap signals remain static.

#### Table A-17 Memory remap signals

| Name     | Direction | Width | Description                                                                                                                          |
|----------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------|
| MTXREMAP | Input     | 4     | REMAP[0]: Determines the size of the eFlash memory region:                                                                           |
|          |           |       | 1 256KB region for flash.                                                                                                            |
|          |           |       | 0 512KB region for flash.                                                                                                            |
|          |           |       | REMAP[1]: If SRAM1 is not present, the corresponding memory range can be mapped to the AHB expansion port by tying this signal HIGH. |
|          |           |       | REMAP[2]: If SRAM2 is not present, the corresponding memory range can be mapped to AHB expansion port by tying this signal HIGH.     |
|          |           |       | REMAP[3]: If SRAM3 is not present, the corresponding memory range can be mapped to AHB expansion port by tying this signal HIGH.     |

# A.9 DFT signals

The following table list signals related to test mode.

#### Table A-18 DFT signals

| Name                   | Direction | Width | Description                                                                                                                                                    |  |
|------------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>DFTSCANMODECPU0</b> | Input     | 1     | Reset bypass to disable internal generated reset for testing, for example ATPG.                                                                                |  |
| DFTCGENCPU0            | Input     | 1     | Clock gating bypass to disable internal clock gating for testing. This signal is used to ensure safe shift where the clock is forced on during the shift mode. |  |
| DFTSE                  | Input     | 1     | Scan mode enable for ETM, if present.                                                                                                                          |  |

# Appendix B **Revisions**

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

It contains the following section:

• *B.1 Revisions* on page Appx-B-63.

## B.1 Revisions

This section describes the technical changes between released issues of this document.

#### Table B-1 Issue A

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

#### Table B-2 Differences between Issue 0000-00 and Issue 0001-00

| Change                                                      | Location                      | Affects       |
|-------------------------------------------------------------|-------------------------------|---------------|
| System register revision and part number ID values changed. | System registers on page 3-46 | Issue 0001-00 |