# SPMDEVARCH\_EL1, System Performance Monitors Device Architecture Register

The SPMDEVARCH EL1 characteristics are:

# **Purpose**

Provides discovery information for System PMU <s>.

# **Configuration**

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

### **Attributes**

SPMDEVARCH 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         | 35 | 343 | 33. | 32 |
|----------------------------------|---------|-------------|-------------|----------|-------|-------|------------|----|-----|-----|----|
| RES0                             |         |             |             |          |       |       |            |    |     |     |    |
| ARCHITECT                        | PRESENT | REVISION    | ARCHVER     |          | AR    | CHPA  | <b>ART</b> | •  |     |     |    |
| 31 30 29 28 27 26 25 24 23 22 21 | 20      | 19 18 17 16 | 15 14 13 12 | 1110 9   | 8 7   | 6 5   | 4          | 3  | 2   | 1   | 0  |

#### Bits [63:32]

Reserved, res0.

#### **ARCHITECT, bits [31:21]**

Architect. Defines the architect of the component. Bits [31:28] are the JEP106 continuation code (JEP106 bank ID, minus 1) and bits [27:21] are the JEP106 ID code.

This field has an implementation defined value.

Access to this field is **RO**.

### PRESENT, bit [20]

DEVARCH present. Defines that SPMDEVARCH\_EL1 register is present.

| PRESENT | Meaning |  |
|---------|---------|--|
|---------|---------|--|

| 0b0 | Device Architecture      |
|-----|--------------------------|
|     | information not present. |
| 0b1 | Device Architecture      |
|     | information present.     |

If SPMDEVARCH EL1 is not present, the register is res0.

### REVISION, bits [19:16]

Revision. Defines the architecture revision of the component.

This field has an implementation defined value.

Access to this field is **RO**.

### ARCHVER, bits [15:12]

Architecture Version. Defines the architecture version of the component.

SPMDEVARCH\_EL1.ARCHVER and SPMDEVARCH\_EL1.ARCHPART are also defined as a single field, SPMDEVARCH\_EL1.ARCHID, so that SPMDEVARCH\_EL1.ARCHVER is SPMDEVARCH\_EL1.ARCHID[15:12].

This field has an implementation defined value.

Access to this field is **RO**.

#### ARCHPART, bits [11:0]

Architecture Part. Defines the architecture of the component.

SPMDEVARCH\_EL1.ARCHVER and SPMDEVARCH\_EL1.ARCHPART are also defined as a single field, SPMDEVARCH\_EL1.ARCHID, so that SPMDEVARCH\_EL1.ARCHPART is SPMDEVARCH\_EL1.ARCHID[11:0].

This field has an implementation defined value.

Access to this field is **RO**.

# **Accessing SPMDEVARCH\_EL1**

To access SPMDEVARCH\_EL1 for System PMU <s>, set <a href="SPMSELR EL0">SPMSELR EL0</a>. SYSPMUSEL to s.

SPMDEVARCH\_EL1 reads-as-zero if the System PMU selected by <a href="mailto:SPMSELR\_EL0">SPMSELR\_EL0</a>. SYSPMUSEL is not implemented.

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

# MRS <Xt>, SPMDEVARCH EL1

| op0  | op1   | op1 CRn |        | op2   |  |
|------|-------|---------|--------|-------|--|
| 0b10 | 0b000 | 0b1001  | 0b1101 | 0b101 |  |

```
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.EnPM2 == '0' then
        UNDEFINED;
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT2) && HaveEL(EL3) &&
SCR EL3.FGTEn2 == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT2) &&
HDFGRTR2_EL2.nSPMID == '0' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && MDCR_EL3.EnPM2 == '0' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] =
SPMDEVARCH_EL1[UInt(SPMSELR_EL0.SYSPMUSEL)];
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && MDCR_EL3.EnPM2 == '0' then
        UNDEFINED;
    elsif HaveEL(EL3) && MDCR_EL3.EnPM2 == '0' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] =
SPMDEVARCH_EL1[UInt(SPMSELR_EL0.SYSPMUSEL)];
elsif PSTATE.EL == EL3 then
    X[t, 64] =
SPMDEVARCH_EL1[UInt(SPMSELR_EL0.SYSPMUSEL)];
```

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64
Instructions

Index by Encoding

External Registers

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