blob: 740880ad65576c9a84dabc6382f2c283336d8ab4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
{ %CPU=x86_64 }
// Basic test for 3-operand SIMD instructions with rip-relative operand
{$codealign varmin=16}
{$codealign constmin=16}
type
tvec=array[0..3] of longword;
var
t: tvec = ($00010203, $04050607, $08090a0b, $0c0d0e0f);
{$asmmode att}
function test: word; assembler; nostackframe;
asm
pshufd $0b11100100,t(%rip),%xmm0 // direct copy
pcmpeqd t(%rip),%xmm0
pmovmskb %xmm0,%eax
end;
begin
if test<>65535 then
Halt(1)
else
writeln('ok');
end.
|