File: tasm3.pp

package info (click to toggle)
fpc 3.2.2%2Bdfsg-49
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 341,452 kB
  • sloc: pascal: 3,820,194; xml: 194,356; ansic: 9,637; asm: 8,482; java: 5,346; sh: 4,813; yacc: 3,956; makefile: 2,705; lex: 2,661; javascript: 2,454; sql: 929; php: 474; cpp: 145; perl: 136; sed: 132; csh: 34; tcl: 7
file content (27 lines) | stat: -rw-r--r-- 513 bytes parent folder | download | duplicates (10)
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
27
{ %CPU=x86_64 }
{ %opt=-vw -Sew }

// 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.