annotate gcc/testsuite/gcc.c-torture/execute/20040409-2.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 #include <limits.h>
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 extern void abort ();
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 int test1(int x)
kono
parents:
diff changeset
6 {
kono
parents:
diff changeset
7 return (x ^ INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
8 }
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 unsigned int test1u(unsigned int x)
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 return (x ^ (unsigned int)INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
13 }
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 int test2(int x)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 return (x ^ 0x1234) ^ INT_MIN;
kono
parents:
diff changeset
18 }
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 unsigned int test2u(unsigned int x)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 return (x ^ 0x1234) ^ (unsigned int)INT_MIN;
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 int test3(int x)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 return (x + INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 unsigned int test3u(unsigned int x)
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 return (x + (unsigned int)INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 int test4(int x)
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 return (x ^ 0x1234) + INT_MIN;
kono
parents:
diff changeset
38 }
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 unsigned int test4u(unsigned int x)
kono
parents:
diff changeset
41 {
kono
parents:
diff changeset
42 return (x ^ 0x1234) + (unsigned int)INT_MIN;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 int test5(int x)
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 return (x - INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 unsigned int test5u(unsigned int x)
kono
parents:
diff changeset
51 {
kono
parents:
diff changeset
52 return (x - (unsigned int)INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
53 }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 int test6(int x)
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 return (x ^ 0x1234) - INT_MIN;
kono
parents:
diff changeset
58 }
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 unsigned int test6u(unsigned int x)
kono
parents:
diff changeset
61 {
kono
parents:
diff changeset
62 return (x ^ 0x1234) - (unsigned int)INT_MIN;
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 int test7(int x)
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 int y = INT_MIN;
kono
parents:
diff changeset
68 int z = 0x1234;
kono
parents:
diff changeset
69 return (x ^ y) ^ z;
kono
parents:
diff changeset
70 }
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 unsigned int test7u(unsigned int x)
kono
parents:
diff changeset
73 {
kono
parents:
diff changeset
74 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
75 unsigned int z = 0x1234;
kono
parents:
diff changeset
76 return (x ^ y) ^ z;
kono
parents:
diff changeset
77 }
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 int test8(int x)
kono
parents:
diff changeset
80 {
kono
parents:
diff changeset
81 int y = 0x1234;
kono
parents:
diff changeset
82 int z = INT_MIN;
kono
parents:
diff changeset
83 return (x ^ y) ^ z;
kono
parents:
diff changeset
84 }
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86 unsigned int test8u(unsigned int x)
kono
parents:
diff changeset
87 {
kono
parents:
diff changeset
88 unsigned int y = 0x1234;
kono
parents:
diff changeset
89 unsigned int z = (unsigned int)INT_MIN;
kono
parents:
diff changeset
90 return (x ^ y) ^ z;
kono
parents:
diff changeset
91 }
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 int test9(int x)
kono
parents:
diff changeset
94 {
kono
parents:
diff changeset
95 int y = INT_MIN;
kono
parents:
diff changeset
96 int z = 0x1234;
kono
parents:
diff changeset
97 return (x + y) ^ z;
kono
parents:
diff changeset
98 }
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 unsigned int test9u(unsigned int x)
kono
parents:
diff changeset
101 {
kono
parents:
diff changeset
102 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
103 unsigned int z = 0x1234;
kono
parents:
diff changeset
104 return (x + y) ^ z;
kono
parents:
diff changeset
105 }
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 int test10(int x)
kono
parents:
diff changeset
108 {
kono
parents:
diff changeset
109 int y = 0x1234;
kono
parents:
diff changeset
110 int z = INT_MIN;
kono
parents:
diff changeset
111 return (x ^ y) + z;
kono
parents:
diff changeset
112 }
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 unsigned int test10u(unsigned int x)
kono
parents:
diff changeset
115 {
kono
parents:
diff changeset
116 unsigned int y = 0x1234;
kono
parents:
diff changeset
117 unsigned int z = (unsigned int)INT_MIN;
kono
parents:
diff changeset
118 return (x ^ y) + z;
kono
parents:
diff changeset
119 }
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 int test11(int x)
kono
parents:
diff changeset
122 {
kono
parents:
diff changeset
123 int y = INT_MIN;
kono
parents:
diff changeset
124 int z = 0x1234;
kono
parents:
diff changeset
125 return (x - y) ^ z;
kono
parents:
diff changeset
126 }
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 unsigned int test11u(unsigned int x)
kono
parents:
diff changeset
129 {
kono
parents:
diff changeset
130 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
131 unsigned int z = 0x1234;
kono
parents:
diff changeset
132 return (x - y) ^ z;
kono
parents:
diff changeset
133 }
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 int test12(int x)
kono
parents:
diff changeset
136 {
kono
parents:
diff changeset
137 int y = 0x1234;
kono
parents:
diff changeset
138 int z = INT_MIN;
kono
parents:
diff changeset
139 return (x ^ y) - z;
kono
parents:
diff changeset
140 }
kono
parents:
diff changeset
141
kono
parents:
diff changeset
142 unsigned int test12u(unsigned int x)
kono
parents:
diff changeset
143 {
kono
parents:
diff changeset
144 unsigned int y = 0x1234;
kono
parents:
diff changeset
145 unsigned int z = (unsigned int)INT_MIN;
kono
parents:
diff changeset
146 return (x ^ y) - z;
kono
parents:
diff changeset
147 }
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149
kono
parents:
diff changeset
150 void test(int a, int b)
kono
parents:
diff changeset
151 {
kono
parents:
diff changeset
152 if (test1(a) != b)
kono
parents:
diff changeset
153 abort();
kono
parents:
diff changeset
154 if (test2(a) != b)
kono
parents:
diff changeset
155 abort();
kono
parents:
diff changeset
156 if (test3(a) != b)
kono
parents:
diff changeset
157 abort();
kono
parents:
diff changeset
158 if (test4(a) != b)
kono
parents:
diff changeset
159 abort();
kono
parents:
diff changeset
160 if (test5(a) != b)
kono
parents:
diff changeset
161 abort();
kono
parents:
diff changeset
162 if (test6(a) != b)
kono
parents:
diff changeset
163 abort();
kono
parents:
diff changeset
164 if (test7(a) != b)
kono
parents:
diff changeset
165 abort();
kono
parents:
diff changeset
166 if (test8(a) != b)
kono
parents:
diff changeset
167 abort();
kono
parents:
diff changeset
168 if (test9(a) != b)
kono
parents:
diff changeset
169 abort();
kono
parents:
diff changeset
170 if (test10(a) != b)
kono
parents:
diff changeset
171 abort();
kono
parents:
diff changeset
172 if (test11(a) != b)
kono
parents:
diff changeset
173 abort();
kono
parents:
diff changeset
174 if (test12(a) != b)
kono
parents:
diff changeset
175 abort();
kono
parents:
diff changeset
176 }
kono
parents:
diff changeset
177
kono
parents:
diff changeset
178 void testu(unsigned int a, unsigned int b)
kono
parents:
diff changeset
179 {
kono
parents:
diff changeset
180 if (test1u(a) != b)
kono
parents:
diff changeset
181 abort();
kono
parents:
diff changeset
182 if (test2u(a) != b)
kono
parents:
diff changeset
183 abort();
kono
parents:
diff changeset
184 if (test3u(a) != b)
kono
parents:
diff changeset
185 abort();
kono
parents:
diff changeset
186 if (test4u(a) != b)
kono
parents:
diff changeset
187 abort();
kono
parents:
diff changeset
188 if (test5u(a) != b)
kono
parents:
diff changeset
189 abort();
kono
parents:
diff changeset
190 if (test6u(a) != b)
kono
parents:
diff changeset
191 abort();
kono
parents:
diff changeset
192 if (test7u(a) != b)
kono
parents:
diff changeset
193 abort();
kono
parents:
diff changeset
194 if (test8u(a) != b)
kono
parents:
diff changeset
195 abort();
kono
parents:
diff changeset
196 if (test9u(a) != b)
kono
parents:
diff changeset
197 abort();
kono
parents:
diff changeset
198 if (test10u(a) != b)
kono
parents:
diff changeset
199 abort();
kono
parents:
diff changeset
200 if (test11u(a) != b)
kono
parents:
diff changeset
201 abort();
kono
parents:
diff changeset
202 if (test12u(a) != b)
kono
parents:
diff changeset
203 abort();
kono
parents:
diff changeset
204 }
kono
parents:
diff changeset
205
kono
parents:
diff changeset
206
kono
parents:
diff changeset
207 int main()
kono
parents:
diff changeset
208 {
kono
parents:
diff changeset
209 #if INT_MAX == 2147483647
kono
parents:
diff changeset
210 test(0x00000000,0x80001234);
kono
parents:
diff changeset
211 test(0x00001234,0x80000000);
kono
parents:
diff changeset
212 test(0x80000000,0x00001234);
kono
parents:
diff changeset
213 test(0x80001234,0x00000000);
kono
parents:
diff changeset
214 test(0x7fffffff,0xffffedcb);
kono
parents:
diff changeset
215 test(0xffffffff,0x7fffedcb);
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 testu(0x00000000,0x80001234);
kono
parents:
diff changeset
218 testu(0x00001234,0x80000000);
kono
parents:
diff changeset
219 testu(0x80000000,0x00001234);
kono
parents:
diff changeset
220 testu(0x80001234,0x00000000);
kono
parents:
diff changeset
221 testu(0x7fffffff,0xffffedcb);
kono
parents:
diff changeset
222 testu(0xffffffff,0x7fffedcb);
kono
parents:
diff changeset
223 #endif
kono
parents:
diff changeset
224
kono
parents:
diff changeset
225 #if INT_MAX == 32767
kono
parents:
diff changeset
226 test(0x0000,0x9234);
kono
parents:
diff changeset
227 test(0x1234,0x8000);
kono
parents:
diff changeset
228 test(0x8000,0x1234);
kono
parents:
diff changeset
229 test(0x9234,0x0000);
kono
parents:
diff changeset
230 test(0x7fff,0xedcb);
kono
parents:
diff changeset
231 test(0xffff,0x6dcb);
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 testu(0x0000,0x9234);
kono
parents:
diff changeset
234 testu(0x8000,0x1234);
kono
parents:
diff changeset
235 testu(0x1234,0x8000);
kono
parents:
diff changeset
236 testu(0x9234,0x0000);
kono
parents:
diff changeset
237 testu(0x7fff,0xedcb);
kono
parents:
diff changeset
238 testu(0xffff,0x6dcb);
kono
parents:
diff changeset
239 #endif
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 return 0;
kono
parents:
diff changeset
242 }
kono
parents:
diff changeset
243