annotate gcc/testsuite/c-c++-common/dfp/pr39902.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Check that optimizations like (x * 1) to x, or (x * -1) to -x,
kono
parents:
diff changeset
2 do not apply to decimal float computations where trailing zeroes
kono
parents:
diff changeset
3 are significant. */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #include "dfp-dbg.h"
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 #define COMPARE32(A,B) \
kono
parents:
diff changeset
8 A.i == B.i
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 #define COMPARE64(A,B) \
kono
parents:
diff changeset
11 A.i[0] == B.i[0] && A.i[1] == B.i[1]
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 #define COMPARE128(A,B) \
kono
parents:
diff changeset
14 A.i[0] == B.i[0] && A.i[1] == B.i[1] && A.i[2] == B.i[2] && A.i[3] == B.i[3]
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 typedef union {
kono
parents:
diff changeset
17 _Decimal32 d;
kono
parents:
diff changeset
18 unsigned int i;
kono
parents:
diff changeset
19 } u32;
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 typedef union {
kono
parents:
diff changeset
22 _Decimal64 d;
kono
parents:
diff changeset
23 unsigned int i[2];
kono
parents:
diff changeset
24 } u64;
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 typedef union {
kono
parents:
diff changeset
27 _Decimal128 d;
kono
parents:
diff changeset
28 unsigned int i[4];
kono
parents:
diff changeset
29 } u128;
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 volatile u32 p32_1;
kono
parents:
diff changeset
32 volatile u32 p32_1_0;
kono
parents:
diff changeset
33 volatile u32 p32_2_0;
kono
parents:
diff changeset
34 volatile u32 m32_1;
kono
parents:
diff changeset
35 volatile u32 m32_1_0;
kono
parents:
diff changeset
36 volatile u32 m32_2_0;
kono
parents:
diff changeset
37 volatile u32 a32;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 volatile u64 p64_1;
kono
parents:
diff changeset
40 volatile u64 p64_1_0;
kono
parents:
diff changeset
41 volatile u64 p64_2_0;
kono
parents:
diff changeset
42 volatile u64 m64_1;
kono
parents:
diff changeset
43 volatile u64 m64_1_0;
kono
parents:
diff changeset
44 volatile u64 m64_2_0;
kono
parents:
diff changeset
45 volatile u64 a64;
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 volatile u128 p128_1;
kono
parents:
diff changeset
48 volatile u128 p128_1_0;
kono
parents:
diff changeset
49 volatile u128 p128_2_0;
kono
parents:
diff changeset
50 volatile u128 m128_1;
kono
parents:
diff changeset
51 volatile u128 m128_1_0;
kono
parents:
diff changeset
52 volatile u128 m128_2_0;
kono
parents:
diff changeset
53 volatile u128 a128;
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 void
kono
parents:
diff changeset
56 init32 (void)
kono
parents:
diff changeset
57 {
kono
parents:
diff changeset
58 p32_1.d = 1.DF;
kono
parents:
diff changeset
59 p32_1_0.d = 1.0DF;
kono
parents:
diff changeset
60 p32_2_0.d = 2.0DF;
kono
parents:
diff changeset
61 m32_1.d = -1.DF;
kono
parents:
diff changeset
62 m32_1_0.d = -1.0DF;
kono
parents:
diff changeset
63 m32_2_0.d = -2.0DF;
kono
parents:
diff changeset
64 }
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 void
kono
parents:
diff changeset
67 init64 (void)
kono
parents:
diff changeset
68 {
kono
parents:
diff changeset
69 p64_1.d = 1.DD;
kono
parents:
diff changeset
70 p64_1_0.d = 1.0DD;
kono
parents:
diff changeset
71 p64_2_0.d = 2.0DD;
kono
parents:
diff changeset
72 m64_1.d = -1.DD;
kono
parents:
diff changeset
73 m64_1_0.d = -1.0DD;
kono
parents:
diff changeset
74 m64_2_0.d = -2.0DD;
kono
parents:
diff changeset
75 }
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 void
kono
parents:
diff changeset
78 init128 (void)
kono
parents:
diff changeset
79 {
kono
parents:
diff changeset
80 p128_1.d = 1.DL;
kono
parents:
diff changeset
81 p128_1_0.d = 1.0DL;
kono
parents:
diff changeset
82 p128_2_0.d = 2.0DL;
kono
parents:
diff changeset
83 m128_1.d = -1.DL;
kono
parents:
diff changeset
84 m128_1_0.d = -1.0DL;
kono
parents:
diff changeset
85 m128_2_0.d = -2.0DL;
kono
parents:
diff changeset
86 }
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 void
kono
parents:
diff changeset
89 doit32 (void)
kono
parents:
diff changeset
90 {
kono
parents:
diff changeset
91 /* Multiplying by a value with no trailing zero should not change the
kono
parents:
diff changeset
92 quantum exponent. */
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 a32.d = p32_2_0.d * p32_1.d;
kono
parents:
diff changeset
95 if (! (COMPARE32 (a32, p32_2_0)))
kono
parents:
diff changeset
96 FAILURE
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 a32.d = p32_2_0.d * 1.DF;
kono
parents:
diff changeset
99 if (! (COMPARE32 (a32, p32_2_0)))
kono
parents:
diff changeset
100 FAILURE
kono
parents:
diff changeset
101
kono
parents:
diff changeset
102 a32.d = p32_2_0.d * m32_1.d;
kono
parents:
diff changeset
103 if (! (COMPARE32 (a32, m32_2_0)))
kono
parents:
diff changeset
104 FAILURE
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 a32.d = p32_2_0.d * -1.DF;
kono
parents:
diff changeset
107 if (! (COMPARE32 (a32, m32_2_0)))
kono
parents:
diff changeset
108 FAILURE
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 /* Multiplying by a value with a trailing zero should change the
kono
parents:
diff changeset
111 quantum exponent. */
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 a32.d = p32_2_0.d * p32_1_0.d;
kono
parents:
diff changeset
114 if (COMPARE32 (a32, p32_2_0))
kono
parents:
diff changeset
115 FAILURE
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 a32.d = p32_2_0.d * 1.0DF;
kono
parents:
diff changeset
118 if (COMPARE32 (a32, p32_2_0))
kono
parents:
diff changeset
119 FAILURE
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 a32.d = p32_2_0.d * m32_1_0.d;
kono
parents:
diff changeset
122 if (COMPARE32 (a32, m32_2_0))
kono
parents:
diff changeset
123 FAILURE
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 a32.d = p32_2_0.d * -1.0DF;
kono
parents:
diff changeset
126 if (COMPARE32 (a32, m32_2_0))
kono
parents:
diff changeset
127 FAILURE
kono
parents:
diff changeset
128 }
kono
parents:
diff changeset
129
kono
parents:
diff changeset
130 void
kono
parents:
diff changeset
131 doit64 (void)
kono
parents:
diff changeset
132 {
kono
parents:
diff changeset
133 /* Multiplying by a value with no trailing zero should not change the
kono
parents:
diff changeset
134 quantum exponent. */
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 a64.d = p64_2_0.d * p64_1.d;
kono
parents:
diff changeset
137 if (! (COMPARE64 (a64, p64_2_0)))
kono
parents:
diff changeset
138 FAILURE
kono
parents:
diff changeset
139
kono
parents:
diff changeset
140 a64.d = p64_2_0.d * 1.DD;
kono
parents:
diff changeset
141 if (! (COMPARE64 (a64, p64_2_0)))
kono
parents:
diff changeset
142 FAILURE
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 a64.d = p64_2_0.d * m64_1.d;
kono
parents:
diff changeset
145 if (! (COMPARE64 (a64, m64_2_0)))
kono
parents:
diff changeset
146 FAILURE
kono
parents:
diff changeset
147
kono
parents:
diff changeset
148 a64.d = p64_2_0.d * -1.DD;
kono
parents:
diff changeset
149 if (! (COMPARE64 (a64, m64_2_0)))
kono
parents:
diff changeset
150 FAILURE
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 /* Multiplying by a value with a trailing zero should change the
kono
parents:
diff changeset
153 quantum exponent. */
kono
parents:
diff changeset
154
kono
parents:
diff changeset
155 a64.d = p64_2_0.d * p64_1_0.d;
kono
parents:
diff changeset
156 if (COMPARE64 (a64, p64_2_0))
kono
parents:
diff changeset
157 FAILURE
kono
parents:
diff changeset
158
kono
parents:
diff changeset
159 a64.d = p64_2_0.d * 1.0DD;
kono
parents:
diff changeset
160 if (COMPARE64 (a64, p64_2_0))
kono
parents:
diff changeset
161 FAILURE
kono
parents:
diff changeset
162
kono
parents:
diff changeset
163 a64.d = p64_2_0.d * m64_1_0.d;
kono
parents:
diff changeset
164 if (COMPARE64 (a64, m64_2_0))
kono
parents:
diff changeset
165 FAILURE
kono
parents:
diff changeset
166
kono
parents:
diff changeset
167 a64.d = p64_2_0.d * -1.0DD;
kono
parents:
diff changeset
168 if (COMPARE64 (a64, m64_2_0))
kono
parents:
diff changeset
169 FAILURE
kono
parents:
diff changeset
170 }
kono
parents:
diff changeset
171
kono
parents:
diff changeset
172 void
kono
parents:
diff changeset
173 doit128 (void)
kono
parents:
diff changeset
174 {
kono
parents:
diff changeset
175 /* Multiplying by a value with no trailing zero should not change the
kono
parents:
diff changeset
176 quantum exponent. */
kono
parents:
diff changeset
177
kono
parents:
diff changeset
178 a128.d = p128_2_0.d * p128_1_0.d;
kono
parents:
diff changeset
179 if (COMPARE128 (a128, p128_2_0))
kono
parents:
diff changeset
180 FAILURE
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 a128.d = p128_2_0.d * 1.0DL;
kono
parents:
diff changeset
183 if (COMPARE128 (a128, p128_2_0))
kono
parents:
diff changeset
184 FAILURE
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 a128.d = p128_2_0.d * m128_1_0.d;
kono
parents:
diff changeset
187 if (COMPARE128 (a128, m128_2_0))
kono
parents:
diff changeset
188 FAILURE
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 a128.d = p128_2_0.d * -1.0DL;
kono
parents:
diff changeset
191 if (COMPARE128 (a128, m128_2_0))
kono
parents:
diff changeset
192 FAILURE
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 /* Multiplying by a value with a trailing zero should change the
kono
parents:
diff changeset
195 quantum exponent. */
kono
parents:
diff changeset
196
kono
parents:
diff changeset
197 a128.d = p128_2_0.d * p128_1.d;
kono
parents:
diff changeset
198 if (! (COMPARE128 (a128, p128_2_0)))
kono
parents:
diff changeset
199 FAILURE
kono
parents:
diff changeset
200
kono
parents:
diff changeset
201 a128.d = p128_2_0.d * 1.DL;
kono
parents:
diff changeset
202 if (! (COMPARE128 (a128, p128_2_0)))
kono
parents:
diff changeset
203 FAILURE
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205 a128.d = p128_2_0.d * m128_1.d;
kono
parents:
diff changeset
206 if (! (COMPARE128 (a128, m128_2_0)))
kono
parents:
diff changeset
207 FAILURE
kono
parents:
diff changeset
208
kono
parents:
diff changeset
209 a128.d = p128_2_0.d * -1.DL;
kono
parents:
diff changeset
210 if (! (COMPARE128 (a128, m128_2_0)))
kono
parents:
diff changeset
211 FAILURE
kono
parents:
diff changeset
212 }
kono
parents:
diff changeset
213
kono
parents:
diff changeset
214 int
kono
parents:
diff changeset
215 main (void)
kono
parents:
diff changeset
216 {
kono
parents:
diff changeset
217 init32 ();
kono
parents:
diff changeset
218 init64 ();
kono
parents:
diff changeset
219 init128 ();
kono
parents:
diff changeset
220
kono
parents:
diff changeset
221 doit32 ();
kono
parents:
diff changeset
222 doit64 ();
kono
parents:
diff changeset
223 doit128 ();
kono
parents:
diff changeset
224
kono
parents:
diff changeset
225 FINISH
kono
parents:
diff changeset
226 }