From: Russ Cox Date: Fri, 13 Jun 2014 01:12:53 +0000 (-0400) Subject: runtime: revise CL 105140044 (defer nil) to work on Windows X-Git-Tag: go1.4beta1~1296 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=060a988011b34ded3e002e1a4cb138b7ed21b176;p=gostls13.git runtime: revise CL 105140044 (defer nil) to work on Windows It appears that something about Go on Windows cannot handle the fault cause by a jump to address 0. The way Go represents and calls functions, this never happened at all, until CL 105140044. This CL changes the code added in CL 105140044 to make jump to 0 impossible once again. Fixes #8047. (again, on Windows) TBR=bradfitz R=golang-codereviews, dave CC=adg, golang-codereviews, iant, r https://golang.org/cl/105120044 --- diff --git a/src/pkg/runtime/stack.c b/src/pkg/runtime/stack.c index 1f7c2eaada..1680f004eb 100644 --- a/src/pkg/runtime/stack.c +++ b/src/pkg/runtime/stack.c @@ -9,6 +9,7 @@ #include "funcdata.h" #include "typekind.h" #include "type.h" +#include "../../cmd/ld/textflag.h" enum { @@ -851,6 +852,13 @@ runtime·newstack(void) *(int32*)345 = 123; // never return } +#pragma textflag NOSPLIT +void +runtime·nilfunc(void) +{ + *(byte*)0 = 0; +} + // adjust Gobuf as if it executed a call to fn // and then did an immediate gosave. void @@ -858,9 +866,10 @@ runtime·gostartcallfn(Gobuf *gobuf, FuncVal *fv) { void *fn; - fn = nil; if(fv != nil) fn = fv->fn; + else + fn = runtime·nilfunc; runtime·gostartcall(gobuf, fn, fv); }