SEAL (immediate)

Seal capability (immediate) seals a capability by setting the ObjectType of that capability to nonzero, and writes the result to the destination Capability register. An operand of rb seals for use with a register based branch, lpb for a load pair and branch and lb for a load and branch.

313029282726252423222120191817161514131211109876543210
11000010110000110form100CnCd

SEAL <Cd>, <Cn>, <form>

integer d = UInt(Cd); integer n = UInt(Cn); bits(64) f = ZeroExtend(form,64);

Assembler Symbols

<Cd>

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

<Cn>

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

<form> Is the form specifier, encoded in form:
form <form>
00 RESERVED
01 rb
10 lpb
11 lb

Operation

if f == 0 then UNDEFINED; CheckCapabilitiesEnabled(); Capability c = CapSetObjectType(C[n], f); if CapIsTagSet(C[n]) && !CapIsSealed(C[n]) then C[d] = c; else C[d] = CapWithTagClear(c);


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.