CLRPERM (immediate)

Clear capability permissions (immediate) clears the Capability Permissions of the source capability based on an immediate value and writes the result to the destination Capability register.

313029282726252423222120191817161514131211109876543210
1100001011000110perm100CnCd

CLRPERM <Cd|CSP>, <Cn|CSP>, <perm>

integer n = UInt(Cn); integer d = UInt(Cd); bits(3) imm = perm;

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 source register or stack pointer, encoded in the "Cn" field.

<perm> Is the perm specifier, encoded in perm:
perm <perm>
000 #0
001 X
010 W
011 WX
100 R
101 RX
110 RW
111 RWX

Operation

CheckCapabilitiesEnabled(); Capability data = if n == 31 then CSP[] else C[n]; Capability result; bits(64) clr_perms = Zeros(64); if imm<0> == '1' then clr_perms = clr_perms OR CAP_PERM_EXECUTE; if imm<1> == '1' then clr_perms = clr_perms OR CAP_PERM_STORE; if imm<2> == '1' then clr_perms = clr_perms OR CAP_PERM_LOAD; result = CapClearPerms(data, clr_perms); if CapIsSealed(data) then result = CapWithTagClear(result); 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.