annotate gcc/testsuite/gcc.c-torture/execute/20040409-2.c @ 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 #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 unsigned int test3u(unsigned int x)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 return (x + (unsigned int)INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 unsigned int test4u(unsigned int x)
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 return (x ^ 0x1234) + (unsigned int)INT_MIN;
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 unsigned int test5u(unsigned int x)
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 return (x - (unsigned int)INT_MIN) ^ 0x1234;
kono
parents:
diff changeset
38 }
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 unsigned int test6u(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 test7(int x)
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 int y = INT_MIN;
kono
parents:
diff changeset
48 int z = 0x1234;
kono
parents:
diff changeset
49 return (x ^ y) ^ z;
kono
parents:
diff changeset
50 }
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 unsigned int test7u(unsigned int x)
kono
parents:
diff changeset
53 {
kono
parents:
diff changeset
54 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
55 unsigned int z = 0x1234;
kono
parents:
diff changeset
56 return (x ^ y) ^ z;
kono
parents:
diff changeset
57 }
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 int test8(int x)
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 int y = 0x1234;
kono
parents:
diff changeset
62 int z = INT_MIN;
kono
parents:
diff changeset
63 return (x ^ y) ^ z;
kono
parents:
diff changeset
64 }
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 unsigned int test8u(unsigned int x)
kono
parents:
diff changeset
67 {
kono
parents:
diff changeset
68 unsigned int y = 0x1234;
kono
parents:
diff changeset
69 unsigned int z = (unsigned int)INT_MIN;
kono
parents:
diff changeset
70 return (x ^ y) ^ z;
kono
parents:
diff changeset
71 }
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 unsigned int test9u(unsigned int x)
kono
parents:
diff changeset
74 {
kono
parents:
diff changeset
75 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
76 unsigned int z = 0x1234;
kono
parents:
diff changeset
77 return (x + y) ^ z;
kono
parents:
diff changeset
78 }
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 unsigned int test10u(unsigned int x)
kono
parents:
diff changeset
81 {
kono
parents:
diff changeset
82 unsigned int y = 0x1234;
kono
parents:
diff changeset
83 unsigned int z = (unsigned int)INT_MIN;
kono
parents:
diff changeset
84 return (x ^ y) + z;
kono
parents:
diff changeset
85 }
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 unsigned int test11u(unsigned int x)
kono
parents:
diff changeset
88 {
kono
parents:
diff changeset
89 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
90 unsigned int z = 0x1234;
kono
parents:
diff changeset
91 return (x - y) ^ z;
kono
parents:
diff changeset
92 }
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 unsigned int test12u(unsigned int x)
kono
parents:
diff changeset
95 {
kono
parents:
diff changeset
96 unsigned int y = 0x1234;
kono
parents:
diff changeset
97 unsigned int z = (unsigned int)INT_MIN;
kono
parents:
diff changeset
98 return (x ^ y) - z;
kono
parents:
diff changeset
99 }
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101
kono
parents:
diff changeset
102 void test(int a, int b)
kono
parents:
diff changeset
103 {
kono
parents:
diff changeset
104 if (test1(a) != b)
kono
parents:
diff changeset
105 abort();
kono
parents:
diff changeset
106 if (test2(a) != b)
kono
parents:
diff changeset
107 abort();
kono
parents:
diff changeset
108 if (test7(a) != b)
kono
parents:
diff changeset
109 abort();
kono
parents:
diff changeset
110 if (test8(a) != b)
kono
parents:
diff changeset
111 abort();
kono
parents:
diff changeset
112 }
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 void testu(unsigned int a, unsigned int b)
kono
parents:
diff changeset
115 {
kono
parents:
diff changeset
116 if (test1u(a) != b)
kono
parents:
diff changeset
117 abort();
kono
parents:
diff changeset
118 if (test2u(a) != b)
kono
parents:
diff changeset
119 abort();
kono
parents:
diff changeset
120 if (test3u(a) != b)
kono
parents:
diff changeset
121 abort();
kono
parents:
diff changeset
122 if (test4u(a) != b)
kono
parents:
diff changeset
123 abort();
kono
parents:
diff changeset
124 if (test5u(a) != b)
kono
parents:
diff changeset
125 abort();
kono
parents:
diff changeset
126 if (test6u(a) != b)
kono
parents:
diff changeset
127 abort();
kono
parents:
diff changeset
128 if (test7u(a) != b)
kono
parents:
diff changeset
129 abort();
kono
parents:
diff changeset
130 if (test8u(a) != b)
kono
parents:
diff changeset
131 abort();
kono
parents:
diff changeset
132 if (test9u(a) != b)
kono
parents:
diff changeset
133 abort();
kono
parents:
diff changeset
134 if (test10u(a) != b)
kono
parents:
diff changeset
135 abort();
kono
parents:
diff changeset
136 if (test11u(a) != b)
kono
parents:
diff changeset
137 abort();
kono
parents:
diff changeset
138 if (test12u(a) != b)
kono
parents:
diff changeset
139 abort();
kono
parents:
diff changeset
140 }
kono
parents:
diff changeset
141
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143 int main()
kono
parents:
diff changeset
144 {
kono
parents:
diff changeset
145 #if INT_MAX == 2147483647
kono
parents:
diff changeset
146 test(0x00000000,0x80001234);
kono
parents:
diff changeset
147 test(0x00001234,0x80000000);
kono
parents:
diff changeset
148 test(0x80000000,0x00001234);
kono
parents:
diff changeset
149 test(0x80001234,0x00000000);
kono
parents:
diff changeset
150 test(0x7fffffff,0xffffedcb);
kono
parents:
diff changeset
151 test(0xffffffff,0x7fffedcb);
kono
parents:
diff changeset
152
kono
parents:
diff changeset
153 testu(0x00000000,0x80001234);
kono
parents:
diff changeset
154 testu(0x00001234,0x80000000);
kono
parents:
diff changeset
155 testu(0x80000000,0x00001234);
kono
parents:
diff changeset
156 testu(0x80001234,0x00000000);
kono
parents:
diff changeset
157 testu(0x7fffffff,0xffffedcb);
kono
parents:
diff changeset
158 testu(0xffffffff,0x7fffedcb);
kono
parents:
diff changeset
159 #endif
kono
parents:
diff changeset
160
kono
parents:
diff changeset
161 #if INT_MAX == 32767
kono
parents:
diff changeset
162 test(0x0000,0x9234);
kono
parents:
diff changeset
163 test(0x1234,0x8000);
kono
parents:
diff changeset
164 test(0x8000,0x1234);
kono
parents:
diff changeset
165 test(0x9234,0x0000);
kono
parents:
diff changeset
166 test(0x7fff,0xedcb);
kono
parents:
diff changeset
167 test(0xffff,0x6dcb);
kono
parents:
diff changeset
168
kono
parents:
diff changeset
169 testu(0x0000,0x9234);
kono
parents:
diff changeset
170 testu(0x8000,0x1234);
kono
parents:
diff changeset
171 testu(0x1234,0x8000);
kono
parents:
diff changeset
172 testu(0x9234,0x0000);
kono
parents:
diff changeset
173 testu(0x7fff,0xedcb);
kono
parents:
diff changeset
174 testu(0xffff,0x6dcb);
kono
parents:
diff changeset
175 #endif
kono
parents:
diff changeset
176
kono
parents:
diff changeset
177 return 0;
kono
parents:
diff changeset
178 }
kono
parents:
diff changeset
179