bug fixes
git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@1163 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
parent
eb05d95935
commit
8e92ce869f
12
C/cdmgr.c
12
C/cdmgr.c
@ -11,8 +11,13 @@
|
|||||||
* File: cdmgr.c *
|
* File: cdmgr.c *
|
||||||
* comments: Code manager *
|
* comments: Code manager *
|
||||||
* *
|
* *
|
||||||
* Last rev: $Date: 2004-10-06 16:55:46 $,$Author: vsc $ *
|
* Last rev: $Date: 2004-10-22 16:53:19 $,$Author: vsc $ *
|
||||||
* $Log: not supported by cvs2svn $
|
* $Log: not supported by cvs2svn $
|
||||||
|
* Revision 1.136 2004/10/06 16:55:46 vsc
|
||||||
|
* change configure to support big mem configs
|
||||||
|
* get rid of extra globals
|
||||||
|
* fix trouble with multifile preds
|
||||||
|
*
|
||||||
* Revision 1.135 2004/09/30 21:37:40 vsc
|
* Revision 1.135 2004/09/30 21:37:40 vsc
|
||||||
* fixes for thread support
|
* fixes for thread support
|
||||||
*
|
*
|
||||||
@ -395,12 +400,16 @@ split_megaclause(PredEntry *ap)
|
|||||||
StaticClause *cl = start;
|
StaticClause *cl = start;
|
||||||
start = cl->ClNext;
|
start = cl->ClNext;
|
||||||
Yap_FreeCodeSpace((char *)cl);
|
Yap_FreeCodeSpace((char *)cl);
|
||||||
|
start = NULL;
|
||||||
}
|
}
|
||||||
if (ap->ArityOfPE) {
|
if (ap->ArityOfPE) {
|
||||||
Yap_Error(OUT_OF_HEAP_ERROR,TermNil,"while breaking up mega clause for %s/%d\n",RepAtom(NameOfFunctor(ap->FunctorOfPred))->StrOfAE,ap->ArityOfPE);
|
Yap_Error(OUT_OF_HEAP_ERROR,TermNil,"while breaking up mega clause for %s/%d\n",RepAtom(NameOfFunctor(ap->FunctorOfPred))->StrOfAE,ap->ArityOfPE);
|
||||||
} else {
|
} else {
|
||||||
Yap_Error(OUT_OF_HEAP_ERROR,TermNil,"while breaking up mega clause for %s\n", RepAtom((Atom)ap->FunctorOfPred)->StrOfAE);
|
Yap_Error(OUT_OF_HEAP_ERROR,TermNil,"while breaking up mega clause for %s\n", RepAtom((Atom)ap->FunctorOfPred)->StrOfAE);
|
||||||
}
|
}
|
||||||
|
WRITE_UNLOCK(ap->PRWLock);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
new->ClFlags = FactMask;
|
new->ClFlags = FactMask;
|
||||||
new->ClSize = mcl->ClItemSize;
|
new->ClSize = mcl->ClItemSize;
|
||||||
@ -415,7 +424,6 @@ split_megaclause(PredEntry *ap)
|
|||||||
ptr = (yamop *)((char *)ptr + mcl->ClItemSize);
|
ptr = (yamop *)((char *)ptr + mcl->ClItemSize);
|
||||||
prev = new;
|
prev = new;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
ap->PredFlags &= ~MegaClausePredFlag;
|
ap->PredFlags &= ~MegaClausePredFlag;
|
||||||
ap->cs.p_code.FirstClause = start->ClCode;
|
ap->cs.p_code.FirstClause = start->ClCode;
|
||||||
ap->cs.p_code.LastClause = prev->ClCode;
|
ap->cs.p_code.LastClause = prev->ClCode;
|
||||||
|
63
C/index.c
63
C/index.c
@ -11,8 +11,12 @@
|
|||||||
* File: index.c *
|
* File: index.c *
|
||||||
* comments: Indexing a Prolog predicate *
|
* comments: Indexing a Prolog predicate *
|
||||||
* *
|
* *
|
||||||
* Last rev: $Date: 2004-10-04 18:56:19 $,$Author: vsc $ *
|
* Last rev: $Date: 2004-10-22 16:53:19 $,$Author: vsc $ *
|
||||||
* $Log: not supported by cvs2svn $
|
* $Log: not supported by cvs2svn $
|
||||||
|
* Revision 1.102 2004/10/04 18:56:19 vsc
|
||||||
|
* fixes for thread support
|
||||||
|
* fix indexing bug (serious)
|
||||||
|
*
|
||||||
* Revision 1.101 2004/09/30 21:37:41 vsc
|
* Revision 1.101 2004/09/30 21:37:41 vsc
|
||||||
* fixes for thread support
|
* fixes for thread support
|
||||||
*
|
*
|
||||||
@ -5943,7 +5947,13 @@ insertz_in_lu_block(LogUpdIndex *blk, PredEntry *ap, yamop *code)
|
|||||||
bsize = blk->ClSize;
|
bsize = blk->ClSize;
|
||||||
end = (yamop *)((CODEADDR)blk+bsize);
|
end = (yamop *)((CODEADDR)blk+bsize);
|
||||||
where = last = begin->u.Ill.l2;
|
where = last = begin->u.Ill.l2;
|
||||||
next = NEXTOP(NEXTOP(where, ld),p); /* trust logical followed by trust */
|
next = NEXTOP(where, ld);
|
||||||
|
if (ap->PredFlags & CountPredFlag) {
|
||||||
|
next = NEXTOP(where,p); /* trust logical followed by trust */
|
||||||
|
}
|
||||||
|
if (ap->PredFlags & ProfiledPredFlag) {
|
||||||
|
next = NEXTOP(where,p); /* trust logical followed by trust */
|
||||||
|
}
|
||||||
last = PREVOP(last, ld);
|
last = PREVOP(last, ld);
|
||||||
/* follow profiling and counting instructions */
|
/* follow profiling and counting instructions */
|
||||||
if (ap->PredFlags & ProfiledPredFlag) {
|
if (ap->PredFlags & ProfiledPredFlag) {
|
||||||
@ -6793,36 +6803,21 @@ Yap_AddClauseToIndex(PredEntry *ap, yamop *beg, int first) {
|
|||||||
if ((cb = setjmp(cint.CompilerBotch)) == 3) {
|
if ((cb = setjmp(cint.CompilerBotch)) == 3) {
|
||||||
restore_machine_regs();
|
restore_machine_regs();
|
||||||
Yap_gcl(Yap_Error_Size, ap->ArityOfPE, ENV, CP);
|
Yap_gcl(Yap_Error_Size, ap->ArityOfPE, ENV, CP);
|
||||||
|
save_machine_regs();
|
||||||
} else if (cb == 2) {
|
} else if (cb == 2) {
|
||||||
restore_machine_regs();
|
restore_machine_regs();
|
||||||
if (!Yap_growheap(FALSE, Yap_Error_Size, NULL)) {
|
Yap_growheap(FALSE, Yap_Error_Size, NULL);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
if (ap->PredFlags & LogUpdatePredFlag) {
|
|
||||||
Yap_kill_iblock((ClauseUnion *)ClauseCodeToLogUpdIndex(ap->cs.p_code.TrueCodeOfPred),NULL, ap);
|
|
||||||
} else {
|
|
||||||
StaticIndex *cl;
|
|
||||||
|
|
||||||
cl = ClauseCodeToStaticIndex(ap->cs.p_code.TrueCodeOfPred);
|
|
||||||
Yap_kill_iblock((ClauseUnion *)cl, NULL, ap);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} else if (cb == 4) {
|
} else if (cb == 4) {
|
||||||
restore_machine_regs();
|
restore_machine_regs();
|
||||||
if (!Yap_growtrail(Yap_Error_Size)) {
|
Yap_growtrail(Yap_Error_Size);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
if (ap->PredFlags & LogUpdatePredFlag) {
|
|
||||||
Yap_kill_iblock((ClauseUnion *)ClauseCodeToLogUpdIndex(ap->cs.p_code.TrueCodeOfPred),NULL, ap);
|
|
||||||
} else {
|
|
||||||
StaticIndex *cl;
|
|
||||||
|
|
||||||
cl = ClauseCodeToStaticIndex(ap->cs.p_code.TrueCodeOfPred);
|
|
||||||
Yap_kill_iblock((ClauseUnion *)cl, NULL, ap);
|
|
||||||
}
|
}
|
||||||
|
if (cb) {
|
||||||
|
Yap_RemoveIndexation(ap);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Yap_Error_Size = 0;
|
Yap_Error_Size = 0;
|
||||||
}
|
|
||||||
Yap_ErrorMessage = NULL;
|
Yap_ErrorMessage = NULL;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (Yap_Option['i' - 'a' + 1]) {
|
if (Yap_Option['i' - 'a' + 1]) {
|
||||||
@ -7324,25 +7319,20 @@ Yap_RemoveClauseFromIndex(PredEntry *ap, yamop *beg) {
|
|||||||
if ((cb = setjmp(cint.CompilerBotch)) == 3) {
|
if ((cb = setjmp(cint.CompilerBotch)) == 3) {
|
||||||
restore_machine_regs();
|
restore_machine_regs();
|
||||||
Yap_gcl(Yap_Error_Size, ap->ArityOfPE, ENV, CP);
|
Yap_gcl(Yap_Error_Size, ap->ArityOfPE, ENV, CP);
|
||||||
|
save_machine_regs();
|
||||||
} else if (cb == 2) {
|
} else if (cb == 2) {
|
||||||
restore_machine_regs();
|
restore_machine_regs();
|
||||||
if (!Yap_growheap(FALSE, Yap_Error_Size, NULL)) {
|
Yap_growheap(FALSE, Yap_Error_Size, NULL);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
if (ap->PredFlags & LogUpdatePredFlag) {
|
|
||||||
Yap_kill_iblock((ClauseUnion *)ClauseCodeToLogUpdIndex(ap->cs.p_code.TrueCodeOfPred),NULL, ap);
|
|
||||||
} else {
|
|
||||||
StaticIndex *cl;
|
|
||||||
|
|
||||||
cl = ClauseCodeToStaticIndex(ap->cs.p_code.TrueCodeOfPred);
|
|
||||||
Yap_kill_iblock((ClauseUnion *)cl, NULL, ap);
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Yap_Error_Size = 0;
|
|
||||||
} else if (cb == 4) {
|
} else if (cb == 4) {
|
||||||
restore_machine_regs();
|
restore_machine_regs();
|
||||||
if (!Yap_growtrail(Yap_Error_Size)) {
|
Yap_growtrail(Yap_Error_Size);
|
||||||
save_machine_regs();
|
save_machine_regs();
|
||||||
|
}
|
||||||
|
Yap_Error_Size = 0;
|
||||||
|
Yap_ErrorMessage = NULL;
|
||||||
|
if (cb) {
|
||||||
|
/* cannot rely on the code */
|
||||||
if (ap->PredFlags & LogUpdatePredFlag) {
|
if (ap->PredFlags & LogUpdatePredFlag) {
|
||||||
Yap_kill_iblock((ClauseUnion *)ClauseCodeToLogUpdIndex(ap->cs.p_code.TrueCodeOfPred),NULL, ap);
|
Yap_kill_iblock((ClauseUnion *)ClauseCodeToLogUpdIndex(ap->cs.p_code.TrueCodeOfPred),NULL, ap);
|
||||||
} else {
|
} else {
|
||||||
@ -7353,9 +7343,6 @@ Yap_RemoveClauseFromIndex(PredEntry *ap, yamop *beg) {
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Yap_Error_Size = 0;
|
|
||||||
}
|
|
||||||
Yap_ErrorMessage = NULL;
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (Yap_Option['i' - 'a' + 1]) {
|
if (Yap_Option['i' - 'a' + 1]) {
|
||||||
Term tmod = ap->ModuleOfPred;
|
Term tmod = ap->ModuleOfPred;
|
||||||
|
@ -1159,6 +1159,7 @@ InteractSIGINT(int ch) {
|
|||||||
fprintf(Yap_stderr, "Please press one of:\n");
|
fprintf(Yap_stderr, "Please press one of:\n");
|
||||||
fprintf(Yap_stderr, " a for abort\n c for continue\n d for debug\n");
|
fprintf(Yap_stderr, " a for abort\n c for continue\n d for debug\n");
|
||||||
fprintf(Yap_stderr, " e for exit\n s for statistics\n t for trace\n");
|
fprintf(Yap_stderr, " e for exit\n s for statistics\n t for trace\n");
|
||||||
|
fprintf(Yap_stderr, " b for break\n");
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,8 +45,8 @@ typedef struct StructClauseDef {
|
|||||||
yamop *CurrentCode; /* start of code for clause */
|
yamop *CurrentCode; /* start of code for clause */
|
||||||
union {
|
union {
|
||||||
yamop *WorkPC; /* start of code for clause */
|
yamop *WorkPC; /* start of code for clause */
|
||||||
CELL *c_sreg;
|
|
||||||
Term t_ptr;
|
Term t_ptr;
|
||||||
|
CELL *c_sreg;
|
||||||
} u;
|
} u;
|
||||||
} ClauseDef;
|
} ClauseDef;
|
||||||
|
|
||||||
|
@ -799,7 +799,10 @@ incore(G) :- '$execute'(G).
|
|||||||
it saves the importante data about current streams and
|
it saves the importante data about current streams and
|
||||||
debugger state */
|
debugger state */
|
||||||
|
|
||||||
break :- get_value('$break',BL), NBL is BL+1,
|
break :-
|
||||||
|
( recorded('$trace',Val,R) -> Trace = Val, erase(R); true),
|
||||||
|
( recorded('$debug',Val,R1) -> Debug = Val, erase(R1); true),
|
||||||
|
get_value('$break',BL), NBL is BL+1,
|
||||||
get_value(spy_gn,SPY_GN),
|
get_value(spy_gn,SPY_GN),
|
||||||
'$access_yap_flags'(10,SPY_CREEP),
|
'$access_yap_flags'(10,SPY_CREEP),
|
||||||
get_value(spy_cl,SPY_CL),
|
get_value(spy_cl,SPY_CL),
|
||||||
@ -815,6 +818,10 @@ break :- get_value('$break',BL), NBL is BL+1,
|
|||||||
set_value(spy_cl,SPY_CL),
|
set_value(spy_cl,SPY_CL),
|
||||||
set_value(spy_leap,_Leap),
|
set_value(spy_leap,_Leap),
|
||||||
'$set_input'(InpStream), '$set_output'(OutStream),
|
'$set_input'(InpStream), '$set_output'(OutStream),
|
||||||
|
( recorded('$trace',_,R2), erase(R2), fail; true),
|
||||||
|
( recorded('$debug',_,R3), erase(R3), fail; true),
|
||||||
|
(nonvar(Trace) -> recorda('$trace',Trace,_)),
|
||||||
|
(nonvar(Debug) -> recorda('$debug',Debug,_)),
|
||||||
set_value('$break',BL).
|
set_value('$break',BL).
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user