# MPAMCFG\_MBW\_PBM<n>, MPAM Bandwidth Portion Bitmap Partition Configuration Register, n = 0 - 127

The MPAMCFG MBW PBM<n> characteristics are:

## **Purpose**

The MPAMCFG\_MBW\_PBM<n> register array gives access to the memory bandwidth portion bitmap. Each register in the array is a read/ write register that configures whether a PARTID is allowed to allocate bandwidth portions within a range.

The range of portions covered in MPAMCFG\_MBW\_PBM<n> is from portion <32\*n> to portion <32\*n +31>.

After setting <u>MPAMCFG\_PART\_SEL</u> with a PARTID, software writes to one or more of the MPAMCFG\_MBW\_PBM<n> registers to configure with bandwidth portions the PARTID is allowed to allocate.

The MPAMCFG\_MBW\_PBM<n> register that contains the bitmap bit corresponding to memory bandwidth portion p has n equal to p[11:5]. The field, P<x> of that MPAMCFG\_MBW\_PBM<n> register that contains the bitmap bit corresponding to memory bandwidth portion p has <x> equal to p[4:0].

The MPAMCFG\_MBW\_PBM<n>\_s registers control the bandwidth portion bitmap for the Secure PARTID selected by the Secure instance of MPAMCFG\_PART\_SEL. The MPAMCFG\_MBW\_PBM<n>\_ns registers control the bandwidth portion bitmap for the Non-secure PARTID selected by the Non-secure instance of MPAMCFG\_PART\_SEL. The MPAMCFG\_MBW\_PBM<n>\_rt registers control the bandwidth portion bitmap for the Root PARTID selected by the Root instance of MPAMCFG\_PART\_SEL. The MPAMCFG\_MBW\_PBM<n>\_rl registers control the bandwidth portion bitmap for the Realm PARTID selected by the Realm instance of MPAMCFG\_PART\_SEL.

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\_MBW\_PART == 1 and MPAMF\_MBW\_IDR.HAS\_PBM

== 1. Otherwise, direct accesses to MPAMCFG\_MBW\_PBM<n> are res0.

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

#### **Attributes**

MPAMCFG\_MBW\_PBM<n> is a 32-bit register.

## Field descriptions

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

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

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

The number of bits in the bandwidth portion partitioning bit map of this component is given in <a href="MPAMF\_MBW\_IDR">MPAMF\_MBW\_IDR</a>.BWPBM\_WD.

BWPBM\_WD contains a value from 1 to 2<sup>12</sup>, inclusive. Values of <a href="MPAMF\_MBW\_IDR">MPAMF\_MBW\_IDR</a>.BWPBM\_WD greater than 32 require a group of 32-bit registers to access the bandwidth portion bitmap, up to 128 32-bit registers.

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

## Accessing MPAMCFG\_MBW\_PBM<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\_MBW\_PBM<n>\_s must only be accessible from the Secure MPAM feature page.
- MPAMCFG\_MBW\_PBM<n>\_ns must only be accessible from the Non-secure MPAM feature page.

- MPAMCFG\_MBW\_PBM<n>\_rt must only be accessible from the Root MPAM feature page.
- MPAMCFG\_MBW\_PBM<n>\_rl must only be accessible from the Realm MPAM feature page.

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

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

When RIS is implemented, loads and stores to MPAMCFG\_MBW\_PBM<n> access the memory bandwidth portion bitmap configuration settings for the bandwidth resource instance selected by MPAMCFG\_PART\_SEL.RIS and the PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL.

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

When PARTID narrowing is implemented, loads and stores to MPAMCFG\_MBW\_PBM<n> access the memory bandwidth 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\_MBW\_PBM<n> access the memory bandwidth portion bitmap configuration settings for the request PARTID selected by MPAMCFG\_PART\_SEL.PARTID\_SEL, and MPAMCFG\_PART\_SEL.INTERNAL must be 0.

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

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

Accesses on this interface are **RW**.

| Component | Component Frame |        | Instance                   |
|-----------|-----------------|--------|----------------------------|
| MPAM      | MPAMF_BASE_ns   | 0x2000 | MPAMCFG_MBW_PBM <n>_ns</n> |
|           |                 | + (4 * |                            |
|           |                 | n)     |                            |

Accesses on this interface are RW.

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

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

| Component | Frame         | Offset | Instance                   |
|-----------|---------------|--------|----------------------------|
| MPAM      | MPAMF_BASE_rl | 0x2000 | MPAMCFG_MBW_PBM <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> |
|------------------|------------------|---------------------|---------------------|-----------------|-----------------|
| <u>Registers</u> | <u>Registers</u> | <u>Instructions</u> | <u>Instructions</u> | <b>Encoding</b> | Registers       |

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright  $\hat{A}$  © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.