The MPAMF_IDR characteristics are:
Indicates which memory partitioning and monitoring features are present on this MSC.
MPAMF_IDR_s indicates the MPAM features accessed from the Secure MPAM feature page. MPAMF_IDR_ns indicates the MPAM features accessed from the Non-secure MPAM feature page. MPAMF_IDR_rt indicates the MPAM features accessed from the Root MPAM feature page. MPAMF_IDR_rl indicates the MPAM features accessed from the Realm MPAM feature page.
When MPAMF_IDR.HAS_RIS is 1, some fields in this register give information for the resource instance selected by MPAMCFG_PART_SEL.RIS. The description of every field that is affected by MPAMCFG_PART_SEL.RIS has that information within the field description.
The power domain of MPAMF_IDR is IMPLEMENTATION DEFINED.
This register is present only when FEAT_MPAM is implemented. Otherwise, direct accesses to MPAMF_IDR are RES0.
MPAMF_IDR is a 64-bit register when MPAM v0.1 or v1.1 is implemented.
Otherwise, MPAMF_IDR is a 32-bit register.
The power and reset domain of each MSC component is specific to that component.
MPAMF_IDR is a:
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 |
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 |
RES0 | RIS_MAX | RES0 | HAS_NFU | HAS_ENDIS | SP4 | HAS_ERR_MSI | HAS_ESR | HAS_EXTD_ESR | NO_IMPL_MSMON | NO_IMPL_PART | RES0 | HAS_RIS | |||||||||||||||||||
HAS_PARTID_NRW | HAS_MSMON | HAS_IMPL_IDR | EXT | HAS_PRI_PART | HAS_MBW_PART | HAS_CPOR_PART | HAS_CCAP_PART | PMG_MAX | PARTID_MAX |
Reserved, RES0.
Maximum RIS value supported in MPAMCFG_PART_SEL. Must be 0b0000 if MPAMF_IDR.HAS_RIS == 0.
This field has an IMPLEMENTATION DEFINED value.
Access to this field is RO.
Reserved, RES0.
Reserved, RES0.
Has No Future Use field in MPAMCFG_DIS. Indicates that MPAMCFG_DIS.NFU is implemented.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_NFU | Meaning |
---|---|
0b0 |
MPAMCFG_DIS.NFU is not implemented. A PARTID disabled through access to MPAMCFG_DIS must preserve the control settings of the disabled PARTID. |
0b1 |
Implements MPAMCFG_DIS.NFU. A PARTID disabled with NFU as 1 may have its control settings forgotten. |
If MPAMF_IDR.HAS_ENDIS is 0b0, this field must also be 0b0.
This field must be the same in each instance of this register and for any value in MPAMCFG_PART_SEL.RIS.
Access to this field is RO.
Reserved, RES0.
Has PARTID enable and disable. Indicates that this MSC supports PARTID disable and enable via MPAMCFG_DIS, MPAMCFG_EN and MPAMCFG_EN_FLAGS registers.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_ENDIS | Meaning |
---|---|
0b0 |
Does not support PARTID enable and disable functionality, and MPAMCFG_EN, MPAMCFG_DIS and MPAMCFG_EN_FLAGS registers are not implemented. |
0b1 |
Supports PARTID enable and disable through the MPAMCFG_EN, MPAMCFG_DIS and MPAMCFG_EN_FLAGS registers. |
All three registers must be implemented when this field is 1, MPAMCFG_EN, MPAMCFG_DIS, and MPAMCFG_EN_FLAGS.
This field must be the same in each instance of this register and for any value in MPAMCFG_PART_SEL.RIS.
Access to this field is RO.
Reserved, RES0.
Indicates whether this MSC supports 4 PARTID spaces.
The value of this field is an IMPLEMENTATION DEFINED choice of:
SP4 | Meaning |
---|---|
0b0 |
This MSC supports two PARTID spaces. |
0b1 |
This MSC supports four PARTID spaces. |
This field must read the same in each instance of this register and for any value in MPAMCFG_PART_SEL.RIS.
Access to this field is RO.
Reserved, RES0.
Has support for MSI writes to signal MPAM error interrupts. These registers are implemented: MPAMF_ERR_MSI_ADDR_L, MPAMF_ERR_MSI_ADDR_H, MPAMF_ERR_MSI_ATTR, MPAMF_ERR_MSI_DATA, and MPAMF_ERR_MSI_MPAM.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_ERR_MSI | Meaning |
---|---|
0b0 |
MPAMF_ERR_MSI_ADDR_L, MPAMF_ERR_MSI_ADDR_H, MPAMF_ERR_MSI_ATTR, MPAMF_ERR_MSI_DATA, and MPAMF_ERR_MSI_MPAM registers are not implemented. |
0b1 |
MPAMF_ERR_MSI_ADDR_L, MPAMF_ERR_MSI_ADDR_H, MPAMF_ERR_MSI_ATTR, MPAMF_ERR_MSI_DATA, and MPAMF_ERR_MSI_MPAM are implemented and can be used to generate writes to signal error interrupts. |
If MPAMF_IDR.HAS_ESR is 0, this bit must also be 0.
Access to this field is RO.
Reserved, RES0.
MPAMF_ESR is implemented.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_ESR | Meaning |
---|---|
0b0 |
MPAMF_ESR, MPAMF_ECR, and MPAM error handling are not implemented. |
0b1 |
MPAMF_ESR, MPAMF_ECR, and MPAM error handling are implemented. |
If an MSC cannot encounter any of the error conditions listed in 'Errors in MSCs' in Arm® Architecture Reference Manual Supplement, Memory System Resource Partitioning and Monitoring (MPAM), for Armv8-A (ARM DDI 0598), both the MPAMF_ESR and MPAMF_ECR must be RAZ/WI.
Access to this field is RO.
Reserved, RES0.
MPAMF_ESR is 64 bits.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_EXTD_ESR | Meaning |
---|---|
0b0 |
MPAMF_ESR is 32 bits. |
0b1 |
MPAMF_ESR is 64 bits. |
When MPAMF_IDR.HAS_RIS and MPAMF_IDR.HAS_ESR, this field must be 1.
Access to this field is RO.
Reserved, RES0.
MPAMF_IMPL_IDR defines no IMPLEMENTATION DEFINED resource monitors.
The value of this field is an IMPLEMENTATION DEFINED choice of:
NO_IMPL_MSMON | Meaning |
---|---|
0b0 |
MPAMF_IMPL_IDR defines at least one IMPLEMENTATION DEFINED resource monitor. |
0b1 |
MPAMF_IMPL_IDR does not define any IMPLEMENTATION DEFINED resource monitors. |
If RIS is implemented, this field indicates the presence of IMPLEMENTATION DEFINED resource monitors described in MPAMF_IMPL_IDR for the selected resource instance.
Access to this field is RO.
Reserved, RES0.
MPAMF_IMPL_IDR defines no IMPLEMENTATION DEFINED resource controls.
The value of this field is an IMPLEMENTATION DEFINED choice of:
NO_IMPL_PART | Meaning |
---|---|
0b0 |
MPAMF_IMPL_IDR defines at least one IMPLEMENTATION DEFINED resource control. |
0b1 |
MPAMF_IMPL_IDR does not define any IMPLEMENTATION DEFINED resource controls. |
If RIS is implemented, this field indicates the presence of IMPLEMENTATION DEFINED resource controls described in MPAMF_IMPL_IDR for the selected resource instance.
Access to this field is RO.
Reserved, RES0.
Reserved, RES0.
Has resource instance selector. Indicates that MPAMCFG_PART_SEL contains the RIS field that selects a resource instance to control.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_RIS | Meaning |
---|---|
0b0 |
MPAMCFG_PART_SEL does not implement the MPAMCFG_PART_SEL.RIS field or multiple resource instance support. |
0b1 |
MPAMCFG_PART_SEL implements the MPAMCFG_PART_SEL.RIS field and MPAM resource instance numbers up to and including MPAMF_IDR.RIS_MAX. |
Access to this field is RO.
Reserved, RES0.
Has PARTID narrowing.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_PARTID_NRW | Meaning |
---|---|
0b0 |
Does not have MPAMF_PARTID_NRW_IDR, MPAMCFG_INTPARTID, or intPARTID mapping support. |
0b1 |
Supports the MPAMF_PARTID_NRW_IDR, MPAMCFG_INTPARTID registers. |
Access to this field is RO.
Has resource Monitors. Indicates whether this MSC has MPAM resource monitors.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_MSMON | Meaning |
---|---|
0b0 |
Does not support MPAM resource monitoring by groups or MPAMF_MSMON_IDR. |
0b1 |
Supports resource monitoring by matching a combination of PARTID and PMG. See MPAMF_MSMON_IDR. |
Access to this field is RO.
Has MPAMF_IMPL_IDR. Indicates whether this MSC has the IMPLEMENTATION SPECIFIC MPAM features register, MPAMF_IMPL_IDR.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_IMPL_IDR | Meaning |
---|---|
0b0 |
Does not have MPAMF_IMPL_IDR. |
0b1 |
Has MPAMF_IMPL_IDR. |
Access to this field is RO.
Extended MPAMF_IDR.
The value of this field is an IMPLEMENTATION DEFINED choice of:
EXT | Meaning |
---|---|
0b0 |
MPAMF_IDR has no defined bits in [63:32]. The register is effectively 32 bits. |
0b1 |
MPAMF_IDR has bits defined in [63:32]. The register is 64-bits. |
Access to this field is RO.
Reserved, RES0.
Has Priority Partitioning. Indicates that MPAM priority partitioning is implemented and MPAMF_PRI_IDR exists.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_PRI_PART | Meaning |
---|---|
0b0 |
Does not support priority partitioning or have MPAMF_PRI_IDR. |
0b1 |
Has priority partitioning and MPAMF_PRI_IDR. |
If RIS is implemented, this field indicates the presence of priority partitioning resource controls as described in MPAMF_PRI_IDR for the selected resource instance.
Access to this field is RO.
Has Memory Bandwidth Partitioning. Indicates whether this MSC implements MPAM memory bandwidth partitioning and MPAMF_MBW_IDR.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_MBW_PART | Meaning |
---|---|
0b0 |
Does not support memory bandwidth partitioning or have MPAMF_MBW_IDR register. |
0b1 |
Has MPAMF_MBW_IDR register. |
If RIS is implemented, this field indicates the presence of memory bandwidth partitioning resource controls as described in MPAMF_MBW_IDR for the selected resource instance.
Access to this field is RO.
Has Cache Portion Partitioning. Indicates whether this MSC implements MPAM cache portion partitioning and MPAMF_CPOR_IDR.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_CPOR_PART | Meaning |
---|---|
0b0 |
Does not support cache portion partitioning or have MPAMF_CPOR_IDR or MPAMCFG_CPBM<n> registers. |
0b1 |
Has MPAMF_CPOR_IDR and MPAMCFG_CPBM<n> registers. |
If RIS is implemented, this field indicates the presence of cache portion partitioning resource controls as described in MPAMF_CPOR_IDR for the selected resource instance.
Access to this field is RO.
Has Cache Capacity Partitioning. Indicates whether this MSC implements MPAM cache capacity partitioning and the MPAMF_CCAP_IDR and MPAMCFG_CMAX registers.
The value of this field is an IMPLEMENTATION DEFINED choice of:
HAS_CCAP_PART | Meaning |
---|---|
0b0 |
Does not support cache capacity partitioning or have MPAMF_CCAP_IDR and MPAMCFG_CMAX registers. |
0b1 |
Has MPAMF_CCAP_IDR and MPAMCFG_CMAX registers. |
If RIS is implemented, this field indicates the presence of cache capacity partitioning resource controls as described in MPAMF_CPOR_IDR for the selected resource instance.
Access to this field is RO.
Maximum supported value of PMG.
The value of this field is permitted to vary between the instances of MPAMF_IDR, each reporting the maximum supported PMG value in the PARTID space associated with that instance.
In MPAMF_IDR_s, this field is permitted to report the maximum PMG value for the Non-secure PARTID space or for the Secure PARTID space. The maximum PMG value for the Secure PARTID space can be read from MPAMF_SIDR.PMG_MAX.
This field has an IMPLEMENTATION DEFINED value.
Access to this field is RO.
Maximum supported value of PARTID.
The value of this field is permitted to vary between the instances of MPAMF_IDR, each reporting the maximum supported PARTID value in the PARTID space associated with that instance.
In MPAMF_IDR_s, this field is permitted to report the maximum PARTID value for the Non-secure PARTID space or for the Secure PARTID space. The maximum PARTID value for the Secure PARTID space can be read from MPAMF_SIDR.PARTID_MAX.
This field has an IMPLEMENTATION DEFINED value.
Access to this field is RO.
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 |
HAS_PARTID_NRW | HAS_MSMON | HAS_IMPL_IDR | EXT | HAS_PRI_PART | HAS_MBW_PART | HAS_CPOR_PART | HAS_CCAP_PART | PMG_MAX | PARTID_MAX |
Has PARTID Narrowing.
HAS_PARTID_NRW | Meaning |
---|---|
0b0 |
Does not have MPAMF_PARTID_NRW_IDR, MPAMCFG_INTPARTID, or intPARTID mapping support. |
0b1 |
Supports the MPAMF_PARTID_NRW_IDR, MPAMCFG_INTPARTID registers. |
Has resource Monitors. Indicates whether this MSC has MPAM resource monitors.
HAS_MSMON | Meaning |
---|---|
0b0 |
Does not support MPAM resource monitoring by groups or MPAMF_MSMON_IDR. |
0b1 |
Supports resource monitoring by matching a combination of PARTID and PMG. See MPAMF_MSMON_IDR. |
Has MPAMF_IMPL_IDR. Indicates whether this MSC has the IMPLEMENTATION SPECIFIC MPAM features register, MPAMF_IMPL_IDR.
HAS_IMPL_IDR | Meaning |
---|---|
0b0 |
Does not have MPAMF_IMPL_IDR. |
0b1 |
Has MPAMF_IMPL_IDR. |
Extended MPAMF_IDR.
EXT | Meaning |
---|---|
0b0 |
MPAMF_IDR has no defined bits in [63:32]. The register is effectively 32 bits. |
0b1 |
MPAMF_IDR has bits defined in [63:32]. The register is 64-bits. |
Reserved, RES0.
Has Priority Partitioning. Indicates whether this MSC implements MPAM priority partitioning and MPAMF_PRI_IDR.
HAS_PRI_PART | Meaning |
---|---|
0b0 |
Does not support priority partitioning or have MPAMF_PRI_IDR. |
0b1 |
Has MPAMF_PRI_IDR. |
Has Memory Bandwidth Partitioning. Indicates whether this MSC implements MPAM memory bandwidth partitioning and MPAMF_MBW_IDR.
HAS_MBW_PART | Meaning |
---|---|
0b0 |
Does not support memory bandwidth partitioning or have MPAMF_MBW_IDR register. |
0b1 |
Has MPAMF_MBW_IDR register. |
Has Cache Portion Partitioning. Indicates whether this MSC implements MPAM cache portion partitioning and MPAMF_CPOR_IDR.
HAS_CPOR_PART | Meaning |
---|---|
0b0 |
Does not support cache portion partitioning or have MPAMF_CPOR_IDR or MPAMCFG_CPBM<n> registers. |
0b1 |
Has MPAMF_CPOR_IDR and MPAMCFG_CPBM<n> registers. |
Has Cache Capacity Partitioning. Indicates whether this MSC implements MPAM cache capacity partitioning and the MPAMF_CCAP_IDR and MPAMCFG_CMAX registers.
HAS_CCAP_PART | Meaning |
---|---|
0b0 |
Does not support cache capacity partitioning or have MPAMF_CCAP_IDR and MPAMCFG_CMAX registers. |
0b1 |
Has MPAMF_CCAP_IDR and MPAMCFG_CMAX registers. |
Maximum supported value of PMG.
The value of this field is permitted to vary between the instances of MPAMF_IDR, each reporting the maximum supported PMG value in the PARTID space associated with that instance.
In MPAMF_IDR_s this field is permitted to report the maximum PMG value for the Non-secure PARTID space or for the Secure PARTID space. The maximum PMG value for the Secure PARTID space can be read from MPAMF_SIDR.PMG_MAX.
Maximum supported value of PARTID.
The value of this field is permitted to vary between the instances of MPAMF_IDR, each reporting the maximum supported PARTID value in the PARTID space associated with that instance.
In MPAMF_IDR_s this field is permitted to report the maximum PARTID value for the Non-secure PARTID space or for the Secure PARTID space. The maximum PARTID value for the Secure PARTID space can be read from MPAMF_SIDR.PARTID_MAX.
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_IDR is read-only.
MPAMF_IDR must be readable from the Non-secure, Secure, Root, and Realm MPAM feature pages.
MPAMF_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:
There must be separate registers in the Secure (MPAMF_IDR_s), Non-secure (MPAMF_IDR_ns), Root (MPAMF_IDR_rt), and Realm (MPAMF_IDR_rl) MPAM feature pages.
When MPAMF_IDR.HAS_RIS is 1, MPAMF_IDR shows the configuration of MSC MPAM for the resource instance selected by MPAMCFG_PART_SEL.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.
Component | Frame | Offset | Instance |
---|---|---|---|
MPAM | MPAMF_BASE_s | 0x0000 | MPAMF_IDR_s |
Accesses on this interface are RO.
Component | Frame | Offset | Instance |
---|---|---|---|
MPAM | MPAMF_BASE_ns | 0x0000 | MPAMF_IDR_ns |
Accesses on this interface are RO.
Component | Frame | Offset | Instance |
---|---|---|---|
MPAM | MPAMF_BASE_rt | 0x0000 | MPAMF_IDR_rt |
When FEAT_RME is implemented, accesses on this interface are RO.
Component | Frame | Offset | Instance |
---|---|---|---|
MPAM | MPAMF_BASE_rl | 0x0000 | MPAMF_IDR_rl |
When FEAT_RME is implemented, accesses on this interface are RO.
26/03/2024 09:49; 67c0ae5282a7629ba0ea0ba7267b43cd4f7939f6
Copyright © 2010-2024 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.