Viewing file: vsx-13.c (1.15 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* { 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 } } */
|