From: Michael Hudson-Doyle Date: Thu, 8 Dec 2016 19:49:23 +0000 (+1300) Subject: cmd/link: do not mark go.plugin.tabs as reachable in non-plugins X-Git-Tag: go1.8beta2~63 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=67b292799051f7423cc15154d5fc8bb9c57e7057;p=gostls13.git cmd/link: do not mark go.plugin.tabs as reachable in non-plugins Fixes #18250 Change-Id: I4f61591356ddb4a906c206ad8456d1839daf7b91 Reviewed-on: https://go-review.googlesource.com/34170 Run-TryBot: Michael Hudson-Doyle Reviewed-by: David Crawshaw --- diff --git a/misc/cgo/testshared/src/exe/exe.go b/misc/cgo/testshared/src/exe/exe.go index 31fbedd31c..f01ad8ab78 100644 --- a/misc/cgo/testshared/src/exe/exe.go +++ b/misc/cgo/testshared/src/exe/exe.go @@ -7,6 +7,11 @@ import ( "runtime" ) +// Having a function declared in the main package triggered +// golang.org/issue/18250 +func DeclaredInMain() { +} + func main() { defer depBase.ImplementedInAsm() // This code below causes various go.itab.* symbols to be generated in diff --git a/src/cmd/link/internal/ld/symtab.go b/src/cmd/link/internal/ld/symtab.go index 98ce3ad79b..dd0e5407e8 100644 --- a/src/cmd/link/internal/ld/symtab.go +++ b/src/cmd/link/internal/ld/symtab.go @@ -602,8 +602,7 @@ func (ctxt *Link) symtab() { adduint(ctxt, moduledata, uint64(nitablinks)) adduint(ctxt, moduledata, uint64(nitablinks)) // The ptab slice - if ptab := ctxt.Syms.ROLookup("go.plugin.tabs", 0); ptab != nil { - ptab.Attr |= AttrReachable + if ptab := ctxt.Syms.ROLookup("go.plugin.tabs", 0); ptab != nil && ptab.Attr.Reachable() { ptab.Attr |= AttrLocal ptab.Type = obj.SRODATA