summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorhjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>2010-10-14 02:27:59 +0000
committerhjl <hjl@138bc75d-0d04-0410-961f-82ee72b054a4>2010-10-14 02:27:59 +0000
commite7bd05ebfea6e83d75d7a7cf70b8d8f633fdbb8f (patch)
tree84d983ccebee7abf96d55118b80962dd30ace5c6
parent2e9add70148eb9d73dc0c825e8fdc9ff27606e2f (diff)
downloadgcc-e7bd05ebfea6e83d75d7a7cf70b8d8f633fdbb8f.tar.gz
Add a testcase for PR middle-end/44130.
2010-10-13 H.J. Lu <hongjiu.lu@intel.com> PR middle-end/44130 * gcc.target/i386/pr44130.c: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@165447 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.target/i386/pr44130.c26
2 files changed, 31 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a8a5a3a9e66..bdaa976125c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2010-10-13 H.J. Lu <hongjiu.lu@intel.com>
+ PR middle-end/44130
+ * gcc.target/i386/pr44130.c: New.
+
+2010-10-13 H.J. Lu <hongjiu.lu@intel.com>
+
PR middle-end/44144
* gcc.target/i386/pr44144.c: New.
diff --git a/gcc/testsuite/gcc.target/i386/pr44130.c b/gcc/testsuite/gcc.target/i386/pr44130.c
new file mode 100644
index 00000000000..7b1035fcafa
--- /dev/null
+++ b/gcc/testsuite/gcc.target/i386/pr44130.c
@@ -0,0 +1,26 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -ftree-vectorize -mavx" } */
+/* { dg-final { scan-assembler "and\[lq\]?\[\\t \]*\\$-32,\[\\t \]*%\[re\]?sp" } } */
+/* { dg-final { scan-assembler "vmovaps\[\\t \]*%ymm" } } */
+
+extern void abort (void);
+
+static float Yf[] = { 2.0, -2.0, -2.0, -2.0, -2.0, 2.0, -0.0, __builtin_inff () };
+static const float Zf[] = { 1.0, -1.0, -1.0, -0.0, -0.0, 0.0, -__builtin_inff (), __builtin_nanf ("") };
+
+void testf (void)
+{
+ float xxxxx[8];
+ int i;
+ xxxxx[0] = __builtin_copysignf (1.0, Yf[0]);
+ xxxxx[1] = __builtin_copysignf (1.0, Yf[1]);
+ xxxxx[2] = __builtin_copysignf (-1.0, Yf[2]);
+ xxxxx[3] = __builtin_copysignf (0.0, Yf[3]);
+ xxxxx[4] = __builtin_copysignf (-0.0, Yf[4]);
+ xxxxx[5] = __builtin_copysignf (-0.0, Yf[5]);
+ xxxxx[6] = __builtin_copysignf (__builtin_inff (), Yf[6]);
+ xxxxx[7] = __builtin_copysignf (-__builtin_nanf (""), Yf[7]);
+ for (i = 0; i < 8; ++i)
+ if (__builtin_memcmp (xxxxx+i, Zf+i, sizeof(float)) != 0)
+ abort ();
+}