From: Cherry Mui Date: Wed, 26 Apr 2023 21:29:33 +0000 (-0400) Subject: cmd/link: write buildid to plugin X-Git-Tag: go1.21rc1~752 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=6c8ea391cf7f84f6861e26f27eef3bd8938cfb98;p=gostls13.git cmd/link: write buildid to plugin Currently, in plugin build mode we don't write the build ID. This is disabled in CL 29394 since plugin is supported on Darwin. Maybe it caused some problem with the Darwin dynamic linker. But it seems no problem currently. Enabled it. Fixes #59845. Change-Id: I60589ffc7937e4d30055960d391cac1e7cd0cd42 Reviewed-on: https://go-review.googlesource.com/c/go/+/489457 TryBot-Result: Gopher Robot Reviewed-by: Than McIntosh Run-TryBot: Cherry Mui --- diff --git a/misc/cgo/testplugin/plugin_test.go b/misc/cgo/testplugin/plugin_test.go index 285681018a..8960694351 100644 --- a/misc/cgo/testplugin/plugin_test.go +++ b/misc/cgo/testplugin/plugin_test.go @@ -116,11 +116,15 @@ func testMain(m *testing.M) int { return m.Run() } -func goCmd(t *testing.T, op string, args ...string) { +func goCmd(t *testing.T, op string, args ...string) string { if t != nil { t.Helper() } - run(t, filepath.Join(goroot, "bin", "go"), append([]string{op, "-gcflags", gcflags}, args...)...) + var flags []string + if op != "tool" { + flags = []string{"-gcflags", gcflags} + } + return run(t, filepath.Join(goroot, "bin", "go"), append(append([]string{op}, flags...), args...)...) } // escape converts a string to something suitable for a shell command line. @@ -190,6 +194,14 @@ func TestDWARFSections(t *testing.T) { goCmd(t, "run", "./checkdwarf/main.go", "./host.exe", "main.main") } +func TestBuildID(t *testing.T) { + // check that plugin has build ID. + b := goCmd(t, "tool", "buildid", "plugin1.so") + if len(b) == 0 { + t.Errorf("build id not found") + } +} + func TestRunHost(t *testing.T) { run(t, "./host.exe") } diff --git a/src/cmd/link/internal/ld/data.go b/src/cmd/link/internal/ld/data.go index c3550e59a5..7c135ae7e6 100644 --- a/src/cmd/link/internal/ld/data.go +++ b/src/cmd/link/internal/ld/data.go @@ -2248,7 +2248,7 @@ func (state *dodataState) dodataSect(ctxt *Link, symn sym.SymKind, syms []loader // at the very beginning of the text segment. // This “header” is read by cmd/go. func (ctxt *Link) textbuildid() { - if ctxt.IsELF || ctxt.BuildMode == BuildModePlugin || *flagBuildid == "" { + if ctxt.IsELF || *flagBuildid == "" { return }