annotate gcc/testsuite/gcc.c-torture/execute/20040409-1.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;
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;
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 + 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 + (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;
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;
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 int y = INT_MIN;
kono
parents:
diff changeset
38 return x ^ y;
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 unsigned int test4u(unsigned int x)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
44 return x ^ y;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 int test5(int x)
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 int y = INT_MIN;
kono
parents:
diff changeset
50 return x + y;
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 unsigned int test5u(unsigned int x)
kono
parents:
diff changeset
54 {
kono
parents:
diff changeset
55 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
56 return x + y;
kono
parents:
diff changeset
57 }
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 int test6(int x)
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 int y = INT_MIN;
kono
parents:
diff changeset
62 return x - y;
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 unsigned int test6u(unsigned int x)
kono
parents:
diff changeset
66 {
kono
parents:
diff changeset
67 unsigned int y = (unsigned int)INT_MIN;
kono
parents:
diff changeset
68 return x - y;
kono
parents:
diff changeset
69 }
kono
parents:
diff changeset
70
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 void test(int a, int b)
kono
parents:
diff changeset
74 {
kono
parents:
diff changeset
75 if (test1(a) != b)
kono
parents:
diff changeset
76 abort();
kono
parents:
diff changeset
77 if (test2(a) != b)
kono
parents:
diff changeset
78 abort();
kono
parents:
diff changeset
79 if (test3(a) != b)
kono
parents:
diff changeset
80 abort();
kono
parents:
diff changeset
81 if (test4(a) != b)
kono
parents:
diff changeset
82 abort();
kono
parents:
diff changeset
83 if (test5(a) != b)
kono
parents:
diff changeset
84 abort();
kono
parents:
diff changeset
85 if (test6(a) != b)
kono
parents:
diff changeset
86 abort();
kono
parents:
diff changeset
87 }
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 void testu(unsigned int a, unsigned int b)
kono
parents:
diff changeset
90 {
kono
parents:
diff changeset
91 if (test1u(a) != b)
kono
parents:
diff changeset
92 abort();
kono
parents:
diff changeset
93 if (test2u(a) != b)
kono
parents:
diff changeset
94 abort();
kono
parents:
diff changeset
95 if (test3u(a) != b)
kono
parents:
diff changeset
96 abort();
kono
parents:
diff changeset
97 if (test4u(a) != b)
kono
parents:
diff changeset
98 abort();
kono
parents:
diff changeset
99 if (test5u(a) != b)
kono
parents:
diff changeset
100 abort();
kono
parents:
diff changeset
101 if (test6u(a) != b)
kono
parents:
diff changeset
102 abort();
kono
parents:
diff changeset
103 }
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 int main()
kono
parents:
diff changeset
107 {
kono
parents:
diff changeset
108 #if INT_MAX == 2147483647
kono
parents:
diff changeset
109 test(0x00000000,0x80000000);
kono
parents:
diff changeset
110 test(0x80000000,0x00000000);
kono
parents:
diff changeset
111 test(0x12345678,0x92345678);
kono
parents:
diff changeset
112 test(0x92345678,0x12345678);
kono
parents:
diff changeset
113 test(0x7fffffff,0xffffffff);
kono
parents:
diff changeset
114 test(0xffffffff,0x7fffffff);
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 testu(0x00000000,0x80000000);
kono
parents:
diff changeset
117 testu(0x80000000,0x00000000);
kono
parents:
diff changeset
118 testu(0x12345678,0x92345678);
kono
parents:
diff changeset
119 testu(0x92345678,0x12345678);
kono
parents:
diff changeset
120 testu(0x7fffffff,0xffffffff);
kono
parents:
diff changeset
121 testu(0xffffffff,0x7fffffff);
kono
parents:
diff changeset
122 #endif
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 #if INT_MAX == 32767
kono
parents:
diff changeset
125 test(0x0000,0x8000);
kono
parents:
diff changeset
126 test(0x8000,0x0000);
kono
parents:
diff changeset
127 test(0x1234,0x9234);
kono
parents:
diff changeset
128 test(0x9234,0x1234);
kono
parents:
diff changeset
129 test(0x7fff,0xffff);
kono
parents:
diff changeset
130 test(0xffff,0x7fff);
kono
parents:
diff changeset
131
kono
parents:
diff changeset
132 testu(0x0000,0x8000);
kono
parents:
diff changeset
133 testu(0x8000,0x0000);
kono
parents:
diff changeset
134 testu(0x1234,0x9234);
kono
parents:
diff changeset
135 testu(0x9234,0x1234);
kono
parents:
diff changeset
136 testu(0x7fff,0xffff);
kono
parents:
diff changeset
137 testu(0xffff,0x7fff);
kono
parents:
diff changeset
138 #endif
kono
parents:
diff changeset
139
kono
parents:
diff changeset
140 return 0;
kono
parents:
diff changeset
141 }
kono
parents:
diff changeset
142