annotate gcc/testsuite/gcc.dg/torture/floatn-complex.h @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Tests for _FloatN / _FloatNx types: compile and execution tests for
kono
parents:
diff changeset
2 valid code with complex arithmetic. Before including this file,
kono
parents:
diff changeset
3 define WIDTH as the value N; define EXT to 1 for _FloatNx and 0 for
kono
parents:
diff changeset
4 _FloatN. */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 #define CONCATX(X, Y) X ## Y
kono
parents:
diff changeset
7 #define CONCAT(X, Y) CONCATX (X, Y)
kono
parents:
diff changeset
8 #define CONCAT3(X, Y, Z) CONCAT (CONCAT (X, Y), Z)
kono
parents:
diff changeset
9 #define CONCAT4(W, X, Y, Z) CONCAT (CONCAT (CONCAT (W, X), Y), Z)
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 #if EXT
kono
parents:
diff changeset
12 # define TYPE CONCAT3 (_Float, WIDTH, x)
kono
parents:
diff changeset
13 # define CST(C) CONCAT4 (C, f, WIDTH, x)
kono
parents:
diff changeset
14 # define CSTI(C) CONCAT4 (C, if, WIDTH, x)
kono
parents:
diff changeset
15 # define CSTI2(C) CONCAT4 (C, F, WIDTH, xi)
kono
parents:
diff changeset
16 #else
kono
parents:
diff changeset
17 # define TYPE CONCAT (_Float, WIDTH)
kono
parents:
diff changeset
18 # define CST(C) CONCAT3 (C, f, WIDTH)
kono
parents:
diff changeset
19 # define CSTI(C) CONCAT3 (C, if, WIDTH)
kono
parents:
diff changeset
20 # define CSTI2(C) CONCAT4 (C, F, WIDTH, i)
kono
parents:
diff changeset
21 #endif
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 extern void exit (int);
kono
parents:
diff changeset
24 extern void abort (void);
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 volatile TYPE a = CST (1.0);
kono
parents:
diff changeset
27 volatile _Complex TYPE b = CST (2.0) + CSTI (3.0);
kono
parents:
diff changeset
28 volatile _Complex TYPE c = CST (2.0) + CSTI2 (3.0);
kono
parents:
diff changeset
29 volatile _Complex TYPE d = __builtin_complex (CST (2.0), CST (3.0));
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 _Complex TYPE
kono
parents:
diff changeset
32 fn (_Complex TYPE arg)
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 return arg / 4;
kono
parents:
diff changeset
35 }
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 int
kono
parents:
diff changeset
38 main (void)
kono
parents:
diff changeset
39 {
kono
parents:
diff changeset
40 volatile _Complex TYPE r;
kono
parents:
diff changeset
41 if (b != c)
kono
parents:
diff changeset
42 abort ();
kono
parents:
diff changeset
43 if (b != d)
kono
parents:
diff changeset
44 abort ();
kono
parents:
diff changeset
45 r = a + b;
kono
parents:
diff changeset
46 if (__real__ r != CST (3.0) || __imag__ r != CST (3.0))
kono
parents:
diff changeset
47 abort ();
kono
parents:
diff changeset
48 r += d;
kono
parents:
diff changeset
49 if (__real__ r != CST (5.0) || __imag__ r != CST (6.0))
kono
parents:
diff changeset
50 abort ();
kono
parents:
diff changeset
51 r -= a;
kono
parents:
diff changeset
52 if (__real__ r != CST (4.0) || __imag__ r != CST (6.0))
kono
parents:
diff changeset
53 abort ();
kono
parents:
diff changeset
54 r /= (a + a);
kono
parents:
diff changeset
55 if (__real__ r != CST (2.0) || __imag__ r != CST (3.0))
kono
parents:
diff changeset
56 abort ();
kono
parents:
diff changeset
57 r *= (a + a);
kono
parents:
diff changeset
58 if (__real__ r != CST (4.0) || __imag__ r != CST (6.0))
kono
parents:
diff changeset
59 abort ();
kono
parents:
diff changeset
60 r -= b;
kono
parents:
diff changeset
61 if (__real__ r != CST (2.0) || __imag__ r != CST (3.0))
kono
parents:
diff changeset
62 abort ();
kono
parents:
diff changeset
63 r *= r;
kono
parents:
diff changeset
64 if (__real__ r != -CST (5.0) || __imag__ r != CST (12.0))
kono
parents:
diff changeset
65 abort ();
kono
parents:
diff changeset
66 /* Division may not be exact, so round result before comparing. */
kono
parents:
diff changeset
67 r /= b;
kono
parents:
diff changeset
68 r += __builtin_complex (CST (100.0), CST (100.0));
kono
parents:
diff changeset
69 r -= __builtin_complex (CST (100.0), CST (100.0));
kono
parents:
diff changeset
70 if (r != b)
kono
parents:
diff changeset
71 abort ();
kono
parents:
diff changeset
72 r = fn (r);
kono
parents:
diff changeset
73 if (__real__ r != CST (0.5) || __imag__ r != CST (0.75))
kono
parents:
diff changeset
74 abort ();
kono
parents:
diff changeset
75 exit (0);
kono
parents:
diff changeset
76 }