# LOREA\_EL1, LORegion End Address (EL1)

The LOREA EL1 characteristics are:

## **Purpose**

Holds the physical address of the end of the LORegion described in the current LORegion descriptor selected by LORC EL1.DS.

## Configuration

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

This register is res0 if any of the following apply:

- No LORegion descriptors are supported by the PE.
- LORC EL1.DS points to a LORegion that is not supported by the PE.

### **Attributes**

LOREA\_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 4 | 2 41 | 40   | 39         | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
|-------------------------|-------------------|-------|----------|---------|------|------|------------|----|----|----|----|----|----|----|
| RES0                    | EA[55:52] EA[51   | 1:48] | ·        |         | E/   | \[4] | 7:1        | 6] |    |    |    |    |    |    |
| EA[4                    | 7:16]             |       | ,        |         |      | RE   | <b>S</b> 0 |    |    |    |    |    |    |    |
| 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 | 17 16 | 15 14 13 | 12 11 1 | .0 9 | 8    | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

Any of the fields in this register are permitted to be cached in a TLB.

### Bits [63:56]

Reserved, res0.

### EA[55:52], bits [55:52] When FEAT\_D128 is implemented:

Extension to EA[47:16]. For more information, see EA[47:16].

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

### EA[51:48], bits [51:48] When FEAT\_LPA is implemented:

Extension to EA[47:16]. For more information, see EA[47:16].

The reset behavior of this field is:

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

#### Otherwise:

Reserved, res0.

#### **EA**[47:16], bits [47:16]

Bits [47:16] of the end physical address of an LORegion described in the current LORegion descriptor selected by <u>LORC\_EL1</u>.DS. Bits[15:0] of this address are <code>0xffff</code>. For implementations with fewer than 48 bits, the upper bits of this field are res0.

When FEAT\_LPA is implemented and 52-bit addresses are in use, EA[51:48] form bits [51:48] of the end physical address of the LORegion. Otherwise, when 52-bit addresses are not in use, EA[51:48] is res0.

The reset behavior of this field is:

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

#### Bits [15:0]

Reserved, res0.

## Accessing LOREA\_EL1

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

| op0 op1 | CRn | CRm | op2 |
|---------|-----|-----|-----|
|---------|-----|-----|-----|

0b11 | 0b000 | 0b1010 | 0b0100 | 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'" && SCR EL3.TLOR == '1' then
        UNDEFINED;
    elsif SCR EL3.NS == '0' then
        UNDEFINED;
    elsif EL2Enabled() && HCR EL2.TLOR == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) | |
SCR_EL3.FGTEn == '1') && HFGRTR_EL2.LOREA_EL1 == '1'
then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && SCR_EL3.TLOR == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
        X[t, 64] = LOREA\_EL1;
elsif PSTATE.EL == EL2 then
    if SCR_EL3.NS == '0' then
        UNDEFINED;
    elsif Halted() && HaveEL(EL3) && EDSCR.SDD ==
'1' && boolean IMPLEMENTATION DEFINED "EL3 trap
priority when SDD == '1'" && SCR_EL3.TLOR == '1' then
        UNDEFINED;
    elsif HaveEL(EL3) && SCR_EL3.TLOR == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = LOREA\_EL1;
elsif PSTATE.EL == EL3 then
    if SCR_EL3.NS == '0' then
        UNDEFINED;
    else
        X[t, 64] = LOREA\_EL1;
```

## MSR LOREA EL1, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |  |  |
|------|-------|--------|--------|-------|--|--|
| 0b11 | 0b000 | 0b1010 | 0b0100 | 0b001 |  |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
```

```
elsif PSTATE.EL == EL1 then
    if Halted() && HaveEL(EL3) && EDSCR.SDD == '1'
&& boolean IMPLEMENTATION_DEFINED "EL3 trap priority
when SDD == '1'" && SCR_EL3.TLOR == '1' then
        UNDEFINED;
    elsif SCR_EL3.NS == '0' then
        UNDEFINED;
    elsif EL2Enabled() && HCR_EL2.TLOR == '1' then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif EL2Enabled() &&
IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) | |
SCR EL3.FGTEn == '1') && HFGWTR EL2.LOREA EL1 == '1'
then
        AArch64.SystemAccessTrap(EL2, 0x18);
    elsif HaveEL(EL3) && SCR_EL3.TLOR == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        LOREA EL1 = X[t, 64];
elsif PSTATE.EL == EL2 then
    if SCR EL3.NS == '0' then
        UNDEFINED;
    elsif Halted() && HaveEL(EL3) && EDSCR.SDD ==
'1' && boolean IMPLEMENTATION_DEFINED "EL3 trap
priority when SDD == '1'" && SCR_EL3.TLOR == '1' then
        UNDEFINED:
    elsif HaveEL(EL3) && SCR EL3.TLOR == '1' then
        if Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        LOREA EL1 = X[t, 64];
elsif PSTATE.EL == EL3 then
    if SCR EL3.NS == '0' then
        UNDEFINED;
    else
        LOREA\_EL1 = 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.