AArch64
Instructions

Index by Encoding External Registers

# MSMON\_MBWU\_L, MPAM Long Memory Bandwidth Usage Monitor Register

The MSMON MBWU L characteristics are:

## **Purpose**

Accesses the monitor instance selected by MSMON CFG MON SEL.

MSMON\_MBWU\_L\_s is the Secure long memory bandwidth usage monitor instance selected by the Secure instance of <a href="MSMON\_CFG\_MON\_SEL">MSMON\_MBWU\_L\_</a>ns is the Non-secure long memory bandwidth usage monitor instance selected by the Non-secure instance of <a href="MSMON\_CFG\_MON\_SEL">MSMON\_MBWU\_L\_</a>rt is the Root long memory bandwidth usage monitor instance selected by <a href="MSMON\_CFG\_MON\_SEL">MSMON\_MBWU\_L\_</a>rl is the Realm long memory bandwidth usage monitor instance selected by <a href="MSMON\_CFG\_MON\_SEL\_rl">MSMON\_CFG\_MON\_SEL\_</a>rl.

If <u>MPAMF\_IDR</u>.HAS\_RIS is 1, the monitor instance long monitor register accessed is for the resource instance currently selected by <u>MSMON\_CFG\_MON\_SEL</u>.RIS and the monitor instance of that resource instance selected by <u>MSMON\_CFG\_MON\_SEL</u>.MON\_SEL.

## **Configuration**

This register is present only when FEAT\_MPAM is implemented, MPAMF\_IDR.HAS\_MSMON == 1, MPAMF\_MSMON\_IDR.MSMON\_MBWU == 1 and MPAMF\_MBWUMON\_IDR.HAS\_LONG == 1. Otherwise, direct accesses to MSMON\_MBWU\_L are res0.

The power and reset domain of each MSC component is specific to that component.

## **Attributes**

MSMON\_MBWU\_L is a 64-bit register.

## Field descriptions

## When MPAMF\_MBWUMON\_IDR.LWD == 0:

| 63 62 61 | 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 | 43 42 41 40 39 38 37 36 35 34 33 32 |
|----------|----------------------------------------------------|-------------------------------------|
| NRDY     | RES0                                               | VALUE                               |
| 31 30 29 | 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 | 11 10 9 8 7 6 5 4 3 2 1 0           |

VALUE

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

#### NRDY, bit [63]

Not Ready. Indicates whether the monitor instance has possibly inaccurate data.

| NRDY | Meaning                               |
|------|---------------------------------------|
| 0b0  | The monitor instance is ready and the |
|      | MSMON_MBWU_L.VALUE field              |
|      | is accurate.                          |
| 0b1  | The monitor instance is not           |
|      | ready and the contents of the         |
|      | MSMON_MBWU_L.VALUE field              |
|      | might be inaccurate or                |
|      | otherwise not represent the           |
|      | actual memory bandwidth               |
|      | usage.                                |

#### Bits [62:44]

Reserved, res0.

#### **VALUE, bits [43:0]**

Long (44-bit) memory bandwidth usage counter value if MSMON\_MBWU\_L.NRDY is 0. Invalid if MSMON\_MBWU\_L.NRDY is 1.

VALUE is the long count of bytes transferred since the monitor was last reset that met the criteria set in <a href="MSMON\_CFG\_MBWU\_FLT">MSMON\_CFG\_MBWU\_CTL</a> for the monitor instance selected by MSMON CFG MON SEL.

## When MPAMF MBWUMON IDR.LWD == 1:

63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 40 39 38 37 36 35 34 33 32

NRDY

VALUE

VALUE

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

#### NRDY, bit [63]

Not Ready. Indicates whether the monitor instance has possibly inaccurate data.

| NRDY | Meaning |  |
|------|---------|--|
|      |         |  |

