BR (memory indirect)

Unseal load and branch loads a capability and an offset, derives, unseals, and branches to the destination Capability register.

313029282726252423222120191817161514131211109876543210
110000101101imm7100Cn00000

BR [<Cn|CSP>, #<imm>]

integer n = UInt(Cn); bits(64) offset = SignExtend(imm7:'0000',64); BranchType branch_type = BranchType_INDIR;

Assembler Symbols

<Cn|CSP>

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

<imm>

Is the signed immediate byte offset, a multiple of 16 in the range -1024 to 1008, encoded in the "imm7" field.

Operation

CheckCapabilitiesEnabled(); Capability base; Capability target; if n == 31 then CheckSPAlignment(); base = CSP[]; else base = C[n]; // When C29 is used, the unsealed capability is written back to C29. if n == 29 then if CapIsTagSet(base) && CapIsSealed(base) && CapGetObjectType(base) == CAP_SEAL_TYPE_LB then base = CapUnseal(base); VirtualAddress vabase = VAFromCapability(base); bits(64) addr = VAddress(vabase) + offset; VACheckAddress(vabase,addr,CAPABILITY_DBYTES,CAP_PERM_LOAD,AccType_NORMAL); target = MemC[addr,AccType_NORMAL]; target = CapSquashPostLoadCap(target,vabase); C[29] = base; else VirtualAddress vabase = VAFromCapability(base); bits(64) addr = VAddress(vabase) + offset; VACheckAddress(vabase,addr,CAPABILITY_DBYTES,CAP_PERM_LOAD,AccType_NORMAL); target = MemC[addr,AccType_NORMAL]; target = CapSquashPostLoadCap(target,vabase); 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.