## MPAMF\_MSMON\_IDR, MPAM Resource Monitoring Identification Register

The MPAMF MSMON IDR characteristics are:

## **Purpose**

Indicates which MPAM monitoring features are present on this MSC.

MPAMF\_MSMON\_IDR\_s indicates Secure monitoring features.
MPAMF\_MSMON\_IDR\_ns indicates Non-secure monitoring features.
MPAMF\_MSMON\_IDR\_rt indicates Root monitoring features.
MPAMF\_MSMON\_IDR\_rl indicates Realm monitoring features.

If <u>MPAMF\_IDR</u>.HAS\_RIS is 1, fields that mention RIS must reflect the properties of the resource instance currently selected by <u>MPAMCFG\_PART\_SEL</u>.RIS. Fields that do not mention RIS are constant across all resource instances.

## **Configuration**

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

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

### **Attributes**

MPAMF MSMON IDR is a 32-bit register.

## Field descriptions

31 30 29 28 27262524232221201918
HAS LOCAL CAPT EVNTNO HW OFLW INTRIHAS OFLW MSIHAS OFLOW SR RESO MS

#### HAS LOCAL CAPT EVNT, bit [31]

Has local capture event generator. Indicates whether this MSC has the MPAM local capture event generator and the <a href="MSMON\_CAPT\_EVNT">MSMON\_CAPT\_EVNT</a> register.

| 0b0 | Does not support MPAM |
|-----|-----------------------|
|     | local capture event   |
|     | generator or          |
|     | MSMON_CAPT_EVNT.      |
| 0b1 | Supports the MPAM     |
|     | local capture event   |
|     | generator and the     |
|     | MSMON CAPT EVNT       |
|     | register.             |

# NO\_HW\_OFLW\_INTR, bit [30] When FEAT\_MPAMv1p1 is implemented:

Does not have hardwired MPAM monitor overflow interrupt.

| NO_HW_OFLW_INTR | Meaning          |
|-----------------|------------------|
| 0b0             | Supports         |
|                 | generating a     |
|                 | hardwired        |
|                 | interrupt to     |
|                 | signal MPAM      |
|                 | monitor          |
|                 | overflow.        |
| 0b1             | No support for a |
|                 | hardwired        |
|                 | interrupt to     |
|                 | signal MPAM      |
|                 | monitor          |
|                 | overflow.        |

If this field is 0, the MSC supports generating a hardwired interrupt for monitor overflow events.

If this field is 0 and the HAS\_OFLW\_MSI field in this register is 1, the MSC supports generating both hardwired interrupts and MSI writes to signal interrupts.

#### Otherwise:

Reserved, res0.

#### HAS\_OFLW\_MSI, bit [29] When FEAT\_MPAMv1p1 is implemented:

Has support for MSI writes to signal MPAM monitor overflow interrupts. These registers are implemented:

MSMON\_OFLOW\_MSI\_ADDR\_L, MSMON\_OFLOW\_MSI\_ADDR\_H,
MSMON\_OFLOW\_MSI\_ATTR, MSMON\_OFLOW\_MSI\_DATA and
MSMON\_OFLOW\_MSI\_MPAM.

| HAS_OFLW_MSI | Meaning                                  |
|--------------|------------------------------------------|
| 0b0          | MSMON_OFLOW_MSI_ADDR_L, MSMON_OFLOW_MSI  |
|              | MSMON_OFLOW_MSI_DATA and MSMON_OFLOW_MS  |
| 0b1          | MSMON OFLOW MSI ADDR L, MSMON OFLOW MS   |
|              | MSMON OFLOW MSI DATA and MSMON OFLOW MS  |
|              | signal MPAM monitor overflow interrupts. |

If <u>MPAMF\_MSMON\_IDR</u>.NO\_HW\_OFLW\_INTR is 1 and this bit is 0, this MSC does not support monitor overflow interrupts.

#### Otherwise:

Reserved, res0.

#### HAS\_OFLOW\_SR, bit [28] When FEAT\_MPAMv1p1 is implemented:

Has MPAM monitor overflow status register MSMON OFLOW SR.

| HAS_OFLOW_SR | Meaning         |
|--------------|-----------------|
| 0b0          | Does not have   |
|              | MSMON_OFLOW_SR. |
| 0b1          | Supports        |
|              | MSMON OFLOW SR. |

#### Otherwise:

Reserved, res0.

#### Bits [27:18]

Reserved, res0.

#### MSMON MBWU, bit [17]

Memory bandwidth usage monitoring. Indicates whether MPAM monitoring for Memory Bandwidth Usage by PARTID and PMG is implemented and whether the following bandwidth usage registers are accessible:

- <u>MPAMF\_MBWUMON\_IDR</u>, <u>MSMON\_CFG\_MBWU\_CTL</u>, MSMON\_CFG\_MBWU\_FLT, MSMON\_MBWU.
- The optional MSMON MBWU CAPTURE.
- If MPAM v0.1 or MPAM v1.1 is implemented, the optional <u>MSMON\_MBWU\_L</u> and the optional MSMON\_MBWU\_L CAPTURE.

