CHKSSU

Check Subset, setting flags and conditionally unseal checks if a capability is a subset of a testing capability. If the capability is a valid sealed capability, and the testing capability is a valid unsealed capability, the operation unseals the capability and writes it to the destination Capability register. The instruction updates the condition flags based on the result.

313029282726252423222120191817161514131211109876543210
11000010110Cm100010CnCd
opc

CHKSSU <Cd>, <Cn|CSP>, <Cm|CSP>

integer d = UInt(Cd); integer n = UInt(Cn); integer m = UInt(Cm);

Assembler Symbols

<Cd>

Is the capability name of the destination register, encoded in the "Cd" field.

<Cn|CSP>

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

<Cm|CSP>

Is the capability name of the second source register or stack pointer, encoded in the "Cm" field.

Operation

CheckCapabilitiesEnabled(); Capability operand1 = if n == 31 then CSP[] else C[n]; Capability testingcap = if m == 31 then CSP[] else C[m]; Capability result = operand1; if CapIsSubSetOf(operand1,testingcap) && CapGetTag(operand1) == CapGetTag(testingcap) then if CapIsTagSet(testingcap) && !CapIsSealed(testingcap) && CapIsTagSet(operand1) && CapIsSealed(operand1) then result = CapUnseal(operand1); PSTATE.<N,Z,C,V> = '1000'; else PSTATE.<N,Z,C,V> = '0000'; C[d] = result;


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.