aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/powerpc/vsx-13.c
blob: 5b4eb68068fa4d6423b81e2d8f6644a0b68c1bd9 (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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/* { dg-do compile { target powerpc*-*-* } } */
/* { dg-require-effective-target powerpc_vsx_ok } */
/* { dg-options "-mvsx" } */

/* Variations of tests that require VSX support.  This is a variation of
   the altivec-13.c testcase.  */

#include <altivec.h>

void foo (void)
{

  vector signed char vsc1, vsc2, vscz;
  vector unsigned char vuc1, vuc2, vucz;
  vector bool long long vubll1, vubll2, vubllz;
  vector signed int long long vsill1, vsill2, vsillz;
  vector unsigned int long long vuill1, vuill2, vuillz;
  vector double vd1, vd2, vdz;

  vubllz = vec_sld( vubll1, vubll2, 1 );
  vsillz = vec_sld( vsill1, vsill2, 1 );
  vuillz = vec_sld( vuill1, vuill2, 1 );

  vsillz = vec_srl(vsill1, vuc2);
  vuillz = vec_srl(vuill1, vuc2);

  vsillz = vec_sro(vsill1, vsc2);
  vsillz = vec_sro(vsill1, vuc2);
  vuillz = vec_sro(vuill1, vsc2);
  vuillz = vec_sro(vuill1, vuc2);

  vdz = vec_sld( vd1, vd2, 1 );
}

/* Expected results:
   vec_sld          vsldoi
   vec_srl          vsr
   vec_sro          vsro  */

/* { dg-final { scan-assembler-times "vsldoi" 4 } } */
/* { dg-final { scan-assembler-times "vsr " 2 } } */
/* { dg-final { scan-assembler-times "vsro" 4 } } */