AArch64
Instructions

Index by Encoding

External Registers

# PMINTENSET\_EL1, Performance Monitors Interrupt Enable Set Register

The PMINTENSET EL1 characteristics are:

## **Purpose**

Enables the generation of interrupt requests or, when FEAT\_EBEP is implemented, PMU exceptions on overflows from the instruction counter, <a href="MICNTR\_EL0">PMICNTR\_EL0</a>, the cycle counter, <a href="MICNTR\_EL0">PMCCNTR\_EL0</a>, and the event counters <a href="MICNTR<">PMEVCNTR<<<a href="MICNTR\_EL0">PMEVCNTR<<<a href="MICNTR\_EL0">PMEVCNTR\_EL0</a>. Reading the register shows which overflow interrupt requests or PMU exceptions are enabled.

## **Configuration**

AArch64 System register PMINTENSET\_EL1 bits [31:0] are architecturally mapped to AArch32 System register <a href="MINTENSET[31:0]">PMINTENSET[31:0]</a>.

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

AArch64 System register PMINTENSET\_EL1 bits [63:32] are architecturally mapped to External register <a href="MU.PMINTENSET\_EL1[63:32">PMU.PMINTENSET\_EL1[63:32]</a> when FEAT\_PMUv3p9 is implemented or FEAT PMUv3 EXT64 is implemented.

This register is present only when FEAT\_PMUv3 is implemented. Otherwise, direct accesses to PMINTENSET EL1 are undefined.

### **Attributes**

PMINTENSET\_EL1 is a 64-bit register.

## Field descriptions

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.

### F<m>, bit [m+32], for m = 0 When FEAT\_PMUv3\_ICNTR is implemented:

Interrupt request or PMU exception on unsigned overflow of fixed-function counter <m> enable. On writes, allows software to enable the interrupt request or PMU exception on unsigned overflow of fixed-function counter <m>. On reads, returns the interrupt request or PMU exception on unsigned overflow of fixed-function counter <m> enable status.

| F <m></m> | Meaning                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------|
| 0b0       | Interrupt request or PMU exception on unsigned overflow of fixed-function counter <m> disabled.</m> |
| 0b1       | Interrupt request or PMU exception on unsigned overflow of fixed-function counter <m> enabled.</m>  |

PMINTENSET EL1.F0 holds the enable status for **PMICNTR EL0**.

Accessing this field has the following behavior:

- This field reads-as-zero if all of the following are true:
  - Any of the following are true:
    - EL3 is implemented and SCR EL3.FGTEn2 == 0.
    - HDFGRTR2 EL2.nPMICFILTR EL0 == 0.
  - FEAT FGT2 is implemented.
  - EL2 is implemented and enabled in the current Security state.
  - Accessed at EL1.
- This field reads-as-zero and ignores writes if any of the following are true:
  - All of the following are true:
    - EL3 is implemented.
    - MDCR EL3.EnPM2 == 0.
    - Accessed at EL2 or EL1.
- This field ignores writes if any of the following are true:
  - All of the following are true:
    - EL3 is implemented and <u>SCR\_EL3</u>.FGTEn2 == 0, or <u>HDFGWTR2\_EL2</u>.nPMICFILTR\_EL0 == 0.
    - FEAT FGT2 is implemented.
    - EL2 is implemented and enabled in the current Security state.
    - Accessed at EL1.
- Otherwise access to this field is W1S.

The reset behavior of this field is:

• On a Warm reset, this field resets to 0.

#### Otherwise:

Reserved, res0.

### C, bit [31]

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

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

Access to this field is W1S.

The reset behavior of this field is:

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

### 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.                       |

Accessing this field has the following behavior:

- This field reads-as-zero and ignores writes if any of the following are true:
  - All of the following are true:
    - EL2 is implemented and enabled in the current Security state.
    - $m \ge UInt(MDCR EL2.HPMN)$ .
    - Accessed at EL1.
  - $\circ$  m >= UInt(<u>PMCR EL0</u>.N).
- Otherwise access to this field is W1S.

The reset behavior of this field is:

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

## Accessing PMINTENSET\_EL1

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, PMINTENSET\_EL1

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1001 | 0b1110 | 0b001 |

```
if PSTATE.EL == ELO then
   UNDEFINED:
elsif PSTATE.EL == EL1 then
   if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && MDCR EL3.TPM == '1' then
        UNDEFINED;
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3)
SCR_EL3.FGTEn == '1') && HDFGRTR_EL2.PMINTEN == '1'
then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && MDCR_EL2.TPM == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && MDCR_EL3.TPM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
        X[t, 64] = PMINTENSET\_EL1;
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
```

# MSR PMINTENSET EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b000 | 0b1001 | 0b1110 | 0b001 |

```
if PSTATE.EL == ELO then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && MDCR EL3.TPM == '1' then
        UNDEFINED;
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) | |
SCR_EL3.FGTEn == '1') && HDFGWTR_EL2.PMINTEN == '1'
then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() && MDCR_EL2.TPM == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && MDCR_EL3.TPM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
        PMINTENSET_EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && MDCR_EL3.TPM == '1' then
        UNDEFINED;
    elsif HaveEL(EL3) && MDCR_EL3.TPM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        PMINTENSET_EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    PMINTENSET_EL1 = X[t, 64];
```

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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