| 11011011_11D | MSMON_MBWU | Meaning |
|--------------|------------|---------|
|--------------|------------|---------|

| 0b0 | Does not have      |
|-----|--------------------|
|     | monitoring for     |
|     | memory bandwidth   |
|     | usage and does not |
|     | use the bandwidth  |
|     | usage registers.   |
| 0b1 | Has monitoring of  |
|     | memory bandwidth   |
|     | usage and uses the |
|     | bandwidth usage    |
|     | registers.         |

If RIS is implemented, this field indicates that memory bandwidth usage monitoring is implemented for the resource instance selected by <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_PART\_SEL</a>.RIS as described in <a href="MPAMFMBWUMON">MPAMF MBWUMON</a> IDR.

#### MSMON CSU, bit [16]

Cache storage usage monitoring. Indicates whether MPAM monitoring of cache storage usage by PARTID and PMG is implemented and the following registers are accessible:

- <u>MPAMF\_CSUMON\_IDR</u>, <u>MSMON\_CFG\_CSU\_CTL</u>, MSMON\_CFG\_CSU\_FLT, MSMON\_CSU.
- The optional MSMON CSU CAPTURE.

| MSMON_CSU | Meaning                                                   |
|-----------|-----------------------------------------------------------|
| 0b0       | Does not have monitoring for cache storage usage or the N |
|           | MSMON_CFG_CSU_CTL, MSMON_CFG_CSU_FLT, MSMO                |
|           | MSMON_CSU_CAPTURE registers.                              |
| 0b1       | Has monitoring of cache storage usage and the MPAMF C     |
|           | MSMON CFG CSU CTL, MSMON CFG CSU FLT, MSMO                |
|           | MSMON_CSU_CAPTURE registers.                              |

If RIS is implemented, this field indicates that cache storage usage monitoring is implemented for the resource instance selected by <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_PART\_SEL</a>.RIS as described in <a href="MPAMF\_CSUMON\_IDR">MPAMF\_CSUMON\_IDR</a>.

#### Bits [15:0]

Reserved, res0.

## Accessing MPAMF\_MSMON\_IDR

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.

MPAMF\_MSMON\_IDR is read-only.

MPAMF\_MSMON\_IDR must be readable from the Non-secure, Secure, Root, and Realm MPAM feature pages.

MPAMF\_MSMON\_IDR is permitted to have the same contents when read from the Secure, Non-secure, Root, and Realm MPAM feature pages unless the register contents are different for the different versions:

- MPAMF\_MSMON\_IDR\_s is permitted to have either the same or different contents to MPAMF\_MSMON\_IDR\_ns, MPAMF\_MSMON\_IDR\_rt, or MPAMF\_MSMON\_IDR\_rt.
- MPAMF\_MSMON\_IDR\_ns is permitted to have either the same or different contents to MPAMF\_MSMON\_IDR\_rt or MPAMF\_MSMON\_IDR\_rl.
- MPAMF\_MSMON\_IDR\_rt is permitted to have either the same or different contents to MPAMF\_MSMON\_IDR\_rl.

There must be separate registers in the Secure (MPAMF\_MSMON\_IDR\_s), Non-secure (MPAMF\_MSMON\_IDR\_ns), Root (MPAMF\_MSMON\_IDR\_rt), and Realm (MPAMF\_MSMON\_IDR\_rl) MPAM feature pages.

When <u>MPAMF\_IDR</u>.HAS\_RIS is 1, MPAMF\_MSMON\_IDR shows the configuration of memory system monitoring for the resource instance selected by <u>MPAMCFG\_PART\_SEL</u>.RIS. Fields that mention RIS in their field descriptions have values that track the implemented properties of the resource instance. Fields that do not mention RIS are constant across all resource instances.

Access to MPAMF\_MSMON\_IDR is not affected by MSMON\_CFG\_MON\_SEL.RIS.

## MPAMF\_MSMON\_IDR can be accessed through the memory-mapped interfaces:

| Component | Frame        | Offset | Instance          |
|-----------|--------------|--------|-------------------|
| MPAM      | MPAMF_BASE_s | 0x0080 | MPAMF_MSMON_IDR_s |

Accesses on this interface are **RO**.

| Component | Frame         | Offset | Instance           |
|-----------|---------------|--------|--------------------|
| MPAM      | MPAMF_BASE_ns | 0x0080 | MPAMF_MSMON_IDR_ns |

Accesses on this interface are **RO**.

| Component | Frame         | Offset | Instance           |
|-----------|---------------|--------|--------------------|
| MPAM      | MPAMF_BASE_rt | 0x0080 | MPAMF_MSMON_IDR_rt |

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

| Component | Frame | Offset | Instance |
|-----------|-------|--------|----------|
|-----------|-------|--------|----------|

| MPAM | MPAMF BASE rl | 0x0080 | MPAMF MSMON IDR rl |
|------|---------------|--------|--------------------|
|      |               |        |                    |

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

AArch32 Registers AArch64 Registers

AArch32 Instructions AArch64 Instructions Index by Encoding

External Registers

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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