--- gforth/engine/libcc.h.in 2012/03/22 16:27:11 1.13 +++ gforth/engine/libcc.h.in 2012/10/05 22:41:24 1.18 @@ -19,7 +19,6 @@ */ #include -#include #if defined(_WIN32) || defined(__WIN32__) || defined(__CYGWIN__) || defined(__ANDROID__) #undef HAS_BACKLINK @@ -28,21 +27,37 @@ #endif typedef CELL_TYPE Cell; +typedef unsigned char Char; typedef double Float; +typedef Char *Address; +typedef void **Xt; #define Clongest long long typedef unsigned Clongest UClongest; +typedef struct { + Cell next_task; + Cell prev_task; + Cell save_task; + Cell* sp0; + Cell* rp0; + Float* fp0; + Address lp0; + Xt *throw_entry; +} user_area; + #ifdef HAS_BACKLINK extern __thread Cell *gforth_SP; extern __thread Float *gforth_FP; extern __thread Cell *gforth_RP; extern __thread char *gforth_LP; extern __thread char *gforth_UP; -extern void *gforth_engine(void *, Cell *, Cell *, Float *, char *); +extern void *gforth_engine(void *); extern char *cstr(char *from, Cell size); extern char *tilde_cstr(char *from, Cell size); -extern __thread jmp_buf throw_jmp_buf; +extern __thread void *throw_jmp_handler; +extern user_area* gforth_stacks(Cell dsize, Cell rsize, Cell fsize, Cell lsize); +extern void gforth_free_stacks(user_area* t); #define GFORTH_ARGS void #else #define gforth_SP *((Cell **)(gforth_pointers(0))) @@ -50,10 +65,12 @@ extern __thread jmp_buf throw_jmp_buf; #define gforth_LP *((char **)(gforth_pointers(2))) #define gforth_RP *((Cell **)(gforth_pointers(3))) #define gforth_UP *((char **)(gforth_pointers(4))) -#define gforth_engine ((char *(*)(void *, Cell *, Cell *, Float *, char *))(((void **)(gforth_pointers(5))))) -#define cstr ((char *(*)(char *, Cell))(((void **)(gforth_pointers(6))))) -#define tilde_cstr ((char *(*)(char *, Cell))(((void **)(gforth_pointers(7))))) -#define throw_jmp_buf *((jmp_buf*)(gforth_pointers(8))) +#define gforth_engine ((char *(*)(void *))gforth_pointers(5)) +#define cstr ((char *(*)(char *, Cell))gforth_pointers(6)) +#define tilde_cstr ((char *(*)(char *, Cell))gforth_pointers(7)) +#define throw_jmp_handler *((void**)(gforth_pointers(8))) +#define gforth_stacks ((user_area *(*)(Cell, Cell, Cell, Cell))gforth_pointers(9)) +#define gforth_free_stacks ((void(*)(user_area* t))gforth_pointers(10)) #define GFORTH_ARGS void *(*gforth_pointers)(Cell) #endif