# PMINTENSET\_EL1, Performance Monitors Interrupt Enable Set Register

The PMINTENSET EL1 characteristics are:

# **Purpose**

Enables the generation of interrupt requests on overflows from the Cycle Count Register, PMU.PMCCNTR\_EL0, and the event counters PMU.PMEVCNTR<n>\_EL0. Reading the register shows which overflow interrupt requests are enabled.

# **Configuration**

External register PMINTENSET\_EL1 bits [31:0] are architecturally mapped to AArch64 System register <a href="MINTENSET\_EL1[31:0]">PMINTENSET\_EL1[31:0]</a> when FEAT\_PMUv3\_EXT32 is implemented, FEAT\_PMUv3p9 is not implemented and FEAT PMUv3 ICNTR is not implemented.

External register PMINTENSET\_EL1 bits [31:0] are architecturally mapped to AArch64 System register PMINTENCLR\_EL1[31:0] when FEAT\_PMUv3\_EXT32 is implemented, FEAT\_PMUv3p9 is not implemented and FEAT\_PMUv3 ICNTR is not implemented.

External register PMINTENSET\_EL1 bits [63:0] are architecturally mapped to AArch64 System register <a href="MINTENSET\_EL1[63:0]">PMINTENSET\_EL1[63:0]</a> when FEAT\_PMUv3\_EXT64 is implemented, or FEAT\_PMUv3p9 is implemented or FEAT\_PMUv3 ICNTR is implemented.

External register PMINTENSET\_EL1 bits [63:0] are architecturally mapped to AArch64 System register <a href="PMINTENCLR\_EL1[63:0">PMINTENCLR\_EL1[63:0]</a> when FEAT\_PMUv3\_EXT64 is implemented, or FEAT\_PMUv3p9 is implemented or FEAT\_PMUv3 ICNTR is implemented.

External register PMINTENSET\_EL1 bits [31:0] are architecturally mapped to AArch32 System register PMINTENSET[31:0].

External register PMINTENSET\_EL1 bits [31:0] are architecturally mapped to AArch32 System register PMINTENCLR[31:0].

This register is present only when FEAT\_PMUv3\_EXT is implemented. Otherwise, direct accesses to PMINTENSET\_EL1 are res0.

PMINTENSET\_EL1 is in the Core power domain.

### **Attributes**

PMINTENSET EL1 is a:

- 64-bit register when FEAT\_PMUv3\_EXT64 is implemented, or FEAT\_PMUv3p9 is implemented or FEAT\_PMUv3\_ICNTR is implemented
- 32-bit register otherwise

This register is part of the **PMU** block.

# **Field descriptions**

# When FEAT\_PMUv3\_EXT64 is implemented, or FEAT\_PMUv3p9 is implemented or FEAT\_PMUv3\_ICNTR is implemented:

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

RESO

C|P30|P29|P28|P27|P26|P25|P24|P23|P22|P21|P20|P19|P18|P17|P16|P15|P14|P13|P12|P11|P10|P9|P8|P7|P6|P5|P4|
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

#### Bits [63:33]

Reserved, res0.

# F0, bit [32] When FEAT\_PMUv3\_ICNTR is implemented:

Interrupt request on unsigned overflow of PMU.PMICNTR\_EL0 enable. On writes, allows software to enable the interrupt request on unsigned overflow of PMU.PMICNTR\_EL0. On reads, returns the interrupt request on unsigned overflow of PMU.PMICNTR\_EL0 enable status.

| F0  | Meaning                       |
|-----|-------------------------------|
| 0b0 | Interrupt request on unsigned |
|     | overflow of PMU.PMICNTR EL0   |
|     | disabled.                     |
| 0b1 | Interrupt request on unsigned |
|     | overflow of PMU.PMICNTR EL0   |
|     | enabled.                      |

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally unknown value.

Accessing this field has the following behavior:

- When SoftwareLockStatus(), access to this field is **RO**.
- Otherwise, access to this field is W1S.

#### Otherwise:

Reserved, res0.

#### C, bit [31]

Interrupt request or PMU exception on unsigned overflow of PMU.PMCCNTR\_EL0 enable. On writes, allows software to enable the interrupt request or PMU exception on unsigned overflow of PMU.PMCCNTR\_EL0. On reads, returns the interrupt request or PMU exception on unsigned overflow of PMU.PMCCNTR\_EL0 enable status.

| C   | Meaning                           |
|-----|-----------------------------------|
| 0b0 | Interrupt request or PMU          |
|     | exception on unsigned overflow of |
|     | PMU.PMCCNTR_EL0 disabled.         |
| 0b1 | Interrupt request or PMU          |
|     | exception on unsigned overflow of |
|     | PMU.PMCCNTR_EL0 enabled.          |

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally unknown value.

Accessing this field has the following behavior:

- When SoftwareLockStatus(), access to this field is **RO**.
- Otherwise, access to this field is **W1S**.

#### P < m >, bit [m], for m = 30 to 0

