# SP\_EL3, Stack Pointer (EL3)

The SP EL3 characteristics are:

### **Purpose**

Holds the stack pointer associated with EL3. When executing at EL3, the value of <u>SPSel</u>.SP determines the current stack pointer:

| SPSel.SP | Current stack pointer |
|----------|-----------------------|
| 0b0      | SP_ELO                |
| 0b1      | SP_EL3                |

### **Configuration**

This register is present only when EL3 is implemented. Otherwise, direct accesses to SP EL3 are undefined.

#### **Attributes**

SP EL3 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

| Stack pointer                                                       |     |     |   |   |   |   |   |   |
|---------------------------------------------------------------------|-----|-----|---|---|---|---|---|---|
| Stack pointer                                                       |     |     |   |   |   |   |   |   |
| 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 | 7 6 | 5 | 4 | 3 | 2 | 1 | 0 |

31302320272023242322212013101710131413121110 3 0 7 0 3 4 3 2 1

#### Bits [63:0]

Stack pointer.

The reset behavior of this field is:

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

## **Accessing SP\_EL3**

This register is not accessible using MRS and MSR instructions.

When the value of <u>SPSel</u>.SP is 1, this register is accessible at EL3 as the current stack pointer.

#### Note

When the value of <u>SPSel</u>.SP is 0, <u>SP\_EL0</u> is used as the current stack pointer at all Exception levels.

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64 Instructions

Index by Encoding

External Registers

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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