more test added
[libfirm] / ir / be / test / localopts.c
1 /*$ -fno-inline $*/
2 #include <stdio.h>
3
4 #define CONST 42
5
6 int mul0(int x)
7 {
8         return -x * CONST;
9 }
10
11 int mul1(int x, int y)
12 {
13         return -x * -y;
14 }
15
16 int mul2(int x, int y, int z)
17 {
18         return -x * (y - z);
19 }
20
21 int mul3(int x, int y, int z)
22 {
23         return (x - y) * z;
24 }
25
26 int sub0(int x, int y, int z)
27 {
28         return x - (y - z);
29 }
30
31 int sub1(int x, int y)
32 {
33         return x - (y * CONST);
34 }
35
36 int sub2(int x, int y)
37 {
38         return x - -y;
39 }
40
41 int sub3(int x, int y)
42 {
43         return -x - y;
44 }
45
46 int sub4(int x) {
47         return 6 - ~x;
48 }
49
50 int cmp1(int x, int y) {
51         return -x == -y;
52 }
53
54 int cmp2(int x, int y) {
55         return -x != -y;
56 }
57
58 int cmp3(int x, int y) {
59         return ~x == ~y;
60 }
61
62 int cmp4(int x, int y) {
63         return ~x != ~y;
64 }
65
66 int cmp5(int x, int y, int z) {
67         return x + z == z + y;
68 }
69
70 int cmp6(int x, int y, int z) {
71         return x + z != y + z;
72 }
73
74 int cmp7(int x, int y, int z) {
75         return x - z == y - z;
76 }
77
78 int cmp8(int x, int y, int z) {
79         return z -x != z - y;
80 }
81
82 int cmp9(int x) {
83         return -x == 3;
84 }
85
86 int cmp10(int x) {
87         return -x != 3;
88 }
89
90 int and1(int a, int b) {
91         return (a|b)&a;
92 }
93
94 int and2(int a, int b) {
95         return (a|b) & ~(a&b);
96 }
97
98 int and3(int a) {
99         return (a & 2) == 2;
100 }
101
102 int add1(int x) {
103         return x + ~x;
104 }
105
106 int shr1(int x) {
107         return -(x >> 31);
108 }
109
110 int shrs1(unsigned x) {
111         return -(x >> 31);
112 }
113
114 int demorgan1(int a, int b) {
115         return (~a) & (~b);
116 }
117
118 int demorgan2(int a, int b) {
119         return (~a) | (~b);
120 }
121
122 int eor1(int a, int b) {
123         return a & (a ^ b);
124 }
125
126 int shl1(int a) {
127         return (a << 3) == (5<<3);
128 }
129
130 int shl2(int a) {
131         return (a << 3) == 41;
132 }
133
134 int shr2(unsigned int a) {
135         return (a >> 3) == 5;
136 }
137
138 int shr3(unsigned int a) {
139         return (a >> 3) == (1 << 29);
140 }
141
142 int shrs2(int a) {
143         return (a >> 3) == 5;
144 }
145
146 int shrs3(int a) {
147         return (a >> 3) == -5;
148 }
149
150 int shrs4(int a) {
151         return (a >> 3) == (1 << 29);
152 }
153
154 int main(void)
155 {
156 #define TU(func,x,expect) \
157         printf("%s(%d) = %d (should be %d)\n", #func, x, func(x), expect);
158 #define TB(func,x,y,expect) \
159         printf("%s(%d,%d) = %d (should be %d)\n", #func, x, y, func(x,y), expect);
160 #define TT(func,x,y,z,expect) \
161         printf("%s(%d,%d,%d) = %d (should be %d)\n", #func, x, y, z, func(x,y,z), expect);
162
163         TU(mul0, 3, -126);
164         TB(mul1, 20, 3, 60);
165         TT(mul2, 9, 2, 5, 27);
166         TT(mul3, 5, 2, 9, 27);
167         TT(sub0, 42, 17, 59, 84);
168         TB(sub1, 23, 17, -691);
169         TB(sub2, 42, 17, 59);
170         TB(sub3, 42, 17, -59);
171         TU(sub4, 42, 49);
172         TB(cmp1, 42, 17, 0);
173         TB(cmp2, 42, 17, 1);
174         TB(cmp3, 42, 17, 0);
175         TB(cmp4, 42, 17, 1);
176         TT(cmp5, 42, 17, -4, 0);
177         TT(cmp6, 42, 17, -4, 1);
178         TT(cmp7, 42, 17, -4, 0);
179         TT(cmp8, 42, 17, -4, 1);
180         TU(cmp9, -3, 1);
181         TU(cmp10, -3, 0);
182         TB(and1, 42, 17, 42);
183         TB(and2, 42, 17, 42^17);
184         TU(and3, 34, 1);
185         TU(add1, -3, -1);
186         TU(shr1, -3, 1);
187         TU(shrs1, -3, -1);
188         TB(demorgan1, 42, 17, ~(42|17));
189         TB(demorgan2, 42, 17, ~(42&17));
190         TB(eor1, 42, 44, 42&~44);
191         TU(shl1, 5, 1);
192         TU(shl1, 6, 0);
193         TU(shl2, 5, 0);
194         TU(shr2, 5<<3, 1);
195         TU(shr2, 6<<3, 0);
196         TU(shr3, 5, 0);
197         TU(shrs2, 5<<3, 1);
198         TU(shrs2, 6<<3, 0);
199         TU(shrs3, -5<<3, 1);
200         TU(shrs3, -6<<3, 0);
201         TU(shrs4, 5, 0);
202 }