diff options
Diffstat (limited to 'gcc/testsuite/gcc.target/powerpc/vec-extract-8.c')
-rw-r--r-- | gcc/testsuite/gcc.target/powerpc/vec-extract-8.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.target/powerpc/vec-extract-8.c b/gcc/testsuite/gcc.target/powerpc/vec-extract-8.c new file mode 100644 index 0000000..f10b3b0 --- /dev/null +++ b/gcc/testsuite/gcc.target/powerpc/vec-extract-8.c @@ -0,0 +1,44 @@ +/* { dg-do compile { target { powerpc*-*-* && lp64 } } } */ +/* { dg-skip-if "" { powerpc*-*-darwin* } { "*" } { "" } } */ +/* { dg-require-effective-target powerpc_p8vector_ok } */ +/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power8" } } */ +/* { dg-options "-O2 -mcpu=power8" } */ + +#include <altivec.h> + +int +add_int_0 (vector int *p) +{ + return vec_extract (*p, 0) + 1; +} + +int +add_int_1 (vector int *p) +{ + return vec_extract (*p, 1) + 1; +} + +int +add_int_2 (vector int *p) +{ + return vec_extract (*p, 2) + 1; +} + +int +add_int_3 (vector int *p) +{ + return vec_extract (*p, 3) + 1; +} + +int +add_int_n (vector int *p, int n) +{ + return vec_extract (*p, n) + 1; +} + +/* { dg-final { scan-assembler-not "lxvd2x" } } */ +/* { dg-final { scan-assembler-not "lxvw4x" } } */ +/* { dg-final { scan-assembler-not "lxvx" } } */ +/* { dg-final { scan-assembler-not "lxv" } } */ +/* { dg-final { scan-assembler-not "lvx" } } */ +/* { dg-final { scan-assembler-not "xxpermdi" } } */ |