diff options
| author | Russ Cox <rsc@golang.org> | 2010-04-13 22:31:47 -0700 |
|---|---|---|
| committer | Russ Cox <rsc@golang.org> | 2010-04-13 22:31:47 -0700 |
| commit | 5b3825261301b55243a9529d83b68500f87c00c0 (patch) | |
| tree | 132e81d75cc022447dcc0e94209b1d889a90738f /src/pkg/runtime/freebsd/386/signal.c | |
| parent | 403065e079898cb5e87298b50c27e41cfe7a269c (diff) | |
| download | golang-5b3825261301b55243a9529d83b68500f87c00c0.tar.gz | |
runtime: better trace for fault due to nil pointer call
R=r
CC=golang-dev
http://codereview.appspot.com/854048
Diffstat (limited to 'src/pkg/runtime/freebsd/386/signal.c')
| -rw-r--r-- | src/pkg/runtime/freebsd/386/signal.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/src/pkg/runtime/freebsd/386/signal.c b/src/pkg/runtime/freebsd/386/signal.c index ec8ac3a7d..be2f4ce6f 100644 --- a/src/pkg/runtime/freebsd/386/signal.c +++ b/src/pkg/runtime/freebsd/386/signal.c @@ -64,10 +64,18 @@ sighandler(int32 sig, Siginfo* info, void* context) gp->sigcode0 = info->si_code; gp->sigcode1 = (uintptr)info->si_addr; - sp = (uintptr*)r->mc_esp; - *--sp = r->mc_eip; + // Only push sigpanic if r->mc_eip != 0. + // If r->mc_eip == 0, probably panicked because of a + // call to a nil func. Not pushing that onto sp will + // make the trace look like a call to sigpanic instead. + // (Otherwise the trace will end at sigpanic and we + // won't get to see who faulted.) + if(r->mc_eip != 0) { + sp = (uintptr*)r->mc_esp; + *--sp = r->mc_eip; + r->mc_esp = (uintptr)sp; + } r->mc_eip = (uintptr)sigpanic; - r->mc_esp = (uintptr)sp; return; } |
