This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
yap-6.3/H/sshift.h

1126 lines
29 KiB
C
Raw Normal View History

/*************************************************************************
* *
* YAP Prolog %W% %G%
* *
* Yap Prolog was developed at NCCUP - Universidade do Porto *
* *
* Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997 *
* *
**************************************************************************
* *
* File: sshift.h *
* Last rev: 19/2/88 *
* mods: *
* comments: stack shifter functionality for YAP *
* *
*************************************************************************/
#define REINIT_LOCK(P) INIT_LOCK(P)
#define REINIT_RWLOCK(P) INIT_RWLOCK(P)
#define CharP(ptr) ((char *) (ptr))
#define CodeAdjust(P) CodeAdjust__(P PASS_REGS)
#define PtoTRAdjust(P) PtoTRAdjust__(P PASS_REGS)
#define BaseAddrAdjust(P) BaseAddrAdjust__(P PASS_REGS)
#define CutCAdjust(P) CutCAdjust__(P PASS_REGS)
#define ChoicePtrAdjust(P) ChoicePtrAdjust__(P PASS_REGS)
#define FuncAdjust(P) FuncAdjust__(P PASS_REGS)
#define AtomTermAdjust(P) AtomTermAdjust__(P PASS_REGS)
#define TermToGlobalOrAtomAdjust(P) TermToGlobalOrAtomAdjust__(P PASS_REGS)
#define AtomAdjust(P) AtomAdjust__(P PASS_REGS)
#define IsOldCode(P) IsOldCode__(P PASS_REGS)
#define IsOldLocal(P) IsOldLocal__(P PASS_REGS)
#define IsOldLocalPtr(P) IsOldLocalPtr__(P PASS_REGS)
#define IsOldCodeCellPtr(P) IsOldCodeCellPtr__(P PASS_REGS)
#define IsOldDelay(P) IsOldDelay__(P PASS_REGS)
#define IsOldDelayPtr(P) IsOldDelayPtr__(P PASS_REGS)
#define IsOldLocalInTR(P) IsOldLocalInTR__(P PASS_REGS)
#define IsOldLocalInTRPtr(P) IsOldLocalInTRPtr__(P PASS_REGS)
#define IsOldGlobal(P) IsOldGlobal__(P PASS_REGS)
#define IsOldGlobalPtr(P) IsOldGlobalPtr__(P PASS_REGS)
#define IsOldTrail(P) IsOldTrail__(P PASS_REGS)
#define IsOldTrailPtr(P) IsOldTrailPtr__(P PASS_REGS)
#define NoAGCAtomAdjust(P) NoAGCAtomAdjust__(P PASS_REGS)
// #define OrArgAdjust(P) OrArgAdjust__(P PASS_REGS)
// #define TabEntryAdjust(P) TabEntryAdjust__(P PASS_REGS)
// #define IntegerAdjust(D) IntegerAdjust__(P PASS_REGS)
#define AddrAdjust(P) AddrAdjust__(P PASS_REGS)
#define BlockAdjust(P) BlockAdjust__(P PASS_REGS)
#define CodeVarAdjust(P) CodeVarAdjust__(P PASS_REGS)
#define ConstantAdjust(P) ConstantAdjust__(P PASS_REGS)
#define ArityAdjust(P) ArityAdjust__(P PASS_REGS)
// #define DoubleInCodeAdjust(P) DoubleInCodeAdjust__(P PASS_REGS)
// #define IntegerInCodeAdjust(P) IntegerInCodeAdjust__(P PASS_REGS)
#define OpcodeAdjust(P) OpcodeAdjust__(P PASS_REGS)
#define ModuleAdjust(P) ModuleAdjust__(P PASS_REGS)
// #define ExternalFunctionAdjust(P) ExternalFunctionAdjust__(P PASS_REGS)
#define DBRecordAdjust(P) DBRecordAdjust__(P PASS_REGS)
#define PredEntryAdjust(P) PredEntryAdjust__(P PASS_REGS)
#define ModEntryPtrAdjust(P) ModEntryPtrAdjust__(P PASS_REGS)
#define AtomEntryAdjust(P) AtomEntryAdjust__(P PASS_REGS)
#define GlobalEntryAdjust(P) GlobalEntryAdjust__(P PASS_REGS)
#define BlobTermInCodeAdjust(P) BlobTermInCodeAdjust__(P PASS_REGS)
#define CellPtoHeapAdjust(P) CellPtoHeapAdjust__(P PASS_REGS)
#define PtoAtomHashEntryAdjust(P) PtoAtomHashEntryAdjust__(P PASS_REGS)
#define CellPtoHeapCellAdjust(P) CellPtoHeapCellAdjust__(P PASS_REGS)
#define CellPtoTRAdjust(P) CellPtoTRAdjust__(P PASS_REGS)
#define CodeAddrAdjust(P) CodeAddrAdjust__(P PASS_REGS)
#define ConsultObjAdjust(P) ConsultObjAdjust__(P PASS_REGS)
#define DelayAddrAdjust(P) DelayAddrAdjust__(P PASS_REGS)
#define DelayAdjust(P) DelayAdjust__(P PASS_REGS)
#define GlobalAdjust(P) GlobalAdjust__(P PASS_REGS)
2012-06-12 14:50:36 +01:00
#define DBRefAdjust(P,C) DBRefAdjust__(P PASS_REGS)
#define DBRefPAdjust(P) DBRefPAdjust__(P PASS_REGS)
#define DBTermAdjust(P) DBTermAdjust__(P PASS_REGS)
#define LUIndexAdjust(P) LUIndexAdjust__(P PASS_REGS)
#define SIndexAdjust(P) SIndexAdjust__(P PASS_REGS)
#define LocalAddrAdjust(P) LocalAddrAdjust__(P PASS_REGS)
#define GlobalAddrAdjust(P) GlobalAddrAdjust__(P PASS_REGS)
#define OpListAdjust(P) OpListAdjust__(P PASS_REGS)
#define PtoLUCAdjust(P) PtoLUCAdjust__(P PASS_REGS)
#define PtoStCAdjust(P) PtoStCAdjust__(P PASS_REGS)
#define PtoArrayEAdjust(P) PtoArrayEAdjust__(P PASS_REGS)
#define PtoArraySAdjust(P) PtoArraySAdjust__(P PASS_REGS)
#define PtoGlobalEAdjust(P) PtoGlobalEAdjust__(P PASS_REGS)
#define PtoDelayAdjust(P) PtoDelayAdjust__(P PASS_REGS)
#define PtoGloAdjust(P) PtoGloAdjust__(P PASS_REGS)
#define PtoLocAdjust(P) PtoLocAdjust__(P PASS_REGS)
#define PtoHeapCellAdjust(P) PtoHeapCellAdjust__(P PASS_REGS)
#define TermToGlobalAdjust(P) TermToGlobalAdjust__(P PASS_REGS)
#define PtoOpAdjust(P) PtoOpAdjust__(P PASS_REGS)
#define PtoLUClauseAdjust(P) PtoLUClauseAdjust__(P PASS_REGS)
#define PtoLUIndexAdjust(P) PtoLUIndexAdjust__(P PASS_REGS)
#define PtoDBTLAdjust(P) PtoDBTLAdjust__(P PASS_REGS)
#define PtoPredAdjust(P) PtoPredAdjust__(P PASS_REGS)
#define PtoPtoPredAdjust(P) PtoPtoPredAdjust__(P PASS_REGS)
#define OpRTableAdjust(P) OpRTableAdjust__(P PASS_REGS)
#define OpEntryAdjust(P) OpEntryAdjust__(P PASS_REGS)
#define PropAdjust(P) PropAdjust__(P PASS_REGS)
2011-03-08 00:22:32 +00:00
#define BlobTypeAdjust(P) BlobTypeAdjust__(P PASS_REGS)
#define TrailAddrAdjust(P) TrailAddrAdjust__(P PASS_REGS)
#define XAdjust(P) XAdjust__(P PASS_REGS)
#define YAdjust(P) YAdjust__(P PASS_REGS)
#define LocalAdjust(P) LocalAdjust__(P PASS_REGS)
#define TrailAdjust(P) TrailAdjust__(P PASS_REGS)
#define HoldEntryAdjust(P) HoldEntryAdjust__(P PASS_REGS)
#define CodeCharPAdjust(P) CodeCharPAdjust__(P PASS_REGS)
#define CodeVoidPAdjust(P) CodeVoidPAdjust__(P PASS_REGS)
#define HaltHookAdjust(P) HaltHookAdjust__(P PASS_REGS)
#define TokEntryAdjust(P) TokEntryAdjust__(P PASS_REGS)
#define VarEntryAdjust(P) VarEntryAdjust__(P PASS_REGS)
#define ConsumerChoicePtrAdjust(P) ConsumerChoicePtrAdjust__(P PASS_REGS)
#define GeneratorChoicePtrAdjust(P) GeneratorChoicePtrAdjust__(P PASS_REGS)
#define IsHeapP(P) IsHeapP__(P PASS_REGS)
#define IsOldVarTableTrailPtr(P) IsOldVarTableTrailPtr__(P PASS_REGS)
#define IsOldTokenTrailPtr(P) IsOldTokenTrailPtr__(P PASS_REGS)
2012-06-29 22:44:08 +01:00
#include "inline-only.h"
INLINE_ONLY inline EXTERN int IsHeapP__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsHeapP__ (CELL * ptr USES_REGS)
{
#if USE_SYSTEM_MALLOC
return (int) ((ptr < (CELL *) LOCAL_GlobalBase || ptr > (CELL *) LOCAL_TrailTop));
#else
return (int) ((ptr >= (CELL *) Yap_HeapBase && ptr <= (CELL *) HeapTop));
#endif
}
#define OrArgAdjust(P)
#define TabEntryAdjust(P)
/* Adjusting cells and pointers to cells */
INLINE_ONLY inline EXTERN CELL *PtoGloAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
PtoGloAdjust__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
if (ptr < LOCAL_GSplit) {
if (ptr < H0)
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_DelayDiff)));
else
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_GDiff0)));
} else {
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_GDiff)));
}
}
INLINE_ONLY inline EXTERN CELL *PtoDelayAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
PtoDelayAdjust__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
if (!LOCAL_GSplit || ptr < LOCAL_GSplit)
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_DelayDiff)));
else
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_GDiff0)));
}
INLINE_ONLY inline EXTERN CELL *PtoBaseAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
PtoBaseAdjust__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_BaseDiff)));
}
INLINE_ONLY inline EXTERN tr_fr_ptr PtoTRAdjust__ (tr_fr_ptr CACHE_TYPE);
INLINE_ONLY inline EXTERN tr_fr_ptr
PtoTRAdjust__ (tr_fr_ptr ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (tr_fr_ptr) (((tr_fr_ptr) (CharP (ptr) + LOCAL_TrDiff)));
}
INLINE_ONLY inline EXTERN CELL *CellPtoTRAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
CellPtoTRAdjust__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_TrDiff)));
}
INLINE_ONLY inline EXTERN CELL *PtoLocAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
PtoLocAdjust__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_LDiff)));
}
INLINE_ONLY inline EXTERN struct cut_c_str *CutCAdjust__ (struct cut_c_str * CACHE_TYPE);
2010-01-28 15:42:49 +00:00
INLINE_ONLY inline EXTERN struct cut_c_str *
CutCAdjust__ (struct cut_c_str * ptr USES_REGS)
2010-01-28 15:42:49 +00:00
{
2011-05-04 10:11:41 +01:00
return (struct cut_c_str *) (CharP (ptr) + LOCAL_LDiff);
2010-01-28 15:42:49 +00:00
}
INLINE_ONLY inline EXTERN choiceptr ChoicePtrAdjust__ (choiceptr CACHE_TYPE);
INLINE_ONLY inline EXTERN choiceptr
ChoicePtrAdjust__ (choiceptr ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (choiceptr) (((choiceptr) (CharP (ptr) + LOCAL_LDiff)));
}
#ifdef TABLING
INLINE_ONLY inline EXTERN choiceptr ConsumerChoicePtrAdjust__ (choiceptr CACHE_TYPE);
INLINE_ONLY inline EXTERN choiceptr
ConsumerChoicePtrAdjust__ (choiceptr ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (choiceptr) (((choiceptr) (CharP (ptr) + LOCAL_LDiff)));
}
INLINE_ONLY inline EXTERN choiceptr GeneratorChoicePtrAdjust__ (choiceptr CACHE_TYPE);
INLINE_ONLY inline EXTERN choiceptr
GeneratorChoicePtrAdjust__ (choiceptr ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (choiceptr) (((choiceptr) (CharP (ptr) + LOCAL_LDiff)));
}
#endif /* TABLING */
INLINE_ONLY inline EXTERN CELL GlobalAdjust__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL
GlobalAdjust__ (CELL val USES_REGS)
{
2011-05-04 10:11:41 +01:00
if ((CELL *)val < LOCAL_GSplit) {
if ((CELL *)val < H0)
2011-05-04 10:11:41 +01:00
return (CELL) (val + LOCAL_DelayDiff);
else
2011-05-04 10:11:41 +01:00
return (CELL) (val + LOCAL_GDiff0);
} else {
2011-05-04 10:11:41 +01:00
return (CELL) (val + LOCAL_GDiff);
}
}
INLINE_ONLY inline EXTERN CELL DelayAdjust__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL
DelayAdjust__ (CELL val USES_REGS)
{
2011-05-04 10:11:41 +01:00
if (!LOCAL_GSplit || (CELL *)val < LOCAL_GSplit)
return (CELL) (val + LOCAL_DelayDiff);
else
2011-05-04 10:11:41 +01:00
return (CELL) (val + LOCAL_GDiff0);
}
INLINE_ONLY inline EXTERN ADDR GlobalAddrAdjust__ (ADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN ADDR
GlobalAddrAdjust__ (ADDR ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
if ((CELL *)ptr < LOCAL_GSplit) {
if ((CELL *)ptr < H0)
2011-05-04 10:11:41 +01:00
return (ADDR) (ptr + LOCAL_DelayDiff);
else
2011-05-04 10:11:41 +01:00
return (ADDR) ((ptr + LOCAL_GDiff0));
} else {
2011-05-04 10:11:41 +01:00
return (ADDR) ((ptr + LOCAL_GDiff));
}
}
INLINE_ONLY inline EXTERN ADDR DelayAddrAdjust__ (ADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN ADDR
DelayAddrAdjust__ (ADDR ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
if (!LOCAL_GSplit || (CELL *)ptr < LOCAL_GSplit)
return (ADDR) ((ptr + LOCAL_DelayDiff));
else
2011-05-04 10:11:41 +01:00
return (ADDR) ((ptr + LOCAL_GDiff0));
}
INLINE_ONLY inline EXTERN ADDR BaseAddrAdjust__ (ADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN ADDR
BaseAddrAdjust__ (ADDR ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (ADDR) ((ptr + LOCAL_BaseDiff));
}
INLINE_ONLY inline EXTERN CELL LocalAdjust__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL
LocalAdjust__ (CELL val USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CELL) ((val + LOCAL_LDiff));
}
INLINE_ONLY inline EXTERN ADDR LocalAddrAdjust__ (ADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN ADDR
LocalAddrAdjust__ (ADDR ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (ADDR) ((ptr + LOCAL_LDiff));
}
INLINE_ONLY inline EXTERN CELL TrailAdjust__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL
TrailAdjust__ (CELL val USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CELL) ((val + LOCAL_TrDiff));
}
INLINE_ONLY inline EXTERN ADDR TrailAddrAdjust__ (ADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN ADDR
TrailAddrAdjust__ (ADDR ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (ADDR) ((ptr + LOCAL_TrDiff));
}
INLINE_ONLY inline EXTERN TokEntry *TokEntryAdjust__ (TokEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN TokEntry *
TokEntryAdjust__ (TokEntry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (TokEntry *) (((CELL) ptr + LOCAL_TrDiff));
}
INLINE_ONLY inline EXTERN VarEntry *VarEntryAdjust__ (VarEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN VarEntry *
VarEntryAdjust__ (VarEntry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (VarEntry *) (((CELL) ptr + LOCAL_TrDiff));
}
/* heap data structures */
INLINE_ONLY inline EXTERN Functor FuncAdjust__ (Functor CACHE_TYPE);
INLINE_ONLY inline EXTERN Functor
FuncAdjust__ (Functor f USES_REGS)
{
if (!IsExtensionFunctor(f))
2011-05-04 10:11:41 +01:00
return (Functor) ((CharP (f) + LOCAL_HDiff));
return f;
}
INLINE_ONLY inline EXTERN CELL *CellPtoHeapAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
CellPtoHeapAdjust__ (CELL * ptr USES_REGS)
{
if (!ptr)
return ptr;
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN HoldEntry *HoldEntryAdjust__ (HoldEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN HoldEntry *
HoldEntryAdjust__ (HoldEntry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (HoldEntry *) (((HoldEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN struct record_list *DBRecordAdjust__ (struct record_list * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct record_list *
DBRecordAdjust__ (struct record_list * ptr USES_REGS)
{
if (!ptr)
return ptr;
2011-05-04 10:11:41 +01:00
return (struct record_list *) (CharP (ptr) + LOCAL_HDiff);
}
#if USE_OFFSETS
INLINE_ONLY inline EXTERN Atom AtomAdjust__ (Atom CACHE_TYPE);
INLINE_ONLY inline EXTERN Atom
AtomAdjust__ (Atom at USES_REGS)
{
return (Atom) ((at));
}
INLINE_ONLY inline EXTERN Atom NoAGCAtomAdjust__ (Atom CACHE_TYPE);
INLINE_ONLY inline EXTERN Atom
NoAGCAtomAdjust__ (Atom at USES_REGS)
{
return (Atom) ((at));
}
INLINE_ONLY inline EXTERN Prop PropAdjust__ (Prop CACHE_TYPE);
INLINE_ONLY inline EXTERN Prop
PropAdjust__ (Prop p USES_REGS)
{
return (Prop) ((p));
}
#else
INLINE_ONLY inline EXTERN Atom AtomAdjust__ (Atom CACHE_TYPE);
INLINE_ONLY inline EXTERN Atom
AtomAdjust__ (Atom at USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Atom) ((at == NULL ? (at) : (Atom) (CharP (at) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN Atom NoAGCAtomAdjust__ (Atom CACHE_TYPE);
INLINE_ONLY inline EXTERN Atom
NoAGCAtomAdjust__ (Atom at USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Atom) ((at == NULL ? (at) : (Atom) (CharP (at) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN Prop PropAdjust__ (Prop CACHE_TYPE);
INLINE_ONLY inline EXTERN Prop
PropAdjust__ (Prop p USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Prop) ((p == NULL ? (p) : (Prop) (CharP (p) + LOCAL_HDiff)));
}
#endif
INLINE_ONLY inline EXTERN struct PL_blob_t *BlobTypeAdjust__ (struct PL_blob_t *CACHE_TYPE);
2011-03-08 00:22:32 +00:00
INLINE_ONLY inline EXTERN struct PL_blob_t *
2011-03-08 00:22:32 +00:00
BlobTypeAdjust__ (struct PL_blob_t *at USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (struct PL_blob_t *) ((at == NULL ? (at) : (struct PL_blob_t *) (CharP (at) + LOCAL_HDiff)));
2011-03-08 00:22:32 +00:00
}
INLINE_ONLY inline EXTERN PredEntry *PredEntryAdjust__ (PredEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN PredEntry *
PredEntryAdjust__ (PredEntry *p USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (PredEntry *) ((p == NULL ? (p) : (PredEntry *) (CharP (p) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN struct mod_entry *ModEntryPtrAdjust__ (struct mod_entry * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct mod_entry *
ModEntryPtrAdjust__ (struct mod_entry *p USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (struct mod_entry *) ((p == NULL ? (p) : (struct mod_entry *) (CharP (p) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN COUNT ConstantAdjust__ (COUNT CACHE_TYPE);
INLINE_ONLY inline EXTERN COUNT
ConstantAdjust__ (COUNT val USES_REGS)
{
return val;
}
INLINE_ONLY inline EXTERN Int ArityAdjust__ (Int CACHE_TYPE);
INLINE_ONLY inline EXTERN Int
ArityAdjust__ (Int val USES_REGS)
{
return val;
}
INLINE_ONLY inline EXTERN OPCODE OpcodeAdjust__ (OPCODE CACHE_TYPE);
INLINE_ONLY inline EXTERN OPCODE
OpcodeAdjust__ (OPCODE val USES_REGS)
{
return Yap_opcode(Yap_op_from_opcode(val));
}
#define DoubleInCodeAdjust(D)
#define IntegerInCodeAdjust(D)
#define IntegerAdjust(D) (D)
#define ExternalFunctionAdjust(D) (D);
INLINE_ONLY inline EXTERN Term AtomTermAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
AtomTermAdjust__ (Term at USES_REGS)
{
if (at == 0L)
return at;
2011-05-04 10:11:41 +01:00
return (Term)(CharP(at) + LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN Term ModuleAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
ModuleAdjust__ (Term t USES_REGS)
{
return AtomTermAdjust(t);
}
INLINE_ONLY inline EXTERN Term CodeVarAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
CodeVarAdjust__ (Term var USES_REGS)
{
if (var == 0L)
return var;
2011-05-04 10:11:41 +01:00
return (Term)(CharP(var) + LOCAL_HDiff);
}
#if TAGS_FAST_OPS
INLINE_ONLY inline EXTERN Term BlobTermInCodeAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
BlobTermInCodeAdjust__ (Term t USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Term) (CharP(t) - LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN Term CodeComposedTermAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
CodeComposedTermAdjust__ (Term t USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Term) (CharP(t) - LOCAL_HDiff);
}
#else
INLINE_ONLY inline EXTERN Term BlobTermInCodeAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
BlobTermInCodeAdjust__ (Term t USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Term) (CharP(t) + LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN Term CodeComposedTermAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
CodeComposedTermAdjust__ (Term t USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Term) (CharP(t) + LOCAL_HDiff);
}
#endif
INLINE_ONLY inline EXTERN AtomEntry *AtomEntryAdjust__ (AtomEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN AtomEntry *
AtomEntryAdjust__ (AtomEntry * at USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (AtomEntry *) ((AtomEntry *) (CharP (at) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN GlobalEntry *GlobalEntryAdjust__ (GlobalEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN GlobalEntry *
GlobalEntryAdjust__ (GlobalEntry * at USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (GlobalEntry *) ((GlobalEntry *) (CharP (at) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN union CONSULT_OBJ *ConsultObjAdjust__ (union CONSULT_OBJ * CACHE_TYPE);
INLINE_ONLY inline EXTERN union CONSULT_OBJ *
ConsultObjAdjust__ (union CONSULT_OBJ *co USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (union CONSULT_OBJ *) ((union CONSULT_OBJ *) (CharP (co) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN DBRef DBRefAdjust__ (DBRef CACHE_TYPE);
INLINE_ONLY inline EXTERN DBRef
DBRefAdjust__ (DBRef dbr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (DBRef) ((DBRef) (CharP (dbr) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN DBRef *DBRefPAdjust__ (DBRef * CACHE_TYPE);
INLINE_ONLY inline EXTERN DBRef *
DBRefPAdjust__ (DBRef * dbrp USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (DBRef *) ((DBRef *) (CharP (dbrp) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN DBTerm *DBTermAdjust__ (DBTerm * CACHE_TYPE);
INLINE_ONLY inline EXTERN DBTerm *
DBTermAdjust__ (DBTerm * dbtp USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (DBTerm *) ((DBTerm *) (CharP (dbtp) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN struct static_index *SIndexAdjust__ (struct static_index * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct static_index *
SIndexAdjust__ (struct static_index *si USES_REGS)
{
return (struct static_index
2011-05-04 10:11:41 +01:00
*) ((struct static_index *) (CharP (si) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN
struct logic_upd_index *LUIndexAdjust__ (struct logic_upd_index
* CACHE_TYPE);
INLINE_ONLY inline EXTERN struct logic_upd_index *
LUIndexAdjust__ (struct logic_upd_index *lui USES_REGS)
{
return (struct logic_upd_index
2011-05-04 10:11:41 +01:00
*) ((struct logic_upd_index *) (CharP (lui) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN Term CodeAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
CodeAdjust__ (Term dbr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (Term) (CharP(dbr) + LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN ADDR AddrAdjust__ (ADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN ADDR
AddrAdjust__ (ADDR addr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (ADDR) ((ADDR) (CharP (addr) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN CODEADDR CodeAddrAdjust__ (CODEADDR CACHE_TYPE);
INLINE_ONLY inline EXTERN CODEADDR
CodeAddrAdjust__ (CODEADDR addr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CODEADDR) ((CODEADDR) (CharP (addr) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN char * CodeCharPAdjust__ (char * CACHE_TYPE);
INLINE_ONLY inline EXTERN char *
CodeCharPAdjust__ (char * addr USES_REGS)
{
2009-10-30 23:59:00 +00:00
if (!addr)
return NULL;
2011-05-04 10:11:41 +01:00
return addr + LOCAL_HDiff;
2009-10-30 23:59:00 +00:00
}
INLINE_ONLY inline EXTERN void * CodeVoidPAdjust__ (void * CACHE_TYPE);
2009-10-30 23:59:00 +00:00
INLINE_ONLY inline EXTERN void *
CodeVoidPAdjust__ (void * addr USES_REGS)
2009-10-30 23:59:00 +00:00
{
if (!addr)
return NULL;
2011-05-04 10:11:41 +01:00
return addr + LOCAL_HDiff;
}
INLINE_ONLY inline EXTERN struct halt_hook *HaltHookAdjust__ (struct halt_hook * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct halt_hook *
HaltHookAdjust__ (struct halt_hook * addr USES_REGS)
{
if (!addr)
return NULL;
2011-05-04 10:11:41 +01:00
return (struct halt_hook *) (CharP (addr) + LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN BlockHeader *BlockAdjust__ (BlockHeader * CACHE_TYPE);
INLINE_ONLY inline EXTERN BlockHeader *
BlockAdjust__ (BlockHeader * addr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (BlockHeader *) ((BlockHeader *) (CharP (addr) + LOCAL_HDiff));
}
INLINE_ONLY inline EXTERN yamop *PtoOpAdjust__ (yamop * CACHE_TYPE);
INLINE_ONLY inline EXTERN yamop *
PtoOpAdjust__ (yamop * ptr USES_REGS)
{
2011-02-04 01:41:01 +00:00
if (ptr)
2011-05-04 10:11:41 +01:00
return (yamop *) (CharP (ptr) + LOCAL_HDiff);
2011-02-12 14:14:12 +00:00
return ptr;
}
INLINE_ONLY inline EXTERN struct operator_entry *OpListAdjust__ (struct operator_entry * CACHE_TYPE);
2009-10-30 23:59:00 +00:00
INLINE_ONLY inline EXTERN struct operator_entry *
OpListAdjust__ (struct operator_entry * ptr USES_REGS)
2009-10-30 23:59:00 +00:00
{
if (!ptr)
return ptr;
2011-05-04 10:11:41 +01:00
return (struct operator_entry *) (CharP (ptr) + LOCAL_HDiff);
2009-10-30 23:59:00 +00:00
}
INLINE_ONLY inline EXTERN struct logic_upd_clause *PtoLUClauseAdjust__ (struct logic_upd_clause * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct logic_upd_clause *
PtoLUClauseAdjust__ (struct logic_upd_clause * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (struct logic_upd_clause *) (CharP (ptr) + LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN struct logic_upd_index *PtoLUIndexAdjust__ (struct logic_upd_index * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct logic_upd_index *
PtoLUIndexAdjust__ (struct logic_upd_index * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (struct logic_upd_index *) (CharP (ptr) + LOCAL_HDiff);
}
INLINE_ONLY inline EXTERN CELL *PtoHeapCellAdjust__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN CELL *
PtoHeapCellAdjust__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (CELL *) (((CELL *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN AtomHashEntry *PtoAtomHashEntryAdjust__ (AtomHashEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN AtomHashEntry *
PtoAtomHashEntryAdjust__ (AtomHashEntry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (AtomHashEntry *) (((AtomHashEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN Term TermToGlobalAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
TermToGlobalAdjust__ (Term t USES_REGS)
{
if (t == 0L)
return t;
return AbsAppl(PtoGloAdjust(RepAppl(t)));
}
INLINE_ONLY inline EXTERN Term TermToGlobalOrAtomAdjust__ (Term CACHE_TYPE);
INLINE_ONLY inline EXTERN Term
TermToGlobalOrAtomAdjust__ (Term t USES_REGS)
{
if (t == 0L)
return t;
if (IsAtomTerm(t))
return AtomTermAdjust(t);
if (IsApplTerm(t))
return AbsAppl(PtoGloAdjust(RepAppl(t)));
if (IsPairTerm(t))
return AbsPair(PtoGloAdjust(RepPair(t)));
return t;
}
INLINE_ONLY inline EXTERN opentry *OpRTableAdjust__ (opentry * CACHE_TYPE);
INLINE_ONLY inline EXTERN opentry *
OpRTableAdjust__ (opentry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (opentry *) (((opentry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN OpEntry *OpEntryAdjust__ (OpEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN OpEntry *
OpEntryAdjust__ (OpEntry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (OpEntry *) (((OpEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN PredEntry *PtoPredAdjust__ (PredEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN PredEntry *
PtoPredAdjust__ (PredEntry * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (PredEntry *) (((PredEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN PredEntry **PtoPtoPredAdjust__ (PredEntry ** CACHE_TYPE);
INLINE_ONLY inline EXTERN PredEntry **
PtoPtoPredAdjust__ (PredEntry **ptr USES_REGS)
{
if (!ptr)
return NULL;
2011-05-04 10:11:41 +01:00
return (PredEntry **) (((PredEntry **) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN ArrayEntry *PtoArrayEAdjust__ (ArrayEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN ArrayEntry *
PtoArrayEAdjust__ (ArrayEntry * ptr USES_REGS)
{
if (!ptr)
return NULL;
2011-05-04 10:11:41 +01:00
return (ArrayEntry *) (((ArrayEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN GlobalEntry *PtoGlobalEAdjust__ (GlobalEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN GlobalEntry *
PtoGlobalEAdjust__ (GlobalEntry * ptr USES_REGS)
{
if (!ptr)
return NULL;
2011-05-04 10:11:41 +01:00
return (GlobalEntry *) (((GlobalEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN StaticArrayEntry *PtoArraySAdjust__ (StaticArrayEntry * CACHE_TYPE);
INLINE_ONLY inline EXTERN StaticArrayEntry *
PtoArraySAdjust__ (StaticArrayEntry * ptr USES_REGS)
{
if (!ptr)
return NULL;
2011-05-04 10:11:41 +01:00
return (StaticArrayEntry *) (((StaticArrayEntry *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN struct logic_upd_clause *PtoLUCAdjust__ (struct logic_upd_clause* CACHE_TYPE);
INLINE_ONLY inline EXTERN struct logic_upd_clause *
PtoLUCAdjust__ (struct logic_upd_clause *ptr USES_REGS)
{
return (struct logic_upd_clause
2011-05-04 10:11:41 +01:00
*) (((struct logic_upd_clause *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN struct static_clause *PtoStCAdjust__ (struct static_clause * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct static_clause *
PtoStCAdjust__ (struct static_clause *ptr USES_REGS)
{
return (struct static_clause
2011-05-04 10:11:41 +01:00
*) (((struct static_upd_clause *) (CharP (ptr) + LOCAL_HDiff)));
}
INLINE_ONLY inline EXTERN struct dbterm_list *PtoDBTLAdjust__ (struct dbterm_list * CACHE_TYPE);
INLINE_ONLY inline EXTERN struct dbterm_list *
PtoDBTLAdjust__ (struct dbterm_list * addr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (struct dbterm_list *) ((ADDR) (CharP (addr) + LOCAL_HDiff));
}
#if PRECOMPUTE_REGADDRESS
INLINE_ONLY inline EXTERN wamreg XAdjust__ (wamreg CACHE_TYPE);
INLINE_ONLY inline EXTERN wamreg
XAdjust__ (wamreg reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (wamreg) ((wamreg) ((reg) + LOCAL_XDiff));
}
#else
INLINE_ONLY inline EXTERN wamreg XAdjust__ (wamreg CACHE_TYPE);
INLINE_ONLY inline EXTERN wamreg
XAdjust__ (wamreg reg USES_REGS)
{
return (wamreg) ((reg));
}
#endif
INLINE_ONLY inline EXTERN yslot YAdjust__ (yslot CACHE_TYPE);
INLINE_ONLY inline EXTERN yslot
YAdjust__ (yslot reg USES_REGS)
{
return (yslot) ((reg));
}
INLINE_ONLY inline EXTERN int IsOldLocal__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldLocal__ (CELL reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldASP, reg, LOCAL_OldLCL0));
}
INLINE_ONLY inline EXTERN int IsOldLocalPtr__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldLocalPtr__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldASP, ptr, LOCAL_OldLCL0));
}
/* require because the trail might contain dangling pointers */
INLINE_ONLY inline EXTERN int IsOldLocalInTR__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldLocalInTR__ (CELL reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldH, reg, LOCAL_OldLCL0));
}
INLINE_ONLY inline EXTERN int IsOldLocalInTRPtr__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldLocalInTRPtr__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldH, ptr, LOCAL_OldLCL0));
}
INLINE_ONLY inline EXTERN int IsOldH__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldH__ (CELL reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) ((CharP (reg) == CharP (LOCAL_OldH)));
}
INLINE_ONLY inline EXTERN int IsOldGlobal__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldGlobal__ (CELL reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldGlobalBase, reg, LOCAL_OldH));
}
INLINE_ONLY inline EXTERN int IsOldDelay__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldDelay__ (CELL reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldGlobalBase, reg, LOCAL_OldH0));
}
INLINE_ONLY inline EXTERN int IsOldGlobalPtr__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldGlobalPtr__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldGlobalBase, ptr, LOCAL_OldH));
}
INLINE_ONLY inline EXTERN int IsOldTrail__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldTrail__ (CELL reg USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldTrailBase, reg, LOCAL_OldTR));
}
INLINE_ONLY inline EXTERN int IsOldTrailPtr__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldTrailPtr__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldTrailBase, ptr, LOCAL_OldTR));
}
INLINE_ONLY inline EXTERN int IsOldVarTableTrailPtr__ (struct VARSTRUCT * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldVarTableTrailPtr__ (struct VARSTRUCT *ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldTrailBase, ptr, LOCAL_OldTR));
}
INLINE_ONLY inline EXTERN int IsOldTokenTrailPtr__ (struct TOKEN * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldTokenTrailPtr__ (struct TOKEN *ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldTrailBase, ptr, LOCAL_OldTR));
}
INLINE_ONLY inline EXTERN int IsOldCode__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldCode__ (CELL reg USES_REGS)
{
#if USE_SYSTEM_MALLOC
2011-05-04 10:11:41 +01:00
return reg < (CELL)LOCAL_OldGlobalBase || reg > (CELL)LOCAL_OldTrailTop;
#else
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldHeapBase, reg, LOCAL_OldHeapTop));
#endif
}
INLINE_ONLY inline EXTERN int IsOldCodeCellPtr__ (CELL * CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsOldCodeCellPtr__ (CELL * ptr USES_REGS)
{
2011-05-04 10:11:41 +01:00
return (int) (IN_BETWEEN (LOCAL_OldHeapBase, ptr, LOCAL_OldHeapTop));
}
INLINE_ONLY inline EXTERN int IsGlobal__ (CELL CACHE_TYPE);
INLINE_ONLY inline EXTERN int
IsGlobal__ (CELL reg USES_REGS)
{
2014-01-19 21:15:05 +00:00
return (int) (IN_BETWEEN (LOCAL_GlobalBase, reg, HR));
}
2013-04-25 23:15:04 +01:00
void Yap_AdjustStacksAndTrail(void);
void Yap_AdjustRegs(int);