LDPBR

Load Pair of capabilities and Branch calculates an address from the source Capability register, loads from memory two capabilities, a target capability and a data capability. The instruction writes the data capability to the destination Capability register and branches to the target capability.

313029282726252423222120191817161514131211109876543210
1100001011000100000100CnCt
opc<1>opc<0>

LDPBR <Ct>, [<Cn|CSP>]

integer t = UInt(Ct); integer n = UInt(Cn); BranchType branch_type = BranchType_INDIR;

Assembler Symbols

<Ct>

Is the capability name of the transfer register, encoded in the "Ct" field.

<Cn|CSP>

Is the capability name of the base register or stack pointer, encoded in the "Cn" field.

Operation

CheckCapabilitiesEnabled(); Capability base; Capability data; Capability target; if n == 31 then CheckSPAlignment(); base = CSP[]; else base = C[n]; if t == 29 then if CapIsTagSet(base) && CapIsSealed(base) && CapGetObjectType(base) == CAP_SEAL_TYPE_LPB then base = CapUnseal(base); VirtualAddress vabase = VAFromCapability(base); bits(64) addr = VAddress(vabase); VACheckAddress(vabase, addr, CAPABILITY_DBYTES*2, CAP_PERM_LOAD, AccType_NORMAL); data = MemC[addr, AccType_NORMAL]; target = MemC[addr + CAPABILITY_DBYTES, AccType_NORMAL]; data = CapSquashPostLoadCap(data, vabase); target = CapSquashPostLoadCap(target, vabase); C[29] = data; else VirtualAddress vabase = VAFromCapability(base); bits(64) addr = VAddress(vabase); VACheckAddress(vabase, addr, CAPABILITY_DBYTES*2, CAP_PERM_LOAD, AccType_NORMAL); data = MemC[addr, AccType_NORMAL]; target = MemC[addr + CAPABILITY_DBYTES, AccType_NORMAL]; data = CapSquashPostLoadCap(data, vabase); target = CapSquashPostLoadCap(target, vabase); C[t] = data; if !IsInRestricted() && !CapCheckPermissions(target, CAP_PERM_EXECUTIVE) then target = CapWithTagClear(target); if CapIsTagSet(target) && CapIsSealed(target) && CapGetObjectType(target) == CAP_SEAL_TYPE_RB then target = CapUnseal(target); BranchXToCapability(target, branch_type);


Internal version only: isa v32.13, AdvSIMD v29.04, pseudocode morello-2022-01_rc2, capabilities morello-2022-01_rc2 ; Build timestamp: 2022-01-11T11:23

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