From fb36ed82ec7470efe4e334ddc054bcb4fa06ae9e Mon Sep 17 00:00:00 2001 From: rsc Date: Wed, 21 Apr 2004 22:47:15 +0000 Subject: how much stack do we need? --- src/libthread/sched.c | 20 ++++++++++++++++---- 1 file changed, 16 insertions(+), 4 deletions(-) diff --git a/src/libthread/sched.c b/src/libthread/sched.c index 57d597ba..9ad7298b 100644 --- a/src/libthread/sched.c +++ b/src/libthread/sched.c @@ -156,6 +156,21 @@ relock: return t; } +void +needstack(int howmuch) +{ + Proc *p; + Thread *t; + + p = _threadgetproc(); + if(p == nil || (t=p->thread) == nil) + return; + if((ulong)&howmuch < (ulong)t->stk+howmuch){ /* stack overflow waiting to happen */ + fprint(2, "stack overflow: stack at 0x%lux, limit at 0x%lux, need 0x%lux\n", (ulong)&p, (ulong)t->stk, howmuch); + abort(); + } +} + void _sched(void) { @@ -166,10 +181,7 @@ Resched: p = _threadgetproc(); //fprint(2, "p %p\n", p); if((t = p->thread) != nil){ - if((ulong)&p < (ulong)t->stk+512){ /* stack overflow waiting to happen */ - fprint(2, "stack overflow: stack at %lux, limit at %lux\n", (ulong)&p, (ulong)t->stk); - abort(); - } + needstack(512); // _threaddebug(DBGSCHED, "pausing, state=%s set %p goto %p", // psstate(t->state), &t->sched, &p->sched); if(_setlabel(&t->sched)==0) -- cgit v1.2.3