# PMCEID0\_EL0, Performance Monitors Common Event Identification Register 0

The PMCEID0 EL0 characteristics are:

### **Purpose**

Defines which Common architectural events and Common microarchitectural events are implemented, or counted, using PMU events in the ranges 0x0000 to 0x001F and 0x4000 to 0x401F.

For more information about the Common events and the use of the PMCEID<n>\_EL0 registers see 'The PMU event number space and common events'.

# **Configuration**

AArch64 System register PMCEID0\_EL0 bits [31:0] are architecturally mapped to AArch32 System register PMCEID0[31:0].

AArch64 System register PMCEID0\_EL0 bits [63:32] are architecturally mapped to AArch32 System register PMCEID2[31:0].

AArch64 System register PMCEID0\_EL0 bits [31:0] are architecturally mapped to External register PMU.PMCEID0[31:0].

AArch64 System register PMCEID0\_EL0 bits [63:32] are architecturally mapped to External register PMU.PMCEID2[31:0].

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

### **Attributes**

PMCEID0 EL0 is a 64-bit register.

# Field descriptions

| 63     | 62     | 61     | 60     | 59     | 58     | 57     | 56     | 55     | 54     | 53     | 52     | 51     | 50     | 49     |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| IDhi31 | IDhi30 | IDhi29 | IDhi28 | IDhi27 | IDhi26 | IDhi25 | IDhi24 | IDhi23 | IDhi22 | IDhi21 | IDhi20 | IDhi19 | IDhi18 | IDhi17 |
| ID31   | ID30   | ID29   | ID28   | ID27   | ID26   | ID25   | ID24   | ID23   | ID22   | ID21   | ID20   | ID19   | ID18   | ID17   |
| 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     |

### IDhi<n>, bit [n+32], for n = 31 to 0 When FEAT PMUv3p1 is implemented:

IDhi[n] corresponds to Common event (0x4000 + n).

For each bit:

| IDhi <n></n> | Meaning                      |
|--------------|------------------------------|
| 0b0          | The Common event is not      |
|              | implemented, or not counted. |
| 0b1          | The Common event is          |
|              | implemented.                 |

When the value of a bit in the field is 1, the corresponding Common event is implemented and counted.

#### **Note**

Arm recommends that if a Common event is never counted, the value of the corresponding bit is 0.

A bit that corresponds to a reserved event number is reserved. The value might be used in a future revision of the architecture to identify an additional Common event.

#### **Note**

Such an event might be added retrospectively to an earlier version of the PMU architecture, provided the event does not require any additional PMU features and has an event number that can be represented in the PMCEID<n>\_EL0 registers of that earlier version of the PMU architecture.

#### Otherwise:

Reserved, res0.

### ID < n >, bit [n], for n = 31 to 0

ID[n] corresponds to Common event n.

For each bit:

| ID <n></n> | Meaning |  |
|------------|---------|--|
|            |         |  |

| 0b0 | The Common event is not      |
|-----|------------------------------|
|     | implemented, or not counted. |
| 0b1 | The Common event is          |
|     | implemented.                 |

When the value of a bit in the field is 1, the corresponding Common event is implemented and counted.

#### **Note**

Arm recommends that if a Common event is never counted, the value of the corresponding bit is 0.

A bit that corresponds to a reserved event number is reserved. The value might be used in a future revision of the architecture to identify an additional Common event.

#### Note

Such an event might be added retrospectively to an earlier version of the PMU architecture, provided the event does not require any additional PMU features and has an event number that can be represented in the PMCEID<n>\_EL0 registers of that earlier version of the PMU architecture.

## **Accessing PMCEID0 EL0**

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

# MRS <Xt>, PMCEID0\_EL0

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b011 | 0b1001 | 0b1100 | 0b110 |

```
AArch64.SystemAccessTrap(EL2, 0x18);
        else
            AArch64.SystemAccessTrap(EL1, 0x18);
    elsif EL2Enabled() && HCR_EL2.<E2H,TGE> != '11'
&& IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3)
| SCR_EL3.FGTEn == '1') && HDFGRTR_EL2.PMCEIDn_EL0
== '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);
    else
        X[t, 64] = PMCEIDO_ELO;
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.PMCEIDn_EL0 ==
'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] = PMCEID0_EL0;
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
        X[t, 64] = PMCEID0_EL0;
elsif PSTATE.EL == EL3 then
    X[t, 64] = PMCEID0_EL0;
```

|   | 28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d9                                                  |     |
|---|------------------------------------------------------------------------------------------------------------|-----|
| С | opyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. Th<br>document is Non-Confidentia | is  |
|   | document is ivon-confidentic                                                                               | 11. |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |