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
check_mul_float(void)37 check_mul_float (void)
38 {
39   CHECK_MUL (float, __builtin_copysignf, 0.0f, 0.0if, 1.0f);
40 }
41 
42 void
check_mul_double(void)43 check_mul_double (void)
44 {
45   CHECK_MUL (double, __builtin_copysign, 0.0, 0.0i, 1.0);
46 }
47 
48 void
check_mul_long_double(void)49 check_mul_long_double (void)
50 {
51   CHECK_MUL (long double, __builtin_copysignl, 0.0l, 0.0il, 1.0l);
52 }
53 
54 int
main(void)55 main (void)
56 {
57   check_mul_float ();
58   check_mul_double ();
59   check_mul_long_double ();
60   exit (0);
61 }
62