# **GPTBR\_EL3, Granule Protection Table Base Register**

The GPTBR EL3 characteristics are:

## **Purpose**

The control register for Granule Protection Table base address.

## **Configuration**

This register is present only when FEAT\_RME is implemented. Otherwise, direct accesses to GPTBR EL3 are undefined.

#### **Attributes**

GPTBR 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 3 | 4 3 | 33 : | 32 |
|-------------------------------------------------------------------------|-------|----|-------|------|-----|------|----|
| RES0                                                                    |       |    | BADDR |      |     |      |    |
| BADDR                                                                   |       |    |       |      |     |      |    |
| 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 6   | 5  | 4     | 3    | 2   | 1    | 0  |

#### Bits [63:40]

Reserved, res0.

#### **BADDR**, bits [39:0]

Base address for the level 0 GPT.

This field represents bits [51:12] of the level 0 GPT base address.

The level 0 GPT is aligned in memory to the greater of:

- The size of the level 0 GPT in bytes.
- 4KB.

Bits [x:0] of the base address are treated as zero, where:

- x = Max(pps l0gptsz + 2, 11)
- pps is derived from GPCCR EL3.PPS as follows:

| GPCCR_EL3.PPS | pps |
|---------------|-----|
| 0b000         | 32  |
| 0b001         | 36  |
| 0b010         | 40  |
| 0b011         | 42  |
| 0b100         | 44  |
| 0b101         | 48  |
| 0b110         | 52  |

• l0gptsz is derived from GPCCR EL3.L0GPTSZ as follows:

| GPCCR_EL3.L0GPTSZ | l0gptsz |
|-------------------|---------|
| 000000            | 30      |
| 0b0100            | 34      |
| 0b0110            | 36      |
| 0b1001            | 39      |

If x is greater than 11, then BADDR[x - 12:0] are res0.

The reset behavior of this field is:

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

## **Accessing GPTBR EL3**

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

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b11 | 0b110 | 0b0010 | 0b0001 | 0b100 |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    UNDEFINED;
elsif PSTATE.EL == EL2 then
    UNDEFINED;
elsif PSTATE.EL == EL3 then
    X[t, 64] = GPTBR_EL3;
```

## MSR GPTBR\_EL3, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |  |
|------|-------|--------|--------|-------|--|
| 0b11 | 0b110 | 0b0010 | 0b0001 | 0b100 |  |

```
if PSTATE.EL == EL0 then
    UNDEFINED;
elsif PSTATE.EL == EL1 then
    UNDEFINED;
elsif PSTATE.EL == EL2 then
    UNDEFINED;
elsif PSTATE.EL == EL3 then
    GPTBR_EL3 = X[t, 64];
```

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsEncodingRegisters

28/03/2023 16:01; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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