CHKSS

Check Subset, setting flags checks if a capability is a subset of a testing capability. The instruction updates the condition flags based on the result.

313029282726252423222120191817161514131211109876543210
11000010110Cm100001Cn00001
opc<1>opc<0>

CHKSS <Cn|CSP>, <Cm|CSP>

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

Assembler Symbols

<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]; if CapIsSubSetOf(operand1,testingcap) && CapGetTag(operand1) == CapGetTag(testingcap) then PSTATE.<N,Z,C,V> = '1000'; else PSTATE.<N,Z,C,V> = '0000';


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.