Interrupt request or PMU exception on unsigned overflow of <a href="PMEVCNTR<m>\_EL0">PMEVCNTR<m>\_EL0</a> enable. On writes, allows software to enable the interrupt request or PMU exception on unsigned overflow of <a href="PMEVCNTR<m>\_EL0">PMEVCNTR<m>\_EL0</a>. On reads, returns the interrupt request or PMU exception on unsigned overflow of <a href="PMEVCNTR<m>\_EL0">PMEVCNTR<m>\_EL0</a> enable status.

| P <m></m> | Meaning                        |
|-----------|--------------------------------|
| 0b0       | Interrupt request or PMU       |
|           | exception on unsigned overflow |
|           | of PMEVCNTR <m>_EL0</m>        |
|           | disabled.                      |
| 0b1       | Interrupt request or PMU       |
|           | exception on unsigned overflow |
|           | of PMEVCNTR <m>_EL0</m>        |
|           | enabled.                       |

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally unknown value.

Accessing this field has the following behavior:

- When m >= NUM\_PMU\_COUNTERS, access to this field is RAZ/WI.
- When SoftwareLockStatus(), access to this field is **RO**.
- Otherwise, access to this field is **W1S**.

#### Otherwise:

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 CP30P29P28P27P26P25P24P23P22P21P20P19P18P17P16P15P14P13P12P11P10P9P8P7P6P5P4

#### C, bit [31]

Interrupt request or PMU exception on unsigned overflow of PMU.PMCCNTR\_ELO enable. On writes, allows software to enable the interrupt request or PMU exception on unsigned overflow of PMU.PMCCNTR\_ELO. On reads, returns the interrupt request or PMU exception on unsigned overflow of PMU.PMCCNTR\_ELO enable status.

| C   | Meaning                           |
|-----|-----------------------------------|
| 0d0 | Interrupt request or PMU          |
|     | exception on unsigned overflow of |
|     | PMU.PMCCNTR_EL0 disabled.         |
| 0b1 | Interrupt request or PMU          |
|     | exception on unsigned overflow of |
|     | PMU.PMCCNTR_EL0 enabled.          |

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally unknown value.

Accessing this field has the following behavior:

- When SoftwareLockStatus(), access to this field is **RO**.
- Otherwise, access to this field is W1S.

#### P < m >, bit [m], for m = 30 to 0

Interrupt request or PMU exception on unsigned overflow of <a href="PMEVCNTR<m>\_EL0">PMEVCNTR<m>\_EL0</a> enable. On writes, allows software to enable the interrupt request or PMU exception on unsigned overflow of <a href="PMEVCNTR<m>\_EL0">PMEVCNTR<m>\_EL0</a>. On reads, returns the interrupt request or PMU exception on unsigned overflow of <a href="PMEVCNTR<m>\_EL0">PMEVCNTR<m>\_EL0</a> enable status.

| P <m></m> | Meaning                                                           |
|-----------|-------------------------------------------------------------------|
| 0b0       | Interrupt request or PMU                                          |
|           | exception on unsigned overflow                                    |
|           | of <a href="mailto:PMEVCNTR&lt;m&gt;_EL0">PMEVCNTR<m>_EL0</m></a> |
|           | disabled.                                                         |
| 0b1       | Interrupt request or PMU                                          |
|           | exception on unsigned overflow                                    |
|           | of PMEVCNTR <m>_EL0</m>                                           |
|           | enabled.                                                          |

The reset behavior of this field is:

• On a Warm reset, this field resets to an architecturally unknown value.

Accessing this field has the following behavior:

- When m >= NUM\_PMU\_COUNTERS, access to this field is RAZ/WI.
- When SoftwareLockStatus(), access to this field is **RO**.
- Otherwise, access to this field is W1S.

## **Accessing PMINTENSET EL1**

#### **Note**

SoftwareLockStatus() depends on the type of access attempted and AllowExternalPMUAccess() has a new definition from Armv8.4. Refer to the Pseudocode definitions for more information.

Accesses to this register use the following encodings:

When FEAT\_PMUv3\_EXT64 is implemented, or FEAT\_PMUv3\_ICNTR is implemented or FEAT\_PMUv3p9 is implemented [63:0] Accessible at offset 0xC40 from PMU

- When DoubleLockStatus(), or !IsCorePowered(), or OSLockStatus() or !AllowExternalPMUAccess(), accesses to this register generate an error response.
- When FEAT\_PMUv3\_EXT32 is implemented and SoftwareLockStatus(), accesses to this register are RO.
- Otherwise, accesses to this register are RW.

# When FEAT\_PMUv3\_EXT32 is implemented, FEAT\_PMUv3\_ICNTR is not implemented and FEAT\_PMUv3p9 is not implemented [31:0] Accessible at offset 0xC40 from PMU

- When DoubleLockStatus(), or !IsCorePowered(), or OSLockStatus() or !AllowExternalPMUAccess(), accesses to this register generate an error response.
- When SoftwareLockStatus(), accesses to this register are **RO**.
- Otherwise, accesses to this register are **RW**.

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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