Conditional Select writes, in the destination capability register, the value of the first source capability register if the condition is TRUE, and otherwise writes the value of the second source capability register.
31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | Cm | cond | 1 | 1 | Cn | Cd |
integer d = UInt(Cd); integer n = UInt(Cn); integer m = UInt(Cm);
<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. |
<Cm> |
Is the capability name of the second source register, encoded in the "Cm" field. |
<cond> |
Is one of the standard conditions,
encoded in
cond:
|
CheckCapabilitiesEnabled(); Capability result; if ConditionHolds(cond) then result = C[n]; else result = C[m]; 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.