CSEAL

Conditionally Seal capability seals a capability using a sealing capability if the ObjectType extracted from the Value field of the sealing capability allows this operation. This is intended to be used with BUILD.

313029282726252423222120191817161514131211109876543210
11000010110Cm010001CnCd
opc<1>opc<0>

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

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

Assembler Symbols

<Cd|CSP>

Is the capability name of the destination register or stack pointer, 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 sealingcap = if m == 31 then CSP[] else C[m]; bits(64) otype = CapGetValue(sealingcap); Capability result = operand1; if otype == CAP_NO_SEALING then PSTATE.<N,Z,C,V> = '0001'; elsif CapIsTagSet(operand1) && CapIsTagSet(sealingcap) && !CapIsSealed(operand1) && !CapIsSealed(sealingcap) && CapCheckPermissions(sealingcap, CAP_PERM_SEAL) && CapIsInBounds(sealingcap) && UInt(otype) <= CAP_MAX_OBJECT_TYPE then result = CapSetObjectType(operand1,otype); PSTATE.<N,Z,C,V> = '0001'; else PSTATE.<N,Z,C,V> = '0000'; if d == 31 then CSP[] = result; else 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.