--- gforth/engine/threaded.h 2005/01/23 13:56:13 1.30 +++ gforth/engine/threaded.h 2007/02/26 19:07:05 1.36 @@ -1,6 +1,6 @@ /* This file defines a number of threading schemes. - Copyright (C) 1995, 1996,1997,1999,2003,2004 Free Software Foundation, Inc. + Copyright (C) 1995, 1996,1997,1999,2003,2004,2005 Free Software Foundation, Inc. This file is part of Gforth. @@ -91,22 +91,36 @@ */ -#ifdef GCC_PR15242_WORKAROUND +#if !defined(GCC_PR15242_WORKAROUND) +#if __GNUC__ == 3 +/* various gcc-3.x version have problems (including PR15242) that are + solved with this workaround */ +#define GCC_PR15242_WORKAROUND 1 +#else +/* other gcc versions are better off without the workaround for + primitives that are not relocatable */ +#define GCC_PR15242_WORKAROUND 0 +#endif +#endif + +#if GCC_PR15242_WORKAROUND #define DO_GOTO goto before_goto #else #define DO_GOTO goto *real_ca #endif + #ifndef GOTO_ALIGN #define GOTO_ALIGN #endif #define GOTO(target) do {(real_ca=(target));} while(0) #define NEXT_P2 do {NEXT_P1_5; DO_GOTO;} while(0) -#define EXEC(XT) do { EXEC1(XT); DO_GOTO;} while (0) +#define EXEC(XT) do { real_ca=EXEC1(XT); DO_GOTO;} while (0) +#define VM_JUMP(target) do {GOTO(target);} while (0) #define NEXT do {DEF_CA NEXT_P1; NEXT_P2;} while(0) #define FIRST_NEXT_P2 NEXT_P1_5; GOTO_ALIGN; \ before_goto: goto *real_ca; after_goto: -#define FIRST_NEXT DEF_CA NEXT_P1; FIRST_NEXT_P2; +#define FIRST_NEXT do {DEF_CA NEXT_P1; FIRST_NEXT_P2;} while(0) #define IPTOS NEXT_INST @@ -128,10 +142,10 @@ before_goto: goto *real_ca; after_goto: fprintf(stderr,"NEXT encountered prim %p at ip=%p\n", cfa, ip); \ ip++;} while(0) # define NEXT_P1_5 do {ca=**cfa; GOTO(ca);} while(0) -# define EXEC1(XT) do {DEF_CA cfa=(XT);\ +# define EXEC1(XT) ({DEF_CA cfa=(XT);\ if (DEBUG_DITC && (cfa>vm_prims+DOESJUMP && cfa