Diff for /gforth/Attic/forth.h between versions 1.9 and 1.26

version 1.9, 1994/09/05 17:36:17 version 1.26, 1996/10/13 19:56:21
Line 1 Line 1
 /*  /* common header file
   $Id$  
   Copyright 1992 by the ANSI figForth Development Group    Copyright (C) 1995 Free Software Foundation, Inc.
   
     This file is part of Gforth.
   
     Gforth is free software; you can redistribute it and/or
     modify it under the terms of the GNU General Public License
     as published by the Free Software Foundation; either version 2
     of the License, or (at your option) any later version.
   
     This program is distributed in the hope that it will be useful,
     but WITHOUT ANY WARRANTY; without even the implied warranty of
     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     GNU General Public License for more details.
   
     You should have received a copy of the GNU General Public License
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */  */
   
 /* common header file */  #include "config.h"
   #include <limits.h>
   #if defined(NeXT)
   #  include <libc.h>
   #endif /* NeXT */
   
 typedef void *Label;  typedef void *Label;
   
Line 14  typedef void *Label; Line 34  typedef void *Label;
 #define DOVAR   2  #define DOVAR   2
 #define DOUSER  3  #define DOUSER  3
 #define DODEFER 4  #define DODEFER 4
 #define DODOES  5  #define DOFIELD 5
 #define DOESJUMP        6  #define DODOES  6
   #define DOESJUMP        7
 /* Some versions of some unices (Linux) have the symbol BIG_ENDIAN defined  
    in their standard headers. Make sure it's undefined -- Lennart */  
 #ifdef BIG_ENDIAN  
 #undef BIG_ENDIAN  
 #endif  
   
 #include "machine.h"  #include "machine.h"
   
 /* Forth data types */  /* Forth data types */
 typedef int Bool;  /* Cell and UCell must be the same size as a pointer */
   typedef CELL_TYPE Cell;
   typedef unsigned CELL_TYPE UCell;
   #define CELL_BITS       (sizeof(Cell) * CHAR_BIT)
   typedef Cell Bool;
 #define FLAG(b) (-(b))  #define FLAG(b) (-(b))
 #define FILEIO(error)   (FLAG(error) & -37)  #define FILEIO(error)   (FLAG(error) & -37)
 #define FILEEXIST(error)        (FLAG(error) & -38)  #define FILEEXIST(error)        (FLAG(error) & -38)
Line 38  typedef unsigned char Char; Line 57  typedef unsigned char Char;
 typedef double Float;  typedef double Float;
 typedef char *Address;  typedef char *Address;
   
   #ifdef BUGGY_LONG_LONG
   typedef struct {
     Cell hi;
     UCell lo;
   } DCell;
   
   typedef struct {
     UCell hi;
     UCell lo;
   } UDCell;
   
   #define FETCH_DCELL(d,lo,hi)    ((d)=(typeof(d)){(hi),(lo)})
   #define STORE_DCELL(d,low,high) ({ \
                                        typeof(d) _d = (d); \
                                        (low) = _d.lo; \
                                        (high)= _d.hi; \
                                    })
   
   #define LONG2UD(l)      ({UDCell _ud; _ud.hi=0; _ud.lo=(Cell)(l); _ud;})
   #define UD2LONG(ud)     ((long)(ud.lo))
   #define DZERO           ((DCell){0,0})
   
   #else /* ! defined(BUGGY_LONG_LONG) */
   
   /* DCell and UDCell must be twice as large as Cell */
   typedef DOUBLE_CELL_TYPE DCell;
   typedef unsigned DOUBLE_CELL_TYPE UDCell;
   
   typedef union {
     struct {
   #ifdef WORDS_BIGENDIAN
       Cell high;
       UCell low;
   #else
       UCell low;
       Cell high;
   #endif;
     } cells;
     DCell dcell;
   } Double_Store;
   
   #define FETCH_DCELL(d,lo,hi)    ({ \
                                        Double_Store _d; \
                                        _d.cells.low = (lo); \
                                        _d.cells.high = (hi); \
                                        (d) = _d.dcell; \
                                    })
   
   #define STORE_DCELL(d,lo,hi)    ({ \
                                        Double_Store _d; \
                                        _d.dcell = (d); \
                                        (lo) = _d.cells.low; \
                                        (hi) = _d.cells.high; \
                                    })
   
   #define LONG2UD(l)      ((UDCell)(l))
   #define UD2LONG(ud)     ((long)(ud))
   #define DZERO           ((DCell)0)
   
   #endif /* ! defined(BUGGY_LONG_LONG) */
   
 #ifdef DIRECT_THREADED  #ifdef DIRECT_THREADED
 typedef Label Xt;  typedef Label Xt;
 #else  #else
 typedef Label *Xt;  typedef Label *Xt;
 #endif  #endif
   
 Label *engine(Xt *ip, Cell *sp, Cell *rp, Float *fp, Address lp);  
   
 #ifndef DIRECT_THREADED  #ifndef DIRECT_THREADED
 /* i.e. indirect threaded */  /* i.e. indirect threaded */
 /* the direct threaded version is machine dependent and resides in machine.h */  /* the direct threaded version is machine dependent and resides in machine.h */
