From 1bc5aee63eb72b341f506ad058502cd0361f0d10 Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Tue, 25 Mar 2014 22:37:19 -0700 Subject: Initial checkin of GCC 4.9.0 from trunk (r208799). Change-Id: I48a3c08bb98542aa215912a75f03c0890e497dba --- .../testsuite/gcc.target/i386/avx-vtestpd-256-3.c | 42 ++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 gcc-4.9/gcc/testsuite/gcc.target/i386/avx-vtestpd-256-3.c (limited to 'gcc-4.9/gcc/testsuite/gcc.target/i386/avx-vtestpd-256-3.c') diff --git a/gcc-4.9/gcc/testsuite/gcc.target/i386/avx-vtestpd-256-3.c b/gcc-4.9/gcc/testsuite/gcc.target/i386/avx-vtestpd-256-3.c new file mode 100644 index 000000000..8a6e32e41 --- /dev/null +++ b/gcc-4.9/gcc/testsuite/gcc.target/i386/avx-vtestpd-256-3.c @@ -0,0 +1,42 @@ +/* { dg-do run } */ +/* { dg-require-effective-target avx } */ +/* { dg-options "-O2 -mavx -DNEED_IEEE754_DOUBLE" } */ +/* { dg-warning "attribute ignored" "" { target default_packed } 164 } */ +/* { dg-message " from " "include chain" { target default_packed } 0 } */ + +#include "avx-check.h" + +static void +avx_test () +{ + int i; + union256d source1, source2; + + double s1[4] = {0, -5463, 86456, 0}; + double s2[4] = {0, -1223, 0, 1}; + int d[1]; + int e[1]; + int c=1; + int z=1; + + source1.x = _mm256_loadu_pd(s1); + source2.x = _mm256_loadu_pd(s2); + d[0] = _mm256_testnzc_pd(source1.x, source2.x); + + e[0] = 1; + for (i = 0; i < 4; i++) { + union ieee754_double u1, u2; + u1.d = s1[i]; + u2.d = s2[i]; + if (u1.bits.sign && u2.bits.sign) + z = 0; + + if (!u1.bits.sign && u2.bits.sign) + c = 0; + } + e[0] = (c==0 && z==0) ? 1:0; + + if (checkVi(d, e, 1)) + abort (); +} + -- cgit v1.2.3