# MPAMCFG\_CPBM<n>, MPAM Cache Portion Bitmap Partition Configuration Register, n = 0 - 1023

The MPAMCFG CPBM<n> characteristics are:

### **Purpose**

The MPAMCFG\_CPBM<n> register array gives access to the cache portion bitmap. Each register in the array is a read/write register that configures the cache portions numbered from <n \* 32> to <31 + (n \* 32)> that a PARTID is allowed to allocate.

After setting MPAMCFG\_PART\_SEL with a PARTID, software writes to the MPAMCFG\_CPBM<n> register to configure which cache portions the PARTID is allowed to allocate.

The MPAMCFG\_CPBM<n> register that contains the bitmap bit corresponding to cache portion p has n equal to p[15:5]. The field, P<x>, of that MPAMCFG\_CPBM<n> register that contains the bitmap bit corresponding to cache portion p has x equal to p[4:0].

MPAMCFG\_CPBM<n>\_s controls cache portions for the Secure PARTID selected by the Secure instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_CPBM<n>\_ns controls the cache portions for the Nonsecure PARTID selected by the Non-secure instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_PART\_SEL</a>. MPAMCFG\_CPBM<n>\_rt controls cache portions for the Root PARTID selected by the Root instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_CPBM<n>\_rl controls the cache portions for the Realm PARTID selected by the Non-secure instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_PART\_SEL</a>.

If <u>MPAMF\_IDR</u>.HAS\_RIS is 1, the control settings accessed are those of the resource instance currently selected by <u>MPAMCFG\_PART\_SEL</u>.RIS and the PARTID selected by <u>MPAMCFG\_PART\_SEL</u>.PARTID\_SEL.

### **Configuration**

This register is present only when FEAT\_MPAM is implemented and MPAMF\_IDR.HAS\_CPOR\_PART == 1. Otherwise, direct accesses to MPAMCFG CPBM<n> are res0.

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

#### **Attributes**

MPAMCFG CPBM<n> is a 32-bit register.

## **Field descriptions**

#### P < x >, bit [x], for x = 31 to 0

Portion allocation control bit. Each cache portion allocation control bit, MPAMCFG\_CPBM<n>.P<x>, grants permission to the PARTID selected by MPAMCFG\_PART\_SEL to allocate cache lines within cache portion <n\*32> + x.

| P <x></x> | Meaning                                       |
|-----------|-----------------------------------------------|
| 0b0       | The PARTID is not permitted to                |
|           | allocate into cache portion $<$ n $*$         |
|           | 32 > + x.                                     |
| 0b1       | The PARTID is permitted to                    |
|           | allocate within cache portion <n< th=""></n<> |
|           | * 32> + x.                                    |

The number of bits in the cache portion partitioning bit map of this component is given in <a href="MPAMF CPOR IDR">MPAMF CPOR IDR</a>. CPBM WD.

MPAMF\_CPOR\_IDR.CPBM\_WD contains a value from 1 to 2<sup>15</sup>, inclusive. Values of MPAMF\_CPOR\_IDR.CPBM\_WD greater than 32 require an array of 32-bit MPAMCFG\_CPBM<n> registers to access the cache portion bitmap, up to 1024 registers.

When  $(n * 32) + x > UInt(MPAMF_CPOR_IDR.CPBM_WD)$ , access to this field is **RESO**.

## Accessing MPAMCFG\_CPBM<n>

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:

- MPAMCFG\_CPBM<n>\_s must only be accessible from the Secure MPAM feature page.
- MPAMCFG\_CPBM<n>\_ns must only be accessible from the Non-secure MPAM feature page.
- MPAMCFG\_CPBM<n>\_rt must only be accessible from the Root MPAM feature page.
- MPAMCFG\_CPBM<n>\_rl must only be accessible from the Realm MPAM feature page.

MPAMCFG\_CPBM<n>\_s, MPAMCFG\_CPBM<n>\_ns, MPAMCFG\_CPBM<n>\_rt, and MPAMCFG\_CPBM<n>\_rl must be separate registers:

- The Secure instance (MPAMCFG\_CPBM<n>\_s) accesses the cache portion bitmap used for Secure PARTIDs.
- The Non-secure instance (MPAMCFG\_CPBM<n>\_ns) accesses the cache portion bitmap used for Non-secure PARTIDs.
- The Root instance (MPAMCFG\_CPBM<n>\_rt) accesses the cache portion bitmap used for Root PARTIDs.
- The Realm instance (MPAMCFG\_CPBM<n>\_rl) accesses the cache portion bitmap used for Realm PARTIDs.

When RIS is implemented, loads and stores to MPAMCFG\_CPBM<n> access the cache portion bitmap configuration settings for the cache resource instance selected by <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_PART\_SEL</a>.RIS and the PARTID selected by <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_PART\_SEL</a>.PARTID\_SEL.

When RIS is not implemented, loads and stores to MPAMCFG\_CPBM<n> access the cache portion bitmap configuration settings for the PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL.

When PARTID narrowing is implemented, loads and stores to MPAMCFG\_CPBM<n> access the cache portion bitmap configuration settings for the internal PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL, and MPAMCFG\_PART\_SEL.INTERNAL must be 1.

When PARTID narrowing is not implemented, loads and stores to MPAMCFG\_CPBM<n> access the cache portion bitmap configuration settings for the request PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL, and MPAMCFG\_PART\_SEL.INTERNAL must be 0.

# MPAMCFG\_CPBM<n> can be accessed through the memory-mapped interfaces:

| Component | Frame        | Offset | Instance               |
|-----------|--------------|--------|------------------------|
| MPAM      | MPAMF_BASE_s | 0x1000 | MPAMCFG_CPBM <n>_s</n> |
|           |              | + (4 * |                        |
|           |              | n)     |                        |

Accesses on this interface are RW.

| Component | onent Frame   |        | Instance                |
|-----------|---------------|--------|-------------------------|
| MPAM      | MPAMF_BASE_ns | 0x1000 | MPAMCFG_CPBM <n>_ns</n> |
|           |               | + (4 * |                         |
|           |               | n)     |                         |

Accesses on this interface are **RW**.

| Component Frame |               | Offset | Instance                |
|-----------------|---------------|--------|-------------------------|
| MPAM            | MPAMF_BASE_rt | 0x1000 | MPAMCFG_CPBM <n>_rt</n> |
|                 |               | + (4 * |                         |
|                 |               | n)     |                         |

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

| Component Frame |               | Offset | Instance                |
|-----------------|---------------|--------|-------------------------|
| MPAM            | MPAMF_BASE_rl | 0x1000 | MPAMCFG_CPBM <n>_rl</n> |
|                 |               | + (4 * |                         |
|                 |               | n)     |                         |

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

| AArch32   | AArch64          | AArch32             | AArch64             | Index by        | <u>External</u>  |
|-----------|------------------|---------------------|---------------------|-----------------|------------------|
| Registers | <u>Registers</u> | <u>Instructions</u> | <u>Instructions</u> | <b>Encoding</b> | <u>Registers</u> |

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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