c++: normalizing ttp constraints [PR115656]
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / sse4_2-pcmpgtq.c
blobce705fb34278afa14c3c9e4f65810d6d3bcdbf8f
1 /* { dg-do run } */
2 /* { dg-options "-O2 -mvsx" } */
3 /* { dg-additional-options "-mdejagnu-cpu=power8" { target { ! has_arch_pwr8 } } } */
4 /* { dg-require-effective-target p8vector_hw } */
6 #ifndef CHECK_H
7 #define CHECK_H "sse4_2-check.h"
8 #endif
10 #ifndef TEST
11 #define TEST sse4_2_test
12 #endif
14 #include CHECK_H
16 #include <nmmintrin.h>
18 #define NUM 64
20 static void
21 TEST (void)
23 union
25 __m128i x[NUM / 2];
26 long long ll[NUM];
27 } dst, src1, src2;
28 int i, sign = 1;
29 long long is_eq;
31 for (i = 0; i < NUM; i++)
33 src1.ll[i] = i * i * sign;
34 src2.ll[i] = (i + 20) * sign;
35 sign = -sign;
38 for (i = 0; i < NUM; i += 2)
39 dst.x[i / 2] = _mm_cmpgt_epi64 (src1.x[i / 2], src2.x[i / 2]);
41 for (i = 0; i < NUM; i++)
43 is_eq = src1.ll[i] > src2.ll[i] ? 0xFFFFFFFFFFFFFFFFLL : 0LL;
44 if (is_eq != dst.ll[i])
45 abort ();