Mercurial > hg > CbC > old > device
view test/conv.c @ 885:1a027275743d
struct returinng function have to be indirect.
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 05 Apr 2014 21:12:43 +0900 |
parents | 5313ed059cee |
children |
line wrap: on
line source
#define __environment _CbC_environment #define __return _CbC_return #include "stdio.h" f0(int i) { int k,j; k = 3+i; j = g0(i+3); return k+4+j; } g0(int i) { return i+4; } typedef char *stack; struct cont_interface { // General Return Continuation __code (*ret)(); }; __code f(int i,stack sp) { int k,j; k = 3+i; goto f_g0(i,k,sp); } struct f_g0_interface { // Specialized Return Continuation __code (*ret)(); int i_,k_,j_; }; __code f_g1(int j,stack sp); __code f_g0(int i,int k,stack sp) { // Caller struct f_g0_interface *c = (struct f_g0_interface *)(sp -= sizeof(struct f_g0_interface)); c->ret = f_g1; c->k_ = k; c->i_ = i; goto g(i+3,sp); } __code f_g1(int j,stack sp) { // Continuation struct f_g0_interface *c = (struct f_g0_interface *)sp; int k = c->k_; sp += sizeof(struct f_g0_interface); goto (( (struct cont_interface *)sp)->ret)(k+4+j,sp); } __code g(int i,stack sp) { goto (( (struct cont_interface *)sp)->ret)(i+4,sp); } struct main_continuation { // General Return Continuation __code (*ret)(); __code (*main_ret)(); void *env; }; __code main_return(int i,stack sp) { printf("#0064:%d\n",i); goto (( (struct main_continuation *)sp)->main_ret)(0, ((struct main_continuation *)sp)->env); } #define STACK_SIZE 2048 char main_stack[STACK_SIZE]; #define stack_last (&main_stack[STACK_SIZE]) int main() { struct main_continuation *cont; stack sp = stack_last; printf("#0079:%d\n",f0(233)); sp -= sizeof(*cont); cont = (struct main_continuation *)sp; cont->ret = main_return; cont->main_ret = __return; cont->env = __environment; goto f(233,sp); return 0; } /* end */