Take care to process heap overflows correctly.

git-svn-id: https://yap.svn.sf.net/svnroot/yap/trunk@992 b08c6af1-5177-4d33-ba66-4b1c6b8b522a
This commit is contained in:
vsc 2004-02-17 16:27:22 +00:00
parent 7d7b79630f
commit 860ea6d115
3 changed files with 77 additions and 15 deletions

View File

@ -1122,6 +1122,7 @@ Yap_absmi(int inp)
/* restart index */ /* restart index */
setregs(); setregs();
PREG = ipc; PREG = ipc;
if (PREG == NULL) FAIL();
CACHED_A1() = ARG1; CACHED_A1() = ARG1;
#if defined(YAPOR) || defined(THREADS) #if defined(YAPOR) || defined(THREADS)
PP = ap; PP = ap;

View File

@ -4843,8 +4843,11 @@ replace_lu_block(LogUpdIndex *blk, int flag, PredEntry *ap, yamop *code, int has
if (count_reds) sz += xcls*((UInt)NEXTOP((yamop *)NULL,p)); if (count_reds) sz += xcls*((UInt)NEXTOP((yamop *)NULL,p));
if (profiled) sz += xcls*((UInt)NEXTOP((yamop *)NULL,p)); if (profiled) sz += xcls*((UInt)NEXTOP((yamop *)NULL,p));
ncl = (LogUpdIndex *)Yap_AllocCodeSpace(sz); ncl = (LogUpdIndex *)Yap_AllocCodeSpace(sz);
if (ncl == NULL) if (ncl == NULL) {
Yap_Error_Size = sz;
Yap_ErrorMessage = "while at indexing code";
return NULL; return NULL;
}
ncl->ClFlags = LogUpdMask|IndexedPredFlag|IndexMask; ncl->ClFlags = LogUpdMask|IndexedPredFlag|IndexMask;
ncl->ClRefCount = 0; ncl->ClRefCount = 0;
ncl->u.ParentIndex = blk->u.ParentIndex; ncl->u.ParentIndex = blk->u.ParentIndex;
@ -5063,15 +5066,18 @@ inserta_in_lu_block(LogUpdIndex *blk, PredEntry *ap, yamop *code)
} }
static path_stack_entry * static path_stack_entry *
expanda_block(path_stack_entry *sp, PredEntry *ap, ClauseDef *cls, int group1, yamop *alt) expanda_block(path_stack_entry *sp, PredEntry *ap, ClauseDef *cls, int group1, yamop *alt, struct intermediates *cint)
{ {
while ((--sp)->flag != block_entry); while ((--sp)->flag != block_entry);
if (sp->u.cle.entry_code == NULL) { if (sp->u.cle.entry_code == NULL) {
Yap_kill_iblock(sp->u.cle.block, NULL, ap); Yap_kill_iblock(sp->u.cle.block, NULL, ap);
} else if (ap->PredFlags & LogUpdatePredFlag && } else if (ap->PredFlags & LogUpdatePredFlag &&
group1 && alt == NULL) { group1 && alt == NULL) {
*sp->u.cle.entry_code = yamop *new_code =
inserta_in_lu_block((LogUpdIndex *)sp->u.cle.block, ap, cls->Code); inserta_in_lu_block((LogUpdIndex *)sp->u.cle.block, ap, cls->Code);
if (new_code == NULL)
longjmp(cint->CompilerBotch,2);
*sp->u.cle.entry_code = new_code;
} else { } else {
path_stack_entry *nsp = sp; path_stack_entry *nsp = sp;
@ -5083,15 +5089,19 @@ expanda_block(path_stack_entry *sp, PredEntry *ap, ClauseDef *cls, int group1, y
} }
static path_stack_entry * static path_stack_entry *
expandz_block(path_stack_entry *sp, PredEntry *ap, ClauseDef *cls, int group1, yamop *alt) expandz_block(path_stack_entry *sp, PredEntry *ap, ClauseDef *cls, int group1, yamop *alt, struct intermediates *cint)
{ {
while ((--sp)->flag != block_entry); while ((--sp)->flag != block_entry);
if (sp->u.cle.entry_code == NULL) { if (sp->u.cle.entry_code == NULL) {
Yap_kill_iblock(sp->u.cle.block, NULL, ap); Yap_kill_iblock(sp->u.cle.block, NULL, ap);
} else if (ap->PredFlags & LogUpdatePredFlag && } else if (ap->PredFlags & LogUpdatePredFlag &&
group1 && alt == NULL) { group1 && alt == NULL) {
*sp->u.cle.entry_code = yamop *new_code =
insertz_in_lu_block((LogUpdIndex *)sp->u.cle.block, ap, cls->Code); insertz_in_lu_block((LogUpdIndex *)sp->u.cle.block, ap, cls->Code);
if (new_code == NULL)
longjmp(cint->CompilerBotch,2);
*sp->u.cle.entry_code =
new_code;
} else { } else {
path_stack_entry *nsp = sp; path_stack_entry *nsp = sp;
@ -5142,7 +5152,7 @@ add_to_index(struct intermediates *cint, int first, path_stack_entry *sp, Clause
have to expand the index. have to expand the index.
*/ */
if (first) { if (first) {
sp = expanda_block(sp, ap, cls, group1, alt); sp = expanda_block(sp, ap, cls, group1, alt, cint);
ipc = pop_path(&sp, cls, ap); ipc = pop_path(&sp, cls, ap);
} else { } else {
/* just go to next instruction */ /* just go to next instruction */
@ -5152,9 +5162,9 @@ add_to_index(struct intermediates *cint, int first, path_stack_entry *sp, Clause
case _stale_lu_index: case _stale_lu_index:
case _enter_lu_pred: case _enter_lu_pred:
if (first) { if (first) {
sp = expanda_block(sp, ap, cls, group1, alt); sp = expanda_block(sp, ap, cls, group1, alt, cint);
} else { } else {
sp = expandz_block(sp, ap, cls, group1, alt); sp = expandz_block(sp, ap, cls, group1, alt, cint);
} }
ipc = pop_path(&sp, cls, ap); ipc = pop_path(&sp, cls, ap);
break; break;
@ -5205,7 +5215,7 @@ add_to_index(struct intermediates *cint, int first, path_stack_entry *sp, Clause
break; break;
case _trust: case _trust:
case _trust_killed: case _trust_killed:
sp = expandz_block(sp, ap, cls, group1, alt); sp = expandz_block(sp, ap, cls, group1, alt, cint);
ipc = pop_path(&sp, cls, ap); ipc = pop_path(&sp, cls, ap);
break; break;
case _jump: case _jump:
@ -6372,7 +6382,27 @@ Yap_FollowIndexingCode(PredEntry *ap, yamop *ipc, Term t1, Term tb, Term tr, yam
ipc = NEXTOP(ipc,l); ipc = NEXTOP(ipc,l);
break; break;
case _stale_lu_index: case _stale_lu_index:
ipc = clean_up_index(ipc->u.Ill.I, jlbl, ap); while (TRUE) {
yamop *nipc = clean_up_index(ipc->u.Ill.I, jlbl, ap);
if (nipc == NULL) {
/* not enough space */
H[0] = t1;
H[1] = tb;
H[2] = tr;
H += 3;
if (!Yap_growheap(FALSE, Yap_Error_Size, NULL)) {
Yap_Error(OUT_OF_HEAP_ERROR, TermNil, Yap_ErrorMessage);
return NULL;
}
H -= 3;
t1 = H[0];
tb = H[1];
tr = H[2];
} else {
ipc = nipc;
break;
}
}
break; break;
case _enter_lu_pred: case _enter_lu_pred:
{ {
@ -6706,7 +6736,19 @@ Yap_NthClause(PredEntry *ap, Int ncls)
case _trust_logical_pred: case _trust_logical_pred:
ipc = NEXTOP(ipc,l); ipc = NEXTOP(ipc,l);
case _stale_lu_index: case _stale_lu_index:
ipc = clean_up_index(ipc->u.Ill.I, jlbl, ap); while (TRUE) {
yamop *nipc = clean_up_index(ipc->u.Ill.I, jlbl, ap);
if (nipc == NULL) {
/* not enough space */
if (!Yap_growheap(FALSE, Yap_Error_Size, NULL)) {
Yap_Error(OUT_OF_HEAP_ERROR, TermNil, Yap_ErrorMessage);
return NULL;
}
} else {
ipc = nipc;
break;
}
}
break; break;
case _enter_lu_pred: case _enter_lu_pred:
ipc = ipc->u.Ill.l1; ipc = ipc->u.Ill.l1;
@ -7014,12 +7056,15 @@ find_caller(PredEntry *ap, yamop *code) {
return NULL; return NULL;
} }
static int vsc_clup;
yamop * yamop *
Yap_CleanUpIndex(LogUpdIndex *blk) Yap_CleanUpIndex(LogUpdIndex *blk)
{ {
PredEntry *ap; PredEntry *ap;
LogUpdIndex *pblk = blk->u.ParentIndex, *tblk; LogUpdIndex *pblk = blk->u.ParentIndex, *tblk;
vsc_clup++;
/* first, go up until findin'your pred */ /* first, go up until findin'your pred */
tblk = pblk; tblk = pblk;
while (!(tblk->ClFlags & SwitchRootMask)) while (!(tblk->ClFlags & SwitchRootMask))
@ -7030,9 +7075,17 @@ Yap_CleanUpIndex(LogUpdIndex *blk)
/* I have to kill this block */ /* I have to kill this block */
yamop **caller, *new; yamop **caller, *new;
caller = find_caller(ap, blk->ClCode); caller = find_caller(ap, blk->ClCode);
if (caller == NULL) return NULL; while (TRUE) {
*caller = new = replace_lu_block(blk, REFRESH, ap, NULL, FALSE); *caller = new = replace_lu_block(blk, REFRESH, ap, NULL, FALSE);
if (new == NULL) {
if (!Yap_growheap(FALSE, Yap_Error_Size, NULL)) {
Yap_Error(OUT_OF_HEAP_ERROR, TermNil, Yap_ErrorMessage);
return FAILCODE;
}
} else {
return new; return new;
}
}
} else { } else {
/* just compact the code */ /* just compact the code */
yamop *start = blk->ClCode, *codep = start->u.Ill.l1; yamop *start = blk->ClCode, *codep = start->u.Ill.l1;

View File

@ -2687,6 +2687,14 @@ The predicate holds when the first argument is a list of atoms, and the
second unifies with the atom obtained by concatenating all the atoms in second unifies with the atom obtained by concatenating all the atoms in
the first list. the first list.
@item atom_concat(+@var{A1},+@var{A2},?@var{A})
@findex atom_concat/3
@syindex atom_concat/3
@cnindex atom_concat/3
The predicate holds when the first argument and second argument are
atoms, and the third unifies with the atom obtained by concatenating
the first two arguments.
@item atom_length(+@var{A},?@var{I}) [ISO] @item atom_length(+@var{A},?@var{I}) [ISO]
@findex atom_length/2 @findex atom_length/2
@snindex atom_length/2 @snindex atom_length/2