diff options
| author | Than McIntosh <thanm@google.com> | 2023-09-06 10:15:37 -0400 |
|---|---|---|
| committer | Than McIntosh <thanm@google.com> | 2023-09-07 13:18:51 +0000 |
| commit | 660620dd45dc11f2d889add79bedf2dc771c7d04 (patch) | |
| tree | 56b5d8b4830866fb6ea5125292e14f836ee37121 /src/cmd/cgo/internal/testplugin/testdata | |
| parent | 3466e57354974cd2d17ce902df02e0ac58b8ded5 (diff) | |
| download | go-660620dd45dc11f2d889add79bedf2dc771c7d04.tar.xz | |
cmd/link: avoid deadcode of global map vars for programs using plugins
If a program imports the plugin package, the mechanisms in place for
detecting and deleting unused global map variables are no longer safe,
since it's possibly for a given global map var to be unreferenced in
the main program but referenced by a plugin. This patch changes the
linker to test for plugin use and to avoid removing any unused global
map variables if the main program could possibly load up a plugin.
Fixes #62430.
Change-Id: Ie00b18b681cb0d259e3c859ac947ade5778cd6c8
Reviewed-on: https://go-review.googlesource.com/c/go/+/526115
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
Reviewed-by: Cherry Mui <cherryyz@google.com>
Diffstat (limited to 'src/cmd/cgo/internal/testplugin/testdata')
| -rw-r--r-- | src/cmd/cgo/internal/testplugin/testdata/issue62430/main.go | 35 | ||||
| -rw-r--r-- | src/cmd/cgo/internal/testplugin/testdata/issue62430/plugin.go | 11 |
2 files changed, 46 insertions, 0 deletions
diff --git a/src/cmd/cgo/internal/testplugin/testdata/issue62430/main.go b/src/cmd/cgo/internal/testplugin/testdata/issue62430/main.go new file mode 100644 index 0000000000..80108407c2 --- /dev/null +++ b/src/cmd/cgo/internal/testplugin/testdata/issue62430/main.go @@ -0,0 +1,35 @@ +// Copyright 2023 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// Issue 62430: a program that uses plugins may appear +// to have no references to an initialized global map variable defined +// in some stdlib package (ex: unicode), however there +// may be references to that map var from a plugin that +// gets loaded. + +package main + +import ( + "fmt" + "plugin" + "unicode" +) + +func main() { + p, err := plugin.Open("issue62430.so") + if err != nil { + panic(err) + } + s, err := p.Lookup("F") + if err != nil { + panic(err) + } + + f := s.(func(string) *unicode.RangeTable) + if f("C") == nil { + panic("unicode.Categories not properly initialized") + } else { + fmt.Println("unicode.Categories properly initialized") + } +} diff --git a/src/cmd/cgo/internal/testplugin/testdata/issue62430/plugin.go b/src/cmd/cgo/internal/testplugin/testdata/issue62430/plugin.go new file mode 100644 index 0000000000..e42cd8bb77 --- /dev/null +++ b/src/cmd/cgo/internal/testplugin/testdata/issue62430/plugin.go @@ -0,0 +1,11 @@ +package main + +import ( + "unicode" +) + +func F(s string) *unicode.RangeTable { + return unicode.Categories[s] +} + +func main() {} |
