43 lines
1.2 KiB
C
43 lines
1.2 KiB
C
|
/* { 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 } } */
|