From: Carl Love Date: Mon, 13 Nov 2017 22:40:18 +0000 (+0000) Subject: altivec.md (altivec_vsumsws_be): Add define_expand. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=24cd339b9b17d7c26ce741bf3a72c5670cf7166d;p=gcc.git altivec.md (altivec_vsumsws_be): Add define_expand. gcc/ChangeLog: 2017-11-13 Carl Love * config/rs6000/altivec.md (altivec_vsumsws_be): Add define_expand. gcc/testsuite/ChangeLog: 2017-11-13 Carl Love * gcc.target/powerpc/builtin-vec-sums-be-int.c: New test file. From-SVN: r254714 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index b7ac84c44d7..13a60e8ed7d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2017-11-13 Carl Love + + * config/rs6000/altivec.md (altivec_vsumsws_be): Add define_expand. + 2017-11-13 Tom Tromey * doc/cpp.texi (Variadic Macros): Document __VA_OPT__. diff --git a/gcc/config/rs6000/rs6000-builtin.def b/gcc/config/rs6000/rs6000-builtin.def index 8eaa79783ff..1ef98e37012 100644 --- a/gcc/config/rs6000/rs6000-builtin.def +++ b/gcc/config/rs6000/rs6000-builtin.def @@ -1079,6 +1079,7 @@ BU_ALTIVEC_2 (VSUM4SBS, "vsum4sbs", CONST, altivec_vsum4sbs) BU_ALTIVEC_2 (VSUM4SHS, "vsum4shs", CONST, altivec_vsum4shs) BU_ALTIVEC_2 (VSUM2SWS, "vsum2sws", CONST, altivec_vsum2sws) BU_ALTIVEC_2 (VSUMSWS, "vsumsws", CONST, altivec_vsumsws) +BU_ALTIVEC_2 (VSUMSWS_BE, "vsumsws_be", CONST, altivec_vsumsws_direct) BU_ALTIVEC_2 (VXOR, "vxor", CONST, xorv4si3) BU_ALTIVEC_2 (COPYSIGN_V4SF, "copysignfp", CONST, vector_copysignv4sf3) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b1c2f3e0530..e5226149996 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2017-11-13 Carl Love + + * gcc.target/powerpc/builtin-vec-sums-be-int.c: New test file. + 2017-11-13 Tom Tromey * c-c++-common/cpp/va-opt-pedantic.c: New file. diff --git a/gcc/testsuite/gcc.target/powerpc/builtin-vec-sums-be-int.c b/gcc/testsuite/gcc.target/powerpc/builtin-vec-sums-be-int.c new file mode 100644 index 00000000000..b4dfd0637e4 --- /dev/null +++ b/gcc/testsuite/gcc.target/powerpc/builtin-vec-sums-be-int.c @@ -0,0 +1,16 @@ +/* Test for the __builtin_altivec_vsumsws_be() builtin. + It produces just the instruction vsumsws in LE and BE modes. */ + +/* { dg-do compile } */ +/* { dg-require-effective-target powerpc_altivec_ok } */ +/* { dg-options "-maltivec -O2" } */ + +#include + +vector signed int +test_vec_sums (vector signed int vsi2, vector signed int vsi3) +{ + return __builtin_altivec_vsumsws_be (vsi2, vsi3); +} + +/* { dg-final { scan-assembler-times "vsumsws" 1 } } */