From: Cherry Zhang Date: Sun, 9 Feb 2020 22:01:53 +0000 (-0500) Subject: cmd/dist: test cgo internal linking PIE X-Git-Tag: go1.15beta1~1139 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=3e4e644433cca68118eaa3878b88dddfa5352af5;p=gostls13.git cmd/dist: test cgo internal linking PIE On platforms where internal linking PIE is supported, run misc/cgo/test with that configuration. Change-Id: Ia09631b07cc469c85818e1494093d802ea9d69a1 Reviewed-on: https://go-review.googlesource.com/c/go/+/218838 Run-TryBot: Cherry Zhang TryBot-Result: Gobot Gobot Reviewed-by: Ian Lance Taylor --- diff --git a/src/cmd/dist/test.go b/src/cmd/dist/test.go index 56bdfcac19..1869fb5b2d 100644 --- a/src/cmd/dist/test.go +++ b/src/cmd/dist/test.go @@ -581,7 +581,7 @@ func (t *tester) registerTests() { } // Test internal linking of PIE binaries where it is supported. - if goos == "linux" && (goarch == "amd64" || goarch == "arm64") { + if t.internalLinkPIE() { t.tests = append(t.tests, distTest{ name: "pie_internal", heading: "internal linking of -buildmode=pie", @@ -936,6 +936,10 @@ func (t *tester) internalLink() bool { return true } +func (t *tester) internalLinkPIE() bool { + return goos == "linux" && (goarch == "amd64" || goarch == "arm64") +} + func (t *tester) supportedBuildmode(mode string) bool { pair := goos + "-" + goarch switch mode { @@ -1110,6 +1114,9 @@ func (t *tester) cgoTest(dt *distTest) error { if t.supportedBuildmode("pie") { t.addCmd(dt, "misc/cgo/test", t.goTest(), "-buildmode=pie") + if t.internalLinkPIE() { + t.addCmd(dt, "misc/cgo/test", t.goTest(), "-buildmode=pie", "-ldflags=-linkmode=internal") + } t.addCmd(dt, "misc/cgo/testtls", t.goTest(), "-buildmode=pie") t.addCmd(dt, "misc/cgo/nocgo", t.goTest(), "-buildmode=pie") }