force system to check for overflows at end of procceed for clauses with body.

This commit is contained in:
Vitor Santos Costa 2010-10-11 14:45:15 +01:00
parent f40ba3e6db
commit e5232bc8fc
8 changed files with 33 additions and 4 deletions

View File

@ -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);

View File

@ -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);

View File

@ -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] +

View File

@ -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;

View File

@ -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 */

View File

@ -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),

View File

@ -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;

View File

@ -335,6 +335,7 @@
case _deallocate:
case _enter_profiling:
case _retry_profiled:
case _safe_procceed:
pc = NEXTOP(pc,p);
break;
/* instructions type plxxs */