1
0
mirror of https://github.com/golang/go synced 2024-07-08 12:18:55 +00:00

runtime: fix bad status throw

when garbage collector sees recovering goroutine

Fixes #711.

R=r
CC=golang-dev
https://golang.org/cl/869045
This commit is contained in:
Russ Cox 2010-04-08 13:24:53 -07:00
parent 2f0cae46d8
commit 72157c300b
3 changed files with 11 additions and 3 deletions

View File

@ -135,6 +135,7 @@ mark(void)
case Grunnable:
case Gsyscall:
case Gwaiting:
case Grecovery:
scanstack(gp);
break;
}

View File

@ -461,9 +461,7 @@ scheduler(void)
// unwind to the stack frame with d->sp in it.
unwindstack(gp, d->sp);
if(d->sp < gp->stackguard || gp->stackbase < d->sp)
throw("bad stack in recovery");
// make the deferproc for this d return again,
// this time returning 1. function will jump to
// standard return epilogue.
@ -930,6 +928,11 @@ unwindstack(G *gp, byte *sp)
gp->stackguard = top->stackguard;
free(stk);
}
if(sp != nil && (sp < gp->stackguard - StackGuard || gp->stackbase < sp)) {
printf("recover: %p not in [%p, %p]\n", sp, gp->stackguard - StackGuard, gp->stackbase);
throw("bad unwindstack");
}
}
static void

View File

@ -92,6 +92,10 @@ extern register M* m;
enum
{
// G status
//
// If you add to this list, add to the list
// of "okay during garbage collection" status
// in mgc0.c too.
Gidle,
Grunnable,
Grunning,