From 7b89916c438ba7355f6121e177fc59c1c9e91d14 Mon Sep 17 00:00:00 2001 From: Vitor Santos Costa Date: Sun, 21 Feb 2010 00:45:49 +0000 Subject: [PATCH] C-code may mess up with environment: we cannot afford to just jump there from anywhere (obs from Stefano Ferili). --- C/exec.c | 24 ++++++++---------------- 1 file changed, 8 insertions(+), 16 deletions(-) diff --git a/C/exec.c b/C/exec.c index 3f84f6338..da5fa5752 100644 --- a/C/exec.c +++ b/C/exec.c @@ -782,25 +782,17 @@ p_execute_nonstop(void) } /* N = arity; */ /* call may not define new system predicates!! */ - if (ActiveSignals & YAP_CREEP_SIGNAL && !Yap_InterruptsDisabled) { - Yap_signal(YAP_CREEP_SIGNAL); - } if (RepPredProp(pe)->PredFlags & SpiedPredFlag) { + if (ActiveSignals & YAP_CREEP_SIGNAL && !Yap_InterruptsDisabled) { + Yap_signal(YAP_CREEP_SIGNAL); + } return CallPredicate(RepPredProp(pe), B, RepPredProp(pe)->cs.p_code.TrueCodeOfPred); - } else if ((RepPredProp(pe)->PredFlags & (AsmPredFlag|CPredFlag)) && - RepPredProp(pe)->OpcodeOfPred != Yap_opcode(_call_bfunc_xx)) { - /* USER C-Code may walk over registers */ - if (RepPredProp(pe)->PredFlags & UserCPredFlag) { - save_machine_regs(); + } else { if (ActiveSignals & YAP_CREEP_SIGNAL && + !Yap_InterruptsDisabled && + (!(RepPredProp(pe)->PredFlags & (AsmPredFlag|CPredFlag)) || + RepPredProp(pe)->OpcodeOfPred == Yap_opcode(_call_bfunc_xx))) { + Yap_signal(YAP_CREEP_SIGNAL); } - if (RepPredProp(pe)->PredFlags & UserCPredFlag) { - Int out = RepPredProp(pe)->cs.f_code(); - restore_machine_regs(); - return out; - } else { - return RepPredProp(pe)->cs.f_code(); - } - } else { return CallPredicate(RepPredProp(pe), B, RepPredProp(pe)->CodeOfPred); } }