| 0d0 | The monitor instance is ready and the |
|-----|---------------------------------------|
|     | MSMON MBWU L.VALUE field              |
|     | is accurate.                          |
| 0b1 | The monitor instance is not           |
|     | ready and the contents of the         |
|     | MSMON MBWU L.VALUE field              |
|     | might be inaccurate or                |
|     | otherwise not represent the           |
|     | actual memory bandwidth               |
|     | usage.                                |

#### **VALUE, bits [62:0]**

Long (63-bit) memory bandwidth usage counter value if MSMON\_MBWU\_L.NRDY is 0. Invalid if MSMON\_MBWU\_L.NRDY is 1.

VALUE is the long count of bytes transferred since the monitor instance was last reset that met the criteria set in <a href="MSMON\_CFG\_MBWU\_FLT">MSMON\_CFG\_MBWU\_FLT</a> and <a href="MSMON\_CFG\_MBWU\_CTL">MSMON\_CFG\_MBWU\_CTL</a> for the monitor instance selected by <a href="MSMON\_CFG\_MON\_SEL">MSMON\_CFG\_MON\_SEL</a>.

## **Accessing MSMON MBWU L**

This register is within the MPAM feature page memory frames.

In a system that supports Secure, Non-secure, Root, and Realm memory maps, there must be MPAM feature pages in all four address maps:

- MSMON\_MBWU\_L\_s must only be accessible from the Secure MPAM feature page.
- MSMON\_MBWU\_L\_ns must only be accessible from the Non-secure MPAM feature page.
- MSMON\_MBWU\_L\_rt must only be accessible from the Root MPAM feature page.
- MSMON\_MBWU\_L\_rl must only be accessible from the Realm MPAM feature page.

MSMON\_MBWU\_L\_s, MSMON\_MBWU\_L\_ns, MSMON\_MBWU\_L\_rt, and MSMON\_MBWU\_L\_rl must be separate registers:

- The Secure instance (MSMON\_MBWU\_L\_s) accesses the long memory bandwidth usage monitor used for Secure PARTIDs.
- The Non-secure instance (MSMON\_MBWU\_L\_ns) accesses the long memory bandwidth usage monitor used for Non-secure PARTIDs.
- The Root instance (MSMON\_MBWU\_L\_rt) accesses the long memory bandwidth usage monitor used for Root PARTIDs.
- The Realm instance (MSMON\_MBWU\_L\_rl) accesses the long memory bandwidth usage monitor used for Realm PARTIDs.

When RIS is implemented, reads and writes to MSMON\_MBWU\_L access the long memory bandwidth usage monitor instance for the bandwidth resource instance selected by <a href="MSMON\_CFG\_MON\_SEL">MSMON\_CFG\_MON\_SEL</a>.RIS and the monitor instance selected by <a href="MSMON\_CFG\_MON\_SEL">MSMON\_CFG\_MON\_SEL</a>.MON SEL.

When RIS is not implemented, reads and writes to MSMON\_MBWU\_L access the long memory bandwidth usage monitor instance for the monitor instance selected by MSMON\_CFG\_MON\_SEL.MON\_SEL.

## MSMON\_MBWU\_L can be accessed through the memory-mapped interfaces:

| Component | Frame        | Offset | Instance     |
|-----------|--------------|--------|--------------|
| MPAM      | MPAMF_BASE_s | 0x0880 | MSMON_MBWU_s |

Accesses on this interface are RW.

| Component | Frame         | Offset | Instance      |
|-----------|---------------|--------|---------------|
| MPAM      | MPAMF_BASE_ns | 0x0880 | MSMON_MBWU_ns |

Accesses on this interface are RW.

| Component | Frame         | Offset | Instance      |
|-----------|---------------|--------|---------------|
| MPAM      | MPAMF_BASE_rt | 0x0880 | MSMON_MBWU_rt |

When FEAT RME is implemented, accesses on this interface are **RW**.

| Component | Frame         | Offset | Instance      |
|-----------|---------------|--------|---------------|
| MPAM      | MPAMF_BASE_rl | 0x0880 | MSMON_MBWU_rl |

When FEAT RME is implemented, accesses on this interface are RW.

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.