try to handle overflows in stack dumpers.
This commit is contained in:
parent
64528946d9
commit
3e8dc5cd19
58
C/cdmgr.c
58
C/cdmgr.c
@ -3461,17 +3461,23 @@ static Term
|
|||||||
all_envs(CELL *env_ptr)
|
all_envs(CELL *env_ptr)
|
||||||
{
|
{
|
||||||
Term tf = AbsPair(H);
|
Term tf = AbsPair(H);
|
||||||
|
CELL *start = H;
|
||||||
CELL *bp = NULL;
|
CELL *bp = NULL;
|
||||||
|
|
||||||
/* walk the environment chain */
|
/* walk the environment chain */
|
||||||
while (env_ptr != NULL) {
|
while (env_ptr) {
|
||||||
bp = H;
|
bp = H;
|
||||||
H += 2;
|
H += 2;
|
||||||
/* notice that MkIntegerTerm may increase the Heap */
|
/* notice that MkIntegerTerm may increase the Heap */
|
||||||
bp[0] = MkIntegerTerm(LCL0-env_ptr);
|
bp[0] = MkIntegerTerm(LCL0-env_ptr);
|
||||||
if (H >= ASP) {
|
if (H >= ASP-1024) {
|
||||||
bp[1] = TermNil;
|
H = start;
|
||||||
return tf;
|
Yap_Error_Size = (ASP-1024)-H;
|
||||||
|
while (env_ptr) {
|
||||||
|
Yap_Error_Size += 2;
|
||||||
|
env_ptr = (CELL *)(env_ptr[E_E]);
|
||||||
|
}
|
||||||
|
return 0L;
|
||||||
} else {
|
} else {
|
||||||
bp[1] = AbsPair(H);
|
bp[1] = AbsPair(H);
|
||||||
}
|
}
|
||||||
@ -3485,16 +3491,22 @@ static Term
|
|||||||
all_cps(choiceptr b_ptr)
|
all_cps(choiceptr b_ptr)
|
||||||
{
|
{
|
||||||
CELL *bp = NULL;
|
CELL *bp = NULL;
|
||||||
|
CELL *start = H;
|
||||||
Term tf = AbsPair(H);
|
Term tf = AbsPair(H);
|
||||||
|
|
||||||
while (b_ptr != NULL) {
|
while (b_ptr) {
|
||||||
bp = H;
|
bp = H;
|
||||||
H += 2;
|
H += 2;
|
||||||
/* notice that MkIntegerTerm may increase the Heap */
|
/* notice that MkIntegerTerm may increase the Heap */
|
||||||
bp[0] = MkIntegerTerm((Int)(LCL0-(CELL *)b_ptr));
|
bp[0] = MkIntegerTerm((Int)(LCL0-(CELL *)b_ptr));
|
||||||
if (H >= ASP) {
|
if (H >= ASP-1024) {
|
||||||
bp[1] = TermNil;
|
H = start;
|
||||||
return tf;
|
Yap_Error_Size = (ASP-1024)-H;
|
||||||
|
while (b_ptr) {
|
||||||
|
Yap_Error_Size += 2;
|
||||||
|
b_ptr = b_ptr->cp_b;
|
||||||
|
}
|
||||||
|
return 0L;
|
||||||
} else {
|
} else {
|
||||||
bp[1] = AbsPair(H);
|
bp[1] = AbsPair(H);
|
||||||
}
|
}
|
||||||
@ -3516,6 +3528,9 @@ all_calls(void)
|
|||||||
if (yap_flags[STACK_DUMP_ON_ERROR_FLAG]) {
|
if (yap_flags[STACK_DUMP_ON_ERROR_FLAG]) {
|
||||||
ts[2] = all_envs(ENV);
|
ts[2] = all_envs(ENV);
|
||||||
ts[3] = all_cps(B);
|
ts[3] = all_cps(B);
|
||||||
|
if (ts[2] == 0L ||
|
||||||
|
ts[3] == 0L)
|
||||||
|
return 0L;
|
||||||
} else {
|
} else {
|
||||||
ts[2] = ts[3] = TermNil;
|
ts[2] = ts[3] = TermNil;
|
||||||
}
|
}
|
||||||
@ -3531,13 +3546,27 @@ Yap_all_calls(void)
|
|||||||
static Int
|
static Int
|
||||||
p_all_choicepoints(void)
|
p_all_choicepoints(void)
|
||||||
{
|
{
|
||||||
return Yap_unify(ARG1,all_cps(B));
|
Term t;
|
||||||
|
while ((t = all_cps(B)) == 0L) {
|
||||||
|
if (!Yap_gcl(Yap_Error_Size, 1, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, "while dumping choicepoints");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Yap_unify(ARG1,t);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
p_all_envs(void)
|
p_all_envs(void)
|
||||||
{
|
{
|
||||||
return Yap_unify(ARG1,all_envs(ENV));
|
Term t;
|
||||||
|
while ((t = all_envs(ENV)) == 0L) {
|
||||||
|
if (!Yap_gcl(Yap_Error_Size, 1, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, "while dumping environments");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Yap_unify(ARG1,t);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
@ -3546,7 +3575,14 @@ p_current_stack(void)
|
|||||||
#ifdef YAPOR
|
#ifdef YAPOR
|
||||||
return(FALSE);
|
return(FALSE);
|
||||||
#else
|
#else
|
||||||
return(Yap_unify(ARG1,all_calls()));
|
Term t;
|
||||||
|
while ((t = all_calls()) == 0L) {
|
||||||
|
if (!Yap_gcl(Yap_Error_Size, 1, ENV, gc_P(P,CP))) {
|
||||||
|
Yap_Error(OUT_OF_STACK_ERROR, TermNil, "while dumping stack");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Yap_unify(ARG1,t);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
15
C/errors.c
15
C/errors.c
@ -1819,7 +1819,15 @@ Yap_Error(yap_error_number type, Term where, char *format,...)
|
|||||||
nt[1] = MkAtomTerm(Yap_LookupAtom(tmpbuf));
|
nt[1] = MkAtomTerm(Yap_LookupAtom(tmpbuf));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
nt[1] = MkPairTerm(MkAtomTerm(Yap_LookupAtom(tmpbuf)), Yap_all_calls());
|
{
|
||||||
|
Term stack_dump;
|
||||||
|
|
||||||
|
if ((stack_dump = Yap_all_calls()) == 0L) {
|
||||||
|
stack_dump = TermNil;
|
||||||
|
Yap_Error_Size = 0L;
|
||||||
|
}
|
||||||
|
nt[1] = MkPairTerm(MkAtomTerm(Yap_LookupAtom(tmpbuf)), stack_dump);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (serious) {
|
if (serious) {
|
||||||
/* disable active signals at this point */
|
/* disable active signals at this point */
|
||||||
@ -1838,9 +1846,10 @@ Yap_Error(yap_error_number type, Term where, char *format,...)
|
|||||||
siglongjmp(Yap_RestartEnv,1);
|
siglongjmp(Yap_RestartEnv,1);
|
||||||
}
|
}
|
||||||
UNLOCK(SignalLock);
|
UNLOCK(SignalLock);
|
||||||
if (type == PURE_ABORT)
|
if (type == PURE_ABORT) {
|
||||||
Yap_JumpToEnv(MkAtomTerm(AtomDAbort));
|
Yap_JumpToEnv(MkAtomTerm(AtomDAbort));
|
||||||
else
|
CreepFlag = LCL0-ASP;
|
||||||
|
} else
|
||||||
Yap_JumpToEnv(Yap_MkApplTerm(fun, 2, nt));
|
Yap_JumpToEnv(Yap_MkApplTerm(fun, 2, nt));
|
||||||
P = (yamop *)FAILCODE;
|
P = (yamop *)FAILCODE;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1437,6 +1437,10 @@ InteractSIGINT(int ch) {
|
|||||||
/* exit */
|
/* exit */
|
||||||
Yap_exit(0);
|
Yap_exit(0);
|
||||||
return -1;
|
return -1;
|
||||||
|
case 'g':
|
||||||
|
/* exit */
|
||||||
|
Yap_signal (YAP_STACK_DUMP_SIGNAL);
|
||||||
|
return -1;
|
||||||
case 't':
|
case 't':
|
||||||
/* start tracing */
|
/* start tracing */
|
||||||
Yap_signal (YAP_TRACE_SIGNAL);
|
Yap_signal (YAP_TRACE_SIGNAL);
|
||||||
@ -1459,7 +1463,7 @@ InteractSIGINT(int ch) {
|
|||||||
/* show an helpful message */
|
/* show an helpful message */
|
||||||
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 g for stack dump\n s for statistics\n t for trace\n");
|
||||||
fprintf(Yap_stderr, " b for break\n");
|
fprintf(Yap_stderr, " b for break\n");
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user