vcmpgtsh
Vector Compare Greater Than Signed Halfword
vcmpgtsh VRT,VRA,VRB
vcmpgtsh. VRT,VRA,VRB
vcmpgtsh. VRT,VRA,VRB
Compares each halfword of two vector registers and sets the corresponding result element to all 1s if the first operand is greater than the second, otherwise all 0s.
Details
For vcmpgtsh, each halfword of VSR[VRA+32] is compared with the corresponding halfword of VSR[VRB+32]. If the signed value in VSR[VRA+32].hword[i] is greater than that in VSR[VRB+32].hword[i], then VSR[VRT+32].hword[i] is set to 0xFFFF; otherwise, it is set to 0x0000.
Pseudocode Operation
if MSR.VEC=0 then Vector_Unavailable()
all_true ←1
all_false ←1
do i = 0 to 7
src1 ←EXTS(VSR[VRA+32].hword[i])
src2 ←EXTS(VSR[VRB+32].hword[i])
if src1 > src2 then do
VSR[VRT+32].hword[i] ←0xFFFF
all_false ←0
end
else do
VSR[VRT+32].hword[i] ←0x0000
all_true ←0
end
end
if Rc=1 then
CR.field[6] ←all_true || 0b0 || all_false || 0b0
Programming Note
When Rc=1, CR1 is set from the FPSCR[FX, FEX, VX, OX] bits immediately after the operation completes.
Example
vcmpgtsh v1, v2, v3
Encoding
Binary Layout
0
4
VRT
6
VRA
11
VRB
16
Rc
21
Operands
-
vD
Target -
vA
Src A -
vB
Src B -
VRT
Target Vector Register -
VRA
Source Vector Register -
VRB
Source Vector Register