317 lines
8.3 KiB
C
317 lines
8.3 KiB
C
#define WRITE_X_VAR_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
XREG((*_PREG)->y_u.x.x) = Unsigned((*_SREG)); \
|
|
(*_PREG) = NEXTOP((*_PREG), x); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext();
|
|
|
|
#define WRITE_VOID_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
(*_PREG) = NEXTOP((*_PREG), e); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext();
|
|
|
|
#define WRITE_N_VOIDS_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = (*_PREG)->y_u.s.s; \
|
|
(*_PREG) = NEXTOP((*_PREG), s); \
|
|
for (; d0 > 0; d0--) { \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
} \
|
|
GONext();
|
|
|
|
#define WRITE_Y_VAR_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
INITIALIZE_PERMVAR(YREG+(*_PREG)->y_u.y.y,Unsigned((*_SREG))); \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext();
|
|
|
|
#define WRITE_X_VAL_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = XREG((*_PREG)->y_u.x.x); \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), x); \
|
|
GONext();
|
|
|
|
#define WRITE_X_LOC_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
register CELL *pt0; \
|
|
d0 = XREG((*_PREG)->y_u.x.x); \
|
|
(*_PREG) = NEXTOP((*_PREG), x);
|
|
|
|
#define WRITE_X_LOC_W_X_BOUND \
|
|
*(*_SREG)++ = d0; \
|
|
GONext();
|
|
|
|
#if defined(YAPOR_SBA) && defined(FROZEN_STACKS)
|
|
#ifdef FROZEN_STACKS
|
|
#define WRITE_X_LOC_W_X_UNK \
|
|
if (pt0 > HR && pt0<(CELL *)B_FZ) { \
|
|
Bind_Local(pt0, Unsigned((*_SREG))); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} \
|
|
else { \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#else /* FROZEN_STACKS */
|
|
#define WRITE_X_LOC_W_X_UNK \
|
|
if (pt0 > HR && pt0<(CELL *)B_FZ) { \
|
|
TRAIL_LOCAL(pt0, Unsigned((*_SREG))); \
|
|
*pt0 = Unsigned((*_SREG)); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} \
|
|
else { \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#endif /* FROZEN_STACKS */
|
|
#else /* defined(YAPOR_SBA) && defined(FROZEN_STACKS) */
|
|
#ifdef FROZEN_STACKS
|
|
#define WRITE_X_LOC_W_X_UNK \
|
|
if (pt0 > HR) { \
|
|
Bind_Local(pt0, Unsigned((*_SREG))); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} \
|
|
else { \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#else /* FROZEN_STACKS */
|
|
#define WRITE_X_LOC_W_X_UNK \
|
|
if (pt0 > HR) { \
|
|
TRAIL_LOCAL(pt0, Unsigned((*_SREG))); \
|
|
*pt0 = Unsigned((*_SREG)); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} \
|
|
else { \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#endif /* FROZEN_STACKS */
|
|
#endif /*defined(YAPOR_SBA) && defined(FROZEN_STACKS) */
|
|
|
|
#ifdef YAPOR_SBA
|
|
#define WRITE_Y_VAL_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = YREG[(*_PREG)->y_u.y.y]; \
|
|
if (d0 == 0) \
|
|
*(*_SREG)++ = (CELL)(YREG+(*_PREG)->y_u.y.y); \
|
|
else \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
GONext();
|
|
#else /* YAPOR_SBA */
|
|
#define WRITE_Y_VAL_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = YREG[(*_PREG)->y_u.y.y]; \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
GONext();
|
|
#endif /* YAPOR_SBA */
|
|
|
|
#define WRITE_Y_LOC_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
register CELL *pt0; \
|
|
pt0 = YREG+(*_PREG)->y_u.y.y; \
|
|
d0 = *pt0;
|
|
|
|
#define WRITE_Y_LOC_W_Y_BOUND \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*(*_SREG)++ = d0; \
|
|
GONext();
|
|
|
|
#if defined(YAPOR_SBA) && defined(FROZEN_STACKS)
|
|
#ifdef FROZEN_STACKS
|
|
#define WRITE_Y_LOC_W_Y_UNK \
|
|
if (pt0 > HR \
|
|
&& pt0<(CELL *)B_FZ \
|
|
) { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
Bind_Local(pt0, Unsigned((*_SREG))); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} else { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#else /* FROZEN_STACKS */
|
|
#define WRITE_Y_LOC_W_Y_UNK \
|
|
if (pt0 > HR \
|
|
&& pt0<(CELL *)B_FZ \
|
|
) { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*pt0 = Unsigned((*_SREG)); \
|
|
TRAIL_LOCAL(pt0, Unsigned((*_SREG))); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} else { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#endif /* FROZEN_STACKS */
|
|
#else /* defined(YAPOR_SBA) && defined(FROZEN_STACKS) */
|
|
#ifdef FROZEN_STACKS
|
|
#define WRITE_Y_LOC_W_Y_UNK \
|
|
if (pt0 > HR \
|
|
) { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
Bind_Local(pt0, Unsigned((*_SREG))); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} else { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#else /* FROZEN_STACKS */
|
|
#define WRITE_Y_LOC_W_Y_UNK \
|
|
if (pt0 > HR \
|
|
) { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*pt0 = Unsigned((*_SREG)); \
|
|
TRAIL_LOCAL(pt0, Unsigned((*_SREG))); \
|
|
RESET_VARIABLE((*_SREG)); \
|
|
(*_SREG)++; \
|
|
GONext(); \
|
|
} else { \
|
|
(*_PREG) = NEXTOP((*_PREG), y); \
|
|
*(*_SREG)++ = Unsigned(pt0); \
|
|
GONext(); \
|
|
}
|
|
#endif /* FROZEN_STACKS */
|
|
#endif /* defined(YAPOR_SBA) && defined(FROZEN_STACKS) */
|
|
|
|
#define WRITE_ATOM_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = (*_PREG)->y_u.c.c; \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), c); \
|
|
GONext();
|
|
|
|
#define WRITE_BIGINT_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = (*_PREG)->y_u.N.b; \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), N); \
|
|
GONext();
|
|
|
|
#define WRITE_DBTERM_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = (*_PREG)->y_u.D.D; \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), D); \
|
|
GONext();
|
|
|
|
#define WRITE_FLOAT_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = AbsAppl((*_PREG)->y_u.d.d); \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), d); \
|
|
GONext();
|
|
|
|
#define WRITE_LONGIT_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = AbsAppl((*_PREG)->y_u.i.i); \
|
|
*(*_SREG)++ = d0; \
|
|
(*_PREG) = NEXTOP((*_PREG), i); \
|
|
GONext();
|
|
|
|
#define WRITE_N_ATOMS_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0, d1; \
|
|
d0 = (*_PREG)->y_u.sc.s; \
|
|
d1 = (*_PREG)->y_u.sc.c; \
|
|
for (; d0 > 0; d0--) { \
|
|
*(*_SREG)++ = d1; \
|
|
} \
|
|
(*_PREG) = NEXTOP((*_PREG), sc); \
|
|
GONext();
|
|
|
|
#define WRITE_LIST_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = AbsPair(HR); \
|
|
*(*_SREG)++ = d0; \
|
|
SP[-1] = Unsigned((*_SREG)); \
|
|
SP[-2] = 1; \
|
|
SP -= 2; \
|
|
(*_SREG) = HR; \
|
|
HR += 2; \
|
|
(*_PREG) = NEXTOP((*_PREG), e); \
|
|
GONext();
|
|
|
|
#define WRITE_L_LIST_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
ALWAYS_START_PREFETCH(e); \
|
|
(*_PREG) = NEXTOP((*_PREG), e); \
|
|
CACHE_S(); \
|
|
READ_IN_S(); \
|
|
d0 = AbsPair(HR); \
|
|
*S_SREG = d0; \
|
|
WRITEBACK_S(HR); \
|
|
HR += 2; \
|
|
ENDCACHE_S(); \
|
|
ALWAYS_GONext(); \
|
|
ALWAYS_END_PREFETCH();
|
|
|
|
#define WRITE_STRUCT_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = AbsAppl(HR); \
|
|
*(*_SREG)++ = d0; \
|
|
SP[-1] = Unsigned((*_SREG)); \
|
|
SP[-2] = 1; \
|
|
SP -= 2; \
|
|
d0 = (CELL) ((*_PREG)->y_u.fa.f); \
|
|
*HR++ = d0; \
|
|
d0 = (*_PREG)->y_u.fa.a; \
|
|
(*_PREG) = NEXTOP((*_PREG), fa); \
|
|
(*_SREG) = HR; \
|
|
HR += d0; \
|
|
GONext();
|
|
|
|
#define WRITE_L_STRUC_INSTINIT \
|
|
print_instruction((*_PREG), ON_NATIVE); \
|
|
register CELL d0; \
|
|
d0 = AbsAppl(HR); \
|
|
*(*_SREG) = d0; \
|
|
d0 = (CELL) ((*_PREG)->y_u.fa.f); \
|
|
*HR++ = d0; \
|
|
(*_SREG) = HR; \
|
|
d0 = (*_PREG)->y_u.fa.a; \
|
|
(*_PREG) = NEXTOP((*_PREG), fa); \
|
|
HR += d0; \
|
|
GONext();
|
|
|