--- gforth/engine/threaded.h 2000/12/24 15:54:18 1.9 +++ gforth/engine/threaded.h 2003/03/09 15:17:04 1.22 @@ -1,6 +1,6 @@ /* This file defines a number of threading schemes. - Copyright (C) 1995, 1996,1997,1999 Free Software Foundation, Inc. + Copyright (C) 1995, 1996,1997,1999,2003 Free Software Foundation, Inc. This file is part of Gforth. @@ -91,33 +91,69 @@ */ -/* CFA_NEXT: if NEXT uses cfa, you have to #define CFA_NEXT, to get - * cfa declared in engine. - */ - #ifdef DOUBLY_INDIRECT -# define CFA_NEXT +# ifndef DEBUG_DITC +# define DEBUG_DITC 0 +# endif +/* define to 1 if you want to check consistency */ # define NEXT_P0 ({cfa=*ip;}) # define IP (ip) # define SET_IP(p) ({ip=(p); NEXT_P0;}) # define NEXT_INST (cfa) # define INC_IP(const_inc) ({cfa=IP[const_inc]; ip+=(const_inc);}) # define DEF_CA Label ca; -# define NEXT_P1 ({ip++; ca=**cfa;}) -# define NEXT_P2 ({goto *ca;}) -# define EXEC(XT) ({DEF_CA cfa=(XT); ca=**cfa; goto *ca;}) -# define NEXT1_P1 ({ca = **cfa;}) -# define NEXT1_P2 ({goto *ca;}) +# define NEXT_P1 ({\ + if (DEBUG_DITC && (cfa<=vm_prims+DOESJUMP || cfa>=vm_prims+npriminfos)) \ + fprintf(stderr,"NEXT encountered prim %p at ip=%p\n", cfa, ip); \ + ip++;}) +# define NEXT_P2 ({ca=**cfa; goto *ca;}) +# define EXEC(XT) ({DEF_CA cfa=(XT);\ + if (DEBUG_DITC && (cfa>vm_prims+DOESJUMP && cfa