# AMUSERENR\_ELO, Activity Monitors User Enable Register

The AMUSERENR EL0 characteristics are:

## **Purpose**

Global user enable register for the activity monitors. Enables or disables ELO access to the activity monitors. AMUSERENR\_ELO is applicable to both the architected and the auxiliary counter groups.

## **Configuration**

AArch64 System register AMUSERENR\_EL0 bits [31:0] are architecturally mapped to AArch32 System register <u>AMUSERENR[31:0]</u>.

This register is present only when FEAT\_AMUv1 is implemented. Otherwise, direct accesses to AMUSERENR\_EL0 are undefined.

### **Attributes**

AMUSERENR EL0 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 34 33 32

RESO

RESO

BI 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

#### Bits [63:1]

Reserved, res0.

#### **EN, bit [0]**

Traps EL0 accesses to the activity monitors registers to EL1, or to EL2 when it is implemented and enabled for the current Security state and <u>HCR\_EL2</u>.TGE is 1, as follows:

- In AArch64 state, accesses to the following registers are trapped, reported using EC syndrome value 0x18:
  - AMCFGR\_EL0, AMCGCR\_EL0, AMCNTENCLR0\_EL0, AMCNTENCLR1\_EL0, AMCNTENSET0\_EL0, AMCNTENSET1\_EL0, AMCR\_EL0,

### <u>AMEVCNTR0<n>\_EL0</u>, <u>AMEVCNTR1<n>\_EL0</u>, <u>AMEVTYPER0<n>\_EL0</u>, <u>and</u> <u>AMEVTYPER1<n>\_EL0</u>.

- In AArch32 state, MRC and MCR accesses to the following registers are trapped and reported using EC syndrome value 0x03, MRRC and MCRR accesses are trapped and reported using EC syndrome value 0x04:
  - AMCFGR, AMCGCR, AMCNTENCLRO, AMCNTENCLR1, AMCNTENSETO, AMCNTENSET1, AMCR, AMEVCNTRO<n>, AMEVCNTR1<n>, AMEVTYPERO<n>, and AMEVTYPER1<n>.

| EN  | Meaning                          |
|-----|----------------------------------|
| 0d0 | EL0 accesses to the activity     |
|     | monitors registers are trapped.  |
| 0b1 | This control does not cause any  |
|     | instructions to be trapped.      |
|     | Software can access all activity |
|     | monitor registers at EL0.        |

#### Note

 AMUSERENR\_EL0 can always be read at EL0 and is not governed by this bit.

The reset behavior of this field is:

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

## **Accessing AMUSERENR ELO**

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

# MRS <Xt>, AMUSERENR\_EL0

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b011 | 0b1101 | 0b0010 | 0b011 |

```
elsif HaveEL(EL3) && CPTR EL3.TAM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = AMUSERENR ELO;
elsif PSTATE.EL == EL1 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR_EL3.TAM == '1' then
        UNDEFINED;
    elsif EL2Enabled() && CPTR EL2.TAM == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && CPTR_EL3.TAM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = AMUSERENR ELO;
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR_EL3.TAM == '1' then
        UNDEFINED;
    elsif HaveEL(EL3) && CPTR EL3.TAM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = AMUSERENR\_EL0;
elsif PSTATE.EL == EL3 then
    X[t, 64] = AMUSERENR ELO;
```

## MSR AMUSERENR\_EL0, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b011 | 0b1101 | 0b0010 | 0b011 |

```
else
            AArch64.SystemAccessTrap(EL3, 0x18);
        AMUSERENR\_EL0 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && CPTR_EL3.TAM == '1' then
        UNDEFINED;
    elsif HaveEL(EL3) && CPTR EL3.TAM == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        AMUSERENR\_EL0 = X[t, 64];
elsif PSTATE.EL == EL3 then
    AMUSERENR_ELO = X[t, 64];
```

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64 Instructions

Index by Encoding

External Registers

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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