Diff for /gforth/prim between versions 1.246 and 1.248

version 1.246, 2010/04/05 22:17:56 version 1.248, 2010/04/25 18:27:09
Line 229  fprintf(stderr, "dodoes to %x, push %x\n Line 229  fprintf(stderr, "dodoes to %x, push %x\n
 SET_IP(DOES_CODE1(CFA));  SET_IP(DOES_CODE1(CFA));
 #endif /* !defined(NO_IP) */  #endif /* !defined(NO_IP) */
   
 (does-handler) ( -- )   gforth-internal paren_does_handler  (doabicode) ( ... -- ...)       gforth-internal paren_doabicode
 ""just a slot to have an encoding for the DOESJUMP,   ""run-time routine for @code{ABI-code} definitions""
 which is no longer used anyway (!! eliminate this)""  abifunc *f = (abifunc *)PFA(CFA);
   Float *fp_mem = fp;
 (doabicode) ( s:... f:... -- s:... f:...)       gforth-internal paren_doabicode  sp = (*f)(sp, &fp_mem);
 ""run-time routine for ABI-CODE definitions""  fp = fp_mem;
 struct abi_code_ret_t {    #ifdef NO_IP
     Cell *sp;   INST_TAIL;
     double * fp;   goto *next_code;
 } ret = ((struct abi_code_ret_t(*)(Cell *, double *))(PFA(CFA)))(sp, fp);  #endif /* defined(NO_IP) */
 sp = ret.sp;  
 fp = ret.fp;  (do;abicode) ( ... -- ... ) gforth-internal paren_do_semicolon_abi_code
   ""run-time routine for @code{;abi-code}-defined words""
   Float *fp_mem = fp;
   Address body = (Address)PFA(CFA);
   semiabifunc *f = (semiabifunc *)DOES_CODE1(CFA);
   sp = (*f)(sp, &fp_mem, body);
   fp = fp_mem;
 #ifdef NO_IP  #ifdef NO_IP
 INST_TAIL;  INST_TAIL;
 goto *next_code;  goto *next_code;
Line 638  k ( R:w R:w1 R:w2 R:w3 R:w4 -- w R:w R:w Line 644  k ( R:w R:w1 R:w2 R:w3 R:w4 -- w R:w R:w
   
 \ digit is high-level: 0/0%  \ digit is high-level: 0/0%
   
 abi-call        ( #a_callee s:... f:... -- s:... f:... )        gforth  abi_call  
 struct abi_code_ret_t {    
     Cell *sp;   
     double * fp;   
 } ret = ((struct abi_code_ret_t(*)(Cell *, double *))(a_callee))(sp, fp);  
 sp = ret.sp;  
 fp = ret.fp;  
   
 \g strings  \g strings
   
 move    ( c_from c_to ucount -- )               core  move    ( c_from c_to ucount -- )               core
Line 2541  a_addr = groups; Line 2539  a_addr = groups;
   
 \+  \+
   
   \g primitive_centric
   
   \ primitives for primitive-centric code
   \ another one is does-exec
   
   abi-call        ( #a_callee ... -- ... ) gforth-internal abi_call
   /* primitive for compiled ABI-CODE words */
   abifunc *f = (abifunc *)a_callee;
   Float *fp_mem = fp;
   sp = (*f)(sp, &fp_mem);
   fp = fp_mem;
   
   ;abi-code-exec ( #a_cfa ... -- ... ) gforth-internal semi_abi_code_exec
   /* primitive for performing ;ABI-CODE words */
   Float *fp_mem = fp;
   semiabifunc *f = (semiabifunc *)DOES_CODE1(a_cfa);
   Address body = (Address)PFA(a_cfa);
   sp = (*f)(sp, &fp_mem, body);
   fp = fp_mem;
   
   ;code-exec ( #a_cfa -- ) gforth-internal semi_code_exec
   /* routine for performing ;code-defined words */
   SUPER_END;
   VM_JUMP(EXEC1(a_cfa));
   
   
 \g static_super  \g static_super
   
 ifdef(`STACK_CACHE_FILE',  ifdef(`STACK_CACHE_FILE',

Removed from v.1.246  
changed lines
  Added in v.1.248


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>