CASL

Compare and Swap capabilities in memory with release determines the base register to be used, derives an address from the base register, atomically loads a Capability register from the calculated address in memory, and performs a comparison between this first Capability register with a second Capability register. If the result of the comparison is equal, the second Capability register is atomically stored to the calculated address in memory. This instruction stores to memory with release semantics.

313029282726252423222120191817161514131211109876543210
10100010101Cs111111RnCt
LR

CASL <Cs>, <Ct>, [<Xn|SP>] // (PSTATE.C64 == '0')

CASL <Cs>, <Ct>, [<Cn|CSP>] // (PSTATE.C64 == '1')

AccType ldacctype = AccType_ATOMICRW; AccType stacctype = AccType_ORDEREDATOMICRW; integer t = UInt(Ct); integer s = UInt(Cs); integer n = UInt(Rn);

Assembler Symbols

<Cs>

Is the capability name of the register to be compared and loaded, encoded in the "Cs" field.

<Ct>

Is the capability name of the register to be conditionally stored, encoded in the "Ct" field.

<Xn|SP>

Is the 64-bit name of the general-purpose base register or stack pointer, encoded in the "Rn" field.

<Cn|CSP>

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

Operation

CheckCapabilitiesEnabled(); VirtualAddress base; Capability comparecap; Capability newcap; Capability data; comparecap = C[s]; newcap = C[t]; base = BaseReg[n]; bits(64) addr = VAddress(base); VACheckAddress(base, addr, CAPABILITY_DBYTES, CAP_PERM_LOAD, ldacctype); bits(64) cap_required = CAP_PERM_STORE; if CapIsTagSet(newcap) then cap_required = cap_required OR CAP_PERM_STORE_CAP; if CapIsLocal(newcap) then cap_required = cap_required OR CAP_PERM_STORE_LOCAL; VACheckAddress(base, addr, CAPABILITY_DBYTES, cap_required, stacctype); // Both the original VirtualAddress and 64 bit address are passed in // order to be able to squash permissions and tags correctly. C[s] = MemAtomicCompareAndSwapC(base,addr,comparecap,newcap,ldacctype,stacctype);


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.