← Home

GPTBR_EL3

Granule Protection Table Base Register

The control register for Granule Protection Table base address.

Configuration

This register is present only when FEAT_RME is implemented and FEAT_AA64 is implemented. Otherwise, direct accesses to GPTBR_EL3 are UNDEFINED.

Attributes

GPTBR_EL3 is a 64-bit register.

Field descriptions

6362616059585756555453525150494847464544434241403938373635343332
313029282726252423222120191817161514131211109876543210
RES0BADDR[43:40]BADDR
BADDR

Bits [63:44]:

Reserved, RES0.

BADDR[43:40], bits [43:40] when FEAT_RME_GPC3 is implemented:

Extension to BADDR[39:0]. This field represents bit [55:52] of the level 0 GPT base address.

The reset behavior of this field is:

Otherwise:

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:

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

GPCCR_EL3.PPSpps
0b00032
0b00136
0b01040
0b01142
0b10044
0b10148
0b11052
GPCCR_EL3.L0GPTSZl0gptsz
0b000030
0b010034
0b011036
0b100139

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

The reset behavior of this field is:

Access Instructions

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

MRS <Xt>, GPTBR_EL3

(op0 = 0b11, op1 = 0b110, CRn = 0b0010, CRm = 0b0001, op2 = 0b100)

if !(IsFeatureImplemented(FEAT_RME) && IsFeatureImplemented(FEAT_AA64)) then UNDEFINED; elsif 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 = 0b11, op1 = 0b110, CRn = 0b0010, CRm = 0b0001, op2 = 0b100)

if !(IsFeatureImplemented(FEAT_RME) && IsFeatureImplemented(FEAT_AA64)) then UNDEFINED; elsif PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then UNDEFINED; elsif PSTATE.EL == EL2 then UNDEFINED; elsif PSTATE.EL == EL3 then if IsFeatureImplemented(FEAT_FGWTE3) && FGWTE3_EL3.GPTBR_EL3 == '1' then AArch64.SystemAccessTrap(EL3, 0x18); else GPTBR_EL3 = X[t, 64];


Version 2025.09 — Copyright © 2010-2025 Arm Limited or its affiliates.

This site is provided as a community resource and is NOT affiliated with nor endorsed by Arm Limited.