# MPAMCFG\_CMAX, MPAM Cache Maximum Capacity Partition Configuration Register

The MPAMCFG CMAX characteristics are:

### **Purpose**

The MPAMCFG\_CMAX is a 32-bit read/write register that controls the maximum fraction of the cache capacity that the PARTID selected by MPAMCFG\_PART\_SEL is permitted to allocate.

MPAMCFG\_CMAX\_s controls the cache maximum capacity for the Secure PARTID selected by the Secure instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_CMAX\_ns controls the cache maximum capacity for the Non-secure PARTID selected by the Non-secure instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_CMAX\_rt controls the cache maximum capacity for the Root PARTID selected by the Root instance of <a href="MPAMCFG\_PART\_SEL">MPAMCFG\_CMAX\_rl controls the cache maximum capacity for the Realm PARTID selected by the Realm instance of 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, MPAMF\_IDR.HAS\_CCAP\_PART == 1 and MPAMF\_CCAP\_IDR.NO\_CMAX == 0. Otherwise, direct accesses to MPAMCFG CMAX are res0.

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

# **Attributes**

MPAMCFG\_CMAX is a 32-bit register.

## Field descriptions

| 31      | 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | 151413121110 9 8 7 6 5 4 3 2 1 0 |
|---------|----------------------------------------------|----------------------------------|
| SOFTLIM | RES0                                         | CMAX                             |

#### SOFTLIM, bit [31]

When (FEAT\_MPAMv0p1 is implemented or FEAT\_MPAMv1p1 is implemented) and MPAMF CCAP IDR.HAS CMAX SOFTLIM == 1:

Soft limiting of CMAX. Soft limiting allows some allocations by a PARTID when its cache use is above the CMAX maximum cache capacity.

| SOFTLIM | Meaning                       |
|---------|-------------------------------|
| 0b0     | When CMAX cache capacity      |
|         | is exceeded, the partition is |
|         | not allowed to increase its   |
|         | cache capacity usage. It is   |
|         | only permitted to replace a   |
|         | line that was previously      |
|         | occupied by a line allocated  |
|         | by that PARTID.               |
| 0b1     | When CMAX cache capacity      |
|         | is exceeded, the partition is |
|         | permitted to allocate         |
|         | capacity beyond CMAX, but     |
|         | only from invalid lines or    |
|         | lines belonging to disabled   |
|         | PARTIDs.                      |

#### Otherwise:

Reserved, res0.

#### Bits [30:16]

Reserved, res0.

#### **CMAX, bits [15:0]**

Maximum cache capacity usage in fixed-point fraction format by the partition selected by <u>MPAMCFG\_PART\_SEL</u>. The fraction represents the portion of the total cache capacity that the PARTID is permitted to allocate.

The implemented width of the fixed-point fraction is given in <a href="MPAMF\_CCAP\_IDR">MPAMF\_CCAP\_IDR</a>. CMAX\_WD. Unimplemented bits within the field are RAZ/WI. The implemented bits of the CMAX field are always the most significant bits of the field.

The fixed-point fraction CMAX is less than 1. The implied binary point is between bits 15 and 16. This representation has as the largest fraction of the cache that can be represented in an implementation with w implemented bits is 1.0 minus one half to the power w.

# **Accessing MPAMCFG\_CMAX**

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\_CMAX\_s must only be accessible from the Secure MPAM feature page.
- MPAMCFG\_CMAX\_ns must only be accessible from the Non-secure MPAM feature page.
- MPAMCFG\_CMAX\_rt must only be accessible from the Root MPAM feature page.
- MPAMCFG\_CMAX\_rl must only be accessible from the Realm MPAM feature page.

MPAMCFG\_CMAX\_s, MPAMCFG\_CMAX\_ns, MPAMCFG\_CMAX\_rt, and MPAMCFG\_CMAX\_rl must be separate registers:

- The Secure instance (MPAMCFG\_CMAX\_s) accesses the cache capacity partitioning used for Secure PARTIDs.
- The Non-secure instance (MPAMCFG\_CMAX\_ns) accesses the cache capacity partitioning used for Non-secure PARTIDs.
- The Root instance (MPAMCFG\_CMAX\_rt) accesses the cache capacity partitioning used for Root PARTIDs.
- The Realm instance (MPAMCFG\_CMAX\_rl) accesses the cache capacity partitioning used for Realm PARTIDs.

When RIS is implemented, loads and stores to MPAMCFG\_CMAX access the cache maximum capacity partitioning 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\_CMAX access the cache maximum capacity partitioning configuration settings for the PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL.

When PARTID narrowing is implemented, loads and stores to MPAMCFG\_CMAX access the cache maximum capacity partitioning 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\_CMAX access the cache maximum capacity partitioning configuration settings for the request PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL, and MPAMCFG\_PART\_SEL.INTERNAL must be 0.

# MPAMCFG\_CMAX can be accessed through the memory-mapped interfaces:

| Component | Frame        | Offset | Instance       |
|-----------|--------------|--------|----------------|
| MPAM      | MPAMF_BASE_s | 0x0108 | MPAMCFG_CMAX_s |

Accesses on this interface are RW.

| Component | Frame         | Offset | Instance        |
|-----------|---------------|--------|-----------------|
| MPAM      | MPAMF_BASE_ns | 0x0108 | MPAMCFG_CMAX_ns |

Accesses on this interface are RW.

| Component | Frame         | Offset | Instance        |  |
|-----------|---------------|--------|-----------------|--|
| MPAM      | MPAMF_BASE_rt | 0x0108 | MPAMCFG_CMAX_rt |  |

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

| Component | Frame         | Offset | Instance        |
|-----------|---------------|--------|-----------------|
| MPAM      | MPAMF_BASE_rl | 0x0108 | MPAMCFG_CMAX_rl |

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

| AArch32          | AArch64          | AArch32             | AArch64             | <u>Index by</u> | <u>External</u>  |
|------------------|------------------|---------------------|---------------------|-----------------|------------------|
| <u>Registers</u> | <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.