

# Message Handling Unit Architecture

version 3.0

| Document number          | ARM-AES-0072     |
|--------------------------|------------------|
| Document quality         | eac              |
| Document version         | A.a              |
| Document confidentiality | Non-confidential |

Copyright © 2023-2024 Arm Limited or its affiliates. All rights reserved.

## Message Handling Unit Architecture

### **Release information**

| Date        | Version | Changes                                     |
|-------------|---------|---------------------------------------------|
| 2024/Mar/11 | A.a     | • Initial release of MHU v3.0 architecture. |

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

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 ® or <sup>TM</sup> are registered trademarks or trademarks of Arm Limited (or its affiliates) 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 © 2023-2024 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 version 21.0

## Contents Message Handling Unit Architecture

| Release information .<br>Non-Confidential Propr | ietary No | otice | ••• | • • | • | · · · · · · · · · · · · · · · · · · · | • | · ·<br>· · | • | · ·<br>· · | •<br>• | · ·<br>· · | • | • • | · ·<br>· · | • | •<br>• | · ·<br>· · | • |
|-------------------------------------------------|-----------|-------|-----|-----|---|---------------------------------------|---|------------|---|------------|--------|------------|---|-----|------------|---|--------|------------|---|
|                                                 | -         |       |     |     |   |                                       |   |            |   |            |        |            |   |     |            |   |        |            |   |
| About this specification                        |           |       |     |     |   |                                       |   |            |   |            |        |            |   |     |            |   |        |            |   |
| Intended audience                               |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Conventions                                     |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Typographical convention                        | ons       |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Numbers                                         |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Pseudocode descriptio                           | ns        |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Assembler syntax desc                           | riptions  |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Rules-based writing                             |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Content item identifiers                        |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Content item rendering                          |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Content item classes .                          |           |       |     |     |   |                                       |   |            |   |            |        |            |   |     |            |   |        |            |   |
| Additional reading                              |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
| Feedback                                        |           |       |     |     |   |                                       |   |            |   |            |        |            |   | •   |            |   |        |            |   |
|                                                 |           |       |     |     |   |                                       |   |            |   |            |        |            |   |     |            |   |        |            |   |

### Part A Message Handling Unit Architecture Overview

| Chapter A1 I | Introduction to Message Handling Unit Architecture |    |  |  |  |  |  |  |  |
|--------------|----------------------------------------------------|----|--|--|--|--|--|--|--|
| A            | Interrupt Based Communication                      | 17 |  |  |  |  |  |  |  |
| A            | Usage                                              | 18 |  |  |  |  |  |  |  |
| Α            | Architecture Structure                             | 19 |  |  |  |  |  |  |  |

### Part B Message Handling Unit v3.0

| Chapter B1 | Message Handling Unit v3.0 Overview         B1.1       Structure       22                                                                                                                                                                                                                                                                                                                          |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chapter B2 | MHU Sender and Receiver                                                                                                                                                                                                                                                                                                                                                                            |
| Chapter B3 | Postbox and Mailbox                                                                                                                                                                                                                                                                                                                                                                                |
| Chapter B4 | Power Control         B4.1       Overview       26         B4.2       Auto Op       28         B4.2.1       Auto Op(Min)       28         B4.2.2       Auto Op(Full)       29         B4.3       Entry to a Non-Operational State       31         B4.3.1       Controlled entry into Non-operational state       31         B4.3.2       Uncontrolled entry into a Non-operational state       33 |
| Chapter B5 | Data Endianness                                                                                                                                                                                                                                                                                                                                                                                    |
| Chapter B6 | Doorbell Extension                                                                                                                                                                                                                                                                                                                                                                                 |

Preface

#### Contents

|             | B6.1Doorbell Channel Window37B6.2Events39B6.2.1Channel Transfer event39B6.2.2Channel Transfer Acknowledge event39                                                                                                                                                                                                                                                                                                       |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chapter B7  | Fast Channel ExtensionB7.1Fast Channel Groups42B7.2Fast Channel Storage43B7.3Fast Channel Window44B7.4Fast Channel Control registers46B7.5Read-Acknowledge47B7.6Events48                                                                                                                                                                                                                                                |
| Chapter B8  | FIFO ExtensionB8.1Data Flags51B8.1.1Transfer Delineation Mode51B8.1.2Data Flag Storage53B8.2FIFO Behavior54B8.2.1Reset54B8.2.2Pushing data onto the FIFO54B8.2.3Reading data from the FIFO55B8.2.4Flag History Buffer57B8.2.5Popping bytes from the FIFO57B8.2.6Ordering of bytes when push, read or popping multiple bytes60                                                                                           |
|             | B8.3FIFO Flush61B8.4FIFO Channel Window63B8.4.1Accesses to Payload and Flag registers64B8.4.2FIFO Status68B8.4.3Transfer Acknowledge Tracking69B8.5Events70B8.5.1Channel Transfer event70B8.5.2FIFO Pop Ack event70B8.5.3Channel Transfer Acknowledge event70B8.5.4Sender FIFO Low and High Tide events70B8.5.5Receiver FIFO Low and High Tide events71B8.5.6Sender FIFO flush event71B8.5.7Receiver FIFO flush event71 |
| Chapter B9  | TrustZone and Realm Management ExtensionB9.1Overview72B9.2Security Assignment Agent74B9.3TZE75B9.4RME76                                                                                                                                                                                                                                                                                                                 |
| Chapter B10 | Reliability, Availability and Serviceability ExtensionsB10.1Overview78B10.2Reporting Requirements79B10.3Implications of error detection81B10.4Error record requirements82B10.5RAS and Security83B10.5.1Error reporting83B10.5.2Error detection and reporting information84B10.6Interrupts85B10.7Recommend implementation of RAS using Arm RAS extensions87                                                              |

#### Contents

| Chapter B11 | Interrupts    |                                   |
|-------------|---------------|-----------------------------------|
|             | B11.1 Interru | upt Types                         |
|             | B11.1.1       | Maskable interrupt                |
|             | B11.1.2       | Enable interrupt                  |
|             | B11.1.3       | Shared enable interrupt           |
|             | B11.1.4       | Combined interrupt                |
|             | B11.1.5       | Combined status interrupt         |
|             | B11.1.6       | Combined enable interrupt         |
|             | B11.2 MHU     | Interrupts                        |
|             | B11.2.1       | Channel Transfer                  |
|             | B11.2.2       | Channel Transfer Acknowledge      |
|             | B11.2.3       | Fast Channel Transfer    96       |
|             | B11.2.4       | Fast Channel Group Transfer    97 |
|             | B11.2.5       | Sender FIFO Low Tidemark          |
|             | B11.2.6       | Sender FIFO High Tidemark         |
|             | B11.2.7       | Sender FIFO Flush                 |
|             | B11.2.8       | Receiver FIFO Low Tidemark        |
|             | B11.2.9       | Receiver FIFO High Tidemark       |
|             | B11.2.10      | Receiver FIFO Flush               |
|             | B11.2.11      | Sender FFCH Combined              |
|             | B11.2.12      | Receiver FFCH Combined            |
|             | B11.2.13      | Postbox Combined                  |
|             | B11.2.14      | Mailbox Combined                  |

## Part C Programmers Model

| Chapter C1 | Prog  | ramme  | rs Model Overview                               |
|------------|-------|--------|-------------------------------------------------|
|            | C1.1  | Regis  | ster Access                                     |
|            |       | C1.1.1 | Generic Rules                                   |
|            |       | C1.1.2 | FCH Payload Accesses                            |
|            |       | C1.1.3 | FFCH Payload and Flag Accesses                  |
|            |       | C1.1.4 | Unsupported Accesses                            |
|            |       | C1.1.5 | Illegal Accesses                                |
|            | C1.2  | Regis  | ster Access Response                            |
|            | C1.3  | Rese   | t Domains                                       |
|            | C1.4  | Stora  | ge Resources                                    |
|            |       | C1.4.1 | Storage resource location                       |
|            |       | C1.4.2 | Field Aliasing                                  |
|            |       | C1.4.3 | FIFO storage resources                          |
|            | C1.5  | Regis  | ster Blocks                                     |
|            | C1.6  | Softw  | vare Discovery                                  |
|            | C1.7  | IMPL   | EMENTATION DEFINED registers                    |
|            |       | C1.7.1 | Implementation Identification Registers         |
|            |       | C1.7.2 | IMPLEMENTATION DEFINED Identification Registers |
|            |       | C1.7.3 | IMPLEMENTATION DEFINED Page                     |
| Chapter C2 | Reais | sters  |                                                 |
| •          | C2.1  | MHU    | S, MHU Sender                                   |
|            |       | C2.1.1 | PBX, Postbox                                    |
|            |       | C2.1.2 | SSC, Sender Security Control                    |
|            | C2.2  | MHU    | R, MHU Receiver                                 |
|            |       | C2.2.1 | MBX, Mailbox                                    |
|            |       | C2.2.2 | RSC, Receiver Security Control                  |

Contents Contents

## Part D Appendix

| Chapter D1 | Postbox and Mailbox Interrupt LogicD1.1Postbox Interrupt Logic319D1.2Mailbox Interrupt Logic321 |
|------------|-------------------------------------------------------------------------------------------------|
| Chapter D2 | Transport Protocols                                                                             |
| •          | D2.1 Doorbell                                                                                   |
|            | D2.1.1 Requirements                                                                             |
|            | D2.1.2 Procedure                                                                                |
|            | D2.2 FIFO                                                                                       |
|            | D2.2.1 Requirements                                                                             |
|            | D2.2.2 Procedure                                                                                |
|            | D2.3 Streaming FIFO                                                                             |
|            | D2.3.1 Requirements                                                                             |
|            | D2.3.2 Procedure                                                                                |
|            | D2.4 Last-value                                                                                 |
|            | D2.4.1 Requirements                                                                             |
|            | D2.4.2 Procedure                                                                                |

Glossary

## Preface

This preface introduces the Message Handling Unit Architecture Specification. It contains the following sections:

- About this specification.
- Conventions.
- Additional reading.
- Feedback.

## About this specification

This specification describes the Message Handling Unit(MHU) architecture version 3.0.

Throughout this specification, references to *the MHU* or *a MHU* refer to a device that implements the MHUv3.0 architecture.

### Intended audience

This architecture is for users who want to design, implement or program the MHU in a range of Arm-compliant implementations of the MHUv3. It does not assume familiarity with previous versions of the MHU.

The architecture assumes that that users have some experience of Arm products, and are familiar with the terminology that describes the Arm A-profile architecture.

### Conventions

### **Typographical conventions**

The typographical conventions are:

italic

Introduces special terminology, and denotes citations.

#### bold

Denotes signal names, and is used for terms in descriptive lists, where appropriate.

#### monospace

Used for assembler syntax descriptions, pseudocode, and source code examples.

Also used in the main text for instruction mnemonics and for references to other items appearing in assembler syntax descriptions, pseudocode, and source code examples.

#### SMALL CAPITALS

Used for some common terms such as IMPLEMENTATION DEFINED.

Used for a few terms that have specific technical meanings, and are included in the Glossary.

#### Red text

Indicates an open issue.

#### Blue text

Indicates a link. This can be

- A cross-reference to another location within the architecture
- A URL, for example http://developer.arm.com

#### **Numbers**

Numbers are normally written in decimal. Binary numbers are preceded by 0b, and hexadecimal numbers by 0x. In both cases, the prefix and the associated value are written in a monospace font, for example 0xFFFF0000. To improve readability, long numbers can be written with an underscore separator between every four characters, for example  $0xFFFF_0000_0000_0000$ . Ignore any underscores when interpreting the value of a number.

#### **Pseudocode descriptions**

This book uses a form of pseudocode to provide precise descriptions of the specified functionality. This pseudocode is written in a monospace font. The pseudocode language is described in the Arm Architecture Reference Manual.

#### Assembler syntax descriptions

This book contains numerous syntax descriptions for assembler instructions and for components of assembler instructions. These are shown in a monospace font.

### **Rules-based writing**

This specification consists of a set of individual *content items*. A content item is classified as one of the following:

- Declaration
- Rule
- Information
- Rationale
- Implementation note
- Software usage

Declarations and Rules are normative statements. An implementation that is compliant with this specification must conform to all Declarations and Rules in this specification that apply to that implementation.

Declarations and Rules must not be read in isolation. Where a particular feature is specified by multiple Declarations and Rules, these are generally grouped into sections and subsections that provide context. Where appropriate, these sections begin with a short introduction.

Arm strongly recommends that implementers read *all* chapters and sections of this document to ensure that an implementation is compliant.

Content items other than Declarations and Rules are informative statements. These are provided as an aid to understanding this specification.

### **Content item identifiers**

A content item may have an associated identifier which is unique among content items in this specification.

After this specification reaches beta status, a given content item has the same identifier across subsequent versions of the specification.

### Content item rendering

In this document, a content item is rendered with a token of the following format in the left margin: L<sub>iiiii</sub>

- *L* is a label that indicates the content class of the content item.
- *iiiii* is the identifier of the content item.

### **Content item classes**

#### Declaration

A Declaration is a statement that does one or more of the following:

- Introduces a concept
- Introduces a term
- Describes the structure of data
- Describes the encoding of data

A Declaration does not describe behavior.

A Declaration is rendered with the label *D*.

### Rule

A Rule is a statement that describes the behaviour of a compliant implementation.

A Rule explains what happens in a particular situation.

A Rule does not define concepts or terminology.

A Rule is rendered with the label *R*.

### Information

An Information statement provides information and guidance as an aid to understanding the specification.

An Information statement is rendered with the label I.

### Rationale

A Rationale statement explains why the specification was specified in the way it was.

A Rationale statement is rendered with the label *X*.

### Implementation note

An Implementation note provides guidance on implementation of the specification.

An Implementation note is rendered with the label U.

### Software usage

A Software usage statement provides guidance on how software can make use of the features defined by the specification.

A Software usage statement is rendered with the label S.

## **Additional reading**

This section lists publications by Arm and by third parties.

See Arm Developer (http://developer.arm.com) for access to Arm documentation.

[1] AMBA<sup>®</sup> Low Power Interface Specification. (ARM IHI 0068) Arm.

[2] Arm<sup>®</sup> Architecture Reference Manual for A-profile architecture. (ARM DDI 0487) Arm.

[3] Arm<sup>®</sup> CoreSight Architecture Specification v3. (ARM IHI 0029) Arm.

## Feedback

Arm welcomes feedback on its documentation.

### Feedback on this book

If you have comments on the content of this book, create a ticket at (https://support.developer.arm.com). Give:

- The title (Message Handling Unit Architecture).
- The number (ARM-AES-0072 A.a).
- The section name to which your comments refer.
- The page number(s) to which your comments apply.
- The rule identifier(s) to which your comments apply, if applicable.
- A concise explanation of your comments.

Arm also welcomes general suggestions for additions and improvements.

#### Note

Arm tests PDFs only in Adobe Acrobat and Acrobat Reader, and cannot guarantee the appearance or behavior of any document when viewed with any other PDF reader.

Part A Message Handling Unit Architecture Overview

## Chapter A1 Introduction to Message Handling Unit Architecture

In an SoC there can be multiple systems, each with their own processing elements, peripherals and memory. Each system executes an independent software stack and those software stacks want to communicate with one or more of the other software stacks. The following systems are just some of the many systems that might be found in a typical SoC:

- Application Processor Executes the RichOS or RTOS and performs the primary task of the SoC
- · Communication Processor A modem or WiFi system, which provides communication to an external network
- System Control Processor System control functionality, such as power and clock control
- Security Processor A secure system which provides security functionality to the rest of the SoC. This is typically implemented as a separate system to reduce the possibility of a malicious agent gaining access to secrets.

For the SoC to function as required, the different software entities operating on each of these systems need to communicate with one another. There are different software based communication methods, for example:

- System calls, such as SVC or SMC.
- Events.
- Interrupts.

Each type of communication has advantages and disadvantages and is suitable in different situations.

The usage of system calls and events for communication is considered outside the scope of this architecture. For the remainder of this architecture only interrupt-based communication is considered.

Chapter A1. Introduction to Message Handling Unit Architecture A1.1. Interrupt Based Communication

### A1.1 Interrupt Based Communication

- $I_{NTKVN}$  At the lowest level, interrupt communication depends on a Sender passing an indication of an event to a Receiver. This event is generated by a software operation, that is, an instruction or memory operation. This event is often passed using a physical signal called an interrupt to the Receiver. Alongside the interrupt, additional information can be included either in-band or out-band. The interrupt and additional information form a transfer, sent by the Sender to the Receiver. A number of transfers then form a complete message, with the number of messages dependent on the message protocol.
- I<sub>GKWTZ</sub> A system that uses interrupts includes an Interrupt Controller. It is common for software to be able to generate an interrupt, often referred to as a Inter-Processor Interrupt (IPI), which can be used to support Inter-Process Communication (IPC). SGIs can be generated in many ways including writing a value to a defined memory location.

Chapter A1. Introduction to Message Handling Unit Architecture A1.2. Usage

### A1.2 Usage

IDREGPThe expected usage of a Message Handling Unit (MHU) is to facilitate IPC between pieces of software which<br/>do not share a common Interrupt Controller. The MHU provides a standard interface to software, enabling the<br/>Sender of a message to use a generic driver to send a message without having specific knowledge of the Receiver's<br/>Interrupt Controller.

 $I_{MMJNN}$  This architecture is written with the following assumptions:

- Messages sent across the Message Handling Unit use one of the transport protocols defined in Transport Protocol.
- Sending and receiving agents either have a pre-defined communication format or use an IMPLEMENTATION DEFINED software scheme to negotiate the communication format to use.

Chapter A1. Introduction to Message Handling Unit Architecture A1.3. Architecture Structure

### A1.3 Architecture Structure

I<sub>BRRXV</sub> The MHUv3 architecture provides extensions in Table A1.1.

| Extension                        | Description                                                                                    |
|----------------------------------|------------------------------------------------------------------------------------------------|
| Doorbell Extension (DBE)         | Adds support for Doorbell events to be sent.                                                   |
| FIFO Extension (FE)              | Adds support for variable size in-band payload to be sent using the MHU.                       |
| Fast Channel Extension (FCE)     | Adds support for a low overhead Channel designed to be used to provide the last value written. |
| TrustZone Extension (TZE)        | Adds support for Arm <sup>®</sup> TrustZone <sup>®</sup> to the MHU.                           |
| Realm Management Extension (RME) | Adds support for the Realm Management Extension (RME) of the Armv9-A architecture              |

### Table A1.1: Summary of the Extension in the Message Handling Unit v3.0 architecture

I<sub>DNLGQ</sub> There can be rules defining dependencies between two or more extensions. Examples of these dependencies are:

- Requiring that when extension A is implemented extension B must be implemented.
- Requiring that when extension A is implemented extension B must not be implemented.

#### Note

In this architecture, the term RME is used to refer to the Realm Management Extension defined by the MHUv3.0 architecture.

Part B Message Handling Unit v3.0

## Chapter B1 Message Handling Unit v3.0 Overview

| R <sub>NWMZD</sub> | The MHUv3.0 architecture defines the following extensions:                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>Doorbell Extension (DBE)</li> <li>FIFO Extension (FE)</li> <li>Fast Channel Extension (FCE)</li> <li>TrustZone Extension (TZE)</li> <li>Realm Management Extension (RME)</li> </ul> |
| $R_{ZLLHG}$        | It is IMPLEMENTATION DEFINED which extension an implementation of the MHU implements, but an implementation must implement one of the following extensions:                                  |
|                    | • DBE<br>• FE<br>• FCE                                                                                                                                                                       |
| R <sub>dyppk</sub> | An implementation of the MHUv3.0 sets the fields of the PBX_AIDR, MBX_AIDR, SSC_AIDR and RSC_AIDR registers to the following values:                                                         |
|                    | <ul> <li>ARCH_REV_MAJOR field is set to 0x2.</li> <li>ARCH_REV_MINOR field is set to 0x0.</li> </ul>                                                                                         |
| S <sub>XSGPW</sub> | The extensions implemented are identified to software by the following registers:                                                                                                            |
|                    | <ul> <li>PBX_FEAT_SPT0 and PBX_FEAT_SPT1.</li> <li>MBX_FEAT_SPT0 and MBX_FEAT_SPT1.</li> <li>SSC_FEAT_SPT0 and SSC_FEAT_SPT1.</li> <li>RSC_FEAT_SPT0 and RSC_FEAT_SPT1.</li> </ul>           |
| I <sub>WQMGP</sub> | MHUv3.0 is not backward compatible with previous versions of the MHU architecture.                                                                                                           |

Chapter B1. Message Handling Unit v3.0 Overview B1.1. Structure

### **B1.1 Structure**

MHUS MHUR PBX FCH MBX Config/ ID Reg Config/ ID Reg

 $I_{NTMSN}$  An implementation of MHUv3 has the structure as shown in Figure B1.1

### Figure B1.1: MHU Structure

- MHUS MHU Sender.
- MHUR MHU Receiver.
- DBCH Doorbell Channel.
- FFCH FIFO Channel.
- FCH Fast Channel.
- PBX Postbox.
- MBX Mailbox.
- Config/ID Reg Configuration and Identification registers.

 $R_{FDRJH}$  An instance of the MHUv3.0 includes:

- One MHUS.
- One MHUR.
- One PBX.
- One MBX.
- At least one channel.

## Chapter B2 MHU Sender and Receiver

| I <sub>YRQTP</sub> | An implementation of MHUv3.0 can be implemented as a monolithic or distributed component.                                                                                                                                                                                                                      |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>JWQHX</sub> | The choice of how the MHU is implemented is typically decided by the requirement for the MHU to cross one or more of the following types of domains:                                                                                                                                                           |
|                    | <ul> <li>Clock</li> <li>Reset</li> <li>Power</li> <li>Voltage</li> </ul>                                                                                                                                                                                                                                       |
| R <sub>NVQXF</sub> | The MHUS is used by the agent sending the Transfer.                                                                                                                                                                                                                                                            |
| $R_{ZQWHB}$        | The MHUS is used by the agent receiving the Transfer.                                                                                                                                                                                                                                                          |
| I <sub>RVGLR</sub> | In this architecture the agents sending and receiving the Transfer are referred to as the Sender and Receiver.                                                                                                                                                                                                 |
| R <sub>GWCXP</sub> | When the MHU is implemented as a monolithic component, the MHUS and MHUR are considered as a single entity and enter and exit the Operational state at the same time. For more information on Operational and Non-operational states refer to Chapter B4 <i>Power Control</i> .                                |
| $R_{PTFSJ}$        | When the MHU is implemented as distributed component, the MHUS and MHUR are two different components connected by an interconnect.                                                                                                                                                                             |
| R <sub>QMHGN</sub> | When the MHU is implemented as a distributed component, the MHUS and MHUR are independent entities and are allowed to enter and exit Operational and Non-operational states independently of one another. For information on Operational and Non-operational states refer to Chapter B4 <i>Power Control</i> . |
| R <sub>ZCVWV</sub> | There must be one MHUS and one MHUR connected together to enable unidirectional communication regardless of whether the MHU is implemented as a monolithic or distributed component.                                                                                                                           |
| I <sub>QWFQP</sub> | To separate instances of MHU are required to enable full duplex communication.                                                                                                                                                                                                                                 |

#### Chapter B2. MHU Sender and Receiver

R<sub>SFBNQ</sub> The interconnect used to connect the MHUS and MHUR is IMPLEMENTATION DEFINED, and is allowed to be shared between multiple MHUS/MHUR pairs, as long as one MHUS/MHUR pair is not able to block another.

### R<sub>XHMZQ</sub> The MHUS and MHUR implement the same extensions, except for the following exceptions:

- TZE
- RME
- R<sub>CNFRV</sub> The MHUS has the following interfaces:
  - Configuration interface
  - Interrupt interfaces
  - MHU interface for connection to the MHUR, if the implementation is distributed
- R<sub>CDBBL</sub> The MHUR has the following interfaces:
  - Configuration interface
  - Interrupt interface
  - MHU interface for connection to the MHUS, if the implementation is distributed

## Chapter B3 Postbox and Mailbox

| I <sub>GGGPQ</sub> | The MHUS and MHUR contain one Postbox (PBX) and one Mailbox (MBX) respectively.                                                                                                                        |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>dpvvk</sub> | There is one PBX that is part of the MHUS and is used by the Sender to:                                                                                                                                |
|                    | <ul><li>Configure the behavior of the MHU.</li><li>Send Transfers to the Receiver.</li><li>Receive acknowledgement of a Transfer from the Receiver.</li></ul>                                          |
| R <sub>YGMFZ</sub> | There is one MBX that is part of the MHUR and is used by the Receiver to:                                                                                                                              |
|                    | <ul> <li>Configure the behavior of the MHU.</li> <li>Receive Transfers from the Sender.</li> <li>Acknowledge Transfers sent by the Sender.</li> </ul>                                                  |
| I <sub>KHVTF</sub> | The PBX and MBX contain all the registers used to send Transfers and configure the behavior of the channels allocated to the PBX/MBX.                                                                  |
| R <sub>WDZXK</sub> | A PBX and MBX are allocated a single 64KB frame for all their registers.                                                                                                                               |
| R <sub>KHDJV</sub> | A PBX and MBX contains a IMPLEMENTATION DEFINED number of:                                                                                                                                             |
|                    | <ul> <li><i>Doorbell Channel</i> (DBCH), when DBE is implemented.</li> <li><i>FIFO Channel</i> (FFCH), when FE is implemented.</li> <li><i>Fast Channel</i> (FCH), when FCE is implemented.</li> </ul> |

For information on DBCH, FFCH and FCH refer to Chapter B6 *Doorbell Extension*, Chapter B8 *FIFO Extension* and Chapter B7 *Fast Channel Extension* respectively.

## Chapter B4 Power Control

### **B4.1** Overview

- R<sub>VFNDK</sub> The MHU can be implemented as either monolithic or distributed depending on the configuration of the reset, power and voltage domains. Depending on the implementation the following configuration of reset, power and voltages domains are allowed under the MHUv3.0 architecture:
  - Monolithic
    - MHUS and MHUR share the same reset, power and voltage domains.
  - Distributed
    - MHUS and MHUR can have independent or shared reset, power and voltage domains.
- $I_{KPHYX}$  For the purposes of this architecture the clock is ignored as it is presumed the clock domain is always available or available when required by the MHU. Therefore it is considered to be transparent to the operation of the MHU.
- IDXBBL
   Whether the implementation of the MHU is monolithic or distributed determines the features which are required to be implemented.
- IWhen the MHU implementation is monolithic, the MHUS and MHUR are considered as a single entity and are<br/>both in the Operational or Non-operational state at the same time.
- I\_JVCSGWhen the MHU implementation is distributed, the MHUS and MHUR are considered separate. It is possible for<br/>any of the following to occur:
  - MHUS to be in a Non-operational state when the MHUR is in an Operational state.
  - MHUR to be in a Non-operational state when the MHUS is in an Operational state.

# Chapter B4. Power Control B4.1. Overview

| $D_{FGTMK}$        | An Operational state is where all the following are true:                                                                                                                                                                     |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>the power is supplied</li> <li>the reset is de-asserted</li> <li>the MHUS or MHUR are informed, using an IMPLEMENTATION DEFINED mechanism, that it is in an Operational state</li> </ul>                             |
| D <sub>LYFRJ</sub> | A Non-operational state is where any of the following are true:                                                                                                                                                               |
|                    | <ul> <li>the power is not supplied</li> <li>the reset is asserted</li> <li>the MHUS or MHUR are informed, using an IMPLEMENTATION DEFINED mechanism, that it is in a Non-operational state</li> </ul>                         |
| $U_{\rm JWKHL}$    | An example of an interface which allows the MHUS or MHUR to know whether it is in an Operational or Non-operational state is an instance of an AMBA <sup>®</sup> P-Channel or Q-Channel interface protocol as defined in [1]. |
| R <sub>PBDXY</sub> | Before the Sender can send Transfers it must ensure the MHUS is in and ensure the MHUS remains in an Operational state throughout the Transfer.                                                                               |
| R <sub>tcqhk</sub> | Before the Receiver can access the MHUR to receive information about a Transfer it must make sure the MHUR is in and remains in an Operational state whilst it is doing so.                                                   |
| I <sub>rklrs</sub> | The method by which the Sender and Receiver get the MHUS and MHUR into an Operational state is IMPLEMEN-<br>TATION DEFINED.                                                                                                   |

Chapter B4. Power Control B4.2. Auto Op

### B4.2 Auto Op

L<sub>ZWMZV</sub> Auto Op reduces the software overhead for both the Sender and Receiver when sending Transfers by not requiring the Sender to request the Receiver enter an Operational state before sending the Transfer. Instead the Sender sends the Transfer and the MHUS requests that the MHUR enters an Operational state. The Sender and Receiver can work on a Transfer per Transfer basis or can establish longer communication sessions which cover many Transfers sent over an IMPLEMENTATION DEFINED time period.

 $I_{QBCSW}$  There are two level of the Auto Op protocol:

- Auto Op(Min)
- Auto Op(Full)
- R<sub>GXDVN</sub> The Sender and Receiver can determine which version of the Auto Op protocol is implemented by reading the value of the <x>\_FEAT\_SPT1.AUTO\_OP field. Where <x> is one of the following block prefixes: PBX, MBX, SSC, RSC.

### B4.2.1 Auto Op(Min)

- R<sub>ZFFRG</sub> Auto Op(Min) is only allowed to be implemented when the MHU is implemented as a monolithic component.
- IYQVJHAuto Op(Min) provides no guarantees that any access to the registers of the MHUS or MHUR will complete or<br/>that any Transfer previously sent by Sender will be received by the Receiver.
- R<sub>NWSYP</sub> To guarantee that any accesses to the MHUS and MHUR registers complete, or to guarantee that any Transfers sent by the Sender are received by the Receiver, software must perform a software defined sequence to keep the MHU in an Operational state. For example, making a request to a System Control Processor to enter the MHU into an Operational state.
- $I_{MSYCW}$  As the MHU is implemented as a monolithic component keeping either the MHUS or MHUR in an Operational state also means that the MHUR or MHUS respectively will be kept in an Operational state.
- R<sub>DRHYN</sub> When Auto Op(Min) is implemented there is no requirement for the all channels to be idle before entering into the Non-operational state. For information on entry to the Non-operational state and when a channel is considered idle refer to B4.3 *Entry to a Non-Operational State*.
- S<sub>WNZB2</sub> When Auto Op(Min) is implemented it is the responsibility of the Sender and Receiver to make sure all Transfers and interrupts have been handled before allowing or requesting the MHUS or MHUR to enter into the Non-operational state.
- R<sub>YWTTL</sub> If the Sender of a Transfer requires to know that the Receiver has received a Transfer, the Sender must:
  - Request that the Receiver acknowledges Transfers, using the method defined in the transport protocol being used
  - Keep the MHUS in an Operational state until it has received acknowledgements using a software IMPLEMEN-TATION DEFINED method
- S<sub>VRGXC</sub> If requested, the Receiver of a Transfer must acknowledge the Transfer.
- S<sub>TJVMN</sub> When Auto Op(Min) is implemented the Sender and Receiver must perform a software IMPLEMENTATION DEFINED sequence, to ensure the MHUS and MHUR enter and remain in an Operational state through the sending of the Transfer(s). This must be performed before the Sender and Receiver perform the steps defined by the transport protocol used to send the Transfer.

After the transport protocol is complete the Sender and Receiver can perform a software IMPLEMENTATION DEFINED sequence, to enable the MHUR and MHUR to enter a Non-operational state, if there are no further Transfers to send, otherwise they continue to send Transfer using the steps defined by the transport protocol to be used.

### B4.2.2 Auto Op(Full)

| R <sub>QRHPW</sub> | Auto Op(Full) is used when the MHU is implemented as a distributed component.                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>TXDWB</sub> | It is allowed for a monolithic implementation of the MHU to implement Auto Op(Full).                                                                                                                                                                                                                                                                                                                                                                   |
| I <sub>SMSKS</sub> | Auto Op(Full) provides the following features:                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>An automatic request for MHUR to enter an Operational state when a new Transfer is started.</li> <li>A method for the Sender or Receiver to request the MHUS or MHUR respectively remains in an Operational state.</li> <li>A method for the Sender or Receiver to ignore outstanding Transfers.</li> </ul>                                                                                                                                   |
| $R_{XWLJD}$        | When the Sender attempts to send a Transfer the MHUS is required to request the MHUR enters an Operational state. The method by which the MHUS achieves this is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                |
| $R_{NZDHL}$        | The MHUS is required to keep the MHUR in an Operational state until it has completed the actions required to inform the MHUR of a pending Transfer.                                                                                                                                                                                                                                                                                                    |
| R <sub>vyshz</sub> | Once the MHUS has performed the actions required to inform the MHUR of a pending Transfer, it is the responsibility of the MHUR to keep itself in an Operational state, if it is configured to consider the state of the channels before entering the Non-operational state, until the Receiver acknowledges the Transfer.                                                                                                                             |
| R <sub>QGZCP</sub> | The Sender and Receiver can use the PBX_CTRL.CH_OP_MSK and MBX_CTRL.CH_OP_MSK fields respectively to control whether the MHUS and MHUR consider the state of channels when requested to enter a Non-operational state.                                                                                                                                                                                                                                 |
| $R_{PNLFC}$        | The Sender and Receiver can use the PBX_PWR_CFG.OP_REQ and MBX_PWR_CFG.OP_REQ fields respectively to request that either MHUS or MHUR remains in an Operational state.                                                                                                                                                                                                                                                                                 |
| R <sub>JYVVY</sub> | The method by which the MHUS and MHUR indicate the need to be in an Operational state is iS IMPLEMENTATION DEFINED.                                                                                                                                                                                                                                                                                                                                    |
| $U_{LYGPM}$        | An example of an interface which allows the MHUS or MHUR to indicate it requires to remain in an Operational state is an instance of an AMBA <sup>®</sup> P-Channel or Q-Channel interface protocol as defined in [1].                                                                                                                                                                                                                                 |
| R <sub>fwtvl</sub> | If the Sender of a Transfer requires to know that the Receiver has received a Transfer, the Sender must:                                                                                                                                                                                                                                                                                                                                               |
|                    | <ul> <li>Request that the Receiver acknowledges Transfers, using the method defined in the transport protocol being used.</li> <li>Keep the MHUS in an Operational state until it has received acknowledgements by setting the PBX_CTRL.OP_REQ field to 0b1.</li> </ul>                                                                                                                                                                                |
| S <sub>TDFYV</sub> | If requested, the Receiver of a Transfer must acknowledge the Transfer.                                                                                                                                                                                                                                                                                                                                                                                |
| I <sub>TGGMV</sub> | The method by which the Receiver acknowledges a Transfer depends on the transport protocol being used.                                                                                                                                                                                                                                                                                                                                                 |
| S <sub>YVPCV</sub> | The recommended software sequence for the Sender to send a Transfer when Auto Op(Full) is implemented is:                                                                                                                                                                                                                                                                                                                                              |
|                    | <ol> <li>When the Sender wants to send a Transfer it first set the PBX_CTRL.OP_REQ field to 0b1 to make sure the MHUS remains in an Operational state.</li> <li>Perform the steps defined by the selected transport protocol to send the Transfer.</li> <li>If the Sender has more Transfers to send, it repeats step 2.</li> <li>Set the PBX_CTRL.OP_REQ to 0b0 to remove the requirement for the MHUS to remain in the Operational state.</li> </ol> |
|                    | It is allowed for the Sender to send another Transfer, if required, using the same or different channels before completing all steps of the transport protocol, as long as all the following are all true:                                                                                                                                                                                                                                             |
|                    | <ul> <li>All steps in the transport protocol are performed before step 4.</li> <li>When sending the new Transfer using the same DBCH the Transfer uses a flag bit which currently doesn't</li> </ul>                                                                                                                                                                                                                                                   |

• When sending the new Transfer using the same DBCH the Transfer uses a flag bit which currently doesn't have a Transfer outstanding.

## Chapter B4. Power Control B4.2. Auto Op

S<sub>QMNYB</sub> The recommended software sequence for the Receiver to use when Auto Op(Full) protocol on receiving an interrupt from the MHUR is:

- 1. If the Sender and Receiver are setting up a long term communication session the Receiver sets the MBX\_CTRL.OP\_REQ fields to 0b1
- 2. Process the interrupt from the MHU using the steps defined by the transport protocol being used to send the Transfer

This processing can include one or more of the following:

- Reading out-band memory locations.
- Acknowledge the Transfer.
- 3. Wait for the next Transfer in the communication session to arrive before repeating step 2.
- 4. When the communication session is no longer required the Receiver sets the MBX\_CTRL.OP\_REQ field to 0b0.

It is allowed for the Receiver to receiver another Transfer, if required, using the same or different channels before completing all steps of the transport protocol, as long as all steps in the transport protocol are performed before step 4.

- S<sub>NNPTS</sub> When the Sender no longer wants to send Transfers to the Receiver and it has received all the expected Transfer Acknowledgements it was expecting, it sets the PBX\_CTRL.OP\_REQ field to 0b0, if it is not already set to 0b0.
- The MHUS and MHUR can only enter the Non-operational state if all the DBCHs, FFCHs and FCs are idle. If the Sender or Receiver wants to enter the MHUS or MHUR into a Non-operational state immediately without waiting for any outstanding or new Transfers to complete, the Sender or Receiver can set PBX\_CTRL.CH\_OP\_MSK or MBX\_CTRL.CH\_OP\_MSK to 0b1. This causes all channels to be considered idle for the purpose of entry into the Non-operational state. Setting either PBX\_CTRL.CH\_OP\_MSK or MBX\_CTRL.CH\_OP\_MSK to 0b1 can lead to lost of Transfer data and Transfer Acknowledgements.

Arm recommends that the:

- Sender or Receiver informs the other that they want to enter the MHUS or MHUR into a Non-operational state before they set the PBX\_CTRL.CH\_OP\_MSK or MBX\_CTRL.CH\_OP\_MSK field to 0b1.
- Sender on receipt of this request stops sending new Transfers.
- Receiver on receipt of this request is prepared that accesses to retrieve data from the FIFO may result in no data being returned.
- S<sub>BKSHQ</sub> There are times when the MHUR enters a Non-operational state, whereby it may be slower to exit from the Non-operational state than normal. For example, the MHUR will take longer to exit a Non-operational state where the power is removed compare to the time taken for the MHUR to exit a Non-operational state where the power was not removed and only the reset was asserted.

In these cases it is desirable for the Sender to be aware so that it can perform a software IMPLEMENTATION DEFINED sequence to wake the MHUR. This allows the Sender to perform other actions whilst the MHUR enters the Operational state,

It is the responsibility of the Sender and Receiver to negotiate this using a software IMPLEMENTATION DEFINED method before the MHUR enters the Non-operational state.

S<sub>YDQHS</sub> There are times when the MHUR enters a Non-operational state, whereby it is unable to exit from without actions being performed by another entity in the system. An example of this is when the MHUR enters a Non-operational state and the voltage supply used by the power domain is turned off. For the MHUR to enter an Operational state the voltage supply must be turned on before then powering the power domain back on. The process of enabling and disabling voltage supplies typically requires software interventions, for example by a System Control Processor.

In these cases it is required that the Sender is aware, so that it can perform a software IMPLEMENTATION DEFINED sequence to wake the MHUR. The software IMPLEMENTATION DEFINED sequence may be limited to removing the deadlock possibility, for example sending a request to a System Control Processor to enable the voltage supply for the power domain, and not actually entering the MHUR into an Operational state.

### B4.3 Entry to a Non-Operational State

- I<sub>BWJVC</sub> The MHUS and MHUR can enter a Non-operational state in either a controlled or uncontrolled manner.
- $\mathbb{I}_{QQQVK}$  Depending on whether it is the MHUS or MHUR and whether the entry is controlled or uncontrolled the entry into a Non-operational state is different. The following sections defines the rules for both controlled and uncontrolled entry into a Non-operational state for both the MHUS and MHUR.

### B4.3.1 Controlled entry into Non-operational state

A controlled entry into the Non-operational state for either the MHUS or MHUR is defined as when the MHUS or  $\mathsf{R}_{\mathrm{NNYLN}}$ MHUR is requested to enter the Non-operational state and the MHUS or MHUR accept the request before then entering the Non-operational state. It is valid for the MHUS or MHUR to deny entry into a Non-operational state and to then remain in the Operational Ryodsm state. After a denial to a request to enter the Non-operational state in a controlled manner, it is valid for additional requests, IYOBDG to be made without any changes in conditions. It is also valid for an uncontrolled entry into the Non-operational state to occur after a denial of a controlled entry. The request to enter a Non-operational state comes from an IMPLEMENTATION DEFINED hardware entity which IVOHCE might have been triggered by software running on the Sender, Receiver or another agent. The method by which the IMPLEMENTATION DEFINED hardware entity makes the request to the MHUS or MHUR is IMPLEMENTATION DEFINED. An instance of an AMBA® P-Channel or Q-Channel interface protocol, as defined in [1], is an example of an interface which allows for the IMPLEMENTATION DEFINED hardware entity, referred to as a controller by [1], to make requests to the MHUS or MHUR to enter or exit a Non-operational state. For the MHUS to accept entry into the Non-operational state, the following must all be true: Roovms • No outstanding accesses from the MHUS or Sender to the MHUR reset domain. • No outstanding accesses from the MHUR or Receiver to the MHUS reset domain. • No outstanding accesses to the MHUS by the Sender. • When all DBCHs and FFCHs are idle. • The value of PFFCW<n>\_CTRL.FF is equal to PFFCW<n>\_ST.FF for all implemented FFCHs. • PBX\_CTRL.OP\_REQ is set to 0b0, if Auto Op(Full) is implemented. IWPDZS Arm strongly recommends that before the MHUS enters the Non-operational state in a controlled manner that the Sender completes all Transfers, including receiving any acknowledgements associated with those Transfers. For the MHUR to accept entry into the Non-operational state the following must all be true: R<sub>QYXDM</sub> • No outstanding accesses from the MHUS or Sender to the MHUR reset domain. • No outstanding accesses from the MHUR or Receiver to the MHUS reset domain. • No outstanding accesses to the MHUR from the Receiver. • All DBCHs, FFCHs and FCs are idle. • The value of MFFCW<n>\_CTRL.FF is equal to MFFCW<n>\_ST.FF for all implemented FFCHs. • MBX\_CTRL.OP\_REQ is set to 0b0, if Auto Op(Full) is implemented. Arm strongly recommends that when the MHUR enters the Non-operational state in a controller manner and the ISZRND exit time is considered to be a long duration or exit from the Non-operational state requires interaction with a hardware or software entity external to the MHU that the Sender is informed of this. This allows the Sender to take different action when it requires the MHUR to enter an Operational state. An access to the MHUS or MHUR is considered outstanding until all the required effects of the access are complete. R<sub>TDCNZ</sub> This includes any side effects from the access. If the registers is one of the registers which supports early write

responses, the access is considered outstanding, even though the write response may been returned, until the required steps have been completed.

Examples of side effects an access can have are:

• Update to fields within other registers.

For example, a write to the MFFCW<n>\_FIFO\_POP field, when the MFFCW<n>\_CTRL.RA\_EN field is set to 0b0, cause a number of bytes to be popped from the FIFO. This leads to an update of the following fields:

- PFFCW<n>\_ST.FFS
- PFFCW<n>\_PAY.FFS
- PFFCW<n>\_ACK\_CNT.ACN\_CNT and PFFCW<n>\_ACK\_CNT.ACK\_CNT\_OVRFLW fields, if any of popped bytes generated a FIFO Pop Ack event
- MFFCW<n>\_ST.FFL
- MFFCW<n>\_FLG.FFL
- Update of the status of any interrupts.

boundary between the MHUS and MHUR.

For example, a read of the MFCW<n>\_PAY register causes the Channel Transfer interrupt for the FCH to be updated. • Update of any IMPLEMENTATION DEFINED internal state of the MHU. When Auto Op(Min) is implemented a DBCH is always considered idle. R<sub>KTPMT</sub> When Auto Op(Full) is implemented, for the MHUS a DBCH is considered idle when either of the following are RDHSLS true: • All bits in the PDBCW<n>\_ST register are 0b0, and PBX\_CTRL.CH\_OP\_MSK is set to 0b0. • PBX\_CTRL.CH\_OP\_MSK is set to Ob1. When Auto Op(Full) is implemented, for the MHUR a DBCH is considered idle when either of the following are  $\mathsf{R}_{\mathsf{KMQWB}}$ true: • All bits in the MDBCW<n>\_ST register are 0b0, and MBX\_CTRL.CH\_OP\_MSK is set to 0b0. • MBX\_CTRL.CH\_OP\_MSK is set to 0b1. When Auto Op(Min) is implemented a FFCH is always considered idle. RVBYYM When Auto Op(Full) is implemented, for the MHUS a FFCH is considered idle when either of the following are R<sub>CMHCV</sub> true: • FIFO is empty and PBX\_CTRL.CH\_OP\_MSK is set to 0b0. • PBX\_CTRL.CH\_OP\_MSK is set to Ob1. When Auto Op(Full) is implemented, for the MHUR a FFCH is considered idle when either of the following are R<sub>CBTZN</sub> true: • FIFO is empty and MBX\_CTRL.CH\_OP\_MSK is set to 0b0. • MBX\_CTRL.CH\_OP\_MSK is set to Ob1. When Auto Op(Min) is implemented a FCH is always considered idle. R<sub>THYRL</sub> When Auto Op(Full) is implemented a FCH is considered idle when either of the following are true: RVCZVF • MBX\_CTRL.CH\_OP\_MSK is set to 0b0 and there is no outstanding Transfer • MBX\_CTRL.CH\_OP\_MSK is set to 0b1. A Transfer is considered outstanding for an FCH from the point where the write to the PFCW<n>\_PAY register R<sub>PNBDG</sub> occurs until the read of the MFCW<n>\_PAY register, allowing for any delay in crossing a clock, reset and power

- I\_ZMNQY
   The value of the MBX\_FCH\_CTRL.INT\_EN field has no effect on whether a Transfer in an FCH is considered outstanding or not. The MBX\_FCH\_CTRL.INT\_EN field only controls whether an interrupt is generated.
- I<sub>RBSVR</sub> For more information on Auto Op(Min) and Auto Op(Full) refer to B4.2 *Auto Op*.

### B4.3.2 Uncontrolled entry into a Non-operational state

| R <sub>gsrny</sub> | An uncontrolled entry into the Non-operational state for either the MHUS or MHUR, is defined as when the MHUS or MHUR enter the Non-operational state, without having accepted a request to enter the Non-operational state.                                                                                                                                         |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>YWFYT</sub> | An uncontrolled entry into the Non-operational state can occur at any point, including after a previous attempt to enter the Non-operational state in a controlled manner that was denied by either the MHUS or MHUR.                                                                                                                                                |
| I <sub>rkpkh</sub> | Uncontrolled resets are not expected to be generated under normal operating conditions and are expected to be generated as a last response to a system deadlock or security impact. For example, a watchdog event.                                                                                                                                                   |
| R <sub>FHLRF</sub> | If the MHUS or MHUR enter the Non-operational state in an uncontrolled manner it is UNPREDICTABLE whether:                                                                                                                                                                                                                                                           |
|                    | <ul><li>Any Transfers that were outstanding at the time are lost or not.</li><li>If FE is implemented:</li></ul>                                                                                                                                                                                                                                                     |
|                    | <ul> <li>The value of PFFCW<n>_ST.FFS and MFFCW<n>_ST.FFL accurately reflects the number of<br/>valid bytes in the FIFO.</n></n></li> </ul>                                                                                                                                                                                                                          |
|                    | <ul> <li>Any bytes are written to the FIFO on a write of the MFFCW<n>_PAY register.</n></li> <li>Any bytes are read from the FIFO on a read of the MFFCW<n>_PAY register.</n></li> <li>Any bytes are popped from the FIFO on a read of MFFCW<n>_PAY, when MFFCW<n>_CTRL.RA_EN is set to 0b1, or on a write to the MFFCW<n>_FIFO_POP register.</n></n></n></li> </ul> |
| $S_{RDKMF}$        | Software must be prepared that if an uncontrolled entry into the Non-operational state occurs for either the MHUS or MHUR that:                                                                                                                                                                                                                                      |
|                    | <ul><li>Any Transfers which have not been acknowledged by the Receiver might have been lost.</li><li>Sending of any future Transfers might not be possible.</li></ul>                                                                                                                                                                                                |
| $S_{QKBGJ}$        | Arm recommends that software perform an IMPLEMENTATION DEFINED sequence to recover the MHU to a known state before sending any new Transfers. Part of the IMPLEMENTATION DEFINED sequence might include flushing any FFCHs which are implemented, using the FIFO flush mechanism.                                                                                    |
| R <sub>wcrcg</sub> | It is UNPREDICTABLE whether the MHUS considers the MHUR to be in an Operational or Non-operational state, if the MHUR entered the Non-operational state in an uncontrolled manner. This means it is valid for the MHUS to treat the MHUR as if it was in an Operational state even though it has entered an Non-operational state.                                   |
| R <sub>vscxq</sub> | It is UNPREDICTABLE whether the MHUR considers the MHUS to be in an Operational or Non-operational state, if the MHUS entered the Non-operational state in an uncontrolled manner. This means it is valid for the MHUR to treat the MHUS as if it was in an Operational state even though it has entered an Non-operational state.                                   |
| I <sub>XKCGC</sub> | For the remainder of this architecture when talking about either the MHUS or MHUR being in a Non-operational state, implies that the MHUS or MHUR entered the Non-operational state in a controlled manner.                                                                                                                                                          |

## Chapter B5 Data Endianness

| I <sub>JYRLY</sub> | It is possible that the Sender and Receiver use different data endianness when sending Transfers between each |
|--------------------|---------------------------------------------------------------------------------------------------------------|
|                    | other.                                                                                                        |

- R<sub>FBSSF</sub> The registers of the MHU are little-endian device.
- S<sub>JTRFV</sub> It is the responsibility of the Sender and Receiver to perform any byte swapping operations when passing data in-band using the MHU. This means any Sender or Receiver that uses an endianness other than little-endian will need to perform a sequence to arrange the bits and bytes of the payload to be little-endian, when accessing any registers of the MHU.
- S<sub>TDDYX</sub> If the Sender and Receiver used different endianness, software must agree on, the endianness of any out-band payload which is sent along side the Transfer. Failure to do so will lead to corruption or lost of Transfer data.
- S<sub>PXTMM</sub> The method the Sender and Receiver agree on a data endianness to use for out-band payload is software defined.

## Chapter B6 Doorbell Extension

| I <sub>rvwpv</sub> | The Doorbell Extension (DBE) defines a type of channel called a Doorbell Channel (DBCH).                                                                                                                                                 |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>MNMQF</sub> | A DBCH enables a single bit Transfer to be sent from the Sender to Receiver. The Transfer indicates that an event has occurred.                                                                                                          |
| R <sub>HBNFC</sub> | When DBE is implemented, the number of DBCHs implemented is IMPLEMENTATION DEFINED between 1 and 128.                                                                                                                                    |
| R <sub>KSKHN</sub> | When DBE is not implemented, all registers related to DBCHs are reserved and it is considered that the MHU has 0 DBCH.                                                                                                                   |
| R <sub>ZJLJR</sub> | DBCH are numbered starting from 0 in ascending order.                                                                                                                                                                                    |
| R <sub>kgfdb</sub> | Each DBCH contains 32 individual fields, referred to as flags, each of which can be used independently.                                                                                                                                  |
| R <sub>PWNZN</sub> | The meaning of each flag in a DBCH is defined by software.                                                                                                                                                                               |
| $R_{QBZLZ}$        | It is possible for the Sender to send multiple Transfers at once using a single DBCH, so long as each Transfer uses a different flag in the DBCH.                                                                                        |
| R <sub>rdwwb</sub> | The Receiver of the Transfer is required to acknowledge receipt of the Transfer, by clearing the flag, before it can receive a new Transfer using the same flag.                                                                         |
| S <sub>JCTVP</sub> | Sending two Transfers using the same flag of the same DBCH without waiting for the first Transfer to be acknowledged by the Receiver can lead lead to the two Transfers being merged into a single Transfer as observed by the Receiver. |
| R <sub>tyvkt</sub> | A DBCH has the following resources:                                                                                                                                                                                                      |
|                    | <ul><li>A Doorbell Channel Window.</li><li>Storage for 32 flags.</li></ul>                                                                                                                                                               |

- Channel Transfer event.
- Channel Transfer Acknowledge event.
### B6.1 Doorbell Channel Window

R<sub>YYDGW</sub> The Doorbell Channel Window is 8 32-bit words.

R<sub>HYMRJ</sub> Table B6.1 shows the registers in the DBCW when accessed via the PBX:

#### Table B6.1: DBCW when accessed from PBX

| Offset | Name                  | Access |
|--------|-----------------------|--------|
| 0x00   | PDBCW <n>_ST</n>      | RO     |
| 0x04   | Reserved              |        |
| 0x08   | Reserved              |        |
| 0x0C   | PDBCW <n>_SET</n>     | WO/RAZ |
| 0x10   | PDBCW <n>_INT_ST</n>  | RO     |
| 0x14   | PDBCW <n>_INT_CLR</n> | WO/RAZ |
| 0x18   | PDBCW <n>_INT_EN</n>  | RW     |
| 0x1C   | PDBCW <n>_CTRL</n>    | RW     |

R<sub>JYYHF</sub> Table B6.2 shows the registers in the DBCW when accessed via the MBX:

#### Table B6.2: DBCW when accessed from MBX

| Offset | Name                  | Access |
|--------|-----------------------|--------|
| 0x00   | MDBCW <n>_ST</n>      | RO     |
| 0x04   | MDBCW <n>_ST_MSK</n>  | RO     |
| 0x08   | MDBCW <n>_CLR</n>     | WO/RAZ |
| 0x0C   | Reserved              |        |
| 0x10   | MDBCW <n>_MSK_ST</n>  | RO     |
| 0x14   | MDBCW <n>_MSK_SET</n> | WO/RAZ |
| 0x18   | MDBCW <n>_MSK_CLR</n> | WO/RAZ |
| 0x1C   | MDBCW <n>_CTRL</n>    | RW     |

- R<sub>FFHVZ</sub> The PDBCW<n>\_SET and MDBCW<n>\_CLR register update the value of the {PDBCW/MDBCW}<n>\_ST registers as follows:
  - Any field set to 0b0 by a write to either register is ignored.
  - Any field set to 0b1 in the PDBCW<n>\_SET register sets the associated field in the {PDBCW/MDBCW}<n>\_ST registers to 0b1.
  - Any field set to 0b1 in the MDBCW<n>\_CLR register clears the associated field in the {PDBCW/MDBCW}<n>\_ST registers to 0b0.
- $R_{CYWTR}$  The setting of a bit in the {PDBCW/MDBCW}<n>\_ST takes precedence over clearing.

## Chapter B6. Doorbell Extension B6.1. Doorbell Channel Window

- $S_{SPCCB}$  Arm strongly recommends that the Sender never writes to the PDBCW<n>\_SET register to set a field which is already set in the {PDBCW/MDBCW}<n>\_ST register.
- R<sub>CRNNS</sub> The MDBCW<n>\_ST\_MSK register is the result of a bitwise AND between the MDBCW<n>\_ST and the inverted value of the MDBCW<n>\_MSK\_ST register.
- R<sub>CHMVJ</sub> The MDBCW<n>\_MSK\_SET and MDBCW<n>\_MSK\_CLR registers update the value of the MDBCW<n>\_MSK\_ST as follows:
  - Any field set to 0b0 by a write to either register is ignored.
  - Any field set to 0b1 in the MDBCW<n>\_MSK\_SET register sets the associated field in the MDBCW<n>\_MSK\_ST register to 0b1.
  - Any field set to 0b1 in the MDBCW<n>\_MSK\_CLR register clears the associated field in the MDBCW<n>\_MSK\_ST register to 0b0.

R<sub>ZSRMX</sub> The setting of a bit in the MDBCW<n>\_MSK\_ST register takes precedence over clearing.

Chapter B6. Doorbell Extension B6.2. Events

### **B6.2 Events**

I<sub>DCMYB</sub> Each DBCH has the following events:

- 32 Channel Transfer.
- Channel Transfer Acknowledge.

#### B6.2.1 Channel Transfer event

 $R_{BTBCW}$  There is a Channel Transfer event per each flag in the DBCH.

R<sub>WMYTF</sub> Channel Transfer event <x> is generated when a write to the PDBCW<n>\_SET.FLG<x> with a value of 0b1 occurs.

#### B6.2.2 Channel Transfer Acknowledge event

 $R_{LRFNQ} A Channel Transfer Acknowledge event is generated when the Receiver writes to the MDBCW<n>_CLR register, independent of whether any bits in the {PDBCW/MDBCW}<n>_ST register are updated.$ 

## Chapter B7 **Fast Channel Extension**

| I <sub>BVHJC</sub> | The Fast Channel Extension (FCE) defines a type of channel called a Fast Channel (FCH).                                                                                                                                                                                                                                                              |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>YMZJW</sub> | A FCH is intended for lower overhead communication between Sender and Receiver at the expense of determinism. A FCH allows the Sender to update the channel value at any time, regardless of whether the previous value has been seen by the Receiver. When the Receiver reads the channel's contents it gets the last value written to the channel. |
| I <sub>FNZMK</sub> | A FCH is considered lossy in nature, and means that the Sender has no architected way of knowing if or when the Receiver will act on the Transfer.                                                                                                                                                                                                   |
| I <sub>zpzsn</sub> | FCHs are expected to behave as RAM which generates interrupts when writes occur to the locations within the RAM.                                                                                                                                                                                                                                     |
| R <sub>yjxzz</sub> | The reset value of a FCH is UNKNOWN.                                                                                                                                                                                                                                                                                                                 |
| R <sub>fmnwt</sub> | When FCE is implemented, the number of FCH that an implementation of the MHU can support is IMPLEMENTA-<br>TION DEFINED between:                                                                                                                                                                                                                     |
|                    | <ul> <li>1-1024, when the Fast Channel word-size is 32-bits.</li> <li>1-512, when the Fast Channel word-size is 64-bits.</li> </ul>                                                                                                                                                                                                                  |
| R <sub>XFZZB</sub> | When FCE is not implemented, the number of FCH is 0 and all registers related to FCHs are Reserved.                                                                                                                                                                                                                                                  |
| R <sub>CKLPQ</sub> | FCH are numbered from 0 in ascending order.                                                                                                                                                                                                                                                                                                          |
| Sywknx             | FCHs must only be used for sending Transfers where all the following apply:                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>If the Sender writes two values to the same FCH it does not matter if the Receiver sees both values as two separate Transfer or sees only the last value written.</li> <li>Sender does not require any indication that the Receiver has received the Transfer</li> </ul>                                                                    |

ndication that the Receiver has received the Transfer. naer aoes not rea ure any

#### Chapter B7. Fast Channel Extension

| R <sub>XVPTY</sub> | A FCH has the following resources:                                                                                                                        |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>A Fast Channel Window.</li> <li>Fast Channel Storage.</li> <li>A Channel Transfer event.</li> </ul>                                              |
| R <sub>czchk</sub> | Alongside the resource each FCH has, there is a set of shared Fast Channel Control registers which are shared between all FCH implemented in the Mailbox. |

### **B7.1 Fast Channel Groups**

| I <sub>BWJJT</sub> | FCHs are controlled in groups called Fast Channel Groups (FCG).                                                                                                                                                                                                                                                             |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>rbqdq</sub> | There can be between 1 and 32 FCGs in a Postbox or Mailbox.                                                                                                                                                                                                                                                                 |
| R <sub>LHHTS</sub> | A FCG can contain between 1 and 32 FCHs.                                                                                                                                                                                                                                                                                    |
| R <sub>bctpb</sub> | The number of FCGs is less than or equal to the number of FCHs implemented in the MHU.                                                                                                                                                                                                                                      |
| R <sub>qzqbp</sub> | The number of FCH in each FCG is defined as:                                                                                                                                                                                                                                                                                |
|                    | NUM_FCH_PER_FCG = NUM_FCH / NUM_FCG                                                                                                                                                                                                                                                                                         |
|                    | Where:                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>NUM_FCG is the number of FCGs in the PBX or MBX.</li> <li>NUM_FCH is the number of FCHs in the PBX or MBX.</li> <li>NUM_FCH_PER_FCG is the number of FCHs per FCG.</li> </ul>                                                                                                                                      |
| S <sub>XKBTS</sub> | Software can discover:                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>The number of FCHs in the Postbox or Mailbox using the value of <x>_FCH_CFG0.NUM_FCH field.</x></li> <li>The number of FCGs in the Postbox or Mailbox using the value of <x>_FCH_CFG0.NUM_FCG field.</x></li> <li>The number of FCHs per FCG using the value of <x>_FCH_CFG0.NUM_FCH_PER_FCG field.</x></li> </ul> |
|                    | Where <x> is either PBX for the Postbox or MBX for the Mailbox.</x>                                                                                                                                                                                                                                                         |
| R <sub>dzvyv</sub> | The FCH which are part of FCG <n> can be determined as follows:</n>                                                                                                                                                                                                                                                         |
|                    | <ul> <li>Lowest FCH in the Group is = n * NUM_FCH_PER_FCG.</li> <li>Highest FCH in the Group is = ((n + 1) * NUM_FCH_PER_FCG) - 1.</li> </ul>                                                                                                                                                                               |
|                    |                                                                                                                                                                                                                                                                                                                             |

Where *<*n*>* is the FCG number.

### B7.2 Fast Channel Storage

| I <sub>XYVYR</sub> | The size of the storage of the FCH is set by the Fast Channel word-size.                                   |
|--------------------|------------------------------------------------------------------------------------------------------------|
| R <sub>CMPSG</sub> | The Fast Channel word-size can be either 32-bit or 64-bit in size.                                         |
| R <sub>QDTWK</sub> | All FCHs have the same Fast Channel word-size.                                                             |
| S <sub>RHCHH</sub> | Software can discover the Fast Channel word-size by reading the value of the <x>_FCH_CFG.FCH_WS field.</x> |
|                    | Where <x> is either PBX for the Postbox or MBX for the Mailbox.</x>                                        |

### **B7.3 Fast Channel Window**

| R <sub>kbwzw</sub> | The Fast Channel Window (FCW) allows the Sender and Receiver to access the registers of the FCH. |
|--------------------|--------------------------------------------------------------------------------------------------|
| R <sub>JZZPV</sub> | When the Fast Channel word-size is 32-bit the FCW occupies 4bytes aligned on a 4 byte boundary.  |
| R <sub>BLKRB</sub> | When the Fast Channel word-size is 64-bit the FCW occupies 8bytes aligned on an 8 byte boundary. |

R<sub>SCKMT</sub> Table B7.1 shows the registers in the FCW when accessed via the PBX:

#### Table B7.1: FCW when accessed from PBX

| Offset | Name             | Access |
|--------|------------------|--------|
| 0x00   | PFCW <n>_PAY</n> | RW     |

R<sub>NYDRX</sub> Table B7.2 shows the registers in the FCW when accessed via the MBX:

#### Table B7.2: FCW when accessed from MBX

| Offset | Name             | Access |
|--------|------------------|--------|
| 0x00   | MFCW <n>_PAY</n> | RW     |

#### Note

Both the PFCW<n>\_PAY and MFCW<n>\_PAY registers are either a 32-bit or 64-bit version depending on the Fast Channel word-size. In this architecture, the term PFCW<n>\_PAY and MFCW<n>\_PAY refers to either version of the register, whilst PFCW<n>\_PAY32/MFCW<n>\_PAY32 and PFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n>\_PAY64/MFCW<n<\_PAY64/MFCW<n>\_PAY64/MFCW<n<\_PAY64/MFCW<n>\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n>\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MFCW<n<\_PAY64/MF

- $\mathbb{I}_{\text{ZDJCN}}$  The PFCW<n>\_PAY and MFCW<n>\_PAY registers are windows to the storage of the FCH and therefore a write to the FCH through either the PFCW<n>\_PAY or MFCW<n>\_PAY register is visible by a read to either register.
- S<sub>MCTKS</sub> The Sender and Receiver must access the FCW atomically aligned to the Fast Channel word-size, otherwise, partial or corrupted data can be read from or stored to the FCH(s).
- S<sub>NGTYH</sub> If software accesses the FCW with a size that is not equal to the Fast Channel word-size, but is a supported transaction size of the MHU, the MHU treats this as a legal access and will perform the operation, including generating the Channel Transfer event. For information on the supported transaction sizes of the MHU refer to C1.1 *Register Access*,
- R<sub>KBSFG</sub> There is no guarantee of ordering between read and write accesses between either the PFCW<n>\_PAY and MFCW<n>\_PAY register.
- S<sub>PCPVL</sub> To avoid data loss or consumption of UNKNOWN data, the Sender and Receiver must:
  - Only use a FCH to send data from the Sender to the Receiver as defined by one of the transport protocols defined in Chapter D2 *Transport Protocols*.
  - Never allow both Sender and Receiver to write to the FCH at the same time, the method by which the Sender and Receiver coordinate this is software IMPLEMENTATION DEFINED.
  - If the FCH is not to be initialized by either the Sender or Receiver to a known value, the:

- Sender must write all bytes with a value when writing to a FCH.
- Receiver must only read the FCH after the write has occurred for that FCH. The FCH Transfer or Fast Channel Group Transfer interrupts can be used to know when the write has occurred.
- If the FCH is to be initialized to a known value by the Receiver, then:
  - The Receiver must inform the Sender it is going to initialize the FCH using a software IMPLEMEN-TATION DEFINED method.
  - The Sender must not perform any writes to the FCH which is to be initialized.
  - The Receiver must inform the Sender when the FCH has been initialized using a software IMPLE-MENTATION DEFINED method.
  - The Sender must check that it can observe the initialized value before sending any Transfers using the FCH.
- If the FCH is to be initialized to a known value by the Sender, then:
  - The Sender must inform the Receiver it is going to initialize the FCH using a software IMPLEMEN-TATION DEFINED method.
  - The Sender must inform the Receiver when the FCH has been initialized using a software IMPLE-MENTATION DEFINED method.
  - The Receiver must clear any Channel Transfer event for the FCH which is being initialized, ignoring the value in FCH.

### **B7.4 Fast Channel Control registers**

- IBXFDT
   FCHs are controlled exclusively by the Receiver using the Fast Channel Control registers implemented in the Mailbox Control page.
- $I_{YNPDC}$  There are no control registers for FCHs in the Postbox.
- R<sub>ZSKVF</sub> Table B7.3 shows the registers used to control the FCHs and their location within the Mailbox Control page of the Mailbox.

#### Table B7.3: Fast Channel control registers located in the MBX\_CTRL page when accessed via MBX

| Offset          | Name                   | Access |
|-----------------|------------------------|--------|
| 0x140           | MBX_FCH_CTRL           | RW     |
| 0x144           | MBX_FCH_GRP_INT_EN     | RW     |
| 0x470           | MBX_FCH_GRP_INT_ST     | RO     |
| 0x480 + (4 * n) | MBX_FCG <n>_INT_ST</n> | RO     |

R<sub>XDBJN</sub> The MBX\_FCH\_GRP\_INT\_EN, MBX\_FCH\_GRP<n>\_INT\_ST and MBX\_FCH\_GRP\_INT\_ST registers are only implemented if Fast Channel Group Transfer Interrupts are implemented, otherwise they are RES0.

Refer to Chapter B11 Interrupts for more information on Fast Channel Group Transfer Interrupts.

### B7.5 Read-Acknowledge

 IZSYWN
 FCHs support Read-Acknowledge, which reduces the software overhead for the Receiver by allowing it to perform all the following with a single read access to the MFCW<n>\_PAY register:

- Read the value held in the MFCW<n>\_PAY register.
- Acknowledge the Transfer.
- Clear the Channel Transfer interrupt, if it was asserted, for the FCH.
- S<sub>GGJXT</sub> Unlike other channel types, FCHs do not generate a Channel Transfer Acknowledge event back to the Sender, but the Transfer must be acknowledged by the Receiver to enable future Fast Channel Transfer interrupts to be generated by the channel. For more information on the Fast Channel Transfer interrupt refer to Chapter B11 Interrupts

Chapter B7. Fast Channel Extension B7.6. Events

### **B7.6 Events**

- $I_{LTTPJ}$  An FCH only has a Channel Transfer event.
- $R_{RXQHS}$  The Channel Transfer event is generated for a FCH when a write of any size to the PFCW<n>\_PAY register occurs, independent of the value written.

## Chapter B8 FIFO Extension

| I <sub>gdgvg</sub> | The FIFO Extension (FE) defines a Channel type called a FIFO Channel (FFCH).                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>GXDRW</sub> | A FFCH allows a Sender to send:                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | <ul> <li>Multiple Transfer to the Receiver without having to wait for a previous Transfer to be acknowledged by the Receiver, as long as the FIFO has room for the Transfer.</li> <li>Transfers which require the Receiver to provide acknowledgement.</li> <li>Transfers which have in-band payload.</li> </ul>                                                                                                                           |
|                    | In all cases, the data is guaranteed to be observed by the Receiver in the same order which the Sender sent it, reducing the overhead in sending multiple or long Transfers.                                                                                                                                                                                                                                                               |
| I <sub>rfcbb</sub> | FFCH allow larger payloads to be sent, however the intent is for the Transfers to have sizes which are 10s of bytes long. An example usage for a FFCH is to send a command packet which contains a command header of a few bytes, followed by an address pointer to an out-band payload which the command relates to. The sending of very long Transfers can have a performance impact on the Sender or Receiver over using shared memory. |
| R <sub>QDFMY</sub> | When FE is implemented, the number of FFCH an implementation of the MHU can support is IMPLEMENTATION DEFINED between 1 and 64.                                                                                                                                                                                                                                                                                                            |
| $R_{ZPHHM}$        | When FE is not implemented, the number of FFCH is 0 and all registers related to FE are Reserved.                                                                                                                                                                                                                                                                                                                                          |
| R <sub>fptgy</sub> | FFCH are numbered starting from the 0 in ascending order.                                                                                                                                                                                                                                                                                                                                                                                  |
| R <sub>JPVGT</sub> | A FFCH has the following resources:                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | <ul> <li>A FIFO.</li> <li>A Flag History Buffer.</li> <li>A FIFO Channel Window (FFCW).</li> <li>Channel Transfer event.</li> </ul>                                                                                                                                                                                                                                                                                                        |

- Channel Transfer Acknowledge event and acknowledge counter.
- Channel Tidemark events.
- FIFO Pop Ack event.
- FIFO Flush events.

 $R_{PPLXC}$  The depth of the FIFO must satisfy both of the following conditions:

- Be between 1 and 1024 bytes.
- A multiple of the largest push operation which the MHU implementation supports.

For example, if the largest push operation allowed is four bytes the depth of the FIFO must be a multiple of four.

R<sub>HMFXJ</sub> All FIFOs in an implementation of the MHU are the same depth.

#### R<sub>HRYRD</sub> Bytes within the FIFO are either invalid or valid.

R<sub>VQQLV</sub> Bytes are invalid until the Sender pushes data onto the FIFO, which is stored in the bytes, making these bytes valid. The bytes remain valid until the Receiver pops the data, stored in the bytes, from the FIFO. When data is popped from the FIFO the bytes which store the popped data become invalid.

### **B8.1 Data Flags**

| I <sub>YFSZR</sub> | Each byte stored in the FIFO has three different flags stored alongside the value of the byte. Theses flags are referred to as Data flags and are called:                                                                                                                                                                                                                                                                |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>Start of Transfer (SOT) - Indicates the start of a new Transfer in a stream of bytes.</li> <li>End of Transfer (EOT) - Indicates the last byte of a Transfer in a stream of bytes.</li> <li>Acknowledge (ACK) - Request by the Sender for an indication when the byte has been popped from the FIFO. This is considered to be when the Receiver acknowledges the Transfer.</li> </ul>                           |
| R <sub>ffprg</sub> | The SOT and EOT flags can either be:                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ul><li>Managed by the Sender.</li><li>Managed jointly by the Sender and MHU.</li><li>Managed by the MHU.</li></ul>                                                                                                                                                                                                                                                                                                      |
| I <sub>DTBCJ</sub> | The different ways of managing the SOT and EOT flags is referred to as the Transfer Delineation mode. For more information refer to B8.1.1 <i>Transfer Delineation Mode</i> .                                                                                                                                                                                                                                            |
| R <sub>HWMNV</sub> | The ACK flag is always managed by the Sender.                                                                                                                                                                                                                                                                                                                                                                            |
| R <sub>wkkyx</sub> | The value of the data flags, which are to be used for the next byte(s) pushed onto the FIFO, can be read and set via the PFFCW <n>_FLG register.</n>                                                                                                                                                                                                                                                                     |
| $R_{\rm LJYWB}$    | The SOT and EOT data flags can be read by the Receiver, for the last bytes read from the FIFO, using the MFFCW <n>_FLG register.</n>                                                                                                                                                                                                                                                                                     |
| $I_{\rm GNHJG}$    | The ACK flag is not exposed to the Receiver and is instead used by the MHUR to generate the Channel Transfer event. For more information refer to B8.5 <i>Events</i> .                                                                                                                                                                                                                                                   |
| S <sub>QQNKK</sub> | It is the responsibility of software to:                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ul> <li>Select the Transfer Delineation mode to be used before sending a Transfer.</li> <li>Set the ACK flag as required when pushing the last byte of the Transfer onto the FIFO.</li> <li>If using the software or partial flag Transfer Delineation mode, to set the SOT and EOT flags for each byte as required, before pushing the byte onto the FIFO, based on the bytes position within the Transfer.</li> </ul> |
|                    | Failure to set the SOT and EOT flags correctly can lead to data corruption or loss when the Receiver reads data from the FIFO.                                                                                                                                                                                                                                                                                           |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                          |

Failure to set the EOT fields will lead to no Channel Transfer event being generated when the last byte is pushed onto the FIFO, which can lead to the Receiver not being informed about a pending Transfer when using the FIFO Transport protocol.

#### **B8.1.1 Transfer Delineation Mode**

 $I_{XVVQK}$  The SOT and EOT flags are used to mark the boundaries of a Transfer in a stream of bytes.

- I<sub>SRCLS</sub> The MHU supports three modes of using the SOT and EOT flags called Transfer Delineation modes. Each mode of Transfer Delineation has a different intended usage listed below:
  - Software flag
  - Partial flag
  - Auto flag

R<sub>NJNYP</sub> The PFFCW<n>\_CTRL.TDM field controls which Transfer Delineation mode is used.

- L<sub>VBFVJ</sub> Depending on the transport protocol being used to send the Transfer, refer to D2.2 *FIFO* or D2.3 *Streaming FIFO* for information on:
  - Which Transfer Delineation mode to use.

• How to use each Transfer Delineation mode.

#### B8.1.1.1 Software flag

- $R_{PMHZG}$  When software flag Transfer Delineation mode is used the flags are managed by the Sender and the values of the PFFCW<n>\_FLG.{SOT/EOT} fields will not be updated by the MHU.
- R<sub>HJSVC</sub> Software flag Transfer Delineation mode is selected by setting PFFCW<n>\_CTRL.TDM to 0b00.

#### B8.1.1.2 Partial Flag

 $\mathbb{R}_{SZXNH}$  When partial flag Transfer Delineation mode is used the flags are managed jointly by the Sender and the MHU, with the values of the PFFCW<n>\_FLG.{SOT,EOT} fields being updated by both.

#### R<sub>YMBCQ</sub> Partial flag Transfer Delineation mode is selected by setting the PFFCW<n>\_CTRL.TDM is set to 0b01.

- R<sub>PKXTW</sub> When partial flag Transfer Delineation mode is selected the SOT and EOT flags behave as follows:
  - When a write occurs to PFFCW<n>\_CTRL.TDM which sets it to 0b01, the PFFCW<n>\_FLG.{SOT,EOT} fields are set to 0b1 and 0b0 respectively.
  - The PFFCW<n>\_FLG.{SOT/EOT} fields can only be written by the Sender if at least one of the fields will be set to 0b1, otherwise the write will not update the SOT and EOT fields but will update other fields in the register.
  - When one or more bytes are pushed onto the FIFO the values of the SOT and EOT fields change as shown in Table B8.1.

# Table B8.1: SOT and EOT flag values after a push of one or more bytes to the FIFO when using partial Transfer Delineation mode

| Value of data flags of before push |     | Value o | f data flags for after push |
|------------------------------------|-----|---------|-----------------------------|
| SOT                                | EOT | SOT     | EOT                         |
| 0                                  | 0   | 0       | 0                           |
| 0                                  | 1   | 1       | 0                           |
| 1                                  | 0   | 0       | 0                           |
| 1                                  | 1   | 1       | 0                           |

- I<sub>VZDVP</sub> The PFFCW<n>\_FLG.ACK field behavior is not affected by using the partial flag Transfer Delineation mode. The value of ACK field is always the value last written by the Sender or its reset value.
- $S_{NQJSJ}$  When the Sender wants to update the value of the PFFCW<n>\_FLG.ACK field the Sender must set the SOT and EOT fields to 0b0. This will cause only the ACK field to be updated.

Failure to do this can lead to data loss or corruption when the Receiver reads the data from the FIFO as the SOT or EOT fields may not follow a valid sequence.

#### B8.1.1.3 Auto Flag

- $\mathbb{R}_{WWQWV}$  When auto flag Transfer Delineation mode is used the flags are managed by the MHU, with the values of the PFFCW<n>\_FLG.{SOT,EOT} fields are updated only by the MHU.
- R<sub>ZLYXR</sub> Auto flag Transfer Delineation mode is selected by setting the PFFCW<n>\_CTRL.TDM is set to 0b10.

# Chapter B8. FIFO Extension B8.1. Data Flags

| RZDIEI  | When auto flag Transfer | Delineation mode is selected the | ne SOT and EOT flags behave as follo | ows: |
|---------|-------------------------|----------------------------------|--------------------------------------|------|
| - SPUPU | in men wave mag mansrer |                                  | te s'e i una 201 nags senare as ion  | 0    |

- When a writes occurs to the PFFCW<n>\_CTRL.TDM field which sets it to 0b10:
  - The PFFCW<n>\_FLG.{SOT,EOT} fields become read-only.
  - The PFFCW<n>\_FLG.{SOT,EOT} fields are set to 0b1 and 0b0 respectively.
- When one or more bytes are pushed onto the FIFO the value of the SOT and EOT fields toggle.
- I\_VWRKSThe PFFCW<n>\_FLG.ACK field behavior is not affected by using the auto flag Transfer Delineation mode. The<br/>value of ACK field is always the value last written by the Sender or its reset value.

#### B8.1.2 Data Flag Storage

- R<sub>DBBMR</sub> It is IMPLEMENTATION DEFINED how the data flags are stored alongside the Transfer data but the rules in this section must be followed.
- $R_{GQXLH}$  The relationship between data flags and the bytes they are associated with is determined at the point when the write to the PFFCW<n>\_PAY register occurs. It must never be possible for the association between data flags and byte to be altered.
- R<sub>ZYGSL</sub> Data flags and the associated Transfer data byte must be read, written and popped from the FIFO atomically.

### B8.2 FIFO Behavior

R<sub>MYCDY</sub> It is IMPLEMENTATION DEFINED how the FIFO is implemented.

#### B8.2.1 Reset

- I<sub>RPVZT</sub> It is IMPLEMENTATION DEFINED whether the FIFO is part of the MHUS or MHUR or split between the two. This includes any logic which is used to control the locations within the FIFO where new data is pushed to or data is read or popped from, for example read and write pointers.
- R<sub>VVTNW</sub> When either the MHUS or MHUR is in a Non-operational state, all bytes in the FIFO become invalid and contain an UNKNOWN value.

#### Note

 $R_{VVTNW}$  only applies for controlled entry into the Non-operational state. For an uncontrolled entry of the MHUS or MHUR into a Non-operational state  $R_{FHLRF}$  takes precedence.

- R<sub>TGLBZ</sub> When the MHUS is in a Non-operational state, no bytes can be pushed onto the FIFO.
- S<sub>QXJGK</sub> The Sender must be capable of handling the loss of Transfers due to the MHUR entering a Non-operational state in a controlled manner. For example, the Receiver sets the MBX\_CTRL.CH\_OP\_MSK field to 0b1, when there are outstanding Transfers in the FIFO. Arm recommends that the Receiver indicates to the Sender when it wants to enter a Non-operational state before it sets the MBX\_CTRL.CH\_OP\_MSK field to 0b1 and starts to enter the MHUR into a Non-operational state.
- S<sub>FTWHV</sub> The Receiver must be capable of handling spurious interrupts where the contents of the FIFO are lost due to the Sender entering a Non-operational state whilst the FIFO contains one or more valid bytes. The Receiver can use the MFFCW<n>\_FLG.VFLG<m> fields to know whether a previous read from the FIFO returned any bytes with valid data.
- R<sub>VLXGB</sub> Attempts to push bytes onto the FIFO when the MHUR is in a Non-operational state always generate a request to enter the MHUR into the Operational state. It is allowed for data to be pushed onto the FIFO, if it is possible whilst the MHUR is in a Non-operational state.

R<sub>VPVBG</sub> When the MHUR is in a Non-operational state no bytes can be read or popped from the FIFO.

#### B8.2.2 Pushing data onto the FIFO

 R<sub>ZTYGZ</sub>
 Bytes are pushed onto the FIFO when the Sender writes to the PFFCW<n>\_PAY register.

 R<sub>LVCVN</sub>
 When one or more bytes are pushed onto the FIFO, the value of the flags in the PFFCW<n>\_FLG register, at the time of the write to the PFFCW<n>\_PAY register, is recorded along with the bytes and stored in the FIFO.

 R<sub>DNVMP</sub>
 The SOT flag is always associated with the first byte pushed onto the FIFO.

 R<sub>KNQYQ</sub>
 The EOT and ACK flags are always associated with the last byte pushed onto the FIFO.

 R<sub>LBCSG</sub>
 The number of bytes pushed onto FIFO is equal to the size of the write access to the PFFCW<n>\_PAY register.

 R<sub>ZHYJT</sub>
 On a write to the PFFCW<n>\_PAY register, the following occurs:

- If the number of bytes to be pushed onto the FIFO is less than or equal to the space in the FIFO:
  - All bytes are pushed onto the FIFO.
  - PFFCW<n>\_ST.PPE field is set to 0b0.

- Update to the PFFCW<n>\_FLG.{SOT,EOT} fields based on the Transfer Delineation Mode selected by the PFFCW<n>\_CTRL.TDM field.
- If the number of bytes to be pushed onto the FIFO is greater than the space in the FIFO:
  - No bytes are pushed onto the FIFO.
  - PFFCW<n>\_ST.PPE field is set to 0b1.
  - No update to the PFFCW<n>\_FLG.{SOT,EOT} fields are made.
- $S_{NBZZY}$  Arm recommends that software either:
  - Never attempts to push more bytes onto the FIFO than the value of the PFFCW<n>\_ST.FFS field indicates are free.
  - Checks the PFFCW<n>\_ST.PPE field after each write to the PFFCW<n>\_PAY register and if it is set to 0b1 repeat the write.

Otherwise writes to the FIFO without sufficient space could result in data loss.

- $R_{YQLGF}$  The order in which bytes are pushed onto the FIFO depends on the setting of the PFFCW<n>\_CTRL.MSBF field when the write occurs.
- I\_LWCLD
   For more information on how the PFFCW<n>\_CTRL.MSBF field affect the order in which bytes are pushed onto the FIFO refer to B8.2.6 Ordering of bytes when push, read or popping multiple bytes.

#### B8.2.3 Reading data from the FIFO

- R<sub>GCZCC</sub> The Receiver reads the contents of the FIFO using the MFFCW<n>\_PAY register.
- R<sub>RHCQK</sub> When one or more bytes are read from the FIFO by the Receiver reading the MFFCW<n>\_PAY register, the flags associated with those bytes read are stored in the Flag History Buffer (FHB).
- $I_{CSZMC}$  The entries of the FHB are used in subsequent reads of the MFFCW<n>\_FLG register.
- R<sub>XVYRH</sub> A byte and the associated flags must be read from the FIFO atomically.

#### Note

It is possible that whilst reading data from the FIFO any of the following occurs:

- FIFO Flush.
- MHUS or MHUR enter a Non-operational state.

All of the above conditions cause all bytes in the FIFO to become invalid. Depending on the implementation of the FIFO, it may be possible that one or more of the bytes and associated flags being atomically read from the FIFO are still to be read. These bytes are now invalid and are treated as such in the returned read data and in the associated entries in the FHB. R<sub>QXSCS</sub> describes the behavior for reading bytes which are invalid from the FIFO.

- I<sub>VTDGV</sub> When reading multiple bytes from the FIFO it is possible that the bytes belong to one or more Transfers. This can make processing Transfers more complicated as the bytes from a later Transfer need to be buffered, when Read-Acknowledge is enabled, as the act of reading the bytes causes them to be popped from the FIFO. To reduce the software complexity, FFCHs support automatically buffering future Transfer data, referred to a Future Transfer Auto Buffering.
- R<sub>DBKWN</sub> Future Transfer Auto Buffering is enabled using the MFFCW<n>\_CTRL.FTAB field.
- R<sub>MLQJF</sub> Future Transfer Auto Buffering is only enabled for the FIFO, when Read-Acknowledge is also enabled for the FFCH.
- R<sub>CFJRX</sub> When MFFCW<n>\_CTRL.FTAB is set to 0b0 or MFFCW<n>\_CTRL.RA\_EN is set to 0b0, no buffering of Transfers occurs.

- R<sub>SSPSL</sub> When MFFCW<n>\_CTRL.FTAB is set to 0b1 and MFFCW<n>\_CTRL.RA\_EN is 0b1, buffering of future of Transfers occurs.
- R<sub>XPVVK</sub> The number of bytes read from the FIFO when the Receiver performs a read access to the MFFCW<n>\_PAY register depends on:
  - The value of the MFFCW<n>\_CTRL.RA\_EN field.
  - The value of the MFFCW<n>\_CTRL.FTAB field.
  - The size of the read access.
  - Number of valid bytes in the FIFO.

Table B8.2 shows the number of bytes read from the FIFO when the Receiver performs a read access to the MFFCW<n>\_PAY register.

## Table B8.2: Number of bytes read when the Receiver performs a read access to the MFFCW<n>\_PAY register

| RA_EN | FTAB | Read Access Size (Bytes) | Bytes Read     |
|-------|------|--------------------------|----------------|
| 0     | Х    | 1                        | min(1,FFL)     |
|       |      | 2                        | min(2,FFL)     |
|       |      | 4                        | min(4,FFL)     |
|       |      | 8                        | min(8,FFL)     |
| 1     | 0    | 1                        | min(1,FFL)     |
|       |      | 2                        | min(2,FFL)     |
|       |      | 4                        | min(4,FFL)     |
|       |      | 8                        | min(8,FFL)     |
| 1     | 1    | 1                        | min(1,FFL,FBE) |
|       |      | 2                        | min(2,FFL,FBE) |
|       |      | 4                        | min(4,FFL,FBE) |
|       |      | 8                        | min(8,FFL,FBE) |

I<sub>JQDFS</sub>

#### In Table B8.2:

- min() is a function which takes two or more arguments and returns the argument with the smallest value.
- FFL is the current number of valid bytes in the FIFO.
- FBE is the byte number of the first byte in the FIFO which is associated with an EOT flag, starting from 1 for the first byte read.

# $\mathbb{I}_{\text{FPYXF}} \qquad \text{A byte is said to be valid in the FIFO if it has been pushed onto the FIFO by the Sender and not yet popped from the FIFO by the Receiver. Refer to <math>\mathbb{R}_{\text{VOQLV}}$ for more information on when bytes are valid or invalid.

R<sub>QXSCS</sub> If a read of the MFFCW<n>\_PAY register results in less bytes being read from the FIFO than requested by the read, the following occurs:

- Byte offsets of the read data, which does not contain data for a byte read from the FIFO, are set to an UNKNOWN value.
- Entries in the FHB, for a byte which has its value set to an UNKNOWN value, are set to be invalid.

For more information on FHB entries refer to B8.2.4 Flag History Buffer.

| I <sub>JFBHD</sub> | This can be due to either: |
|--------------------|----------------------------|
|                    |                            |

- The FIFO contain less valid bytes than the requested number of bytes.
- The number of bytes remaining in the Transfer were less than the size of the read, as indicated by the last byte of the Transfer having the EOT flag set to 0b1, and the MFFCW<n>\_CTRL.RA\_EN and MFFCW<n>\_CTRL.FTAB fields were both set to 0b1.
- I\_JGWBQThe byte offsets within the read data returned from the MFFCW<n>\_PAY register depend on the setting of the<br/>MFFCW<n>\_CTRL.MSBF field. For more information refer<br/>B8.4.1 Accesses to Payload and Flag registers.

#### B8.2.4 Flag History Buffer

- $I_{GQBNG}$  The Flag History Buffer (FHB), holds the values of flags for the bytes read from the FIFO by the last read operation of the MFFCW<n>\_PAY register.
- $R_{RFGHK}$  At reset all entries in the FHB are invalid.
- $R_{SDCQK}$  The FHB is considered part of the MHUR reset domain.
- R<sub>HDDTJ</sub> The FHB buffers up to N entries, where N is the maximum size of a read access supported to the MFFCW<n>\_PAY register.
- $R_{JNFBJ}$  FHB entries are numbered 0 to N-1.
- $I_{WQCPC}$  In this architecture FHB entries are referred to as FHB[x] where x is the FHB entry number in the range 0 to N-1, for example FHB[0] refers to the first FHB entry.
- R<sub>MXWTV</sub> Each entry contains the following:
  - Valid byte indicator.
  - SOT field.
  - EOT field.
- R<sub>TJFTS</sub> When an entry is valid the SOT and EOT must contain the value of the Data Flag for the byte it is associated with.
- R<sub>YWMSM</sub> When an entry is invalid it is UNKNOWN what value the SOT and EOT fields take in the entry.
- R<sub>YTJQG</sub> The FHB contents are updated each time a read of the MFFCW<n>\_PAY register occurs, replacing any previous data that was in the buffer.
- R<sub>DFLXG</sub> The entries within the FHB are populated in the order in which the bytes are read from the FIFO, with the first byte read being stored in FHB[0].
- R<sub>FNNMX</sub> When a read access to the MFFCW<n>\_PAY register returns less bytes than there are entries in the FHB any remaining entries in the FHB are set to be invalid.

#### $I_{KVPRM}$ This can occur due to one of the following reasons:

- Size of the last read access to the MFFCW<n>\_PAY register being smaller than maximum supported size read.
- The FIFO contained less valid bytes than the requested by the last read of the MFFCW<n>\_PAY register.
- The number of bytes remaining in the Transfer were less than the size of the read of the MFFCW<n>\_PAY register, as indicated by the last byte of the Transfer having the EOT flag set to 0b1, and the MFFCW<n>\_CTRL.RA\_EN and MFFCW<n>\_CTRL.FTAB fields both being set to 0b1.

#### **B8.2.5** Popping bytes from the FIFO

- R<sub>SYTTK</sub> Bytes are popped from the FIFO when the FIFO contains at least one byte and the Receiver performs one of the following actions:
  - Reads from the MFFCW<n>\_PAY register and MFFCW<n>\_CTRL.RA\_EN is set to 0b1.

 $R_{KQYYB}$ 

• Writes to the MFFCW<n>\_FIFO\_POP.POP field and MFFCW<n>\_CTRL.RA\_EN is set to 0b0.

R<sub>VLSBF</sub> The number of bytes popped from the FIFO when the Receiver performs an action which would cause bytes to be popped from the FIFO is the smallest value of the following:

- The number of bytes requested by the Receiver.
- The number of bytes in the FIFO.
- Whether a previous byte popped from the same request had the EOT field set, when the MFFCW<n>\_CTRL.RA\_EN and MFFCW<n>\_CTRL.FTAB fields are both set to 0b1.

Table B8.3 shows the number of bytes popped from the FIFO when the Receiver performs a read of the MFFCW<n>\_PAY register, based on:

- Value of MFFCW<n>\_CTRL.RA\_EN field.
- Value of MFFCW<n>\_CTRL.FTAB field.
- Size of the read access to the MFFCW<n>\_PAY register.

# Table B8.3: Number of bytes popped from the FIFO when the Receiver performs a read of the MFFCW<n>\_PAY register

| RA_EN | FTAB | Access Size<br>(Bytes) | Bytes Popped from FIFO |
|-------|------|------------------------|------------------------|
| 0     | Х    | Х                      | 0                      |
| 1     | 0    | 1                      | min(1,FFL)             |
|       |      | 2                      | min(2,FFL)             |
|       |      | 4                      | min(4,FFL)             |
|       |      | 8                      | min(8,FFL)             |
| 1     | 1    | 1                      | min(1,FFL,FBE)         |
|       |      | 2                      | min(2,FFL,FBE)         |
|       |      | 4                      | min(4,FFL,FBE)         |
|       |      | 8                      | min(8,FFL,FBE)         |

I<sub>cdkdq</sub>

#### In Table B8.3:

- min() is a function which takes two or more arguments and returns the argument with the smallest value.
- FFL is the current number of valid bytes in the FIFO.

• FBE is the byte offset, with respect to the head of the FIFO, of the first byte which is associated with an EOT flag.

R<sub>PHJLP</sub> Table B8.4 shows the number of bytes popped from the FIFO when the Receiver performs a write to the MFFCW<n>\_FIFO\_POP.POP field, based on:

- Value of MFFCW<n>\_CTRL.RA\_EN field.
- Value of MBX\_FFCH\_CFG0.M64BA\_SPT field.
- Value written to the MFFCW<n>\_FIFO\_POP.POP field

# Table B8.4: Number of bytes popped from the FIFO when the Receiver performs a write of the MFFCW<n>\_FIFO\_POP.POP field

| RA_EN | Pop Field | M64BA_SPT | T M32BA_SPT | M16BA_SPT | M8BA_SPT | Bytes Popped from FIFO                                                                                                                                            |
|-------|-----------|-----------|-------------|-----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | X         | X         | X           | Х         | X        | 0                                                                                                                                                                 |
| 0     | 0         | Х         | Х           | Х         | 0        | <ul> <li>IMPLEMENTATION DEFINED whether:</li> <li>No bytes are popped from the FIFO.</li> <li>Treated as if the Pop value was another supported value.</li> </ul> |
|       |           | X         | X           | Х         | 1        | min(1,FFL)                                                                                                                                                        |
|       | 1         | Х         | Х           | 0         | Х        | <ul><li>IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>Treated as if the Pop value was another supported value.</li></ul>     |
|       |           | X         | X           | 1         | Х        | min(2,FFL)                                                                                                                                                        |
|       | 2         | Х         | Х           | Х         | Х        | <ul> <li>IMPLEMENTATION DEFINED whether:</li> <li>No bytes are popped from the FIFO.</li> <li>Treated as if the Pop value was another supported value.</li> </ul> |
|       | 3         | 1         | 0           | Х         | Х        | <ul> <li>IMPLEMENTATION DEFINED whether:</li> <li>No bytes are popped from the FIFO.</li> <li>Treated as if the Pop value was another supported value.</li> </ul> |
|       |           | Х         | 1           | Х         | Х        | min(4,FFL)                                                                                                                                                        |
|       | 4-6       | Х         | Х           | Х         | Х        | <ul> <li>IMPLEMENTATION DEFINED whether:</li> <li>No bytes are popped from the FIFO.</li> <li>Treated as if the Pop value was another supported value.</li> </ul> |

| RA_EN | Pop Field | M64BA_SPT | Г МЗ2ВА_ЅРТ | M16BA_SPT | M8BA_SPT | Bytes Popped from FIFO                                                                                                                                        |
|-------|-----------|-----------|-------------|-----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 7         | 0         | 1           | Х         | Х        | <ul><li>IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>Treated as if the Pop value was another supported value.</li></ul> |
|       |           | 1         | Х           | Х         | Х        | min(8,FFL)                                                                                                                                                    |

| I, <sub>ILKPS</sub> | In | Table | <b>B8.4</b> : |
|---------------------|----|-------|---------------|

- min() is a function which takes two or more arguments and returns the argument with the smallest value.
- FFL is the current number of valid bytes in the FIFO.
- FBE is the byte offset, with respect to the head of the FIFO, of the first byte which is associated with an EOT flag.
- $I_{CZQVY}$  Some combinations of settings in Table B8.4 are not show or are illegal as the architecture requires that either M32BA\_SPT or M64BA\_SPT or both are set to 0b1.

S<sub>HVVKD</sub> Software must only write values to the MFFCW<n>\_FIFO\_POP.POP field which are supported as indicated by the MBX\_FFCH\_CFG0.{M8BA\_SPT/M16BA\_SPT/M32BA\_SPT/M64BA\_SPT} fields, otherwise it can lead to corruption or lost of Transfer data.

#### B8.2.6 Ordering of bytes when push, read or popping multiple bytes

| I <sub>fkytl</sub> | It is possible for the Sender to push multiple bytes onto the FIFO and the Receiver to read or pop multiple bytes  |
|--------------------|--------------------------------------------------------------------------------------------------------------------|
|                    | from the FIFO using a single access. The data is stored to and read or popped from the FIFO one byte at a time.    |
| RODAVE             | The order in which multiple bytes are stored in the EIFO is determined by the value of the PEECW <n> CTRL MSRF</n> |

- R<sub>GFMXZ</sub> The order in which multiple bytes are stored in the FIFO is determined by the value of the PFFCW<n>\_CTRL.MSBF field, at the time the push occurs.
- $R_{QWNCR}$  The order in which the bytes are read or popped from the FIFO is determined by the value of the MFFCW<n>\_CTRL.MSBF field at the time the read or pop occurs.
- R<sub>HNHCT</sub> Depending on the value of the PFFCW<n>\_CTRL.MSBF field bytes are pushed onto the FIFO:
  - 0b0 Least-Significant Byte (LSB) first.
  - Ob1 Most-Significant Byte (MSB) first.

#### R<sub>QPRYY</sub> Depending on the value of the MFFCW<n>\_CTRL.MSBF field the first byte read from the FIFO:

- 0b0 is considered the LSB.
- 0b1 is considered the MSB.
- I\_LXMKH
   The value of MFFCW<n>\_CTRL.MSBF has no effect on the order in which flags are stored in the FHB. For more information on the order in which flags are stored in the FHB refer to B8.2.4 *Flag History Buffer*.
- R<sub>WDWXS</sub> FFCHs are considered little endian where the LSB is in the lowest offset within the access and the MSB is in the highest offset within the access.
- S<sub>SQRDD</sub> The Sender and Receiver must set the {PFFCW/MFFCW}<n>\_CTRL.MSBF fields to the same value for the same FFCH otherwise the order of the bytes in the Transfer will be observed differently by the Receiver to the order the Sender sent them in.

R<sub>GVJHV</sub> For POP field values in Table B8.4 which are marked as IMPLEMENTATION DEFINED and the implementation selects to treat the POP field value as another supported value it is allowed to pop more or less bytes.

### B8.3 FIFO Flush

- IPQCGKEach FFCH has a mechanism to return it to a known state, know as FIFO flush. The FIFO flush can be triggered<br/>by either the Sender or Receiver.
- S<sub>DJZQX</sub> The FIFO flush is not intended to be used during normal operation but as a method to restore the FIFO back to a known state when unexpected events occur. For example, either the MHUS or MHUR enter a Non-operational state in an uncontrolled manner.
- R<sub>WJXWB</sub> Each FFCH has two independent FIFO flush mechanisms, one in the MHUS and one in the MHUR, which operate independently of one another. It is valid for both mechanism to be trigger at the same time.
- R<sub>LWVXX</sub> Each FFCH's flush mechanisms are independent of one another, meaning multiple FFCHs can be flushed at once.
- $\mathbb{R}_{ZQDZN}$  The FIFO flush mechanism in the MHUS is controlled is PFFCW<n>\_CTRL.FF field and the status is shown in the PFFCW<n>\_ST.FF field.
- $R_{QHMJV}$  The FIFO flush mechanism in the MHUR is controlled is MFFCW<n>\_CTRL.FF field and the status is shown in the MFFCW<n>\_ST.FF field.
- $I_{NZFTD}$  For the remainder of sections:
  - <x>FFCW<n>\_CTRL.FF is used when the statement could apply to either the PFFCW<n>\_CTRL.FF or MFFCW<n>\_CTRL.FF fields.
  - <x>FFCW<n>\_ST.FF is used when the statement could apply to either the PFFCW<n>\_ST.FF or MFFCW<n>\_ST.FF fields.

However, the remainder of this section should be read from the prospective of single flush mechanism. For example, if a flush is in progress by the flush mechanism of the MHUS, PFFCW<n>\_CTRL.FF is set to 0b1, and a write of 0b0 to the MFFCW<n>\_CTRL.FF occurs this has no effect on the flush in progress by the flush mechanism of the MHUS. The same applies the other way round.

- R<sub>GPKVB</sub> When a flush is triggered, by software writing 0b1 to <x>FFCW<n>\_CTRL.FF field, the following steps takes places:
  - All bytes within the FIFO becomes invalid.
  - The location to read or pop the next byte is set to same location as the location to push the next byte to.
  - Any IMPLEMENTATION DEFINED state which software is unable to return to the state it was in immediately after reset, is returned back to its reset state.

The order in which the above steps take place is IMPLEMENTATION DEFINED.

Once all the steps for the flush have taken place the <x>FFCW<n>\_ST.FF field is set to 0b1.

- ILVEXC
   Other state of the FFCH is also affected by the side effects of the flush. The PFFCW<n>\_ST.FFS and MFFCW<n>\_ST.FFL fields report the number of invalid and valid bytes in the FIFO respectively, their values will change to reflect all bytes being made invalid.
- R<sub>NNNCQ</sub> Even though the FIFO flush mechanism makes all bytes in the FIFO become invalid it does not generate a Sender or Receiver FIFO Low Tide event.
- S<sub>FYLPK</sub> If software is using the Sender or Receiver FIFO Low Tide events to know when the FIFO has less than a certain value of valid bytes, the Sender or Receiver FIFO Flush events should be used to know when a flush of the FIFO has occurred and the the number of valid bytes is less than low tide value.
- RDSYPSWhen software sets the <x>FFCW<n>\_CTRL.FF field to 0b0 and the <x>FFCW<n>\_ST.FF field is set to 0b1,<br/>the <x>FFCW<n>\_ST.FF field is set to 0b0 at the same time.
- R<sub>TCCLM</sub> If software sets the <x>FFCW<n>\_CTRL.FF field to 0b0 when that FIFO flush mechanism is performing a flush and the <x>FFCW<n>\_ST.FF field is set to 0b0 it is IMPLEMENTATION DEFINED whether:
  - The FIFO flush mechanism completes the current FIFO flush or aborts. If the FIFO flush completes the <x>FFCW<n>\_ST.FF field is set to 0b0 when it completes.

# Chapter B8. FIFO Extension B8.3. FIFO Flush

|                    | Generates the Sender or Receiver FIFO flush event.                                                                                                                                                                                                                                                        |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>CRDXR</sub> | If, due to the <x>FFCW<n>_CTRL.FF field being set to 0b0, an in-progress FIFO flush mechanism is aborted it must leave the FIFO in a state whereby it is possible to send new Transfers between the Sender and Receiver.</n></x>                                                                          |
| R <sub>YQVWP</sub> | It is CONSTRAINED UNPREDICTABLE whether a new FIFO flush is generated if the <x>FFCW<n>_CTRL.FF field is set to 0b1 when <x>FFCW<n>_ST.FF is not 0b0.</n></x></n></x>                                                                                                                                     |
| R <sub>MGMGV</sub> | The time taken for all the steps of the FIFO flush to take place is IMPLEMENTATION DEFINED, but it must be complete within a bounded period of time.                                                                                                                                                      |
| R <sub>VMKYT</sub> | It is CONSTRAINED UNPREDICTABLE whether a push operation which starts or is outstanding whilst a FIFO flush is in progress is treated as completing before or after the FIFO flush request.                                                                                                               |
| R <sub>RRGLX</sub> | It is CONSTRAINED UNPREDICTABLE whether a read or pop operation which starts or is outstanding whilst a FIFO flush is in progress is treated as completing before or after the FIFO flush request.                                                                                                        |
| S <sub>ZSSSP</sub> | It is software responsibility to sequence flushing of the FIFO with respect to any outstanding push, read or pop operation.                                                                                                                                                                               |
| R <sub>bxgxc</sub> | A FIFO flush request triggered in the MHUS does not cause the MHUR to enter an Operational state, if the MHUR is in a Non-operational state. If, to complete all steps required for a FIFO flush, the MHUR is required to enter the Operational state the following applies:                              |
|                    | <ul> <li>The steps are skipped or delayed until the MHUR returns to the Operational state for another reason.</li> <li>When the MHUR returns to the Operational state the steps are performed, if required.</li> <li>The location to read or pop the next byte is set to one of the following:</li> </ul> |
|                    | <ul><li>The location of the first valid byte in the FIFO, if one or more bytes have been pushed onto the FIFO after the flush completed.</li><li>The same as the location to push the next byte to, if no bytes have been pushed onto the FIFO after the flush completed.</li></ul>                       |
| R <sub>HKJMV</sub> | A FIFO flush request trigger in the MHUR does not cause the MHUS to enter an Operational state, if the MHUS is in a Non-operational state. If, to complete all steps required for a FIFO flush, the MHUS is required to enter the Operational state the following applies:                                |
|                    | <ul><li>The steps are skipped or delayed until the MHUS returns to the Operational state for another reason.</li><li>When the MHUS returns to the Operational state the steps are performed, if required.</li></ul>                                                                                       |
| I <sub>MYRWD</sub> | When referring to bytes being pushed onto the FIFO after the flush completed, this includes bytes pushed onto the FIFO due to push operations which started during or were outstanding when the FIFO flush event and were treated as if they occurred after the FIFO flush.                               |
| S <sub>XXPRP</sub> | The <x>FFCW<n>_CTRL.FF and <x>FFCW<n>_CTRL.FF fields form a four-phase handshake between the Sender or Receiver and the MHUS and MHUR respectively.</n></x></n></x>                                                                                                                                       |
|                    | Software must follow this sequence otherwise it is UNPREDICTABLE whether the flush completes all steps required.                                                                                                                                                                                          |
|                    | <ol> <li>Set <x>FFCW<n>_CTRL.FF to 0b1.</n></x></li> <li>Poll <x>FFCW<n>_ST;.FF until it reads as 0b1.</n></x></li> <li>Set <x>FFCW<n>_CTRL.FF to 0b0.</n></x></li> <li>Poll <x>FFCW<n>_ST.FF until it reads as 0b0.</n></x></li> </ol>                                                                   |
| S <sub>QTDMT</sub> | Arm recommends software never sets the <x>FFCW<n>_CTRL.FF field to 0b1 when <x>FFCW<n>_ST.FF is not 0b0.</n></x></n></x>                                                                                                                                                                                  |
| S <sub>WHZXJ</sub> | It is the responsibility of the Sender or Receiver or both to:                                                                                                                                                                                                                                            |
|                    | <ul><li>Clear any outstanding interrupts.</li><li>Return any previously programmed fields to their reset values, if required.</li></ul>                                                                                                                                                                   |

### **B8.4 FIFO Channel Window**

- R<sub>NHHSG</sub> The Sender and Receiver use the FIFO Channel Window (FFCW) to access the registers of the FFCH.
- R<sub>VVNNQ</sub> The FFCW occupies 16 consecutive words.

R<sub>CJBQX</sub> Table B8.5 shows the registers in the FFCW when accessed through the PBX:

| Offset | Name                  | Access |
|--------|-----------------------|--------|
| 0x00   | PFFCW <n>_PAY</n>     | RW     |
| 0x08   | PFFCW <n>_FLG</n>     | RW     |
| 0x0C   | Reserved              |        |
| 0x10   | PFFCW <n>_INT_ST</n>  | RO     |
| 0x14   | PFFCW <n>_INT_CLR</n> | WO/RAZ |
| 0x18   | PFFCW <n>_INT_EN</n>  | RW     |
| 0x1C   | Reserved              |        |
| 0x20   | PFFCW <n>_CTRL</n>    | RW     |
| 0x24   | PFFCW <n>_ST</n>      | RO     |
| 0x28   | PFFCW <n>_ACK_CNT</n> | RO     |
| 0x2C   | PFFCW <n>_TIDE</n>    | RW     |
| 0x30   | Reserved              |        |
| 0x34   | Reserved              |        |
| 0x38   | Reserved              |        |
| 0x3C   | Reserved              |        |

#### Table B8.5: FFCW when accessed from PBX

R<sub>VPTCQ</sub> Table B8.6 shows the registers in the FFCW when accessed through the MBX:

#### Table B8.6: FFCW when accessed from MBX

| Offset | Name                  | Access |
|--------|-----------------------|--------|
| 0x00   | MFFCW <n>_PAY</n>     | RO     |
| 0x08   | MFFCW <n>_FLG</n>     | RO     |
| 0x10   | MFFCW <n>_INT_ST</n>  | RO     |
| 0x14   | MFFCW <n>_INT_CLR</n> | WO/RAZ |
| 0x18   | MFFCW <n>_INT_EN</n>  | RW     |
| 0x1C   | Reserved              |        |
| 0x20   | MFFCW <n>_CTRL</n>    | RW     |
| 0x24   | MFFCW <n>_ST</n>      | RO     |
|        |                       |        |

| Offset | Name                   | Access |
|--------|------------------------|--------|
| 0x28   | MFFCW <n>_FIFO_POP</n> | WO     |
| 0x2C   | MFFCW <n>_TIDE</n>     | RW     |
| 0x30   | Reserved               |        |
| 0x34   | Reserved               |        |
| 0x38   | Reserved               |        |
| 0x3C   | Reserved               |        |

#### B8.4.1 Accesses to Payload and Flag registers

I<sub>BCNFY</sub> This section provides information on accesses to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers.

## I\_PKKSX The PFFCW<n>\_PAY and MFFCW<n>\_PAY registers are windows which allow the Sender and Receiver to interact with the contents of the FIFO as follows:

- A write to the PFFCW<n>\_PAY register pushes more data onto the FIFO.
- A read of the MFFCW<n>\_PAY register reads and optionally pops data from the FIFO.
- A read of the MFFCW<n>\_FLG register provides the values of the flags stored in the FHB for the last read of the MFFCW<n>\_PAY register.

#### R<sub>ZGDML</sub> The PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers are 64-bits.

I<sub>HYCNN</sub>

- The size of the access to the: PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers effect:
  - PFFCW<n>\_PAY register determines the amount of data pushed onto the FIFO.
  - MFFCW<n>\_PAY register determines the amount of data read or popped from the FIFO.
  - MFFCW<n>\_PAY register determines the number of flags which are return.

An implementation of the MHU can support 8-, 16-, 32- or 64-bit accesses to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers. For more information on the supported accesses sizes to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers refer to C1.1 *Register Access*.

#### Note

In this architecture the terms:

- PFFCW<n>\_PAY{8/16/32/64} are used to refer to 8-, 16-, 32-, 64-bit accesses to the PFFCW<n>\_PAY register respectively.
- MFFCW<n>\_PAY{8/16/32/64} are used to refer to 8-, 16-, 32-, 64-bit accesses to the MFFCW<n>\_PAY register respectively.
- MFFCW<n>\_FLG{8/16/32/64} are used to refer to 8-, 16-, 32-, 64-bit accesses to the MFFCW<n>\_FLG register respectively.

 $S_{BGGWD}$  Software can use the:

- PBX\_FFCH\_CFG0.{P8BA\_SPT/P16BA\_SPT/P32BA\_SPT/P64BA\_SPT} fields, to determine the supported access sizes to the PFFCW<n>\_PAY register.
- MBX\_FFCH\_CFG0.{M8BA\_SPT/M16BA\_SPT/M32BA\_SPT/M64BA\_SPT} fields, to determine the supported access sizes of the MFFCW<n>\_PAY and MFFCW<n>\_FLG registers.

## Chapter B8. FIFO Extension B8.4. FIFO Channel Window

| Wh                                     | en accessing the PFFCW <n>_PAY, MFFCW<n>_PAY and MFFCW<n>_FLG registers software must:</n></n></n>                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •                                      | <ul><li>Only access the registers with a supported access size.</li><li>Have the access aligned to a boundary equal to the size of the access.</li></ul>                                                                                                                                                                                                                                                                                 |
| Oth                                    | erwise it can lead to data lost or corruption.                                                                                                                                                                                                                                                                                                                                                                                           |
| Sof<br>add                             | tware must never generate an access to the PFFCW <n>_PAY/MFFCW<n>_PAY registers which has a st ress and size which would cause locations allocated outside the PFFCW<n>_PAY, MFFCW<n>_PAY</n></n></n></n>                                                                                                                                                                                                                                |
| MF                                     | Te well-The registers to be accessed, otherwise it is can read to rost of data.                                                                                                                                                                                                                                                                                                                                                          |
| МР.<br><b>В8</b>                       | .4.1.1 PFFCW <n>_PAY register</n>                                                                                                                                                                                                                                                                                                                                                                                                        |
| B8<br>This                             | .4.1.1 PFFCW <n>_PAY register s sections covers the behavior when the the Sender accesses the PFFCW<n>_PAY register.</n></n>                                                                                                                                                                                                                                                                                                             |
| B8<br>This<br>The<br>regi              | <b>.4.1.1 PFFCW</b> < <b>n&gt;_PAY register</b><br>s sections covers the behavior when the the Sender accesses the PFFCW< <b>n&gt;_PAY register</b> .<br>re is no requirement for the read or write accesses to always target any specific offset(s) in the PFFCW< <b>n&gt;_P</b> .<br>ister, for accesses with a smaller size than PFFCW< <b>n&gt;_PAY</b> .                                                                            |
| MF<br>B8<br>This<br>The<br>regi<br>Wri | <b>.4.1.1 PFFCW<n>_PAY register</n></b><br>s sections covers the behavior when the the Sender accesses the PFFCW <n>_PAY register.<br/>re is no requirement for the read or write accesses to always target any specific offset(s) in the PFFCW<n>_PA<br/>ister, for accesses with a smaller size than PFFCW<n>_PAY.<br/>tes to the PFFCW<n>_PAY register behave as defined in B8.2.2 <i>Pushing data onto the FIFO</i>.</n></n></n></n> |

#### Note

The value of the PFFCW<n>\_ST.FFS field returned when performing a read of the PFFCW<n>\_PAY register can be truncated to fit within the size of the read to the PFFCW<n>\_PAY register.

R<sub>MTGRD</sub> Table B8.7 shows the arrangement of the PFFCW<n>\_ST.{PPE,FFS} fields in the returned data for a read of the PFFCW<n>\_PAY register depending the size of the read access.

# Table B8.7: Returned read data for a read of PFFCW<n>\_PAY register depending on size of the read access

| Size of read of<br>PFFCW <n>_PAY<br/>register</n> | Returned re ad data bit offset | Field of<br>PFFCW <n>_ST register</n> | Note                                                                                           |
|---------------------------------------------------|--------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------|
| 8-bit                                             | 7                              | PPE                                   |                                                                                                |
|                                                   | 6:0                            | FFS                                   | If value of FFS field is greater than 127 the value<br>in the returned read data is set to 127 |
| 16-bit                                            | 15                             | PPE                                   |                                                                                                |
|                                                   | 10:0                           | FFS                                   |                                                                                                |
| 32-bit                                            | 31                             | PPE                                   |                                                                                                |
|                                                   | 10:0                           | FFS                                   |                                                                                                |
| 64-bit                                            | 63                             | PPE                                   |                                                                                                |
|                                                   | 10:0                           | FFS                                   |                                                                                                |

R<sub>QKPFW</sub> All bit offsets not listed in Table B8.7 are reserved and treated as RES0.

#### B8.4.1.2 MFFCW<n>\_PAY register

## Chapter B8. FIFO Extension B8.4. FIFO Channel Window

I QBWLRThe behavior of reads to the MFFCW<n>\_PAY register behave as defined in B8.2.3 Reading data from the FIFO.RHCKPRThere is no requirement for the read accesses to always target any specific offset(s) in the MFFCW<n>\_PAY register, for accesses with a smaller size than MFFCW<n>\_PAY register.

#### B8.4.1.3 MFFCW<n>\_FLG register

I<sub>FRCPT</sub> This section covers reads of the MFFCW<n>\_FLG register.

R<sub>KKNXY</sub> Read accesses to the MFFCW<n>\_FLG register returns:

- The SOT and EOT flags for the bytes last read from the FIFO and stored in the FHB, by the last read access to the MFFCW<n>\_PAY register.
- A valid flag field per each set of flag returned.
- The value of the MFFCW<n>\_ST.FFL field.

#### Note

The value of the MFFCW<n>\_ST.FFL field returned when performing a read of the MFFCW<n>\_FLG register can be truncated to fit within the size of the read to the MFFCW<n>\_FLG register.

| $R_{ZQBCD}$         | When a read of the MFFCW <n>_FLG register occurs, the entries in the FHB are used to generate the read response as follows:</n>                                                                                                                                          |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | • When MFFCW_CTRL.MSBF is 0b0:                                                                                                                                                                                                                                           |
|                     | <ul> <li>FHB[0] is associated with FLG0 and VFLG0 fields.</li> <li>FHB[x] is associated with FLGx and VFLGx fields.</li> </ul>                                                                                                                                           |
|                     | • When MFFCW_CTRL.MSBF is 0b1:                                                                                                                                                                                                                                           |
|                     | <ul> <li>FHB[0] is associated with FLGx and VFLGx fields.</li> <li>FHB[x] is associated with FLG0 and VFLG0 fields.</li> </ul>                                                                                                                                           |
|                     | Where x is equal to the size of the read access to the MFFCW <n>_FLG registers minus 1.</n>                                                                                                                                                                              |
| $\rm S_{\rm JFXLH}$ | Software must:                                                                                                                                                                                                                                                           |
|                     | <ul> <li>Access the MFFCW<n>_FLG register with the same size of access as it did to read the data from the MFFCW<n>_PAY register.</n></n></li> <li>Use the same value of MFFCW<n>_CTRL.MSBF to access the MFFCW<n>_PAY and MFFCW<n>_FLG register.</n></n></n></li> </ul> |
|                     | Otherwise it can lead to loss or corruption of information.                                                                                                                                                                                                              |
| S <sub>KTTFC</sub>  | Software must use the values of MFFCW <n>_FLG.{VFLG,FLG}<m> fields, to know whether:</m></n>                                                                                                                                                                             |
|                     | <ul> <li>The byte previously read from the MFFCW<n>_PAY register associated with the flag is valid.</n></li> <li>The byte was considered the start of a new Transfer, if it is valid.</li> <li>The byte was considered the end of a Transfer, if it is valid.</li> </ul> |
|                     | Invalid bytes and flags must not be used by software, otherwise, Transfer data as read by the Receiver, will include bytes which were not pushed onto the FIFO by the Sender.                                                                                            |
| $R_{LWJQC}$         | Table B8.8 shows the format of the returned read data, depending on the size of the read access, for a read of the MFFCW <n>_FLG register.</n>                                                                                                                           |

| Size of read of<br>MFFCW <n>_FLG<br/>register</n> | Returned read data bit offset | Description          | Note                                                                                             |
|---------------------------------------------------|-------------------------------|----------------------|--------------------------------------------------------------------------------------------------|
| 8-bit                                             | 7:4                           | MFFCW <n>_ST.FFL</n> | If the value of FFL field is greater than 15 the value in the returned r ead data is set to 15.  |
|                                                   | 2                             | Valid Flag 0         |                                                                                                  |
|                                                   | 1:0                           | Flag 0               |                                                                                                  |
| 16-bit                                            | 15:8                          | MFFCW <n>_ST.FFL</n> | If the value of FFL field is greater than 255 the value in the returned read data is set to 255. |
|                                                   | 7                             | Valid Flag 1         |                                                                                                  |
|                                                   | 6:4                           | Flag 1               |                                                                                                  |
|                                                   | 2                             | Valid Flag 0         |                                                                                                  |
|                                                   | 3:0                           | Flag 0               |                                                                                                  |
| 32-bit                                            | 31:21                         | MFFCW <n>_ST.FFL</n> |                                                                                                  |
|                                                   | 14                            | Valid Flag 3         |                                                                                                  |
|                                                   | 13:12                         | Flag 3               |                                                                                                  |
|                                                   | 10                            | Valid Flag 2         |                                                                                                  |
|                                                   | 9:8                           | Flag 2               |                                                                                                  |
|                                                   | 6                             | Valid Flag 1         |                                                                                                  |
|                                                   | 5:4                           | Flag 1               |                                                                                                  |
|                                                   | 2                             | Valid Flag 0         |                                                                                                  |
|                                                   | 1:0                           | Flag 0               |                                                                                                  |
| 64-bit                                            | 63:53                         | MFFCW <n>_ST.FFL</n> |                                                                                                  |
|                                                   | 30                            | Valid Flag 7         |                                                                                                  |
|                                                   | 29:28                         | Flag 7               |                                                                                                  |
|                                                   | 26                            | Valid Flag 6         |                                                                                                  |
|                                                   | 25:24                         | Flag 6               |                                                                                                  |
|                                                   | 22                            | Valid Flag 5         |                                                                                                  |
|                                                   | 21:20                         | Flag 5               |                                                                                                  |
|                                                   | 18                            | Valid Flag 4         |                                                                                                  |
|                                                   | 17:16                         | Flag 4               |                                                                                                  |
|                                                   | 14                            | Valid Flag 3         |                                                                                                  |
|                                                   | 13:12                         | Flag 3               |                                                                                                  |
|                                                   | 10                            | Valid Flag 2         |                                                                                                  |
|                                                   | 9:8                           | Flag 2               |                                                                                                  |
|                                                   | 6                             | Valid Flag 1         |                                                                                                  |

# Table B8.8: Returned read data for a read of MFFCW<n>\_FLG register depending on size of the read access

| Size of read of<br>MFFCW <n>_FLG<br/>register</n> | Returned read data bit offset | Description  | Note |  |
|---------------------------------------------------|-------------------------------|--------------|------|--|
|                                                   | 5:4                           | Flag 1       |      |  |
|                                                   | 2                             | Valid Flag 0 |      |  |
|                                                   | 1:0                           | Flag 0       |      |  |

#### Note

The association between Flag and the FHB entries depends on the value of the MFFCW<n>\_CTRL.MSBF field at the time of the read of the MFFCW<n>\_FLG register.

R<sub>MYWXN</sub> All bit offsets not listed in Table B8.8 are reserved and treated as RES0.

#### B8.4.2 FIFO Status

#### B8.4.2.1 PFFCW<n>\_ST register

| R <sub>vgrks</sub> | The PFFCW <n>_ST register provides the following fields:</n>                                                                                                                                                                                                           |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul><li>FFS field - Number of free bytes in the FIFO.</li><li>PPE field - Whether the last attempt to push data onto the FIFO was successful or not.</li></ul>                                                                                                         |
| R <sub>NMGFD</sub> | The PFFCW <n>_ST.FFS field indicates the number of invalid bytes in the FIFO. The behavior of the FFS field is as follows:</n>                                                                                                                                         |
|                    | <ul><li>When a FIFO flush occurs is set to the depth of the FIFO.</li><li>Decremented by one for every byte which is pushed onto the FIFO.</li><li>Incremented by one for every byte which is popped from the FIFO.</li></ul>                                          |
| R <sub>WGXZJ</sub> | The behavior of the PFFCW <n>_ST.PPE field is as follows:</n>                                                                                                                                                                                                          |
|                    | <ul> <li>Reset to 0b0.</li> <li>Set to 0b0 when a write to the PFFCW<n>_PAY register successfully pushes all bytes onto the FIFO.</n></li> <li>Set to 0b1 when a write to the PFFCW<n>_PAY register does not successfully push all bytes onto the FIFO.</n></li> </ul> |
| I <sub>CYBWG</sub> | The conditions that can cause one or more bytes to not be pushed onto the FIFO are defined in B8.2.2 <i>Pushing data onto the FIFO</i> and C1.1 <i>Register Access</i> .                                                                                               |
| R <sub>ynzjp</sub> | The PPE field is not affected by an access which fails the security checks if TZE or RME are implemented.                                                                                                                                                              |
|                    | B8.4.2.2 MFFCW <n>_ST register</n>                                                                                                                                                                                                                                     |
| R <sub>qmlml</sub> | The MFFCW <n>_ST.FFL field indicates the number of valid bytes in the FIFO. The behavior of the FFL field is as follows:</n>                                                                                                                                           |
|                    |                                                                                                                                                                                                                                                                        |

- FIFO flush occurs is set to 0.
- Incremented by one for every byte is pushed onto the FIFO.
- Decremented by one from every byte which is popped from the FIFO.

#### B8.4.3 Transfer Acknowledge Tracking

- I<sub>NSLSC</sub> As it is possible for the Sender to send multiple Transfer without waiting for a previous Transfer to be acknowledged, it is also possible for the Receiver to acknowledge multiple Transfer in the time taken for the Sender to detect this. To allow the Sender to keep track of how many Transfers have been acknowledged the Sender can use the PFFCW<n>\_ACK\_CNT register which counts the number of Transfer, which had the ACK flag set to 0b1 for the last byte of the Transfer, which have been popped from the FIFO by the Receiver.
- R<sub>VYFBW</sub> For every FIFO Pop Ack event generated PFFCW<n>\_ACK\_CNT.ACK\_CNT field is incremented by 1.
- $\mathbb{I}_{HRQTQ}$  The FIFO Pop Ack event indicates when the last byte of the Transfer has been popped from the FIFO and the byte had the ACK flag set. For more information on the FIFO Pop Ack event refer to <u>B8.5 *Events*</u>
- $R_{QXLLR}$  The max value of the PFFCW<n>\_ACK\_CNT.ACK\_CNT field is  $2^{clog2((FFCH_DEPTH/MTS)+1)}-1$ , where MTS is the minimum size of a Transfer in bytes which the Sender can send. The minimum size of a Transfer depends on the value of the P{8/16/32/64}BA\_SPT and the allowed values are shown in Table B8.9

| P8BA_SPT | P16BA_SPT | P32BA_SPT | P64BA_SPT | Minimum Transfer Size (Bytes) |
|----------|-----------|-----------|-----------|-------------------------------|
| 1        | Х         | Х         | Х         | 1                             |
| 0        | 1         | Х         | Х         | 2                             |
| 0        | 0         | 1         | Х         | 4                             |
| 0        | 0         | 0         | 1         | 8                             |

#### Table B8.9: Formula used to calculate minimum Transfer size in bytes

 $R_{HWFNN} If when the PFFCW<n>_ACK_CNT.ACK_CNT field is incremented and the value overflows the PFFCW<n>_ACK_CNT_ACK_CNT_OVRFLW field is set to 0b1.$ 

R<sub>JGWTP</sub> It is UNPREDICTABLE whether the value of the PFFCW<n>\_ACK\_CNT.ACK\_CNT is incremented, if between the generation of the a FIFO Pop Ack event and the event being counted, the MHUR enters a Non-operational state.

R<sub>MDTHX</sub> On a read of the PFFCW<n>\_ACK\_CNT register, the values of the ACK\_CNT and ACK\_CNT\_OVRFLW fields are set to 0x0 and 0b0 respectively if there is no needed to update the ACK\_CNT due to FIFO Pop Ack events. If there is a need to update the counter due to FIFO Pop Ack events the ACK\_CNT field is set to the number of FIFO Pop Ack events and the ACK\_CNT\_OVRFLW field is set to 0b0.

Chapter B8. FIFO Extension B8.5. Events

### **B8.5 Events**

**Each FFCH is associated with the following events:** 

- · Channel Transfer event
- FIFO Pop Ack event
- Channel Transfer Acknowledge event
- Sender FIFO Low Tide event
- Sender FIFO High Tide event
- Receiver FIFO Low Tide event
- Receiver FIFO High Tide event
- Sender FIFO flush event
- Receiver FIFO flush event

#### B8.5.1 Channel Transfer event

 $R_{BRRKX}$  A Channel Transfer event is generated when one or more bytes are pushed onto the FIFO and the PFFCW<n>\_FLG.EOT field was set to 0b1 for one of those bytes.

#### B8.5.2 FIFO Pop Ack event

R<sub>KJLVT</sub> When one or more bytes are popped from the FIFO for each byte popped which has the ACK and EOT fields both set to 0b1 a FIFO Pop Ack event is generated.

#### B8.5.3 Channel Transfer Acknowledge event

R<sub>MJDDH</sub> A Channel Transfer Acknowledge event is generated when the PFFCW<n>\_ACK\_CNT.ACK\_CNT field was zero and then becomes non-zero.

#### B8.5.4 Sender FIFO Low and High Tide events

- R<sub>KGWZM</sub> A Sender FIFO Low Tide event is generated when one or more bytes are popped from the FIFO and both the following are true:
  - The number of valid bytes in the FIFO before the pop operation was greater than the value of the PFFCW<n>\_TIDE.LOW field.
  - The number of valid bytes in the FIFO after the pop operation is less than or equal to the value of the PFFCW<n>\_TIDE.LOW field.
- R<sub>XGHGJ</sub> A Sender FIFO High Tide event is generated when one or more bytes are pushed onto the FIFO and both the following are true:
  - The number of valid bytes in the FIFO before the push operation was less than or equal the value of the PFFCW<n>\_TIDE.HIGH field.
  - The number of valid bytes in the FIFO after the push operation is greater than the value of the PFFCW<n>\_TIDE.HIGH field.
- $$\label{eq:linear} \begin{split} \mathbb{I}_{\text{LXYBS}} & \text{The value of PFFCW}{<}n{>}_{\text{TIDE}}.\{\text{HIGH/LOW}\} \text{ used in the calculations includes any offsets of the field which are RES0 due to the configuration of the MHU.} \end{split}$$

## Chapter B8. FIFO Extension B8.5. Events

 $I_{HZKYC}$  The intended uses of the Sender FIFO Low and High Tide events are:

- FIFO Low Tide event indicates to the Sender that there is N or more bytes free in the FIFO. It can use this to know when it can push more bytes onto the FIFO, for example it is possible to push all bytes of a new Transfer onto the FIFO.
- FIFO High Tide event indicates to the Sender that there is less than N bytes free in the FIFO. It can use this to know when it should stop pushing more bytes onto the FIFO, for example it is not possible to push a all bytes of a new Transfer onto the FIFO.

Where N is equal to the FIFO Depth minus the value of the PFFCW<n>\_TIDE.{LOW/HIGH} field respectively.

#### B8.5.5 Receiver FIFO Low and High Tide events

R<sub>XHDQD</sub> A Receiver FIFO Low Tide event is generated when one or more bytes are popped from the FIFO and both the following are true:

- The number of valid bytes in the FIFO before the pop operation was greater than the value of the MFFCW<n>\_TIDE.LOW field.
- The number of valid bytes in the FIFO after the pop operation is less than or equal to the value of the MFFCW<n>\_TIDE.LOW field.
- R<sub>LYXWB</sub> A Receiver FIFO High Tide event is generated when one or more bytes are pushed onto the FIFO and both the following are true:
  - The number of valid bytes in the FIFO before the push operation was less than or equal the value of the MFFCW<n>\_TIDE.HIGH field.
  - The number of valid bytes in the FIFO after the push operation is greater than the value of the MFFCW<n>\_TIDE.HIGH field.
- $I_{NWJFL}$  The value of MFFCW<n>\_TIDE.{HIGH/LOW} used in the calculations includes any offsets of the field which are RESO due to the configuration of the MHU.
- I<sub>TYDNB</sub> The intended uses of the Receiver FIFO Low and High Tide events are:
  - FIFO Low Tide event indicates to the Receiver that there is N or less bytes used in the FIFO. It can use this to know when it can stop processing data in the FIFO, for example there is not a complete Transfer in the FIFO.
  - FIFO High Tide event indicates to the Receiver that there is less than N bytes free in the FIFO. It can use this to know when it should start processing data in the FIFO, for example there is a complete Transfer in the FIFO.

Where N is equal to the value of the MFFCW<n>\_TIDE.{LOW/HIGH} field respectively.

#### B8.5.6 Sender FIFO flush event

R<sub>ZGNXL</sub> A Sender FIFO flush event is generated, by the MHUS, when all the following are true:

- A FIFO flush, performed by the mechanisms in the MHUR completes, and the MFFCW<n>\_ST.FF field is set to 0b1.
- MHUS is in an Operational state.

#### B8.5.7 Receiver FIFO flush event

 $R_{WMMSD}$  A Receiver FIFO flush event is generated, by the MHUR, when all the following are true:

- A FIFO flush, performed by the mechanisms in the MHUS completes, and the PFFCW<n>\_ST.FF field is set to 0b1.
- MHUR is in an Operational state.

## Chapter B9 TrustZone and Realm Management Extension

### **B9.1** Overview

- Image: Light states
   TrustZone (TZE) and Realm Management (RME) extensions enable an MHU to be integrated into a system with an Arm processor that supports multiple Security states and for the MHU to restrict which Security states can access the MHU resources.
- I<sub>NSNHG</sub> The Realm Management Extension defined by the Arm A-profile architecture v9 is referred to as FEAT\_RME.
- $I_{TSNFQ}$  The following sections cover the rules of TZE and RME.
- R<sub>YWLRF</sub> The MHUS and MHUR can have different support for the TZE and RME extensions.
- I<sub>HBSFJ</sub> Arm recommends that TZE and RME are implemented to match the features of the systems into which the MHUS or MHUR are to be integrated. For example, an Application system communicating with a System Control Processor (SCP) in full-duplex mode, where the Application system includes an Armv9-A processor with support for FEAT\_RME and the System Control Processor includes an Armv8-M processor without support for Arm<sup>®</sup> TrustZone<sup>®</sup> for Armv8-M. Table B9.1 shows the configuration of TZE and RME for both MHUS and MHUR of the two MHUS.

# Table B9.1: Example configuration of a pair of MHUs, used in full duplex mode, between an Application and System Control Processor

| Communication Link | MHUS/MHUR | TZE | RME |
|--------------------|-----------|-----|-----|
| Application -> SCP | MHUS      | Yes | Yes |
| Application -> SCP | MHUR      | No  | No  |
## Chapter B9. TrustZone and Realm Management Extension B9.1. Overview

| Communication Link | MHUS/MHUR | TZE | RME |
|--------------------|-----------|-----|-----|
| SCP -> Application | MHUS      | No  | No  |
| SCP -> Application | MHUR      | Yes | Yes |

Where -> indicates the direction in which Transfers are sent.

Both TZE and RME define the following concepts:

• All accesses to the registers of the MHUS and MHUR have a security property.

The security property indicates the security of the access.

• Security Group.

I<sub>QCFNF</sub>

There is a Security Group per each security world which is implemented. Resources of the MHU are then allocated to a Security Group, by software.

Chapter B9. TrustZone and Realm Management Extension B9.2. Security Assignment Agent

### **B9.2 Security Assignment Agent**

- D\_SSQNSWhen TZE or RME is implemented, introduces a software agent called the Security Assignment Agent.I\_HPZXLThere is a Security Assignment Agent for both the MHUS and MHUR, depending on whether TZE or RME are<br/>implemented for MHUS or MHUR.I\_JQTBKThe task of the Security Assignment Agent is to assign the resources of the MHUS or MHUR to the different<br/>Security Groups.R\_JKGJDThe Security Assignment Agent can only allocate the Postbox or Mailbox, including all channels in the MHU, to a<br/>specific Security Group.
- I<sub>RWMJZ</sub> Arm recommends that the assignment of Postbox and Mailbox to a Security Group is not changed dynamically.
- S<sub>KTLGX</sub> Software is responsible for handling the security implications if it re-assigns the Postbox or Mailbox to a different Security Group. This includes completing the Transfers for any outstanding Transfer and preventing any leakage of data between security worlds.

Chapter B9. TrustZone and Realm Management Extension B9.3. TZE

### B9.3 TZE

| R <sub>YPHCW</sub> | The rules in this section only apply when TZE is implemented by the MHUS or MHUR.                                                                                                                           |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>NRMQT</sub> | When TZE is implemented, there are two Security Groups defined:                                                                                                                                             |
|                    | <ul><li>Secure</li><li>Non-secure</li></ul>                                                                                                                                                                 |
| R <sub>QYLVY</sub> | When TZE is implemented, the Postbox and Mailbox of the MHU can be assigned to either the Secure Security Group or the Non-secure Security Group.                                                           |
| R <sub>YLVRN</sub> | At reset, the Postbox and Mailbox are assigned to the Secure Security Group.                                                                                                                                |
| R <sub>WTHVC</sub> | When TZE is implemented for the MHUS, the MHUS includes a Sender Security Control (SSC) block.                                                                                                              |
| R <sub>JNPTV</sub> | When TZE is implemented for the MHUR, the MHUR includes a Receiver Security Control (RSC) block.                                                                                                            |
| I <sub>ZWKMN</sub> | The SSC and RSC blocks provide registers to configure the Security Group which the Postbox or Mailbox belongs to.                                                                                           |
| R <sub>fZMMY</sub> | The SSC and RSC blocks are only accessible by Secure accesses.                                                                                                                                              |
| R <sub>szgsw</sub> | Any Non-secure access to either the SSC or RSC blocks is treated as an illegal access. For more information on the behavior of illegal accesses refer to C1.1.5 <i>Illegal Accesses</i> .                   |
| R <sub>KJHJD</sub> | Table B9.3 shows whether an access is allowed to access the registers of the Postbox or Mailbox depending on the security of the access and the Security Group which the Postbox or Mailbox is assigned to. |

# Table B9.2: Whether an access is allowed to access the registers the Postbox or Mailbox when TZE is implemented and not RME

| Security of access | Postbox/Mailbox Security Group | Access Allowed |
|--------------------|--------------------------------|----------------|
| Secure             | Any                            | No             |
| Non-secure         | Secure                         | No             |
|                    | Non-secure                     | Yes            |

Any access which is not allowed is treated as an illegal access. For more information on the behavior of illegal accesses refer to C1.1.5 *Illegal Accesses*.

Chapter B9. TrustZone and Realm Management Extension B9.4. RME

### **B9.4 RME**

| R <sub>dscbj</sub> | When RME is implemented, TZE is also implemented.                                                                                                                                                                                                     |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>CPSSP</sub> | The rules in this section only apply when RME is implemented.                                                                                                                                                                                         |
| I <sub>rzsdd</sub> | RME extends the capabilities of TZE to support the four security worlds defined by Realm Management Extension (RME) of the Armv9-A architecture.                                                                                                      |
| R <sub>HMLSB</sub> | RME adds two additional Security Groups:                                                                                                                                                                                                              |
|                    | <ul><li> Root Security Group.</li><li> Realm Security Group.</li></ul>                                                                                                                                                                                |
| R <sub>trvbr</sub> | At reset, the Postbox and Mailbox are assigned to the Root Security Group.                                                                                                                                                                            |
| R <sub>XCPJW</sub> | The SSC and RSC block are enhanced to enable selection between the four Security Groups.                                                                                                                                                              |
| R <sub>rmhpn</sub> | The registers of the SSC and RSC blocks are accessible only by the Root Security Group.                                                                                                                                                               |
| R <sub>hzqth</sub> | Any access to the registers of either the SSC or RSC blocks from the Secure, Non-secure or Realm security worlds are treated as an illegal access. For more information on the behavior of illegal accesses refer to C1.1.5 <i>Illegal Accesses</i> . |
| R <sub>bztsk</sub> | Table B9.3 shows whether an access is allowed to access the registers of the Postbox or Mailbox depending on the security of the access and the Security Group which the Postbox or Mailbox is assigned to.                                           |

## Table B9.3: Whether an access is allowed to access the registers the Postbox or Mailbox when RME is implemented

| Security of access | Postbox/Mailbox Security Group | Access Allowed |
|--------------------|--------------------------------|----------------|
| Root               | Any                            | Yes            |
| Realm              | Root                           | No             |
|                    | Realm                          | Yes            |
|                    | Secure                         | No             |
|                    | Non-secure                     | Yes            |
| Secure             | Root                           | No             |
|                    | Realm                          | No             |
|                    | Secure                         | Yes            |
|                    | Non-secure                     | Yes            |
| Non-secure         | Root                           | No             |
|                    | Realm                          | No             |
|                    | Secure                         | No             |
|                    | Non-secure                     | Yes            |

Any access which is not allowed is treated as an illegal access. For more information on the behavior of illegal accesses refer to C1.1.5 *Illegal Accesses*.

R<sub>CVZBG</sub> When the MHUS or MHUR implement RME, it is IMPLEMENTATION DEFINED whether the MHUS or MHUR implements a tie-off signal called LEGACY\_TZ\_EN.

## Chapter B9. TrustZone and Realm Management Extension B9.4. RME

| R <sub>yjpbh</sub> | The sampled value of the:                                                                                                                                                |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>LEGACY_TZ_EN for the MHUS only effects the behavior of the MHUS.</li> <li>LEGACY_TZ_EN for the MHUR only effects the behavior of the MHUR.</li> </ul>           |
| $R_{TLKPF}$        | The value of <b>LEGACY_TZ_EN</b> signal for the MHUS, where present, is sampled at de-assertion of the reset of the MHUS.                                                |
| R <sub>trbkt</sub> | The value of <b>LEGACY_TZ_EN</b> signal for the MHUR, where present, is sampled at de-assertion of the reset of the MHUR.                                                |
| I <sub>KLSHD</sub> | It is valid for the sampled <b>LEGACY_TZ_EN</b> value to be different between different between de-assertions of the reset of the MHU.                                   |
| R <sub>SXXLF</sub> | When the sampled value of LEGACY_TZ_EN tie-off is Obl, RME is disabled and the MHUS or MHUR behaves as if RME was not implemented.                                       |
|                    | This includes:                                                                                                                                                           |
|                    | • Modifying the behavior of the registers and fields to behave as if RME was not implemented.                                                                            |
|                    | All <x>_FEAT_SPT0.RME_SPT fields must read as <math>0 \times 0</math>, where <x> is one of the following register block prefixes:</x></x>                                |
|                    | <ul> <li>PBX</li> <li>MBX</li> <li>SSC</li> <li>RSC</li> </ul>                                                                                                           |
|                    | • Any security access check only checks whether the access is considered to be secure or non-secure.                                                                     |
|                    | <ul><li>Any access which is Root is considered to be Secure.</li><li>Any access which is Realm is considered to be Non-secure.</li></ul>                                 |
| R <sub>gtclm</sub> | When the sampled value of LEGACY_TZ_EN tie-off is Obl, it does not remove support for TZE.                                                                               |
| I <sub>pplsd</sub> | As RME requires TZE to be implemented when RME is disabled, via the sampled value of the LEGACY_TZ_EN being 0b1, the MHUS or MHUR behaves as if it only implemented TZE. |
| R                  | It is IMPLEMENTATION DEFINED whether fields which are defined as part of PME are writeable or not when                                                                   |

R<sub>ZTRJX</sub> It is IMPLEMENTATION DEFINED whether fields which are defined as part of RME are writeable or not when **LEGACY\_TZ\_EN** sampled value is 0b1. If the field is writeable the value of the field has no effect on the operation of the MHU and only be used to return a value when the field is read.

## Chapter B10 Reliability, Availability and Serviceability Extensions

### B10.1 Overview

| I <sub>JTDZS</sub> | Reliability, Availability and Serviceability Extensions (RASE) defines a framework for how RAS features can be included in a MHU implementation. Unlike other extensions whereby the architecture defines a set of features, RASE is an IMPLEMENTATION DEFINED features due to the highly implementation specific nature of the type of errors which can be detected. The architecture mandates a set of requirements which must be followed. |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>DSFTF</sub> | Arm recommends that the implementor implements RAS features as defined in B10.7 <i>Recommend implementation of RAS using Arm RAS extensions</i> .                                                                                                                                                                                                                                                                                             |
| R <sub>KTBFC</sub> | When RASE is implemented, the Sender RAS (SRAS) and Receiver RAS (RRAS) blocks are implemented.                                                                                                                                                                                                                                                                                                                                               |
| X <sub>CBSRW</sub> | The RAS register block is implemented as a separate 64KB block to allow the software agent which is acting on the RAS events to be independent of the Sender or Receiver using the Postbox or Mailbox.                                                                                                                                                                                                                                        |
| S <sub>NWRZG</sub> | Software can discover whether RASE is implemented by reading the value of the RASE_SPT field in the following registers:                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>PBX_FEAT_SPT0.</li> <li>MBX_FEAT_SPT0.</li> <li>SSC_FEAT_SPT0.</li> <li>RSC_FEAT_SPT0.</li> </ul>                                                                                                                                                                                                                                                                                                                                    |

R<sub>CPFDQ</sub> The contents of the SRAS and RRAS blocks are IMPLEMENTATION DEFINED.

Chapter B10. Reliability, Availability and Serviceability Extensions B10.2. Reporting Requirements

### **B10.2 Reporting Requirements**

- R<sub>TRPDL</sub> When an error is detected it must be reported. The mechanism by which it is reported and the information that is logged about the error is IMPLEMENTATION DEFINED.
- R<sub>GBFDV</sub> It is IMPLEMENTATION DEFINED whether an attempt is made to correct the error. Refer to B10.3 *Implications of error detection* for more information on the actions allowed to be taken to correct an error.
- I<sub>FDJGW</sub> The MHU is formed of two components, MHUS and MHUR which is used by two different software entities the Sender and Receiver. The Sender uses the MHUS to send Transfers and the Receiver uses the MHUR to receive the Transfers. To transfer a Transfer from the Sender to the Receiver, it requires logic in both the MHUS and MHUR to function correctly. Certain errors in one component can lead to incorrect operation that may only be detected by the other component or the software entity using the other component.

For example, corruption of the data inside the FIFO could occur and would be detected when the Receiver reads data from the FIFO. The Receiver will be informed of the data corruption and would considered the Transfer to be invalid. There are cases where the Sender would also want to be informed of the corrupted data so that it could re-send the Transfer.

- R<sub>DQRFH</sub> Errors that are detected and can only effect the Sender or Receiver are only reported by the RAS logic in the MHUS or MHUR respectively. Examples of errors which only effect the Sender or Receiver are:
  - Error of the Acknowledge Counter logic of the FIFO only affects the Sender and is only needed to be reported by the MHUS RAS logic.
  - Error of the Sender or Receiver Tidemark logic only effects the Sender or Receiver respectively and is only needed to be reported by the MHUS RAS logic for errors with the Sender Tidemark logic or the MHUR RAS logic for errors with the Receiver Tidemark logic.
  - Error of interrupt generation logic only effects the Sender or Receiver, and is only needed to be reported by the MHUS RAS logic for errors with interrupt generation logic of the MHUS or the MHUR RAS logic for errors with the MHUR interrupt generation logic.
  - Corruption of any payload data which has been corrected is only required to be reported in the MHUS RAS if the correction is performed on writing the data or MHUR if the correction is performed on reading the data.
- R<sub>DYFSP</sub> Errors that are detected and can effect both the Sender or Receiver, even if they will only effect the one of them, are reported by the RAS logic of both MHUS and MHUR. Examples of errors which can effect both the Sender and Receiver:
  - Corruption of any payload data which has not been corrected.
  - Corruption of the FIFO read or write logic.
- IQCPXRDetected errors can be specific to a specific part of the MHU. For example, an error could be related to a specific<br/>channel or type of channels. This is referred to as the impact zone of the error.
- R<sub>VFBDR</sub> The impact zone of an error detected in the MHU, is one of the following:
  - Global An error which effects either the whole MHU or when the MHU is unable to be identify or report which specific channel or types of channels of which are impacted.
  - Channel An error which effects a single channel of the MHU.
  - Channel type An error which effects all channels of a specific type.
- R<sub>RBLLF</sub> Impact zone for an error which apply to multiple channels and are all of the same type are reported as either effecting all channels of that type or global.
- R<sub>HTKHB</sub> Impact zone for an error which effects multiple channels of different types is reported as global.
- R<sub>LJWKG</sub> Impact zone for an error which does not effect a specific channel or all channels of a specific type is reported as global.
- R<sub>VCSWD</sub> An MHU implementation is only required to support the global impact zone.
- R<sub>WPMQX</sub> It is IMPLEMENTATION DEFINED which impact zone is reported for a specific error.

## *Chapter B10. Reliability, Availability and Serviceability Extensions B10.2. Reporting Requirements*

R<sub>KXLSV</sub> It is not required that different types of errors are reported with the same impact zone or that the same type of error but for a different piece of logic be reported with the same impact zone. However, the same type of error with the same bit of logic must always be reported with the same impact zone.

For example, in an MHU which supports 2 DBCH and 1 FFCH a double bit error detected in the PDBCW0\_ST or PDBCW1\_ST must both be reported with the same impact zone, whilst a double bit error detected in the FIFO of the FFCH can be reported with a different impact zone.

### B10.3 Implications of error detection

- When an error is detected, it is IMPLEMENTATION DEFINED whether the MHU attempts to correct it. For example, R<sub>MBNJW</sub> the MHU may implement ECC for the FIFO and be able to recover from a single bit error without impacting the functionality of the MHU. Errors where the MHU is able to correct the error are referred to as corrected errors, whilst errors where the MHU IWMVRK is unable to correct the error is referred to as an uncorrected error. Deferred errors are errors which are detected but are not correct at that point in time. Deferred errors might later ITLXVT be consumed and at that point become either corrected or uncorrected errors. It is IMPLEMENTATION DEFINED whether the MHU takes any actions to recover from an uncorrected error or not, R<sub>NGTZK</sub> including taking actions which can cause the lost of Transfers which are outstanding at the point when the error was detected. If a MHU implementation does takes steps to recover from an uncorrectable error that causes the lost of Transfer R<sub>XBJMW</sub> data, the following applies: • The error must be reported to both the Sender and Receiver using the MHUS and MHUR RAS logic, before any steps to correct the error are started. • The Sender or Receiver must be informed that data has been lost using an IMPLEMENTATION DEFINED method. • The lost of any Transfer data must never be wider than the reported impact zone of the error. For example, if the error is reported as being specific to FFCH0, then only Transfer data in FFCH0 is allowed to be lost. If Transfer data from another channel is lost then the error must be reported as either: • Impact all channels of that type. • Impact the entire MHU. Software must be prepared to perform an IMPLEMENTATION DEFINED sequence to recover from an uncorrectable S<sub>RZHJT</sub> error. Examples of these steps could be: • Completing any outstanding Transfers with the channel which is effected, but discarding the Transfer data. After this resending any Transfers which have been discarded. • Completing any outstanding Transfers with all channels that are effected, but discarding the Transfer data. After this resending any Transfers which have been discarded. • Performing a reset of either of or both the MHUS or MHUR, before resending any Transfers outstanding when the error was detected or sending new Transfers. It is valid for the Sender or Receiver to be responsible for acting on RAS events reported via the SRAS/RRAS S<sub>NXHVT</sub> blocks or for another piece of software, RAS agent, to be responsible for this. If the RAS agent is present, it is the responsibility of the RAS agent to either: • Implement a method by which the Sender or Receiver can discover that there has been a lost of data due to a RAS event.
  - To perform an IMPLEMENTATION DEFINED sequence to handle the possible lost of data.

Chapter B10. Reliability, Availability and Serviceability Extensions B10.4. Error record requirements

### B10.4 Error record requirements

| I <sub>gzzky</sub> | An error record records information about an error which has been detected.                                                                                                                      |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>MHYHG</sub> | It is IMPLEMENTATION DEFINED whether on detection of an error an error record is generated. If no error record is generated then the behavior for all detected errors must be as follows:        |
|                    | <ul><li>All errors are considered global errors.</li><li>All errors are considered to have causes lost of Transfer data.</li></ul>                                                               |
| R <sub>zgorp</sub> | If an error recorded is generated, the format of any error record is IMPLEMENTATION DEFINED but must include the following information:                                                          |
|                    | <ul><li>The impact zone of the error if impact zones other than global are supported.</li><li>Whether the MHU has taken corrective action which has lead to the lost of Transfer data.</li></ul> |
| R <sub>WJCXW</sub> | Whether an error recorded is generated or not for the error must be reported back to the Sender/Receiver.                                                                                        |

*Chapter B10. Reliability, Availability and Serviceability Extensions B10.5. RAS and Security* 

### B10.5 RAS and Security

R<sub>BNLSF</sub> The rules in this section only apply:

- To the Sender RAS block when the MHUS implements TZE or RME.
- The the Receiver RAS block when the MHUR implements TZE or RME.

#### B10.5.1 Error reporting

I<br/>VGNVBWhen TZE or RME is implemented in the MHUS or MHUR, the MHU enforces isolation between the different<br/>Security Groups. When RASE is also implemented this is extended to the reporting of RAS related errors. There<br/>is a strong industry requirement to allow RAS related events to be handled by the Kernel or Hypervisor running in<br/>the Non-secure world. To avoid breaking the security boundaries RAS error records must be sanitized to avoid<br/>leakage of information.

I<sub>TVNFH</sub> A RAS error is reported when an error is detected with a hardware resource which is related with a:

- Channel.
- Postbox or Mailbox.
- Sender or Receiver Security Control.

When the error is reported, information related to the error can be reported alongside the indication of the error in an error record. Information reported in an error record can be consider confidential information, depending on the Security Group of the hardware entity which generated the error and the security state of the memory access accessing the error record.

- D<sub>TQTPF</sub> In this section, confidential information is defined as being information which would not be accessible to the software agent handling the RAS error if it attempted to access the information via the normal method. This comprises:
  - Any data values which are part of a Transfer, include any contents held within the FIFO of a FFCH.
  - Any data values of any control or status registers which is part of the Postbox or Mailbox.
  - Any data values of any control or status registers which is part of the Sender or Receiver Security Control.

The following is not consider confidential information:

- Address offset of the register location which generated the error.
- Identifiers the channel number or type of channel.
- Information used to ascertain the severity of an error.

R<sub>SJCMX</sub> RAS error are associated with a Security Group.

R<sub>BTGJN</sub> The Security Group which an error is associated with depends on whether the error relates to a hardware resource associated with a:

• Channel.

As channels are part of a Postbox and Mailbox, which could be assigned to different Security Groups, the Security Group of the error is determined as follows:

- For an error reported in an error record in the Sender RAS block, the Security Group of the Postbox is used.
- For an error reported in an error record in the Receiver RAS block, the Security Group of the Mailbox is used.

If the error is reported in both the Sender and Receiver RAS blocks, this is consider two separate errors which are both treated separately and both have their own independent security.

• Register of a Postbox or Mailbox.

The Security Group the Postbox or Mailbox is associated with.

## Chapter B10. Reliability, Availability and Serviceability Extensions B10.5. RAS and Security

• Register of the Sender or Receiver Security Control.

The Root Security Group, when RME is implemented, otherwise it is the Secure Security Group.

- R<sub>YCLRQ</sub> There can be a time delay between when an error occurs until it is generated. In this time period the Security Group of the hardware resource which generated or caused the error may change. The Security Group associated with an error is taken to be the Security Group of the hardware resource which detects the error at the point it detects the error.
- S<sub>JJXZJ</sub> Software is responsible for handling the security implications, when changing the Security Group of a resource within the MHU.
- R<sub>KHFVV</sub> Confidential information, in an error record, must only be accessed by a security state which is of the same security state or higher. Table B10.1 shows the allowed security state of a memory access to the error record to be able to view confidential information of an error in the error record, depending on the security state associated with the error.

#### Table B10.1: Confidential information access security

| Error Security State | Allowed security state of access to the er ror record |
|----------------------|-------------------------------------------------------|
| Non-secure           | Any                                                   |
| Secure               | Secure or Root                                        |
| Realm                | Root or Realm                                         |
| Root                 | Root                                                  |

U<sub>GMPGB</sub> A number of implementation options are possible to meet the requirements for reporting errors when TZE or RME are implemented:

- RAS error records contain no confidential information. For example, only containing information about the offset or Channel which detected the error.
- RAS error records filter the information based on the security of the error and the security of the access to the error record.
- RAS error records which contain confidential information are only accessible by:
  - Root, if RME is implemented.
  - Secure, if RME is not implemented.

#### Note

Arm strongly recommends against making error records only accessible by a Root or Secure access.

#### B10.5.2 Error detection and reporting information

 $R_{LSQJF}$ 

Whether error detection logic is enabled and what information is reported in an error record may be control via IMPLEMENTATION DEFINED registers. If these registers are implemented the following rules apply:

- When RME is implemented, controls must default to accessible only to Root accesses.
- When RME is not implemented, controls must default to accessible only to Secure accesses.

It is allowed for the Root or Secure state to assign these controls to another security state if it so wishes.

*Chapter B10. Reliability, Availability and Serviceability Extensions B10.5. RAS and Security* 

#### B10.5.3 Error Injection

- R<sub>TTMGQ</sub> If the implementation supports generating an error, as defined by the Common Fault Injection Model Extension in [2], on an access to a register of the MHU the error is only generated if the access passes the security checks defined in Chapter B9 *TrustZone and Realm Management Extension*.
- R<sub>WMBCQ</sub> An access which fails its security checks is considered an illegal access as defined in Chapter B9 *TrustZone and Realm Management Extension*.

*Chapter B10. Reliability, Availability and Serviceability Extensions B10.6. Interrupts* 

### B10.6 Interrupts

- R<sub>LFCKP</sub> It is IMPLEMENTATION DEFINED whether one or more interrupts are generated when an error is detected. There can be different interrupts based on the type or severity of error detected and any corrective action taken.
- I<sub>XYLKZ</sub> These interrupts are referred to a RAS interrupts in this architecture.
- R<sub>YCGXP</sub> Any RAS interrupts must be a separate interrupt to any of the interrupts defined in Chapter B11 *Interrupts*. It is allowed for an IMPLEMENTATION DEFINED interrupt to combined one or more RAS interrupts with one or more of the interrupts defined in Chapter B11 *Interrupts*. This rule applies whether the combined interrupt is internal or external interrupt.

### B10.7 Recommend implementation of RAS using Arm RAS extensions

| I <sub>NRTXT</sub> | Arm recommends that an implementation of the MHU which implements RASE, follows the rules in this section.                                                                                                                                                                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>rgnsy</sub> | The registers in the SRAS/RRAS block follow the format described in [2] for RAS registers.                                                                                                                                                                                                                                                                                                   |
| $R_{LSCHM}$        | Unless stated here the rules of [2] defines the behavior of the RAS logic.                                                                                                                                                                                                                                                                                                                   |
| I <sub>MTZRR</sub> | Arm recommends that FEAT_RASSA_ACR is implemented for the registers in the SRAS/RRAS block when either TZE or RME are implemented.                                                                                                                                                                                                                                                           |
| X <sub>gdpkf</sub> | This allows for control of which security world can access the SRAS/RRAS blocks.                                                                                                                                                                                                                                                                                                             |
| R <sub>hhqdj</sub> | When following all rules in this section the value of the RASE_SPT field is set to 0b0011. Otherwise, it must be set to 0b0010 if RASE is implemented.                                                                                                                                                                                                                                       |
| I <sub>TVVJG</sub> | The ERR <n>MISC0[31:0] are used to convey information about the error. All of bits in ERR<n>MISC0 are as defined in [2].</n></n>                                                                                                                                                                                                                                                             |
| R <sub>cdfqg</sub> | ERR <n>MISC0[31:17] and ERR<n>MISC0[15] is RES0.</n></n>                                                                                                                                                                                                                                                                                                                                     |
| R <sub>CPJZK</sub> | ERR <n>MISC0[16] indicates whether the error may have caused lost of Transfer data from the channels within the impact zone.</n>                                                                                                                                                                                                                                                             |
| R <sub>BCVNN</sub> | ERR <n>MISC0[14:13] is the IZ, Impact Zone, field and has the following values:</n>                                                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>0b00 - Global.</li> <li>0b01 - Channel specific.</li> <li>0b10 - Channel Type.</li> </ul>                                                                                                                                                                                                                                                                                           |
| R <sub>szckk</sub> | ERR <n>MISC0[12:0] when IZ is 0b00 are RESO.</n>                                                                                                                                                                                                                                                                                                                                             |
| R <sub>KBXVC</sub> | ERR <n>MISC0[12:0] when IZ is Ob01 are as follows:</n>                                                                                                                                                                                                                                                                                                                                       |
|                    | • [12:10] - CT, Channel Type and has the following values:                                                                                                                                                                                                                                                                                                                                   |
|                    | <ul> <li>0b000 - DBCH.</li> <li>0b001 - FCH.</li> <li>0b010 - FFCH.</li> </ul>                                                                                                                                                                                                                                                                                                               |
|                    | • [9:0] - CN, Channel Number.                                                                                                                                                                                                                                                                                                                                                                |
| R <sub>JSHYC</sub> | ERR <n>MISC0[12:0] when IZ is 0b10 are as follows:</n>                                                                                                                                                                                                                                                                                                                                       |
|                    | • [12:10] - CT, Channel Type and has the following values:                                                                                                                                                                                                                                                                                                                                   |
|                    | <ul> <li>0b000 - DBCH.</li> <li>0b001 - FCH.</li> <li>0b010 - FFCH.</li> </ul>                                                                                                                                                                                                                                                                                                               |
|                    | • [9:0] - RESO.                                                                                                                                                                                                                                                                                                                                                                              |
| R <sub>NDMNJ</sub> | If the Common Fault Injection Model Extension defined in [2] is implemented, the value of the ERR <n>MISC0[31:0] bits are set as follows:</n>                                                                                                                                                                                                                                                |
|                    | <ul> <li>If ERR<n>PFGF.{NA,MV} are set to any value other than 0b00 the value of ERR<n>MISCO[31:0] reads as 0x0000\_0000, indicating the error is reported with a impact zone of global.</n></n></li> <li>If ERR<n>PFGF.{NA,MV} are set to 0b0 and 0b0 respectively the value in the ERR<n>MISC0[31:0] is set as follows, when an access to a register in the MHU occurs:</n></n></li> </ul> |
|                    | • If the access is to a location, even a Reserved location, of an implemented Channel Window the error is recorded as an error with an impact zone of only the channel which was accessed. For example, an access to the PDBCW0_ST would be recorded as an error for the DBCH0.                                                                                                              |

## Chapter B10. Reliability, Availability and Serviceability Extensions B10.7. Recommend implementation of RAS using Arm RAS extensions

- If the access is to a Reserved location outside an implemented Channel Window in PDBCW\_page, PFFCW\_page, PFFCW\_page of PDCW\_page and the page is implemented, or any location in an unimplemented Channel Window, the error is recorded as having an impact zone effecting all channels of that type. For example, an access to MFFCW4\_PAY when only a single FFCH is implemented is recorded with an impact zone effecting all FFCHs.
- The behavior of accesses to registers in the <x>\_IMPL\_DEF\_pages is IMPLEMENTATION DEFINED. Arm recommends these are report as Global unless the register accessed controls features of a specific channel or channel type.
- If the access is to any other location the error is recorded with an impact zone of global.

 $R_{MKSWQ}$  When reporting injected errors, if the impact zone is not supported by the implementation the impact zone is recorded as follows:

- Error should be reported with an impact zone of a specific channel is reported as being specific to a channel type or Global.
- Error should be reported with an impact zone of a channel type is reported as being Global.

## Chapter B11 Interrupts

 INGCPH
 The MHU generates a number of events some of which are used to generate interrupts. These interrupts are then indicated to the Interrupt Controllers of the Sender and Receiver using a wired interrupt.

### B11.1 Interrupt Types

I<sub>XBJGB</sub> The MHU supports the following interrupt types:

- Maskable interrupt
- Enable interrupt
- Shared enable interrupt
- Combined interrupt
- Combined status interrupt
- Combined enabled interrupt

I<sub>DRGWB</sub> Each type of interrupt defines the following:

- How events are used to determine whether to assert the interrupt or not.
- How software interacts with the interrupt, for example whether the interrupt has an enable and status field.

#### B11.1.1 Maskable interrupt

I<sub>RCXDJ</sub> A maskable interrupt is an interrupt that has a mask which is used to select which events generate (unmasked) and do not generate (masked) an interrupt.

- R<sub>JRVTB</sub> A maskable interrupt has the following registers:
  - Mask status Provides the status of the mask.
  - Mask set Allows setting of bits in the mask status register to Ob1.
  - Mask clear Allows settings of bits in the mask status register to 0b0.
  - Status Raw status.
  - Status masked Status with the mask applied.
  - Set Allows settings of bits in the status register to 0b1.
  - Clear Allows settings of bits in the status register to 0b0.
- R<sub>DPDMZ</sub> A maskable interrupt is asserted when any bit of the status masked register is 0b1.
- R<sub>RPKZT</sub> The mask is set and cleared by writing 0b1 to the associated field of the mask set and clear register respectively.
- R<sub>GWYHJ</sub> Setting of a field in the mask takes precedence over clearing the field.
- R<sub>CNQJS</sub> Field <x> in the status register is set to:
  - 0b1, when a write to field  $\langle x \rangle$  in the set register causes the event to be triggered.
  - 0b0, when a write to field <x> in the clear register causes any previously triggered events for that event to be cleared.
- $R_{MMLJR}$  Setting of a field <x> in the status register takes precedence over clearing the field.

#### R<sub>SZZVV</sub> The status masked is generated by ANDing together the status and the inverted mask value.

- $R_{PDJDQ}$  The interrupt is cleared by making all fields in the status masked register be 0b0, by either:
  - Setting all fields in the mask status register to 0b1.
  - Setting all fields in the status register to 0b0.

## Chapter B11. Interrupts B11.1. Interrupt Types





Note

In Figure B11.1 the thick lines indicate buses and all logic on these buses is replicated for each bit except for the final output OR gate.

#### B11.1.2 Enable interrupt

An enable interrupt is an interrupt that has an enable which selects whether the event(s) generate an interrupt or IFLODC not. An enable interrupt has the following fields: R<sub>JZWFR</sub> • Interrupt status - Indicates whether the event has occurred. • Interrupt enable - Controls whether the event should generate an interrupt. · Interrupt clear - Allows software to clear the status bit. The interrupt status field is:  $R_{GGJBD}$ • Set to Ob1 when the event occurs and the enable bit is set to Ob1. • Set to 0b0 when 0b1 is written to the interrupt clear field. Set takes precedence over clear for the interrupt status field. R<sub>ZHVKX</sub> An enable interrupt is asserted when the status field is 0b1. R<sub>PDRRP</sub> Figure B11.2 shows the logic used to generated an enable interrupt. R<sub>BCZQZ</sub> EN



Figure B11.2: Enable interrupt logic

#### B11.1.3 Shared enable interrupt

| I <sub>cthfw</sub> | Shared enable interrupt are similar to enable interrupts except they:                                                                                                                                                          |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                    | <ul><li>Have a shared interrupt enable field which is used to enable two or more shared enable interrupts.</li><li>They have no software visible interrupt status field.</li><li>They have no interrupt clear field.</li></ul> |  |
| R <sub>lmgdf</sub> | A shared enable interrupt is asserted when the event occurs and the interrupt enable is set to Ob1.                                                                                                                            |  |
| R <sub>rxjss</sub> | There is no dedicated clear register.                                                                                                                                                                                          |  |
| R <sub>mhrpx</sub> | The interrupt is cleared by performing an action which acknowledges the interrupt.                                                                                                                                             |  |
| R <sub>rwrxr</sub> | Set takes precedence over clear for a shared enable interrupt.                                                                                                                                                                 |  |
| R <sub>dtzgb</sub> | There is no software visible status register.                                                                                                                                                                                  |  |
| X <sub>TMMWJ</sub> | As there is an interrupt per shared enable interrupt there is no need for a dedicated status registers as when a shared enable interrupt output is asserted that is the indication of the source of the interrupt.             |  |

R<sub>GCHGK</sub> Figure B11.3 shows the logic used to generate a shared enable interrupt



Figure B11.3: Shared enable interrupt logic

 ${\tt I}_{\rm VTYJN}$ 

In Figure B11.3 more than one shared enable interrupt interrupt is shown to demonstrate that a single enable register is used to enable all shared enable interrupts.

#### B11.1.4 Combined interrupt

ImportA combined interrupt is a combination of several interrupts in the MHU to reduce the number of interrupts from<br/>the MHU.RwQWPZA combined interrupt has no dedicated status, enable or clear fields.RBGHBHThe interrupt is asserted when any of the interrupts combined by the interrupt are asserted.STDDPTSoftware uses the underlying fields of the interrupts which are combined as follows:<br/>• Enable field to select whether the interrupt is enabled and contributes to the combined interrupt.<br/>• Status field to identify which interrupt caused the combined interrupt to be asserted.RXYKRTFigure B11.4 shows the logic used to generate a combined interrupt.



Figure B11.4: Combined interrupt

#### B11.1.5 Combined status interrupt

I\_SBVYKA combined status interrupt is a combination of several interrupt in the MHU to reduce the number of interrupts<br/>from the MHU with a dedicated status field for each interrupt it combines.

- R<sub>QRKKR</sub> A combined status interrupt has a dedicated status field for each interrupt it combines.
- R<sub>KSHKB</sub> The status field is set to 0b1 when the interrupt it is associated with is asserted, otherwise it is set to 0b0.
- $R_{BQBNW}$  The combined status interrupt is asserted when any of the status fields are set to 0b1.
- S<sub>VLJJG</sub> Software clears a combined status interrupt by clearing all the interrupts which are combined together.
- R<sub>FRBYY</sub> Figure B11.5 shows the logic used to generate a combined status interrupt.



Figure B11.5: Combined status interrupt

### B11.1.6 Combined enable interrupt

| I <sub>kgvbp</sub> | Combined enable interrupts are similar to combined interrupts but have a dedicated enable and a status field per each interrupt which it combines.                                          |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>ygzsy</sub> | There is an enable and status field for each interrupt which is combined together to form the combined enable interrupt.                                                                    |
| R <sub>hrkbt</sub> | A field in the status register is set to $0b1$ when both the enable field is set to $0b1$ and the interrupt the field is associated with is asserted, otherwise the field is set to $0b0$ . |
| R <sub>XTGTF</sub> | A combined enable interrupt is asserted when one or more of the status fields are Ob1.                                                                                                      |
| S <sub>SLQSZ</sub> | Software uses the enable and status fields as follows:                                                                                                                                      |
|                    | • Enable                                                                                                                                                                                    |
|                    | Select which interrupt it receives via the combined enable interrupt.                                                                                                                       |
|                    | • Status                                                                                                                                                                                    |
|                    | Identify which of the combined interrupts caused the combined enable interrupt to be asserted.                                                                                              |
| $S_{\text{TFZMD}}$ | To clear a combined enable interrupt, software must do one of the following:                                                                                                                |
|                    | <ul> <li>Clear all interrupts which are combined by the combined enable interrupt.</li> <li>Set the enable for that interrupt to 0b0.</li> </ul>                                            |
| R <sub>QXLSZ</sub> | Figure B11.6 shows the logic used to generate a combined enable interrupt.                                                                                                                  |
|                    | Enable[0]                                                                                                                                                                                   |
|                    | Enable[1]                                                                                                                                                                                   |
|                    |                                                                                                                                                                                             |



Figure B11.6: Combined enable interrupt

### B11.2 MHU Interrupts

- I<sub>RWFMY</sub> This section covers the interrupts of the MHU.
- R<sub>DXFTW</sub> All interrupts of the MHU are level-sensitive wired interrupts.
- R<sub>LGXZT</sub> Interrupts of the MHU can be either:
  - Internal

Internal interrupts do not have an interrupt output and are only exposed to software via another interrupt which has an interrupt output.

• External

External interrupts must have an interrupt output for software to receive the interrupt directly. External interrupts can also be used internally to generate other interrupts.

- I<sub>HYXJD</sub> The MHU has the following interrupts:
  - Channel Transfer
  - Channel Transfer Acknowledge
  - Fast Channel Transfer
  - Fast Channel Group Transfer
  - Sender FIFO Low Tidemark
  - Sender FIFO High Tidemark
  - Receiver FIFO Low Tidemark
  - Receiver FIFO High Tidemark
  - Sender FFCH Combined
  - Receiver FFCH Combined
  - Postbox Combined
  - Mailbox Combined

The following sections provide details on each interrupt.

L<sub>PTFZB</sub> Chapter D1 *Postbox and Mailbox Interrupt Logic* shows the structure of both the Postbox and Mailbox interrupt generation logic showing all interrupts.

#### B11.2.1 Channel Transfer

- I<sub>CZTZL</sub> The Channel Transfer interrupt indicates when there is a new Transfer in DBCH or FFCH.
- R<sub>SMGPR</sub> There is a Channel Transfer interrupt per each DBCH and FFCH implemented in the MHU.
- R<sub>QRCFQ</sub> It is IMPLEMENTATION DEFINED whether the Channel Transfer interrupt is implemented as an internal or external interrupt.
- R<sub>NWSSD</sub> If the Channel Transfer interrupt is implemented as an external interrupt the interrupt output is present on the MHUR.
- $I_{MJRZC}$  The Channel Transfer interrupt behavior is dependent on the type of channel it is associated with.

#### B11.2.1.1 DBCH

- R<sub>CVQXG</sub> The Channel Transfer interrupt for a DBCH is a maskable interrupt and uses the Channel Transfer events of the DBCH as the event inputs.
- R<sub>XVGGL</sub> The Channel Transfer interrupt for a DBCH has the following registers:
  - MDBCW<n>\_MSK\_ST is the mask register.
  - MDBCW<n>\_MSK\_SET is the mask set register.

- MDBCW<n>\_MSK\_CLR is the mask clear register.
- MDBCW<n>\_ST is the status register.
- MDBCW<n>\_ST\_MSK is the status masked register.
- PDBCW<n>\_SET is the set register.
- MDBCW<n>\_CLR is the clear register.

#### B11.2.1.2 FFCH

R<sub>RHJGW</sub> The Channel Transfer interrupt for an FFCH is an enable interrupt and uses the Channel Transfer event of the FFCH as the event input.

R<sub>ZMFHH</sub> The Channel Transfer interrupt for a FFCH uses the following fields:

- MFFCW<n>\_INT\_ST.TFR interrupt status.
- MFFCW<n>\_INT\_EN.TFR interrupt enable.
- MFFCW<n>\_INT\_CLR.TFR interrupt clear.

#### B11.2.2 Channel Transfer Acknowledge

| I <sub>TZMQG</sub> | The Channel Transfer Acknowledge interrupt indicates to the Sender when a Transfer in a DBCH or FFCH has been acknowledge by the Receiver.                                            |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>qxnvj</sub> | There is a Channel Transfer Acknowledge interrupt per each DBCH and FFCH implemented in the MHU.                                                                                      |
| I <sub>CGJHF</sub> | FC do not have a Channel Transfer Acknowledge as it is considered a lossy channel and a Transfer does not require the Receiver indicates acknowledgement back to the Sender.          |
| R <sub>gqyps</sub> | It is IMPLEMENTATION DEFINED whether the Channel Transfer Acknowledge interrupt is implemented as an internal or external interrupt.                                                  |
| R <sub>CBKXM</sub> | If the Channel Transfer Acknowledge interrupt is implemented as an external interrupt the interrupt output is present on the MHUS.                                                    |
| R <sub>cvgtw</sub> | The Channel Transfer Acknowledge interrupt is an enable interrupt and uses the Channel Transfer Acknowledge event of the DBCH or FFCH.                                                |
| R <sub>zctcl</sub> | The Channel Transfer Acknowledge interrupt for the DBCH uses the following fields:                                                                                                    |
|                    | <ul> <li>PDBCW<n>_INT_ST.TFR_ACK - interrupt status.</n></li> <li>PDBCW<n>_INT_EN.TFR_ACK - interrupt enable.</n></li> <li>PDBCW<n>_INT_CLR.TFR_ACK - interrupt clear.</n></li> </ul> |
| R <sub>gdhgf</sub> | The Channel Transfer Acknowledge interrupt for the FFCH uses the following fields:                                                                                                    |
|                    | • PFFCW <n>_INT_ST.TFR_ACK - interrupt status.</n>                                                                                                                                    |

- PFFCW<n>\_INT\_EN.TFR\_ACK interrupt status.
  PFFCW<n>\_INT\_EN.TFR\_ACK interrupt enable.
- PFFCW<n>\_INT\_EN.TFR\_ACK interrupt clear.
  PFFCW<n>\_INT\_CLR.TFR\_ACK interrupt clear.

#### B11.2.3 Fast Channel Transfer

- $I_{TQPWT}$  The Fast Channel Transfer interrupt indicates when there is a new Transfer in a FC.
- R<sub>HZDJR</sub> There is a Fast Channel Transfer interrupt per each FC implemented in the MHU.
- R<sub>HLKGD</sub> If Fast Channel Group Transfer interrupts are implemented, it is IMPLEMENTATION DEFINED whether the Fast Channel Transfer interrupt is implemented as an internal or external interrupt.
- R<sub>QFVST</sub> If Fast Channel Group Transfer interrupts are not implemented, the Fast Channel Transfer interrupt must be implemented as an external interrupt.

| R <sub>KKRKV</sub> | If the Fast Channel Transfer interrupt is implemented as an external interrupt the interrupt output is present on the MHUR.        |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| $R_{\rm JWBYZ}$    | The Fast Channel Transfer interrupt is a shared enable interrupt and uses the Channel Transfer event of the FC as the event input. |
| R <sub>vzyfj</sub> | The MBX_FCH_CTRL.INT_EN is the interrupt enable field.                                                                             |
| R <sub>XNVBJ</sub> | The interrupt is cleared when the Receiver acknowledges the Transfer by reading the MFCW <n>_PAY register.</n>                     |

#### B11.2.4 Fast Channel Group Transfer

- INSRJYFast Channel Group Transfer interrupt indicates when one or more of the FCHs in a FCG, have asserted the Fast<br/>Channel Transfer interrupt.RQKDVGIt is IMPLEMENTATION DEFINED whether Fast Channel Group Transfer interrupts are implemented and whether it<br/>is implemented as an internal or external interrupt.RCJWKWIf the Fast Channel Group Transfer interrupts are implemented as an external interrupt the interrupt output is<br/>present on the MHUR.
- S<sub>SSGYY</sub> Software can discover whether the Fast Channel Group Transfer interrupts are implemented using the MBX\_FCH\_CFG0.FCGI\_SPT field.
- R<sub>JFNNV</sub> When Fast Channel Group Transfer interrupts are implemented the following all applies:
  - MBX\_FCH\_CFG0.FCGI\_SPT is set to Ob1.
  - MBX\_FCH\_GRP<n>\_INT\_ST registers are implemented.
- R<sub>MSFBJ</sub> When Fast Channel Group Transfer is implemented there is one Fast Channel Group Transfer interrupt per each FCG implemented in the MHU.
- R<sub>QCTMJ</sub> The Fast Channel Group Transfer interrupt is a combined status interrupt and combines the Fast Channel Transfer interrupts of each Fast Channel in the FCG.
- R<sub>DGLDS</sub> MBX\_FCH\_GRP<n>\_INT\_ST.FCH\_INT\_ST<m> is the status field for each Fast Channel Transfer interrupt combined by the Fast Channel Group Transfer interrupt, where:
  - <n> is the FCG number.
  - <m> is the FCH number within the FCG.

Both <n> and <m> are numbered starting from 0 in ascending order.

#### B11.2.5 Sender FIFO Low Tidemark

- I\_XFLTT
   The Sender FIFO Low Tidemark interrupt indicates when the number of bytes used in the FIFO becomes less than or equal the low tidemark value set by the Sender.
- R<sub>XVNSY</sub> There is a Sender FIFO Low Tidemark interrupt per each FFCH implemented in the MHU.
- R<sub>YFRNZ</sub> It is IMPLEMENTATION DEFINED whether the Sender FIFO Low Tidemark interrupt is implemented as an internal or external interrupt.
- R<sub>QXJRQ</sub> If the Sender FIFO Low Tidemark interrupt is implemented as an external interrupt the interrupt output is present on the MHUS.
- R<sub>MZJRM</sub> The Sender FIFO Low Tidemark interrupt is an enable interrupt and uses the Sender FIFO Low Tidemark event of the FFCH as the event input.

R<sub>NMPJL</sub> The Sender FIFO Low Tidemark interrupt for the FFCH uses the following fields:

- PFFCW<n>\_INT\_ST.FLT interrupt status.
- PFFCW<n>\_INT\_EN.FLT interrupt enable.
- PFFCW<n>\_INT\_CLR.FLT interrupt clear.

#### B11.2.6 Sender FIFO High Tidemark

- Image: Image:
- $R_{HZTJG} \qquad \mbox{There is a Sender FIFO High Tidemark interrupt per each FFCH implemented in the MHU}.$
- R<sub>VSSGL</sub> It is IMPLEMENTATION DEFINED whether the Sender FIFO High Tidemark interrupt is implemented as an internal or external interrupt.
- R<sub>PJPLZ</sub> If the Sender FIFO High Tidemark interrupt is implemented as an external interrupt the interrupt output is present on the MHUS.
- R<sub>LXCPZ</sub> The Sender FIFO High Tidemark interrupt is an enable interrupt and uses the Sender FIFO High Tidemark event of the FFCH as the event input.
- R<sub>KHTRL</sub> The Sender FIFO High Tidemark interrupt for the FFCH uses the following fields:
  - PFFCW<n>\_INT\_ST.FHT interrupt status.
  - PFFCW<n>\_INT\_EN.FHT interrupt enable.
  - PFFCW<n>\_INT\_CLR.FHT interrupt clear.

#### B11.2.7 Sender FIFO Flush

- I<sub>BNRBC</sub> The Sender FIFO flush interrupt indicates when a FIFO flush, requested by the Receiver, has completed.
- R<sub>JDQBC</sub> There is a Sender FIFO flush interrupt per each FFCH implemented in the MHU.
- R<sub>GVYRG</sub> It is IMPLEMENTATION DEFINED whether the Sender FIFO flush interrupt is implemented as an internal or external interrupt.
- R<sub>MWHXF</sub> If the Sender FIFO flush interrupt is implemented as an external interrupt the interrupt output is present on the MHUS.
- R<sub>LRYBR</sub> The Sender FIFO flush interrupt is an enable interrupt and uses the Sender FIFO flush event of the FFCH as the event input.
- R<sub>ZBPCD</sub> The Sender FIFO flush interrupt for the FFCH uses the following fields:
  - PFFCW<n>\_INT\_ST.FF interrupt status.
  - PFFCW<n>\_INT\_EN.FF interrupt enable.
  - PFFCW<n>\_INT\_CLR.FF interrupt clear.

#### B11.2.8 Receiver FIFO Low Tidemark

- IVHPGY
   The Receiver FIFO Low Tidemark interrupt indicates when the number of bytes used in the FIFO becomes less than or equal the low tidemark value set by the Receiver.
- R<sub>XHLSF</sub> There is a Receiver FIFO Low Tidemark interrupt per each FFCH implemented in the MHU.
- R<sub>LVKLR</sub> It is IMPLEMENTATION DEFINED whether the Receiver FIFO Low Tidemark interrupt is implemented as an internal or external interrupt.

- R<sub>CVTHH</sub> If the Receiver FIFO Low Tidemark interrupt is implemented as an external interrupt the interrupt output is present on the MHUR.
- R<sub>FLGDH</sub> The Receiver FIFO Low Tidemark interrupt is an enable interrupt and uses the Receiver FIFO Low Tidemark event of the FFCH as the event input.
- R<sub>YLZSV</sub> The Receiver FIFO Low Tidemark interrupt for the FFCH uses the following fields:
  - MFFCW<n>\_INT\_ST.FLT interrupt status.
  - MFFCW<n>\_INT\_EN.FLT interrupt enable.
  - MFFCW<n>\_INT\_CLR.FLT interrupt clear.

#### B11.2.9 Receiver FIFO High Tidemark

- IFDZLTThe Receiver FIFO High Tidemark interrupt indicates when the number of valid bytes in the FIFO becomes greater<br/>than the high tidemark value set by the Receiver.
- R<sub>DVMSQ</sub> There is a Receiver FIFO High Tidemark interrupt per each FFCH implemented in the MHU.
- R<sub>GKRGN</sub> It is IMPLEMENTATION DEFINED whether the Receiver FIFO High Tidemark interrupt is implemented as an internal or external interrupt.
- R<sub>FHQRP</sub> If the Receiver FIFO High Tidemark interrupt is implemented as an external interrupt the interrupt output is present on the MHUR.
- R<sub>MZNZT</sub> The Receiver FIFO High Tidemark interrupt is an enable interrupt and uses the Receiver FIFO High Tidemark event of the FFCH as the event input.
- R<sub>JNPBK</sub> The Receiver FIFO High Tidemark interrupt for the FFCH uses the following fields:
  - MFFCW<n>\_INT\_ST.FHT interrupt status.
  - MFFCW<n>\_INT\_EN.FHT interrupt enable.
  - MFFCW<n>\_INT\_CLR.FHT interrupt clear.

#### B11.2.10 Receiver FIFO Flush

- I<sub>VNDJD</sub> The Receiver FIFO flush interrupt indicates when a FIFO flush, requested by the Sender, has completed.
- R<sub>XYRSG</sub> There is a Receiver FIFO flush interrupt per each FFCH implemented in the MHU.
- R<sub>RLZTH</sub> It is IMPLEMENTATION DEFINED whether the Receiver FIFO flush interrupt is implemented as an internal or external interrupt.
- R<sub>LCWBG</sub> If the Receiver FIFO flush interrupt is implemented as an external interrupt the interrupt output is present on the MHUR.
- R<sub>HHLJG</sub> The Receiver FIFO flush interrupt is an enable interrupt and uses the Receiver FIFO flush event of the FFCH as the event input.

 $R_{\text{HDHBS}}$  The Receiver FIFO flush interrupt for the FFCH uses the following fields:

- MFFCW<n>\_INT\_ST.FF interrupt status.
- MFFCW<n>\_INT\_EN.FF interrupt enable.
- MFFCW<n>\_INT\_CLR.FF interrupt clear.

#### B11.2.11 Sender FFCH Combined

 I\_JFTBW
 The Sender FFCH Combined interrupt is provided to reduce the number of interrupt wires required for the Sender to receive all possible events from a FFCH.

| R <sub>NXBTC</sub> | There is a Sender FFCH Combined interrupt per each FFCH implemented in the MHU.                                                                     |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>YCCTJ</sub> | It is IMPLEMENTATION DEFINED whether the Sender FFCH Combined interrupt is implemented as an internal or external interrupt.                        |
| R <sub>dbxhb</sub> | If the Sender FFCH Combined interrupt is implemented as an external interrupt the interrupt output is present on the MHUS.                          |
| $R_{\rm FWHYF}$    | The Sender FFCH Combined interrupt is a combined interrupt and combines the following interrupts of the FFCH:                                       |
|                    | <ul> <li>Channel Transfer Acknowledge interrupt</li> <li>Sender FIFO Low Tidemark interrupt</li> <li>Sender FIFO High Tidemark interrupt</li> </ul> |

Sender FIFO Flush interrupt

### B11.2.12 Receiver FFCH Combined

| I <sub>MCSGZ</sub> | The Receiver FFCH Combined interrupt is provided to reduce the number of interrupt wires required for the Receiver to receive all possible events from a FFCH. |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>XBCKQ</sub> | There is a Receiver FFCH Combined interrupt per each FFCH implemented in the MHU.                                                                              |
| R <sub>tdwyh</sub> | It is IMPLEMENTATION DEFINED whether the Receiver FFCH Combined interrupt is implemented as an internal or external interrupt.                                 |
| R <sub>bsgyd</sub> | If the Receiver FFCH Combined interrupt is implemented as an external interrupt the interrupt output is present on the MHUS.                                   |
| R <sub>HWCFF</sub> | The Receiver FFCH Combined interrupt is a combined interrupt and combines the following interrupts of the FFCH:                                                |

- Channel Transfer
- Receiver FIFO Low Tidemark interrupt
- Receiver FIFO High Tidemark interrupt
- Receiver FIFO Flush interrupt

#### B11.2.13 Postbox Combined

| I <sub>bdfsr</sub> | The Postbox Combined interrupt is provided to reduce the number of interrupt wires required to receive all events from a Postbox.                                          |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>kqqjr</sub> | There is one Postbox Combined interrupt per Postbox implemented in the MHU.                                                                                                |
| R <sub>QMSWR</sub> | The Postbox Combined interrupt is an external interrupt and has the output on the MHUS.                                                                                    |
| R <sub>tfrcy</sub> | The Postbox Combined interrupt is a combined enabled interrupt.                                                                                                            |
| R <sub>MDSFB</sub> | The Postbox Combined interrupt combines the following interrupts:                                                                                                          |
|                    | <ul><li>Channel Transfer Acknowledge interrupt of each DBCH implemented in the MHU.</li><li>Sender FFCH Combined interrupt for each FFCH implemented in the MHU.</li></ul> |
| R <sub>BWFWH</sub> | The Postbox Combined interrupt has the following register fields which are the interrupt enables:                                                                          |
|                    | <ul> <li>PDBCW<n>_CTRL.PBX_COMB_EN</n></li> <li>PFFCW<n>_CTRL.PBX_COMB_EN</n></li> </ul>                                                                                   |
| R <sub>DJMZN</sub> | The Postbox Combined interrupt has the following register fields which are the interrupt status:                                                                           |
|                    | • PBX_DBCH_INT_ST <n>.DBCH_INT_ST<m></m></n>                                                                                                                               |

• PBX\_FFCH\_INT\_ST<n>.FFCH\_INT\_ST<m>

- R<sub>PVJLY</sub> PBX\_DBCH\_INT\_ST<n>.DBCH\_INT\_ST<m> shows whether the Channel Transfer Acknowledge interrupt for that DBCH is asserted, where:
  - $<n> = floor(DBCH_num/32)$
  - $<m> = DBCH_num 32*n$
- R<sub>CVQBN</sub> PBX\_FFCH\_INT\_ST<n>.FFCH\_INT\_ST<m> shows whether the Sender FFCH Combined interrupt for that FFCH is asserted, where:
  - $<n> = floor(FFCH_num/32)$
  - $<m> = FFCH_num 32*n$

#### B11.2.14 Mailbox Combined

| I <sub>NGCJF</sub> | The Mailbox Combined interrupt is provided to reduce the number of interrupt wires required to receive all events from a Mailbox.                                                                                                                                                                  |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>byghd</sub> | There is one Mailbox Combined interrupt per Mailbox implemented in the MHU.                                                                                                                                                                                                                        |
| R <sub>ftzcx</sub> | The Mailbox Combined interrupt is an external interrupt and has the output on the MHUR.                                                                                                                                                                                                            |
| R <sub>PXZQK</sub> | The Mailbox Combined interrupt is a combined enabled interrupt.                                                                                                                                                                                                                                    |
| R <sub>JRWCQ</sub> | The Mailbox Combined interrupt combines the following interrupts:                                                                                                                                                                                                                                  |
|                    | <ul> <li>Channel Transfer interrupt for each DBCH implemented in the MHU.</li> <li>Receiver FFCH Combined interrupt for each FFCH implemented in the MHU.</li> <li>Fast Channel Group Transfer interrupts, if they are implemented, for each Fast Channel Group implemented in the MHU.</li> </ul> |
| R <sub>spgdv</sub> | The Mailbox Combined interrupt has the following register fields which are the interrupt enables:                                                                                                                                                                                                  |
|                    | <ul> <li>MDBCW<n>_CTRL.MBX_COMB_EN.</n></li> <li>MFFCW<n>_CTRL.MBX_COMB_EN.</n></li> <li>MBX_FCH_INT_EN.MBX_COMB_EN<m>, if Fast Channel Group Transfer interrupts are implemented.</m></li> </ul>                                                                                                  |
| R <sub>JKNVD</sub> | The Mailbox Combined interrupt has the following register fields which are the interrupt status:                                                                                                                                                                                                   |
|                    | <ul> <li>MBX_DBCH_INT_ST<n>.DBCH_INT_ST<m>.</m></n></li> <li>MBX_FFCH_INT_ST<n>.FFCH_INT_ST<m>.</m></n></li> <li>MBX_FCG_INT_ST.FCH_GRP<m>, if Fast Channel Group Transfer interrupts are implemented.</m></li> </ul>                                                                              |
| $R_{DQPLS}$        | MBX_DBCH_INT_ST <n>.DBCH_INT_ST<m> shows whether the Receiver Channel Transfer interrupt for that DBCH is asserted, where:</m></n>                                                                                                                                                                 |
|                    | <pre>• <n> = floor(DBCH_num/32)<br/>• <m> = DBCH_num - 32*n</m></n></pre>                                                                                                                                                                                                                          |
| R <sub>XMQDD</sub> | MBX_FFCH_INT_ST <n>.FFCH_INT_ST<m> shows whether the Receiver FFCH Combined interrupt for that FFCH is asserted, where:</m></n>                                                                                                                                                                    |
|                    | <pre>• <n> = floor(FFCH_num/32)<br/>• <m> = FFCH_num - 32*n</m></n></pre>                                                                                                                                                                                                                          |
| $R_{PTPFH}$        | MBX_FCG_INT_ST.FCH_GRP <m> shows whether the Fast Channel Group Transfer interrupt for that FCG is asserted, where <m> is the FCG number.</m></m>                                                                                                                                                  |

Part C Programmers Model

### Chapter C1 Programmers Model Overview

### C1.1 Register Access

I<sub>RBDNK</sub> This section covers the requirements for accesses to registers of the MHU.

#### C1.1.1 Generic Rules

 RVMLNR
 An implementation of the MHU support aligned accesses to all registers.

 SHNDQC
 To ensure the order of and visibility accesses to the MHU, software must only use one of the following memory types to access the registers of the MHU:

 Device non-gathering, non-reordering, non-early write-response (DEV-nGnRnE).
 Device non-gathering, non-reordering, early write-response (DEV-nGnRnE).

 For a definition of memory access types refer to [2].

 R

 An implementation of the MHU is required to support 32-bit access to all registers except for the following:

 PFFCW
 PAY
 PFFCW
 PAY
 MFFCW
 MFFCW
 PAY
 MFFCW
 PAY
 MFFCW
 PAY
 MFFCW
 PAY
 MFFCW
 PAY
 MFFCW
 PAY
 MFFCW
 PAY

R<sub>FBFXY</sub> It is IMPLEMENTATION DEFINED whether accesses of other sizes are supported by an implementation to any registers except the following:

- PFFCW<n>\_PAY
- PFCW<n>\_PAY
- MFFCW<n>\_PAY
- MFFCW<n>\_FLG
- MFCW<n>\_PAY

R<sub>ssgqs</sub>

An access is considered an unsupported access if any of the following apply:

- The access is of a size not supported by the MHU implementation, for the register being accessed.
- The access is not aligned to the size of the access and the MHU implementation does not support unaligned accesses.

For more information on unsupported accesses refer to C1.1.4 Unsupported Accesses.

R<sub>TBWRZ</sub> It is not required for the MHUS and MHUR to have support for the same access sizes and alignment.

#### C1.1.2 FCH Payload Accesses

I<sub>SMVKS</sub> This section covers the rules specific for accesses to the PFCW<n>\_PAY and MFCW<n>\_PAY registers.

- R<sub>ZTSGC</sub> When FCE is implemented with a Fast Channel word-size of 32-bits, the MHU must support 32-bit accesses to the PFCW<n>\_PAY and MFCW<n>\_PAY registers.
- R<sub>HXVTN</sub> When FCE is implemented with a Fast Channel word-size of 64-bits, the MHU must support 64-bit accesses to the PFCW<n>\_PAY and MFCW<n>\_PAY registers.
- R<sub>VHMXF</sub> It is IMPLEMENTATION DEFINED whether other size accesses are supported to the PFCW<n>\_PAY and MFCW<n>\_PAY register.
- R<sub>MKVMT</sub> An access of an unsupported size to the PFCW<n>\_PAY and MFCW<n>\_PAY registers is considered an illegal access. For more information on illegal accesses refer to C1.1.5 *Illegal Accesses*.
- S<sub>PSJCJ</sub> Arm recommends that software access the PFCW<n>\_PAY and MFCW<n>\_PAY registers at the Fast Channel word-size so as to atomically update all bytes of the FCH.

#### C1.1.3 FFCH Payload and Flag Accesses

- $I_{ZBZLM}$  This section covers the rules specific for accesses to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers.
- R<sub>CDCVS</sub> When FE is implemented the MHU can support the following access sizes to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers:
  - 8-bit
  - 16-bit
  - 32-bit
  - 64-bit
- R<sub>PMJHB</sub> An implementation of the MHU which implements FE must support either 32-bit or 64-bit accesses to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers. Support for other sizes is IMPLEMENTA-TION DEFINED.
- $\mathbb{R}_{XVQKL}$  It is allowed for an implementation to support different accesses sizes between the PFFCW<n>\_PAY and MFFCW<n>\_PAY registers and the PFFCW<n>\_PAY and the MFFCW<n>\_FLG registers.
- R<sub>YCHPT</sub> The supported accesses sizes to the MFFCW<n>\_PAY and MFFCW<n>\_FLG registers must be the same.
- R<sub>PYSBT</sub> It is IMPLEMENTATION DEFINED whether an access of an unsupported size to the PFFCW<n>\_PAY register is:
  - Considered an unsupported access.
  - Truncated to a smaller supported size.

• Zero extended to a larger supported size.

When the access is truncated or zero extended to a supported size the MHU uses the new size as the requested size when calculating if it has space to push data onto the FIFO. This includes any update to the PFFCW<n>\_ST.PPE field.

R<sub>GPXQC</sub> It is IMPLEMENTATION DEFINED whether an access of an unsupported size to the MFFCW<n>\_PAY or MFFCW<n>\_FLG register is:

- Considered an unsupported access.
- Truncated to a smaller supported size.
- Zero extended to a large supported size.

When the access is truncated or zero extended to a supported size, the MHU uses the new size when for one or more of the following operations:

- Calculating the number of bytes to read from the FIFO.
- Calculating the number of bytes to pop from the FIFO.

For more information on illegal accesses refer to C1.1.5 Illegal Accesses.

- S<sub>TJXXR</sub> Arm recommends that both the Sender and Receiver only uses accesses with a supported size to access the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers, otherwise it can lead to corruption of or lost of Transfer data.
- R<sub>MCSPF</sub> When 8-bit accesses are supported to the PFFCW<n>\_PAY register the PBX\_FFCH\_CFG0.P8BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>ZLCQF</sub> When 16-bit accesses are supported to the PFFCW<n>\_PAY register the PBX\_FFCH\_CFG0.P16BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>MQYCM</sub> When 32-bit accesses are supported to the PFFCW<n>\_PAY register the PBX\_FFCH\_CFG0.P32BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>WTXTG</sub> When 64-bit accesses are supported to the PFFCW<n>\_PAY register the PBX\_FFCH\_CFG0.P64BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>JJCJC</sub> When 8-bit accesses are supported to the MFFCW<n>\_PAY and MFFCW<n>\_FLG registers the MBX\_FFCH\_CFG0.M8BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>DZGTF</sub> When 16-bit accesses are supported to the MFFCW<n>\_PAY and MFFCW<n>\_FLG registers the MBX\_FFCH\_CFG0.M16BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>HCKZC</sub> When 32-bit accesses are supported to the MFFCW<n>\_PAY and MFFCW<n>\_FLG registers the MBX\_FFCH\_CFG0.M32BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- R<sub>YLNVH</sub> When 64-bit accesses are supported to the MFFCW<n>\_PAY and MFFCW<n>\_FLG registers the MBX\_FFCH\_CFG0.M64BA\_SPT field is set to 0b1 otherwise it is set to 0b0.
- S<sub>SWNSD</sub> Sender or Receiver can use the values of the PBX\_FFCH\_CFG0.P{8/16/32/64}BA\_SPT and MBX\_FFCH\_CFG0.M{8/16/32/64}BA\_SPT fields to determine the supported accesses sizes to the PFFCW<n>\_PAY, MFFCW<n>\_PAY and MFFCW<n>\_FLG registers.
- IWhen TZE or RME are implemented, there are equivalent fields in the SSC\_FFCH\_CFG0 and RSC\_FFCH\_CFG0registers. These values are intended to be used by the software agent which owns the SSC and RSC block.

#### C1.1.4 Unsupported Accesses

- I\_PPCMR Access to the MHUS or MHUR can be considered to be an unsupported access, due to having one or more of the following:
  - A size which is not supported by the register being accessed.

## Chapter C1. Programmers Model Overview C1.1. Register Access

- An alignment which is not aligned to the size of the access, if the implementation of the MHU does not support unaligned accesses.
- R<sub>RKZZH</sub> It is CONSTRAINED UNPREDICTABLE whether an implementation of the MHU treats an unsupported access as one of the following:
  - RAZ/WI, and has no effect on any internal state of the MHU.
  - Modifies the access to have an alignment and size, which is supported by the implementation of the MHU.

#### C1.1.5 Illegal Accesses

- IFYSWJAccesses to the MHUS or MHU can be considered to be an illegal access, due to the access having the incorrect<br/>security to access the register. Refer to Chapter B9 *TrustZone and Realm Management Extension* for more<br/>information on the security requirements for accesses.
- R<sub>RYGLR</sub> An illegal access is treated as RAZ/WI and has no effect on any internal state of the MHU. For example, a write access to the PFFCW<n>\_PAY register which is consider illegal does not:
  - Push any data onto the FIFO.
  - Change the value of the PFFCW<n>\_ST.PPE field.
  - Generate any events.

### C1.2 Register Access Response

| R <sub>rfjvn</sub> | All read accesses must provide their response from the location storing the data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>YHYZB</sub> | A read (R1) to the MFFCW <n>_PAY register when the MFFCW<n>_CTRL.RA_EN field is set to Ob1, cause data to be popped from the FIFO and one or more of the following to occur:</n></n>                                                                                                                                                                                                                                                                                                                                                                    |
|                    | <ul> <li>The PFFCW<n>_ST.FFS, PFFCW<n>_PAY.FFS, MFFCW<n>_ST.FFL and MFFCW<n>_FLG.FFL fields are updated.</n></n></n></n></li> <li>The PFFCW<n>_ACK_CNT.ACK_CNT field is incremented by the number of bytes popped from the FIFO which had the both the EOT and ACK flags set.</n></li> <li>The Transfer Acknowledge event is generated, if the conditions are correct.</li> <li>A Sender Low Tidemark event is generated, if the conditions are correct.</li> <li>A Receiver Low Tidemark event is generated, if the conditions are correct.</li> </ul> |
|                    | It is not required for the updates to the PFFCW <n>_ST.FFS, PFFCW<n>_PAY.FLS, MFFCW<n>_ST.FFL, MFFCW<n>_FLG.FFL and PFFCW<n>_ACK_CNT.ACK_CNT fields to be made before the data is returned in response to the read(R1). However the following is required:</n></n></n></n></n>                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>The Transfer Acknowledge and Sender Low Tidemark events are generated only if a read (R2) of the PFFCW<n>_ACK_CNT, PFFCW<n>_ST.FFS or PFFCW<n>_PAY.FFS fields would observe the updated value due to the first read (R1).</n></n></n></li> <li>The Receiver Low Tidemark event is generated only if a read (R2) of MFFCW<n>_ST.FFL or MFFCW<n>_FLG.FFL fields would observe the updated value due to the first read (R1).</n></n></li> </ul>                                                                                                   |
| R <sub>mmxtn</sub> | A read (R1) to the MFCW <n>_PAY register causes the Channel Transfer interrupt for the FCH to be updated.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| R <sub>jkgjw</sub> | A read (R1) to the PFFCW <n>_ACK_CNT register caused the value of the register to be updated as defined in <math>R_{MDTHX}</math>.</n>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| R <sub>tzybz</sub> | The MHUS or MHUR must only provide a write response to a write after all effect, including side effects, except for writes to the following registers:                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | <ul> <li>PDBCW<n>_SET</n></li> <li>PFFCW<n>_PAY</n></li> <li>PFCW<n>_PAY</n></li> <li>MDBCW<n>_CLR</n></li> <li>MFFCW<n>_FIFO_POP</n></li> <li>MFCW<n>_PAY</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                               |
| R <sub>jfxry</sub> | It is IMPLEMENTATION DEFINED whether write accesses to the following registers provide an early write response:                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                    | <ul> <li>PDBCW<n>_SET</n></li> <li>PFFCW<n>_PAY</n></li> <li>PFCW<n>_PAY</n></li> <li>MDBCW<n>_CLR</n></li> <li>MFFCW<n>_FIFO_POP</n></li> <li>MFCW<n>_PAY</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                               |
| I <sub>zyhsq</sub> | An early write response is defined as when a response to a write is generated before all effects of the write, for example setting values in another register, have occurred.                                                                                                                                                                                                                                                                                                                                                                           |
| R <sub>thjmq</sub> | When an implementation of the MHU does not implement early write response, for a write W1, to the PDBCW <n>_SET register the following must all be completed before the write response is generated:</n>                                                                                                                                                                                                                                                                                                                                                |
|                    | • PDBCW <n>_ST register is updated to reflect its new value.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

- MDBCW<n>\_ST and MDBCW<n>\_ST\_MSK register is updated to reflect its new value.
- Channel Transfer event is generated only when a read by the Receiver would observe the updated value of the MDBCW<n>\_ST and MDBCW<n>\_ST\_MSK.

| R <sub>PYKHD</sub> | When an implementation of the MHU implements early write response, for a write W1, to the PDBCW <n>_SET register the following must be true:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>Any subsequent read by the Sender of the PDBCW<n>_ST register must observe the updates caused by W1.</n></li> <li>Any subsequent write by the Sender to the PDBCW<n>_SET register must occur after W1.</n></li> <li>A Channel Transfer event is generated only when a read by the Receiver of the MDBCW<n>_ST or MDBCW<n>_ST_MSK register would observe the updates caused by W1.</n></n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| R <sub>PWFZF</sub> | When an implementation of the MHU does not implement early write response, for a write W1, to the PFFCW <n>_PAY register the following must all be completed before the write response is generated:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ul> <li>The values of the PFFCW<n>_PAY or PFFCW<n>_ST register is updated to reflect the changes to the PPE and FFS fields caused by W1.</n></n></li> <li>The values of the PFFCW<n>_FLG register is updated, if the PFFCW<n>_CTRL.TDM field is set to 0b01 or 0b10.</n></n></li> <li>FIFO High Tide event is generated, if required.</li> <li>Channel Transfer event is generated only when a read by the Receiver of the MFFCW<n>_PAY register, will be able to observe the value of the bytes pushed onto the FIFO by W1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                             |
| R <sub>XLYSQ</sub> | When an implementation of the MHU implements early write response, for a write W1, to the PFFCW <n>_PAY register the following all must be true:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ul> <li>Any subsequent read by the Sender of the PFFCW<n>_PAY or PFFCW<n>_ST register must observe the changes to the PPE and FFS fields caused by W1.</n></n></li> <li>Any subsequent write by the Sender of the PFFCW<n>_PAY register must occur after W1.</n></li> <li>When the write data is pushed onto the FIFO the value of the SOT, EOT and ACK flags is the value of the fields in the PFFCW<n>_FLG register when the write response was generated.</n></li> <li>If PFFCW<n>_CTRL.TDM is set to 0b01 or 0b10 the value of the SOT and EOT fields in the PFFCW<n>_FLG register are updated when the write response is generated.</n></n></li> <li>A Channel Transfer event is only generated when a read by the Receiver of the MFFCW<n>_PAY register, will be able to observe the value of the bytes pushed onto the FIFO by W1.</n></li> <li>Any FIFO High Tide event is generated to the Sender when the write response is given.</li> </ul> |
| R <sub>TVNND</sub> | When an implementation of the MHU does not implement early write response, for a write W1, to the PFCW <n>_PAY register the following must all be completed before the write response is generated:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | <ul> <li>PFCW<n>_PAY register is updated to reflect the value set by W1.</n></li> <li>MFCW<n>_PAY register is updated to reflect the value set by W1.</n></li> <li>A Channel Transfer event is generated only when a read by the Receiver of the MFCW<n>_PAY register would observe the updates caused by W1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| $R_{WZQFJ}$        | When an implementation of the MHU implements early write response, for a write W1, to the PFCW <n>_PAY register the following must be true:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>Any subsequent read by the Sender of the PFCW<n>_PAY register must observe the updates caused by W1.</n></li> <li>Any subsequent write by the Sender of the PFCW<n>_PAY register must occur after W1.</n></li> <li>A Channel Transfer event is only generated when a read by the Receiver of the MFCW<n>_PAY register would observe the updates caused by W1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| R <sub>vgnnj</sub> | When an implementation of the MHU does not implement early write response, for a write W1, to the MDBCW <n>_CLR register the following must all be completed before the write response is generated:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | <ul> <li>MDBCW<n>_ST and MDBCW<n>_ST_MSK registers are updated to reflect the updated value caused by W1.</n></n></li> <li>PDBCW<n>_ST register are updated to reflect the updated value caused by W1.</n></li> <li>Channel Transfer Acknowledge event is only generated when a read by the Sender of the PDBCW<n>_ST register would observe the updates caused by W1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| $R_{XGGMJ}$        | When an implementation of the MHU implements early write response, for a write W1, to the MDBCW <n>_CLR register the following must be true:</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
- Any subsequent read by the Receiver of the MDBCW<n>\_ST or MDBCW<n>\_ST\_MSK registers must observe the updates caused by W1.
- Any subsequent write by the Receiver to the MDBCW<n>\_CLR register must occur after W1.
- Any Channel Transfer Acknowledge event is only generated when a read by the Sender of the PDBCW<n>\_ST register would observe the updates caused by W1.
- IZRXJG
   A write to the MDBCW<n>\_CLR register can causes the de-assertion of the Channel Transfer interrupt for a DBCH, if the write results in all fields in the MDBCW<n>\_ST\_MSK registers being 0b0. Arm recommends that the Channel Transfer interrupt is de-asserted either at or before the point where a read of MDBCW<n>\_ST\_MSK register would return all fields as 0b0.
- R<sub>CKBFN</sub> When an implementation of the MHU does not implement early write response, for a write W1, to the MFFCW<n>\_FIFO\_POP register, and the MFFCW<n>\_CTRL.RA\_EN is 0b0, the following must all be completed before the write response is generated:
  - The number of bytes requested by W1 are popped from the FIFO.
  - MFFCW<n>\_ST.FFL and MFFCW<n>\_FLG.FFL fields are updated to reflect the number of bytes popped from the FIFO caused by W1.
  - PFFCW<n>\_ACK\_CNT.ACK\_CNT, PFFCW<n>\_ACK\_CNT.ACK\_CNT\_OVRFLW are updated, as required by the popping of bytes requested by W1.
  - PFFCW<n>\_ST.FFS and PFFCW<n>\_PAY.FFS fields are updated to reflect the number of bytes popped from the FIFO caused by W1.
  - A Channel Transfer Acknowledge or Sender FIFO Low Tide events are generated only when a read of the PFFCW<n>\_ACK\_CNT.ACK\_CNT, PFFCW<n>\_ACK\_CNT.ACK\_CNT\_OVRFLW, PFFCW<n>\_ST.FFS or PFFCW<n>\_PAY.FFS fields would observe the updated values caused by W1.
- R<sub>HPVGP</sub> When an implementation of the MHU implements early write response, for a write W1, to the MFFCW<n>\_FIFO\_POP register, when MFFCW<n>\_CTRL.RA\_EN is 0b0, the following must be true:
  - Any subsequent read (R1) by the Receiver of the MFFCW<n>\_PAY register will return the number of bytes equal to the size of the read, starting from the first byte after the bytes to be popped from the FIFO by write W1.

For example, if W1 has a value of X and R1 has a size Y the bytes returned by the R1 is:

- FIFO byte offset start = X.
- FIFO byte offset end = X + Y 1.

Bytes in the FIFO are numbered from 0, with 0 being the head of the FIFO

- Any subsequent read (R1) by the Receiver of the MFFCW<n>\_ST.FFL or MFFCW<n>\_FLG.FFL fields returns a fill level observing the bytes popped by W1.
- Any Channel Transfer Acknowledge or Sender FIFO Low Tide events are only generated when a read by the Sender of the PFFCW<n>\_ACK\_CNT.ACK\_CNT, PFFCW<n>\_ACK\_CNT.ACK\_CNT\_OVRFLW, PFFCW<n>\_ST.FFS or PFFCW<n>\_PAY.FFS fields would observe the bytes popped by W1.
- ILPDNMWhen MFFCW<n>\_CTRL.RA\_EN is 0b1, writes to the MFFCW<n>\_FIFO\_POP register have no effect and can<br/>complete instantly. This is not considered an early write response.
- R<sub>ZNRTW</sub> When an implementation of the MHU does not implement early write response, for a write W1, to the MFCW<n>\_PAY register the following must all be completed before providing the write response:
  - MFCW<n>\_PAY register must be updated to reflect the changes caused by W1.
  - PFCW<n>\_PAY register must be updated to reflect the changes caused by W1.
- R<sub>JGBZR</sub> When an implementation of the MHU implement early write response, for a write W1, to the MFCW<n>\_PAY register the following must be true:
  - Any subsequent read by the Receiver of the MFCW<n>\_PAY register must observe the updates caused by W1.
  - Any subsequent write by the Receiver of the MFCW<n>\_PAY register must occur after W1.

Chapter C1. Programmers Model Overview C1.3. Reset Domains

# C1.3 Reset Domains

| I <sub>BBPSM</sub> | This section contains information about the reset for fields, for fields which have an architected reset value.                                                                                                                                                                                                                                                                                                  |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $R_{WLPFV}$        | The MHU has two reset domains:                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | <ul><li>MHUS</li><li>MHUR</li></ul>                                                                                                                                                                                                                                                                                                                                                                              |
| R <sub>CYRLT</sub> | Fields which have a reset domain of MHUS are set to its architected reset value, if it has one, when the MHUS enters a Non-operational state.                                                                                                                                                                                                                                                                    |
| R <sub>rzhky</sub> | Fields which have a reset domain of MHUR are set to its architected reset value, if it has one, when the MHUR enters a Non-operational state.                                                                                                                                                                                                                                                                    |
| R <sub>bbjjg</sub> | Fields which have no reset domain either:                                                                                                                                                                                                                                                                                                                                                                        |
|                    | <ul> <li>Do not have an architected reset value, for example the PFCW<n>_PAY and MFCW<n>_PAY registers.</n></n></li> <li>Have a constant value, for example the PBX_FEAT_SPT0 or MBX_FEAT_SPT0 registers.</li> <li>Have a value which is calculated based on other fields which have a reset value, for example reads of the PFFCW<n>_PAY register return values based on the status of the FIFO.</n></li> </ul> |

Chapter C1. Programmers Model Overview C1.4. Storage Resources

# C1.4 Storage Resources

I<sub>KPGMS</sub> The MHU architecture allows for flexibility in the type and location of storage elements used in an implementation of the MHU. The MHU architecture also uses aliasing where two or more fields use the same storage resource to store the value.

# C1.4.1 Storage resource location

I<sub>BYDLG</sub> The location of a storage resource only applies for when the MHU implementation is distributed, as for a monolithic implementation the MHUS and MHUR are considered a single entity.

R<sub>TPXFT</sub> A storage resource refers to any logical structure which meets the following requirements:

- Has a method for reading the value of the logical structure.
- Has a method for writing the value of the logical structure based on a write enable.
- Has a method for being set to a known value when the storage element exits a Non-operational state, if the field it is storing the value for has a defined reset value.
- Retains the last value written to it, when it is not being written to and it has not entered a Non-operational state.

**I**<sub>TSWFV</sub> Examples of logical structures which meet these requirements are:

- Flip-flops
- RAM
- R<sub>LBHGN</sub> Storage location for a field which is part of the MHUS reset domain must be in the MHUS.
- R<sub>CVPZP</sub> Storage location for a field which is part of the MHUR reset domain must be in the MHUR.
- I<sub>DKMOB</sub> A field is considered part of a reset domain even if the reset value is UNKNOWN.

# C1.4.2 Field Aliasing

 $I_{KMHJD}$  Some fields in the MHU architecture are mapped onto the same storage location.

R<sub>LGLBK</sub> The field which share resources are:

- PDBCW<n>\_ST.FLG<x> and MDBCW<n>\_ST.FLG<x>.
- PFCW<n>\_PAY.PAY and MFCW<n>\_PAY.PAY.
- PFFCW<n>\_PAY.PPE and PFFCW<n>\_ST.PPE.

# C1.4.3 FIFO storage resources

I<sub>ZSNCM</sub> When FE is implemented there is implicit storage elements required to form the FIFO and FHB.

- R<sub>KLDLF</sub> The location of the storage elements which make up the FIFO is IMPLEMENTATION DEFINED but must meet the requirements defined in Chapter B8 *FIFO Extension*
- R<sub>TDFGW</sub> The FHB must be implemented in the MHUR as defined in Chapter B8 *FIFO Extension*.

Chapter C1. Programmers Model Overview C1.5. Register Blocks

# C1.5 Register Blocks

| I <sub>PTVSV</sub> | The registers of the MHU and grouped in pages and blocks.                                                                                                                                                                                                                                          |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>WGHKQ</sub> | A page is 4KB in size and groups register which are related together.                                                                                                                                                                                                                              |
| R <sub>ffnts</sub> | Any location in a page which is not defined to include registers is Reserved and treated as RAZ/WI.                                                                                                                                                                                                |
| R <sub>hfwkn</sub> | A block is 64KB in size and is formed of a number of pages.                                                                                                                                                                                                                                        |
| $R_{XDLJJ}$        | Any location within a block which is not allocated a page or the page is not implemented due to the configuration of the MHU, is Reserved and treated as RAZ/WI, with the exception of the IMPLEMENTATION DEFINED page within a block.                                                             |
| I <sub>MQWYQ</sub> | For more information on the IMPLEMENTATION DEFINED page refer to C1.7 <i>IMPLEMENTATION DEFINED registers</i> .                                                                                                                                                                                    |
| I <sub>kpdsx</sub> | Even though it may be possible for individual pages or smaller to be allocated to different software agents it is not<br>an expected use cases. The MHU has been designed so that an agent has access to all pages within a block and<br>isolation between agents is performed at the block level. |
| R <sub>zmtfx</sub> | The offset of registers within pages, and pages within blocks is fixed by the architecture.                                                                                                                                                                                                        |
| R <sub>JWYVT</sub> | The offset of blocks within an implementation of the MHU is IMPLEMENTATION DEFINED.                                                                                                                                                                                                                |
| I <sub>DKZDC</sub> | Arm recommends that the order of blocks within the MHUS or MHUR for an MHUv3.0 compliant MHU is as follows:                                                                                                                                                                                        |
|                    | <ol> <li>Sender/Receiver Security Control block, if TZE or RME are implemented.</li> <li>Postbox/Mailbox block.</li> </ol>                                                                                                                                                                         |

3. Sender/Receiver RAS block, if RASE is implemented.

Table C1.1 shows the layout of blocks within the MHUS or MHUR following these recommendations:

# Table C1.1: Example order of blocks for an MHUv3.0 implementation, with support for TZE and RME and RASE

| Block Num | Block                            |
|-----------|----------------------------------|
| 0         | Sender/Receiver Security Control |
| 1         | Postbox/Mailbox                  |
| 2         | Sender/Receiver RAS              |

# C1.6 Software Discovery

| I <sub>MGFLR</sub> | Each MHU implementation can implement a different selection and configuration of extensions of the MHU architecture. Software will need to identify the extensions and configurations of those extensions which the MHU implementation implements. To support this the MHU includes registers to enable software to discover the configuration of the MHU. These registers are referred to as the Configuration and Feature registers (CFR). |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $\rm S_{JBNMC}$    | Software can use the CFRs or it can use an IMPLEMENTATION DEFINED method to discover the configuration of the MHU implementation.                                                                                                                                                                                                                                                                                                            |
| I <sub>CLCVW</sub> | An example IMPLEMENTATION DEFINED method would be software data structures or APIs, for example Device Tree or ACPI.                                                                                                                                                                                                                                                                                                                         |
| R <sub>hpbzw</sub> | There is a set of CFRs for each block in the MHU located in the first page. These identification register provide the following information:                                                                                                                                                                                                                                                                                                 |
|                    | <ul><li>Type of block being accessed.</li><li>Features supported by the MHU.</li><li>Configuration of the block.</li></ul>                                                                                                                                                                                                                                                                                                                   |
| R <sub>tsckf</sub> | The CFR are located within the first 64 32-bits words within the block.                                                                                                                                                                                                                                                                                                                                                                      |
| R <sub>rrqyj</sub> | At offset $0 \times 0000$ of a block, with the exception of the Sender and Receiver RAS blocks, is the block identifier <x>_BLK_ID, where <x> is one of the following block prefixes: PBX, MBX, SSC, RSC.</x></x>                                                                                                                                                                                                                            |
| R <sub>ytlnx</sub> | The block identifier has a single 4-bit field called, BLK_ID which has one of the following values:                                                                                                                                                                                                                                                                                                                                          |
|                    | <ul> <li>0x0 - Postbox.</li> <li>0x1 - Mailbox.</li> <li>0x2 - Sender Security Control.</li> <li>0x3 - Receiver Security Control.</li> </ul>                                                                                                                                                                                                                                                                                                 |
| $S_{\rm JVXKP}$    | Software can use the block identifier to know the type of the block, except for the Sender and Receiver RAS block, it is accessing.                                                                                                                                                                                                                                                                                                          |
| R <sub>LYSFN</sub> | The Sender and Receiver RAS blocks do not include a <x>_BLK_ID register.</x>                                                                                                                                                                                                                                                                                                                                                                 |
| $S_{RVDLZ}$        | Software must use an IMPLEMENTATION DEFINED method to discover whether a block is the Sender or Receiver RAS block.                                                                                                                                                                                                                                                                                                                          |
| X <sub>bjpnk</sub> | The reason for the Sender and Receiver RAS blocks not including a <x>_BLK_ID register is that the expected user of the RAS blocks is different to the other blocks. RAS registers have their own standard, which have their own method of identification.</x>                                                                                                                                                                                |
| R <sub>fjmqr</sub> | The CFRs include registers which provide information on the extensions which are implemented by the implementation of the MHU. These are referred to as Feature registers and have the following format <x>_FEAT_SPT<n>, where:</n></x>                                                                                                                                                                                                      |
|                    | <ul> <li><x> is the block prefixes: PBX, MBX, SSC, RSC.</x></li> <li><n> is the register number and is in the range 0-1.</n></li> </ul>                                                                                                                                                                                                                                                                                                      |
|                    | An example of a Feature registers is PBX_FEAT_SPT0 and PBX_FEAT_SPT1 which provides information on the features implemented by the Postbox.                                                                                                                                                                                                                                                                                                  |
| $R_{\rm XLGHZ}$    | The CFRs includes registers which provide information on the configuration of the extensions, block or MHU. These are referred to as Configuration registers and have following format $__CFG$ , where:                                                                                                                                                                                                                                      |
|                    | <ul> <li><x> is the block prefixes: PBX, MBX, SSC, RSC.</x></li> <li><y> is the identifier for the name of the feature the register provides configuration information on, for example DBCH or FFCH for Doorbell Extension and FIFO Channel Extension configuration information respectively.</y></li> <li><z> is the register number starting from 0.</z></li> </ul>                                                                        |

# Chapter C1. Programmers Model Overview C1.6. Software Discovery

An example of a Configuration registers is MBX\_DBCH\_CFG0 and MBX\_FFCH\_CFG0 which provide configuration information about the DBCHs and FFCHs implemented in the Mailbox.

 $R_{NMDWK}$  The CFRs are read-only, when accessed from the block they apply to.

 $R_{DXXSQ}$  The values of the CFRs are constant.

# C1.7 IMPLEMENTATION DEFINED registers

R<sub>XCBXX</sub> The MHU provides the following regions for IMPLEMENTATION DEFINED registers:

- Offset 0x0FC8 of every block for the Implementation Identification Register.
- Offsets 0x0FD0-0x0FFF of every block for IMPLEMENTATION DEFINED Identification Registers.
- Offsets 0xF000-0xFFFF of every block for an IMPLEMENTATION DEFINED page.

# C1.7.1 Implementation Identification Registers

- I<sub>GWYRC</sub> The MHU provides the Implementation Identification Register (IIDR) which provides the product ID, revision and variant and implementor identifier.
- IDZYNDThe name of the IIDR register is prefixed by the block ID. For example, PBX\_IIDR is the IIDR register in the<br/>Postbox.

R<sub>JVTWG</sub> The IIDR is a read-only register.

- $R_{KLMQZ}$  An implementation must always set the fields of the IIDR registers to values which will identify the implementor, part and version of the implementation of the MHU.
- $I_{NDSPJ}$  The variant and revision fields of the IIDR are considered to be major and minor revisions of the implementation of the MHU respectively.

# C1.7.2 IMPLEMENTATION DEFINED Identification Registers

- R<sub>LLBMK</sub> The MHU defines a region of 12 registers for IMPLEMENTATION DEFINED identification registers located at 0xFD0-0xFFF in the first 4KB of each block.
- R<sub>ZPLLS</sub> The IMPLEMENTATION DEFINED identification registers are always read-only.
- R<sub>ZWGRB</sub> The presence, names of the registers and fields and values of the IMPLEMENTATION DEFINED identification registers is IMPLEMENTATION DEFINED. If an offset within the IMPLEMENTATION DEFINED identification registers region is not implemented the offsets is Reserved and treated as RES0.
- $I_{TRNJQ}$  Arm recommends that the format of the Identification Registers follows the format defined in [3] for Component and Peripheral Identification Registers, with the Class field set to 0xF.

# C1.7.3 IMPLEMENTATION DEFINED Page

I<sub>BMKWS</sub> The IMPLEMENTATION DEFINED page provides a locations for the implementor of the MHU to include additional registers to extend the functionality of the MHU to meet the use case of the MHU. An example of where additional registers may be required is to add registers related to functional safety.

 $I_{PVZWR}$  The names of the IMPLEMENTATION DEFINED pages are as follows:

- Postbox IMPLEMENTATION DEFINED page, PBX\_IMPL\_DEF\_page, in the Postbox block.
- Mailbox IMPLEMENTATION DEFINED page, MBX\_IMPL\_DEF\_page, in the Mailbox block.
- Sender Security Control IMPLEMENTATION DEFINED page, SSC\_IMPL\_DEF\_page, in the Sender Security Control block.
- Receiver Security Control IMPLEMENTATION DEFINED page, RSC\_IMPL\_DEF\_page, in the Receiver Security Control block.

#### R<sub>TKRFW</sub> Each block of the MHU has a single IMPLEMENTATION DEFINED page located at offset 0xF000 in the block

# Chapter C1. Programmers Model Overview C1.7. IMPLEMENTATION DEFINED registers

| R <sub>RXYYB</sub> | The registers of the IMPLEMENTATION DEFINED page are IMPLEMENTATION DEFINED. This includes:                                                                                                                                                                                                                                                                                                                                        |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>Whether a register is present or not.</li> <li>The name of the register.</li> <li>The access permission of the registers, so long as they are not more permissive than the architecture defines for the IMPLEMENTATION DEFINED register.</li> <li>The names, behavior and reset value of any fields.</li> <li>The access permissions of any fields, so long as they are not more permissive than the register.</li> </ul> |
| R <sub>SDQNR</sub> | When TZE or RME are implemented access to the IMPLEMENTATION DEFINED page are only allowed if the security of the access matches the requirement of the block as follows:                                                                                                                                                                                                                                                          |
|                    | <ul> <li>For a PBX_IMPL_DEF_page or MBX_IMPL_DEF_page the security of the access must be of a security allowed to access the Postbox or Mailbox.</li> <li>For a SSC_IMPL_DEF_page or RSC_IMPL_DEF_page the security of the access must be:</li> </ul>                                                                                                                                                                              |
|                    | <ul> <li>Secure when TZE is implemented and RME is not implemented or RME is implemented and the sampled value of the LEGACY_TZ_EN input is 0b1.</li> <li>Root when RME is implemented and the sampled value of the LEGACY_TZ_EN input is 0b0.</li> </ul>                                                                                                                                                                          |
| $R_{WFCBR}$        | It is allowed for registers in the IMPLEMENTATION DEFINED page to be restricted to accesses from a specific security world, for example only accessible by secure accesses, however the access must first past the register block security check.                                                                                                                                                                                  |
| R <sub>fhfpx</sub> | It is not required that IMPLEMENTATION DEFINED pages of different blocks contain the same registers.                                                                                                                                                                                                                                                                                                                               |
| $R_{\rm BFHGB}$    | The architected functionality of the MHU must not be altered by the reset value of any register in IMPLEMENTATION DEFINED page.                                                                                                                                                                                                                                                                                                    |
| $X_{\rm LBNRD}$    | This allows generic MHU drivers to make use of the MHU implementation without having knowledge of the IMPLEMENTATION DEFINED features.                                                                                                                                                                                                                                                                                             |
| R <sub>SWBPM</sub> | The IMPLEMENTATION DEFINED page follows the same rules as any other page in the MHU and any unused locations are considered to be Reserved and treated as RESO.                                                                                                                                                                                                                                                                    |

Chapter C2 Registers

# C2.1 MHUS, MHU Sender

The MHUS characteristics are:

## Purpose

Contains the blocks which are part of the MHU Sender

The offsets of the blocks, within the MHU Sender are IMPLEMENTATION DEFINED, however, Arm recommends the following offsets:

# When TZE is implemented for the MHUS

0x0\_0000 - SSC

0x1\_0000 - PBX

# When TZE is not implemented for the MHUS

0x0\_0000 - PBX

# Attributes

# When TZE is implemented for the MHUS

The MHUS block is of size 128KB.

# When TZE is not implemented for the MHUS

The MHUS block is of size 64KB.

# **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

# Contents

| Offset | Name | Notes                                                                                                                                              |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| IMPDEF | SSC  | Most permissive access: RW<br>Register condition: When TZE is implemented for the MHUS<br>Accessor condition: When TZE is implemented for the MHUS |
| IMPDEF | PBX  | Most permissive access: RW                                                                                                                         |

# C2.1.1 PBX, Postbox

The PBX characteristics are:

#### Purpose

Contains the individual pages of the Postbox block.

Only accesses with the correct security can access the registers within the Postbox, otherwise the access is treated as an illegal access

The allowed security of an access to a register of the Postbox depends on:

- Whether RME is implemented for the MHUS.
- Whether TZE is implemented for the MHUS.
- Sampled value of MHUS LEGACY\_TZ\_EN input.
- Value of SSC\_CTRL\_page.SSC\_PBX\_SG0.SG\_PBX0 field.

The following table list the allowed security states of an access:

| RME | TZE | Sampled LEGACY_TZ_EN | SSC_PBX_SG0.SG_PBX | Allowed access securities |
|-----|-----|----------------------|--------------------|---------------------------|
| 0   | 0   | NA                   | NA                 | Any                       |
| 0   | 1   | NA                   | 0b0                | Secure                    |
|     |     |                      | 0b1                | Any                       |
| 1   | 1   | 0                    | 0b00               | Root and Secure           |
|     |     |                      | 0b01               | Any                       |
|     |     |                      | 0b10               | Root                      |
|     |     |                      | 0b11               | Root and Realm            |
|     |     | 1                    | 0bx0               | Root and Secure           |
|     |     |                      | 0bx1               | Any                       |

# Configuration

#### Attributes

The PBX block is of size 64KB.

This block is part of the MHUS block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset | Name          | Notes                                                                                                                    |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x0000 | PBX_CTRL_page | Most permissive access: RW                                                                                               |
| 0x1000 | PDBCW_page    | Most permissive access: RW<br>Register condition: When DBE is implemented<br>Accessor condition: When DBE is implemented |

# Chapter C2. Registers C2.1. MHUS, MHU Sender

| Offset Name Notes |                   | Notes                                                                                                                    |
|-------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x2000            | PFFCW_page        | Most permissive access: RW<br>Register condition: When FE is implemented<br>Accessor condition: When FE is implemented   |
| 0x3000            | PFCW_page         | Most permissive access: RW<br>Register condition: When FCE is implemented<br>Accessor condition: When FCE is implemented |
| 0xF000            | PBX_IMPL_DEF_page | Most permissive access: RW                                                                                               |

# C2.1.1.1 PBX\_CTRL\_page, Postbox CTRL page

The PBX\_CTRL\_page characteristics are:

# Purpose

Allows access to the configuration registers of the Postbox.

# Configuration

#### Attributes

The PBX\_CTRL\_page block is of size 4KB.

This block is part of the MHUS.PBX block.

# **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset                      | Name                    | Notes                                                                                                                          |  |  |  |
|-----------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0x000                       | PBX_BLK_ID              | Most permissive access: RO                                                                                                     |  |  |  |
| 0x010                       | PBX_FEAT_SPT0           | Most permissive access: RO                                                                                                     |  |  |  |
| 0x014                       | PBX_FEAT_SPT1           | Most permissive access: RO                                                                                                     |  |  |  |
| 0x020                       | PBX_DBCH_CFG0           | Most permissive access: RO<br>Register condition: When DBE is<br>implemented<br>Accessor condition: When DBE is<br>implemented |  |  |  |
| 0x030                       | PBX_FFCH_CFG0           | Most permissive access: RO<br>Register condition: When FE is<br>implemented<br>Accessor condition: When FE is<br>implemented   |  |  |  |
| 0x040                       | PBX_FCH_CFG0            | Most permissive access: RO<br>Register condition: When FCE is<br>implemented<br>Accessor condition: When FCE is<br>implemented |  |  |  |
| 0x100                       | PBX_CTRL                | Most permissive access: RW                                                                                                     |  |  |  |
| 0x400 + (4 * n)for n in 3:0 | PBX_DBCH_INT_ST <n></n> | Most permissive access: RO<br>Register condition: When DBE is<br>implemented<br>Accessor condition: When DBE is<br>implemented |  |  |  |
| 0x410 + (4 * n)for n in 1:0 | PBX_FFCH_INT_ST <n></n> | Most permissive access: RO<br>Register condition: When FE is<br>implemented<br>Accessor condition: When FE is<br>implemented   |  |  |  |
| 0xFC8                       | PBX_IIDR                | Most permissive access: RO                                                                                                     |  |  |  |

| Offset                       | Name                    | Notes                      |  |  |  |
|------------------------------|-------------------------|----------------------------|--|--|--|
| OxFCC                        | PBX_AIDR                | Most permissive access: RO |  |  |  |
| 0xFD0 + (4 * n)for n in 11:0 | PBX_IMPL_DEF_ID <n></n> | Most permissive access: RO |  |  |  |

# C2.1.1.1.1 PBX\_BLK\_ID, Postbox Block Identifier

The PBX\_BLK\_ID characteristics are:

# Purpose

Identifies the block as a Postbox.

# Attributes

PBX\_BLK\_ID is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_BLK\_ID bit assignments are:

| 31   | 4 | 3 |   |     | 0  | 1 |
|------|---|---|---|-----|----|---|
| RES0 |   | 0 | 0 | 0   | 0  |   |
|      |   |   |   | Lbi | _K | I |

# Bits [31:4]

Reserved, RESO.

# BLK\_ID, bits [3:0]

Block Identifier

Identifies the type of block that resides in this 64KB.

Reads as 0b0000

Identifies the block as the Postbox block.

Access to this field is RO.

# Accessing PBX\_BLK\_ID

Accesses to this register use the following encodings:

# Accessible at offset 0x000 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.2 PBX\_FEAT\_SPT0, Postbox Feature Support 0

The PBX\_FEAT\_SPT0 characteristics are:

#### Purpose

Provides information on the features implemented in the Postbox.

#### Attributes

PBX\_FEAT\_SPT0 is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_FEAT\_SPT0 bit assignments are:

| 31 24 | 23 20    | 19 16   | 15 12   | 11 8    | 7 4    | <sub>1</sub> 3 0 |
|-------|----------|---------|---------|---------|--------|------------------|
| RES0  | RASE_SPT | RME_SPT | TZE_SPT | FCE_SPT | FE_SPT | DBE_SPT          |

# Bits [31:24]

Reserved, RESO.

# RASE\_SPT, bits [23:20]

Reliability, Availability and Serviceability Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RASE_SPT | Meaning                                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000000   | MHU does not implement the RAS extension                                                                                                                          |
| 060010   | MHU implements the RAS extension but does<br>not follow the recommendations in B10.7<br><i>Recommend implementation of RAS using Arm</i><br><i>RAS extensions</i> |
| 0b0011   | MHU implements the RAS extension and follows the recommendations in B10.7 <i>Recommend implementation of RAS using Arm RAS extensions</i>                         |

Access to this field is RO.

# RME\_SPT, bits [19:16]

Realm Management Extension Support

The value of this field depends on the implementation of the MHU and an optional reset time sampled input LEGACY\_TZ\_EN.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RME_SPT | Meaning                                                  |
|---------|----------------------------------------------------------|
| 060000  | MHU does not implement the Realm<br>Management extension |

| RME_SPT | Meaning                                   |
|---------|-------------------------------------------|
| 0b0001  | MHU implements Realm Management extension |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

When RME is implemented, for the half of the MHU, there can be a **LEGACY\_TZ\_EN** tie-off present on that side of the MHU.

The value of the LEGACY\_TZ\_EN tie-off is sampled at reset of the side of the MHU which the tie-off is associated with.

When the sampled value of the tie-off is 0b1 the value of this field is always 0x0, otherwise the value of this field is dependent on whether RME is implemented for this half of the MHU.

Access to this field is RO.

#### TZE\_SPT, bits [15:12]

TrustZone Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| TZE_SPT | Meaning                                        |
|---------|------------------------------------------------|
| 00000   | MHU does not implement the TrustZone extension |
| 0b0001  | MHU implements TrustZone extension             |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

Access to this field is RO.

## FCE\_SPT, bits [11:8]

Fast Channel Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCE_SPT | Meaning                                           |
|---------|---------------------------------------------------|
| 0000d0  | MHU does not implement the Fast Channel extension |
| 0b0001  | MHU implements Fast Channel extension             |

Access to this field is **RO**.

FE\_SPT, bits [7:4]

FIFO Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FE_SPT | Meaning                                   |
|--------|-------------------------------------------|
| 000000 | MHU does not implement the FIFO extension |
| 0b0001 | MHU implements FIFO extension             |

Access to this field is **RO**.

# DBE\_SPT, bits [3:0]

Doorbell Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| DBE_SPT | Meaning                                       |
|---------|-----------------------------------------------|
| 0000d0  | MHU does not implement the Doorbell extension |
| 0b0001  | MHU implements Doorbell extension             |

Access to this field is **RO**.

# Accessing PBX\_FEAT\_SPT0

Accesses to this register use the following encodings:

# Accessible at offset 0x010 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.3 PBX\_FEAT\_SPT1, Postbox Feature Support 1

The PBX\_FEAT\_SPT1 characteristics are:

# Purpose

Provides information on the features implemented in the Postbox.

# Attributes

PBX\_FEAT\_SPT1 is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

# **Field descriptions**

The PBX\_FEAT\_SPT1 bit assignments are:

| 131 4 | 3 | 0     |         |
|-------|---|-------|---------|
| RES0  |   |       |         |
|       |   | LAUTO | _0P_SPT |

# Bits [31:4]

Reserved, RESO.

# AUTO\_OP\_SPT, bits [3:0]

Auto Op Protocol Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| AUTO_OP_SPT | Meaning                      |
|-------------|------------------------------|
| 060000      | Auto Op(Min) is implemented  |
| 0b0001      | Auto Op(Full) is implemented |

Access to this field is **RO**.

# Accessing PBX\_FEAT\_SPT1

Accesses to this register use the following encodings:

# Accessible at offset 0x014 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.4 PBX\_DBCH\_CFG0, Postbox Doorbell Channel Configuration 0

The PBX\_DBCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of DBE in Postbox.

#### Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PBX\_DBCH\_CFG0 are RAZ/WI.

#### Attributes

PBX\_DBCH\_CFG0 is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_DBCH\_CFG0 bit assignments are:

| 31   | 8   7 | 0        |
|------|-------|----------|
| RES0 |       | NUM_DBCH |

#### Bits [31:8]

Reserved, RESO.

#### NUM\_DBCH, bits [7:0]

Number of Doorbell Channels

Number of DBCH implemented in the Postbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

# NUM\_DBCH Meaning

 $0 \times 00..0 \times 7F$  Number of DBCH is N+1, where N is the value of this field

Access to this field is **RO**.

Accessing PBX\_DBCH\_CFG0

Accesses to this register use the following encodings:

Accessible at offset 0x020 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.5 PBX\_FFCH\_CFG0, Postbox FIFO Channel Configuration 0

The PBX\_FFCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of FE in Postbox.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PBX\_FFCH\_CFG0 are RAZ/WI.

#### Attributes

PBX\_FFCH\_CFG0 is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_FFCH\_CFG0 bit assignments are:



#### Bits [31:26]

Reserved, RESO.

#### FFCH\_DEPTH, bits [25:16]

FIFO Channel Depth

Depth of the FIFOs of the FFCHs in the Postbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FFCH_DEPTH                 | Meaning                                                      |
|----------------------------|--------------------------------------------------------------|
| 0b0000000000<br>⇔b11111111 | FIFO depth is N+1 bytes, where N is the value of this field. |

Access to this field is RO.

Bits [15:12]

Reserved, RESO.

# P64BA\_SPT, bit [11]

Postbox 64-bit Access Support

Whether 64-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P64BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0b0       | 64-bit accesses are not supported |
| 0b1       | 64-bit accesses are supported     |

Accesses must be aligned to an 64-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

When 64-bit accesses are supported the PFFCW<n>\_PAY register occupies offsets 0x00-0x07 of the PFFCW.

When 64-bit accesses are not supported the PFFCW<n>\_PAY register occupies offsets 0x00-0x03 of the PFFCW and offsets 0x04-0x07 of the PFFCW are RES0.

Access to this field is RO.

# P32BA\_SPT, bit [10]

Postbox 32-bit Access Support

Whether 32-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P32BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0d0       | 32-bit accesses are not supported |
| 0b1       | 32-bit accesses are supported     |

Accesses must be aligned to an 32-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

# P16BA\_SPT, bit [9]

Postbox 16-bit Access Support

Whether 16-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P16BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0d0       | 16-bit accesses are not supported |
| 0b1       | 16-bit accesses are supported     |

Accesses must be aligned to an 16-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

# P8BA\_SPT, bit [8]

Postbox 8-bit Access Support

Whether 8-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P8BA_SPT | Meaning |  |
|----------|---------|--|
|          |         |  |

0b0

8-bit accesses are not supported

| P8BA_SPT | Meaning                      |
|----------|------------------------------|
| 0b1      | 8-bit accesses are supported |

Accesses must be aligned to an 8-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is **RO**.

# NUM\_FFCH, bits [7:0]

Number of FIFO Channels

The number of FFCHs in the Postbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FFCH | Meaning                                                    |
|----------|------------------------------------------------------------|
| 0x000x3F | Number of FFCHs is N+1, where N is the value of this field |

Access to this field is **RO**.

# Accessing PBX\_FFCH\_CFG0

Accesses to this register use the following encodings:

# Accessible at offset 0x030 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.6 PBX\_FCH\_CFG0, Postbox Fast Channel Configuration 0

The PBX\_FCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of FCE in the Postbox.

#### Configuration

This register is present only when FCE is implemented. Otherwise, direct accesses to PBX\_FCH\_CFG0 are RAZ/WI.

#### Attributes

PBX\_FCH\_CFG0 is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_FCH\_CFG0 bit assignments are:



#### Bits [31:29]

Reserved, RESO.

#### FCH\_WS, bits [28:21]

Fast Channel Word-Size

Number of bits each FCH implements.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCH_WS | Meaning                           |
|--------|-----------------------------------|
| 0x20   | Fast Channel word-size is 32-bits |
| 0x40   | Fast Channel word-size is 64-bits |

Access to this field is **RO**.

#### NUM\_FCH\_PER\_FCG, bits [20:16]

Number of Fast Channels per Fast Channel Group

Number of FCHs implemented in FCGs for Postbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH_PER_FCG | Meaning                                                           |
|-----------------|-------------------------------------------------------------------|
| 0b000000b11111  | Number of FCHs per FCG is N+1, where N is the value of this field |

Access to this field is RO.

# NUM\_FCG, bits [15:11]

Number of Fast Channel Groups

Number of FCGs implemented in Postbox

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCG             | Meaning                                                   |
|---------------------|-----------------------------------------------------------|
| 0b000000<br>⇔b11111 | Number of FCGs is N+1, where N is the value of this field |

Access to this field is **RO**.

# Bit [10]

Reserved, RESO.

#### NUM\_FCH, bits [9:0]

Number of Fast Channels

Number of FCHs implemented in Postbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH                     | Meaning                                                  | Applies             |
|-----------------------------|----------------------------------------------------------|---------------------|
| 0b0000000000<br>∽b011111111 | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x40 |
| 0b0000000000<br>⇔b11111111  | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x20 |

## Access to this field is **RO**.

# Accessing PBX\_FCH\_CFG0

Accesses to this register use the following encodings:

# Accessible at offset 0x040 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.7 PBX\_CTRL, Postbox Control

The PBX\_CTRL characteristics are:

#### Purpose

Configures the behavior of the Postbox.

## Attributes

PBX\_CTRL is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_CTRL bit assignments are:

| 31 2      | 1 | 0 |        |
|-----------|---|---|--------|
| RES0      |   |   |        |
| CH_OP_MSK |   | Ľ | OP_REQ |

# Bits [31:2]

Reserved, RESO.

# CH\_OP\_MSK, bit [1]

Channel Operational Mask

Controls whether channels need to be idle to allow a controlled entry of the MHUS into a non-operational state.

| CH_OP_MSK | Meaning                                                                        |
|-----------|--------------------------------------------------------------------------------|
| 060       | Channels must be idle to enter a non-operational state                         |
| 0b1       | Channels status is ignored when considering entry into a non-operational state |

This field has no effect on entry into a non-operation state in an uncontrolled manner for the MHUS.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# OP\_REQ, bit [0]

**Operational Request** 

Controls whether the MHUS is required to remain in an operational state.

| OP_REQ | Meaning                                                     |
|--------|-------------------------------------------------------------|
| 0b0    | Postbox is not requested to remain in the operational state |
| 0b1    | Postbox is requested to remain in the operational state     |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# Accessing PBX\_CTRL

Accesses to this register use the following encodings:

# Accessible at offset 0x100 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.8 PBX\_DBCH\_INT\_ST<n>, Postbox Doorbell Channel Interrupt Status n, n = 0 - 3

The PBX\_DBCH\_INT\_ST<n> characteristics are:

#### Purpose

Indicates whether there is an interrupt outstanding for a DBCH

PBX\_DBCH\_INT\_ST0 has status fields for DBCHs 0 to 31

PBX\_DBCH\_INT\_ST1 has status fields for DBCHs 32 to 63

PBX\_DBCH\_INT\_ST2 has status fields for DBCHs 64 to 95

PBX\_DBCH\_INT\_ST3 has status fields for DBCHs 96 to 127

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PBX\_DBCH\_INT\_ST<n> are RAZ/WI.

#### Attributes

PBX\_DBCH\_INT\_ST<n> is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### Field descriptions

The PBX\_DBCH\_INT\_ST<n> bit assignments are:



#### DBCH\_INT\_ST<x>, bits [x], for x = 31 to 0

Doorbell Channel Interrupt Status

Each bit indicates whether there is an outstanding interrupt for the DBCH, that is contributing to the Postbox Combined interrupt.

| DBCH_INT_ST <x></x> | Meaning                                                                                    |
|---------------------|--------------------------------------------------------------------------------------------|
| 060                 | No interrupt outstanding for the DBCH or the DBCH is not configured to contribute into the |
|                     | Postbox Combined interrupt.                                                                |

| DBCH_INT_ST <x></x> | Meaning                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------|
| 0b1                 | Interrupt outstanding for the DBCH and the DBCH is configured to contribute into the Postbox Combined interrupt. |

Any fields which are not assigned to a DBCH are Reserved and treated as RESO

# Accessing PBX\_DBCH\_INT\_ST<n>

Accesses to this register use the following encodings:

# Accessible at offset 0x400 + (4 \* n) from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.9 PBX\_FFCH\_INT\_ST<n>, Postbox FIFO Channel Interrupt Status n, n = 0 - 1

The PBX\_FFCH\_INT\_ST<n> characteristics are:

#### Purpose

Indicates whether there is an interrupt outstanding for the FFCH.

PBX\_FFCH\_INT\_ST0 has status fields for FFCHs 0 to 31

PBX\_FFCH\_INT\_ST1 has status fields for FFCHs 32 to 63

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PBX\_FFCH\_INT\_ST<n> are RAZ/WI.

# Attributes

PBX\_FFCH\_INT\_ST<n> is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

# Field descriptions

The PBX\_FFCH\_INT\_ST<n> bit assignments are:



## FFCH\_INT\_ST<x>, bits [x], for x = 31 to 0

FIFO Channel Interrupt Status

Each bit indicates whether there is an outstanding interrupt for the FFCH, that is contributing to the Postbox Combined interrupt

| FFCH_INT_ST <x></x> | Meaning                                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------------------------|
| 040                 | No interrupt outstanding for the FFCH or the FFCH is not configured to contribute into the Postbox Combined interrupt. |
| 0b1                 | Interrupt outstanding for the FFCH and the FFCH is configured to contribute into the Postbox Combined interrupt.       |

Any fields which are not assigned to a FFCH are Reserved and treated as RAZ/WI

# Accessing PBX\_FFCH\_INT\_ST<n>

Accesses to this register use the following encodings:

# Accessible at offset 0x410 + (4 \* n) from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.10 PBX\_IIDR, Postbox Implementer Identification Register

The PBX\_IIDR characteristics are:

#### Purpose

This field provides information on the implementation of the MHU

#### Attributes

PBX\_IIDR is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_IIDR bit assignments are:

| 31         | 20 | 19 16   | 15 12    | 11 0        |
|------------|----|---------|----------|-------------|
| PRODUCT_ID |    | VARIANT | REVISION | IMPLEMENTER |

# PRODUCT\_ID, bits [31:20]

Product ID of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is **RO**.

### VARIANT, bits [19:16]

Variant or major revision of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

#### **REVISION**, bits [15:12]

Revision or minor version of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

#### **IMPLEMENTER**, bits [11:0]

Implementer ID

Contains the JEP106 identification information as follows:

- 11:8 JEP106 continuation code of implementer
- 7 Always 0
- 6:0 JEP106 identity code of implementer

This field has an IMPLEMENTATION DEFINED value.

Access to this field is **RO**.

#### Accessing PBX\_IIDR

Accesses to this register use the following encodings:

Accessible at offset 0xFC8 from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.11 PBX\_AIDR, Postbox Architecture Identification Register

The PBX\_AIDR characteristics are:

#### Purpose

Provides information on the version of the MHU architecture implemented in this implementation of the MHU.

#### Attributes

PBX\_AIDR is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_AIDR bit assignments are:



## Bits [31:8]

Reserved, RESO.

#### ARCH\_MAJOR\_REV, bits [7:4]

MHU Architecture Major Revision

The value of this field is an IMPLEMENTATION DEFINED choice of:

| ARCH_MAJOR_REV | Meaning                                |
|----------------|----------------------------------------|
| 000000         | MHUv1 or unknown architecture versions |
| 0b0001         | MHUv2                                  |
| 0b0010         | MHUv3                                  |

All other values are Reserved

Access to this field is RO.

# ARCH\_MINOR\_REV, bits [3:0]

MHU Architecture Minor Revision

The value of this field is an IMPLEMENTATION DEFINED choice of:

| ARCH_MINOR_REV | Meaning                                    |  |
|----------------|--------------------------------------------|--|
| 060000         | Minor revision 0 of the major architecture |  |
| 0b0001         | Minor revision 1 of the major architecture |  |

All other values are Reserved

Access to this field is RO.

## **Additional information**

The legal combinations for the ARCH\_MAJOR\_REV and ARCH\_MINOR\_REV fields are as follows:

| ARCH_MAJOR_REV | ARCH_MINOR_REV | Description |
|----------------|----------------|-------------|
| 0x0            | 0x0            | MHUv1       |
| 0x1            | 0x0            | MHUv2.0     |
| 0x1            | 0x1            | MHUv2.1     |
| 0x2            | 0x0            | MHUv3.0     |

MHU implementations based on this architecture, have the ARCH\_MAJOR\_REV set to 0x2 and ARCH\_MINOR\_REV set to 0x0.

# Accessing PBX\_AIDR

Accesses to this register use the following encodings:

# Accessible at offset 0xFCC from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.1.12 PBX\_IMPL\_DEF\_ID<n>, IMPDEF Register, n = 0 - 11

The PBX\_IMPL\_DEF\_ID<n> characteristics are:

#### Purpose

This register is for IMPLEMENTATION DEFINED Identification Registers which can be used to identify the implementation of the MHU Postbox

An implementation can do the following with this register:

- Chose whether a register is present or not.
- The name of the register.
- The access permission of the registers, so long as they are not more permissive than the architecture defines for the IMPLEMENTATION DEFINED register.
- The names, behavior and reset value of any fields.
- The access permissions of any fields, so long as they are not more permissive than the register.

If the PBX\_IMPL\_DEF\_ID<n> is not present then the location is Reserved and treated as RESO

#### Attributes

PBX\_IMPL\_DEF\_ID<n> is a 32-bit register.

This register is part of the MHUS.PBX.PBX\_CTRL\_page block.

#### **Field descriptions**

The PBX\_IMPL\_DEF\_ID<n> bit assignments are:

IMPLEMENTATION DEFINED

#### **IMPLEMENTATION DEFINED, bits [31:0]**

IMPLEMENTATION DEFINED

#### Accessing PBX\_IMPL\_DEF\_ID<n>

Accesses to this register use the following encodings:

#### Accessible at offset 0xFD0 + (4 \* n) from MHUS.PBX.PBX\_CTRL\_page

# C2.1.1.2 PDBCW\_page, Postbox Doorbell Channel Window Page

The PDBCW\_page characteristics are:

# Purpose

Allows access to the PDBCW.

#### Configuration

This Register Block is present only when DBE is implemented.

#### Attributes

The PDBCW\_page block is of size 4KB.

This block is part of the MHUS.PBX block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

# Contents

| Offset                              | Name                  | Notes                          |
|-------------------------------------|-----------------------|--------------------------------|
| 0x0000 + (32 * n)for n in<br>↔127:0 | PDBCW <n>_ST</n>      | Most permissive access: RO     |
| 0x000C + (32 * n)for n in<br>⇔127:0 | PDBCW <n>_SET</n>     | Most permissive access: WO/RAZ |
| 0x0010 + (32 ★ n)for n in<br>⇔127:0 | PDBCW <n>_INT_ST</n>  | Most permissive access: RO     |
| 0x0014 + (32 * n)for n in<br>⇔127:0 | PDBCW <n>_INT_CLR</n> | Most permissive access: WO/RAZ |
| 0x0018 + (32 * n)for n in<br>⇔127:0 | PDBCW <n>_INT_EN</n>  | Most permissive access: RW     |
| 0x001C + (32 * n)for n in<br>↔127:0 | PDBCW <n>_CTRL</n>    | Most permissive access: RW     |
# C2.1.1.2.1 PDBCW<n>\_ST, Postbox Doorbell Channel Window <n> Status, n = 0 - 127

The PDBCW<n>\_ST characteristics are:

# Purpose

Status of the flags for DBCH<n>.

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PDBCW<n>\_ST are RAZ/WI.

# Attributes

PDBCW<n>\_ST is a 32-bit register.

This register is part of the MHUS.PBX.PDBCW\_page block.

#### **Field descriptions**

The PDBCW<n>\_ST bit assignments are:



# FLAG<x>, bits [x], for x = 31 to 0

Flag

Indicates the status of Flag bit <x> of the DBCH.

| FLAG <x></x> | Meaning                     |  |
|--------------|-----------------------------|--|
| 0b0          | Flag <x> bit is not set</x> |  |
| 0b1          | Flag <x> bit is set</x>     |  |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

# Accessing PDBCW<n>\_ST

Accesses to this register use the following encodings:

# Accessible at offset 0x0000 + (32 \* n) from MHUS.PBX.PDBCW\_page

Access on this interface is RO.

# C2.1.1.2.2 PDBCW<n>\_SET, Postbox Doorbell Channel Window <n> Set, n = 0 - 127

The PDBCW<n>\_SET characteristics are:

## Purpose

Set flags of DBCH<n>.

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PDBCW<n>\_SET are RAZ/WI.

# Attributes

PDBCW<n>\_SET is a 32-bit register.

This register is part of the MHUS.PBX.PDBCW\_page block.

#### **Field descriptions**

The PDBCW<n>\_SET bit assignments are:



# FLAG<x>, bits [x], for x = 31 to 0

| FLAG <x></x> | Meaning                                                                                  |
|--------------|------------------------------------------------------------------------------------------|
| 0b0          | No effect                                                                                |
| 0b1          | Sets the associated bit in the PDBCW <n>_ST<br/>and MDBCW<n>_ST registers to 0b1</n></n> |

# Accessing PDBCW<n>\_SET

Accesses to this register use the following encodings:

# Accessible at offset 0x000C + (32 \* n) from MHUS.PBX.PDBCW\_page

Access on this interface is WO/RAZ.

# C2.1.1.2.3 PDBCW<n>\_INT\_ST, Postbox Doorbell Channel Window <n> Interrupt Status, n = 0 - 127

The PDBCW<n>\_INT\_ST characteristics are:

#### Purpose

Provides the status of interrupts for DBCH <n>.

# Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PDBCW<n>\_INT\_ST are RAZ/WI.

## Attributes

PDBCW<n>\_INT\_ST is a 32-bit register.

This register is part of the MHUS.PBX.PDBCW\_page block.

#### **Field descriptions**

The PDBCW<n>\_INT\_ST bit assignments are:



# Bits [31:1]

Reserved, RAZ.

#### TFR\_ACK, bit [0]

Transfer Acknowledge

Indicates whether a Transfer Acknowledge event has occurred.

| TFR_ACK | Meaning                                     |
|---------|---------------------------------------------|
| 0b0     | Transfer Acknowledge event hsa not occurred |
| 0b1     | Transfer Acknowledge event has occurred     |

# Accessing PDBCW<n>\_INT\_ST

Accesses to this register use the following encodings:

Accessible at offset 0x0010 + (32 \* n) from MHUS.PBX.PDBCW\_page

Access on this interface is RO.

# C2.1.1.2.4 PDBCW<n>\_INT\_CLR, Postbox Doorbell Channel Window <n> Interrupt Clear, n = 0 - 127

The PDBCW<n>\_INT\_CLR characteristics are:

## Purpose

Allows clearing of any interrupts for DBCH <n>.

# Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PDBCW<n>\_INT\_CLR are RAZ/WI.

## Attributes

PDBCW<n>\_INT\_CLR is a 32-bit register.

This register is part of the MHUS.PBX.PDBCW\_page block.

#### **Field descriptions**

The PDBCW<n>\_INT\_CLR bit assignments are:



# Bits [31:1]

Reserved, RAZ.

# TFR\_ACK, bit [0]

| TFR_ACK | Meaning                                                                    |
|---------|----------------------------------------------------------------------------|
| 0b0     | No effect                                                                  |
| 0b1     | Clears the Transfer Acknowledge field in the PDBCW <n>_INT_ST register</n> |

# Accessing PDBCW<n>\_INT\_CLR

Accesses to this register use the following encodings:

Accessible at offset 0x0014 + (32 \* n) from MHUS.PBX.PDBCW\_page

Access on this interface is WO/RAZ.

# C2.1.1.2.5 PDBCW<n>\_INT\_EN, Postbox Doorbell Channel Window <n> Interrupt Enable, n = 0 - 127

The PDBCW<n>\_INT\_EN characteristics are:

## Purpose

Configures the interrupts of DBCH <n>.

# Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PDBCW<n>\_INT\_EN are RAZ/WI.

## Attributes

PDBCW<n>\_INT\_EN is a 32-bit register.

This register is part of the MHUS.PBX.PDBCW\_page block.

#### **Field descriptions**

The PDBCW<n>\_INT\_EN bit assignments are:



# Bits [31:1]

Reserved, RAZ.

#### TFR\_ACK, bit [0]

Transfer Acknowledge

Controls whether a Transfer Acknowledge event generates a Channel Transfer Acknowledge interrupt.

| TFR_ACK | Meaning                                                                                          |
|---------|--------------------------------------------------------------------------------------------------|
| 0d0     | A Channel Transfer Acknowledge event does not generate a Channel Transfer Acknowledge interrupt. |
| 0b1     | A Channel Transfer Acknowledge event generates a Channel Transfer Acknowledge interrupt.         |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# Accessing PDBCW<n>\_INT\_EN

Accesses to this register use the following encodings:

# Accessible at offset 0x0018 + (32 \* n) from MHUS.PBX.PDBCW\_page

Access on this interface is RW.

# C2.1.1.2.6 PDBCW<n>\_CTRL, Postbox Doorbell Channel Window <n> Control, n = 0 - 127

The PDBCW<n>\_CTRL characteristics are:

## Purpose

Configures the behavior of DBCH <n>.

# Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to PDBCW<n>\_CTRL are RAZ/WI.

## Attributes

PDBCW<n>\_CTRL is a 32-bit register.

This register is part of the MHUS.PBX.PDBCW\_page block.

#### **Field descriptions**

The PDBCW<n>\_CTRL bit assignments are:



# Bits [31:1]

Reserved, RESO.

# PBX\_COMB\_EN, bit [0]

Postbox Combined Enable

Controls whether interrupts from the DBCH contribute to the Postbox Combined interrupt.

| PBX_COMB_EN | Meaning                                                             |
|-------------|---------------------------------------------------------------------|
| 060         | DBCH interrupts do not contribute to the Postbox Combined interrupt |
| 0b1         | DBCH interrupts contribute to the Postbox<br>Combined interrupt     |

The reset behavior of this field is:

- On a MHUS reset, this field resets to Ob1.

# Accessing PDBCW<n>\_CTRL

Accesses to this register use the following encodings:

# Accessible at offset 0x001C + (32 \* n) from MHUS.PBX.PDBCW\_page

Access on this interface is **RW**.

# C2.1.1.3 PFFCW\_page, Postbox FIFO Channel Windows Page

The PFFCW\_page characteristics are:

# Purpose

Allows access to the PFFCW.

Depending on the size of the access to the PFFCW\_PAY register and whether the access size is supported the access is treated as follows:

- 8-bit access and PBX\_FFCH\_CFG0.P8BA\_SPT == 0b1 the access behaves as defined in PFFCW<n>\_PAY8.
- 8-bit access and PBX\_FFCH\_CFG0.P8BA\_SPT == 0b0 the access is treated as an unsupported access.
- 16-bit access and PBX\_FFCH\_CFG0.P16BA\_SPT == 0b1 the access behaves as defined in PFFCW<n>\_PAY16.
- 16-bit access and PBX\_FFCH\_CFG0.P16BA\_SPT == 0b0 the access is treated as an unsupported access.
- 32-bit access and PBX\_FFCH\_CFG0.P32BA\_SPT == 0b1 the access behaves as defined in PFFCW<n>\_PAY32.
- 32-bit access and PBX\_FFCH\_CFG0.P32BA\_SPT == 0b0 the access is treated as an unsupported access.
- 64-bit access and PBX\_FFCH\_CFG0.P64BA\_SPT == 0b1 the access behaves as defined in PFFCW<n>\_PAY64.
- 64-bit access and PBX\_FFCH\_CFG0.P64BA\_SPT == 0b0 the access is treated as an unsupported access.

# Configuration

This Register Block is present only when FE is implemented.

# Attributes

The PFFCW\_page block is of size 4KB.

This block is part of the MHUS.PBX block.

# **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset                        | Name               | Notes                                                                                                      |
|-------------------------------|--------------------|------------------------------------------------------------------------------------------------------------|
| 0x000 + (64 * n)for n in 63:0 | PFFCW <n>_PAY8</n> | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT |
| 0x000 + (64 * n)for n in 63:0 | PFFCW <n>_PAY8</n> | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT |

| Offset                   | Name                     | Notes                                                                                                        |
|--------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------|
| 0x000 + (64 * n)for n in | 63:0 PFFCW <n>_PAY16</n> | Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P16BA_SPT |
| 0x000 + (64 * n)for n in | 63:0 PFFCW <n>_PAY16</n> | Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P16BA_SPT |
| 0x000 + (64 * n)for n in | 63:0 PFFCW <n>_PAY32</n> | Most permissive access: RW<br>Register condition: When<br>P32BA_SPT<br>Accessor condition: When<br>P32BA_SPT |
| 0x000 + (64 * n)for n in | 63:0 PFFCW <n>_PAY32</n> | Most permissive access: RW<br>Register condition: When<br>P32BA_SPT<br>Accessor condition: When<br>P32BA_SPT |
| 0x000 + (64 * n)for n in | 63:0 PFFCW <n>_PAY64</n> | Most permissive access: RW<br>Register condition: When<br>P64BA_SPT<br>Accessor condition: When<br>P64BA_SPT |
| 0x000 + (64 * n)for n in | 63:0 PFFCW <n>_PAY64</n> | Most permissive access: RW<br>Register condition: When<br>P64BA_SPT<br>Accessor condition: When<br>P64BA_SPT |
| 0x001 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT   |
| 0x001 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT   |
| 0x002 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT   |

| Offset                   | Name                     | Notes                                                                                                                      |
|--------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------|
| 0x002 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When                             |
| 0x002 + (64 * n)for n in | 63:0 PFFCW <n>_PAY16</n> | P8BA_SP1<br>Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P16BA_SPT   |
| 0x002 + (64 * n)for n in | 63:0 PFFCW <n>_PAY16</n> | Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P16BA_SPT               |
| 0x003 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT                 |
| 0x003 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P8BA_SPT                 |
| 0x004 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA SPT and P8BA SPT   |
| 0x004 + (64 * n)for n in | 63:0 PFFCW <n>_PAY8</n>  | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P8BA_SPT   |
| 0x004 + (64 * n)for n in | 63:0 PFFCW <n>_PAY16</n> | Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P16BA_SPT |
| 0x004 + (64 * n)for n in | 63:0 PFFCW <n>_PAY16</n> | Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P16BA_SPT |

| Offset                   | Name                         | Notes                                                                                                                                                 |
|--------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x004 + (64 * n)for n in | 63:0 PFFCW <n>_P/</n>        | MY32 Most permissive access: RW<br>Register condition: When<br>P32BA_SPT<br>Accessor condition: When                                                  |
| 0x004 + (64 * n)for n in | 63:0 <b>PFFCW<n>_P</n></b>   | P64BA_SPT and P32BA_SPT<br>Most permissive access: RW<br>Register condition: When<br>P32BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P32BA_SPT |
| 0x005 + (64 * n)for n in | 63:0 PFFCW <n>_P4</n>        | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P8BA_SPT                              |
| 0x005 + (64 * n)for n in | 63:0 PFFCW <n>_PA</n>        | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P8BA_SPT                              |
| 0x006 + (64 * n)for n in | 63:0 PFFCW <n>_PA</n>        | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P8BA_SPT                              |
| 0x006 + (64 * n)for n in | 63:0 PFFCW <n>_P4</n>        | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA SPT and P8BA SPT                              |
| 0x006 + (64 * n)for n in | 63:0 <b>PFFCW<n>_P</n></b> A | AY16 Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P64BA SPT and P16BA SPT                       |
| 0x006 + (64 * n)for n in | 63:0 <b>PFFCW<n>_P</n></b>   | AY16 Most permissive access: RW<br>Register condition: When<br>P16BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P16BA_SPT                       |
| 0x007 + (64 * n)for n in | 63:0 PFFCW <n>_PA</n>        | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA SPT and P8BA SPT                              |

| Offset                         | Name                  | Notes                                                                                                                    |
|--------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x007 + (64 * n)for n in 63:0  | PFFCW <n>_PAY8</n>    | Most permissive access: RW<br>Register condition: When<br>P8BA_SPT<br>Accessor condition: When<br>P64BA_SPT and P8BA_SPT |
| 0x0008 + (64 * n)for n in 63:0 | PFFCW <n>_FLG</n>     | Most permissive access: RW                                                                                               |
| 0x0010 + (64 * n)for n in 63:0 | PFFCW <n>_INT_ST</n>  | Most permissive access: RO                                                                                               |
| 0x0014 + (64 * n)for n in 63:0 | PFFCW <n>_INT_CLR</n> | Most permissive access: WO/RAZ                                                                                           |
| 0x0018 + (64 * n)for n in 63:0 | PFFCW <n>_INT_EN</n>  | Most permissive access: RW                                                                                               |
| 0x0020 + (64 * n)for n in 63:0 | PFFCW <n>_CTRL</n>    | Most permissive access: RW                                                                                               |
| 0x0024 + (64 * n)for n in 63:0 | PFFCW <n>_ST</n>      | Most permissive access: RO                                                                                               |
| 0x0028 + (64 * n)for n in 63:0 | PFFCW <n>_ACK_CNT</n> | Most permissive access: RO                                                                                               |
| 0x002C + (64 * n)for n in 63:0 | PFFCW <n>_TIDE</n>    | Most permissive access: RW                                                                                               |

# C2.1.1.3.1 PFFCW<n>\_PAY8, Postbox FIFO Channel Window <n> Payload (8-bit access), n = 0 - 63

The PFFCW<n>\_PAY8 characteristics are:

## Purpose

An 8-bit access to the PFFCW<n>\_PAY register. Accesses must be aligned to any 8-bit boundary within the PFFCW\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

8-bit accesses are only supported, if PBX\_FFCH\_CFG0.P8BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If P64BA\_SPT is set to 1 the PFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Postbox FIFO Channel Window <n>.

If P64BA\_SPT is set to 0 the PFFCW<n>\_PAY register occupies offsets 0x00-0x04 and offsets 0x05 - 0x7 are reserved, within the Postbox FIFO Channel Window <n>.

Write access push the byte that is written to this offset onto the FIFO, if the FIFO has at least one byte of free space.

Read accesses return the number of invalid bytes in the FIFO and whether the previous push operation generated an error or not.

#### Configuration

This register is present only when FE is implemented and P8BA\_SPT. Otherwise, direct accesses to PFFCW<n>\_PAY8 are RAZ/WI.

#### Attributes

PFFCW<n>\_PAY8 is a 8-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_PAY8 bit assignments are:

When access is a write:



# PAY, bits [7:0]

Payload to push onto FIFO

Causes the written byte of data to be pushed onto the FIFO, if there is at least one byte of free space in the FIFO and sets the PFFCW<n>\_ST.PPE field to be set to 0b0.

If there is no free space in the FIFO, then no bytes are pushed onto the FIFO and the PFFCW<n>\_ST.PPE field is set to 0b1

The value written to this field has no effect on the operation of the FIFO.

All data flags in the PFFCW<n>\_FLG register are associated with the one byte pushed onto the FIFO

If the Transfer Delineation Mode for the FIFO is set to Partial or Auto Flag then on a write which sets PFFCW<n>\_ST.PPE field to 0b0, the values of data flags in the PFFCW<n>\_FLG register are updated.

#### When access is a read:



# PPE, bit [7]

Previous Push Error

Indicates whether a previous push to the FIFO caused an error

An error occurs due to the FIFO not having enough space to push all the bytes provided in the last write to the PFFCW\_PAY register.

| PPE | Meaning                                          |
|-----|--------------------------------------------------|
| 0b0 | No error has occurred on the last push operation |
| 0b1 | An error has occurred on the last push operation |

# FFS, bits [6:0]

**FIFO Free Space** 

Indicates the number of invalid bytes in the FIFO

| FFS                                     | Meaning                            | Applies                |
|-----------------------------------------|------------------------------------|------------------------|
| 000000000000000000000000000000000000000 | No free bytes in the FIFO          |                        |
| 0b00000010<br>⇔b111110                  | Number of free bytes in the FIFO   |                        |
| 0b1111111                               | 127 bytes free in the FIFO         | When FFCH_DEPTH <= 127 |
| 0b1111111                               | 127 or more bytes free in the FIFO | When FFCH_DEPTH > 127  |

The maximum value returned is never greater than the FIFO Depth

#### Accessing PFFCW<n>\_PAY8

Accesses to this register use the following encodings:

Read at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

# Read at offset 0x001 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

# Read at offset 0x002 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

# Read at offset 0x003 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

#### When P64BA\_SPT

## Read at offset 0x004 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

#### When P64BA\_SPT

#### Read at offset 0x005 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

#### When P64BA\_SPT

#### Read at offset 0x006 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

#### When P64BA\_SPT

#### Read at offset 0x007 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY8;

#### Write at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

#### Write at offset 0x001 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

#### Write at offset 0x002 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

#### Write at offset 0x003 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

#### When P64BA\_SPT

#### Write at offset 0x004 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

#### When P64BA\_SPT

## Write at offset 0x005 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

#### When P64BA\_SPT

#### Write at offset 0x006 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

# When P64BA\_SPT

# Write at offset 0x007 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY8 = value;

# C2.1.1.3.2 PFFCW<n>\_PAY16, Postbox FIFO Channel Window <n> Payload (16-bit access), n = 0 - 63

The PFFCW<n>\_PAY16 characteristics are:

#### Purpose

A 16-bit access to the PFFCW<n>\_PAY register. Accesses must be aligned to any 16-bit boundary within the PFFCW\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

16-bit accesses are only supported, if PBX\_FFCH\_CFG0.P16BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If P64BA\_SPT is set to 1 the PFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Postbox FIFO Channel Window <n>.

If P64BA\_SPT is set to 0 the PFFCW<n>\_PAY register occupies offsets 0x00-0x04 and offsets 0x05 - 0x7 are reserved, within the Postbox FIFO Channel Window <n>.

Write access pushes the two bytes that are written to this offset onto the FIFO, if the FIFO has at least two byte of free space.

Read accesses return the number of invalid bytes in the FIFO and whether the previous push operation generated an error or not.

#### Configuration

This register is present only when FE is implemented and P16BA\_SPT. Otherwise, direct accesses to PFFCW<n>\_PAY16 are RAZ/WI.

# Attributes

PFFCW<n>\_PAY16 is a 16-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

# **Field descriptions**

The PFFCW<n>\_PAY16 bit assignments are:

# When access is a write:



# PAY, bits [15:0]

Payload to push onto FIFO

Causes these written bytes of data to be pushed onto the FIFO, if there is at least two byte of free space in the FIFO and sets the PFFCW<n>\_ST.PPE field to be set to 0b0.

If there is less than two bytes of free space in the FIFO, then no bytes are pushed onto the FIFO and the PFFCW<n>\_ST.PPE field is set to 0b1

The value written to this field has no effect on the operation of the FIFO.

The order in which bytes are pushed onto the FIFO depends on the value of the PFFCW<n>\_CTRL.MSBF field as follows:

- 0b0 Bytes are pushed onto the FIFO starting with the LSB.
- 0b1 Bytes are pushed onto the FIFO starting with the MSB.

#### Chapter C2. Registers C2.1. MHUS, MHU Sender

The MHU is a little endian device and considers the LSB to be the byte which is written to the lowest offsets accessed by the write.

SOT flag is always associated with the first byte pushed onto the FIFO and EOT and ACK flags are associated with the last byte pushed onto the FIFO

If the Transfer Delineation Mode for the FIFO is set to Partial or Auto Flag then on a write which sets PFFCW<n>\_ST.PPE field to 0b0, the values of data flags in the PFFCW<n>\_FLG register are updated.

When access is a read:

| 15 | 14   | 11 | 10 6 | ) |
|----|------|----|------|---|
|    | RES0 |    | FFS  |   |
| T  | PPE  |    |      |   |

PPE, bit [15]

Previous Push Error

Indicates whether a previous push to the FIFO caused an error

An error occurs due to the FIFO not having enough space to push all the bytes provided in the last write to the PFFCW\_PAY register.

| PPE | Meaning                                          |
|-----|--------------------------------------------------|
| 060 | No error has occurred on the last push operation |
| 0b1 | An error has occurred on the last push operation |

# Bits [14:11]

Reserved, RESO.

# FFS, bits [10:0]

**FIFO Free Space** 

Indicates the number of invalid bytes in the FIFO

| FFS                                     | Meaning                          |
|-----------------------------------------|----------------------------------|
| 000000000000000000000000000000000000000 | No free bytes in the FIFO        |
| 0b00000000010<br>⇔b0111111111           | Number of free bytes in the FIFO |
| 0b1000000000                            | 1024 bytes free in the FIFO      |

The maximum value returned is never greater than the FIFO Depth

# Accessing PFFCW<n>\_PAY16

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY16;

# Read at offset 0x002 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY16;

# When P64BA\_SPT

# Read at offset 0x004 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY16;

# When P64BA\_SPT

# Read at offset 0x006 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY16;

# Write at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY16 = value;

# Write at offset 0x002 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY16 = value;

#### When P64BA\_SPT

#### Write at offset 0x004 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY16 = value;

#### When P64BA\_SPT

# Write at offset 0x006 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY16 = value;

# C2.1.1.3.3 PFFCW<n>\_PAY32, Postbox FIFO Channel Window <n> Payload (32-bit access), n = 0 - 63

The PFFCW<n>\_PAY32 characteristics are:

#### Purpose

A 32-bit access to the PFFCW<n>\_PAY register. Accesses must be aligned to any 32-bit boundary within the PFFCW\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

32-bit accesses are only supported, if PBX\_FFCH\_CFG0.P32BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If P64BA\_SPT is set to 1 the PFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Postbox FIFO Channel Window <n>.

If P64BA\_SPT is set to 0 the PFFCW<n>\_PAY register occupies offsets 0x00-0x04 and offsets 0x05 - 0x7 are reserved, within the Postbox FIFO Channel Window <n>.

Write access pushes the four bytes that are written to this offset onto the FIFO, if the FIFO has at least four byte of free space.

Read accesses return the number of invalid bytes in the FIFO and whether the previous push operation generated an error or not.

#### Configuration

This register is present only when FE is implemented and P32BA\_SPT. Otherwise, direct accesses to PFFCW<n>\_PAY32 are RAZ/WI.

#### Attributes

PFFCW<n>\_PAY32 is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_PAY32 bit assignments are:

# When access is a write:



# PAY, bits [31:0]

Payload to push onto FIFO

Causes these written bytes of data to be pushed onto the FIFO, if there is at least four byte of free space in the FIFO and sets the PFFCW<n>\_ST.PPE field to be set to 0b0.

If there is less than four bytes of free space in the FIFO, then no bytes are pushed onto the FIFO and the PFFCW<n>\_ST.PPE field is set to 0b1

The value written to this field has no effect on the operation of the FIFO.

The order in which bytes are pushed onto the FIFO depends on the value of the PFFCW<n>\_CTRL.MSBF field as follows:

- 0b0 Bytes are pushed onto the FIFO starting with the LSB.
- 0b1 Bytes are pushed onto the FIFO starting with the MSB.

The MHU is a little endian device and considers the LSB to be the byte which is written to the lowest offsets accessed by the write.

SOT flag is always associated with the first byte pushed onto the FIFO and EOT and ACK flags are associated with the last byte pushed onto the FIFO

If the Transfer Delineation Mode for the FIFO is set to Partial or Auto Flag then on a write which sets PFFCW<n>\_ST.PPE field to 0b0, the values of data flags in the PFFCW<n>\_FLG register are updated.

#### When access is a read:

| 131 | 30 11 | 10 0 |
|-----|-------|------|
|     | RES0  | FFS  |
| L   | PPE   |      |

# PPE, bit [31]

Previous Push Error

Indicates whether a previous push to the FIFO caused an error

An error occurs due to the FIFO not having enough space to push all the bytes provided in the last write to the PFFCW\_PAY register.

| PPE | Meaning                                          |
|-----|--------------------------------------------------|
| 0b0 | No error has occurred on the last push operation |
| 0b1 | An error has occurred on the last push operation |

# Bits [30:11]

Reserved, RESO.

# FFS, bits [10:0]

**FIFO Free Space** 

Indicates the number of invalid bytes in the FIFO

| FFS                                     | Meaning                          |
|-----------------------------------------|----------------------------------|
| 000000000000000000000000000000000000000 | No free bytes in the FIFO        |
| 0b00000000010<br>⇔b0111111111           | Number of free bytes in the FIFO |
| 0b1000000000                            | 1024 bytes free in the FIFO      |

The maximum value returned is never greater than the FIFO Depth

# Accessing PFFCW<n>\_PAY32

Accesses to this register use the following encodings:

# Read at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY32;

# When P64BA\_SPT

# Read at offset 0x004 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY32;

# Write at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY32 = value;

# When P64BA\_SPT

# Write at offset 0x004 + (64 \* n) from MHUS.PBX.PFFCW\_page

PFFCW<n>\_PAY32 = value;

# C2.1.1.3.4 PFFCW<n>\_PAY64, Postbox FIFO Channel Window <n> Payload (64-bit access), n = 0 - 63

The PFFCW<n>\_PAY64 characteristics are:

#### Purpose

A 64-bit access to the PFFCW<n>\_PAY register. Accesses must be aligned to any 64-bit boundary within the PFFCW\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

64-bit accesses are only supported, if PBX\_FFCH\_CFG0.P64BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

When PBX\_FFCH\_CFG0.P64BA\_SPT is set to 0b1, the PFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Postbox FIFO Channel Window <n>.

Write access pushes the eight bytes that are written to this offset onto the FIFO, if the FIFO has at least eight byte of free space.

Read accesses return the number of invalid bytes in the FIFO and whether the previous push operation generated an error or not.

# Configuration

This register is present only when FE is implemented and P64BA\_SPT. Otherwise, direct accesses to PFFCW<n>\_PAY64 are RAZ/WI.

# Attributes

PFFCW<n>\_PAY64 is a 64-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

# **Field descriptions**

The PFFCW<n>\_PAY64 bit assignments are:

# When access is a write:

| 63 |     | 32 |
|----|-----|----|
|    | PAY |    |
| 31 |     | 0  |
|    | PAY |    |

# PAY, bits [63:0]

Payload to push onto FIFO

Causes these written bytes of data to be pushed onto the FIFO, if there is at least eight byte of free space in the FIFO and sets the PFFCW<n>\_ST.PPE field to be set to 0b0.

If there is less than eight bytes of free space in the FIFO, then no bytes are pushed onto the FIFO and the PFFCW<n>\_ST.PPE field is set to 0b1

The value written to this field has no effect on the operation of the FIFO.

The order in which bytes are pushed onto the FIFO depends on the value of the PFFCW<n>\_CTRL.MSBF field as follows:

- 0b0 Bytes are pushed onto the FIFO starting with the LSB.
- 0b1 Bytes are pushed onto the FIFO starting with the MSB.

The MHU is a little endian device and considers the LSB to be the byte which is written to the lowest offsets accessed by the write.

SOT flag is always associated with the first byte pushed onto the FIFO and EOT and ACK flags are associated with the last byte pushed onto the FIFO

If the Transfer Delineation Mode for the FIFO is set to Partial or Auto Flag then on a write which sets PFFCW<n>\_ST.PPE field to 0b0, the values of data flags in the PFFCW<n>\_FLG register are updated.

#### When access is a read:

| 63  | 62   | 32     |
|-----|------|--------|
|     | RESO |        |
| L   | PPE  |        |
| 131 | 11 1 | 10 O I |
|     | RES0 | FFS    |

# PPE, bit [63]

Previous Push Error

Indicates whether a previous push to the FIFO caused an error

An error occurs due to the FIFO not having enough space to push all the bytes provided in the last write to the PFFCW\_PAY register.

| PPE | Meaning                                          |
|-----|--------------------------------------------------|
| 0b0 | No error has occurred on the last push operation |
| 0b1 | An error has occurred on the last push operation |

# Bits [62:11]

Reserved, RESO.

FFS, bits [10:0]

**FIFO Free Space** 

| FFS                                     | Meaning                          |
|-----------------------------------------|----------------------------------|
| 060000000000000000000000000000000000000 | No free bytes in the FIFO        |
| 0b00000000010<br>⇔b0111111111           | Number of free bytes in the FIFO |
| 0b1000000000                            | 1024 bytes free in the FIFO      |

The maximum value returned is never greater than the FIFO Depth

# Accessing PFFCW<n>\_PAY64

Accesses to this register use the following encodings:

# Read at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

return PFFCW<n>\_PAY64;

# Write at offset 0x000 + (64 \* n) from MHUS.PBX.PFFCW\_page

Chapter C2. Registers C2.1. MHUS, MHU Sender

PFFCW<n>\_PAY64 = value;

# C2.1.1.3.5 PFFCW<n>\_FLG, Postbox FIFO Channel Window <n> Flag, n = 0 - 63

The PFFCW<n>\_FLG characteristics are:

## Purpose

Provides access to the flags to be used for the next group of bytes pushed onto the FIFO by a write to the PFFCW<n>\_PAY register.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_FLG are RAZ/WI.

# Attributes

PFFCW<n>\_FLG is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

# **Field descriptions**

The PFFCW<n>\_FLG bit assignments are:



# Bits [31:3]

Reserved, RESO.

EOT, bit [2]

EOT flag

The EOT field indicates that the next push operation to the FIFO will contain the last byte of a Transfer

This fields behavior depends on the value of the PFFCW<n>\_CTRL.TDM field as follows:

| PFFCW <n>_CTRL.TDM</n> | Behavior of the EOT field                                                                                                                                                                                                                                         |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00                   | Software manages the EOT field directly and hardware will never change the value.                                                                                                                                                                                 |
| 0b01                   | The EOT field is set by software and hardware. The EOT is set to 0b0 when PFFCW <n>_CTRL.TDM is set to 0b01. When one or more bytes are pushed onto the FIFO, the EOT field is set to 0b0 irrespective of the value of the SOT or EOT fields before the push.</n> |
| 0b10                   | The EOT field is managed by hardware. The EOT flag is set to 0b0 when PFFCW <n>_CTRL.TDM is set to 0b10. The EOT flag value will toggle when one or more bytes are pushed onto the FIFO.</n>                                                                      |

| ЕОТ | Meaning                                                            |
|-----|--------------------------------------------------------------------|
| 0b0 | Next push operation does not contain the last byte of the Transfer |
| 0b1 | Next push operation does contain the last byte of the Transfer     |

The EOT flag is always associated with the last byte to be pushed onto the FIFO.

When multiple bytes are pushed onto the FIFO via a single write to the PFFCW<n>\_PAY register, which byte is associated with which fields depends on the value of the PFFCW<n>\_CTRL.MSBF field as follows:

- 0b0 LSB is associated with the SOT flag and MSB is associated with the EOT and ACK flags.
- 0b1 MSB is associated with the SOT flag and LSB is associated with the EOT and ACK flags.

The MHU is a little endian device and considers the LSB to be the byte which is written in the lowest offset accessed by the write.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

Accessing this field has the following behavior:

- When PFFCW<n>\_CTRL.TDM == '00', access to this field is **RW**
- Access is **RW** if all of the following are true:
  - PFFCW<n>\_CTRL.TDM == '01'
  - any of the following are true:
    - \* EOT field will be set to == '1'
    - \* SOT field will be set to == '1'
- Access is **RO** if all of the following are true:
  - PFFCW<n>\_CTRL.TDM == '01'
  - EOT field will be set to == '0'
  - SOT field will be set to == '0'
- When PFFCW<n>\_CTRL.TDM == '10', access to this field is **RO**

SOT, bit [1]

SOT flag

The SOT flag indicates that the next push operation to the FIFO will contain the first byte of a Transfer

This fields behavior depends on the value of the PFFCW<n>\_CTRL.TDM field as follows:

| PFFCW <n>_CTRL.TDM</n> | Behavior of the SOT field                                                                                                                                                                                                                               |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00                   | Software manages the SOT field directly and hardware will never change the value.                                                                                                                                                                       |
| 0Ь01                   | The SOT field is set by software and hardware. The SOT is set to 0b1 when PFFCW <n>_CTRL.TDM is set to 0b01. When one or more bytes are pushed onto the FIFO, the SOT field value will be set to the value of the EOT field when the push occurred.</n> |
| 0b10                   | The SOT field is managed by hardware. The SOT flag is set to 0b1 when PFFCW <n>_CTRL.TDM is set to 0b10 and is read-only. The SOT flag value will toggle when one or more bytes are push ed onto the FIFO.</n>                                          |

| SOT | Meaning                                                             |
|-----|---------------------------------------------------------------------|
| 0b0 | Next push operation does not contain the first byte of the Transfer |
| 0b1 | Next push operation does contain the first byte of the Transfer     |

The SOT flag is always associated with the first byte to be pushed onto the FIFO.

When multiple bytes are pushed onto the FIFO via a single write to the PFFCW<n>\_PAY register, which byte is associated with which fields depends on the value of the PFFCW<n>\_CTRL.MSBF field as follows:

- 0b0 LSB is associated with the SOT flag and MSB is associated with the EOT and ACK flags.
- 0b1 MSB is associated with the SOT flag and LSB is associated with the EOT and ACK flags.

The MHU is a little endian device and considers the LSB to be the byte which is written in the lowest offset accessed by the write.

The reset behavior of this field is:

• On a MHUS reset, this field resets to Ob1.

Accessing this field has the following behavior:

- When PFFCW<n>\_CTRL.TDM == '00', access to this field is **RW**
- Access is **RW** if all of the following are true:
  - PFFCW<n>\_CTRL.TDM == '01'
  - any of the following are true:
    - \* EOT field will be set to == '1'
    - \* SOT field will be set to == '1'
- Access is **RO** if all of the following are true:
  - PFFCW<n>\_CTRL.TDM == '01'
  - EOT field will be set to == '0'
  - SOT field will be set to == 0
- When PFFCW<n>\_CTRL.TDM == '10', access to this field is **RO**

# ACK, bit [0]

# ACK Flag

The ACK flag requests that when the Receiver pops the byte and the byte is the last byte of the Transfer, from the FIFO, a Transfer Acknowledge event is generated.

The behavior of the ACK field is not effected by the value of PFFCW<n>\_CTRL.TDM

| ACK | Meaning                                                                                      |
|-----|----------------------------------------------------------------------------------------------|
| 0b0 | Entry is not requested to generate a Transfer<br>Acknowledge event when popped from the FIFO |
| 0b1 | Entry is requested to generated a Transfer<br>Acknowledge event when popped from the FIFO    |

The ACK flag is always associated with the same byte that is associated with the EOT flag.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# Accessing PFFCW<n>\_FLG

Accesses to this register use the following encodings:

# Accessible at offset 0x0008 + (64 \* n) from MHUS.PBX.PFFCW\_page

Access on this interface is **RW**.

# C2.1.1.3.6 PFFCW<n>\_INT\_ST, Postbox FIFO Channel Window <n> Interrupt Status, n = 0 - 63

The PFFCW<n>\_INT\_ST characteristics are:

#### Purpose

Provides the status of interrupts for FFCH<n>.

# Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_INT\_ST are RAZ/WI.

## Attributes

PFFCW<n>\_INT\_ST is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_INT\_ST bit assignments are:



# FF, bit [31]

# FIFO Flush

Indicates whether the MHUR FIFO Flush mechanism has caused a flush of the FIFO for this FFCH.

| FF  | Meaning                                                      |
|-----|--------------------------------------------------------------|
| 0b0 | MHUR FIFO Flush mechanism has not caused a flush of the FIFO |
| 0b1 | MHU FIFO Flush mechanism has caused a flush of the FIFO      |

# Bits [30:3]

Reserved, RAZ.

# FHT, bit [2]

FIFO High Tidemark

Indicates whether the Sender FIFO High Tidemark event has occurred.

| FHT | Meaning                                          |
|-----|--------------------------------------------------|
| 0b0 | Sender FIFO High Tidemark event has not occurred |
| 0b1 | Sender FIFO High Tidemark event has occurred     |

# FLT, bit [1]

FIFO Low Tidemark

Indicates whether the Sender FIFO Low Tidemark event has occurred.

| FLT | Meaning                                         |
|-----|-------------------------------------------------|
| 0b0 | Sender FIFO Low Tidemark event has not occurred |
| 0b1 | Sender FIFO Low Tidemark event has occurred     |

# TFR\_ACK, bit [0]

Transfer Acknowledge

Indicates whether a Transfer Acknowledge event has occurred.

| TFR_ACK | Meaning                                     |
|---------|---------------------------------------------|
| 0b0     | Transfer Acknowledge event has not occurred |
| 0b1     | Transfer Acknowledge event has occurred     |

# Accessing PFFCW<n>\_INT\_ST

Accesses to this register use the following encodings:

# Accessible at offset 0x0010 + (64 \* n) from MHUS.PBX.PFFCW\_page

Access on this interface is **RO**.

# C2.1.1.3.7 PFFCW<n>\_INT\_CLR, Postbox FIFO Channel Window <n> Interrupt Clear, n = 0 - 63

The PFFCW<n>\_INT\_CLR characteristics are:

# Purpose

Allows clearing of any interrupts for FFCH<n>.

# Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_INT\_CLR are RAZ/WI.

#### Attributes

PFFCW<n>\_INT\_CLR is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_INT\_CLR bit assignments are:



# FF, bit [31]

FIFO Flush

| FF  | Meaning                                                        |
|-----|----------------------------------------------------------------|
| 0b0 | No effect                                                      |
| 0b1 | Clear FIFO flush event in the<br>PFFCW <n>_INT_ST register</n> |

Bits [30:3] Reserved, RAZ. FHT, bit [2]

FIFO High Tidemark

| FHT | Meaning                                                                |
|-----|------------------------------------------------------------------------|
| 0b0 | No effect                                                              |
| 0b1 | Clear FIFO High Tidemark event in the<br>PFFCW <n>_INT_ST register</n> |

# FLT, bit [1]

FIFO Low Tidemark

| FLT | Meaning                                                               |
|-----|-----------------------------------------------------------------------|
| 0b0 | No effect                                                             |
| 0b1 | Clear FIFO Low Tidemark event in the<br>PFFCW <n>_INT_ST register</n> |

# TFR\_ACK, bit [0]

Transfer Acknowledge

| TFR_ACK | Meaning                                                                  |
|---------|--------------------------------------------------------------------------|
| 0b0     | No effect                                                                |
| 0b1     | Clear Transfer Acknowledge event in the<br>PFFCW <n>_INT_ST register</n> |

# Accessing PFFCW<n>\_INT\_CLR

Accesses to this register use the following encodings:

# Accessible at offset 0x0014 + (64 \* n) from MHUS.PBX.PFFCW\_page

Access on this interface is **WO/RAZ**.

# C2.1.1.3.8 PFFCW<n>\_INT\_EN, Postbox FIFO Channel Window <n> Interrupt Enable, n = 0 - 63

The PFFCW<n>\_INT\_EN characteristics are:

## Purpose

Configures the interrupts of FFCH<n>.

# Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_INT\_EN are RAZ/WI.

# Attributes

PFFCW<n>\_INT\_EN is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_INT\_EN bit assignments are:



Shows the status of the events of the DBCH

# FF, bit [31]

# FIFO Flush

Controls whether a FIFO flush event generated by the MHUR generates an interrupt.

| FF  | Meaning                                                         |
|-----|-----------------------------------------------------------------|
| 0b0 | A FIFO flush event from the MHUR does not generate an interrupt |
| 0b1 | A FIFO flush event from the MHUR generates an interrupt         |

The reset behavior of this field is:

• On a MHUS reset, this field resets to Ob1.

# Bits [30:3]

Reserved, RAZ.

## **FHT**, bit [2]

FIFO High Tidemark

Controls whether a Sender FIFO High Tidemark event generates an interrupt.

| FHT | Meaning                                                 |
|-----|---------------------------------------------------------|
| 060 | FIFO High Tidemark event does not generate an interrupt |

| FHT | Meaning                                         |
|-----|-------------------------------------------------|
| 0b1 | FIFO High Tidemark event generates an interrupt |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# FLT, bit [1]

FIFO Low Tidemark

Controls whether a Sender FIFO Low Tidemark event generates an interrupt.

| FLT | Meaning                                                    |
|-----|------------------------------------------------------------|
| 0b0 | FIFO Low Tidemark event has does not generate an interrupt |
| 0b1 | FIFO Low Tidemark event generates an interrupt             |

The reset behavior of this field is:

• On a MHUS reset, this field resets to Ob0.

# TFR\_ACK, bit [0]

Transfer Acknolwedge

Controls whether a Transfer Acknowledge event generates an interrupt.

| TFR_ACK | Meaning                                                    |
|---------|------------------------------------------------------------|
| 0b0     | Transfer Acknowledge events does not generate an interrupt |
| 0b1     | Transfer Acknowledge event generates an interrupt          |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# Accessing PFFCW<n>\_INT\_EN

Accesses to this register use the following encodings:

# Accessible at offset 0x0018 + (64 \* n) from MHUS.PBX.PFFCW\_page

Access on this interface is **RW**.

# C2.1.1.3.9 PFFCW<n>\_CTRL, Postbox FIFO Channel Window <n> Control, n = 0 - 63

The PFFCW<n>\_CTRL characteristics are:

## Purpose

Configures the behavior of FFCH<n>.

# Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_CTRL are RAZ/WI.

# Attributes

PFFCW<n>\_CTRL is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_CTRL bit assignments are:



# FF, bit [31]

FIFO Flush

Request a flush of the FFCH.

| FF  | Meaning                      |
|-----|------------------------------|
| 0b0 | No request to flush the FIFO |
| 0b1 | Request to flush the FIFO    |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# Bits [30:4]

Reserved, RESO.

# TDM, bits [3:2]

Transfer Delineation Mode

Selects which Transfer Delineation mode the MHU uses for the FFCH.

Transfer Delineation mode selects whether the MHU or software or a combination of both manages the SOT and EOT flags.

| TDM  | Meaning                                                       |
|------|---------------------------------------------------------------|
| 0600 | Software flag<br>Software is responsible for managing the SOT |

| TDM  | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b01 | <ul> <li>Partial flag</li> <li>Flags are managed partially by software and partially by the MHU.</li> <li>Upon selecting partial flag Transfer Delineation mode the PFFCW<n>_FLG.{SOT,EOT} fields are set to 0b1 and 0b0 respectively.</n></li> <li>No change occurs to the PFFCW<n>_FLG.ACK field.</n></li> <li>To update either the</li> <li>PFFCW<n>_FLG.{SOT/EOT} fields at least one of them must be set to 0b1, otherwise the update to those fields are ignored.</n></li> <li>When a push operation occurs the SOT and EOT fields are updated as follows: <ul> <li>SOT field is set to value of the EOT field before the push.</li> <li>EOT field is always set to 0b0.</li> </ul> </li> <li>To update only the value of the PFFCW<n>_FLG.ACK field when using partial flag Transfer Delineation mode, software should set both the SOT and EOT fields to 0b0.</n></li> </ul> |
| 0b10 | Auto flag<br>Flags are fully managed by the MHU.<br>Upon selecting auto flag Transfer Delineation<br>mode the PFFCW <n>_FLG.{SOT,EOT} fields<br/>are set to 0b1 and 0b0 respectively.<br/>No change occurs to the PFFCW<n>_FLG.ACK<br/>field.<br/>When a push operation occurs the values of the<br/>SOT and EOT fields toggle.<br/>The PFFCW<n>_FLG.{SOT/EOT} fields are<br/>read-only, but the PFFCW<n>_FLG.ACK field<br/>remains writeable.<br/>To update the value of the<br/>PFFCW<n>_FLG.ACK field when using the<br/>auto flag Transfer Delineation mode software<br/>can write any value ot the SOT and EOT fields as</n></n></n></n></n>                                                                                                                                                                                                                                    |

All other values are Reserved.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b00.

# MSBF, bit [1]

Most Significant Byte First

Selects the order in which bytes are pushed onto the FIFO when multiple bytes are to be pushed due to a single write to the PFFCW<n>\_PAY register.

| MSBF | Meaning                      |
|------|------------------------------|
| 0b0  | Least Significant Byte first |
| 0b1  | Most Significant Byte first  |

FFCH are considered little-endian and the LSB is the lowest byte offset and the MSB is the highest byte offset within the access.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

# PBX\_COMB\_EN, bit [0]

Postbox Combined Enable

Controls whether interrupts from the FFCH contribute to the Postbox Combined interrupt.

| PBX_COMB_EN | Meaning                                                              |
|-------------|----------------------------------------------------------------------|
| 0b0         | FFCH interrupts do not contribute to the Postbox Combined interrupt. |
| 0b1         | FFCH interrupts contribute to the Postbox Combined interrupt.        |

The reset behavior of this field is:

• On a MHUS reset, this field resets to Ob1.

Accessing PFFCW<n>\_CTRL

Accesses to this register use the following encodings:

# Accessible at offset 0x0020 + (64 \* n) from MHUS.PBX.PFFCW\_page

Access on this interface is **RW**.

# C2.1.1.3.10 PFFCW<n>\_ST, Postbox FIFO Channel Window <n> Status, n = 0 - 63

The PFFCW<n>\_ST characteristics are:

#### Purpose

Provides the status of FFCH<n>.

## Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_ST are RAZ/WI.

## Attributes

PFFCW<n>\_ST is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_ST bit assignments are:



# FF, bit [31]

FIFO Flush

Status of MHUS FIFO flush mechanism for the FFCH.

| FF  | Meaning                                                                                                                                                                                                                                                           |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060 | The meaning of this value depends on the value<br>of the PFFCW <n>_CTRL.FF field.<br/>When PFFCW<n>_CTRL.FF is 0b0<br/>Sender FIFO flush mechanism is idle<br/>When PFFCW<n>_CTRL.FF is 0b1<br/>Sender FIFO flush mechanism is performing a<br/>flush</n></n></n> |
| 0b1 | Sender FIFO flush completed                                                                                                                                                                                                                                       |

# Bits [30:17]

Reserved, RESO.

# PPE, bit [16]

Previous Push Error

Indicates whether a previous push to the FIFO caused an error

An error is when the previous write to the PFFCW<n>\_PAY register could not push all bytes onto the FIFO due to the FIFO not having enough invalid bytes.

| PPE | Meaning                                          |
|-----|--------------------------------------------------|
| 060 | No error has occurred on the last push operation |
| PPE | Meaning                                          |
|-----|--------------------------------------------------|
| 0b1 | An error has occurred on the last push operation |

Bits [15:11]

Reserved, RESO.

## FFS, bits [10:0]

FIFO Free Space

Indicates the number of invalid bytes in the FIFO

The maximum value returned is never greater than the FIFO Depth

## Accessing PFFCW<n>\_ST

Accesses to this register use the following encodings:

## Accessible at offset 0x0024 + (64 \* n) from MHUS.PBX.PFFCW\_page

# *C2.1.1.3.11* PFFCW<n>\_ACK\_CNT, Postbox FIFO Channel Window <n> Acknowledge Counter, n = 0 - 63

The PFFCW<n>\_ACK\_CNT characteristics are:

#### Purpose

Provides a count of the number of Transfers which the Receiver has acknowledged, for FFCH<n>, since the last time the register was read.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_ACK\_CNT are RAZ/WI.

#### Attributes

PFFCW<n>\_ACK\_CNT is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_ACK\_CNT bit assignments are:

| 31 12 | 11 | 10             | 0 |
|-------|----|----------------|---|
| RES0  |    | ACK_CNT        |   |
|       | L  | ACK CNT OVRFLW |   |

## Bits [31:12]

Reserved, RESO.

## ACK\_CNT\_OVRFLW, bit [11]

Acknowledge Counter Overflow

Indicate whether the Acknowledge counter has overflown.

| ACK_CNT_OVRFLW | Meaning                               |  |
|----------------|---------------------------------------|--|
| 0b0            | Acknowledge counter has not overflown |  |
| 0b1            | Acknowledge counter has overflown     |  |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

## ACK\_CNT, bits [10:0]

Acknowledge Count

Count of the number of Transfer Acknowledge events which have occurred since the last time the register was read.

When value of ACK\_CNT\_OVRFLW is set to 1 the value in this field no longer provides an accurate count of the number of Transfer Acknowledge events.

| ACK_CNT                       | Meaning                          |
|-------------------------------|----------------------------------|
| 0b000000000000<br>⇔b111111111 | Number of Acknowledged Transfers |

## Chapter C2. Registers C2.1. MHUS, MHU Sender

The maximum value of this field is calculated by  $2^{clog2((FFCH\_DEPTH/min\_transfer\_size)+1)} - 1$ .

Where min\_transfer\_size is minimum size of a Transfer in bytes which the Sender can send.

The value of min\_transfer\_size is determined from the values of the  $P\{8/16/32/64\}BA_SPT$  fields in the PBX\_FFCH\_CFG0 register.

| P8BA_SPT | P16BA_SPT | P32BA_SPT | P64BA_SPT | Minimum Transfer Size (Bytes) |
|----------|-----------|-----------|-----------|-------------------------------|
| 1        | Х         | Х         | Х         | 1                             |
| 0        | 1         | Х         | Х         | 2                             |
| 0        | 0         | 1         | Х         | 4                             |
| 0        | 0         | 0         | 1         | 8                             |

When the counter reaches maximum value and a new Acknowledge occurs the ACK\_CNT\_OVRFLW is set to 0b1 and the ACK\_CNT field wraps around.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0000000000.

## Accessing PFFCW<n>\_ACK\_CNT

Accesses to this register use the following encodings:

## Accessible at offset 0x0028 + (64 \* n) from MHUS.PBX.PFFCW\_page

## C2.1.1.3.12 PFFCW<n>\_TIDE, Postbox FIFO Channel Window <n> Tidemark, n = 0 - 63

The PFFCW<n>\_TIDE characteristics are:

## Purpose

Allows configuration of the low and high tidemark thresholds for the Sender tidemark events for FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to PFFCW<n>\_TIDE are RAZ/WI.

#### Attributes

PFFCW<n>\_TIDE is a 32-bit register.

This register is part of the MHUS.PBX.PFFCW\_page block.

#### **Field descriptions**

The PFFCW<n>\_TIDE bit assignments are:



## Bits [31:26]

Reserved, RESO.

#### HIGH, bits [25:16]

High Tide Mark

Threshold value used in the generation of the Sender FIFO High Tide event.

The event is generated when a push to the FIFO occurs, and the following are both true:

- The FIFO fill level before the push was less than or equal to the value of this field.
- The FIFO fill level after the push is greater than the value of this field.

| HIGH                       | Meaning                  |  |
|----------------------------|--------------------------|--|
| 0b0000000000<br>⇔b11111111 | Threshold value in bytes |  |

The upper and lower offset of this field depend on the configuration of the MHU.

The upper offset of this field is equal to clog2(FFCH\_DEPTH)+15.

The lower offset of this field depends on the supported access sizes to PFFCW<n>\_PAY register as follows:

- When PBX\_FFCH\_CFG.P8BA\_SPT is 0b1 the lower offset is 16.
- When PBX\_FFCH\_CFG.P8BA\_SPT is 0b0 and PBX\_FFCH\_CFG.P16BA\_SPT is 0b1 the lower offset is 17.
- When PBX\_FFCH\_CFG.P{8/16}BA\_SPT are both 0b0 and PBX\_FFCH\_CFG.P32BA\_SPT is 0b1 the lower offset is 18.
- When PBX\_FFCH\_CFG.P{8/16/32}BA\_SPT are all 0b0 and PBX\_FFCH\_CFG.P64BA\_SPT is 0b1 the lower offset is 19.

Any offsets above the upper offset or below the lower offset are RESO.

If the upper offset is less than the lower offset the entire field is RESO.

For calculations of the Sender High Tide event all offsets which are RES0 are used.

The reset behavior of this field is:

• On a MHUS reset, the expression (FFCH\_DEPTH - 1) [u:1].

Where:

u = tide\_upr()

l = tide\_lwr([P64BA\_SPT,P32BA\_SPT,P16BA\_SPT,P8BA\_SPT])

## Bits [15:10]

Reserved, RESO.

## LOW, bits [9:0]

Low Tide Mark

Threshold value used in the generation of the Sender FIFO Low Tide event.

The event is generated when a pop to the FIFO occurs, and the following are both true:

- The FIFO fill level before the pop was greater than the value of this field.
- The FIFO fill level after the pop is less than or equal the value of this field.

| LOW                         | Meaning                  |
|-----------------------------|--------------------------|
| 0b0000000000<br>∽b111111111 | Threshold value in bytes |

The upper and lower offset of this field depend on the configuration of the MHU.

The upper offset of this field is equal to clog2(FFCH\_DEPTH)-1.

The lower offset of this field depends on the supported access sizes to PFFCW<n>\_PAY register as follows:

- When PBX\_FFCH\_CFG.P8BA\_SPT is 0b1 the lower offset is 0.
- When PBX\_FFCH\_CFG.P8BA\_SPT is 0b0 and PBX\_FFCH\_CFG.P16BA\_SPT is 0b1 the lower offset is 1.
- When PBX\_FFCH\_CFG.P{8/16}BA\_SPT are both 0b0 and PBX\_FFCH\_CFG.P32BA\_SPT is 0b1 the lower offset is 2.
- When PBX\_FFCH\_CFG.P{8/16/32}BA\_SPT are all 0b0 and PBX\_FFCH\_CFG.P64BA\_SPT is 0b1 the lower offset is 3.

Any offsets above the upper offset or below the lower offset are RESO.

If the upper offset is less than the lower offset the entire field is RESO.

For calculations of the Sender High Tide event all offsets which are RES0 are used.

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b000000000.

## Accessing PFFCW<n>\_TIDE

Accesses to this register use the following encodings:

## Accessible at offset 0x002C + (64 \* n) from MHUS.PBX.PFFCW\_page

# C2.1.1.4 PFCW\_page, Postbox Fast Channel Windows Page

The PFCW\_page characteristics are:

## Purpose

Allows access to the PFCW.

Depending on the Fast Channel word-size either the PFCW<n>\_PAY32 or PFCW<n>\_PAY64 registers are implmented.

When the Fast Channel word-size is 32-bit

PFCW<n>\_PAY32 is implemented

There can be between 1 and 1024 PFCWs.

## When the Fast Channel word-size is 64-bit

PFCW<n>\_PAY64 is implemented

There can be between 1 and 512 PFCWs.

## Configuration

This Register Block is present only when FCE is implemented.

## Attributes

The PFCW\_page block is of size 4KB.

This block is part of the MHUS.PBX block.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                             | Name               | Notes                                                                                                            |
|------------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 0x000 + (4 * n)for n in<br>→1023:0 | PFCW <n>_PAY32</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x20<br>Accessor condition: When FCH_WS == 0x20 |
| 0x000 + (4 * n)for n in<br>↔1023:0 | PFCW <n>_PAY32</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x20<br>Accessor condition: When FCH_WS == 0x20 |
| 0x000 + (8 * n)for n in<br>⇔511:0  | PFCW <n>_PAY64</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x40<br>Accessor condition: When FCH_WS == 0x40 |
| 0x000 + (8 * n)for n in<br>⇔511:0  | PFCW <n>_PAY64</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x40<br>Accessor condition: When FCH_WS == 0x40 |

## C2.1.1.4.1 PFCW<n>\_PAY32, Postbox Fast Channel Window <n> Payload 32-bit, n = 0 - 1023

The PFCW<n>\_PAY32 characteristics are:

#### Purpose

Access to payload of FCH <n>

Arm recommends that accesses to these registers are atomic.

Note

This is the 32-bit version of the PFCW<n>\_PAY registers

#### Configuration

This register is present only when FCE is implemented and FCH\_WS == 0x20. Otherwise, direct accesses to PFCW<n>\_PAY32 are RAZ/WI.

#### Attributes

PFCW<n>\_PAY32 is a 32-bit register.

This register is part of the MHUS.PBX.PFCW\_page block.

#### **Field descriptions**

The PFCW<n>\_PAY32 bit assignments are:



## PAY, bits [31:0]

Payload for Channel <n>

A write to this register sets the value of the payload and generates a Transfer event.

A read to this register returns the current value of the payload.

The reset behavior of this field is:

• On a MHUR reset, this field resets to an architecturally UNKNOWN value.

## Accessing PFCW<n>\_PAY32

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (4 \* n) from MHUS.PBX.PFCW\_page

return PFCW<n>\_PAY32;

## Write at offset 0x000 + (4 \* n) from MHUS.PBX.PFCW\_page

PFCW<n>\_PAY32 = value;

## C2.1.1.4.2 PFCW<n>\_PAY64, Postbox Fast Channel Window <n> Payload 64-bit, n = 0 - 511

The PFCW<n>\_PAY64 characteristics are:

#### Purpose

Access to payload of FCH <n>

Arm recommends that accesses to these registers are atomic.

Note

This is the 64-bit version of the PFCW<n>\_PAY registers

#### Configuration

This register is present only when FCE is implemented and FCH\_WS == 0x40. Otherwise, direct accesses to PFCW<n>\_PAY64 are RAZ/WI.

#### Attributes

PFCW<n>\_PAY64 is a 64-bit register.

This register is part of the MHUS.PBX.PFCW\_page block.

## **Field descriptions**

The PFCW<n>\_PAY64 bit assignments are:



## PAY, bits [63:0]

Payload for Channel <n>

A write to this register sets the value of the payload and generates a Transfer event.

A read to this register returns the current value of the payload.

The reset behavior of this field is:

• On a MHUR reset, this field resets to an architecturally UNKNOWN value.

## Accessing PFCW<n>\_PAY64

Accesses to this register use the following encodings:

## Read at offset 0x000 + (8 \* n) from MHUS.PBX.PFCW\_page

return PFCW<n>\_PAY64;

## Write at offset 0x000 + (8 \* n) from MHUS.PBX.PFCW\_page

PFCW<n>\_PAY64 = value;

# C2.1.1.5 PBX\_IMPL\_DEF\_page, Postbox Implementation Defined page

The PBX\_IMPL\_DEF\_page characteristics are:

## Purpose

The PBX\_IMPL\_DEF\_page is for an implementation of the MHU, to implement any IMPLEMENTATION DEFINED registers.

Registers defined in this block must follow the rules in C1.7.3 IMPLEMENTATION DEFINED Page

#### Configuration

#### Attributes

The PBX\_IMPL\_DEF\_page block is of size 4KB.

This block is part of the MHUS.PBX block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                          | Name | Notes                                         |
|---------------------------------|------|-----------------------------------------------|
| 0x0000 + (4 * n)for n in 1023:0 | -    | Most permissive access: ImplementationDefined |

# C2.1.2 SSC, Sender Security Control

The SSC characteristics are:

## Purpose

Contains the individual pages of the Sender Security Control block.

Only accesses with the correct security can access the registers within the Sender Security Control block, otherwise the access is treated as an illegal access.

The allowed security of an access to a register of the Sender Security Control block depends on:

- Whether RME is implemented for the MHUS.
- Sampled value of MHUS LEGACY\_TZ\_EN input.

The following table list the allowed security states of an access:

| RME | TZE | LEGACY_TZ_EN | Allowed access security |
|-----|-----|--------------|-------------------------|
| 0   | 0   | NA           | NA                      |
| 0   | 1   | NA           | Secure                  |
| 1   | 1   | 0            | Root                    |
|     |     | 1            | Secure                  |

#### Configuration

This Register Block is present only when TZE is implemented for the MHUS.

#### Attributes

The SSC block is of size 64KB.

This block is part of the MHUS block.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset | Name              | Notes                      |
|--------|-------------------|----------------------------|
| 0x0000 | SSC_CTRL_page     | Most permissive access: RW |
| 0xF000 | SSC_IMPL_DEF_page | Most permissive access: RW |

# C2.1.2.1 SSC\_CTRL\_page, Sender Security Control Page

The SSC\_CTRL\_page characteristics are:

#### Purpose

Allow assignment of resources of the MHUS to a Security Group.

## Configuration

This Register Block is present only when TZE is implemented for the MHUS.

#### Attributes

The SSC\_CTRL\_page block is of size 4KB.

This block is part of the MHUS.SSC block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                       | Name                    | Notes                                                                                                                          |
|------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0x000                        | SSC_BLK_ID              | Most permissive access: RO                                                                                                     |
| 0x010                        | SSC_FEAT_SPT0           | Most permissive access: RO                                                                                                     |
| 0x014                        | SSC_FEAT_SPT1           | Most permissive access: RO                                                                                                     |
| 0x020                        | SSC_DBCH_CFG0           | Most permissive access: RO<br>Register condition: When DBE is<br>implemented<br>Accessor condition: When DBE is<br>implemented |
| 0x030                        | SSC_FFCH_CFG0           | Most permissive access: RO<br>Register condition: When FE is<br>implemented<br>Accessor condition: When FE is<br>implemented   |
| 0x040                        | SSC_FCH_CFG0            | Most permissive access: RO<br>Register condition: When FCE is<br>implemented<br>Accessor condition: When FCE is<br>implemented |
| 0x110 + (4 * n)for n in 0    | SSC_PBX_SG <n></n>      | Most permissive access: RW                                                                                                     |
| 0xFC8                        | SSC_IIDR                | Most permissive access: RO                                                                                                     |
| OxFCC                        | SSC_AIDR                | Most permissive access: RO                                                                                                     |
| 0xFD0 + (4 * n)for n in 11:0 | SSC_IMPL_DEF_ID <n></n> | Most permissive access: RO                                                                                                     |

## C2.1.2.1.1 SSC\_BLK\_ID, Sender Security Block Identifier

The SSC\_BLK\_ID characteristics are:

#### Purpose

Identifies the block as a Sender Security.

## Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_BLK\_ID are RAZ/WI.

## Attributes

SSC\_BLK\_ID is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_BLK\_ID bit assignments are:

| 31   | 4 | 3 |   |     | 0   |    |
|------|---|---|---|-----|-----|----|
| RES0 |   | 0 | 0 | 1   | 0   |    |
|      |   |   | l | _BI | _K_ | ID |

## Bits [31:4]

Reserved, RESO.

#### BLK\_ID, bits [3:0]

**Block Identifier** 

Identifies the type of block that resides in this 64KB.

Reads as 0b0010

Identifies the block as the Sender Security block.

Access to this field is RO.

Accessing SSC\_BLK\_ID

Accesses to this register use the following encodings:

## Accessible at offset 0x000 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.2 SSC\_FEAT\_SPT0, Sender Security Feature Support 0

The SSC\_FEAT\_SPT0 characteristics are:

#### Purpose

Provides information on the features implemented in the Sender Security.

## Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_FEAT\_SPT0 are RAZ/WI.

#### Attributes

SSC\_FEAT\_SPT0 is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_FEAT\_SPT0 bit assignments are:

| 31 24 | 23 20    | 19 16   | 15 12   | 11 8    | 7 4    | 3 0     |
|-------|----------|---------|---------|---------|--------|---------|
| RES0  | RASE_SPT | RME_SPT | TZE_SPT | FCE_SPT | FE_SPT | DBE_SPT |

## Bits [31:24]

Reserved, RESO.

## RASE\_SPT, bits [23:20]

Reliability, Availability and Serviceability Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RASE_SPT | Meaning                                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060000   | MHU does not implement the RAS extension                                                                                                                          |
| 060010   | MHU implements the RAS extension but does<br>not follow the recommendations in B10.7<br><i>Recommend implementation of RAS using Arm</i><br><i>RAS extensions</i> |
| 0b0011   | MHU implements the RAS extension and<br>follows the recommendations in B10.7<br><i>Recommend implementation of RAS using Arm</i><br><i>RAS extensions</i>         |

Access to this field is RO.

## RME\_SPT, bits [19:16]

Realm Management Extension Support

The value of this field depends on the implementation of the MHU and an optional reset time sampled input LEGACY\_TZ\_EN.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RME_SPT | Meaning                                                  |
|---------|----------------------------------------------------------|
| 0000d0  | MHU does not implement the Realm<br>Management extension |
| 0b0001  | MHU implements Realm Management extension                |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

When RME is implemented, for the half of the MHU, there can be a **LEGACY\_TZ\_EN** tie-off present on that side of the MHU.

The value of the LEGACY\_TZ\_EN tie-off is sampled at reset of the side of the MHU which the tie-off is associated with.

When the sampled value of the tie-off is 0b1 the value of this field is always 0x0, otherwise the value of this field is dependent on whether RME is implemented for this half of the MHU.

Access to this field is RO.

#### TZE\_SPT, bits [15:12]

TrustZone Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| TZE_SPT | Meaning                                        |
|---------|------------------------------------------------|
| 00000   | MHU does not implement the TrustZone extension |
| 0b0001  | MHU implements TrustZone extension             |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

Access to this field is RO.

## FCE\_SPT, bits [11:8]

Fast Channel Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCE_SPT | Meaning                                           |
|---------|---------------------------------------------------|
| 060000  | MHU does not implement the Fast Channel extension |

| FCE_SPT | Meaning                               |
|---------|---------------------------------------|
| 0b0001  | MHU implements Fast Channel extension |

Access to this field is **RO**.

## FE\_SPT, bits [7:4]

FIFO Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FE_SPT | Meaning                                   |
|--------|-------------------------------------------|
| 0000d0 | MHU does not implement the FIFO extension |
| 0b0001 | MHU implements FIFO extension             |

Access to this field is **RO**.

## DBE\_SPT, bits [3:0]

Doorbell Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| DBE_SPT | Meaning                                       |
|---------|-----------------------------------------------|
| 00000   | MHU does not implement the Doorbell extension |
| 0b0001  | MHU implements Doorbell extension             |

Access to this field is **RO**.

## Accessing SSC\_FEAT\_SPT0

Accesses to this register use the following encodings:

Accessible at offset 0x010 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.3 SSC\_FEAT\_SPT1, Sender Security Feature Support 1

The SSC\_FEAT\_SPT1 characteristics are:

#### Purpose

Provides information on the features implemented in the Sender Security.

## Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_FEAT\_SPT1 are RAZ/WI.

#### Attributes

SSC\_FEAT\_SPT1 is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_FEAT\_SPT1 bit assignments are:



## Bits [31:4]

Reserved, RESO.

## AUTO\_OP\_SPT, bits [3:0]

Auto Op Protocol Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| AUTO_OP_SPT | Meaning                      |
|-------------|------------------------------|
| 00000       | Auto Op(Min) is implemented  |
| 0b0001      | Auto Op(Full) is implemented |

Access to this field is **RO**.

Accessing SSC\_FEAT\_SPT1

Accesses to this register use the following encodings:

## Accessible at offset 0x014 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.4 SSC\_DBCH\_CFG0, Sender Security Doorbell Channel Configuration 0

The SSC\_DBCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of DBE in MHUS.

#### Configuration

This register is present only when TZE is implemented for the MHUS and DBE is implemented. Otherwise, direct accesses to SSC\_DBCH\_CFG0 are RAZ/WI.

## Attributes

SSC\_DBCH\_CFG0 is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_DBCH\_CFG0 bit assignments are:

| 31   | 8   7 | 7        | 0 |
|------|-------|----------|---|
| RESO |       | NUM_DBCH |   |

## Bits [31:8]

Reserved, RESO.

## NUM\_DBCH, bits [7:0]

Number of Doorbell Channels

Number of DBCH implemented in the MHUS.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_DBCH | Meaning                                                   |
|----------|-----------------------------------------------------------|
| 0x000x7F | Number of DBCH is N+1, where N is the value of this field |

Access to this field is **RO**.

Accessing SSC\_DBCH\_CFG0

Accesses to this register use the following encodings:

Accessible at offset 0x020 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.5 SSC\_FFCH\_CFG0, Sender Security FIFO Channel Configuration 0

The SSC\_FFCH\_CFG0 characteristics are:

## Purpose

Provides information on the configuration of FE in Sender Security.

## Configuration

This register is present only when TZE is implemented for the MHUS and FE is implemented. Otherwise, direct accesses to SSC\_FFCH\_CFG0 are RAZ/WI.

## Attributes

SSC\_FFCH\_CFG0 is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_FFCH\_CFG0 bit assignments are:



## Bits [31:26]

Reserved, RESO.

## FFCH\_DEPTH, bits [25:16]

FIFO Channel Depth

Depth of the FIFOs of the FFCHs in the MHUS.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FFCH_DEPTH                 | Meaning                                                      |
|----------------------------|--------------------------------------------------------------|
| 0b0000000000<br>⇔b11111111 | FIFO depth is N+1 bytes, where N is the value of this field. |

Access to this field is RO.

Bits [15:12]

Reserved, RESO.

## P64BA\_SPT, bit [11]

Postbox 64-bit Access Support

Whether 64-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P64BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0b0       | 64-bit accesses are not supported |
| 0b1       | 64-bit accesses are supported     |

Accesses must be aligned to an 64-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

When 64-bit accesses are supported the PFFCW<n>\_PAY register occupies offsets 0x00-0x07 of the PFFCW.

When 64-bit accesses are not supported the PFFCW<n>\_PAY register occupies offsets 0x00-0x03 of the PFFCW and offsets 0x04-0x07 of the PFFCW are RES0.

Access to this field is RO.

## P32BA\_SPT, bit [10]

Postbox 32-bit Access Support

Whether 32-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P32BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0d0       | 32-bit accesses are not supported |
| 0b1       | 32-bit accesses are supported     |

Accesses must be aligned to an 32-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

## P16BA\_SPT, bit [9]

Postbox 16-bit Access Support

Whether 16-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P16BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0d0       | 16-bit accesses are not supported |
| 0b1       | 16-bit accesses are supported     |

Accesses must be aligned to an 16-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is **RO**.

## P8BA\_SPT, bit [8]

Postbox 8-bit Access Support

Whether 8-bit accesses to the PFFCW<n>\_PAY register are supported.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| P8BA_SPT | Meaning |   |
|----------|---------|---|
|          |         | _ |

8-bit accesses are not supported

| P8BA_SPT | Meaning                      |
|----------|------------------------------|
| 0b1      | 8-bit accesses are supported |

Accesses must be aligned to an 8-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

## NUM\_FFCH, bits [7:0]

Number of FIFO Channels

The number of FFCHs in the MHUS.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FFCH | Meaning                                                    |
|----------|------------------------------------------------------------|
| 0x000x3F | Number of FFCHs is N+1, where N is the value of this field |

Access to this field is **RO**.

## Accessing SSC\_FFCH\_CFG0

Accesses to this register use the following encodings:

## Accessible at offset 0x030 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.6 SSC\_FCH\_CFG0, Sender Security Fast Channel Configuration 0

The SSC\_FCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of FCE in the MHUS.

#### Configuration

This register is present only when TZE is implemented for the MHUS and FCE is implemented. Otherwise, direct accesses to SSC\_FCH\_CFG0 are RAZ/WI.

## Attributes

SSC\_FCH\_CFG0 is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_FCH\_CFG0 bit assignments are:



## Bits [31:29]

Reserved, RESO.

## FCH\_WS, bits [28:21]

Fast Channel Word-Size

Number of bits each FCH implements.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCH_WS | Meaning                           |
|--------|-----------------------------------|
| 0x20   | Fast Channel word-size is 32-bits |
| 0x40   | Fast Channel word-size is 64-bits |

Access to this field is **RO**.

## NUM\_FCH\_PER\_FCG, bits [20:16]

Number of Fast Channels per Fast Channel Group

Number of FCHs implemented in FCGs for MHUS.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH_PER_FCG | Meaning                                                           |
|-----------------|-------------------------------------------------------------------|
| 0b000000b11111  | Number of FCHs per FCG is N+1, where N is the value of this field |

Access to this field is RO.

## NUM\_FCG, bits [15:11]

Number of Fast Channel Groups

Number of FCGs implemented in MHUS

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCG             | Meaning                                                   |
|---------------------|-----------------------------------------------------------|
| 0b000000<br>⇔b11111 | Number of FCGs is N+1, where N is the value of this field |

Access to this field is **RO**.

## NUM\_FCH, bits [9:0]

Number of Fast Channels

Number of FCHs implemented in MHUS.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH                      | Meaning                                                  | Applies             |
|------------------------------|----------------------------------------------------------|---------------------|
| 0b00000000000<br>∽b011111111 | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x40 |
| 0b0000000000<br>⇔b111111111  | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x20 |

Access to this field is **RO**.

## Accessing SSC\_FCH\_CFG0

Accesses to this register use the following encodings:

## Accessible at offset 0x040 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.7 SSC\_PBX\_SG<n>, Sender Postbox Security Group <ngt;, n = 0 - 0

The SSC\_PBX\_SG<n> characteristics are:

#### Purpose

Configuration of the Security Group of the Postbox

## Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_PBX\_SG<n> are RAZ/WI.

## Attributes

SSC\_PBX\_SG<n> is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_PBX\_SG<n> bit assignments are:

When RME is implemented for the MHUS and sampled value of MHUS LEGACY\_TZ\_EN is 0b0:



## Bits [31:2]

Reserved, RESO.

## SG\_PBX<m>, bits [2m+1:2m], for m = 0

Security Group for Postbox

| SG_PBX <m></m> | Meaning                                              |
|----------------|------------------------------------------------------|
| 0b00           | Postbox is assigned to the Secure Security Group     |
| 0b01           | Postbox is assigned to the Non-secure Security Group |
| 0b10           | Postbox is assigned to the Root Security Group       |
| 0b11           | Postbox is assigned to the Realm Security Group      |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b10.

When RME is not implemented for the MHUS or (RME is implemented for the MHUS and sampled value of MHUS LEGACY\_TZ\_EN is 0b1):



Bits [31:1]

Reserved, RESO.

## SG\_PBX<m>, bits [m], for m = 0

Security Group for Postbox

| SG_PBX <m></m> | Meaning                                              |
|----------------|------------------------------------------------------|
| 0b0            | Postbox is assigned to the Secure Security Group     |
| 0b1            | Postbox is assigned to the Non-secure Security Group |

The reset behavior of this field is:

• On a MHUS reset, this field resets to 0b0.

Accessing SSC\_PBX\_SG<n>

Accesses to this register use the following encodings:

## Accessible at offset 0x110 + (4 \* n) from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.8 SSC\_IIDR, Sender Security Implementer Identification Register

The SSC\_IIDR characteristics are:

#### Purpose

This field provides information on the implementation of the MHU

#### Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_IIDR are RAZ/WI.

## Attributes

SSC\_IIDR is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

#### **Field descriptions**

The SSC\_IIDR bit assignments are:

| 31         | 20 | 19 16   | 15 12    | 11 0        |
|------------|----|---------|----------|-------------|
| PRODUCT_ID |    | VARIANT | REVISION | IMPLEMENTER |

## PRODUCT\_ID, bits [31:20]

Product ID of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is **RO**.

## VARIANT, bits [19:16]

Variant or major revision of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

## **REVISION**, bits [15:12]

Revision or minor version of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

## **IMPLEMENTER**, bits [11:0]

Implementer ID

Contains the JEP106 identification information as follows:

- 11:8 JEP106 continuation code of implementer
- 7 Always 0
- 6:0 JEP106 identity code of implementer

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

## Accessing SSC\_IIDR

Accesses to this register use the following encodings:

Accessible at offset 0xFC8 from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.9 SSC\_AIDR, Sender Security Architecture Identification Register

The SSC\_AIDR characteristics are:

#### Purpose

Provides information on the version of the MHU architecture implemented in this implementation of the MHU.

#### Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_AIDR are RAZ/WI.

#### Attributes

SSC\_AIDR is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

## **Field descriptions**

The SSC\_AIDR bit assignments are:



## Bits [31:8]

Reserved, RESO.

## ARCH\_MAJOR\_REV, bits [7:4]

MHU Architecture Major Revision

The value of this field is an IMPLEMENTATION DEFINED choice of:

| ARCH_MAJOR_REV | Meaning                                |
|----------------|----------------------------------------|
| 000000         | MHUv1 or unknown architecture versions |
| 0b0001         | MHUv2                                  |
| 0b0010         | MHUv3                                  |

All other values are Reserved

Access to this field is RO.

## ARCH\_MINOR\_REV, bits [3:0]

MHU Architecture Minor Revision

The value of this field is an IMPLEMENTATION DEFINED choice of:

| ARCH_MINOR_REV | Meaning                                    |
|----------------|--------------------------------------------|
| 000000         | Minor revision 0 of the major architecture |
| 0b0001         | Minor revision 1 of the major architecture |

All other values are Reserved

Access to this field is RO.

## Additional information

The legal combinations for the ARCH\_MAJOR\_REV and ARCH\_MINOR\_REV fields are as follows:

| ARCH_MAJOR_REV | ARCH_MINOR_REV | Description |
|----------------|----------------|-------------|
| 0x0            | 0x0            | MHUv1       |
| 0x1            | 0x0            | MHUv2.0     |
| 0x1            | 0x1            | MHUv2.1     |
| 0x2            | 0x0            | MHUv3.0     |

MHU implementations based on this architecture, have the ARCH\_MAJOR\_REV set to 0x2 and ARCH\_MINOR\_REV set to 0x0.

## Accessing SSC\_AIDR

Accesses to this register use the following encodings:

## Accessible at offset 0xFCC from MHUS.SSC.SSC\_CTRL\_page

## C2.1.2.1.10 SSC\_IMPL\_DEF\_ID<n>, IMPDEF Register, n = 0 - 11

The SSC\_IMPL\_DEF\_ID<n> characteristics are:

#### Purpose

This register is for IMPLEMENTATION DEFINED Identification Registers which can be used to identify the implementation of the MHU Sender Security

An implementation can do the following with this register:

- Chose whether a register is present or not.
- The name of the register.
- The access permission of the registers, so long as they are not more permissive than the architecture defines for the IMPLEMENTATION DEFINED register.
- The names, behavior and reset value of any fields.
- The access permissions of any fields, so long as they are not more permissive than the register.

If the SSC\_IMPL\_DEF\_ID<n> is not present then the location is Reserved and treated as RESO

#### Configuration

This register is present only when TZE is implemented for the MHUS. Otherwise, direct accesses to SSC\_IMPL\_DEF\_ID<n> are RAZ/WI.

#### Attributes

SSC\_IMPL\_DEF\_ID<n> is a 32-bit register.

This register is part of the MHUS.SSC.SSC\_CTRL\_page block.

## **Field descriptions**

The SSC\_IMPL\_DEF\_ID<n> bit assignments are:

IMPLEMENTATION DEFINED

#### **IMPLEMENTATION DEFINED, bits [31:0]**

IMPLEMENTATION DEFINED

## Accessing SSC\_IMPL\_DEF\_ID<n>

Accesses to this register use the following encodings:

Accessible at offset 0xFD0 + (4 \* n) from MHUS.SSC.SSC\_CTRL\_page

# C2.1.2.2 SSC\_IMPL\_DEF\_page, Sender Security Control Implementation Defined page

The SSC\_IMPL\_DEF\_page characteristics are:

## Purpose

The SSC\_IMPL\_DEF\_page is for an implementation of the MHU, to implement any IMPLEMENTATION DEFINED registers.

Registers defined in this block must follow the rules in C1.7.3 IMPLEMENTATION DEFINED Page

## Configuration

This Register Block is present only when TZE is implemented for the MHUS.

## Attributes

The SSC\_IMPL\_DEF\_page block is of size 4KB.

This block is part of the MHUS.SSC block.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                          | Name | Notes                                         |
|---------------------------------|------|-----------------------------------------------|
| 0x0000 + (4 * n)for n in 1023:0 | -    | Most permissive access: ImplementationDefined |

# C2.2 MHUR, MHU Receiver

The MHUR characteristics are:

## Purpose

Contains the blocks which are part of the MHU Receiver

The offsets of the blocks, within the MHU Receiver are IMPLEMENTATION DEFINED, however, Arm recommends the following offsets:

## When TZE is implemented for the MHUR

0x0\_0000 - RSC

0x1\_0000 - MBX

## When TZE is not implemented for the MHUR

0x0\_0000 - MBX

## Attributes

## When TZE is implemented for the MHUR

The MHUR block is of size 128KB.

## When TZE is not implemented for the MHUR

The MHUR block is of size 64KB.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset | Name | Notes                                                                                                                                              |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| IMPDEF | RSC  | Most permissive access: RW<br>Register condition: When TZE is implemented for the MHUR<br>Accessor condition: When TZE is implemented for the MHUR |
| IMPDEF | MBX  | Most permissive access: RW                                                                                                                         |

# C2.2.1 MBX, Mailbox

The MBX characteristics are:

## Purpose

Contains the individual pages of the Mailbox block.

Only accesses with the correct security can access the registers within the Mailbox, otherwise the access is treated as an illegal access

The allowed security of an access to a register of the Mailbox depends on:

- The value of RME is implemented for the MHUR.
- Whether TZE is implemented for the MHUR.
- Sampled value of MHUR LEGACY\_TZ\_EN input.
- Value of RSC\_CTRL\_page.RSC\_MBX\_SG0.SG\_MBX0 field.

The following table list the allowed security states of an access:

| RME | TZE | Sampled<br>LEGACY_TZ_EN | RSC_MBX_SG0.SG_MBX0 | Allowed access securities |
|-----|-----|-------------------------|---------------------|---------------------------|
| 0   | 0   | NA                      | NA                  | Any                       |
| 0   | 1   | NA                      | 0b0                 | Secure                    |
|     |     |                         | 0b1                 | Any                       |
| 1   | 1   | 0                       | 0b00                | Root and Secure           |
|     |     |                         | 0b01                | Any                       |
|     |     |                         | 0b10                | Root                      |
|     |     |                         | 0b11                | Root and Realm            |
|     |     | 1                       | 0bx0                | Root and Secure           |
|     |     |                         | 0bx1                | Any                       |

## Configuration

#### Attributes

The MBX block is of size 64KB.

This block is part of the MHUR block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset | Name          | Notes                                                                                                                    |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x0000 | MBX_CTRL_page | Most permissive access: RW                                                                                               |
| 0x1000 | MDBCW_page    | Most permissive access: RW<br>Register condition: When DBE is implemented<br>Accessor condition: When DBE is implemented |

## Chapter C2. Registers C2.2. MHUR, MHU Receiver

| Offset | Name              | Notes                                                                                                                    |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x2000 | MFFCW_page        | Most permissive access: RW<br>Register condition: When FE is implemented<br>Accessor condition: When FE is implemented   |
| 0x3000 | MFCW_page         | Most permissive access: RW<br>Register condition: When FCE is implemented<br>Accessor condition: When FCE is implemented |
| 0xF000 | MBX_IMPL_DEF_page | Most permissive access: RW                                                                                               |

# C2.2.1.1 MBX\_CTRL\_page, Mailbox Control page

The MBX\_CTRL\_page characteristics are:

## Purpose

Allows access to the configuration registers of the Mailbox.

## Configuration

#### Attributes

The MBX\_CTRL\_page block is of size 4KB.

This block is part of the MHUR.MBX block.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset | Name           | Notes                                                                                                                                               |
|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x000  | MBX_BLK_ID     | Most permissive access: RO                                                                                                                          |
| 0x010  | MBX_FEAT_SPT0  | Most permissive access: RO                                                                                                                          |
| 0x014  | MBX_FEAT_SPT1  | Most permissive access: RO                                                                                                                          |
| 0x020  | MBX_DBCH_CFG0  | Most permissive access: RO<br>Register condition: When DBE<br>is implemented<br>Accessor condition: When DBE<br>is implemented                      |
| 0x030  | MBX_FFCH_CFG0  | Most permissive access: RO<br>Register condition: When FE is<br>implemented<br>Accessor condition: When FE is<br>implemented                        |
| 0x040  | MBX_FCH_CFG0   | Most permissive access: RO<br>Register condition: When FCE is<br>implemented<br>Accessor condition: When FCE<br>is implemented                      |
| 0x100  | MBX_CTRL       | Most permissive access: RW                                                                                                                          |
| 0x140  | MBX_FCH_CTRL   | Most permissive access: RW<br>Register condition: When FCE is<br>implemented<br>Accessor condition: When FCE<br>is implemented                      |
| 0x144  | MBX_FCG_INT_EN | Most permissive access: RW<br>Register condition: When FCE is<br>implemented and FCGI_SPT ==<br>1<br>Accessor condition: When FCE<br>is implemented |

| Offset                           | Name                       | Notes                                                                                                                                               |
|----------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x400 + (4 * n)for n in 3:0      | MBX_DBCH_INT_ST <n></n>    | Most permissive access: RO<br>Register condition: When DBE<br>is implemented<br>Accessor condition: When DBE<br>is implemented                      |
| 0x410 + (4 * n)for n in 1:0      | MBX_FFCH_INT_ST <n></n>    | Most permissive access: RO<br>Register condition: When FE is<br>implemented<br>Accessor condition: When FE is<br>implemented                        |
| 0x470                            | MBX_FCG_INT_ST             | Most permissive access: RO<br>Register condition: When FCE is<br>implemented and FCGI_SPT ==<br>1<br>Accessor condition: When FCE<br>is implemented |
| 0x480 + (4 * n)for n in<br>⇔31:0 | MBX_FCH_GRP <n>_INT_ST</n> | Most permissive access: RO<br>Register condition: When FCE is<br>implemented and FCGI_SPT ==<br>1<br>Accessor condition: When FCE<br>is implemented |
| 0xFC8                            | MBX_IIDR                   | Most permissive access: RO                                                                                                                          |
| OxFCC                            | MBX_AIDR                   | Most permissive access: RO                                                                                                                          |
| 0xFD0 + (4 * n)for n in<br>⇔11.0 | MBX_IMPL_DEF_ID <n></n>    | Most permissive access: RO                                                                                                                          |

## C2.2.1.1.1 MBX\_BLK\_ID, Mailbox Block Identifier

The MBX\_BLK\_ID characteristics are:

## Purpose

Identifies the block as a Mailbox.

## Attributes

MBX\_BLK\_ID is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

## **Field descriptions**

The MBX\_BLK\_ID bit assignments are:

| 1 | 31 4 | 3 |   |     | 0   |    |
|---|------|---|---|-----|-----|----|
|   | RES0 | 0 | 0 | 0   | 1   |    |
|   |      |   | l | _BL | .K_ | ID |

## Bits [31:4]

Reserved, RESO.

## BLK\_ID, bits [3:0]

Block Identifier

Identifies the type of block that resides in this 64KB.

Reads as 0b0001

Identifies the block as the Mailbox block.

Access to this field is RO.

## Accessing MBX\_BLK\_ID

Accesses to this register use the following encodings:

## Accessible at offset 0x000 from MHUR.MBX.MBX\_CTRL\_page
## C2.2.1.1.2 MBX\_FEAT\_SPT0, Mailbox Feature Support 0

The MBX\_FEAT\_SPT0 characteristics are:

## Purpose

Provides information on the features implemented in the Mailbox.

#### Attributes

MBX\_FEAT\_SPT0 is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FEAT\_SPT0 bit assignments are:

| 31 24 | 23 20    | 19 16   | 15 12   | 11 8    | 7 4    | <sub>1</sub> 3 0 |
|-------|----------|---------|---------|---------|--------|------------------|
| RES0  | RASE_SPT | RME_SPT | TZE_SPT | FCE_SPT | FE_SPT | DBE_SPT          |

## Bits [31:24]

Reserved, RESO.

## RASE\_SPT, bits [23:20]

Reliability, Availability and Serviceability Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RASE_SPT | Meaning                                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000000   | MHU does not implement the RAS extension                                                                                                                          |
| 060010   | MHU implements the RAS extension but does<br>not follow the recommendations in B10.7<br><i>Recommend implementation of RAS using Arm</i><br><i>RAS extensions</i> |
| 0b0011   | MHU implements the RAS extension and follows the recommendations in B10.7 <i>Recommend implementation of RAS using Arm RAS extensions</i>                         |

Access to this field is RO.

## **RME\_SPT**, bits [19:16]

Realm Management Extension Support

The value of this field depends on the implementation of the MHU and an optional reset time sampled input LEGACY\_TZ\_EN.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RME_SPT | Meaning                                                  |
|---------|----------------------------------------------------------|
| 060000  | MHU does not implement the Realm<br>Management extension |

| RME_SPT | Meaning                                   |
|---------|-------------------------------------------|
| 0b0001  | MHU implements Realm Management extension |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

When RME is implemented, for the half of the MHU, there can be a **LEGACY\_TZ\_EN** tie-off present on that side of the MHU.

The value of the LEGACY\_TZ\_EN tie-off is sampled at reset of the side of the MHU which the tie-off is associated with.

When the sampled value of the tie-off is 0b1 the value of this field is always 0x0, otherwise the value of this field is dependent on whether RME is implemented for this half of the MHU.

Access to this field is **RO**.

#### TZE\_SPT, bits [15:12]

TrustZone Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| TZE_SPT | Meaning                                        |
|---------|------------------------------------------------|
| 00000   | MHU does not implement the TrustZone extension |
| 0b0001  | MHU implements TrustZone extension             |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

Access to this field is RO.

## FCE\_SPT, bits [11:8]

Fast Channel Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCE_SPT | Meaning                                           |
|---------|---------------------------------------------------|
| 0000d0  | MHU does not implement the Fast Channel extension |
| 0b0001  | MHU implements Fast Channel extension             |

Access to this field is **RO**.

FE\_SPT, bits [7:4]

FIFO Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FE_SPT | Meaning                                   |
|--------|-------------------------------------------|
| 000000 | MHU does not implement the FIFO extension |
| 0b0001 | MHU implements FIFO extension             |

Access to this field is **RO**.

## DBE\_SPT, bits [3:0]

Doorbell Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| DBE_SPT | Meaning                                       |
|---------|-----------------------------------------------|
| 00000   | MHU does not implement the Doorbell extension |
| 0b0001  | MHU implements Doorbell extension             |

Access to this field is **RO**.

## Accessing MBX\_FEAT\_SPT0

Accesses to this register use the following encodings:

## Accessible at offset 0x010 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.3 MBX\_FEAT\_SPT1, Mailbox Feature Support 1

The MBX\_FEAT\_SPT1 characteristics are:

## Purpose

Provides information on the features implemented in the Mailbox.

## Attributes

MBX\_FEAT\_SPT1 is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FEAT\_SPT1 bit assignments are:

| 31 4 | 3 | 0     |         |
|------|---|-------|---------|
| RES0 |   |       |         |
|      |   | LAUTO | _OP_SPT |

## Bits [31:4]

Reserved, RESO.

## AUTO\_OP\_SPT, bits [3:0]

Auto Op Protocol Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| AUTO_OP_SPT | Meaning                      |
|-------------|------------------------------|
| 060000      | Auto Op(Min) is implemented  |
| 0b0001      | Auto Op(Full) is implemented |

Access to this field is **RO**.

## Accessing MBX\_FEAT\_SPT1

Accesses to this register use the following encodings:

## Accessible at offset 0x014 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.4 MBX\_DBCH\_CFG0, Mailbox Doorbell Channel Configuration 0

The MBX\_DBCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of DBE in Mailbox.

#### Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MBX\_DBCH\_CFG0 are RAZ/WI.

#### Attributes

MBX\_DBCH\_CFG0 is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_DBCH\_CFG0 bit assignments are:

| 31   | 8   7 | 0        |
|------|-------|----------|
| RES0 |       | NUM_DBCH |

## Bits [31:8]

Reserved, RESO.

#### NUM\_DBCH, bits [7:0]

Number of Doorbell Channels

Number of DBCH implemented in the Mailbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

## NUM\_DBCH Meaning

 $0 \times 00..0 \times 7F$  Number of DBCH is N+1, where N is the value of this field

Access to this field is **RO**.

Accessing MBX\_DBCH\_CFG0

Accesses to this register use the following encodings:

Accessible at offset 0x020 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.5 MBX\_FFCH\_CFG0, Mailbox FIFO Channel Configuration 0

The MBX\_FFCH\_CFG0 characteristics are:

## Purpose

Provides information on the configuration of FE in Mailbox.

## Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MBX\_FFCH\_CFG0 are RAZ/WI.

## Attributes

MBX\_FFCH\_CFG0 is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FFCH\_CFG0 bit assignments are:



## Bits [31:26]

Reserved, RESO.

## FFCH\_DEPTH, bits [25:16]

FIFO Channel Depth

Depth of the FIFOs of the FFCHs in the Mailbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FFCH_DEPTH                 | Meaning                                                      |
|----------------------------|--------------------------------------------------------------|
| 0b0000000000<br>⇔b11111111 | FIFO depth is N+1 bytes, where N is the value of this field. |

Access to this field is **RO**.

Bits [15:12]

Reserved, RESO.

## M64BA\_SPT, bit [11]

Mailbox 64-bit Access Support

Whether 64-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M64BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0b0       | 64-bit accesses are not supported |
| 0b1       | 64-bit accesses are supported     |

Accesses must be aligned to an 64-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

When 64-bit accesses are supported the:

- MFFCW<n>\_PAY register occupies offsets 0x00-0x07 of the MFFCW.
- MFFCW<n>\_FLG register occupies offsets 0x008-0x0F of the MFFCW.

When 64-bit accesses are not supported:

- MFFCW<n>\_PAY register occupies offsets 0x00-0x03 of the MFFCW and offsets 0x04-0x07 of the MFFCW are RES0.
- MFFCW<n>\_FLG register occupies offsets 0x008-0x0B of the MFFCW and offsets 0x0C-0x0F of the MFFCW are RES0.

Access to this field is RO.

#### M32BA\_SPT, bit [10]

Mailbox 32-bit Access Support

Whether 32-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M32BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0d0       | 32-bit accesses are not supported |
| 0b1       | 32-bit accesses are supported     |

Accesses must be aligned to an 32-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

## M16BA\_SPT, bit [9]

Mailbox 16-bit Access Support

Whether 16-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M16BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0b0       | 16-bit accesses are not supported |
| 0b1       | 16-bit accesses are supported     |

Accesses must be aligned to an 16-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is **RO**.

# M8BA\_SPT, bit [8]

Mailbox 8-bit Access Support

Whether 8-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M8BA_SPT | Meaning                          |
|----------|----------------------------------|
| 0b0      | 8-bit accesses are not supported |
| 0b1      | 8-bit accesses are supported     |

Accesses must be aligned to an 8-bit boundary

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is **RO**.

## NUM\_FFCH, bits [7:0]

Number of FIFO Channels

The number of FFCHs in the Mailbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FFCH | Meaning                                                    |
|----------|------------------------------------------------------------|
| 0x000x3F | Number of FFCHs is N+1, where N is the value of this field |

Access to this field is **RO**.

## Accessing MBX\_FFCH\_CFG0

Accesses to this register use the following encodings:

## Accessible at offset 0x030 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.6 MBX\_FCH\_CFG0, Mailbox Fast Channel Configuration 0

The MBX\_FCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of FCE in the Mailbox.

#### Configuration

This register is present only when FCE is implemented. Otherwise, direct accesses to MBX\_FCH\_CFG0 are RAZ/WI.

#### Attributes

MBX\_FCH\_CFG0 is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FCH\_CFG0 bit assignments are:



## Bits [31:29]

Reserved, RESO.

## FCH\_WS, bits [28:21]

Fast Channel Word-Size

Number of bits each FCH implements.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCH_WS | Meaning                           |
|--------|-----------------------------------|
| 0x20   | Fast Channel word-size is 32-bits |
| 0x40   | Fast Channel word-size is 64-bits |

Access to this field is **RO**.

## NUM\_FCH\_PER\_FCG, bits [20:16]

Number of Fast Channels per Fast Channel Group

Number of FCHs implemented in FCGs for Mailbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH_PER_FCG | Meaning                                                           |
|-----------------|-------------------------------------------------------------------|
| 0b000000b11111  | Number of FCHs per FCG is N+1, where N is the value of this field |

Access to this field is RO.

## NUM\_FCG, bits [15:11]

Number of Fast Channel Groups

Number of FCGs implemented in Mailbox

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCG             | Meaning                                                   |
|---------------------|-----------------------------------------------------------|
| 0b000000<br>⇔b11111 | Number of FCGs is N+1, where N is the value of this field |

Access to this field is RO.

## FCGI\_SPT, bit [10]

Fast Channel Group Interrupt Support

Indicates whether Fast Channel Group Transfer interrupt is implemented for each FCGs.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCGI_SPT | Meaning                                                     |
|----------|-------------------------------------------------------------|
| 060      | Fast Channel Group Transfer interrupts are not implemented. |
| 0b1      | Fast Channel Group Transfer interrupts are implemented.     |

Access to this field is RO.

## NUM\_FCH, bits [9:0]

Number of Fast Channels

Number of FCHs implemented in Mailbox.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH                     | Meaning                                                  | Applies             |
|-----------------------------|----------------------------------------------------------|---------------------|
| 0b0000000000<br>∽b011111111 | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x40 |
| 0b0000000000<br>⇔b11111111  | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x20 |

Access to this field is RO.

## Accessing MBX\_FCH\_CFG0

Accesses to this register use the following encodings:

## Accessible at offset 0x040 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.7 MBX\_CTRL, Mailbox Control

The MBX\_CTRL characteristics are:

## Purpose

Configures the behavior of the Mailbox.

## Attributes

MBX\_CTRL is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_CTRL bit assignments are:

| L <sup>31</sup> 2 | 1 | 0 |        |
|-------------------|---|---|--------|
| RES0              |   |   |        |
| CH_OP_MSK         |   | Τ | OP_REQ |

## Bits [31:2]

Reserved, RESO.

# CH\_OP\_MSK, bit [1]

Channel Operational Mask

Controls whether channels need to be idle to allow a controlled entry of the MHUR into a non-operational state.

| CH_OP_MSK | Meaning                                                                        |
|-----------|--------------------------------------------------------------------------------|
| 060       | Channels must be idle to enter a non-operational state                         |
| 0b1       | Channels status is ignored when considering entry into a non-operational state |

This field has no effect on entry into a non-operation state in an uncontrolled manner for the MHUR.

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## OP\_REQ, bit [0]

**Operational Request** 

Controls whether the MHUR is required to remain in an operational state.

| OP_REQ | Meaning                                                     |
|--------|-------------------------------------------------------------|
| 0b0    | Mailbox is not requested to remain in the operational state |
| 0b1    | Mailbox is requested to remain in the operational state     |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## Accessing MBX\_CTRL

Accesses to this register use the following encodings:

## Accessible at offset 0x100 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.8 MBX\_FCH\_CTRL, Mailbox Fast Channel Control

The MBX\_FCH\_CTRL characteristics are:

#### Purpose

Controls the Fast Channels in the Mailbox

#### Configuration

This register is present only when FCE is implemented. Otherwise, direct accesses to MBX\_FCH\_CTRL are RAZ/WI.

#### Attributes

MBX\_FCH\_CTRL is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FCH\_CTRL bit assignments are:



## Bits [31:3]

Reserved, RESO.

#### INT\_EN, bit [2]

Interrupt Enable

Enables interrupts for all FCHs in the Mailbox.

| INT_EN | Meaning                                           |
|--------|---------------------------------------------------|
| 0b0    | Interrupts for FCHs, in the Mailbox, are disabled |
| 0b1    | Interrupts for FCHs, in the Mailbox, are enabled  |

The reset behavior of this field is:

• On a MHUR reset, this field resets to Ob1.

## Bits [1:0]

Reserved, RESO.

## Accessing MBX\_FCH\_CTRL

Accesses to this register use the following encodings:

## Accessible at offset 0x140 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.9 MBX\_FCG\_INT\_EN, Mailbox Fast Channel Group Interrupt Enable

The MBX\_FCG\_INT\_EN characteristics are:

#### Purpose

Controls whether a FCG contributes to the Mailbox Combined interrupt

## Configuration

This register is present only when FCE is implemented and FCGI\_SPT == 1. Otherwise, direct accesses to MBX\_FCG\_INT\_EN are RAZ/WI.

## Attributes

MBX\_FCG\_INT\_EN is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FCG\_INT\_EN bit assignments are:



## MBX\_COMB\_EN<m>, bits [m], for m = 31 to 0

| MBX_COMB_EN <m></m> | Meaning                                                               |
|---------------------|-----------------------------------------------------------------------|
| 040                 | FCG <m> does not contribute to the Mailbox<br/>Combined interrupt</m> |
| 0b1                 | FCG <m> contributes to the Mailbox Combined interrupt</m>             |

The field is only implemented, if the associated FCG is implemented. Fields which are not implemented are RESO. The reset behavior of this field is:

• On a MHUR reset, this field resets to Ob1.

## Accessing MBX\_FCG\_INT\_EN

Accesses to this register use the following encodings:

## Accessible at offset 0x144 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.10 MBX\_DBCH\_INT\_ST<n>, Mailbox Doorbell Channel Interrupt Status <n>, n = 0 - 3

The MBX\_DBCH\_INT\_ST<n> characteristics are:

## Purpose

Indicates whether there is an interrupt outstanding for the DBCH

MBX\_DBCH\_INT\_ST0 has status fields for DBCHs 0 to 31

MBX\_DBCH\_INT\_ST1 has status fields for DBCHs 32 to 63

MBX\_DBCH\_INT\_ST2 has status fields for DBCHs 64 to 95

MBX\_DBCH\_INT\_ST3 has status fields for DBCHs 96 to 127

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MBX\_DBCH\_INT\_ST<n> are RAZ/WI.

## Attributes

MBX\_DBCH\_INT\_ST<n> is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### Field descriptions

The MBX\_DBCH\_INT\_ST<n> bit assignments are:



## DBCH\_INT\_ST<x>, bits [x], for x = 31 to 0

Doorbell Channel Interrupt Status

Each bit indicates whether there is an outstanding interrupt for the DBCH, that is contributing to the Mailbox Combined interrupt.

| DBCH_INT_ST <x></x> | Meaning                                                                                    |
|---------------------|--------------------------------------------------------------------------------------------|
| 060                 | No interrupt outstanding for the DBCH or the DBCH is not configured to contribute into the |
|                     | Mailbox Combined interrupt.                                                                |

| DBCH_INT_ST <x></x> | Meaning                                                                                                          |
|---------------------|------------------------------------------------------------------------------------------------------------------|
| 0b1                 | Interrupt outstanding for the DBCH and the DBCH is configured to contribute into the Mailbox Combined interrupt. |

Any fields which are not assigned to a DBCH are Reserved and treated as RAZ/WI

## Accessing MBX\_DBCH\_INT\_ST<n>

Accesses to this register use the following encodings:

## Accessible at offset 0x400 + (4 \* n) from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.11 MBX\_FFCH\_INT\_ST<n>, Mailbox FIFO Channel Interrupt Status <n>, n = 0 - 1

The MBX\_FFCH\_INT\_ST<n> characteristics are:

## Purpose

Indicates whether there is an interrupt outstanding for the FFCH.

MBX\_FFCH\_INT\_ST0 has status fields for FFCHs 0 to 31

MBX\_FFCH\_INT\_ST1 has status fields for FFCHs 32 to 63

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MBX\_FFCH\_INT\_ST<n> are RAZ/WI.

## Attributes

MBX\_FFCH\_INT\_ST<n> is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

## Field descriptions

The MBX\_FFCH\_INT\_ST<n> bit assignments are:



## FFCH\_INT\_ST<x>, bits [x], for x = 31 to 0

FIFO Channel Interrupt Status

Each bit indicates whether there is an outstanding interrupt for the FFCH, that is contributing to the Mailbox Combined interrupt.

| FFCH_INT_ST <x></x> | Meaning                                                                                                                |
|---------------------|------------------------------------------------------------------------------------------------------------------------|
| 060                 | No interrupt outstanding for the FFCH or the FFCH is not configured to contribute into the Mailbox Combined interrupt. |
| 0b1                 | Interrupt outstanding for the FFCH and the FFCH is configured to contribute into the Mailbox Combined interrupt.       |

Any fields which are not assigned to a FFCH are Reserved and treated as RAZ/WI

## Accessing MBX\_FFCH\_INT\_ST<n>

Accesses to this register use the following encodings:

## Accessible at offset 0x410 + (4 \* n) from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.12 MBX\_FCG\_INT\_ST, Mailbox Fast Channel Group Interrupt Status

The MBX\_FCG\_INT\_ST characteristics are:

#### Purpose

Provides the status of each Fast Channel Group Transfer interrupt

#### Configuration

This register is present only when FCE is implemented and FCGI\_SPT == 1. Otherwise, direct accesses to MBX\_FCG\_INT\_ST are RAZ/WI.

## Attributes

MBX\_FCG\_INT\_ST is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_FCG\_INT\_ST bit assignments are:



## FCH\_GRP<n>\_INT\_ST, bits [n], for n = 31 to 0

Fast Channel Group Interrupt Status

Each bit indicates whether there is an outstanding interrupt for an FCH which is part of FCG<m>, that is contributing to the Mailbox Combined interrupt.

| FCH_GRP <n>_INT_ST</n> | Meaning                                                                                                                                   |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 060                    | No Fast Channel Group Transfer interrupt for FCG <m> or FCG<m> is configured not to contribute to the Mailbox Combined interrupt.</m></m> |
| 0b1                    | Fast Channel Group Transfer interrupt for FCG <m> and FCG<m> is configured to contribute to the Mailbox Combined interrupt.</m></m>       |

Any fields which are not assigned to an implemented FCG are RES0.

## Accessing MBX\_FCG\_INT\_ST

Accesses to this register use the following encodings:

# Accessible at offset 0x470 from MHUR.MBX.MBX\_CTRL\_page

# C2.2.1.1.13 MBX\_FCH\_GRP<n>\_INT\_ST, Mailbox Fast Channel Group <n> Interrupt Status, n = 0 - 31

The MBX\_FCH\_GRP<n>\_INT\_ST characteristics are:

## Purpose

Provides the status of each FCH with the Fast Channel Group<n>

The number of MBX\_FCH\_GRP<n>\_INT\_ST is set by the value of MBX\_FCH\_CFG0.NUM\_FCG, with any unused registers being RES0.

The number of fields within each register depends on the value of MBX\_FCH\_CFG0.NUM\_FCH\_PER\_FCG, with any unused fields being RES0.

## Configuration

This register is present only when FCE is implemented and FCGI\_SPT == 1. Otherwise, direct accesses to MBX\_FCH\_GRP<n>\_INT\_ST are RAZ/WI.

## Attributes

MBX\_FCH\_GRP<n>\_INT\_ST is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

## **Field descriptions**

The MBX\_FCH\_GRP<n>\_INT\_ST bit assignments are:



## FCH\_INT\_ST<m>, bits [m], for m = 31 to 0

Fast Channel Interrupt Status

Each bit indicates whether there is an outstanding interrupt for the FCH, within FCG<n>, that is contributing to the Mailbox Combined interrupt.

| FCH_INT_ST <m></m> | Meaning                                  |
|--------------------|------------------------------------------|
| 0b0                | No interrupt outstanding for FCH <x></x> |
| 0b1                | Outstanding interrupt for FCH <x></x>    |

Where x is the FCH number and is calculated by the following formula: n\*NUM\_FCH\_PER\_FCG + m.

#### Chapter C2. Registers C2.2. MHUR, MHU Receiver

Any fields which are not assigned to an implemented FCH are RESO.

## Accessing MBX\_FCH\_GRP<n>\_INT\_ST

Accesses to this register use the following encodings:

## Accessible at offset 0x480 + (4 \* n) from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.14 MBX\_IIDR, Mailbox Implementer Identification Register

The MBX\_IIDR characteristics are:

#### Purpose

This field provides information on the implementation of the MHU

#### Attributes

MBX\_IIDR is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_IIDR bit assignments are:

| 31         | 20 I | 19 16   | 15 12    | 11 0        |
|------------|------|---------|----------|-------------|
| PRODUCT_ID |      | VARIANT | REVISION | IMPLEMENTER |

## PRODUCT\_ID, bits [31:20]

Product ID of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is **RO**.

## VARIANT, bits [19:16]

Variant or major revision of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

## **REVISION**, bits [15:12]

Revision or minor version of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

## **IMPLEMENTER**, bits [11:0]

Implementer ID

Contains the JEP106 identification information as follows:

- 11:8 JEP106 continuation code of implementer
- 7 Always 0
- 6:0 JEP106 identity code of implementer

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

## Accessing MBX\_IIDR

Accesses to this register use the following encodings:

Accessible at offset 0xFC8 from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.15 MBX\_AIDR, Mailbox Architecture Identification Register

The MBX\_AIDR characteristics are:

## Purpose

Provides information on the version of the MHU architecture implemented in this implementation of the MHU.

## Attributes

MBX\_AIDR is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_AIDR bit assignments are:

| 131 | 1 8        | 7  |    |   | 4 | 3 |   |    | 0        | I        |   |
|-----|------------|----|----|---|---|---|---|----|----------|----------|---|
|     | RES0       | 0  | 0  | 1 | 0 | 0 | 0 | 0  | 0        |          |   |
|     | ARCH_MAJOR | RE | V_ |   |   |   |   | La | RCH<br>V | I_MINOR_ | R |

## Bits [31:8]

Reserved, RESO.

## ARCH\_MAJOR\_REV, bits [7:4]

MHU Architecture Major Revision

In the current implementation, this field is 0b0010.

None

| ARCH_MAJOR_REV | Meaning                                |
|----------------|----------------------------------------|
| 060000         | MHUv1 or unknown architecture versions |
| 0b0001         | MHUv2                                  |
| 0b0010         | MHUv3                                  |

All other values are Reserved

Access to this field is RO.

## ARCH\_MINOR\_REV, bits [3:0]

MHU Architecture Minor Revision

In the current implementation, this field is 0b0000.

None

| ARCH_MINOR_REV | Meaning                                    |  |  |  |  |
|----------------|--------------------------------------------|--|--|--|--|
| 0000d0         | Minor revision 0 of the major architecture |  |  |  |  |
| 0b0001         | Minor revision 1 of the major architecture |  |  |  |  |

All other values are Reserved

Access to this field is RO.

## Additional information

The legal combinations for the ARCH\_MAJOR\_REV and ARCH\_MINOR\_REV fields are as follows:

| ARCH_MAJOR_REV | ARCH_MINOR_REV | Description |
|----------------|----------------|-------------|
| 0x0            | 0x0            | MHUv1       |
| 0x1            | 0x0            | MHUv2.0     |
| 0x1            | 0x1            | MHUv2.1     |
| 0x2            | 0x0            | MHUv3.0     |

MHU implementations based on this architecture, have the ARCH\_MAJOR\_REV set to 0x2 and ARCH\_MINOR\_REV set to 0x0.

## Accessing MBX\_AIDR

Accesses to this register use the following encodings:

## Accessible at offset 0xFCC from MHUR.MBX.MBX\_CTRL\_page

## C2.2.1.1.16 MBX\_IMPL\_DEF\_ID<n>, IMPDEF Register, n = 0 - 11

The MBX\_IMPL\_DEF\_ID<n> characteristics are:

#### Purpose

This register is for IMPLEMENTATION DEFINED Identification Registers which can be used to identify the implementation of the MHU Mailbox

An implementation can do the following with this register:

- Chose whether a register is present or not.
- The name of the register.
- The access permission of the registers, so long as they are not more permissive than the architecture defines for the IMPLEMENTATION DEFINED register.
- The names, behavior and reset value of any fields.
- The access permissions of any fields, so long as they are not more permissive than the register.

If the MBX\_IMPL\_DEF\_ID<n> is not present then the location is Reserved and treated as RESO

#### Attributes

MBX\_IMPL\_DEF\_ID<n> is a 32-bit register.

This register is part of the MHUR.MBX.MBX\_CTRL\_page block.

#### **Field descriptions**

The MBX\_IMPL\_DEF\_ID<n> bit assignments are:

IMPLEMENTATION DEFINED

#### **IMPLEMENTATION DEFINED, bits [31:0]**

IMPLEMENTATION DEFINED

31

## Accessing MBX\_IMPL\_DEF\_ID<n>

Accesses to this register use the following encodings:

## Accessible at offset 0xFD0 + (4 \* n) from MHUR.MBX.MBX\_CTRL\_page

# C2.2.1.2 MDBCW\_page, Mailbox Doorbell Channel Windows Page

The MDBCW\_page characteristics are:

## Purpose

Allows access to the MDBCW.

## Configuration

This Register Block is present only when DBE is implemented.

## Attributes

The MDBCW\_page block is of size 4KB.

This block is part of the MHUR.MBX block.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

## Contents

| Offset                      |           | Name                  | Notes                          |
|-----------------------------|-----------|-----------------------|--------------------------------|
| 0x0000 + (32 * n)<br>↔127:0 | )for n in | MDBCW <n>_ST</n>      | Most permissive access: RO     |
| 0x0004 + (32 * n)<br>⇔127:0 | )for n in | MDBCW <n>_ST_MSK</n>  | Most permissive access: RO     |
| 0x0008 + (32 * n)<br>↔127:0 | )for n in | MDBCW <n>_CLR</n>     | Most permissive access: WO/RAZ |
| 0x0010 + (32 * n)<br>↔127:0 | )for n in | MDBCW <n>_MSK_ST</n>  | Most permissive access: RO     |
| 0x0014 + (32 * n)<br>↔127:0 | )for n in | MDBCW <n>_MSK_SET</n> | Most permissive access: WO/RAZ |
| 0x0018 + (32 * n)<br>↔127:0 | )for n in | MDBCW <n>_MSK_CLR</n> | Most permissive access: WO/RAZ |
| 0x001C + (32 * n)<br>↔127:0 | )for n in | MDBCW <n>_CTRL</n>    | Most permissive access: RW     |

## C2.2.1.2.1 MDBCW<n>\_ST, Mailbox Doorbell Channel Window <n> Status, n = 0 - 127

The MDBCW<n>\_ST characteristics are:

## Purpose

Status of the flags for DBCH<n>.

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_ST are RAZ/WI.

## Attributes

MDBCW<n>\_ST is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### **Field descriptions**

The MDBCW<n>\_ST bit assignments are:



## FLAG<x>, bits [x], for x = 31 to 0

Flag

| FLAG <x></x> | Meaning                     |  |
|--------------|-----------------------------|--|
| 0d0          | Flag <x> bit is not set</x> |  |
| 0b1          | Flag <x> bit is set</x>     |  |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## Accessing MDBCW<n>\_ST

Accesses to this register use the following encodings:

## Accessible at offset 0x0000 + (32 \* n) from MHUR.MBX.MDBCW\_page

## C2.2.1.2.2 MDBCW<n>\_ST\_MSK, Mailbox Doorbell Channel Window <n> Status Masked, n = 0 - 127

The MDBCW<n>\_ST\_MSK characteristics are:

#### Purpose

Masked status of DBCH<n>.

#### Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_ST\_MSK are RAZ/WI.

## Attributes

MDBCW<n>\_ST\_MSK is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### **Field descriptions**

The MDBCW<n>\_ST\_MSK bit assignments are:



# **FLAG\_MSK<**x>, bits [x], for x = 31 to 0

Flag Masked

Provides the masked status of flag<x>.

| FLAG_MSK <x></x> | Meaning                                                                          |
|------------------|----------------------------------------------------------------------------------|
| 0b0              | Flag <x> and does not contribute to the DBCH<br/>Channel Transfer interrupt.</x> |
| 0b1              | Flag Masked <x> and contribute to the DBCH Channel Transfer interrupt.</x>       |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## Accessing MDBCW<n>\_ST\_MSK

Accesses to this register use the following encodings:

## Accessible at offset 0x0004 + (32 \* n) from MHUR.MBX.MDBCW\_page

Chapter C2. Registers C2.2. MHUR, MHU Receiver

## C2.2.1.2.3 MDBCW<n>\_CLR, Mailbox Doorbell Channel Window <n> Clear, n = 0 - 127

The MDBCW<n>\_CLR characteristics are:

## Purpose

Clear flag of DBCH<n>.

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_CLR are RAZ/WI.

#### Attributes

MDBCW<n>\_CLR is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### **Field descriptions**

The MDBCW<n>\_CLR bit assignments are:



## FLAG<x>, bits [x], for x = 31 to 0

| FLAG <x></x> | Meaning                                                                               |
|--------------|---------------------------------------------------------------------------------------|
| 0b0          | No effect                                                                             |
| 0b1          | Sets the associated bit in the PDBCW <n>_ST<br/>and MDBCW<n>_ST register to 0</n></n> |

## Accessing MDBCW<n>\_CLR

Accesses to this register use the following encodings:

## Accessible at offset 0x0008 + (32 \* n) from MHUR.MBX.MDBCW\_page

## C2.2.1.2.4 MDBCW<n>\_MSK\_ST, Mailbox Doorbell Channel Window <n> Mask Status, n = 0 - 127

The MDBCW<n>\_MSK\_ST characteristics are:

## Purpose

Status of the mask for DBCH<n>.

#### Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_MSK\_ST are RAZ/WI.

#### Attributes

MDBCW<n>\_MSK\_ST is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### **Field descriptions**

The MDBCW<n>\_MSK\_ST bit assignments are:



## MSK<*x*>, bits [*x*], for *x* = 31 to 0

| MSK <x></x> | Meaning                                                |
|-------------|--------------------------------------------------------|
| 060         | Flag <x> in MDBCW<n>_ST register is not masked</n></x> |
| 0b1         | Flag <x> in MDBCW<n>_ST register is masked</n></x>     |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## Accessing MDBCW<n>\_MSK\_ST

Accesses to this register use the following encodings:

## Accessible at offset 0x0010 + (32 \* n) from MHUR.MBX.MDBCW\_page

## C2.2.1.2.5 MDBCW<n>\_MSK\_SET, Mailbox Doorbell Channel Window <n> Mask Set, n = 0 - 127

The MDBCW<n>\_MSK\_SET characteristics are:

#### Purpose

Sets a bit in the mask for DBCH<n>.

## Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_MSK\_SET are RAZ/WI.

## Attributes

MDBCW<n>\_MSK\_SET is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### **Field descriptions**

The MDBCW<n>\_MSK\_SET bit assignments are:



MSK<*x*>, bits [*x*], for *x* = 31 to 0

| MSK <x></x> | Meaning                                                  |
|-------------|----------------------------------------------------------|
| 0d0         | No effect                                                |
| 0b1         | Set associated bit in MDBCW <n>_MSK_ST register to 1</n> |

## Accessing MDBCW<n>\_MSK\_SET

Accesses to this register use the following encodings:

# Accessible at offset 0x0014 + (32 \* n) from MHUR.MBX.MDBCW\_page

## C2.2.1.2.6 MDBCW<n>\_MSK\_CLR, Mailbox Doorbell Channel Window <n> Mask Clear, n = 0 - 127

The MDBCW<n>\_MSK\_CLR characteristics are:

## Purpose

Clears a bit in the mask for DBCH<n>

#### Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_MSK\_CLR are RAZ/WI.

## Attributes

MDBCW<n>\_MSK\_CLR is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### Field descriptions

The MDBCW<n>\_MSK\_CLR bit assignments are:



MSK<*x*>, bits [*x*], for *x* = 31 to 0

| MSK <x></x> | Meaning                                                  |
|-------------|----------------------------------------------------------|
| 060         | No effect                                                |
| 0b1         | Set associated bit in MDBCW <n>_MSK_ST register to 0</n> |

## Accessing MDBCW<n>\_MSK\_CLR

Accesses to this register use the following encodings:

## Accessible at offset 0x0018 + (32 \* n) from MHUR.MBX.MDBCW\_page

## C2.2.1.2.7 MDBCW<n>\_CTRL, Mailbox Doorbell Channel Window <n> Control, n = 0 - 127

The MDBCW<n>\_CTRL characteristics are:

## Purpose

Configures the behavior of DBCH <n>.

#### Configuration

This register is present only when DBE is implemented. Otherwise, direct accesses to MDBCW<n>\_CTRL are RAZ/WI.

## Attributes

MDBCW<n>\_CTRL is a 32-bit register.

This register is part of the MHUR.MBX.MDBCW\_page block.

#### **Field descriptions**

The MDBCW<n>\_CTRL bit assignments are:



## Bits [31:1]

Reserved, RESO.

## MBX\_COMB\_EN, bit [0]

Mailbox Combined Enable

Controls whether events from this DBCH contribute to the Mailbox Combined interrupt.

| MBX_COMB_EN | Meaning                                                             |
|-------------|---------------------------------------------------------------------|
| 060         | DBCH interrupts do not contribute to the Mailbox Combined interrupt |
| 0b1         | DBCH interrupts contribute to the Mailbox<br>Combined interrupt     |

The reset behavior of this field is:

• On a MHUR reset, this field resets to Ob1.

## Accessing MDBCW<n>\_CTRL

Accesses to this register use the following encodings:

## Accessible at offset 0x001C + (32 \* n) from MHUR.MBX.MDBCW\_page

Access on this interface is **RW**.

EN

# C2.2.1.3 MFFCW\_page, Mailbox FIFO Channel Window Page

The MFFCW\_page characteristics are:

## Purpose

Allows access to the MFFCW.

Depending on the size of the access to the MFFCW\_PAY and MFFCW\_FLG registers and whether the access size is supported the access is treated as follows:

- 8-bit access and MBX\_FFCH\_CFG0.M8BA\_SPT == 0b1 the access behaves as defined in MFFCW<n>\_PAY8 or MFFCW<n>\_FLG8.
- 8-bit access and MBX\_FFCH\_CFG0.M8BA\_SPT == 0b0 the access is treated as an unsupported access.
- 16-bit access and MBX\_FFCH\_CFG0.M16BA\_SPT == 0b1 the access behaves as defined in MFFCW<n>\_PAY16 or MFFCW<n>\_FLG16.
- 16-bit access and MBX\_FFCH\_CFG0.M16BA\_SPT == 0b0 the access is treated as an unsupported access.
- 32-bit access and MBX\_FFCH\_CFG0.M32BA\_SPT == 0b1 the access behaves as defined in MFFCW<n>\_PAY32 or MFFCW<n>\_FLG32.
- 32-bit access and MBX\_FFCH\_CFG0.M32BA\_SPT == 0b0 the access is treated as an unsupported access.
- 64-bit access and MBX\_FFCH\_CFG0.M64BA\_SPT == 0b1 the access behaves as defined in MFFCW<n>\_PAY64 or MFFCW<n>\_FLG64.
- 64-bit access and MBX\_FFCH\_CFG0.M64BA\_SPT == 0b0 the access is treated as an unsupported access.

## Configuration

This Register Block is present only when FE is implemented.

## Attributes

The MFFCW\_page block is of size 4KB.

This block is part of the MHUR.MBX block.

## **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

#### Contents

| Offset                        | Name                | Notes                                                                                                        |
|-------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------|
| 0x000 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT   |
| 0x000 + (64 * n)for n in 63:0 | MFFCW <n>_PAY16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M16BA_SPT |
| Offset                        | Name                | Notes                                                                                                                      |
|-------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------|
| 0x000 + (64 * n)for n in 63:0 | MFFCW <n>_PAY32</n> | Most permissive access: RO<br>Register condition: When<br>M32BA_SPT<br>Accessor condition: When<br>M32BA_SPT               |
| 0x000 + (64 * n)for n in 63:0 | MFFCW <n>_PAY64</n> | Most permissive access: RO<br>Register condition: When<br>M64BA_SPT<br>Accessor condition: When<br>M64BA_SPT               |
| 0x001 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |
| 0x002 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |
| 0x002 + (64 * n)for n in 63:0 | MFFCW <n>_PAY16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M16BA_SPT               |
| 0x003 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |
| 0x004 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT   |
| 0x004 + (64 * n)for n in 63:0 | MFFCW <n>_PAY16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M16BA_SPT |
| 0x004 + (64 * n)for n in 63:0 | MFFCW <n>_PAY32</n> | Most permissive access: RO<br>Register condition: When<br>M32BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M32BA_SPT |

| Offset                        | Name                | Notes                                                                                                                      |
|-------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------|
| 0x005 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When                             |
|                               |                     | M64BA_SPT and M8BA_SPT                                                                                                     |
| 0x006 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT   |
| 0x006 + (64 * n)for n in 63:0 | MFFCW <n>_PAY16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M16BA_SPT |
| 0x007 + (64 * n)for n in 63:0 | MFFCW <n>_PAY8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT   |
| 0x008 + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |
| 0x008 + (64 * n)for n in 63:0 | MFFCW <n>_FLG16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M16BA_SPT               |
| 0x008 + (64 * n)for n in 63:0 | MFFCW <n>_FLG32</n> | Most permissive access: RO<br>Register condition: When<br>M32BA_SPT<br>Accessor condition: When<br>M32BA_SPT               |
| 0x008 + (64 * n)for n in 63:0 | MFFCW <n>_FLG64</n> | Most permissive access: RO<br>Register condition: When<br>M64BA_SPT<br>Accessor condition: When<br>M64BA_SPT               |
| 0x009 + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |

| Offset                        | Name                | Notes                                                                                                                      |
|-------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------|
| 0x00A + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |
| 0x00A + (64 * n)for n in 63:0 | MFFCW <n>_FLG16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M16BA_SPT               |
| 0x00B + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M8BA_SPT                 |
| 0x00C + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT   |
| 0x00C + (64 * n)for n in 63:0 | MFFCW <n>_FLG16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M16BA_SPT |
| 0x00C + (64 * n)for n in 63:0 | MFFCW <n>_FLG32</n> | Most permissive access: RO<br>Register condition: When<br>M32BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M32BA_SPT |
| 0x00D + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT   |
| 0x00E + (64 * n)for n in 63:0 | MFFCW <n>_FLG8</n>  | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT   |
| 0x00E + (64 * n)for n in 63:0 | MFFCW <n>_FLG16</n> | Most permissive access: RO<br>Register condition: When<br>M16BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M16BA_SPT |

| Offset                                        | Name                   | Notes                                                                                                                    |
|-----------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0x00F + (64 * n)for n in 63:0                 | MFFCW <n>_FLG8</n>     | Most permissive access: RO<br>Register condition: When<br>M8BA_SPT<br>Accessor condition: When<br>M64BA_SPT and M8BA_SPT |
| $0 \times 0010 + (64 \times n)$ for n in 63:0 | MFFCW <n>_INT_ST</n>   | Most permissive access: RO                                                                                               |
| $0 \times 0014 + (64 * n)$ for n in 63:0      | MFFCW <n>_INT_CLR</n>  | Most permissive access: WO/RAZ                                                                                           |
| 0x0018 + (64 * n)for n in 63:0                | MFFCW <n>_INT_EN</n>   | Most permissive access: RW                                                                                               |
| 0x0020 + (64 * n) for n in 63:0               | MFFCW <n>_CTRL</n>     | Most permissive access: RW                                                                                               |
| 0x0024 + (64 * n) for n in 63:0               | MFFCW <n>_ST</n>       | Most permissive access: RO                                                                                               |
| 0x0028 + (64 * n) for n in 63:0               | MFFCW <n>_FIFO_POP</n> | Most permissive access: WO/RAZ                                                                                           |
| 0x002C + (64 * n) for n in 63:0               | MFFCW <n>_TIDE</n>     | Most permissive access: RW                                                                                               |

## C2.2.1.3.1 MFFCW<n>\_PAY8, Mailbox FIFO Channel Window <n> Payload (8-bit access), n = 0 - 63

The MFFCW<n>\_PAY8 characteristics are:

#### Purpose

An 8-bit access to the MFFCW<n>\_PAY register. Accesses must be aligned to any 8-bit boundary within the MFFCW<n>\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

8-bit accesses are only supported, if MBX\_FFCH\_CFG0.M8BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If M64BA\_SPT is set to 1 the MFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Mailbox FIFO Channel Window <n>.

If M64BA\_SPT is set to 0 the MFFCW<n>\_PAY register occupies offsets 0x00-0x03 and offsets 0x04-0x07 are reserved, within the Mailbox FIFO Channel Window <n>.

A read of this registers reads the byte at the head of the FIFO, if the FIFO is not empty otherwise an IMPLEMENTATION DEFINED value is returned.

If the MFFCW<n>\_CTRL.RA\_EN field is set to 0b1, the byte read from the FIFO is also popped from the FIFO.

On a read of this registers the values of the data flags, associated with the byte read from the FIFO are stored in the Flag History Buffer.

#### Configuration

This register is present only when FE is implemented and M8BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_PAY8 are RAZ/WI.

#### Attributes

MFFCW<n>\_PAY8 is a 8-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_PAY8 bit assignments are:



#### PAY, bits [7:0]

Payload read from FIFO

One byte is read from the FIFO, starting from the head of the FIFO.

A byte read from the FIFO can be either valid or invalid. A valid byte has an 8-bit data value and data flags associated with it. An invalid byte has an IMPLEMENTATION DEFINED data value and no data flags associated with it.

The data flags of the byte are stored in the Flag History Buffer(FHB) in entry 0 of the FHB.

With all other entries being marked as invalid.

If MFFCW<n>\_CTRL.RA\_EN is set to 0b1, when the byte is read from the FIFO:

- It is also removed from the FIFO.
- A Transfer Acknowledge event is generated if that byte was associated with the ACK and EOT data flags.

Otherwise the byte still remains in the FIFO and a subsequent read of the same size would return the same byte.

### Accessing MFFCW<n>\_PAY8

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

### Read at offset 0x001 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

#### Read at offset 0x002 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

## Read at offset 0x003 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

## When M64BA\_SPT

#### Read at offset 0x004 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

#### When M64BA\_SPT

## Read at offset 0x005 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

#### When M64BA\_SPT

#### Read at offset 0x006 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

#### When M64BA\_SPT

## Read at offset 0x007 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY8;

# C2.2.1.3.2 MFFCW<n>\_PAY16, Mailbox FIFO Channel Window <n> Payload (16-bit access), n = 0 - 63

The MFFCW<n>\_PAY16 characteristics are:

#### Purpose

A 16-bit access to the MFFCW<n>\_PAY register. Accesses must be aligned to any 16-bit boundary within the MFFCW<n>\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

16-bit accesses are only supported, if MBX\_FFCH\_CFG0.M16BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If M64BA\_SPT is set to 1 the MFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Mailbox FIFO Channel Window <n>.

If M64BA\_SPT is set to 0 the MFFCW<n>\_PAY register occupies offsets 0x00-0x03 and offsets 0x04-0x07 are reserved, within the Mailbox FIFO Channel Window <n>.

A read of this register reads up to two bytes starting at the head of the FIFO, if the FIFO is not empty otherwise an IMPLEMENTATION DEFINED value is returned.

If the MFFCW<n>\_CTRL.RA\_EN field is set to 0b1, the bytes read from the FIFO is also popped from the FIFO.

On a read of this register, the values of the data flags, associated with the bytes read from the FIFO are stored in the Flag History Buffer.

#### Configuration

This register is present only when FE is implemented and M16BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_PAY16 are RAZ/WI.

## Attributes

MFFCW<n>\_PAY16 is a 16-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_PAY16 bit assignments are:

| 15 |     | 0 |
|----|-----|---|
|    | PAY |   |

## PAY, bits [15:0]

Payload read from FIFO

Two bytes are read from the FIFO, starting from the head of the FIFO.

A byte read from the FIFO can be either valid or invalid. A valid byte has an 8-bit data value and data flags associated with it. An invalid byte has an IMPLEMENTATION DEFINED data value and no data flags associated with it.

The data values of all bytes read from the FIFO, are arrange in the PAY field depending on the value of the MFFCW<n>\_CTRL.MSBF field and the byte number.

## MFFCW<n>\_CTRL.MSBF == 0b0

Bytes are arranged starting with the first byte read from the FIFO in the LSB of the PAY field and the last byte read from the FIFO in the MSB of the PAY field.

## MFFCW<n>\_CTRL.MSBF == 0b1

Bytes are arranged starting with the first byte read from the FIFO in the MSB of the PAY field and the last byte read from the FIFO in the LSB of the PAY field.

The data flags of each byte are stored in the Flag History Buffer(FHB) starting with the first byte read in entry 0 of the FHB and the last byte read in entry 1 of the FHB.

With all other entries being marked as invalid.

If MFFCW<n>\_CTRL.RA\_EN is set to 0b1, when a byte is read from the FIFO:

- Tt is also removed from the FIFO.
- A Transfer Acknowledge event is generated if that byte was associated with the ACK and EOT data flags.

Otherwise the byte still remains in the FIFO and a subsequent read of the same size would return the same bytes.

#### Accessing MFFCW<n>\_PAY16

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY16;

#### Read at offset 0x002 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY16;

#### When M64BA\_SPT

#### Read at offset 0x004 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY16;

#### When M64BA\_SPT

#### Read at offset 0x006 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY16;

# C2.2.1.3.3 MFFCW<n>\_PAY32, Mailbox FIFO Channel Window <n> Payload (32-bit access), n = 0 - 63

The MFFCW<n>\_PAY32 characteristics are:

### Purpose

A 32-bit access to the MFFCW<n>\_PAY register. Accesses must be aligned to any 32-bit boundary within the MFFCW<n>\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

32-bit accesses are only supported, if MBX\_FFCH\_CFG0.M32BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If M64BA\_SPT is set to 1 the MFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Mailbox FIFO Channel Window <n>.

If M64BA\_SPT is set to 0 the MFFCW<n>\_PAY register occupies offsets 0x00-0x03 and offsets 0x04-0x07 are reserved, within the Mailbox FIFO Channel Window <n>.

A read of this register reads up to four bytes starting at the head of the FIFO, if the FIFO is not empty otherwise an IMPLEMENTATION DEFINED value is returned.

If the MFFCW<n>\_CTRL.RA\_EN field is set to 0b1, the bytes read from the FIFO is also popped from the FIFO.

On a read of this register, the values of the data flags, associated with the bytes read from the FIFO are stored in the Flag History Buffer.

#### Configuration

This register is present only when FE is implemented and M32BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_PAY32 are RAZ/WI.

## Attributes

MFFCW<n>\_PAY32 is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_PAY32 bit assignments are:



## PAY, bits [31:0]

Payload read from FIFO

Four bytes are read from the FIFO, starting from the head of the FIFO.

A byte read from the FIFO can be either valid or invalid. A valid byte has an 8-bit data value and data flags associated with it. An invalid byte has an IMPLEMENTATION DEFINED data value and no data flags associated with it.

The data values of all bytes read from the FIFO, are arrange in the PAY field depending on the value of the MFFCW<n>\_CTRL.MSBF field and the byte number.

## MFFCW<n>\_CTRL.MSBF == 0b0

Bytes are arranged starting with the first byte read from the FIFO in the LSB of the PAY field and the last byte read from the FIFO in the MSB of the PAY field.

## MFFCW<n>\_CTRL.MSBF == 0b1

Bytes are arranged starting with the first byte read from the FIFO in the MSB of the PAY field and the last byte read from the FIFO in the LSB of the PAY field.

The data flags of each byte are stored in the Flag History Buffer(FHB) starting with the first byte read in entry 0 of the FHB and the last byte read in entry 3 of the FHB.

With all other entries being marked as invalid.

If MFFCW<n>\_CTRL.RA\_EN is set to 0b1, when a byte is read from the FIFO:

- It is also removed from the FIFO.
- A Transfer Acknowledge event is generated if that byte was associated with the ACK and EOT data flags.

Otherwise the byte still remains in the FIFO and a subsequent read of the same size would return the same bytes.

#### Accessing MFFCW<n>\_PAY32

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY32;

#### When M64BA\_SPT

## Read at offset 0x004 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY32;

# C2.2.1.3.4 MFFCW<n>\_PAY64, Mailbox FIFO Channel Window <n> Payload (64-bit access), n = 0 - 63

The MFFCW<n>\_PAY64 characteristics are:

#### Purpose

A 64-bit access to the MFFCW<n>\_PAY register. Accesses must be aligned to any 64-bit boundary within the MFFCW<n>\_PAY register, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to be an aligned access.

64-bit accesses are only supported, if MBX\_FFCH\_CFG0.M64BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

When MBX\_FFCH\_CFG0.M64BA\_SPT is set to 0b1, the MFFCW<n>\_PAY register occupies offsets 0x00-0x07 within the Mailbox FIFO Channel Window <n>.

A read of this register reads up to eight bytes starting at the head of the FIFO, if the FIFO is not empty otherwise an IMPLEMENTATION DEFINED value is returned.

If the MFFCW<n>\_CTRL.RA\_EN field is set to 0b1, the bytes read from the FIFO is also popped from the FIFO.

On a read of this register, the values of the data flags, associated with the bytes read from the FIFO are stored in the Flag History Buffer.

#### Configuration

This register is present only when FE is implemented and M64BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_PAY64 are RAZ/WI.

#### Attributes

MFFCW<n>\_PAY64 is a 64-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_PAY64 bit assignments are:

| L 63 |     | 32 |
|------|-----|----|
|      | PAY |    |
| 31   |     | 0  |
|      | PAY |    |

#### PAY, bits [63:0]

Payload read from FIFO

Eigth bytes are read from the FIFO, starting from the head of the FIFO.

A byte read from the FIFO can be either valid or invalid. A valid byte has an 8-bit data value and data flags associated with it. An invalid byte has an IMPLEMENTATION DEFINED data value and no data flags associated with it.

The data values of all bytes read from the FIFO, are arrange in the PAY field depending on the value of the MFFCW<n>\_CTRL.MSBF field and the byte number.

#### MFFCW<n>\_CTRL.MSBF == 0b0

Bytes are arranged starting with the first byte read from the FIFO in the LSB of the PAY field and the last byte read from the FIFO in the MSB of the PAY field.

## MFFCW<n>\_CTRL.MSBF == 0b1

Bytes are arranged starting with the first byte read from the FIFO in the MSB of the PAY field and the last byte read from the FIFO in the LSB of the PAY field.

The data flags of each byte are stored in the Flag History Buffer(FHB) starting with the first byte read in entry 0 of the FHB and the last byte read in entry 7 of the FHB.

With all other entries being marked as invalid.

If MFFCW<n>\_CTRL.RA\_EN is set to 0b1, when a byte is read from the FIFO:

- It is also removed from the FIFO.
- A Transfer Acknowledge event is generated if that byte was associated with the ACK and EOT data flags.

Otherwise the byte still remains in the FIFO and a subsequent read of the same size would return the same bytes.

#### Accessing MFFCW<n>\_PAY64

Accesses to this register use the following encodings:

## Read at offset 0x000 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_PAY64;

## C2.2.1.3.5 MFFCW<n>\_FLG8, Mailbox FIFO Channel Window <n> Flag (8-bit access), n = 0 - 63

The MFFCW<n>\_FLG8 characteristics are:

#### Purpose

An 8-bit access to the MFFCW<n>\_FLG register. Accesses must be aligned to any 8-bit boundary within the MFFCW<n>\_FLG register, otherwise the access is treated as RAZ/WI.

8-bit accesses are only supported, if MBX\_FFCH\_CFG0.M8BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If M64BA\_SPT is set to 1 the MFFCW<n>\_FLG register occupies offsets 0x08-0x0F within the Mailbox FIFO Channel Window <n>.

If M64BA\_SPT is set to 0 the MFFCW<n>\_FLG register occupies offsets 0x08-0x0B and offsets 0x0C-0x0F are reserved, within the Mailbox FIFO Channel Window <n>.

A read of this register returns:

- The contents of the Flag History Buffer.
- Current fill level of the FIFO.

This register is expected to be read after a read of the MFFCW<n>\_PAY register to get the data flags associated with the bytes read from the FIFO. The read of this register must be of the same size as the read of the MFFCW<n>\_PAY register, otherwise it can lead to loss or corruption of information.

#### Configuration

This register is present only when FE is implemented and M8BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_FLG8 are RAZ/WI.

#### Attributes

MFFCW<n>\_FLG8 is a 8-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_FLG8 bit assignments are:

| 7 |     | 4  | 3 | 2 | 1   | 0   |
|---|-----|----|---|---|-----|-----|
|   | FFL |    |   |   | FL  | G0  |
|   | RE  | S0 |   |   | VFI | _G0 |

## FFL, bits [7:4]

FIFO Fill Level

Indicates the number of bytes containing valid data in the FIFO.

| FFL          | Meaning                                | Applies               |
|--------------|----------------------------------------|-----------------------|
| 000000       | All bytes in the FIFO are invalid      |                       |
| 0b00010b1110 | Number of valid bytes in the FIFO      |                       |
| 0b1111       | 15 bytes are valid in the FIFO         | When FFCH_DEPTH <= 15 |
| 0b1111       | 15 or more bytes are valid in the FIFO | When FFCH_DEPTH > 15  |

#### Chapter C2. Registers C2.2. MHUR, MHU Receiver

The maximum value returned is never greater than the FIFO Depth.

Bit [3]

Reserved, RESO.

## VFLG0, bit [2]

Valid FLG0

Indicates whether FLG0 field contains valid data or not.

| VFLG0 | Meaning           |
|-------|-------------------|
| 0b0   | FLG0 is not valid |
| 0b1   | FLG0 is valid     |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

#### FLG0, bits [1:0]

Flag 0

Provides the data flags, except for the ACK flag, held in FHB entry 0 and whether the data flags are valid or invalid. The legal values of the FLG0 field are:

| FLG0 | Meaning                                                 |
|------|---------------------------------------------------------|
| 0000 | Payload<br>Neither the first or last byte of a Transfer |
| 0b01 | Start Byte<br>First byte of a Transfer                  |
| 0b10 | End Byte<br>Last byte of a Transfer                     |
| 0b11 | Start and End Byte<br>First and last byte of a Transfer |

The value of the FLG0 field is only valid if VFLG0 is set to 0b1, otherwise the value of this field must be ignored by software.

#### Accessing MFFCW<n>\_FLG8

Accesses to this register use the following encodings:

#### Read at offset 0x008 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

#### Read at offset 0x009 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

#### Read at offset 0x00A + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

#### Read at offset 0x00B + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

#### When M64BA\_SPT

#### Read at offset 0x00C + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

#### When M64BA\_SPT

#### Read at offset 0x00D + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

#### When M64BA\_SPT

#### Read at offset 0x00E + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

## When M64BA\_SPT

#### Read at offset 0x00F + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG8;

## C2.2.1.3.6 MFFCW<n>\_FLG16, Mailbox FIFO Channel Window <n> Flag (16-bit access), n = 0 - 63

The MFFCW<n>\_FLG16 characteristics are:

#### Purpose

A 16-bit access to the MFFCW<n>\_FLG register. Accesses must be aligned to any 16-bit boundary within the MFFCW<n>\_FLG register, otherwise the access is treated as RAZ/WI.

16-bit accesses are only supported, if MBX\_FFCH\_CFG0.M16BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If M64BA\_SPT is set to 1 the MFFCW<n>\_FLG register occupies offsets 0x08-0x0F within the Mailbox FIFO Channel Window <n>.

If M64BA\_SPT is set to 0 the MFFCW<n>\_FLG register occupies offsets 0x08-0x0B and offsets 0x0C-0x0F are reserved, within the Mailbox FIFO Channel Window <n>.

A read of this register returns:

- The contents of the Flag History Buffer.
- Current fill level of the FIFO.

This register is expected to be read after a read of the MFFCW<n>\_PAY register to get the data flags associated with the bytes read from the FIFO. The read of this register must be of the same size as the read of the MFFCW<n>\_PAY register, otherwise it can lead to loss or corruption of information.

#### Configuration

This register is present only when FE is implemented and M16BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_FLG16 are RAZ/WI.

#### Attributes

MFFCW<n>\_FLG16 is a 16-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_FLG16 bit assignments are:

| 15 |     | 8           | 7 | 6 | 5  | 4  | 3 | 2   | 1         | 0   |  |
|----|-----|-------------|---|---|----|----|---|-----|-----------|-----|--|
|    | FFL |             |   |   | FL | G1 |   |     | FL        | GO  |  |
|    |     | RES0<br>VFL |   |   |    |    |   | RES | VFL<br>50 | _G0 |  |

## FFL, bits [15:8]

FIFO Fill Level

Indicates the number of bytes containing valid data in the FIFO.

| FFL      | Meaning                           | Applies                |
|----------|-----------------------------------|------------------------|
| 0x00     | All bytes in the FIFO are invalid |                        |
| 0x010xFE | Number of valid bytes in the FIFO |                        |
| 0×FF     | 255 bytes are valid in the FIFO   | When FFCH_DEPTH <= 255 |

| FFL  | Meaning                                 | Applies               |
|------|-----------------------------------------|-----------------------|
| OxFF | 255 or more bytes are valid in the FIFO | When FFCH_DEPTH > 255 |

The maximum value returned is never greater than the FIFO Depth.

Bits [7, 3]

Reserved, RESO.

#### VFLG<m>, bits [2+4m], for m = 1 to 0

Valid Flag <m>

Indicates whether FLG<m> field contains valid data or not.

| VFLG <m></m> | Meaning                  |  |
|--------------|--------------------------|--|
| 0b0          | FLG <m> is not valid</m> |  |
| 0b1          | FLG <m> is valid</m>     |  |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

#### FLG<m>, bits [5:4, 1:0], for m = 1 to 0, where each field is 2 bits wide

Flag <m>

Provides the data flags, except for the ACK flag, held in FHB entry 0 and 1 and whether the data flags are valid or invalid.

The association of the FLG<m> field to the FHB entries depends on the value of the MFFCW<n>\_CTRL.MSBF field when the read of the MFFCW<n>\_FLG register occurrs.

#### MFFCW<n>\_CTRL.MSBF == 0b0

FLG0 is associated with FHB entry 0 and FLG1 is associated with FHB entry 1

#### MFFCW<n>\_CTRL.MSBF == 0b1

FLG0 is associated with FHB entry 1 and FLG1 is associated with FHB entry 0

The legal values of the FLG<m> field, when VFLG<m> is set to 0b1 are:

| FLG <m></m> | Meaning                                                 |
|-------------|---------------------------------------------------------|
| 0600        | Payload<br>Neither the first or last byte of a Transfer |
| 0b01        | Start Byte<br>First byte of a Transfer                  |
| 0b10        | End Byte<br>Last byte of a Transfer                     |
| 0b11        | Start and End Byte<br>First and last byte of a Transfer |

#### Chapter C2. Registers C2.2. MHUR, MHU Receiver

The value of the FLG<m> field is only valid if VFLG<m> is set to 0b1, otherwise the value of this field must be ignored by software.

## Accessing MFFCW<n>\_FLG16

Accesses to this register use the following encodings:

#### Read at offset 0x008 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG16;

#### Read at offset 0x00A + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG16;

## When M64BA\_SPT

## Read at offset 0x00C + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG16;

## When M64BA\_SPT

## Read at offset 0x00E + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG16;

# C2.2.1.3.7 MFFCW<n>\_FLG32, MailboxPostbox FIFO Channel Window <n> Flag (32-bit access), n = 0 - 63

The MFFCW<n>\_FLG32 characteristics are:

#### Purpose

A 32-bit access to the MFFCW<n>\_FLG register. Accesses must be aligned to any 32-bit boundary within the MFFCW<n>\_FLG register, otherwise the access is treated as RAZ/WI.

32-bit accesses are only supported, if MBX\_FFCH\_CFG0.M32BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

If M64BA\_SPT is set to 1 the MFFCW<n>\_FLG register occupies offsets 0x08-0x0F within the Mailbox FIFO Channel Window <n>.

If M64BA\_SPT is set to 0 the MFFCW<n>\_FLG register occupies offsets 0x08-0x0B and offsets 0x0C-0x0F are reserved, within the Mailbox FIFO Channel Window <n>.

A read of this register returns:

- The contents of the Flag History Buffer.
- Current fill level of the FIFO.

This register is expected to be read after a read of the MFFCW<n>\_PAY register to get the data flags associated with the bytes read from the FIFO. The read of this register must be of the same size as the read of the MFFCW<n>\_PAY register, otherwise it can lead to loss or corruption of information.

#### Configuration

This register is present only when FE is implemented and M32BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_FLG32 are RAZ/WI.

#### Attributes

MFFCW<n>\_FLG32 is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_FLG32 bit assignments are:



#### FFL, bits [31:21]

FIFO Fill Level

Indicates the number of bytes containing valid data in the FIFO.

| FFL                                     | Meaning                           |
|-----------------------------------------|-----------------------------------|
| 000000000000000000000000000000000000000 | All bytes in the FIFO are invalid |
| 0b00000000010<br>⇔b0111111111           | Number of valid bytes in the FIFO |

| FFL          | Meaning                                  |
|--------------|------------------------------------------|
| 0b1000000000 | 1024 or more bytes are valid in the FIFO |

The maximum value returned is never greater than the FIFO Depth.

## Bits [20:15, 11, 7, 3]

Reserved, RESO.

#### VFLG<m>, bits [2+4m], for m = 3 to 0

Valid Flag <m>

Indicates whether FLG<m> field contains valid data or not.

| VFLG <m></m> | Meaning                  |  |
|--------------|--------------------------|--|
| 060          | FLG <m> is not valid</m> |  |
| 0b1          | FLG <m> is valid</m>     |  |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

#### FLG<m>, bits [13:12, 9:8, 5:4, 1:0], for m = 3 to 0, where each field is 2 bits wide

Flag <m>

Provides the data flags, except for the ACK flag, held in FHB entry 0 to 3 and whether the data flags are valid or invalid.

The association of the FLG<m> field to the FHB entries depends on the value of the MFFCW<n>\_CTRL.MSBF field when the read of the MFFCW<n>\_FLG register occurrs.

#### MFFCW<n>\_CTRL.MSBF == 0b0

FLG0 is associated with FHB entry 0 and FLG3 is associated with FHB entry 3

#### MFFCW<n>\_CTRL.MSBF == 0b1

FLG0 is associated with FHB entry 3 and FLG3 is associated with FHB entry 0

The legal values of the FLG<m> field, when VFLG<m> is set to 0b1 are:

| FLG <m></m> | Meaning                                                 |
|-------------|---------------------------------------------------------|
| 0000        | Payload<br>Neither the first or last byte of a Transfer |
| 0b01        | Start Byte<br>First byte of a Transfer                  |
| 0b10        | End Byte<br>Last byte of a Transfer                     |
| 0b11        | Start and End Byte<br>First and last byte of a Transfer |

#### Chapter C2. Registers C2.2. MHUR, MHU Receiver

The value of the FLG<m> field is only valid if VFLG<m> is set to 0b1, otherwise the value of this field must be ignored by software.

## Accessing MFFCW<n>\_FLG32

Accesses to this register use the following encodings:

## Read at offset 0x008 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG32;

## When M64BA\_SPT

## Read at offset 0x00C + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG32;

## C2.2.1.3.8 MFFCW<n>\_FLG64, Mailbox FIFO Channel Window <n> Flag (64-bit access), n = 0 - 63

The MFFCW<n>\_FLG64 characteristics are:

#### Purpose

A 64-bit access to the MFFCW<n>\_FLG register. Accesses must be aligned to any 64-bit boundary within the MFFCW<n>\_FLG register, otherwise the access is treated as RAZ/WI.

64-bit accesses are only supported, if MBX\_FFCH\_CFG0.M64BA\_SPT is set to 0b1, otherwise it is an unsupported access and it is IMPLEMENTATION DEFINED whether the access is treated as RAZ/WI or modified to a supported size.

When MBX\_FFCH\_CFG0.M64BA\_SPT is set to 0b1, the MFFCW<n>\_FLG register occupies offsets 0x08-0x0F within the Mailbox FIFO Channel Window <n>.

A read of this register returns:

- The contents of the Flag History Buffer.
- Current fill level of the FIFO.

This register is expected to be read after a read of the MFFCW<n>\_PAY register to get the data flags associated with the bytes read from the FIFO. The read of this register must be of the same size as the read of the MFFCW<n>\_PAY register, otherwise it can lead to loss or corruption of information.

## Configuration

This register is present only when FE is implemented and M64BA\_SPT. Otherwise, direct accesses to MFFCW<n>\_FLG64 are RAZ/WI.

#### Attributes

MFFCW<n>\_FLG64 is a 64-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### Field descriptions

The MFFCW<n>\_FLG64 bit assignments are:



## FFL, bits [63:53]

FIFO Fill Level

Indicates the number of bytes containing valid data in the FIFO.

#### FFL

Meaning

0b0000000000000

All bytes in the FIFO are invalid

| FFL                           | Meaning                                  |
|-------------------------------|------------------------------------------|
| 0b00000000010<br>⇔b0111111111 | Number of valid bytes in the FIFO        |
| 0b1000000000                  | 1024 or more bytes are valid in the FIFO |

The maximum value returned is never greater than the FIFO Depth.

## Bits [52:31, 27, 23, 19, 15, 11, 7, 3]

Reserved, RESO.

#### VFLG<m>, bits [2+4m], for m = 7 to 0

Valid Flag <m>

Indicates whether FLG<m> field contains valid data or not.

| VFLG <m></m> | Meaning                  |  |
|--------------|--------------------------|--|
| 0b0          | FLG <m> is not valid</m> |  |
| 0b1          | FLG <m> is valid</m>     |  |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

#### FLG<m>, bits [29:28, 25:24, 21:20, 17:16, 13:12, 9:8, 5:4, 1:0], for m = 7 to 0, where each field is 2 bits wide

Flag <m>

Provides the data flags, except for the ACK flag, held in FHB entry 0 to 7 and whether the data flags are valid or invalid.

The association of the FLG<m> field to the FHB entries depends on the value of the MFFCW<n>\_CTRL.MSBF field when the read of the MFFCW<n>\_FLG register occurrs.

## MFFCW<n>\_CTRL.MSBF == 0b0

FLG0 is associated with FHB entry 0 and FLG7 is associated with FHB entry 7

#### MFFCW<n>\_CTRL.MSBF == 0b1

FLG0 is associated with FHB entry 7 and FLG7 is associated with FHB entry 0

The legal values of the FLG<m> field, when VFLG<m> is set to 0b1 are:

| FLG <m></m> | Meaning                                                 |
|-------------|---------------------------------------------------------|
| 0600        | Payload<br>Neither the first or last byte of a Transfer |
| 0b01        | Start Byte<br>First byte of a Transfer                  |
| 0b10        | End Byte<br>Last byte of a Transfer                     |
| 0b11        | Start and End Byte<br>First and last byte of a Transfer |

#### Chapter C2. Registers C2.2. MHUR, MHU Receiver

The value of the FLG<m> field is only valid if VFLG<m> is set to 0b1, otherwise the value of this field must be ignored by software.

## Accessing MFFCW<n>\_FLG64

Accesses to this register use the following encodings:

## Read at offset 0x008 + (64 \* n) from MHUR.MBX.MFFCW\_page

return MFFCW<n>\_FLG64;

## C2.2.1.3.9 MFFCW<n>\_INT\_ST, Mailbox FIFO Channel Window <n> Interrupt Status, n = 0 - 63

The MFFCW<n>\_INT\_ST characteristics are:

#### Purpose

Provides the status of the interrupts for the FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_INT\_ST are RAZ/WI.

#### Attributes

MFFCW<n>\_INT\_ST is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_INT\_ST bit assignments are:



## FF, bit [31]

#### FIFO Flush

Indicates whether the MHUS FIFO Flush mechanism has caused a flush of the FIFO for this FFCH.

| FF  | Meaning                                                      |
|-----|--------------------------------------------------------------|
| 0b0 | MHUS FIFO Flush mechanism has not caused a flush of the FIFO |
| 0b1 | MHUS FIFO Flush mechanism has caused a flush of the FIFO     |

#### Bits [30:3]

Reserved, RAZ.

#### FHT, bit [2]

FIFO High Tidemark

Indicates whether the Receiver FIFO High Tidemark event has occurred.

| FHT | Meaning                                           |
|-----|---------------------------------------------------|
| 0b0 | Receiver FIFO High Tidemark has not occurred      |
| 0b1 | Receiver FIFO High Tidemark event has<br>occurred |

#### FLT, bit [1]

FIFO Low Tidemark

Indicates whether the Receiver FIFO Low Tidemark event has occurred.

| FLT | Meaning                                           |
|-----|---------------------------------------------------|
| 0b0 | Receiver FIFO Low Tidemark event has not occurred |
| 0b1 | Receiver FIFO Low Tidemark event has occured      |

## TFR, bit [0]

Transfer

Indicates whether a Transfer event has occurred.

| TFR | Meaning                         |
|-----|---------------------------------|
| 0b0 | Transfer event has not occurred |
| 0b1 | Transfer event has occurred     |

## Accessing MFFCW<n>\_INT\_ST

Accesses to this register use the following encodings:

Accessible at offset 0x0010 + (64 \* n) from MHUR.MBX.MFFCW\_page

Access on this interface is **RO**.

## C2.2.1.3.10 MFFCW<n>\_INT\_CLR, Mailbox FIFO Channel Window <n> Interrupt Clear, n = 0 - 63

The MFFCW<n>\_INT\_CLR characteristics are:

#### Purpose

Allows clearing of any interrupts for FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_INT\_CLR are RAZ/WI.

#### Attributes

MFFCW<n>\_INT\_CLR is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_INT\_CLR bit assignments are:



Shows the status of the events of the DBCH

**FF, bit [31]** FIFO Flush

| FF  | Meaning                                                        |
|-----|----------------------------------------------------------------|
| 0b0 | No effect                                                      |
| 0b1 | Clear FIFO flush event in the<br>MFFCW <n>_INT_ST register</n> |

Bits [30:3] Reserved, RAZ. FHT, bit [2] FIFO High Tidemark

| FHT | Meaning                                                                |
|-----|------------------------------------------------------------------------|
| 0b0 | No effect                                                              |
| 0b1 | Clear FIFO High Tidemark event in the<br>MFFCW <n>_INT_ST register</n> |

#### FLT, bit [1]

FIFO Low Tidemark

| FLT | Meaning                                                               |
|-----|-----------------------------------------------------------------------|
| 0b0 | No effect                                                             |
| 0b1 | Clear FIFO Low Tidemark event in the<br>MFFCW <n>_INT_ST register</n> |

## TFR, bit [0]

Transfer

| TFR | Meaning                                                      |
|-----|--------------------------------------------------------------|
| 0b0 | No effect                                                    |
| 0b1 | Clear Transfer event in the<br>MFFCW <n>_INT_ST register</n> |

## Accessing MFFCW<n>\_INT\_CLR

Accesses to this register use the following encodings:

Accessible at offset 0x0014 + (64 \* n) from MHUR.MBX.MFFCW\_page

Access on this interface is **WO/RAZ**.

## C2.2.1.3.11 MFFCW<n>\_INT\_EN, Mailbox FIFO Channel Window <n> Interrupt Enable, n = 0 - 63

The MFFCW<n>\_INT\_EN characteristics are:

#### Purpose

Configures the interrupts of FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_INT\_EN are RAZ/WI.

#### Attributes

MFFCW<n>\_INT\_EN is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_INT\_EN bit assignments are:



Shows the status of the events of the DBCH

## FF, bit [31]

## FIFO Flush

Controls whether a FIFO flush event generated by the MHUS generates an interrupt.

| FF  | Meaning                                                         |
|-----|-----------------------------------------------------------------|
| 0b0 | A FIFO flush event from the MHUS does not generate an interrupt |
| 0b1 | A FIFO flush event from the MHUS generates an interrupt         |

The reset behavior of this field is:

• On a MHUS reset, this field resets to Ob1.

## Bits [30:3]

Reserved, RAZ.

#### FHT, bit [2]

FIFO High Tidemark

Controls whether a Receiver FIFO High Tidemark event generates an interrupt.

| FHT | Meaning                                                 |
|-----|---------------------------------------------------------|
| 060 | FIFO High Tidemark event does not generate an interrupt |

| FHT | Meaning                                         |
|-----|-------------------------------------------------|
| 0b1 | FIFO High Tidemark event generates an interrupt |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## FLT, bit [1]

FIFO Low Tidemark

Controls whether a Receiver FIFO Low Tidemark event generates an interrupt.

| FLT | Meaning                                                    |
|-----|------------------------------------------------------------|
| 0b0 | FIFO Low Tidemark event has does not generate an interrupt |
| 0b1 | FIFO Low Tidemark event generates an interrupt             |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## TFR, bit [0]

## Transfer

Controls whether a Transfer event generates an interrupt.

| TFR | Meaning                                       |
|-----|-----------------------------------------------|
| 0b0 | Transfer event does not generate an interrupt |
| 0b1 | Transfer event generates interrupt            |

The reset behavior of this field is:

• On a MHUR reset, this field resets to Ob1.

#### Accessing MFFCW<n>\_INT\_EN

Accesses to this register use the following encodings:

## Accessible at offset 0x0018 + (64 \* n) from MHUR.MBX.MFFCW\_page

Access on this interface is **RW**.

## C2.2.1.3.12 MFFCW<n>\_CTRL, Mailbox FIFO Channel Window <n> Control, n = 0 - 63

The MFFCW<n>\_CTRL characteristics are:

#### Purpose

Configures the behavior of FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_CTRL are RAZ/WI.

#### Attributes

MFFCW<n>\_CTRL is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_CTRL bit assignments are:



## FF, bit [31]

FIFO Flush

Request a flush of the FFCH

| FF  | Meaning                      |
|-----|------------------------------|
| 0b0 | No request to flush the FIFO |
| 0b1 | Request to flush the FIFO    |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

#### Bits [30:4]

Reserved, RESO.

## FTAB, bit [3]

Future Transfer Auto Buffering

| FTAB | Meaning                                                                                                                                                                                 |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 000  | Future Transfer Auto Buffering is not enabled.<br>The value of flags associated with bytes read<br>from the FIFO have no effect on the number of<br>bytes read or popped from the FIFO. |

| FTAB | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0b1  | <ul> <li>Future Transfer Auto Buffering is enabled</li> <li>When a read of the MFFCW<n>_PAY register</n></li> <li>with an access size greater than 1 occurs, any</li> <li>bytes read from the FIFO after the first byte with</li> <li>the EOT field set to 0b1 has been detected, are: <ul> <li>Not read or popped from the FIFO.</li> <li>The bytes are set to an UNKNOWN value in the read data response.</li> <li>Entries in the Flag History Buffer are set to invalid.</li> </ul> </li> </ul> |  |
|      | Only bytes up to the first byte read from the                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|      | FIFO with the EOT field set to 0b1 are popped from the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |

Must be used with the RA\_EN field set to 0b1, otherwise the field is considered to be 0b0

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## RA\_EN, bit [2]

Controls whether Read to acknowledge is enabled.

| RA_EN | Meaning                                                                                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060   | Read acknowledge is not enabled<br>Bytes are popped from the FIFO by writing to<br>MFFCW <n>_FIFO_POP register.<br/>THe number of bytes popped from the FIFO is<br/>determined by the value written to the<br/>MFFCW<n>_FIFO_POP register.</n></n>                                   |
| 061   | Read acknowledge is enabled<br>Bytes are popped from the FIFO by reading the<br>MFFCW <n>_PAY register.<br/>The number of bytes popped from the FIFO is<br/>determined by the:<br/>• Size of the access.<br/>• FTAB field value.<br/>• Value of the FOT flag for a byte which is</n> |
|       | • Value of the EOT flag for a byte which is<br>popped from the FIFO due to this read,<br>when the FTAB field is set 0b1.                                                                                                                                                             |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## MSBF, bit [1]

Most Significant Byte First

Selects the order in which bytes are read from the FIFO when multiple bytes are to be read due to a single read of the MFFCW<n>\_PAY register.

| MSBF | Meaning                      |
|------|------------------------------|
| 0b0  | Least Significant Byte first |
| 0b1  | Most Significant Byte first  |

FFCH are considered little endian and the LSB is the byte lowest offset within the access and the MSB is the highest byte offset within the access.

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## MBX\_COMB\_EN, bit [0]

### Mailbox Combined Enable

Controls whether interrupts from the FFCH contribute to the Mailbox Combined interrupt.

| MBX_COMB_EN | Meaning                                                               |
|-------------|-----------------------------------------------------------------------|
| 0d0         | FFCH interrupts does not contribute to the Mailbox Combined interrupt |
| 0b1         | FFCH interrupts contributes to the Mailbox<br>Combined interrupt      |

The reset behavior of this field is:

• On a MHUR reset, this field resets to Ob1.

## Accessing MFFCW<n>\_CTRL

Accesses to this register use the following encodings:

## Accessible at offset 0x0020 + (64 \* n) from MHUR.MBX.MFFCW\_page

Access on this interface is **RW**.

## C2.2.1.3.13 MFFCW<n>\_ST, Mailbox FIFO Channel Window <n> Status, n = 0 - 63

The MFFCW<n>\_ST characteristics are:

#### Purpose

Provides the status of the FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_ST are RAZ/WI.

#### Attributes

MFFCW<n>\_ST is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_ST bit assignments are:



## FF, bit [31]

## FIFO Flush

Status of MHUR FIFO Flush mechanism for the FFCH.

| FF  | Meaning                                                                                                                                                                                                                                                                                                  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060 | The meaning of this value depends on the value<br>of the FF field in the corresponding<br>MFFCW <n>_CTRL register.<br/>When MFFCW<n>_CTRL.FF is 0b0<br/>Receiver FIFO flush mechanism is idle.<br/>When MFFCW<n>_CTRL;FF is 0b1<br/>Receiver FIFO flush mechanism is performing a<br/>flush.</n></n></n> |
| 0b1 | FIFO flush complete                                                                                                                                                                                                                                                                                      |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

## Bits [30:11]

Reserved, RESO.

### FFL, bits [10:0]

FIFO Fill Level

Indicates the number of valid bytes in the FIFO.

The maximum value returned is never greater than the FIFO Depth.

#### Accessing MFFCW<n>\_ST

Accesses to this register use the following encodings:

## Accessible at offset 0x0024 + (64 \* n) from MHUR.MBX.MFFCW\_page

Access on this interface is **RO**.

## C2.2.1.3.14 MFFCW<n>\_FIFO\_POP, Mailbox FIFO Channel Window <n> FIFO POP, n = 0 - 63

The MFFCW<n>\_FIFO\_POP characteristics are:

#### Purpose

Request bytes to be popped from the FIFO of FFCH<n>.

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_FIFO\_POP are RAZ/WI.

#### Attributes

MFFCW<n>\_FIFO\_POP is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_FIFO\_POP bit assignments are:



#### Bits [31:3]

Reserved, RESO.

#### POP, bits [2:0]

Number of bytes to pop from the FIFO.

This is the maximum number of bytes popped from the FIFO.

The number of bytes actually popped from the FIFO is as follows:

- When MFFCW<n>\_CTRL.RA\_EN is set to 0b1 no bytes are popped from the FIFO.
- When MFFCW<n>\_CTRL.RA\_EN is set to 0b0 the number of bytes is the smallest of the following:
  - Value written to this field.
  - Number of valid bytes in the FIFO.

| POP   | Meaning                                                                                                                                                     | Applies         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 06000 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> | When !M8BA_SPT  |
| 0b000 | Maximum of 1 byte is popped from the FIFO                                                                                                                   | When M8BA_SPT   |
| 0b001 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> | When !M16BA_SPT |
| 0b001 | Maximum of 2 bytes are popped from the FIFO                                                                                                                 | When M16BA_SPT  |
| РОР   | Meaning                                                                                                                                                     | Applies         |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| 0b010 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> |                 |
| 0b011 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> | When !M32BA_SPT |
| 0b011 | Maximum of 4 bytes are popped from the FIFO                                                                                                                 | When M32BA_SPT  |
| 0b100 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> |                 |
| 0b101 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> |                 |
| 0b110 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> |                 |
| 0b111 | <ul><li>It is IMPLEMENTATION DEFINED whether:</li><li>No bytes are popped from the FIFO.</li><li>The value is treated as another supported value.</li></ul> | When !M64BA_SPT |
| 0b111 | Maximum of 8 bytes are popped from the FIFO                                                                                                                 | When M64BA_SPT  |

# Accessing MFFCW<n>\_FIFO\_POP

Accesses to this register use the following encodings:

# Accessible at offset 0x0028 + (64 \* n) from MHUR.MBX.MFFCW\_page

# C2.2.1.3.15 MFFCW<n>\_TIDE, Mailbox FIFO Channel Window <n> Tidemark, n = 0 - 63

The MFFCW<n>\_TIDE characteristics are:

#### Purpose

Allows configuration of the low and high tidemark thresholds for the Receiver tidemark events

#### Configuration

This register is present only when FE is implemented. Otherwise, direct accesses to MFFCW<n>\_TIDE are RAZ/WI.

#### Attributes

MFFCW<n>\_TIDE is a 32-bit register.

This register is part of the MHUR.MBX.MFFCW\_page block.

#### **Field descriptions**

The MFFCW<n>\_TIDE bit assignments are:



#### Bits [31:26]

Reserved, RESO.

#### HIGH, bits [25:16]

High Tide Mark

Threshold value used in the generation of the Receiver FIFO High Tide event.

The event is generated when a push to the FIFO occurs, and the following are both true:

- The FIFO fill level before the push was less than or equal to the value of this field.
- The FIFO fill level after the push is greater than the value of this field.

| HIGH                         | Meaning                  |  |
|------------------------------|--------------------------|--|
| 0b00000000000<br>⇔b111111111 | Threshold value in bytes |  |

The upper and lower offset of this field depend on the configuration of the MHU.

The upper offset of this field is equal to clog2(FFCH\_DEPTH)+15.

The lower offset of this field depends on the supported access sizes to MFFCW<n>\_PAY register as follows:

- When MBX\_FFCH\_CFG.M8BA\_SPT is 0b1 the lower offset is 16.
- When MBX\_FFCH\_CFG.M8BA\_SPT is 0b0 and MBX\_FFCH\_CFG.M16BA\_SPT is 0b1 the lower offset is 17.
- When MBX\_FFCH\_CFG.M{8/16}BA\_SPT are both 0b0 and MBX\_FFCH\_CFG.M32BA\_SPT is 0b1 the lower offset is 18.
- When MBX\_FFCH\_CFG.M{8/16/32}BA\_SPT are all 0b0 and MBX\_FFCH\_CFG.M64BA\_SPT is 0b1 the lower offset is 19.

Any offsets above the upper offset or below the lower offset are RESO.

If the upper offset is less than the lower offset the entire field is RESO.

For calculations of the Receiver High Tide event all offsets which are RESO are used.

The reset behavior of this field is:

• On a MHUR reset, the expression (FFCH\_DEPTH - 1) [u:1].

Where:

u = tide\_upr()

l = tide\_lwr([M64BA\_SPT,M32BA\_SPT,M16BA\_SPT,M8BA\_SPT])

### Bits [15:10]

Reserved, RESO.

### LOW, bits [9:0]

Low Tide Mark

Threshold value used in the generation of the Receiver FIFO Low Tide event.

The event is generated when a pop to the FIFO occurs, and the following are both true:

- The FIFO fill level before the pop was greater than the value of this field.
- The FIFO fill level after the pop is less than or equal the value of this field.

| LOW                         | Meaning                  |
|-----------------------------|--------------------------|
| 0b00000000000<br>→b11111111 | Threshold value in bytes |

The upper and lower offset of this field depend on the configuration of the MHU.

The upper offset of this field is equal to clog2(FFCH\_DEPTH)-1.

The lower offset of this field depends on the supported access sizes to MFFCW<n>\_PAY register as follows:

- When MBX\_FFCH\_CFG.M8BA\_SPT is 0b1 the lower offset is 0.
- When MBX\_FFCH\_CFG.M8BA\_SPT is 0b0 and MBX\_FFCH\_CFG.M16BA\_SPT is 0b1 the lower offset is 1.
- When MBX\_FFCH\_CFG.M{8/16}BA\_SPT are both 0b0 and MBX\_FFCH\_CFG.M32BA\_SPT is 0b1 the lower offset is 2.
- When MBX\_FFCH\_CFG.M{8/16/32}BA\_SPT are all 0b0 and MBX\_FFCH\_CFG.M64BA\_SPT is 0b1 the lower offset is 3.

Any offsets above the upper offset or below the lower offset are RESO.

If the upper offset is less than the lower offset the entire field is RESO.

For calculations of the Receiver Low Tide event all offsets which are RESO are used.

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b000000000.

# Accessing MFFCW<n>\_TIDE

Accesses to this register use the following encodings:

### Accessible at offset 0x002C + (64 \* n) from MHUR.MBX.MFFCW\_page

Chapter C2. Registers C2.2. MHUR, MHU Receiver

# C2.2.1.4 MFCW\_page, Mailbox Fast Channel Windows Page

The MFCW\_page characteristics are:

#### Purpose

Allows access to the MFCW.

Depending on the Fast Channel word-size either the MFCW<n>\_PAY32 or MFCW<n>\_PAY64 registers are implmented.

When the Fast Channel word-size is 32-bit

MFCW<n>\_PAY32 is implemented

There can be between 1 and 1024 MFCWs.

# When the Fast Channel word-size is 64-bit

MFCW<n>\_PAY64 is implemented

There can be between 1 and 512 MFCWs.

# Configuration

This Register Block is present only when FCE is implemented.

# Attributes

The MFCW\_page block is of size 4KB.

This block is part of the MHUR.MBX block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                             | Name               | Notes                                                                                                            |
|------------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------|
| 0x000 + (4 * n)for n in<br>→1023:0 | MFCW <n>_PAY32</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x20<br>Accessor condition: When FCH_WS == 0x20 |
| 0x000 + (4 * n)for n in<br>↔1023:0 | MFCW <n>_PAY32</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x20<br>Accessor condition: When FCH_WS == 0x20 |
| 0x000 + (8 * n)for n in<br>⇔511:0  | MFCW <n>_PAY64</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x40<br>Accessor condition: When FCH_WS == 0x40 |
| 0x000 + (8 * n)for n in<br>⇔511:0  | MFCW <n>_PAY64</n> | Most permissive access: RW<br>Register condition: When FCH_WS == 0x40<br>Accessor condition: When FCH_WS == 0x40 |

#### C2.2.1.4.1 MFCW<n>\_PAY32, Mailbox Fast Channel Window <n> Payload 32-bit, n = 0 - 1023

The MFCW<n>\_PAY32 characteristics are:

#### Purpose

Access to payload of FCH<n>

Arm recommends that accesses to these registers are atomic.

Note

This is the 32-bit version of the MFCW<n>\_PAY registers

#### Configuration

This register is present only when FCE is implemented and FCH\_WS == 0x20. Otherwise, direct accesses to MFCW<n>\_PAY32 are RAZ/WI.

#### Attributes

MFCW<n>\_PAY32 is a 32-bit register.

This register is part of the MHUR.MBX.MFCW\_page block.

#### **Field descriptions**

The MFCW<n>\_PAY32 bit assignments are:



#### PAY, bits [31:0]

Payload for Channel <n>

A write to this register sets the value of the payload.

A read to this register:

- Returns the current value of the payload.
- Acknowledges the Transfer.
- Clears the Transfer interrupt for the FCH, if it is set.

The reset behavior of this field is:

• On a MHUR reset, this field resets to an architecturally UNKNOWN value.

#### Accessing MFCW<n>\_PAY32

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (4 \* n) from MHUR.MBX.MFCW\_page

return MFCW<n>\_PAY32;

#### Write at offset 0x000 + (4 \* n) from MHUR.MBX.MFCW\_page

MFCW<n>\_PAY32 = value;

#### C2.2.1.4.2 MFCW<n>\_PAY64, Mailbox Fast Channel Window <n> Payload 64-bit, n = 0 - 511

The MFCW<n>\_PAY64 characteristics are:

#### Purpose

Access to payload of FCH<n>

Arm recommends that accesses to these registers are atomic.

Note

This is the 64-bit version of the MFCW<n>\_PAY registers

#### Configuration

This register is present only when FCE is implemented and FCH\_WS == 0x40. Otherwise, direct accesses to MFCW<n>\_PAY64 are RAZ/WI.

#### Attributes

MFCW<n>\_PAY64 is a 64-bit register.

This register is part of the MHUR.MBX.MFCW\_page block.

#### **Field descriptions**

The MFCW<n>\_PAY64 bit assignments are:



#### PAY, bits [63:0]

Payload for Channel <n>

A write to this register sets the value of the payload.

A read to this register:

- Returns the current value of the payload.
- Acknowledges the Transfer.
- Clears the Transfer interrupt for the FCH, if it is set.

The reset behavior of this field is:

• On a MHUR reset, this field resets to an architecturally UNKNOWN value.

#### Accessing MFCW<n>\_PAY64

Accesses to this register use the following encodings:

#### Read at offset 0x000 + (8 \* n) from MHUR.MBX.MFCW\_page

return MFCW<n>\_PAY64;

#### Write at offset 0x000 + (8 \* n) from MHUR.MBX.MFCW\_page

MFCW<n>\_PAY64 = value;

# C2.2.1.5 MBX\_IMPL\_DEF\_page, Mailbox Implementation Defined page

The MBX\_IMPL\_DEF\_page characteristics are:

#### Purpose

The MBX\_IMPL\_DEF\_page is for an implementation of the MHU, to implement any IMPLEMENTA-TION DEFINED registers.

Registers defined in this block must follow the rules in C1.7.3 IMPLEMENTATION DEFINED Page

#### Configuration

#### Attributes

The MBX\_IMPL\_DEF\_page block is of size 4KB.

This block is part of the MHUR.MBX block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                          | Name | Notes                                         |
|---------------------------------|------|-----------------------------------------------|
| 0x0000 + (4 * n)for n in 1023:0 | -    | Most permissive access: ImplementationDefined |

# C2.2.2 RSC, Receiver Security Control

The RSC characteristics are:

### Purpose

Contains the individual pages of the Receiver Security Control block.

Only accesses with the correct security can access the registers within the Receiver Security Control block, otherwise the access is treated as an illegal access.

The allowed security of an access to a register of the Receiver Security Control block depends on:

- Whether RME is implemented for the MHUR.
- Sampled value of MHUR LEGACY\_TZ\_EN input.

The following table list the allowed security states of an access:

| RME | TZE | LEGACY_TZ_EN | Allowed access security |
|-----|-----|--------------|-------------------------|
| 0   | 0   | NA           | NA                      |
| 0   | 1   | NA           | Secure                  |
| 1   | 1   | 0            | Root                    |
|     |     | 1            | Secure                  |

### Configuration

This Register Block is present only when TZE is implemented for the MHUR.

#### Attributes

The RSC block is of size 64KB.

This block is part of the MHUR block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset | Name              | Notes                      |
|--------|-------------------|----------------------------|
| 0x0000 | RSC_CTRL_page     | Most permissive access: RW |
| 0xF000 | RSC_IMPL_DEF_page | Most permissive access: RW |

# C2.2.2.1 RSC\_CTRL\_page, Receiver Security Control Page

The RSC\_CTRL\_page characteristics are:

#### Purpose

Allow assignment of resources of the MHUR to a Security Group.

#### Configuration

This Register Block is present only when TZE is implemented for the MHUR.

#### Attributes

The RSC\_CTRL\_page block is of size 4KB.

This block is part of the MHUR.RSC block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                       | Name                    | Notes                                                                                                                          |
|------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 0x000                        | RSC_BLK_ID              | Most permissive access: RO                                                                                                     |
| 0x010                        | RSC_FEAT_SPT0           | Most permissive access: RO                                                                                                     |
| 0x014                        | RSC_FEAT_SPT1           | Most permissive access: RO                                                                                                     |
| 0x020                        | RSC_DBCH_CFG0           | Most permissive access: RO<br>Register condition: When DBE is<br>implemented<br>Accessor condition: When DBE is<br>implemented |
| 0x030                        | RSC_FFCH_CFG0           | Most permissive access: RO<br>Register condition: When FE is<br>implemented<br>Accessor condition: When FE is<br>implemented   |
| 0x040                        | RSC_FCH_CFG0            | Most permissive access: RO<br>Register condition: When FCE is<br>implemented<br>Accessor condition: When FCE is<br>implemented |
| 0x110 + (4 * n)for n in 0    | RSC_MBX_SG <n></n>      | Most permissive access: RW                                                                                                     |
| 0xFC8                        | RSC_IIDR                | Most permissive access: RO                                                                                                     |
| OxFCC                        | RSC_AIDR                | Most permissive access: RO                                                                                                     |
| 0xFD0 + (4 * n)for n in 11:0 | RSC_IMPL_DEF_ID <n></n> | Most permissive access: RO                                                                                                     |

## C2.2.2.1.1 RSC\_BLK\_ID, Receiver Security Block Identifier

The RSC\_BLK\_ID characteristics are:

#### Purpose

Identifies the block as a Receiver Security.

#### Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_BLK\_ID are RAZ/WI.

#### Attributes

RSC\_BLK\_ID is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_BLK\_ID bit assignments are:

| 31   | 4 | 3 |   |     | 0   |    |
|------|---|---|---|-----|-----|----|
| RES0 |   | 0 | 0 | 1   | 1   | I  |
|      |   |   |   | _BI | _K_ | ID |

### Bits [31:4]

Reserved, RESO.

#### BLK\_ID, bits [3:0]

**Block Identifier** 

Identifies the type of block that resides in this 64KB.

Reads as 0b0011

Identifies the block as the Receiver Security block.

Access to this field is RO.

Accessing RSC\_BLK\_ID

Accesses to this register use the following encodings:

#### Accessible at offset 0x000 from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.1.2 RSC\_FEAT\_SPT0, Receiver Security Feature Support 0

The RSC\_FEAT\_SPT0 characteristics are:

#### Purpose

Provides information on the features implemented in the Receiver Security.

#### Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_FEAT\_SPT0 are RAZ/WI.

#### Attributes

RSC\_FEAT\_SPT0 is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_FEAT\_SPT0 bit assignments are:

| 131 24 | 23 20    | 19 16   | 15 12   | 11 8    | 7 4    | 3 0     |
|--------|----------|---------|---------|---------|--------|---------|
| RES0   | RASE_SPT | RME_SPT | TZE_SPT | FCE_SPT | FE_SPT | DBE_SPT |

#### Bits [31:24]

Reserved, RESO.

#### RASE\_SPT, bits [23:20]

Reliability, Availability and Serviceability Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RASE_SPT | Meaning                                                                                                                                                           |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060000   | MHU does not implement the RAS extension                                                                                                                          |
| 060010   | MHU implements the RAS extension but does<br>not follow the recommendations in B10.7<br><i>Recommend implementation of RAS using Arm</i><br><i>RAS extensions</i> |
| 0b0011   | MHU implements the RAS extension and<br>follows the recommendations in B10.7<br><i>Recommend implementation of RAS using Arm</i><br><i>RAS extensions</i>         |

Access to this field is RO.

# RME\_SPT, bits [19:16]

Realm Management Extension Support

The value of this field depends on the implementation of the MHU and an optional reset time sampled input LEGACY\_TZ\_EN.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| RME_SPT | Meaning                                                  |
|---------|----------------------------------------------------------|
| 0000d0  | MHU does not implement the Realm<br>Management extension |
| 0b0001  | MHU implements Realm Management extension                |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

When RME is implemented, for the half of the MHU, there can be a **LEGACY\_TZ\_EN** tie-off present on that side of the MHU.

The value of the LEGACY\_TZ\_EN tie-off is sampled at reset of the side of the MHU which the tie-off is associated with.

When the sampled value of the tie-off is 0b1 the value of this field is always 0x0, otherwise the value of this field is dependent on whether RME is implemented for this half of the MHU.

Access to this field is RO.

#### TZE\_SPT, bits [15:12]

TrustZone Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| TZE_SPT | Meaning                                        |
|---------|------------------------------------------------|
| 00000   | MHU does not implement the TrustZone extension |
| 0b0001  | MHU implements TrustZone extension             |

The value of this field only applies to the half of the MHU which the register is associated with.

It is valid for the different halves of the MHU to implement different values for this field.

For fields in the PBX\_FEAT\_SPT0 or SSC\_FEAT\_SPT0 the value applies to the MHUS only.

For fields in the MBX\_FEAT\_SPT0 or RSC\_FEAT\_SPT0 the value applies to the MHUR only.

Access to this field is RO.

#### FCE\_SPT, bits [11:8]

Fast Channel Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCE_SPT | Meaning                                           |
|---------|---------------------------------------------------|
| 060000  | MHU does not implement the Fast Channel extension |

| FCE_SPT | Meaning                               |
|---------|---------------------------------------|
| 0b0001  | MHU implements Fast Channel extension |

Access to this field is **RO**.

# FE\_SPT, bits [7:4]

FIFO Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FE_SPT | Meaning                                   |
|--------|-------------------------------------------|
| 0000d0 | MHU does not implement the FIFO extension |
| 0b0001 | MHU implements FIFO extension             |

Access to this field is **RO**.

# DBE\_SPT, bits [3:0]

Doorbell Extension Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| DBE_SPT | Meaning                                       |
|---------|-----------------------------------------------|
| 00000   | MHU does not implement the Doorbell extension |
| 0b0001  | MHU implements Doorbell extension             |

Access to this field is **RO**.

# Accessing RSC\_FEAT\_SPT0

Accesses to this register use the following encodings:

Accessible at offset 0x010 from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.1.3 RSC\_FEAT\_SPT1, Receiver Security Feature Support 1

The RSC\_FEAT\_SPT1 characteristics are:

#### Purpose

Provides information on the features implemented in the Receiver Security.

#### Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_FEAT\_SPT1 are RAZ/WI.

#### Attributes

RSC\_FEAT\_SPT1 is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_FEAT\_SPT1 bit assignments are:



### Bits [31:4]

Reserved, RESO.

#### AUTO\_OP\_SPT, bits [3:0]

Auto Op Protocol Support

The value of this field depends on the implementation of the MHU.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| AUTO_OP_SPT | Meaning                      |
|-------------|------------------------------|
| 00000       | Auto Op(Min) is implemented  |
| 0b0001      | Auto Op(Full) is implemented |

Access to this field is **RO**.

Accessing RSC\_FEAT\_SPT1

Accesses to this register use the following encodings:

# Accessible at offset 0x014 from MHUR.RSC.RSC\_CTRL\_page

## C2.2.2.1.4 RSC\_DBCH\_CFG0, Receiver Security Doorbell Channel Configuration 0

The RSC\_DBCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of DBE in MHUR.

#### Configuration

This register is present only when TZE is implemented for the MHUR and DBE is implemented. Otherwise, direct accesses to RSC\_DBCH\_CFG0 are RAZ/WI.

#### Attributes

RSC\_DBCH\_CFG0 is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_DBCH\_CFG0 bit assignments are:

| 131 8 1 7 | 7 0      |
|-----------|----------|
| RES0      | NUM_DBCH |

#### Bits [31:8]

Reserved, RESO.

#### NUM\_DBCH, bits [7:0]

Number of Doorbell Channels

Number of DBCH implemented in the MHUR.

The value of this field is an IMPLEMENTATION DEFINED choice of:

# NUM\_DBCH Meaning 0x00..0x7F Number of DBCH is N+1, where N is the value

of this field

Access to this field is **RO**.

Accessing RSC\_DBCH\_CFG0

Accesses to this register use the following encodings:

Accessible at offset 0x020 from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.1.5 RSC\_FFCH\_CFG0, Receiver Security FIFO Channel Configuration 0

The RSC\_FFCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of FE in Receiver Security.

#### Configuration

This register is present only when TZE is implemented for the MHUR and FE is implemented. Otherwise, direct accesses to RSC\_FFCH\_CFG0 are RAZ/WI.

#### Attributes

RSC\_FFCH\_CFG0 is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_FFCH\_CFG0 bit assignments are:



## Bits [31:26]

Reserved, RESO.

### FFCH\_DEPTH, bits [25:16]

FIFO Channel Depth

Depth of the FIFOs of the FFCHs in the MHUR.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FFCH_DEPTH                 | Meaning                                                      |
|----------------------------|--------------------------------------------------------------|
| 0b0000000000<br>⇔b11111111 | FIFO depth is N+1 bytes, where N is the value of this field. |

Access to this field is RO.

Bits [15:12]

Reserved, RESO.

# M64BA\_SPT, bit [11]

Mailbox 64-bit Access Support

Whether 64-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M64BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0b0       | 64-bit accesses are not supported |
| 0b1       | 64-bit accesses are supported     |

Accesses must be aligned to an 64-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

When 64-bit accesses are supported the:

- MFFCW<n>\_PAY register occupies offsets 0x00-0x07 of the MFFCW.
- MFFCW<n>\_FLG register occupies offsets 0x008-0x0F of the MFFCW.

When 64-bit accesses are not supported:

- MFFCW<n>\_PAY register occupies offsets 0x00-0x03 of the MFFCW and offsets 0x04-0x07 of the MFFCW are RES0.
- MFFCW<n>\_FLG register occupies offsets 0x008-0x0B of the MFFCW and offsets 0x0C-0x0F of the MFFCW are RES0.

Access to this field is RO.

#### M32BA\_SPT, bit [10]

Mailbox 32-bit Access Support

Whether 32-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M32BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0d0       | 32-bit accesses are not supported |
| 0b1       | 32-bit accesses are supported     |

Accesses must be aligned to an 32-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

#### M16BA\_SPT, bit [9]

Mailbox 16-bit Access Support

Whether 16-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M16BA_SPT | Meaning                           |
|-----------|-----------------------------------|
| 0b0       | 16-bit accesses are not supported |
| 0b1       | 16-bit accesses are supported     |

Accesses must be aligned to an 16-bit boundary.

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is **RO**.

# M8BA\_SPT, bit [8]

Mailbox 8-bit Access Support

Whether 8-bit accesses to the following registers are supported:

- MFFCW<n>\_PAY
- MFFCW<n>\_FLG

The value of this field is an IMPLEMENTATION DEFINED choice of:

| M8BA_SPT | Meaning                          |
|----------|----------------------------------|
| 0b0      | 8-bit accesses are not supported |
| 0b1      | 8-bit accesses are supported     |

Accesses must be aligned to an 8-bit boundary

The value of this field has no effect on the supported access sizes to any other registers.

Access to this field is RO.

#### NUM\_FFCH, bits [7:0]

Number of FIFO Channels

The number of FFCHs in the MHUR.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FFCH | Meaning                                                    |
|----------|------------------------------------------------------------|
| 0x000x3F | Number of FFCHs is N+1, where N is the value of this field |

Access to this field is RO.

#### Accessing RSC\_FFCH\_CFG0

Accesses to this register use the following encodings:

# Accessible at offset 0x030 from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.1.6 RSC\_FCH\_CFG0, Receiver Security Fast Channel Configuration 0

The RSC\_FCH\_CFG0 characteristics are:

#### Purpose

Provides information on the configuration of FCE in the MHUR.

#### Configuration

This register is present only when TZE is implemented for the MHUR and FCE is implemented. Otherwise, direct accesses to RSC\_FCH\_CFG0 are RAZ/WI.

#### Attributes

RSC\_FCH\_CFG0 is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_FCH\_CFG0 bit assignments are:



#### Bits [31:29]

Reserved, RESO.

### FCH\_WS, bits [28:21]

Fast Channel Word-Size

Number of bits each FCH implements.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCH_WS | Meaning                           |
|--------|-----------------------------------|
| 0x20   | Fast Channel word-size is 32-bits |
| 0x40   | Fast Channel word-size is 64-bits |

Access to this field is **RO**.

#### NUM\_FCH\_PER\_FCG, bits [20:16]

Number of Fast Channels per Fast Channel Group

Number of FCHs implemented in FCGs for MHUR.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH_PER_FCG | Meaning                                                           |
|-----------------|-------------------------------------------------------------------|
| 0b000000b11111  | Number of FCHs per FCG is N+1, where N is the value of this field |

Access to this field is RO.

# NUM\_FCG, bits [15:11]

Number of Fast Channel Groups

Number of FCGs implemented in MHUR

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCG             | Meaning                                                   |
|---------------------|-----------------------------------------------------------|
| 0b000000<br>⇔b11111 | Number of FCGs is N+1, where N is the value of this field |

Access to this field is RO.

# FCGI\_SPT, bit [10]

Fast Channel Group Interrupt Support

Indicates whether Fast Channel Group Transfer interrupt is implemented for each FCGs.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| FCGI_SPT | Meaning                                                     |
|----------|-------------------------------------------------------------|
| 0d0      | Fast Channel Group Transfer interrupts are not implemented. |
| 0b1      | Fast Channel Group Transfer interrupts are implemented.     |

Access to this field is RO.

#### NUM\_FCH, bits [9:0]

Number of Fast Channels

Number of FCHs implemented in MHUR.

The value of this field is an IMPLEMENTATION DEFINED choice of:

| NUM_FCH                     | Meaning                                                  | Applies             |
|-----------------------------|----------------------------------------------------------|---------------------|
| 0b0000000000<br>⇔b011111111 | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x40 |
| 0b0000000000<br>⇔b11111111  | Number of FCH is N+1, where N is the value of this field | When FCH_WS == 0x20 |

Access to this field is RO.

#### Accessing RSC\_FCH\_CFG0

Accesses to this register use the following encodings:

### Accessible at offset 0x040 from MHUR.RSC.RSC\_CTRL\_page

## C2.2.2.1.7 RSC\_MBX\_SG<n>, Receiver Mailbox Security Group <n>, n = 0 - 0

The RSC\_MBX\_SG<n> characteristics are:

#### Purpose

Configuration of the Security Group of the Mailbox

#### Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_MBX\_SG<n> are RAZ/WI.

#### Attributes

RSC\_MBX\_SG<n> is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_MBX\_SG<n> bit assignments are:

When RME is implemented for the MHUR and sampled value of MHUR LEGACY\_TZ\_EN is 0b0:



# Bits [31:2]

Reserved, RESO.

#### SG\_MBX<m>, bits [2m+1:2m], for m = 0

Security Group for Mailbox

| SG_MBX <m></m> | Meaning                                              |
|----------------|------------------------------------------------------|
| 0600           | Mailbox is assigned to the Secure Security Group     |
| 0b01           | Mailbox is assigned to the Non-secure Security Group |
| 0b10           | Mailbox is assigned to the Root Security Group       |
| 0b11           | Mailbox is assigned to the Realm Security Group      |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b10.

When RME is not implemented for the MHUR or (RME is implemented for the MHUR and sampled value of MHUR LEGACY\_TZ\_EN is 0b1):



Bits [31:1]

Reserved, RESO.

# **SG\_MBX<m>**, bits [m], for **m** = **0**

Security Group for Mailbox

| SG_MBX <m></m> | Meaning                                              |
|----------------|------------------------------------------------------|
| 060            | Mailbox is assigned to the Secure Security Group     |
| 0b1            | Mailbox is assigned to the Non-secure Security Group |

The reset behavior of this field is:

• On a MHUR reset, this field resets to 0b0.

# Accessing RSC\_MBX\_SG<n>

Accesses to this register use the following encodings:

## Accessible at offset 0x110 + (4 \* n) from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.1.8 RSC\_IIDR, Receiver Security Implementer Identification Register

The RSC\_IIDR characteristics are:

#### Purpose

This field provides information on the implementation of the MHU

#### Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_IIDR are RAZ/WI.

#### Attributes

RSC\_IIDR is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

#### **Field descriptions**

The RSC\_IIDR bit assignments are:

| 31         | 20 | 19 16   | 15 12    | 11 0        |
|------------|----|---------|----------|-------------|
| PRODUCT_ID |    | VARIANT | REVISION | IMPLEMENTER |

#### PRODUCT\_ID, bits [31:20]

Product ID of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is **RO**.

#### VARIANT, bits [19:16]

Variant or major revision of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

#### **REVISION**, bits [15:12]

Revision or minor version of the MHU implementation

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

#### **IMPLEMENTER**, bits [11:0]

Implementer ID

Contains the JEP106 identification information as follows:

- 11:8 JEP106 continuation code of implementer
- 7 Always 0
- 6:0 JEP106 identity code of implementer

This field has an IMPLEMENTATION DEFINED value.

Access to this field is RO.

#### Accessing RSC\_IIDR

Accesses to this register use the following encodings:

# Accessible at offset 0xFC8 from MHUR.RSC.RSC\_CTRL\_page

## C2.2.2.1.9 RSC\_AIDR, Receiver Security Architecture Identification Register

The RSC\_AIDR characteristics are:

#### Purpose

Provides information on the version of the MHU architecture implemented in this implementation of the MHU.

#### Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_AIDR are RAZ/WI.

#### Attributes

RSC\_AIDR is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

# **Field descriptions**

The RSC\_AIDR bit assignments are:



# Bits [31:8]

Reserved, RESO.

# ARCH\_MAJOR\_REV, bits [7:4]

MHU Architecture Major Revision

The value of this field is an IMPLEMENTATION DEFINED choice of:

| ARCH_MAJOR_REV | Meaning                                |
|----------------|----------------------------------------|
| 000000         | MHUv1 or unknown architecture versions |
| 0b0001         | MHUv2                                  |
| 0b0010         | MHUv3                                  |

All other values are Reserved

Access to this field is RO.

# ARCH\_MINOR\_REV, bits [3:0]

MHU Architecture Minor Revision

The value of this field is an IMPLEMENTATION DEFINED choice of:

| ARCH_MINOR_REV | Meaning                                    |
|----------------|--------------------------------------------|
| 000000         | Minor revision 0 of the major architecture |
| 0b0001         | Minor revision 1 of the major architecture |

All other values are Reserved

Access to this field is RO.

# Additional information

The legal combinations for the ARCH\_MAJOR\_REV and ARCH\_MINOR\_REV fields are as follows:

| ARCH_MAJOR_REV | ARCH_MINOR_REV | Description |
|----------------|----------------|-------------|
| 0x0            | 0x0            | MHUv1       |
| 0x1            | 0x0            | MHUv2.0     |
| 0x1            | 0x1            | MHUv2.1     |
| 0x2            | 0x0            | MHUv3.0     |

MHU implementations based on this architecture, have the ARCH\_MAJOR\_REV set to 0x2 and ARCH\_MINOR\_REV set to 0x0.

# Accessing RSC\_AIDR

Accesses to this register use the following encodings:

## Accessible at offset 0xFCC from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.1.10 RSC\_IMPL\_DEF\_ID<n>, IMPDEF Register, n = 0 - 11

The RSC\_IMPL\_DEF\_ID<n> characteristics are:

### Purpose

This register is for IMPLEMENTATION DEFINED Identification Registers which can be used to identify the implementation of the MHU Receiver Security

An implementation can do the following with this register:

- Chose whether a register is present or not.
- The name of the register.
- The access permission of the registers, so long as they are not more permissive than the architecture defines for the IMPLEMENTATION DEFINED register.
- The names, behavior and reset value of any fields.
- The access permissions of any fields, so long as they are not more permissive than the register.

If the RSC\_IMPL\_DEF\_ID<n> is not present then the location is Reserved and treated as RESO

## Configuration

This register is present only when TZE is implemented for the MHUR. Otherwise, direct accesses to RSC\_IMPL\_DEF\_ID<n> are RAZ/WI.

#### Attributes

RSC\_IMPL\_DEF\_ID<n> is a 32-bit register.

This register is part of the MHUR.RSC.RSC\_CTRL\_page block.

# Field descriptions

The RSC\_IMPL\_DEF\_ID<n> bit assignments are:

IMPLEMENTATION DEFINED

#### **IMPLEMENTATION DEFINED, bits [31:0]**

IMPLEMENTATION DEFINED

# Accessing RSC\_IMPL\_DEF\_ID<n>

Accesses to this register use the following encodings:

Accessible at offset 0xFD0 + (4 \* n) from MHUR.RSC.RSC\_CTRL\_page

# C2.2.2.2 RSC\_IMPL\_DEF\_page, Receiver Security Control Implementation Defined page

The RSC\_IMPL\_DEF\_page characteristics are:

#### Purpose

The RSC\_IMPL\_DEF\_page is for an implementation of the MHU, to implement any IMPLEMENTATION DEFINED registers.

Registers defined in this block must follow the rules in C1.7.3 IMPLEMENTATION DEFINED Page

#### Configuration

This Register Block is present only when TZE is implemented for the MHUR.

#### Attributes

The RSC\_IMPL\_DEF\_page block is of size 4KB.

This block is part of the MHUR.RSC block.

#### **Default access**

Accesses to the address space of this block that do not resolve to a register or a further block are treated as RAZ/WI.

| Offset                          | Name | Notes                                         |
|---------------------------------|------|-----------------------------------------------|
| 0x0000 + (4 * n)for n in 1023:0 | -    | Most permissive access: ImplementationDefined |

Part D Appendix

# Chapter D1 Postbox and Mailbox Interrupt Logic

# D1.1 Postbox Interrupt Logic

I<sub>DFKWG</sub> Figure D1.1 shows an example logic structure of the interrupt generation logic of a Postbox.

# Chapter D1. Postbox and Mailbox Interrupt Logic D1.1. Postbox Interrupt Logic



Figure D1.1: Postbox interrupt logic

In Figure D1.1 the following apply:

- Dotted lines indicate optional output of logic.
- Dashed boxes indicate units which are repeated for each channel.
- <n> indicates the channel number, which starts from 0 for each type of channel.
- <x> is the number of DBCHs implemented in the Postbox.
- Circles with 'S' inside indicate points where status are generated for Postbox Combined interrupts.

Chapter D1. Postbox and Mailbox Interrupt Logic D1.2. Mailbox Interrupt Logic

# D1.2 Mailbox Interrupt Logic



Figure D1.2: Mailbox interrupt logic

In Figure D1.2 the following apply:

- Dotted lines indicate optional output of logic.
- Dashed boxes indicate units which are repeated for each channel.
- <n> indicates the channel number, which starts from 0 for each type of channel.
- <x> is the number of DBCHs implemented in the Postbox.
- <m> is the FCG number.
- <a> is the upper most Fast Channel Transfer interrupt which feeds into the Fast Channel Group Transfer interrupt <m>.
- <b> is lowest most Fast Channel Transfer interrupt which feeds into the Fast Channel Group Transfer interrupt <m>.
- Circles with 'S1' inside indicate points where status are generated for Mailbox Combined interrupt.
- Circles with 'S2' inside indicate points where status are generated for the Fast Channel Group Transfer interrupt.

# Chapter D2 Transport Protocols

| т      | This soutions as | ware the expected | transport protos | als used by the | Sandar and Dagaiyar  |
|--------|------------------|-------------------|------------------|-----------------|----------------------|
| ⊥GFTRL | This sections co | wers the expected | transport protoc | ois used by the | Sender and Receiver. |

- I<sub>ZDPMD</sub> A transport protocol is a method for a Sender to send Transfer to the Receiver using the channels of the MHU.
- R<sub>PZXLB</sub> MHUv3 supports the following transport protocols:
  - Doorbell
  - FIFO
  - Stream FIFO
  - Last-value
- S<sub>PNTZP</sub> Software must use one of the transport protocols described in this section to send Transfers using the MHUv3, otherwise it is not guaranteed that in future versions of the MHU architecture the same method will still work.

Chapter D2. Transport Protocols D2.1. Doorbell

# D2.1 Doorbell

| I <sub>dfjrp</sub> | The Doorbell transport protocol enables the Sender to indicate to the Receiver that a specific event has occurred.                                                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>CHFNH</sub> | It is software IMPLEMENTATION DEFINED:                                                                                                                                                                            |
|                    | <ul><li>The event associated with the doorbell.</li><li>If there is any out-band payload associated with the event.</li><li>The location of any out-band payload.</li></ul>                                       |
| R <sub>cbfzb</sub> | The Doorbell transport protocol can only be used with a DBCH.                                                                                                                                                     |
| I <sub>bQHLS</sub> | Each DBCH has 32 flags bits each of which can be used to indicate a different Doorbell event has occurred. Each time the Sender sets one or more of the flags bits of the DBCH it is considered its own Transfer. |

# **D2.1.1 Requirements**

S<sub>RRSPW</sub> To use the Doorbell protocol the Channel Transfer and Channel Transfer Acknowledge events of the DBCH are used and the Sender and Receiver must configure the DBCH so that the Sender and Receiver can receive these events.

# D2.1.1.1 Sender Requirements

- S<sub>JPZDF</sub> The Sender must only write to the PDBCW<n>\_SET register after the event which the Doorbell is related to has occurred and any out-band payload is guaranteed to be visible to the Receiver.
- $S_{RPHDK}$  Once a flag bit is set, the Sender must wait for the Receiver to acknowledge the flag by clearing it, before the Sender uses the same flag bit to send a new Transfer.
- $S_{WFNDP}$  The Sender knows that the Receiver has acknowledged one or more previous Transfers by waiting for the flag bit or bits in the PDBCW<n>\_ST register to read as 0b0.
- SLQMQX
   The Sender can use the Channel Transfer Acknowledge event to know when the Receiver has acknowledged one or more previous Transfer and therefore the values of one or more flag bits in the PDBCW<n>\_ST register have been updated. This removes the need for the Sender to poll the PDBCW<n>\_ST register.

# D2.1.1.2 Receiver Requirements

- SDFTCQThe Receiver acknowledges receipt of the Transfer by clearing the flag in the MDBCW<n>\_ST register by writing<br/>the MDBCW<n>\_CLR register with the corresponding bit set to 0b1.
- S<sub>JHYLC</sub> Any flag bit of the MDBCW<n>\_ST register used, which are required to generate a Channel Transfer event, the Receiver must have the corresponding bit in the MDBCW<n>\_MSK\_ST register set to 0b0.
- $I_{CWJPP}$  If a flag bit in the MDBCW<n>\_ST register is not required to generate a Channel Transfer event, the Receiver must set the corresponding bit in the MDBCW<n>\_MSK\_ST register to be set to 0b1.

# D2.1.2 Procedure

R<sub>XHYYQ</sub> In Figure D2.1 the sequence of events to use the Doorbell transport protocol is shown. Arrows with dotted lines indicate optional steps.

Chapter D2. Transport Protocols D2.1. Doorbell



Figure D2.1: Doorbell transport protocol

The sequence of events are:

- 1. Sender writes any optional out-band payload for the Transfer to the out-band memory.
- 2. Sender writes Ob1, to the correct flag in the PDBCW<n>\_SET register.
- 3. MHU generates a Channel Transfer event. The Channel Transfer events can generate one or more interrupts depending on the settings the DBCH in the Mailbox:
  - Channel Transfer interrupt, if the corresponding bit in the MDBCW<n>\_MSK\_ST register is set to 0b0.
  - Mailbox Combined interrupt, if the corresponding bit in the MDBCW<n>MSK\_ST register is set to 0b0 .and MDBCW<n>\_CTRL.MBX\_COMB\_EN is set to 0b1.
- 4. Receiver reads MDBCW<n>\_ST register to identify which Doorbell(s) are outstanding.
- 5. Receiver reads any optional payload for the Transfer.
- 6. Receiver clears the flag by writing 0b1, to the corresponding bit in the MDBCW<n>\_CLR register.
- 7. MHU generates a Channel Transfer Acknowledge event. The Channel Transfer Acknowledge event can generate one or more interrupts of the following interrupts:
  - Channel Transfer Acknowledge interrupt, if PDBCW<n>\_INT\_EN.CH\_TFR\_ACK is set to 0b1.
  - Postbox Combined interrupt, if PDBCW<n>\_CTRL.PBX\_COMB\_EN is set to 0b1.

The steps performed by the Sender and Receiver in Figure D2.1 can be run concurrently or sequentially. It is even possible that the Sender is performing the sequences for Transfer Y whilst the Receiver is performing the sequences for Transfer X, where Transfer X is sent by before Transfer Y.

When the Receiver performs step 6 it is enabling the Sender to send another Transfer using the flag bit that was cleared. It is not required that Receiver has acted on the previous Transfer and, if there is any out-band payload, has finished with its use of the payload.
## D2.2 FIFO

| I <sub>NYHNP</sub> | FIFO transport protocol enables:                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <ul> <li>Multiple Transfers in-flight using a single channel.</li> <li>Transfers with variable length.</li> <li>Transfers with in-band payload and an optional out-band payload.</li> </ul>                                                                                                                                                                                                                                                                   |
| S <sub>GSFDN</sub> | It is software IMPLEMENTATION DEFINED:                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | <ul> <li>What the values of the data mean.</li> <li>How many bytes of in-band and out-band data there are in a Transfer, but there must be at least one byte of in-band payload.</li> <li>Whether the number of bytes in-band and out-band payload is the same for all Transfers.</li> <li>The location of any out-band payload.</li> <li>Whether the Sender of the Transfer receives interrupts when the Receiver acknowledges a Transfer or not.</li> </ul> |
| I <sub>VXWVD</sub> | The number of outstanding Transfers is limited by the amount of in-band data each Transfer uses and the depth of the FIFO.                                                                                                                                                                                                                                                                                                                                    |
| S <sub>CYMNN</sub> | The maximum amount of in-band data a Transfer uses must not exceed the FIFO depth, otherwise data loss can occur.                                                                                                                                                                                                                                                                                                                                             |

### D2.2.1 Requirements

| I <sub>pydyk</sub> | This sections covers the requirements to use the FIFO transport protocol.                                                                                                                 |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>dbhrh</sub> | The FIFO transport protocol must only be used with a FFCH.                                                                                                                                |
| S <sub>NXYYW</sub> | The Sender and Receiver must use the same value for PFFCW <n>_CTRL.MSBF and MFFCW<n>_CTRL.MSBF fields for the same Transfer when pushing, reading or popping bytes from the FIFO.</n></n> |
| $S_{\rm JTWFG}$    | The method by which the Sender and Receiver agree on what value to set the PFFCW <n>_CTRL.MSBF and MFFCW<n>_CTRL.MSBF fields to is software IMPLEMENTATION DEFINED.</n></n>               |
| $S_{CJXMN}$        | The Sender can write zero or more bytes to an out-band payload location. It is software IMPLEMENTATION DEFINED when the Receiver reads the out-band payload and depends on the following: |

- How and when the Receiver knows the address to use to access the out-band payload.
- When and how the Sender knows that the out-band payload location is no longer required by the Receiver.

### D2.2.1.1 Sender Requirements

| $S_{\rm KBKHN}$    | The Sender must not push new data onto the FIFO if the FIFO is full.                                                                                                         |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I <sub>LBLHV</sub> | The Sender can determine the amount of free space in the FIFO using the value in the PFFCW <n>_ST.FFS field or the Sender Low and High Tide events.</n>                      |
| S <sub>MVQWK</sub> | The Sender must only push bytes onto the FIFO which belong to the same Transfer using a single write to the PFFCW <n>_PAY register.</n>                                      |
| S <sub>TZFZR</sub> | The Sender is only allowed to change the value of the PFFCW <n>_CTRL.MSBF field before it pushes any bytes onto the FIFO for the Transfer.</n>                               |
| I <sub>byyrd</sub> | Depending on the Transfer Delineation mode being used the Sender must obey different rules for the following:                                                                |
|                    | <ul> <li>Management of the SOT, EOT and ACK flags.</li> <li>Number of writes to the PFFCW<n>_PAY register, to push data onto the FIFO, for a single Transfer.</n></li> </ul> |

# Chapter D2. Transport Protocols D2.2. FIFO

S<sub>BYDXR</sub> When using software flag Transfer Delineation mode the Sender must:

- Set the PFFCW<n>\_FLG.SOT field to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the first byte of the Transfer.
- Have the first byte of the Transfer in either the:
  - LSB position when PFFCW<n>\_CTRL.MSBF is set to 0b0.
  - MSB position when PFFCW<n>\_CTRL.MSBF is set to 0b1.
- Set the PFFCW<n>\_FLG.SOT field to 0b0 before it pushes one or more bytes onto the FIFO, where none of the bytes are the first byte of the Transfer.
- Set the PFFCW<n>\_FLG.ACK field to the correct value before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.
  - If the Sender wants a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>\_FLG.ACK field to 0b1.
  - If the Sender does not want a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>\_FLG.ACK field to 0b0.
- Set the PFFCW<n>\_FLG.EOT field to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.
- Have the last byte of the Transfer in either the:
  - MSB position when PFFCW<n>\_CTRL.MSBF is set to 0b0.
  - LSB position when PFFCW<n>\_CTRL.MSBF is set to 0b1.
- Set the PFFCW<n>\_FLG.EOT field to 0b0 before it pushes one or more bytes onto the FIFO, where none of the bytes are the last byte of the Transfer.
- S<sub>TKHBM</sub> When using software flag Transfer Delineation mode the Sender can perform as many writes to the PFFCW<n>\_PAY register as required to push all data of the Transfer onto the FIFO. So long as there is space in the FIFO for all bytes, requested by the write to be pushed, to be pushed onto the FIFO. It is not required that each write to the PFFCW<n>\_PAY register, when using software flag Transfer Delineation mode, are of the same size.
- S<sub>ZFYHY</sub> It might be required that the Sender either:
  - Has to wait between writes to the PFFCW<n>\_PAY register for FIFO to have enough space to push next N bytes of the Transfer.
  - Has to reduce the number of bytes to be pushed onto the FIFO.
- S<sub>YZTJD</sub> When using partial flag Transfer Delineation mode the Sender must:
  - Set the PFFCW<n>\_FLG.{SOT/EOT} fields to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the first byte of and one of the bytes is the last byte of the Transfer. This also applies if they are the same byte.
  - Set the PFFCW<n>\_FLG.EOT field to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer and none of the bytes are the first byte of the Transfer.
  - Set the PFFCW<n>\_FLG.ACK field to the correct value before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.
    - If the Sender wants a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>\_FLG.ACK field to 0b1.
    - If the Sender does not want a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>\_FLG.ACK field to 0b0.
  - Have the first byte of the Transfer in either the:
    - LSB position when PFFCW<n>\_CTRL.MSBF is set to 0b0.
    - MSB position when PFFCW<n>\_CTRL.MSBF is set to 0b1.
  - Have the last byte of the Transfer in either the:

# Chapter D2. Transport Protocols D2.2. FIFO

- MSB position when PFFCW<n>\_CTRL.MSBF is set to 0b0.
- LSB position when PFFCW<n>\_CTRL.MSBF is set to 0b1.
- S<sub>HWSBQ</sub> When using partial flag Transfer Delineation mode the Sender can perform as many writes to the PFFCW<n>\_PAY register as required to push all data of the Transfer onto the FIFO. So long as there is space in the FIFO for all bytes, requested by the write to be pushed, to be pushed onto the FIFO. It is not required that each write to the PFFCW<n>\_PAY register, when using partial flag Transfer Delineation mode, are of the same size.
- S<sub>LHVZP</sub> It might be required that the Sender either:
  - Has to wait between writes to the PFFCW<n>\_PAY register for FIFO to have enough space to push next N bytes of the Transfer.
  - Has to reduce the number of bytes to be pushed onto the FIFO.

#### S<sub>WZXHD</sub> When using auto flag Transfer Delineation mode the Sender must:

- Set the PFFCW<n>\_FLG.ACK field to the correct value before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.
  - If the Sender wants a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>\_FLG.ACK field to 0b1.
  - If the Sender does not want a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>\_FLG.ACK field to 0b0.
- Have the first byte of the Transfer in either the:
  - LSB position when PFFCW<n>\_CTRL.MSBF is set to 0b0.
  - MSB position when PFFCW<n>\_CTRL.MSBF is set to Ob1.
- Have the last byte of the Transfer in either the:
  - MSB position when PFFCW<n>\_CTRL.MSBF is set to 0b0.
  - LSB position when PFFCW<n>\_CTRL.MSBF is set to Ob1.
- Never write to the PFFCW<n>\_PAY register, where one of the bytes is the first byte and one of the bytes is the last byte of the Transfer, including if they are the same byte.
- S<sub>GMTJJ</sub> When using auto flag Transfer Delineation mode the Sender must perform two writes to the PFFCW<n>\_PAY register to push the data of the Transfer onto the FIFO, and there must be space in the FIFO to push all bytes, requested by the write to be pushed onto the FIFO, to be pushed onto the FIFO. It is not required that each write to the PFFCW<n>\_PAY register, when using auto flag Transfer Delineation mode, are of the same size.

#### S<sub>TRCYX</sub> It might be required that the Sender either:

- Has to wait between writes to the PFFCW<n>\_PAY register for FIFO to have enough space to push next N bytes of the Transfer.
- Has to reduce the number of bytes to be pushed onto the FIFO.
- S<sub>WLJYF</sub> The Channel Transfer Acknowledge event of the FFCH are used by the Sender to know when a Transfer has been acknowledge by the Receiver. The Sender can either:
  - Configure the FFCH to generate the Channel Transfer Acknowledge interrupt and when the interrupt is generated to read the value of the PFFCW<n>\_ACK\_CNT.ACK\_CNT field to know how many Transfer have been acknowledged.
  - Poll the PFFCW<n>\_INT\_ST.CH\_TFR\_ACK field for a value of 0b1 and then read the value of the PFFCW<n>\_ACK\_CNT.ACK\_CNT to know how many Transfers have been acknowledged.
  - Poll the PFFCW<n>\_ACK\_CNT.ACK\_CNT field for a non-zero value.
- IPZRPH
   For the rest of this section it is assumed the Channel Transfer Acknowledge interrupt is used, however, any of the other methods could be used.

### D2.2.1.2 Receiver Requirements

- S<sub>XTHDX</sub> The Receiver is only allowed to change the value of the MFFCW<n>\_CTRL.MSBF field before it reads or pops any bytes from the FIFO for the Transfer.
- S<sub>ZCZGR</sub> The Receiver must use the values of MFFCW<n>\_FLG register to track the flag values of the bytes it has read from the MFFCW<n>\_PAY register. It uses these values to know:
  - Whether a byte is valid or invalid.
  - Which bytes belong to which Transfers.
  - To detect partial Transfers.
- $S_{WXZQC}$  Software should only use the value of MFFCW<n>\_FLG register after it has read at least one byte from the MFFCW<n>\_PAY register.
- S<sub>NDPQV</sub> The Receiver must read the contents of the MFFCW<n>\_FLG register each time data is read from the FIFO, otherwise it can lead to inclusions of data values which are not part of the Transfer.
- S<sub>ZVWNJ</sub> Table D2.1 shows the value of SOT and EOT fields for the current and previous byte, where both bytes are valid. Any non-valid bytes are to be ignore. When there has been no previous valid byte then it should be considered that EOT was set to 0b1.

| SOT' | EOT' | SOT | EOT | Error | Description                                                                                     |
|------|------|-----|-----|-------|-------------------------------------------------------------------------------------------------|
| X    | 0    | 0   | 0   | No    | Current and previous bytes are part of the same Transfer and<br>there are more bytes to read    |
| Х    | 0    | 0   | 1   | No    | Current and previous bytes are part of the same Transfer and<br>there are no more bytes to read |
| Х    | 0    | 1   | 0   | Yes   | New Transfer started without completing previous Transfer                                       |
| Х    | 0    | 1   | 1   | Yes   | New Transfer started without completing previous Transfer                                       |
| Х    | 1    | 0   | 0   | Yes   | Implicit new Transfer started with the beginning of the Transfer missing                        |
| Х    | 1    | 0   | 1   | Yes   | Implicit new Transfer started with the beginning of the Transfer missing                        |
| Х    | 1    | 1   | 0   | No    | New Transfer started and there are more bytes to read                                           |
| Х    | 1    | 1   | 1   | No    | New Transfer started and ended                                                                  |

#### Table D2.1: Meanings of current and previous SOT and EOT fields

|                    | SOT' and EOT' are the values of SOT and EOT for the previous byte.                                                                                                                                                                                                                             |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $S_{\rm SWKMK}$    | Whenever the Receiver detects a sequence of SOT', EOT', SOT and EOT flags for two valid bytes it did not expect it should take IMPLEMENTATION DEFINED actions to resolve the corrupt Transfers.                                                                                                |
| I <sub>YCRWL</sub> | The MFFCW <n>_FLG register contains the flags associated with the bytes last read from the FIFO by the last read of the MFFCW<n>_PAY register.</n></n>                                                                                                                                         |
| S <sub>DSBPF</sub> | To use the FIFO protocol the Channel Transfer event of the FFCH is used and the Receiver must either:                                                                                                                                                                                          |
|                    | <ul> <li>Configure the FFCH to generate Channel Transfer interrupts so that it can receive these events.</li> <li>Poll the MFFCW<n>_PAY and MFFCW<n>_FLG register until valid bytes are detected.</n></n></li> <li>Poll the MFFCW<n>_ST.FFL until a non-zero value is detected.</n></li> </ul> |
| I <sub>LDPZJ</sub> | For the rest of this section it is assumed the Channel Transfer interrupt is used, however, any of the other methods could be used.                                                                                                                                                            |
|                    |                                                                                                                                                                                                                                                                                                |

# Chapter D2. Transport Protocols D2.2. FIFO

- S<sub>HYQCN</sub> When the Receiver is using Read-Acknowledge without enabling Future Transfer Auto Buffering, it may be required to buffer bytes read out of the MFFCW<n>\_PAY register whilst processing the current Transfer, which are part of the next Transfer. These buffered bytes are required to be processed when the Receiver processes the next Transfer and are considered the first bytes of the next Transfer. Only bytes which have a flag value of 0b01 or 0b00 and come after a byte with 0b01 are required to be buffered. Failure to buffer these bytes will result in a lost of data.
- S<sub>YCZWQ</sub> When the Receiver is not using Read-Acknowledge it must only pop the bytes up to the end of current Transfer from the FIFO. Popping the incorrect number of bytes from the FIFO can lead to loss or corruption of Transfer data.

### D2.2.2 Procedure

S<sub>JFNPF</sub> In Figure D2.2 shows the sequence of events to use the FIFO transport protocol. Arrows with dotted lines indicate optional steps.

Chapter D2. Transport Protocols D2.2. FIFO



Figure D2.2: FIFO transport protocol

The sequence of events shown in Figure D2.2:

- 1. Sender writes any out-band payload to shared memory.
- 2. Sender configures the Transfer Delineation Mode by writing to the PFFCW<n>\_CTRL.TDM field.

This is not required for every transfer and can be set when performing the initial configuration of the FFCH or when the conditions change to require a different mode be used.

#### While Bytes to Send > 0

3. Sender writes to the PFFCW<n>\_FLG register to set the data flags correctly.

Depending on the Transfer Delineation Mode the Sender:

• Software flag

If next write to the PFFCW<n>\_PAY register includes the:

- First byte of the Transfer set the PFFCW<n>\_FLG.SOT field to 0b1, otherwise set the field to 0b0.
- Last byte of the Transfer set the PFFCW<n>\_FLG.EOT field to 0b1, otherwise set the field to 0b0.
- Last byte of the Transfer and an acknowledgement is required for this Transfer set the PFFCW<n>\_FLG.ACK field to 0b1, otherwise set it to 0b0.
- Partial flag

If next write to the PFFCW<n>\_PAY register includes the:

- First byte of the Transfer this step is not required.
- First and last byte of the Transfer set the PFFCW<n>\_FLG.{SOT,EOT} fields both to 0b1.
- Last byte but not the first byte of the Transfer set the PFFCW<n>\_FLG.EOT field to Ob1.
- Last byte of the Transfer and an acknowledgement is required for this Transfer set the PFFCW<n>\_FLG.ACK field to 0b1, otherwise set it to 0b0.
- Auto flag

Sets the PFFCW<n>\_FLG.ACK field to 0b1 if the Sender wants an acknowledgement for this Transfer, otherwise sets it 0b0 if the Sender does not want an acknowledgement for this Transfer.

4. Sender performs a write access to the PFFCW<n>\_PAY register with the payload.

The Sender use an access equal to the amount of data that the Sender wants to push onto the FIFO. The order of the bytes in the payload written to the PFFCW<n>\_PAY register depends on the setting of the PFFCW<n>\_CTRL.MSBF field.

- 5. Sender decreases the number of bytes to send by the number of bytes written to the PFFCW<n>\_PAY register. If the number of bytes to send is 0 the Sender exits the loop, otherwise repeat steps 3 and 4 until all bytes of the Transfer have been pushed onto the FIFO.
- 6. MHU generates a Channel Transfer event, when one or more bytes are pushed onto the FIFO and the EOT flag for one of the bytes is set to 0b1. The Channel Transfer event becomes one or more interrupts depending on the settings of the interrupt enables for the FFCH in the Mailbox:
  - Channel Transfer interrupt, if MFFCW<n>\_INT\_EN.CH\_TFR is set to 0b1.
  - Receiver FFCH Combined interrupt, if MFFCW<n>\_INT\_EN.CH\_TFR is set to 0b1.
  - Mailbox Combined interrupt, if MFFCW<n>\_INT\_EN.CH\_TFR and MFFCW<n>\_INT\_EN.MBX\_COMB\_EN are both set to 0b1.

#### **Read-Acknowledge enabled**

- 7. Receiver reads data from the MFFCW<n>\_PAY register.
- 8. Receiver reads the flag information from the MFFCW<n>\_FLG register.

9. Receiver checks the flag information for each byte read from the MFFCW<n>\_FLG register.

Bytes read from the MFFCW<n>\_PAY register are treated as defined in Table D2.1.

If any valid byte read from the MFFCW<n>\_PAY register associated with a flag value indicates the start of a new Transfer, the Receiver exists the loop, otherwise repeats steps 6-8.

- 10. MHU generates Transfer Acknowledge event, for any bytes which are popped from the FIFO which have the EOT and ACK fields set to 0b1. The Transfer Acknowledge event can generate one or more interrupts depending on the settings for the FFCH in the Postbox:
  - Channel Transfer Acknowledge interrupt, if the PFFCW<n>\_INT\_EN.CH\_TFR\_ACK is set to 0b1.
  - Sender FFCH Combined interrupt, if the PFFCW<n>\_INT\_EN.CH\_TFR\_ACK is set to 0b1.
  - Postbox Combined interrupt, if the PFFCW<n>\_INT\_EN.CH\_TFR\_ACK and PFFCW<n>\_INT\_EN.PBX\_COMB\_EN are both set to 0b1.

#### Read-Acknowledge disabled

- 7. Receiver reads data from the MFFCW<n>\_PAY register.
- 8. Receiver reads the flag information from the MFFCW<n>\_FLG register.
- 9. Receiver checks the flag information for each byte read from the MFFCW<n>\_FLG register.

Bytes read from the MFFCW<n>\_PAY register are treated as defined in Table D2.1.

10. Receiver writes to the MFFCW<n>\_FIFO\_POP register with a value equal to the number of bytes the Receiver wants to pop from the FIFO.

If any valid byte read from the MFFCW<n>\_PAY register associated with a flag indicates the start of a new Transfer, Receiver exists the loop, otherwise repeats steps 7-10.

- 11. MHU generates Transfer Acknowledge event, for any bytes which are popped from the FIFO which have the EOT and ACK fields set to 0b1. The Transfer Acknowledge event can generate one or more interrupts depending on the settings of the FFCH in the Postbox:
  - Channel Transfer Acknowledge interrupt, if the PFFCW<n>\_INT\_EN.CH\_TFR\_ACK is set to 0b1.
  - Sender FFCH Combined interrupt, if the PFFCW<n>\_INT\_EN.CH\_TFR\_ACK is set to 0b1.
  - Postbox Combined interrupt, if the PFFCW<n>\_INT\_EN.CH\_TFR\_ACK and PFFCW<n>\_INT\_EN.PBX\_COMB\_EN are both set to 0b1.
- I<sub>CRXYR</sub> The steps performed by the Sender and Receiver in Figure D2.2 can be run concurrently or sequentially. It is even possible that the Sender is performing the sequences for Transfer Y whilst the Receiver is performing the sequences for Transfer X, where Transfer X is sent by before Transfer Y.

## D2.3 Streaming FIFO

IFFGQPStreaming FIFO transport protocol enables Transfers of undefined lengths, even larger than the size of the FIFO. It<br/>uses the FIFO Free Space and FIFO Fill level to allow the:

- Sender to know when bytes can be pushed onto the FIFO.
- Receiver to know when bytes are ready to be read and popped from the FIFO.

```
S<sub>MHGLB</sub> It is software IMPLEMENTATION DEFINED:
```

- What the values of the data mean.
- How many bytes of in-band and out-band data there are in a Transfer, but there must be at least one byte of in-band payload.
- Whether the number of bytes in-band and out-band payload is the same for all Transfers.
- The location of any out-band payload.
- Whether the Sender of the Transfer receives interrupts when the Receiver acknowledges a Transfer.
- Number of bytes which the Sender can push onto the FIFO before it stops.
- Number of bytes which must be in the FIFO before the Receiver will read them from the FIFO.

### **D2.3.1 Requirements**

| I <sub>MLXCY</sub> | This section covers the requirements to use the streaming FIFO transport protocol.                                                                                                                                                               |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R <sub>NLJCL</sub> | The streaming FIFO transport protocol must only be used with a FFCH.                                                                                                                                                                             |
| S <sub>HXJXH</sub> | The Sender and Receiver must use the same value for PFFCW <n>_CTRL.MSBF and MFFCW<n>_CTRL.MSBF fields for the same Transfer when pushing, reading or popping bytes from the FIFO.</n></n>                                                        |
| $S_{\text{DBSHV}}$ | The method by which the Sender and Receiver agree on what value to set the PFFCW <n>_CTRL.MSBF and MFFCW<n>_CTRL.MSBF fields to is software IMPLEMENTATION DEFINED.</n></n>                                                                      |
| $\rm S_{PGGMV}$    | To use the streaming FIFO protocol the FIFO Low and High Tide events are used by both the Sender and Receiver and the Sender and Receiver must either:                                                                                           |
|                    | <ul><li>Configure the FFCH so that it can receive these events.</li><li>Use the values of the FIFO Free Space or FIFO Fill Level fields provided by the MHU.</li></ul>                                                                           |
| S <sub>RTFKF</sub> | When using the Sender and Receiver FIFO Low and High Tidemark events there can be a delay in-between the event being generated and the Sender or Receiver detecting the event, via an interrupt.                                                 |
|                    | To avoid lost of data, Arm recommends that the Sender sets the PFFCW <n>_TIDE.HIGH field to a value which generates the Sender High Tide event early enough so that the Sender can stop push new data onto the FIFO before the FIFO is full.</n> |
| S <sub>LLQSH</sub> | The Sender can write zero or more bytes to an out-band payload location. It is software IMPLEMENTATION DEFINED when the Receiver reads the out-band payload and depends on the following:                                                        |
|                    | <ul><li> How and when the Receiver knows the address to use to access the out-band payload.</li><li> When and how the Sender knows that the out-band payload location is no longer required by the Receiver.</li></ul>                           |

### D2.3.1.1 Sender Requirements

 $\rm S_{GVWTL}$  The Sender must not push new data onto the FIFO if the FIFO is full.

S<sub>PSDQM</sub> The number of outstanding Transfers is limited by the amount of in-band data each Transfer uses and the depth of the FIFO.

 $S_{JWPHV}$  There is no limit on the amount of in-band data used by a Transfer.

 $\label{eq:lowbrank} \mathbb{I}_{\mathbb{QWBRJ}} \qquad \mbox{The Sender can determine the amount of free space in the FIFO using the value in the PFFCW<n>_ST.FFS or PFFCW<n>_PAY.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the amount of free space in the FIFO using the value in the PFFCW<n>_ST.FFS or PFFCW<n>_PAY.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the amount of free space in the FIFO using the value in the PFFCW<n>_ST.FFS or PFFCW<n>_PAY.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the amount of free space in the FIFO using the value in the PFFCW<n>_ST.FFS or PFFCW<n>_ST.FFS or PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the amount of free space in the FIFO using the value in the PFFCW<n>_ST.FFS or PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the amount of free space in the FIFO using the value in the PFFCW<n>_ST.FFS or PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FIFO High Tide event. \mbox{The Sender can determine the space in the PFFCW<n>_ST.FFS fields or FI$ 

|   | Note                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | The values of the PFFCW <n>PAY.FFS and PFFCW<n>_FFS fields can be less than the actual value, if the size of the read access to the register does not have enough bits to encode the FFS field in the returned data. However, the value will always be able to show that it is possible to perform at least one more push operation of any supported size.</n></n>                                                                                         |
|   | For more information on when this occurs refer to Chapter B8 FIFO Extension.                                                                                                                                                                                                                                                                                                                                                                               |
|   | The Sender must only push bytes onto the FIFO which belong to the same Transfer using a single write to the PFFCW <n>_PAY register.</n>                                                                                                                                                                                                                                                                                                                    |
|   | The Sender is only allowed to change the value of the PFFCW <n>_CTRL.MSBF field before it pushes any bytes onto the FIFO for the Transfer.</n>                                                                                                                                                                                                                                                                                                             |
|   | Depending on the Transfer Delineation mode being used the Sender must obey different rules for the following:                                                                                                                                                                                                                                                                                                                                              |
|   | <ul> <li>Management of the SOT, EOT and ACK flags.</li> <li>Number of writes to the PFFCW<n>_PAY register, to push data onto the FIFO, for a single Transfer.</n></li> </ul>                                                                                                                                                                                                                                                                               |
| , | When using software flag Transfer Delineation mode the Sender must:                                                                                                                                                                                                                                                                                                                                                                                        |
|   | <ul> <li>Set the PFFCW<n>_FLG.SOT field to Obl before it pushes one or more bytes onto the FIFO, where one of the bytes is the first byte of the Transfer.</n></li> <li>Have the first byte of the Transfer in either the:</li> </ul>                                                                                                                                                                                                                      |
|   | <ul> <li>LSB position when PFFCW<n>_CTRL.MSBF is set to 0b0.</n></li> <li>MSB position when PFFCW<n>_CTRL.MSBF is set to 0b1.</n></li> </ul>                                                                                                                                                                                                                                                                                                               |
|   | <ul> <li>Set the PFFCW<n>_FLG.SOT field to 0b0 before it pushes one or more bytes onto the FIFO, where none of the bytes are the first byte of the Transfer.</n></li> <li>Set the PFFCW<n>_FLG.ACK field to the correct value before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.</n></li> </ul>                                                                                                    |
|   | <ul> <li>If the Sender wants a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>_FLG.ACK field to 0b1.</n></li> <li>If the Sender does not want a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>_FLG.ACK field to 0b0.</n></li> </ul>                             |
|   | <ul> <li>Set the PFFCW<n>_FLG.EOT field to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.</n></li> <li>Have the last byte of the Transfer in either the:</li> </ul>                                                                                                                                                                                                                        |
|   | <ul> <li>MSB position when PFFCW<n>_CTRL.MSBF is set to 0b0.</n></li> <li>LSB position when PFFCW<n>_CTRL.MSBF is set to 0b1.</n></li> </ul>                                                                                                                                                                                                                                                                                                               |
|   | • Set the PFFCW <n>_FLG.EOT field to 0b0 before it pushes one or more bytes onto the FIFO, where none of the bytes are the last byte of the Transfer.</n>                                                                                                                                                                                                                                                                                                  |
|   | When using software flag Transfer Delineation mode the Sender can perform as many writes to the PFFCW <n>_PAY register as required to push all data of the Transfer onto the FIFO. So long as there is space in the FIFO for all bytes, requested by the write to be pushed, to be pushed onto the FIFO. It is not required that each write to the PFFCW<n> PAY register, when using software flag Transfer Delineation mode, are of the same size</n></n> |

| S <sub>GNXLF</sub> | It might be required that the Sender either:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | • Has to wait between writes to the PFFCW <n>_PAY register for FIFO to have enough space to push next N bytes of the Transfer.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | • Has to reduce the number of bytes to be pushed onto the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| S <sub>bycdh</sub> | When using partial flag Transfer Delineation mode the Sender must:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                    | <ul> <li>Set the PFFCW<n>_FLG.{SOT/EOT} fields to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the first byte of and one of the bytes is the last byte of the Transfer. This also applies if they are the same byte.</n></li> <li>Set the PFFCW<n>_FLG.EOT field to 0b1 before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer and none of the bytes are the first byte of the Transfer.</n></li> <li>Set the PFFCW<n>_FLG.ACK field to the correct value before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.</n></li> </ul> |
|                    | <ul> <li>If the Sender wants a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>_FLG.ACK field to 0b1.</n></li> <li>If the Sender does not want a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>_FLG.ACK field to 0b1.</n></li> </ul>                                                                                                                                                                                                                                            |
|                    | • Have the first byte of the Transfer in either the:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>LSB position when PFFCW<n>_CTRL.MSBF is set to 0b0.</n></li> <li>MSB position when PFFCW<n>_CTRL.MSBF is set to 0b1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | • Have the last byte of the Transfer in either the:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | <ul> <li>MSB position when PFFCW<n>_CTRL.MSBF is set to 0b0.</n></li> <li>LSB position when PFFCW<n>_CTRL.MSBF is set to 0b1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| S <sub>VDPZG</sub> | When using partial flag Transfer Delineation mode the Sender can perform as many writes to the PFFCW <n>_PAY register as required to push all data of the Transfer onto the FIFO. So long as there is space in the FIFO for all bytes, requested by the write to be pushed, to be pushed onto the FIFO. It is not required that each write to the PFFCW<n>_PAY register, when using partial flag Transfer Delineation mode, are of the same size.</n></n>                                                                                                                                                                                                                 |
| S <sub>YFGLQ</sub> | It might be required that the Sender either:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | <ul> <li>Has to wait between writes to the PFFCW<n>_PAY register for FIFO to have enough space to push next N bytes of the Transfer.</n></li> <li>Has to reduce the number of bytes to be pushed onto the FIFO.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| S <sub>cyyyd</sub> | When using auto flag Transfer Delineation mode the Sender must:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                    | • Set the PFFCW <n>_FLG.ACK field to the correct value before it pushes one or more bytes onto the FIFO, where one of the bytes is the last byte of the Transfer.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                    | <ul> <li>If the Sender wants a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>_FLG.ACK field to 0b1.</n></li> <li>If the Sender does not want a Channel Transfer Acknowledge event to be generated, when the last byte of the Transfer is popped from the FIFO, the Sender sets the PFFCW<n>_FLG.ACK field to 0b1.</n></li> </ul>                                                                                                                                                                                                                                            |
|                    | • Have the first byte of the Transfer in either the:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | <ul> <li>LSB position when PFFCW<n>_CTRL.MSBF is set to 0b0.</n></li> <li>MSB position when PFFCW<n>_CTRL.MSBF is set to 0b1.</n></li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                    | • Have the last byte of the Transfer in either the:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                    | • MSB position when PFFCW <n>_CTRL.MSBF is set to 0b0.</n>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

• LSB position when PFFCW<n>\_CTRL.MSBF is set to 0b1.

- Never write to the PFFCW<n>\_PAY register, where one of the bytes is the first byte and one of the bytes is the last byte of the Transfer, including if they are the same byte.
- S<sub>KJSBD</sub> When using auto flag Transfer Delineation mode the Sender must perform two writes to the PFFCW<n>\_PAY register to push the data of the Transfer onto the FIFO, and there must be space in the FIFO to push all bytes, requested by the write to be pushed onto the FIFO, to be pushed onto the FIFO. It is not required that each write to the PFFCW<n>\_PAY register, when using auto flag Transfer Delineation mode, are of the same size.
- S<sub>LVDHS</sub> It might be required that the Sender either has to:
  - Wait between writes to the PFFCW<n>\_PAY register for FIFO to have enough space to push next N bytes of the Transfer.
  - Reduce the number of bytes to be pushed onto the FIFO.
- S<sub>JVHSS</sub> To use the streaming FIFO protocol the Sender must keep track of the number of valid bytes that are in the FIFO. The Sender must either:
  - Configure the FFCH to generate both the Sender FIFO Low and High Tide events and set the PFFCW<n>\_TIDE.{HIGH/LOW} fields to appropriate values.
  - Check the amount of free space in the FIFO and only writing to the PFFCW<n>\_PAY if the free space is below the threshold to push new data onto the FIFO. The Sender can check the amount of free space by reading the value PFFCW<n>\_ST.FFS field.
- I<sub>HCNRC</sub> For the rest of this section it is assumed the Sender FIFO Low and High Tidemark interrupts are used, however, any of the other methods could be used.
- It is the responsibility of the Sender to read the PFFCW<n>\_ACK\_CNT register when the Transfer Acknowledge interrupt is generated to know how many Transfers have been acknowledged since the last time the Sender read the register.

### D2.3.1.2 Receiver Requirements

- S<sub>FPNTK</sub> The Receiver is only allowed to change the value of the MFFCW<n>\_CTRL.MSBF field before it reads or pops any bytes from the FIFO for the Transfer.
- S<sub>KKHKR</sub> The Receiver can know when there are valid bytes in the FIFO by reading the value of MFFCW<n>\_ST.FFL or MFFCW<n>\_FLG.FFL fields or Receiver High Tide event.

#### Note

The values of the MFFCW<n>\_ST.FFL and MFFCW<n>\_FLG.FFL fields can be less than the actual value, if the size of the read access to the register does not have enough bits to encode the FFL field in the returned data. However, the value will always be able to show that it is possible to perform at least one more pop operation of any supported size.

For more information on when this occurs refer to Chapter B8 FIFO Extension.

- S<sub>JTMXN</sub> The Receiver must use the values of MFFCW<n>\_FLG register to track the flag values of the bytes it has read from the MFFCW<n>\_PAY register. It uses these values to know:
  - Whether a byte is valid or invalid.
  - Which bytes belong to which Transfers.
  - To detect partial Transfers.
- S<sub>XDLDG</sub> Software should only use the value of MFFCW<n>\_FLG register after it has read at least one byte from the MFFCW<n>\_PAY register.

I<sub>WJDGJ</sub>

Table D2.2 shows the value of SOT and EOT fields for the current and previous byte, where both bytes are valid. A valid byte is a byte where the Valid flag is set. Any non-valid bytes are to be ignore. When there has been no previous valid byte then it should be considered that EOT was set to 0b1.

| SOT' | EOT' | SOT | EOT | Error | Description                                                                                     |
|------|------|-----|-----|-------|-------------------------------------------------------------------------------------------------|
| X    | 0    | 0   | 0   | No    | Current and previous bytes are part of the same Transfer and<br>there are more bytes to read    |
| Х    | 0    | 0   | 1   | No    | Current and previous bytes are part of the same Transfer and<br>there are no more bytes to read |
| Х    | 0    | 1   | 0   | Yes   | New Transfer started without completing previous Transfer                                       |
| X    | 0    | 1   | 1   | Yes   | New Transfer started without completing previous Transfer                                       |
| Х    | 1    | 0   | 0   | Yes   | Implicit new Transfer started with the beginning of the Transfer missing                        |
| Х    | 1    | 0   | 1   | Yes   | Implicit new Transfer started with the beginning of the Transfer missing                        |
| Х    | 1    | 1   | 0   | No    | New Transfer started and there are more bytes to read                                           |
| Х    | 1    | 1   | 1   | No    | New Transfer started and ended                                                                  |

#### Table D2.2: Meanings of current and previous SOT and EOT fields

SOT' and EOT' are the value of SOT and EOT for the previous byte.

- S<sub>NNGMM</sub> Whenever the Receiver detects a sequence of SOT', EOT', SOT and EOT flags for two valid bytes it did not expect it should take IMPLEMENTATION DEFINED actions to resolve the corrupt Transfers.
- S<sub>HCWMX</sub> When the Receiver is using Read-Acknowledge without enabling Future Transfer Auto Buffering, it may be required to buffer bytes read out of the MFFCW<n>\_PAY register whilst processing the current Transfer, which are part of the next Transfer. These buffered bytes are required to be processed when the Receiver processes the next Transfer and are considered the first bytes of the next Transfer. Only valid bytes which have a flag value of 0b01 or 0b00 and come after a byte with 0b01 are required to be buffered. Failure to buffer these bytes will result in a lost of data.
- S<sub>XZBDZ</sub> When the Receiver is not using Read-Acknowledge it must only pop the bytes up to the end of current Transfer from the FIFO. Popping the incorrect number of bytes from the FIFO can lead to loss or corruption of Transfer data.
- S<sub>JFDWD</sub> To use the streaming FIFO protocol the Receiver must keep track of the number of valid bytes in the FIFO. The Receiver must either:
  - Configure the FFCH to generate both the Receiver FIFO Low and High Tide events and set the MFFCW<n>\_TIDE.{HIGH/LOW} fields to appropriate values.
  - Poll the value of the MFFCW<n>\_ST.FFL field until the value is above the threshold for the Receiver to start processing Transfer.
- I<sub>HFNHG</sub> For the rest of this section it is assumed the Sender FIFO Low and High Tidemark interrupts are used, however, any of the other methods could be used.

### D2.3.2 Procedure

S<sub>WBNDP</sub> Figure D2.3 shows the sequence of events to use the streaming FIFO transport protocol for the Sender. Arrows with dotted lines indicate optional steps.



#### Figure D2.3: Streaming FIFO transport protocol for Sender

The sequence of events shown in Figure D2.3:

- 1. Sender writes any out-band payload to shared memory.
- 2. Sender configures the Transfer Delineation Mode by writing to the PFFCW<n>\_CTRL.TDM field.

This is not required for every transfer and can be set when performing the initial configuration of the FFCH or when the conditions change to require a different mode be used.

#### While Bytes to Send > 0

3. Sender writes to the PFFCW<n>\_FLG register to set the data flags correctly.

Depending on the Transfer Delineation Mode the Sender:

Software Flag

If next write to the PFFCW<n>\_PAY register includes the:

• First byte of the Transfer set the PFFCW<n>\_FLG.SOT field to 0b1, otherwise set the field to 0b0.

- Last byte of the Transfer set the PFFCW<n>\_FLG.EOT field to 0b1, otherwise set the field to 0b0.
- Last byte of the Transfer and an acknowledgement is required for this Transfer set the PFFCW<n>\_FLG.ACK field to 0b1, otherwise set it to 0b0.
- Partial flag

If next write to the PFFCW<n>\_PAY register includes the:

- First byte of the Transfer this step is not required.
- First and last byte of the Transfer set the PFFCW<n>\_FLG.{SOT,EOT} fields both to 0b1.
- Last byte but not the first byte of the Transfer set the PFFCW<n>\_FLG.EOT field to Ob1.
- Last byte of the Transfer and an acknowledgement is required for this Transfer set the PFFCW<n>\_FLG.ACK field to 0b1, otherwise set it to 0b0.
- Auto flag

Sets the PFFCW<n>\_FLG.ACK field to 0b1 if the Sender wants an acknowledgement for this Transfer, otherwise sets it 0b0 if the Sender does not want an acknowledgement for this Transfer.

4. Sender performs a write access to the PFFCW<n>\_PAY register with the payload.

The Sender use an access equal to the amount of data that the Sender want to push onto the FIFO. The order of the bytes in the payload written to the PFFCW<n>\_PAY register depends on the setting of the PFFCW<n>\_CTRL.MSBF field.

- 5. MHU generates a Sender FIFO High Tidemark event, when the number of valid bytes in the FIFO interrupt is greater than the PFFCW<n>\_TIDE.HIGH field. The Sender FIFO High Tidemark event can become one or more interrupts depending on the settings for the channel in the Postbox:
  - Sender FIFO High Tide interrupt, if the PFFCW<n>\_INT\_EN.FHT is set to 0b1.
  - Sender FFCH Combined interrupt, if the PFFCW<n>\_INT\_EN.FHT is set to 0b1.
  - Postbox Combined interrupt, if the PFFCW<n>\_INT\_EN.FHT and PFFCW<n>\_INT\_EN.PBX\_COMB\_EN are both set to 0b1.
- 6. Sender stops pushing new data into the FIFO. The Sender waits until free space in the FIFO is available by either polling the PFFCW<n>\_ST.FFS or using the FIFO Low Tidemark interrupt.
- 7. After a period of time, the number of valid bytes in the FIFO becomes less than or equal to the value of the PFFCW<n>\_TIDE.LOW field. The MHU generates a Sender FIFO Low Tide event. The Sender FIFO Low Tidemark event can become one or more interrupts depending on the settings for the FFCH in the Postbox:
  - Sender FIFO Low Tide interrupt, if the PFFCW<n>\_INT\_EN.FLT is set to 0b1.
  - Sender FFCH Combined interrupt, if the PFFCW<n>\_INT\_EN.FLT is set to 0b1.
  - Postbox Combined interrupt, if the PFFCW<n>\_INT\_EN.FLT and PFFCW<n>\_INT\_EN.PBX\_COMB\_EN are both set to 0b1.

At this point the Sender resuming sending payload data.

8. Sender decreases the number of bytes to send by the number of bytes written to the PFFCW<n>\_PAY register. If the number of bytes to send is 0 the Sender exits the loop, otherwise returns to step 3 to modifying the flags in the PFFCW<n>\_FLG registers as required to send more bytes of the Transfer.

S<sub>HCHCQ</sub> Figure D2.4 shows the sequence of events to use the streaming FIFO transport protocol for the Receiver. Arrows with dotted lines indicate optional steps.



Figure D2.4: Streaming FIFO transport protocol for Receiver

The sequence of events shown in Figure D2.4:

- 1. Receiver waits for a indication that there are enough bytes in the FIFO to being processing. The Receiver uses either the:
  - Receiver FIFO High Tidemark event.
  - Value of the FFL field in either the MFFCW<n>\_FLG or MFFCW<n>\_ST register.
- 2. MHU generates a Receiver FIFO High Tidemark event when the number of valid bytes in the FIFO is greater than the MFFCW<n>\_TIDE.HIGH field. The Receiver FIFO High Tidemark event can become one or more interrupts depending on the settings for the channel in the Mailbox:
  - Receiver FIFO High Tide interrupt, if the MFFCW<n>\_INT\_EN.FHT is set to 0b1.
  - Receiver FFCH Combined interrupt, if the MFFCW<n>\_INT\_EN.FHT is set to 0b1.
  - Mailbox Combined interrupt, if the MFFCW<n>\_INT\_EN.FHT and MFFCW<n>\_INT\_EN.MBX\_COMB\_EN are both set to 0b1.

#### Read-Acknowledge enabled

- 3. Receiver reads data from the MFFCW<n>\_PAY register.
- 4. MHU generates Channel Transfer Acknowledge event for any bytes which are popped from the FIFO which have the EOT and ACK fields set to 0b1. The Channel Transfer Acknowledge event can become one or more interrupts depending on the settings for the FFCH in the Postbox:
  - Channel Transfer Acknowledge interrupt, if the PFFCW<n>\_CH\_TFR\_ACK is set to 0b1.
  - Receiver FFCH Combined interrupt, if the PFFCW<n>\_CH\_TFR\_ACK is set set to 0b1.
  - Postbox Combined interrupt, if the PFFCW<n>\_CH\_TFR\_ACK and PFFCW<n>\_INT\_EN.PBX\_COMB\_EN are both set to 0b1.
- 5. Receiver reads the flag information from the MFFCW<n>\_FLG register.
- 6. Receiver checks the flag information for each byte read from the MFFCW<n>\_FLG register.

Bytes read from the MFFCW<n>\_PAY register are treated as defined in Table D2.2.

- 7. If the number of bytes in the FIFO becomes less than or equal to the value of the MFFCW<n>\_TIDE.LOW field, the MHU generates a Receiver Low Tide event. The Receiver Low Tide event can become one or more interrupts depending on the settings for the FFCH in the Mailbox:
  - Receiver FIFO Low Tide interrupt, if the MFFCW<n>\_INT\_EN.FLT is set to 0b1.
  - Receiver FFCH Combined interrupt, if the MFFCW<n>\_INT\_EN.FLT is set to 0b1.
  - Mailbox Combined interrupt, if the MFFCW<n>\_INT\_EN.FLT and MFFCW<n>\_INT\_EN.MBX\_COMB\_EN are both set to 0b1.
- 8. Receiver stops popping new data from the FIFO. The Receiver returns to steps 2 and waits until enough valid data is available in the FIFO.

#### Read-Acknowledge disabled

- 3. Receiver reads data from the MFFCW<n>\_PAY register.
- 4. Receiver reads the flag information from the MFFCW<n>\_FLG register.
- 5. Receiver checks the flag information for each byte read from the MFFCW<n>\_FLG register.

Bytes read from the MFFCW<n>\_PAY register are treated as defined in Table D2.2.

- 6. Receiver writes to the MFFCW<n>\_FIFO\_POP register. The value of the write must be equal to the number of bytes the Receiver wants to pop from the FIFO.
- 7. MHU generates Channel Transfer Acknowledge event for any bytes which are popped from the FIFO which have the EOT and ACK fields set to 0b1. The Channel Transfer Acknowledge event can become one or more interrupts depending on the settings for the FFCH in the Postbox:
  - Channel Transfer Acknowledge interrupt, if the PFFCW<n>\_CH\_TFR\_ACK is set to 0b1.
  - Receiver FFCH Combined interrupt, if the PFFCW<n>\_CH\_TFR\_ACK is set set to 0b1.

- Postbox Combined interrupt, if the PFFCW<n>\_CH\_TFR\_ACK and PFFCW<n>\_INT\_EN.PBX\_COMB\_EN are both set to 0b1.
- 8. If the number of bytes in the FIFO becomes less than or equal to the value of the MFFCW<n>\_TIDE.LOW field, the MHU generates a Receiver Low Tide event. The Receiver Low Tide event can become one or more interrupts depending on the settings for the FFCH in the Mailbox:
  - Receiver FIFO Low Tide interrupt, if the MFFCW<n>\_INT\_EN.FLT is set to 0b1.
  - Receiver FFCH Combined interrupt, if the MFFCW<n>\_INT\_EN.FLT is set to 0b1.
  - Mailbox Combined interrupt, if the MFFCW<n>\_INT\_EN.FLT and MFFCW<n>\_INT\_EN.MBX\_COMB\_EN are both set to 0b1.
- 9. Receiver stops popping new data from the FIFO. The Receiver returns to steps 2 and waits until enough valid data is available in the FIFO.

 $I_{\text{HSXRQ}}$  The sequences in Figure D2.3 and Figure D2.4 can be run concurrently or sequentially. It is even possible that the Sender is performing the sequences for Transfer Y whilst the Receiver is performing the sequences for Transfer X, where Transfer X is sent by before Transfer Y.

Chapter D2. Transport Protocols D2.4. Last-value

## D2.4 Last-value

- IQHWFRThe Last-value transport protocol enables a Sender to send a value to the a Receiver which can be updated at any<br/>point, even if the Receiver has not seen a previously written value.
- I<sub>GTQWX</sub> The value seen by the Receiver can be either the new or old value when the Sender updates the data value.

### **D2.4.1 Requirements**

| I <sub>TDMNQ</sub> | This section covers the requirements of the last value transport protocol.                                                                      |  |  |  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| R <sub>lgyhm</sub> | The last-value transport protocol must only be used with FCH.                                                                                   |  |  |  |  |
| R <sub>CWVBR</sub> | Only in-band data is supported up to the Fast Channel word-size.                                                                                |  |  |  |  |
| $R_{JLSXH}$        | Both the Sender and Receiver systems must support a single-copy atomic size greater than or equal to the Fast Channel word-size.                |  |  |  |  |
| $S_{PPYYS}$        | All updates to a FCH must be performed atomically, otherwise it is UNPREDICTABLE what value the Receivers will read.                            |  |  |  |  |
| S <sub>YLRFM</sub> | It is software IMPLEMENTATION DEFINED:                                                                                                          |  |  |  |  |
|                    | <ul><li>The value of the data sent by the Sender to the Receiver.</li><li>When the Sender is allowed to update the value of the data.</li></ul> |  |  |  |  |
| S <sub>XLBVH</sub> | Sender and Receiver must be able to handle all the following scenarios:                                                                         |  |  |  |  |
|                    | • Sender writes the FCH once, with data D1, after which the Receiver then reads the FCH and gets value D1.                                      |  |  |  |  |

Sender writes the FCH twice, with data D1, after which the Receiver reads either D1 or D2 depending on the sequence of the Sender writes and Receiver reads.

### D2.4.2 Procedure

S<sub>XJPQT</sub> In Figure D2.5 shows the sequence of events to use the Last-value transport protocol when only sending a single-word of in-band data. Arrows with dotted lines indicate optional steps.



Figure D2.5: Last-value transport protocol

The sequence of events are:

# Chapter D2. Transport Protocols D2.4. Last-value

- 1. Sender atomically writes to the in-band data value to the PFCW<n>\_PAY registers atomically.
- 2. MHU generates Channel Transfer event. The Channel Transfer event can become one or more of the following interrupts depending on the Mailbox configuration:
  - Fast Channel Transfer interrupt, if MBX\_FCH\_CTRL.INT\_EN is set to 0b1.
  - Fast Channel Group Transfer <m> interrupt, if MBX\_FCH\_CTRL.INT\_EN is set to Ob1.
  - Mailbox Combined interrupt, if MBX\_FCH\_CTRL.INT\_EN and MBX\_FCG\_INT\_EN.MBX\_COMB\_EN<m> are both set to 0b1.
- 3. Sender atomically updates the in-band data value, no interrupt is generated as Receiver hasn't acknowledged the previous write.
- 4. Receiver reads the MFCW<n>\_PAY registers atomically to get value of in-band data.

Where <m> is the FCG the FCH is part of.

I\_SJTZXStep 3 is optional and can happen at any time:

- If it happens before step 4 then the in-band value is updated.
- If it happens after step 4 then a new Transfer is triggered.
- If it happens at the same time as step 4, the Receiver reads the old value and a new Transfer is started for the new value.

 $I_{RPFKH}$  The steps performed by the Sender and Receiver in Figure D2.5 can be run concurrently or sequentially. It is even possible that the Sender is performing the sequences for Transfer Y whilst the Receiver is performing the sequences for Transfer X, where Transfer X is sent by before Transfer Y.

## Glossary

#### Agent

Generic term used to refer to a software entity which sends or receives a Transfer.

#### Channel

Generic term for the resource which a Sender uses to send a Transfer to the Receiver.

#### **Doorbell Channel (DBCH)**

A Doorbell Channel is a type of channel, which is used to send Transfers which are a single event to the Receiver.

#### Fast Channel (FCH)

A Fast Channel is a type of channel, which is used to send a Transfer to the Receiver.

#### Fast Channel Group (FCG)

A group of 1-32 FCH.

#### Fast Channel word-size

The size of data payload of an Fast Channel

#### **FIFO Channel (FFCH)**

A FIFO Channel is a type of channel, which is used to send one or more Transfers, where each Transfers can be 32-bit or 64-bits and can be any value.

#### Flag History Buffer (FHB)

Buffer used to record the flags of the bytes read from the FIFO of an FFCH requested by the last read by the Receiver

#### **Illegal Access**

An access which has incorrect security to access the register C1.1.5 Illegal Accesses

#### In-band

A transfer payload sent using a channel of the MHU.

#### Inter-Process Communication (IPC)

A method that allows two separate processes to communicate with one another, using interrupts to indicate when there is a new communication or an update about the communication.

#### Inter-Processor Interrupt (IPC)

An interrupt that is used to indicates to another processor that the interrupting processor requires action from the other processor.

#### Mailbox (MBX)

A Mailbox is collection of channels and control registers, used by the Receiver to receiver a Transfer from the Sender.

#### Message

A message is a self-contain entity which is sent by a Sender to a Receiver. A Message is formed of one or more Transfers.

#### Glossary

#### Message protocol

A protocol which defines the format of messages that are sent between Sender and Receiver.

#### **MHU Receiver (MHUR)**

The side of the MHU used by the Receiver of the message.

#### MHU Sender (MHUS)

The side of the MHU used by the Sender of the message.

#### **Non-operational State**

MHU Sender or Receiver is in a state where it cannot send or receiver Transfer

#### **Operational State**

MHU Sender or Receiver is in a state where it can send or receiver Transfers

#### Out-band

A transfer payload sent using a method other than a channel of the MHU, for example shared memory.

#### Postbox (PBX)

A Postbox is a collection of channels and control registers, used by the Sender to send a Transfer to the Receiver.

#### **Receiver Agent**

Piece of software receiving the message, referred to as the Receiver for short.

#### **Receiver Security Control (RSC)**

Security control block which controls security of the MHUR

#### RES0

A Reserved bit. Used for fields for register descriptions, and for fields in architecturally-defined data structures that are held in memory. For a full definition refer to the Arm ARM [1]

#### RES1

A Reserved bit. Used for fields for register descriptions, and for fields in architecturally-defined data structures that are held in memory. For a full definition refer to the Arm ARM [1]

#### Security Assignment Agent

Piece of software which assigns the resources of the MHU to different Security Groups.

#### Sender Agent

Piece of software sending the message, referred to as the Sender for short.

#### Sender Security Control (SSC)

Security control block which controls security of the MHUS

#### System Control Processor

A processor that controls the clock, power and resets domains of the SoC.

#### Transfer

A transfer is defined as a single interrupt generated by the MHU. A transfer can be nothing more than an interrupt, but it can also have an associated data payload (transfer payload).

#### Transport protocol

A protocol which defines how transfers are indicated by the Sender to the Receiver, using the MHU, and the location of the transfer payload, if applicable.

Glossary

#### **Unsupported Access**

An access which is of an unsupported alignment, size or memory type