diff options
author | Bill Schmidt <wschmidt@linux.vnet.ibm.com> | 2017-05-10 19:40:17 +0000 |
---|---|---|
committer | William Schmidt <wschmidt@gcc.gnu.org> | 2017-05-10 19:40:17 +0000 |
commit | d45d628294574fd6696ab54fdb543485db6e65f9 (patch) | |
tree | 21789631dc74ac58e36262410a695f5904c68467 /gcc | |
parent | f4ee3a9e2ab62e99346ee286be1d10701122c03b (diff) | |
download | gcc-d45d628294574fd6696ab54fdb543485db6e65f9.zip gcc-d45d628294574fd6696ab54fdb543485db6e65f9.tar.gz gcc-d45d628294574fd6696ab54fdb543485db6e65f9.tar.bz2 |
rs6000.c (altivec_init_builtins): Define POWER8 built-ins for vec_xl and vec_xst with short and char pointer...
[gcc]
2017-05-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
* config/rs6000/rs6000.c (altivec_init_builtins): Define POWER8
built-ins for vec_xl and vec_xst with short and char pointer
arguments.
[gcc/testsuite]
2017-05-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com>
* gcc.target/powerpc/p8-vec-xl-xst.c: New file.
From-SVN: r247854
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/config/rs6000/rs6000.c | 11 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.target/powerpc/p8-vec-xl-xst.c | 62 |
4 files changed, 83 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ce83514..075b50d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2017-05-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com> + + * config/rs6000/rs6000.c (altivec_init_builtins): Define POWER8 + built-ins for vec_xl and vec_xst with short and char pointer + arguments. + 2017-05-10 Sebastian Peryt <sebastian.peryt@intel.com> * config/i386/avx512fintrin.h (_mm_mask_max_round_sd) diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index 17b93a6..e77026a 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -18295,6 +18295,17 @@ altivec_init_builtins (void) def_builtin ("__builtin_vsx_st_elemrev_v16qi", void_ftype_v16qi_long_pvoid, VSX_BUILTIN_ST_ELEMREV_V16QI); } + else + { + rs6000_builtin_decls[(int) VSX_BUILTIN_LD_ELEMREV_V8HI] + = rs6000_builtin_decls[(int) VSX_BUILTIN_LXVW4X_V8HI]; + rs6000_builtin_decls[(int) VSX_BUILTIN_LD_ELEMREV_V16QI] + = rs6000_builtin_decls[(int) VSX_BUILTIN_LXVW4X_V16QI]; + rs6000_builtin_decls[(int) VSX_BUILTIN_ST_ELEMREV_V8HI] + = rs6000_builtin_decls[(int) VSX_BUILTIN_STXVW4X_V8HI]; + rs6000_builtin_decls[(int) VSX_BUILTIN_ST_ELEMREV_V16QI] + = rs6000_builtin_decls[(int) VSX_BUILTIN_STXVW4X_V16QI]; + } def_builtin ("__builtin_vec_vsx_ld", opaque_ftype_long_pcvoid, VSX_BUILTIN_VEC_LD); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 57545d7..d7d1d04c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2017-05-10 Bill Schmidt <wschmidt@linux.vnet.ibm.com> + + * gcc.target/powerpc/p8-vec-xl-xst.c: New file. + 2017-05-10 Sebastian Peryt <sebastian.peryt@intel.com> * gcc.target/i386/avx512f-vmaxsd-1.c (_mm_mask_max_round_sd) diff --git a/gcc/testsuite/gcc.target/powerpc/p8-vec-xl-xst.c b/gcc/testsuite/gcc.target/powerpc/p8-vec-xl-xst.c new file mode 100644 index 0000000..de4e10f --- /dev/null +++ b/gcc/testsuite/gcc.target/powerpc/p8-vec-xl-xst.c @@ -0,0 +1,62 @@ +/* { dg-do compile { target { powerpc*-*-* } } } */ +/* { 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 "-mcpu=power8 -O2" } */ + +/* Verify fix for problem where vec_xl and vec_xst are not recognized + for the vector char and vector short cases on P8 only. */ + +#include <altivec.h> + +vector unsigned char +foo (unsigned char * address) +{ + return __builtin_vec_xl (0, address); +} + +void +bar (vector unsigned char x, unsigned char * address) +{ + __builtin_vec_xst (x, 0, address); +} + +vector unsigned short +foot (unsigned short * address) +{ + return __builtin_vec_xl (0, address); +} + +void +bart (vector unsigned short x, unsigned short * address) +{ + __builtin_vec_xst (x, 0, address); +} + +vector unsigned char +fool (unsigned char * address) +{ + return vec_xl (0, address); +} + +void +barl (vector unsigned char x, unsigned char * address) +{ + vec_xst (x, 0, address); +} + +vector unsigned short +footle (unsigned short * address) +{ + return vec_xl (0, address); +} + +void +bartle (vector unsigned short x, unsigned short * address) +{ + vec_xst (x, 0, address); +} + +/* { dg-final { scan-assembler-times "lxvd2x" 4 } } */ +/* { dg-final { scan-assembler-times "stxvd2x" 4 } } */ +/* { dg-final { scan-assembler-times "xxpermdi" 8 } } */ |