OSDN Git Service

Revert delta 190174
[pf3gnuchains/gcc-fork.git] / gcc / testsuite / c-c++-common / torture / complex-sign-mul-minus-one.c
1 /* Test complex arithmetic with signed zeros.  Pure complex
2    multiplication with -1.0 + 0.0i.  */
3 /* { dg-do run } */
4 /* { dg-options "-std=gnu99" { target c } } */
5
6 #include "complex-sign.h"
7
8 #define CHECK_MUL_INT(TYPE, COPY, ZERO, ZEROI, ONE, S1, S2, SR, SI)     \
9   do {                                                                  \
10     _Complex TYPE a1, b1, c1;                                           \
11     volatile _Complex TYPE a2, b2, c2;                                  \
12     a1 = ENCODE(ZERO, ZEROI, S1, S2);                                   \
13     CHECK_RES (a1, COPY, S1, S2);                                       \
14     b1 = -ONE + ZEROI;                                                  \
15     c1 = a1 * b1;                                                       \
16     CHECK_RES (c1, COPY, SR, SI);                                       \
17     c1 = a1 * (-ONE + ZEROI);                                           \
18     CHECK_RES (c1, COPY, SR, SI);                                       \
19     a2 = ENCODE(ZERO, ZEROI, S1, S2);                                   \
20     CHECK_RES (a2, COPY, S1, S2);                                       \
21     b2 = -ONE + ZEROI;                                                  \
22     c2 = a2 * b2;                                                       \
23     CHECK_RES (c2, COPY, SR, SI);                                       \
24     c2 = a2 * (-ONE + ZEROI);                                           \
25     CHECK_RES (c2, COPY, SR, SI);                                       \
26   } while (0)
27
28 #define CHECK_MUL(TYPE, COPY, ZERO, ZEROI, ONE)                 \
29   do {                                                          \
30     CHECK_MUL_INT (TYPE, COPY, ZERO, ZEROI, ONE, +, +, -, +);   \
31     CHECK_MUL_INT (TYPE, COPY, ZERO, ZEROI, ONE, +, -, +, +);   \
32     CHECK_MUL_INT (TYPE, COPY, ZERO, ZEROI, ONE, -, +, +, -);   \
33     CHECK_MUL_INT (TYPE, COPY, ZERO, ZEROI, ONE, -, -, +, +);   \
34   } while (0)
35
36 void
37 check_mul_float (void)
38 {
39 #ifndef __SPU__
40   CHECK_MUL (float, __builtin_copysignf, 0.0f, 0.0if, 1.0f);
41 #endif
42 }
43
44 void
45 check_mul_double (void)
46 {
47   CHECK_MUL (double, __builtin_copysign, 0.0, 0.0i, 1.0);
48 }
49
50 void
51 check_mul_long_double (void)
52 {
53   CHECK_MUL (long double, __builtin_copysignl, 0.0l, 0.0il, 1.0l);
54 }
55
56 int
57 main (void)
58 {
59   check_mul_float ();
60   check_mul_double ();
61   check_mul_long_double ();
62   exit (0);
63 }