include amasm.c
This commit is contained in:
parent
6e2947e8c4
commit
7ad5bc0214
42
C/amasm.c
42
C/amasm.c
@ -1480,7 +1480,7 @@ a_p(op_numbers opcode, clause_info *clinfo, yamop *code_p, int pass_no, struct i
|
|||||||
op = _p_equal; /* just to make some compilers happy */
|
op = _p_equal; /* just to make some compilers happy */
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "internal assembler error for built-in (%d)", (Flags & 0x7f));
|
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "internal assembler error for built-in (%d)", (Flags & 0x7f));
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
}
|
}
|
||||||
if (is_test) {
|
if (is_test) {
|
||||||
UInt lab;
|
UInt lab;
|
||||||
@ -1503,7 +1503,7 @@ a_p(op_numbers opcode, clause_info *clinfo, yamop *code_p, int pass_no, struct i
|
|||||||
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil,
|
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil,
|
||||||
"user defined predicate cannot be a test predicate");
|
"user defined predicate cannot be a test predicate");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
} else
|
} else
|
||||||
code_p->opc = emit_op(_call_c_wfail);
|
code_p->opc = emit_op(_call_c_wfail);
|
||||||
code_p->u.slp.s =
|
code_p->u.slp.s =
|
||||||
@ -2053,7 +2053,7 @@ a_try(op_numbers opcode, CELL lab, CELL opr, int nofalts, int hascut, yamop *cod
|
|||||||
if ((newcp = (yamop *)Yap_AllocCodeSpace(size)) == NULL) {
|
if ((newcp = (yamop *)Yap_AllocCodeSpace(size)) == NULL) {
|
||||||
/* OOOPS, got in trouble, must do a longjmp and recover space */
|
/* OOOPS, got in trouble, must do a longjmp and recover space */
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch,2);
|
siglongjmp(cip->CompilerBotch,2);
|
||||||
}
|
}
|
||||||
Yap_LUIndexSpace_CP += size;
|
Yap_LUIndexSpace_CP += size;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
@ -2693,7 +2693,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _plus:
|
case _plus:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for +/2 (should be XC)");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for +/2 (should be XC)");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _minus:
|
case _minus:
|
||||||
code_p->opc = emit_op(_p_minus_y_cv);
|
code_p->opc = emit_op(_p_minus_y_cv);
|
||||||
@ -2701,7 +2701,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _times:
|
case _times:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for */2 (should be XC)");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for */2 (should be XC)");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _div:
|
case _div:
|
||||||
code_p->opc = emit_op(_p_div_y_cv);
|
code_p->opc = emit_op(_p_div_y_cv);
|
||||||
@ -2709,12 +2709,12 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _and:
|
case _and:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for /\\/2 (should be XC)");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for /\\/2 (should be XC)");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _or:
|
case _or:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for \\//2 (should be XC)");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for \\//2 (should be XC)");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _sll:
|
case _sll:
|
||||||
code_p->opc = emit_op(_p_sll_y_cv);
|
code_p->opc = emit_op(_p_sll_y_cv);
|
||||||
@ -2744,7 +2744,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _minus:
|
case _minus:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error XC for -/2");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error XC for -/2");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _times:
|
case _times:
|
||||||
code_p->opc = emit_op(_p_times_y_vc);
|
code_p->opc = emit_op(_p_times_y_vc);
|
||||||
@ -2777,7 +2777,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _arg:
|
case _arg:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error for arg/3");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error for arg/3");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _functor:
|
case _functor:
|
||||||
code_p->opc = emit_op(_p_func2s_y_vc);
|
code_p->opc = emit_op(_p_func2s_y_vc);
|
||||||
@ -2838,7 +2838,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _plus:
|
case _plus:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for +/2");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for +/2");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _minus:
|
case _minus:
|
||||||
code_p->opc = emit_op(_p_minus_cv);
|
code_p->opc = emit_op(_p_minus_cv);
|
||||||
@ -2846,7 +2846,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _times:
|
case _times:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for */2");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for */2");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _div:
|
case _div:
|
||||||
code_p->opc = emit_op(_p_div_cv);
|
code_p->opc = emit_op(_p_div_cv);
|
||||||
@ -2854,12 +2854,12 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _and:
|
case _and:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for /\\/2");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for /\\/2");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _or:
|
case _or:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for \\//2");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x1_arg, "internal assembler error CX for \\//2");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _sll:
|
case _sll:
|
||||||
code_p->opc = emit_op(_p_sll_cv);
|
code_p->opc = emit_op(_p_sll_cv);
|
||||||
@ -2889,7 +2889,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _minus:
|
case _minus:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error XC for -/2");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error XC for -/2");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _times:
|
case _times:
|
||||||
code_p->opc = emit_op(_p_times_vc);
|
code_p->opc = emit_op(_p_times_vc);
|
||||||
@ -2922,7 +2922,7 @@ a_f2(cmp_op_info *cmp_info, yamop *code_p, int pass_no, struct intermediates *ci
|
|||||||
case _arg:
|
case _arg:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error for arg/3");
|
Yap_Error(INTERNAL_COMPILER_ERROR, cmp_info->x2_arg, "internal assembler error for arg/3");
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
break;
|
break;
|
||||||
case _functor:
|
case _functor:
|
||||||
code_p->opc = emit_op(_p_func2s_vc);
|
code_p->opc = emit_op(_p_func2s_vc);
|
||||||
@ -3540,7 +3540,7 @@ do_pass(int pass_no, yamop **entry_codep, int assembling, int *clause_has_blobsp
|
|||||||
if (CellPtr(cip->label_offset+cip->cpc->rnd1) > ASP-256) {
|
if (CellPtr(cip->label_offset+cip->cpc->rnd1) > ASP-256) {
|
||||||
Yap_Error_Size = 256+((char *)(cip->label_offset+cip->cpc->rnd1) - (char *)H);
|
Yap_Error_Size = 256+((char *)(cip->label_offset+cip->cpc->rnd1) - (char *)H);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 3);
|
siglongjmp(cip->CompilerBotch, 3);
|
||||||
}
|
}
|
||||||
if ( (char *)(cip->label_offset+cip->cpc->rnd1) >= cip->freep)
|
if ( (char *)(cip->label_offset+cip->cpc->rnd1) >= cip->freep)
|
||||||
cip->freep = (char *)(cip->label_offset+(cip->cpc->rnd1+1));
|
cip->freep = (char *)(cip->label_offset+(cip->cpc->rnd1+1));
|
||||||
@ -3722,7 +3722,7 @@ do_pass(int pass_no, yamop **entry_codep, int assembling, int *clause_has_blobsp
|
|||||||
if (cip->cpc->nextInst->op != bccall_op) {
|
if (cip->cpc->nextInst->op != bccall_op) {
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "compiling binary test", (int) cip->cpc->op);
|
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "compiling binary test", (int) cip->cpc->op);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
}
|
}
|
||||||
code_p = a_bfunc(cip->cpc->nextInst->rnd2, &clinfo, code_p, pass_no, cip);
|
code_p = a_bfunc(cip->cpc->nextInst->rnd2, &clinfo, code_p, pass_no, cip);
|
||||||
break;
|
break;
|
||||||
@ -3762,7 +3762,7 @@ do_pass(int pass_no, yamop **entry_codep, int assembling, int *clause_has_blobsp
|
|||||||
default:
|
default:
|
||||||
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "instruction %d found while assembling", (int) cip->cpc->op);
|
Yap_Error(INTERNAL_COMPILER_ERROR, TermNil, "instruction %d found while assembling", (int) cip->cpc->op);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, 1);
|
siglongjmp(cip->CompilerBotch, 1);
|
||||||
}
|
}
|
||||||
cip->cpc = cip->cpc->nextInst;
|
cip->cpc = cip->cpc->nextInst;
|
||||||
}
|
}
|
||||||
@ -3788,7 +3788,7 @@ fetch_clause_space(Term* tp, UInt size, struct intermediates *cip, UInt *osizep)
|
|||||||
case OUT_OF_STACK_ERROR:
|
case OUT_OF_STACK_ERROR:
|
||||||
Yap_Error_Size = 256+((char *)cip->freep - (char *)H);
|
Yap_Error_Size = 256+((char *)cip->freep - (char *)H);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch,3);
|
siglongjmp(cip->CompilerBotch,3);
|
||||||
case OUT_OF_TRAIL_ERROR:
|
case OUT_OF_TRAIL_ERROR:
|
||||||
/* don't just return NULL */
|
/* don't just return NULL */
|
||||||
ARG1 = *tp;
|
ARG1 = *tp;
|
||||||
@ -3865,7 +3865,7 @@ Yap_assemble(int mode, Term t, PredEntry *ap, int is_fact, struct intermediates
|
|||||||
Yap_LabelFirstArraySz = DEFAULT_NLABELS;
|
Yap_LabelFirstArraySz = DEFAULT_NLABELS;
|
||||||
if (!Yap_LabelFirstArray) {
|
if (!Yap_LabelFirstArray) {
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, OUT_OF_HEAP_BOTCH);
|
siglongjmp(cip->CompilerBotch, OUT_OF_HEAP_BOTCH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Yap_LabelFirstArray && max_label <= Yap_LabelFirstArraySz) {
|
if (Yap_LabelFirstArray && max_label <= Yap_LabelFirstArraySz) {
|
||||||
@ -3874,7 +3874,7 @@ Yap_assemble(int mode, Term t, PredEntry *ap, int is_fact, struct intermediates
|
|||||||
cip->label_offset = (Int *)Yap_AllocCodeSpace(sizeof(Int)*max_label);
|
cip->label_offset = (Int *)Yap_AllocCodeSpace(sizeof(Int)*max_label);
|
||||||
if (!cip->label_offset) {
|
if (!cip->label_offset) {
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
_longjmp(cip->CompilerBotch, OUT_OF_HEAP_BOTCH);
|
siglongjmp(cip->CompilerBotch, OUT_OF_HEAP_BOTCH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user