aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/powerpc/altivec-37.c
blob: 4228a1520095cd858d32625dad009c0e758d5b25 (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
/* { dg-do compile { target powerpc*-*-* } } */
/* { dg-options "-mvsx" } */
/* { dg-additional-options "-mdejagnu-cpu=power8" { target { ! has_arch_pwr8 } } } */
/* { dg-require-effective-target powerpc_vsx } */

#include <altivec.h>

vector bool int *vecubi;
vector bool long long *vecublli;
vector signed int *vecsi;
vector signed long long int *vecslli;

int main ()
{

  /*  use of ‘long long’ in AltiVec types requires -mvsx */
  /* __builtin_altivec_vupkhsw and __builtin_altivec_vupklsw
     requires the -mcpu=power8 and -mvsx option */
  *vecublli++ = vec_unpackh(vecubi[0]);
  *vecublli++ = vec_unpackl(vecubi[0]);
  *vecslli++ = vec_unpackh(vecsi[0]);
  *vecslli++ = vec_unpackl(vecsi[0]);
  
  return 0;
}

/* Expected results:
     vec_unpackh                    vupklsw
     vec_unpackl                    vupkhsw
*/

/* { dg-final { scan-assembler-times "vupklsw" 2 } } */
/* { dg-final { scan-assembler-times "vupkhsw" 2 } } */