Re: [PATCH] Fix PR67278, x86 target part
Richard Bienerwrites: > Index: gcc/testsuite/gcc.dg/simd-8.c > === > --- gcc/testsuite/gcc.dg/simd-8.c (revision 0) > +++ gcc/testsuite/gcc.dg/simd-8.c (working copy) > @@ -0,0 +1,19 @@ > +/* { dg-do compile } */ > + > +#if __SIZEOF_LONG_DOUBLE__ == 16 || __SIZEOF_LONG_DOUBLE__ == 8 > +typedef long double a __attribute__((vector_size (32))); > + > +a __attribute__((noinline)) > +sum (a first, a second) > +{ > +return first + second; > +} > + > +a > +foo (a x, a y, a z) > +{ > + return sum (x, y) + z; > +} > +#else > +int main() {} > +#endif On powerpc: FAIL: gcc.dg/simd-8.c (test for excess errors) Excess errors: /daten/gcc/gcc-20160307/gcc/testsuite/gcc.dg/simd-8.c:8:1: warning: GCC vector returned by reference: non-standard ABI extension with no compatibility guarantee /daten/gcc/gcc-20160307/gcc/testsuite/gcc.dg/simd-8.c:7:1: warning: GCC vector passed by reference: non-standard ABI extension with no compatibility guarantee Andreas. -- Andreas Schwab, sch...@linux-m68k.org GPG Key fingerprint = 58CA 54C7 6D53 942B 1756 01D3 44D5 214B 8276 4ED5 "And now for something completely different."
Re: [PATCH] Fix PR67278, x86 target part
On Wed, 2 Mar 2016, Uros Bizjak wrote: > On Wed, Mar 2, 2016 at 9:54 AM, Richard Bienerwrote: > > > > The following fix from Uros properly (not) handles XFmode vectors in > > type_natural_mode. > > > > Bootstrapped and tested on x86_64-unknown-linux-gnu by Uros, applied. > > > > Richard. > > > > 2016-03-02 Richard Biener > > Uros Bizjak > > > > PR target/67278 > > * config/i386/i386.c (type_natural_mode): Handle XFmode vectors. > > > > * gcc.dg/simd-8.c: New testcase. > > > > Index: gcc/config/i386/i386.c > > === > > --- gcc/config/i386/i386.c (revision 233897) > > +++ gcc/config/i386/i386.c (working copy) > > @@ -7794,6 +7794,10 @@ type_natural_mode (const_tree type, cons > > { > > machine_mode innermode = TYPE_MODE (TREE_TYPE (type)); > > > > + /* There are no XFmode vector modes. */ > > + if (innermode = XFmode) > > No, not assignment "=" , but comparison "==" here! Argh. Fixed. Richard. 2016-03-02 Richard Biener * config/i386/i386.c (type_natural_mode): Fix typo. Index: gcc/config/i386/i386.c === --- gcc/config/i386/i386.c (revision 233900) +++ gcc/config/i386/i386.c (working copy) @@ -7795,7 +7795,7 @@ type_natural_mode (const_tree type, cons machine_mode innermode = TYPE_MODE (TREE_TYPE (type)); /* There are no XFmode vector modes. */ - if (innermode = XFmode) + if (innermode == XFmode) return mode; if (TREE_CODE (TREE_TYPE (type)) == REAL_TYPE)
Re: [PATCH] Fix PR67278, x86 target part
> Index: gcc/config/i386/i386.c > === > --- gcc/config/i386/i386.c(revision 233897) > +++ gcc/config/i386/i386.c(working copy) > @@ -7794,6 +7794,10 @@ type_natural_mode (const_tree type, cons > { > machine_mode innermode = TYPE_MODE (TREE_TYPE (type)); > > + /* There are no XFmode vector modes. */ > + if (innermode = XFmode) > + return mode; > + > if (TREE_CODE (TREE_TYPE (type)) == REAL_TYPE) > mode = MIN_MODE_VECTOR_FLOAT; > else You lost one of the '=' though. -- Eric Botcazou
Re: [PATCH] Fix PR67278, x86 target part
On Wed, Mar 2, 2016 at 9:54 AM, Richard Bienerwrote: > > The following fix from Uros properly (not) handles XFmode vectors in > type_natural_mode. > > Bootstrapped and tested on x86_64-unknown-linux-gnu by Uros, applied. > > Richard. > > 2016-03-02 Richard Biener > Uros Bizjak > > PR target/67278 > * config/i386/i386.c (type_natural_mode): Handle XFmode vectors. > > * gcc.dg/simd-8.c: New testcase. > > Index: gcc/config/i386/i386.c > === > --- gcc/config/i386/i386.c (revision 233897) > +++ gcc/config/i386/i386.c (working copy) > @@ -7794,6 +7794,10 @@ type_natural_mode (const_tree type, cons > { > machine_mode innermode = TYPE_MODE (TREE_TYPE (type)); > > + /* There are no XFmode vector modes. */ > + if (innermode = XFmode) No, not assignment "=" , but comparison "==" here! Uros.
[PATCH] Fix PR67278, x86 target part
The following fix from Uros properly (not) handles XFmode vectors in type_natural_mode. Bootstrapped and tested on x86_64-unknown-linux-gnu by Uros, applied. Richard. 2016-03-02 Richard BienerUros Bizjak PR target/67278 * config/i386/i386.c (type_natural_mode): Handle XFmode vectors. * gcc.dg/simd-8.c: New testcase. Index: gcc/config/i386/i386.c === --- gcc/config/i386/i386.c (revision 233897) +++ gcc/config/i386/i386.c (working copy) @@ -7794,6 +7794,10 @@ type_natural_mode (const_tree type, cons { machine_mode innermode = TYPE_MODE (TREE_TYPE (type)); + /* There are no XFmode vector modes. */ + if (innermode = XFmode) + return mode; + if (TREE_CODE (TREE_TYPE (type)) == REAL_TYPE) mode = MIN_MODE_VECTOR_FLOAT; else Index: gcc/testsuite/gcc.dg/simd-8.c === --- gcc/testsuite/gcc.dg/simd-8.c (revision 0) +++ gcc/testsuite/gcc.dg/simd-8.c (working copy) @@ -0,0 +1,19 @@ +/* { dg-do compile } */ + +#if __SIZEOF_LONG_DOUBLE__ == 16 || __SIZEOF_LONG_DOUBLE__ == 8 +typedef long double a __attribute__((vector_size (32))); + +a __attribute__((noinline)) +sum (a first, a second) +{ +return first + second; +} + +a +foo (a x, a y, a z) +{ + return sum (x, y) + z; +} +#else +int main() {} +#endif