force system to check for overflows at end of procceed for clauses with body.
This commit is contained in:
parent
f40ba3e6db
commit
e5232bc8fc
19
C/absmi.c
19
C/absmi.c
@ -2692,6 +2692,7 @@ Yap_absmi(int inp)
|
||||
a execute_c, just wait a bit more */
|
||||
if (ActiveSignals & YAP_CREEP_SIGNAL ||
|
||||
(PREG->opc != Yap_opcode(_procceed) &&
|
||||
PREG->opc != Yap_opcode(_safe_procceed) &&
|
||||
PREG->opc != Yap_opcode(_cut_e))) {
|
||||
GONext();
|
||||
}
|
||||
@ -3086,6 +3087,24 @@ Yap_absmi(int inp)
|
||||
CACHE_A1();
|
||||
JMPNext();
|
||||
|
||||
BOp(safe_procceed, p);
|
||||
CACHE_Y_AS_ENV(YREG);
|
||||
check_trail(TR);
|
||||
check_stack(NoStackDeallocate, H);
|
||||
ALWAYS_LOOKAHEAD(CPREG->opc);
|
||||
PREG = CPREG;
|
||||
/* for profiler */
|
||||
save_pc();
|
||||
ENV_YREG = ENV;
|
||||
#ifdef DEPTH_LIMIT
|
||||
DEPTH = ENV_YREG[E_DEPTH];
|
||||
#endif
|
||||
WRITEBACK_Y_AS_ENV();
|
||||
ALWAYS_GONext();
|
||||
ALWAYS_END_PREFETCH();
|
||||
ENDCACHE_Y_AS_ENV();
|
||||
ENDBOp();
|
||||
|
||||
BOp(procceed, p);
|
||||
CACHE_Y_AS_ENV(YREG);
|
||||
ALWAYS_LOOKAHEAD(CPREG->opc);
|
||||
|
@ -3507,7 +3507,11 @@ do_pass(int pass_no, yamop **entry_codep, int assembling, int *clause_has_blobsp
|
||||
!clinfo.alloc_found)
|
||||
code_p = a_e(_unlock_lu, code_p, pass_no);
|
||||
#endif
|
||||
code_p = a_pl(_procceed, cip->CurrentPred, code_p, pass_no);
|
||||
if (clinfo.alloc_found) {
|
||||
code_p = a_pl(_safe_procceed, cip->CurrentPred, code_p, pass_no);
|
||||
} else {
|
||||
code_p = a_pl(_procceed, cip->CurrentPred, code_p, pass_no);
|
||||
}
|
||||
break;
|
||||
case call_op:
|
||||
code_p = a_p(_call, &clinfo, code_p, pass_no, cip);
|
||||
|
@ -118,6 +118,7 @@ p_show_op_counters()
|
||||
print_instruction(_call_cpred);
|
||||
print_instruction(_call_c_wfail);
|
||||
print_instruction(_procceed);
|
||||
print_instruction(_safe_procceed);
|
||||
print_instruction(_allocate);
|
||||
print_instruction(_deallocate);
|
||||
|
||||
@ -479,7 +480,8 @@ p_show_ops_by_group(void)
|
||||
Yap_opcount[_fcall];
|
||||
|
||||
c_control.nproceeds =
|
||||
Yap_opcount[_procceed];
|
||||
Yap_opcount[_procceed]+
|
||||
Yap_opcount[_safe_procceed];
|
||||
|
||||
c_control.ncallbips =
|
||||
Yap_opcount[_call_cpred] +
|
||||
|
@ -3439,7 +3439,7 @@ lu_recorded(PredEntry *pe) {
|
||||
PELOCK(66,pe);
|
||||
PP = pe;
|
||||
#endif
|
||||
if (opc == _procceed) {
|
||||
if (opc == _procceed || opc == _safe_procceed) {
|
||||
P = pe->CodeOfPred;
|
||||
} else {
|
||||
if (P->opc != Yap_opcode(_execute_cpred)) {
|
||||
@ -3504,7 +3504,7 @@ p_recorded(void)
|
||||
if (!Yap_unify(GetDBLUKey(ap), ARG1))
|
||||
return FALSE;
|
||||
|
||||
if (opc == _procceed) {
|
||||
if (opc == _procceed || opc == _safe_procceed) {
|
||||
P = cl->ClCode;
|
||||
} else {
|
||||
CP = P;
|
||||
|
@ -1396,6 +1396,7 @@ has_cut(yamop *pc)
|
||||
return FALSE;
|
||||
case _deallocate:
|
||||
case _procceed:
|
||||
case _safe_procceed:
|
||||
pc = NEXTOP(pc,p);
|
||||
break;
|
||||
/* instructions type sc */
|
||||
|
@ -43,6 +43,7 @@
|
||||
OPCODE(dexecute ,pp),
|
||||
OPCODE(fcall ,Osbpp),
|
||||
OPCODE(call ,Osbpp),
|
||||
OPCODE(safe_procceed ,p),
|
||||
OPCODE(procceed ,p),
|
||||
OPCODE(allocate ,e),
|
||||
OPCODE(deallocate ,p),
|
||||
|
@ -424,6 +424,7 @@ restore_opcodes(yamop *pc, yamop *max)
|
||||
case _lock_lu:
|
||||
case _procceed:
|
||||
case _retry_profiled:
|
||||
case _safe_procceed:
|
||||
pc->u.p.p = PtoPredAdjust(pc->u.p.p);
|
||||
pc = NEXTOP(pc,p);
|
||||
break;
|
||||
|
@ -335,6 +335,7 @@
|
||||
case _deallocate:
|
||||
case _enter_profiling:
|
||||
case _retry_profiled:
|
||||
case _safe_procceed:
|
||||
pc = NEXTOP(pc,p);
|
||||
break;
|
||||
/* instructions type plxxs */
|
||||
|
Reference in New Issue
Block a user