fix compiltion of binary tests to use a long instruction.
This commit is contained in:
parent
b793ffb71a
commit
b1a6f092fd
67
C/amasm.c
67
C/amasm.c
@ -259,7 +259,6 @@ static yamop *a_try(op_numbers, CELL, CELL, yamop *, int, struct intermediates *
|
|||||||
static yamop *a_either(op_numbers, CELL, CELL, yamop *, int, struct intermediates *);
|
static yamop *a_either(op_numbers, CELL, CELL, yamop *, int, struct intermediates *);
|
||||||
#endif /* YAPOR */
|
#endif /* YAPOR */
|
||||||
static yamop *a_gl(op_numbers, yamop *, int, struct PSEUDO *, struct intermediates * CACHE_TYPE);
|
static yamop *a_gl(op_numbers, yamop *, int, struct PSEUDO *, struct intermediates * CACHE_TYPE);
|
||||||
static yamop *a_bfunc(CELL, clause_info *, yamop *, int, struct intermediates *);
|
|
||||||
static
|
static
|
||||||
COUNT compile_cmp_flags(char *);
|
COUNT compile_cmp_flags(char *);
|
||||||
static yamop *a_igl(CELL, op_numbers, yamop *, int, struct intermediates *);
|
static yamop *a_igl(CELL, op_numbers, yamop *, int, struct intermediates *);
|
||||||
@ -1622,65 +1621,63 @@ Yap_compile_cmp_flags(PredEntry *pred)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static yamop *
|
static yamop *
|
||||||
a_bfunc(CELL pred, clause_info *clinfo, yamop *code_p, int pass_no, struct intermediates *cip)
|
a_bfunc(CELL a1, CELL a2, PredEntry *pred, clause_info *clinfo, yamop *code_p, int pass_no, struct intermediates *cip)
|
||||||
{
|
{
|
||||||
Ventry *ve = (Ventry *) cip->cpc->rnd1;
|
Ventry *ve1 = (Ventry *)a1;
|
||||||
OPREG var_offset;
|
Ventry *ve2 = (Ventry *)a2;
|
||||||
int is_y_var = (ve->KindOfVE == PermVar);
|
OPREG var_offset1;
|
||||||
|
int is_y_var = (ve1->KindOfVE == PermVar);
|
||||||
var_offset = Var_Ref(ve, is_y_var);
|
|
||||||
if (ve->KindOfVE == PermVar) {
|
var_offset1 = Var_Ref(ve1, is_y_var);
|
||||||
yslot v1 = emit_yreg(var_offset);
|
if (ve1->KindOfVE == PermVar) {
|
||||||
cip->cpc = cip->cpc->nextInst;
|
yslot v1 = emit_yreg(var_offset1);
|
||||||
ve = (Ventry *) cip->cpc->rnd1;
|
bool is_y_var2 = (ve2->KindOfVE == PermVar);
|
||||||
is_y_var = (ve->KindOfVE == PermVar);
|
OPREG var_offset2 = Var_Ref(ve2, is_y_var2);
|
||||||
var_offset = Var_Ref(ve, is_y_var);
|
if (is_y_var2) {
|
||||||
if (is_y_var) {
|
|
||||||
if (pass_no) {
|
if (pass_no) {
|
||||||
code_p->opc = emit_op(_call_bfunc_yy);
|
code_p->opc = emit_op(_call_bfunc_yy);
|
||||||
code_p->y_u.plyys.p = RepPredProp(((Prop)pred));
|
code_p->y_u.plyys.p = pred;
|
||||||
code_p->y_u.plyys.f = emit_fail(cip);
|
code_p->y_u.plyys.f = emit_fail(cip);
|
||||||
code_p->y_u.plyys.y1 = v1;
|
code_p->y_u.plyys.y1 = v1;
|
||||||
code_p->y_u.plyys.y2 = emit_yreg(var_offset);
|
code_p->y_u.plyys.y2 = emit_yreg(var_offset2);
|
||||||
code_p->y_u.plyys.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
code_p->y_u.plyys.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
||||||
}
|
}
|
||||||
GONEXT(plyys);
|
GONEXT(plyys);
|
||||||
} else {
|
} else {
|
||||||
if (pass_no) {
|
if (pass_no) {
|
||||||
code_p->opc = emit_op(_call_bfunc_yx);
|
code_p->opc = emit_op(_call_bfunc_yx);
|
||||||
code_p->y_u.plxys.p = RepPredProp(((Prop)pred));
|
code_p->y_u.plxys.p = pred;
|
||||||
code_p->y_u.plxys.f = emit_fail(cip);
|
code_p->y_u.plxys.f = emit_fail(cip);
|
||||||
code_p->y_u.plxys.x = emit_xreg(var_offset);
|
code_p->y_u.plxys.x = emit_xreg(var_offset2);
|
||||||
code_p->y_u.plxys.y = v1;
|
code_p->y_u.plxys.y = v1;
|
||||||
code_p->y_u.plxys.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
code_p->y_u.plxys.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
||||||
}
|
}
|
||||||
GONEXT(plxys);
|
GONEXT(plxys);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
wamreg x1 = emit_xreg(var_offset);
|
wamreg x1 = emit_xreg(var_offset1);
|
||||||
OPREG var_offset;
|
OPREG var_offset2;
|
||||||
|
|
||||||
cip->cpc = cip->cpc->nextInst;
|
bool is_y_var2 = (ve2->KindOfVE == PermVar);
|
||||||
ve = (Ventry *) cip->cpc->rnd1;
|
var_offset2 = Var_Ref(ve2, is_y_var2);
|
||||||
is_y_var = (ve->KindOfVE == PermVar);
|
if (is_y_var2) {
|
||||||
var_offset = Var_Ref(ve, is_y_var);
|
|
||||||
if (is_y_var) {
|
|
||||||
if (pass_no) {
|
if (pass_no) {
|
||||||
code_p->opc = emit_op(_call_bfunc_xy);
|
code_p->opc = emit_op(_call_bfunc_xy);
|
||||||
code_p->y_u.plxys.p = RepPredProp(((Prop)pred));
|
code_p->y_u.plxys.p = pred;
|
||||||
code_p->y_u.plxys.f = emit_fail(cip);
|
code_p->y_u.plxys.f = emit_fail(cip);
|
||||||
code_p->y_u.plxys.x = x1;
|
code_p->y_u.plxys.x = x1;
|
||||||
code_p->y_u.plxys.y = emit_yreg(var_offset);
|
code_p->y_u.plxys.y = emit_yreg(var_offset2);
|
||||||
code_p->y_u.plxys.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
code_p->y_u.plxys.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
||||||
}
|
}
|
||||||
GONEXT(plxys);
|
GONEXT(plxys);
|
||||||
} else {
|
} else {
|
||||||
if (pass_no) {
|
if (pass_no) {
|
||||||
|
// printf(" %p --- %p\n", x1, emit_xreg(var_offset2) );
|
||||||
code_p->opc = emit_op(_call_bfunc_xx);
|
code_p->opc = emit_op(_call_bfunc_xx);
|
||||||
code_p->y_u.plxxs.p = RepPredProp(((Prop)pred));
|
code_p->y_u.plxxs.p = pred;
|
||||||
code_p->y_u.plxxs.f = emit_fail(cip);
|
code_p->y_u.plxxs.f = emit_fail(cip);
|
||||||
code_p->y_u.plxxs.x1 = x1;
|
code_p->y_u.plxxs.x1 = x1;
|
||||||
code_p->y_u.plxxs.x2 = emit_xreg(var_offset);
|
code_p->y_u.plxxs.x2 = emit_xreg(var_offset2);
|
||||||
code_p->y_u.plxxs.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
code_p->y_u.plxxs.flags = compile_cmp_flags(RepAtom(NameOfFunctor(RepPredProp(((Prop)pred))->FunctorOfPred))->StrOfAE);
|
||||||
}
|
}
|
||||||
GONEXT(plxxs);
|
GONEXT(plxxs);
|
||||||
@ -3685,13 +3682,8 @@ do_pass(int pass_no, yamop **entry_codep, int assembling, int *clause_has_blobsp
|
|||||||
case count_retry_op:
|
case count_retry_op:
|
||||||
code_p = a_pl(_count_retry, (PredEntry *)(cip->cpc->rnd1), code_p, pass_no);
|
code_p = a_pl(_count_retry, (PredEntry *)(cip->cpc->rnd1), code_p, pass_no);
|
||||||
break;
|
break;
|
||||||
case fetch_args_for_bccall_op:
|
case bccall_op:
|
||||||
if (cip->cpc->nextInst->op != bccall_op) {
|
code_p = a_bfunc(cip->cpc->rnd1, cip->cpc->rnd3, (PredEntry *)(cip->cpc->rnd5), &clinfo, code_p, pass_no, cip);
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "compiling binary test", (int) cip->cpc->op);
|
|
||||||
save_machine_regs();
|
|
||||||
siglongjmp(cip->CompilerBotch, 1);
|
|
||||||
}
|
|
||||||
code_p = a_bfunc(cip->cpc->nextInst->rnd2, &clinfo, code_p, pass_no, cip);
|
|
||||||
break;
|
break;
|
||||||
case align_float_op:
|
case align_float_op:
|
||||||
/* install a blob */
|
/* install a blob */
|
||||||
@ -3888,6 +3880,7 @@ Yap_assemble(int mode, Term t, PredEntry *ap, int is_fact, struct intermediates
|
|||||||
DBTerm *x;
|
DBTerm *x;
|
||||||
StaticClause *cl;
|
StaticClause *cl;
|
||||||
UInt osize;
|
UInt osize;
|
||||||
|
if (ap->PredFlags & SourcePredFlag ) printf("BINGO\n");
|
||||||
if(!(x = fetch_clause_space(&t, size, cip, &osize PASS_REGS))) {
|
if(!(x = fetch_clause_space(&t, size, cip, &osize PASS_REGS))) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
164
C/compiler.c
164
C/compiler.c
@ -236,7 +236,7 @@ static void c_bifun(basic_preds, Term, Term, Term, Term, Term, compiler_struct *
|
|||||||
static void c_goal(Term, Term, compiler_struct *);
|
static void c_goal(Term, Term, compiler_struct *);
|
||||||
static void c_body(Term, Term, compiler_struct *);
|
static void c_body(Term, Term, compiler_struct *);
|
||||||
static void c_head(Term, compiler_struct *);
|
static void c_head(Term, compiler_struct *);
|
||||||
static int usesvar(compiler_vm_op);
|
static bool usesvar(compiler_vm_op);
|
||||||
static CELL *init_bvarray(int, compiler_struct *);
|
static CELL *init_bvarray(int, compiler_struct *);
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
static void clear_bvarray(int, CELL *, compiler_struct *);
|
static void clear_bvarray(int, CELL *, compiler_struct *);
|
||||||
@ -446,12 +446,6 @@ c_var(Term t, Int argno, unsigned int arity, unsigned int level, compiler_struct
|
|||||||
Yap_emit(f_val_op, t, (CELL)arity, &cglobs->cint);
|
Yap_emit(f_val_op, t, (CELL)arity, &cglobs->cint);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case bt1_flag:
|
|
||||||
Yap_emit(fetch_args_for_bccall_op, t, 0, &cglobs->cint);
|
|
||||||
break;
|
|
||||||
case bt2_flag:
|
|
||||||
Yap_emit(bccall_op, t, (CELL)cglobs->current_p0, &cglobs->cint);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
#ifdef SFUNC
|
#ifdef SFUNC
|
||||||
if (argno < 0) {
|
if (argno < 0) {
|
||||||
@ -483,6 +477,24 @@ c_var(Term t, Int argno, unsigned int arity, unsigned int level, compiler_struct
|
|||||||
tag_var(t, new, cglobs);
|
tag_var(t, new, cglobs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// built-in like X >= Y.
|
||||||
|
static void
|
||||||
|
c_2vars(int op, Term t1, Int argno1, Term t2, Int argno2, CELL extra, unsigned int arity, unsigned int level, compiler_struct *cglobs)
|
||||||
|
{
|
||||||
|
int new1 = check_var((t1 = Deref(t1)), level, argno1, cglobs);
|
||||||
|
int new2 = check_var((t2 = Deref(t2)), level, argno2, cglobs);
|
||||||
|
|
||||||
|
switch (op) {
|
||||||
|
case bt_flag:
|
||||||
|
Yap_emit_5ops(bccall_op, t1, argno1, t2, argno2, extra, &cglobs->cint);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
tag_var(t1, new1, cglobs);
|
||||||
|
tag_var(t2, new2, cglobs);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
reset_vars(Ventry *vtable)
|
reset_vars(Ventry *vtable)
|
||||||
{
|
{
|
||||||
@ -1876,9 +1888,8 @@ c_goal(Term Goal, Term mod, compiler_struct *cglobs)
|
|||||||
v->FlagsOfVE |= SafeVar;
|
v->FlagsOfVE |= SafeVar;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if (p->PredFlags & AsmPredFlag) {
|
else if (p->PredFlags & (AsmPredFlag)) {
|
||||||
basic_preds op = p->PredFlags & 0x7f;
|
basic_preds op = p->PredFlags & 0x7f;
|
||||||
|
|
||||||
if (profiling)
|
if (profiling)
|
||||||
Yap_emit(enter_profiling_op, (CELL)p, Zero, &cglobs->cint);
|
Yap_emit(enter_profiling_op, (CELL)p, Zero, &cglobs->cint);
|
||||||
else if (call_counting)
|
else if (call_counting)
|
||||||
@ -1941,7 +1952,7 @@ c_goal(Term Goal, Term mod, compiler_struct *cglobs)
|
|||||||
#ifdef BEAM
|
#ifdef BEAM
|
||||||
else if (p->PredFlags & BinaryPredFlag && !EAM) {
|
else if (p->PredFlags & BinaryPredFlag && !EAM) {
|
||||||
#else
|
#else
|
||||||
else if (p->PredFlags & BinaryPredFlag) {
|
else if (p->PredFlags & BinaryPredFlag ) {
|
||||||
#endif
|
#endif
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
Term a1 = ArgOfTerm(1,Goal);
|
Term a1 = ArgOfTerm(1,Goal);
|
||||||
@ -1949,33 +1960,25 @@ c_goal(Term Goal, Term mod, compiler_struct *cglobs)
|
|||||||
if (IsVarTerm(a1) && !IsNewVar(a1)) {
|
if (IsVarTerm(a1) && !IsNewVar(a1)) {
|
||||||
Term a2 = ArgOfTerm(2,Goal);
|
Term a2 = ArgOfTerm(2,Goal);
|
||||||
if (IsVarTerm(a2) && !IsNewVar(a2)) {
|
if (IsVarTerm(a2) && !IsNewVar(a2)) {
|
||||||
if (IsNewVar(a2)) {
|
|
||||||
LOCAL_Error_TYPE = INSTANTIATION_ERROR;
|
|
||||||
LOCAL_Error_Term = a2;
|
|
||||||
LOCAL_ErrorMessage = LOCAL_ErrorSay;
|
|
||||||
sprintf(LOCAL_ErrorMessage, "compiling %s/2 with second arg unbound", RepAtom(NameOfFunctor(p->FunctorOfPred))->StrOfAE);
|
|
||||||
save_machine_regs();
|
|
||||||
siglongjmp(cglobs->cint.CompilerBotch,1);
|
|
||||||
}
|
|
||||||
c_var(a1, bt1_flag, 2, 0, cglobs);
|
|
||||||
cglobs->current_p0 = p0;
|
cglobs->current_p0 = p0;
|
||||||
c_var(a2, bt2_flag, 2, 0, cglobs);
|
c_2vars(bt_flag, a1, 0, a2, 0, (CELL)p0, 0, 0, cglobs);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Term t2 = MkVarTerm();
|
Term t2 = MkVarTerm();
|
||||||
|
//c_var(t2, --cglobs->tmpreg, 0, 0, cglobs);
|
||||||
if (HR == (CELL *)cglobs->cint.freep0) {
|
if (HR == (CELL *)cglobs->cint.freep0) {
|
||||||
/* oops, too many new variables */
|
/* oops, too many new variables */
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
siglongjmp(cglobs->cint.CompilerBotch,OUT_OF_TEMPS_BOTCH);
|
siglongjmp(cglobs->cint.CompilerBotch,OUT_OF_TEMPS_BOTCH);
|
||||||
}
|
}
|
||||||
c_eq(t2, a2, cglobs);
|
|
||||||
c_var(a1, bt1_flag, 2, 0, cglobs);
|
|
||||||
cglobs->current_p0 = p0;
|
cglobs->current_p0 = p0;
|
||||||
c_var(t2, bt2_flag, 2, 0, cglobs);
|
c_eq(t2, a2, cglobs);
|
||||||
|
c_2vars(bt_flag, a1, 0, t2, 0, (CELL)p0, 0, 0, cglobs);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Term a2 = ArgOfTerm(2,Goal);
|
Term a2 = ArgOfTerm(2,Goal);
|
||||||
Term t1 = MkVarTerm();
|
Term t1 = MkVarTerm();
|
||||||
|
//c_var(t1, --cglobs->tmpreg, 0, 0, cglobs);
|
||||||
if (HR == (CELL *)cglobs->cint.freep0) {
|
if (HR == (CELL *)cglobs->cint.freep0) {
|
||||||
/* oops, too many new variables */
|
/* oops, too many new variables */
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
@ -1984,21 +1987,20 @@ c_goal(Term Goal, Term mod, compiler_struct *cglobs)
|
|||||||
c_eq(t1, a1, cglobs);
|
c_eq(t1, a1, cglobs);
|
||||||
|
|
||||||
if (IsVarTerm(a2) && !IsNewVar(a2)) {
|
if (IsVarTerm(a2) && !IsNewVar(a2)) {
|
||||||
c_var(t1, bt1_flag, 2, 0, cglobs);
|
|
||||||
cglobs->current_p0 = p0;
|
cglobs->current_p0 = p0;
|
||||||
c_var(a2, bt2_flag, 2, 0, cglobs);
|
c_2vars(bt_flag, t1, 0, a2, 0, (CELL)p0, 0, 0, cglobs);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Term t2 = MkVarTerm();
|
Term t2 = MkVarTerm();
|
||||||
|
// c_var(t2, --cglobs->tmpreg, 0, 0, cglobs);
|
||||||
if (HR == (CELL *)cglobs->cint.freep0) {
|
if (HR == (CELL *)cglobs->cint.freep0) {
|
||||||
/* oops, too many new variables */
|
/* oops, too many new variables */
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
siglongjmp(cglobs->cint.CompilerBotch,OUT_OF_TEMPS_BOTCH);
|
siglongjmp(cglobs->cint.CompilerBotch,OUT_OF_TEMPS_BOTCH);
|
||||||
}
|
}
|
||||||
c_eq(t2, a2, cglobs);
|
c_eq(t2, a2, cglobs);
|
||||||
c_var(t1, bt1_flag, 2, 0, cglobs);
|
|
||||||
cglobs->current_p0 = p0;
|
cglobs->current_p0 = p0;
|
||||||
c_var(t2, bt2_flag, 2, 0, cglobs);
|
c_2vars(bt_flag, t1, 0, t2, 0, (CELL)p0, 0, 0, cglobs);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (cglobs->onlast) {
|
if (cglobs->onlast) {
|
||||||
@ -2183,11 +2185,11 @@ c_head(Term t, compiler_struct *cglobs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline static int
|
inline static bool
|
||||||
usesvar(compiler_vm_op ic)
|
usesvar(compiler_vm_op ic)
|
||||||
{
|
{
|
||||||
if (ic >= get_var_op && ic <= put_val_op)
|
if (ic >= get_var_op && ic <= put_val_op)
|
||||||
return TRUE;
|
return true;
|
||||||
switch (ic) {
|
switch (ic) {
|
||||||
case save_b_op:
|
case save_b_op:
|
||||||
case commit_b_op:
|
case commit_b_op:
|
||||||
@ -2196,21 +2198,36 @@ usesvar(compiler_vm_op ic)
|
|||||||
case save_pair_op:
|
case save_pair_op:
|
||||||
case f_val_op:
|
case f_val_op:
|
||||||
case f_var_op:
|
case f_var_op:
|
||||||
case fetch_args_for_bccall_op:
|
|
||||||
case bccall_op:
|
case bccall_op:
|
||||||
return TRUE;
|
return true;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#ifdef SFUNC
|
#ifdef SFUNC
|
||||||
if (ic >= unify_s_var_op && ic <= write_s_val_op)
|
if (ic >= unify_s_var_op && ic <= write_s_val_op)
|
||||||
return TRUE;
|
return true;
|
||||||
#endif
|
#endif
|
||||||
return ((ic >= unify_var_op && ic <= write_val_op)
|
return ((ic >= unify_var_op && ic <= write_val_op)
|
||||||
||
|
||
|
||||||
(ic >= unify_last_var_op && ic <= unify_last_val_op));
|
(ic >= unify_last_var_op && ic <= unify_last_val_op));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline static bool
|
||||||
|
uses_this_var(PInstr *pc, Term arg)
|
||||||
|
{
|
||||||
|
compiler_vm_op ic = pc->op;
|
||||||
|
|
||||||
|
if (pc->rnd1 != arg)
|
||||||
|
return arg == pc->rnd3 && ic == bccall_op;
|
||||||
|
return usesvar( ic );
|
||||||
|
}
|
||||||
|
|
||||||
|
inline static bool
|
||||||
|
usesvar2(compiler_vm_op ic)
|
||||||
|
{
|
||||||
|
return ic == bccall_op;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Do as in the traditional WAM and make sure voids are in
|
* Do as in the traditional WAM and make sure voids are in
|
||||||
* environments
|
* environments
|
||||||
@ -2224,6 +2241,34 @@ typedef struct env_tmp {
|
|||||||
} EnvTmp;
|
} EnvTmp;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
tag_use(Ventry *v USES_REGS)
|
||||||
|
{
|
||||||
|
#ifdef BEAM
|
||||||
|
if (EAM) {
|
||||||
|
if (v->NoOfVE == Unassigned || v->KindOfVE!=PermVar) {
|
||||||
|
v->NoOfVE = PermVar | (LOCAL_nperm++);
|
||||||
|
v->KindOfVE = PermVar;
|
||||||
|
v->FlagsOfVE |= PermFlag;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
if (v->NoOfVE == Unassigned) {
|
||||||
|
if ((v->AgeOfVE > 1 && (v->AgeOfVE > v->FirstOfVE))
|
||||||
|
|| v->KindOfVE == PermVar /*
|
||||||
|
* * || (v->FlagsOfVE & NonVoid && !(v->FlagsOfVE &
|
||||||
|
* * OnHeadFlag))
|
||||||
|
*/ ) {
|
||||||
|
v->NoOfVE = PermVar | (LOCAL_nperm++);
|
||||||
|
v->KindOfVE = PermVar;
|
||||||
|
v->FlagsOfVE |= PermFlag;
|
||||||
|
} else {
|
||||||
|
v->NoOfVE = v->KindOfVE = TempVar;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
AssignPerm(PInstr *pc, compiler_struct *cglobs)
|
AssignPerm(PInstr *pc, compiler_struct *cglobs)
|
||||||
{
|
{
|
||||||
@ -2277,28 +2322,12 @@ AssignPerm(PInstr *pc, compiler_struct *cglobs)
|
|||||||
if (uses_var) {
|
if (uses_var) {
|
||||||
Ventry *v = (Ventry *) (pc->rnd1);
|
Ventry *v = (Ventry *) (pc->rnd1);
|
||||||
|
|
||||||
#ifdef BEAM
|
tag_use(v PASS_REGS);
|
||||||
if (EAM) {
|
if (usesvar2(pc->op) ) {
|
||||||
if (v->NoOfVE == Unassigned || v->KindOfVE!=PermVar) {
|
Ventry *v2 = (Ventry *) (pc->rnd3);
|
||||||
v->NoOfVE = PermVar | (LOCAL_nperm++);
|
tag_use(v2 PASS_REGS);
|
||||||
v->KindOfVE = PermVar;
|
|
||||||
v->FlagsOfVE |= PermFlag;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (v->NoOfVE == Unassigned) {
|
|
||||||
if ((v->AgeOfVE > 1 && (v->AgeOfVE > v->FirstOfVE))
|
|
||||||
|| v->KindOfVE == PermVar /*
|
|
||||||
* * || (v->FlagsOfVE & NonVoid && !(v->FlagsOfVE &
|
|
||||||
* * OnHeadFlag))
|
|
||||||
*/ ) {
|
|
||||||
v->NoOfVE = PermVar | (LOCAL_nperm++);
|
|
||||||
v->KindOfVE = PermVar;
|
|
||||||
v->FlagsOfVE |= PermFlag;
|
|
||||||
} else {
|
|
||||||
v->NoOfVE = v->KindOfVE = TempVar;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (pc->op == empty_call_op) {
|
} else if (pc->op == empty_call_op) {
|
||||||
pc->rnd2 = LOCAL_nperm;
|
pc->rnd2 = LOCAL_nperm;
|
||||||
} else if (pc->op == call_op || pc->op == either_op || pc->op == orelse_op || pc->op == push_or_op) {
|
} else if (pc->op == call_op || pc->op == either_op || pc->op == orelse_op || pc->op == push_or_op) {
|
||||||
@ -2357,7 +2386,6 @@ clear_bvarray(int var, CELL *bvarray
|
|||||||
LOCAL_Error_TYPE = INTERNAL_COMPILER_ERROR;
|
LOCAL_Error_TYPE = INTERNAL_COMPILER_ERROR;
|
||||||
LOCAL_Error_Term = TermNil;
|
LOCAL_Error_Term = TermNil;
|
||||||
LOCAL_ErrorMessage = "compiler internal error: variable initialised twice";
|
LOCAL_ErrorMessage = "compiler internal error: variable initialised twice";
|
||||||
fprintf(stderr," vsc: compiling7\n");
|
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
siglongjmp(cglobs->cint.CompilerBotch, COMPILER_ERR_BOTCH);
|
siglongjmp(cglobs->cint.CompilerBotch, COMPILER_ERR_BOTCH);
|
||||||
}
|
}
|
||||||
@ -2488,6 +2516,22 @@ CheckUnsafe(PInstr *pc, compiler_struct *cglobs)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case bccall_op:
|
||||||
|
{
|
||||||
|
Ventry *v = (Ventry *) (pc->rnd1),
|
||||||
|
*v3 = (Ventry *) (pc->rnd3);
|
||||||
|
|
||||||
|
if ( (v->FlagsOfVE & PermFlag && pc == v->FirstOpForV) ||
|
||||||
|
(v3->FlagsOfVE & PermFlag && pc == v3->FirstOpForV) ) {
|
||||||
|
CACHE_REGS
|
||||||
|
LOCAL_Error_TYPE = INTERNAL_COMPILER_ERROR;
|
||||||
|
LOCAL_Error_Term = TermNil;
|
||||||
|
LOCAL_ErrorMessage = "comparison should not have first instance of variables";
|
||||||
|
save_machine_regs();
|
||||||
|
siglongjmp(cglobs->cint.CompilerBotch, COMPILER_ERR_BOTCH);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
case put_var_op:
|
case put_var_op:
|
||||||
case get_var_op:
|
case get_var_op:
|
||||||
case save_b_op:
|
case save_b_op:
|
||||||
@ -2625,6 +2669,10 @@ CheckVoids(compiler_struct *cglobs)
|
|||||||
case get_list_op:
|
case get_list_op:
|
||||||
case get_struct_op:
|
case get_struct_op:
|
||||||
cglobs->Uses[cpc->rnd2] = 1;
|
cglobs->Uses[cpc->rnd2] = 1;
|
||||||
|
break;
|
||||||
|
case bccall_op:
|
||||||
|
cglobs->Uses[cpc->rnd2] = 1;
|
||||||
|
cglobs->Uses[cpc->rnd4] = 1;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -2676,7 +2724,9 @@ checktemp(Int arg, Int rn, compiler_vm_op ic, compiler_struct *cglobs)
|
|||||||
n = v->RCountOfVE - 1;
|
n = v->RCountOfVE - 1;
|
||||||
while (q != v->LastOpForV && (q = q->nextInst) != NIL) {
|
while (q != v->LastOpForV && (q = q->nextInst) != NIL) {
|
||||||
if (q->rnd2 <= 0); /* don't try to reuse REGISTER 0 */
|
if (q->rnd2 <= 0); /* don't try to reuse REGISTER 0 */
|
||||||
else if (usesvar(ic = q->op) && arg == q->rnd1) {
|
else if ((usesvar(ic = q->op) && arg == q->rnd1) ||
|
||||||
|
(ic == bccall_op && arg == q->rnd3)/*uses_this_var(q, arg)*/) {
|
||||||
|
ic = q->op;
|
||||||
--n;
|
--n;
|
||||||
if (ic == put_val_op) {
|
if (ic == put_val_op) {
|
||||||
if (target1 == cglobs->MaxCTemps && Needed[q->rnd2] == 0)
|
if (target1 == cglobs->MaxCTemps && Needed[q->rnd2] == 0)
|
||||||
@ -2963,9 +3013,11 @@ c_layout(compiler_struct *cglobs)
|
|||||||
case unify_s_var_op:
|
case unify_s_var_op:
|
||||||
case unify_s_val_op:
|
case unify_s_val_op:
|
||||||
#endif
|
#endif
|
||||||
case fetch_args_for_bccall_op:
|
checktemp(arg, rn, ic, cglobs);
|
||||||
|
break;
|
||||||
case bccall_op:
|
case bccall_op:
|
||||||
checktemp(arg, rn, ic, cglobs);
|
checktemp(arg, rn, ic, cglobs);
|
||||||
|
checktemp(cglobs->cint.cpc->rnd3, cglobs->cint.cpc->rnd4, ic, cglobs);
|
||||||
break;
|
break;
|
||||||
case get_atom_op:
|
case get_atom_op:
|
||||||
case get_num_op:
|
case get_num_op:
|
||||||
|
6
C/grow.c
6
C/grow.c
@ -1079,8 +1079,6 @@ fix_compiler_instructions(PInstr *pcpc USES_REGS)
|
|||||||
case write_local_op:
|
case write_local_op:
|
||||||
case f_var_op:
|
case f_var_op:
|
||||||
case f_val_op:
|
case f_val_op:
|
||||||
case fetch_args_for_bccall_op:
|
|
||||||
case bccall_op:
|
|
||||||
case save_pair_op:
|
case save_pair_op:
|
||||||
case save_appl_op:
|
case save_appl_op:
|
||||||
case save_b_op:
|
case save_b_op:
|
||||||
@ -1090,6 +1088,10 @@ fix_compiler_instructions(PInstr *pcpc USES_REGS)
|
|||||||
case fetch_args_vc_op:
|
case fetch_args_vc_op:
|
||||||
pcpc->rnd1 = GlobalAdjust(pcpc->rnd1);
|
pcpc->rnd1 = GlobalAdjust(pcpc->rnd1);
|
||||||
break;
|
break;
|
||||||
|
case bccall_op:
|
||||||
|
pcpc->rnd1 = GlobalAdjust(pcpc->rnd1);
|
||||||
|
pcpc->rnd3 = GlobalAdjust(pcpc->rnd3);
|
||||||
|
break;
|
||||||
case get_float_op:
|
case get_float_op:
|
||||||
case put_float_op:
|
case put_float_op:
|
||||||
case get_longint_op:
|
case get_longint_op:
|
||||||
|
Reference in New Issue
Block a user