move backend into libfirm
[libfirm] / ir / be / test / ll.c
1 #include <stdio.h>
2 #include <stdlib.h>
3
4 typedef long long int ll_t;
5
6 #ifdef __GNUC__
7 ll_t mul_ll(ll_t a, ll_t b) __attribute__((noinline));
8 ll_t shl_ll(ll_t a, ll_t b) __attribute__((noinline));
9 ll_t shr_ll(ll_t a, ll_t b) __attribute__((noinline));
10 ll_t add_ll(ll_t a, ll_t b) __attribute__((noinline));
11 ll_t sub_ll(ll_t a, ll_t b) __attribute__((noinline));
12 ll_t div_ll(ll_t a, ll_t b) __attribute__((noinline));
13 ll_t mod_ll(ll_t a, ll_t b) __attribute__((noinline));
14 ll_t divmod_ll(ll_t a, ll_t b) __attribute__((noinline));
15 ll_t abs_ll(ll_t a) __attribute__((noinline));
16 ll_t neg_ll(ll_t a) __attribute__((noinline));
17 #endif
18
19 ll_t mul_ll(ll_t a, ll_t b) {
20         return a * b;
21 }
22
23 ll_t shl_ll(ll_t a, ll_t b) {
24         return a << b;
25 }
26
27 ll_t shr_ll(ll_t a, ll_t b) {
28         return a >> b;
29 }
30
31 ll_t add_ll(ll_t a, ll_t b) {
32         return a + b;
33 }
34
35 ll_t sub_ll(ll_t a, ll_t b) {
36         return a - b;
37 }
38
39 ll_t div_ll(ll_t a, ll_t b) {
40         return a / b;
41 }
42
43 ll_t mod_ll(ll_t a, ll_t b) {
44         return a % b;
45 }
46
47 ll_t divmod_ll(ll_t a, ll_t b) {
48         return (a / b) + (a % b);
49 }
50
51 ll_t neg_ll(ll_t a) {
52         return -a;
53 }
54
55 ll_t abs_ll(ll_t a) {
56         return llabs(a);
57 }
58
59 #if 0
60 double conv_ll_d(ll_t a) {
61         return (double)a;
62 }
63
64 ll_t conv_d_ll(double a) {
65         return (ll_t)a;
66 }
67 #endif
68
69 int main(void) {
70         ll_t a = 0xff;
71         ll_t b = 0x123456789;
72         ll_t c = 0x8001023000002460;
73         double d = (double)c;
74
75         printf("%lld * %lld  = %lld\n", a, b, mul_ll(a, b));
76         printf("%lld + %lld  = %lld\n", a, b, add_ll(a, b));
77         printf("%lld - %lld  = %lld\n", a, b, sub_ll(a, b));
78         printf("%lld / %lld  = %lld\n", b, a, div_ll(b, a));
79         printf("%lld %% %lld  = %lld\n", b, a, mod_ll(b, a));
80         printf("%lld / + %% %lld  = %lld\n", b, a, divmod_ll(b, a));
81         printf("%lld << %d = %lld\n", a, 2, shl_ll(a, 2));
82         printf("%lld >> %d = %lld\n", a, 2, shr_ll(a, 2));
83         printf("abs(%lld)    = %lld\n", c, abs_ll(c));
84         printf("neg(%lld)    = %lld\n", b, neg_ll(b));
85 #if 0
86         printf("conv(%lld)   = %lf\n",  c, conv_ll_d(c));
87         printf("conv(%lf)    = %lld\n", d, conv_d_ll(d));
88 #endif
89         return 0;
90 }