annotate CbC-examples/conv1/conv1.c @ 106:85047c4f1ca4

add CbC-examples/rectypeTest
author Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp>
date Wed, 13 Jun 2012 17:18:58 +0900
parents 79124facde7c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
31
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 #include <stdio.h>
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 static int loop;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 #if 1 // def __micro_c__
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 #define CC_ONLY 0
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 #else
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 #define CC_ONLY 1
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 #endif
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
9
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 typedef char *stack;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 #include "conv1.h"
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
12
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 /* classical function call case (0) */
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 f0(int i) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 int k,j;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 k = 3+i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 j = g0(i+3);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 return k+4+j;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
20
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 g0(int i) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 return h0(i+4)+i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
24
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
25 h0(int i) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 return i+4;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
28
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 #if !CC_ONLY
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
30
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 /* straight conversion case (1) */
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
32
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
33
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 struct cont_interface { // General Return Continuation
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 __code (*ret)();
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 };
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
37
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 __code f(int i,stack sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 int k,j;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 k = 3+i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 goto f_g0(i,k,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
43
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 struct f_g0_interface { // Specialized Return Continuation
106
85047c4f1ca4 add CbC-examples/rectypeTest
Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
45 __code (*ret)(int,stack);
31
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 int i_,k_,j_;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 };
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
48
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 __code f_g1(int j,stack sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
50
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 __code f_g0(int i,int k,stack sp) { // Caller
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 struct f_g0_interface *c =
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 (struct f_g0_interface *)(sp -= sizeof(struct f_g0_interface));
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
54
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 c->ret = f_g1;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 c->k_ = k;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 c->i_ = i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
58
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 goto g(i+3,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
61
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 __code f_g1(int j,stack sp) { // Continuation
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 struct f_g0_interface *c = (struct f_g0_interface *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 int k = c->k_;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 sp+=sizeof(struct f_g0_interface);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 c = (struct f_g0_interface *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 goto (c->ret)(k+4+j,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
69
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 __code g_h1(int j,stack sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
71
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 __code g(int i,stack sp) { // Caller
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 struct f_g0_interface *c =
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 (struct f_g0_interface *)(sp -= sizeof(struct f_g0_interface));
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
75
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 c->ret = g_h1;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 c->i_ = i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
78
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 goto h(i+3,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
81
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 __code g_h1(int j,stack sp) { // Continuation
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 struct f_g0_interface *c = (struct f_g0_interface *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 int i = c->i_;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 sp+=sizeof(struct f_g0_interface);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 c = (struct f_g0_interface *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 goto (c->ret)(j+i,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
89
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
90 __code h(int i,stack sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 struct f_g0_interface *c = (struct f_g0_interface *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 goto (c->ret)(i+4,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
94
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 struct main_continuation { // General Return Continuation
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 __code (*ret)();
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 __code (*main_ret)(int,void*);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
98 void *env;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 };
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
100
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
101 __code main_return(int i,stack sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 if (loop-->0)
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 goto f(233,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 printf("#0103:%d\n",i);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 goto (( (struct main_continuation *)sp)->main_ret)(0,
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 ((struct main_continuation *)sp)->env);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
108
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
109 /* little optimzation without stack continuation (2) */
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
110
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 __code f2(int i,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 int k,j;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 k = 3+i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 goto g2(i,k,i+3,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
115 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
116
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
117 __code g2(int i,int k,int j,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 j = j+4;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
119 goto h2(i,k+4+j,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
120 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
121
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 __code h2_1(int i,int k,int j,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 goto main_return2(i+j,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
125
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 __code h2(int i,int k,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 goto h2_1(i,k,i+4,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
129
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 __code main_return2(int i,stack sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 if (loop-->0)
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 goto f2(233,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 printf("#0132:%d\n",i);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
134 goto (( (struct main_continuation *)sp)->main_ret)(0,
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 ((struct main_continuation *)sp)->env);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
136 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
137
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
138 /* little optimizaed case (3) */
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
139
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
140 __code f2_1(int i,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
141 int k,j;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 k = 3+i;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
143 goto g2_1(k,i+3,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
145
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
146 __code g2_1(int k,int i,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 goto h2_11(k,i+4,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
148 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
149
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 __code f2_0_1(int k,int j,char *sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 __code h2_1_1(int i,int k,int j,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 goto f2_0_1(k,i+j,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
153 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
154
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 __code h2_11(int i,int k,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
156 goto h2_1_1(i,k,i+4,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
158
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 __code f2_0_1(int k,int j,char *sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
160 goto (( (struct cont_interface *)sp)->ret)(k+4+j,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
162
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
163 __code main_return2_1(int i,stack sp) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
164 if (loop-->0)
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
165 goto f2_1(233,sp);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 printf("#0165:%d\n",i);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 exit(0);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 //goto (( (struct main_continuation *)sp)->main_ret)(0,
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 //((struct main_continuation *)sp)->env);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
171
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
172 #define STACK_SIZE 2048
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 char main_stack[STACK_SIZE];
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 #define stack_last (main_stack+STACK_SIZE)
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
175
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
176 #endif
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
177
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
178 #define LOOP_COUNT 500000000
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 int
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
180 main(int ac,char *av[])
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
181 {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 #if !CC_ONLY
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 struct main_continuation *cont;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 stack sp = stack_last;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 #endif
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 int sw;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 int j;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 if (ac==2) sw = atoi(av[1]);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 else sw=3;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
190
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 if (sw==0) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 for(loop=0;loop<LOOP_COUNT;loop++) {
106
85047c4f1ca4 add CbC-examples/rectypeTest
Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
193 j = f0(loop);
31
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
195 printf("#0193:%d\n",j);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 #if !CC_ONLY
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
197 } else if (sw==1) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
198 loop = LOOP_COUNT;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 sp -= sizeof(*cont);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 cont = (struct main_continuation *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 cont->ret = main_return;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
202 cont->main_ret = _CbC_return;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
203 cont->env = _CbC_environment;
106
85047c4f1ca4 add CbC-examples/rectypeTest
Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
204 goto f(loop,sp);
31
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 } else if (sw==2) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
206 loop = LOOP_COUNT;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 sp -= sizeof(*cont);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 cont = (struct main_continuation *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 cont->ret = main_return2;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
210 cont->main_ret = _CbC_return;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 cont->env = _CbC_environment;
106
85047c4f1ca4 add CbC-examples/rectypeTest
Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
212 goto f2(loop,sp);
31
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
213 } else if (sw==3) {
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
214 loop = LOOP_COUNT;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 sp -= sizeof(*cont);
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
216 cont = (struct main_continuation *)sp;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 cont->ret = main_return2_1;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 cont->main_ret = _CbC_return;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 cont->env = _CbC_environment;
106
85047c4f1ca4 add CbC-examples/rectypeTest
Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp>
parents: 31
diff changeset
220 goto f2_1(loop,sp);
31
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 #endif
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
222 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 return 0;
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 }
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
225
79124facde7c add some tests.
kent <kent@cr.ie.u-ryukyu.ac.jp>
parents:
diff changeset
226 /* end */