Line 56  Label *engine(Xt *ip, Cell *sp, Cell *rp Line 134  Label *engine(Xt *ip, Cell *sp, Cell *rp
 #define PFA1(cfa)       PFA(cfa)  #define PFA1(cfa)       PFA(cfa)
 /* CODE_ADDRESS is the address of the code jumped to through the code field */  /* CODE_ADDRESS is the address of the code jumped to through the code field */
 #define CODE_ADDRESS(cfa)       (*(Label *)(cfa))  #define CODE_ADDRESS(cfa)       (*(Label *)(cfa))
       /* DOES_CODE is the Forth code does jumps to */  /* DOES_CODE is the Forth code does jumps to */
 #define DOES_CODE(cfa)           (cfa[1])  #define DOES_CODE(cfa)  ({Xt _cfa=(Xt)(cfa); \
 #define DOES_CODE1(cfa)          DOES_CODE(cfa)                            _cfa[0] == symbols[DODOES] ? _cfa[1] : NULL;})
   #define DOES_CODE1(cfa) (cfa[1])
 /* MAKE_CF creates an appropriate code field at the cfa;  /* MAKE_CF creates an appropriate code field at the cfa;
    ca is the code address */     ca is the code address */
 #define MAKE_CF(cfa,ca) ((*(Label *)(cfa)) = ((Label)ca))  #define MAKE_CF(cfa,ca) ((*(Label *)(cfa)) = ((Label)ca))
Line 66  Label *engine(Xt *ip, Cell *sp, Cell *rp Line 145  Label *engine(Xt *ip, Cell *sp, Cell *rp
 #define MAKE_DOES_CF(cfa,does_code)     ({MAKE_CF(cfa,symbols[DODOES]); \  #define MAKE_DOES_CF(cfa,does_code)     ({MAKE_CF(cfa,symbols[DODOES]); \
                                           ((Cell *)cfa)[1] = (Cell)does_code;})                                            ((Cell *)cfa)[1] = (Cell)does_code;})
 /* the does handler resides between DOES> and the following Forth code */  /* the does handler resides between DOES> and the following Forth code */
 #define DOES_HANDLER_SIZE       8  #define DOES_HANDLER_SIZE       (2*sizeof(Cell))
 #define MAKE_DOES_HANDLER(addr) 0 /* do nothing */  #define MAKE_DOES_HANDLER(addr) 0 /* do nothing */
 #endif  #endif /* !defined(DIRECT_THREADED) */
   
 #ifdef DEBUG  #ifdef DEBUG
 #       define  NAME(string)    printf("%08x: "string"\n",(int)ip);  #       define  NAME(string)    fprintf(stderr,"%08lx: "string"\n",(Cell)ip);
 #else  #else
 #       define  NAME(string)  #       define  NAME(string)
 #endif  #endif
Line 80  Label *engine(Xt *ip, Cell *sp, Cell *rp Line 159  Label *engine(Xt *ip, Cell *sp, Cell *rp
   
 #define CF_NIL  -1  #define CF_NIL  -1
   
 #ifndef CACHE_FLUSH  #ifndef FLUSH_ICACHE
 #       define CACHE_FLUSH(addr,size)  #warning flush-icache probably will not work (see manual)
   #       define FLUSH_ICACHE(addr,size)
   #endif
   
   #ifdef DIRECT_THREADED
   #define CACHE_FLUSH(addr,size) FLUSH_ICACHE(addr,size)
   #else
   #define CACHE_FLUSH(addr,size)
 #endif  #endif
   
   Label *engine(Xt *ip, Cell *sp, Cell *rp, Float *fp, Address lp);
   
   /* dblsub routines */
   DCell dnegate(DCell d1);
   UDCell ummul (UCell a, UCell b);
   DCell mmul (Cell a, Cell b);
   UDCell umdiv (UDCell u, UCell v);
   DCell smdiv (DCell num, Cell denom);
   DCell fmdiv (DCell num, Cell denom);
   
   int memcasecmp(const char *s1, const char *s2, long n);
   

Removed from v.1.9  
changed lines
  Added in v.1.26


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