CVT (to pointer)

Convert capability to pointer, setting flags derives an address from the source Capability registers and writes the result to the destination register. The instruction updates the condition flags based on the result.

313029282726252423222120191817161514131211109876543210
11000010110Cm110000CnRd

CVT <Xd>, <Cn|CSP>, <Cm>

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

Assembler Symbols

<Xd>

Is the 64-bit name of the destination general-purpose register, encoded in the "Rd" field.

<Cn|CSP>

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

<Cm>

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

Operation

CheckCapabilitiesEnabled(); Capability operand1 = if n == 31 then CSP[] else C[n]; Capability operand2 = C[m]; bits(64) result; if CapIsTagSet(operand1) then if CCTLR[].DDCBO == '1' then result = CapGetValue(operand1) - CapGetBase(operand2); else result = CapGetValue(operand1); if result == 0 then PSTATE.<N,Z,C,V> = '0110'; else PSTATE.<N,Z,C,V> = '0010'; else result = Zeros(64); PSTATE.<N,Z,C,V> = '0000'; X[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.