]> git.ipfire.org Git - thirdparty/openembedded/openembedded-core-contrib.git/commitdiff
go: Filter build paths on staticly linked arches
authorRichard Purdie <richard.purdie@linuxfoundation.org>
Sat, 2 Jul 2022 22:08:13 +0000 (23:08 +0100)
committerRichard Purdie <richard.purdie@linuxfoundation.org>
Mon, 4 Jul 2022 14:13:18 +0000 (15:13 +0100)
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
meta/recipes-devtools/go/go-1.18.3.inc
meta/recipes-devtools/go/go/filter-build-paths.patch [new file with mode: 0644]

index 68062952caeb7107d54461476a981cd1b5f7ac19..693b045e8f0fa99308e7cf8604d2d51611f0a4a4 100644 (file)
@@ -13,5 +13,6 @@ SRC_URI += "\
     file://0007-cmd-go-make-GOROOT-precious-by-default.patch \
     file://0001-exec.go-do-not-write-linker-flags-into-buildids.patch \
     file://0001-src-cmd-dist-buildgo.go-do-not-hardcode-host-compile.patch \
+    file://filter-build-paths.patch \
 "
 SRC_URI[main.sha256sum] = "0012386ddcbb5f3350e407c679923811dbd283fcdc421724931614a842ecbc2d"
diff --git a/meta/recipes-devtools/go/go/filter-build-paths.patch b/meta/recipes-devtools/go/go/filter-build-paths.patch
new file mode 100644 (file)
index 0000000..caf7277
--- /dev/null
@@ -0,0 +1,48 @@
+Filter out build time paths from ldflags and other flags variables when they're
+embedded in the go binary so that builds are reproducible regardless of build
+location. This codepath is hit for statically linked go binaries such as those
+on mips/ppc.
+
+Upstream-Status: Pending
+Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
+
+Index: go/src/cmd/go/internal/load/pkg.go
+===================================================================
+--- go.orig/src/cmd/go/internal/load/pkg.go
++++ go/src/cmd/go/internal/load/pkg.go
+@@ -2225,6 +2225,17 @@ func (p *Package) collectDeps() {
+ // to their VCS information (vcsStatusError).
+ var vcsStatusCache par.Cache
++func filterCompilerFlags(flags string) string {
++      var newflags []string
++      for _, flag := range strings.Fields(flags) {
++              if strings.HasPrefix(flag, "--sysroot") || strings.HasPrefix(flag, "-fmacro-prefix-map") || strings.HasPrefix(flag, "-fdebug-prefix-map") {
++                      continue
++              }
++              newflags = append(newflags, flag)
++      }
++      return strings.Join(newflags, " ")
++}
++
+ // setBuildInfo gathers build information, formats it as a string to be
+ // embedded in the binary, then sets p.Internal.BuildInfo to that string.
+ // setBuildInfo should only be called on a main package with no errors.
+@@ -2329,7 +2340,7 @@ func (p *Package) setBuildInfo(includeVC
+                       appendSetting("-gcflags", BuildGcflags.String())
+               }
+               if BuildLdflags.present {
+-                      appendSetting("-ldflags", BuildLdflags.String())
++                      appendSetting("-ldflags", filterCompilerFlags(BuildLdflags.String()))
+               }
+               if cfg.BuildMSan {
+                       appendSetting("-msan", "true")
+@@ -2347,7 +2358,7 @@ func (p *Package) setBuildInfo(includeVC
+               appendSetting("CGO_ENABLED", cgo)
+               if cfg.BuildContext.CgoEnabled {
+                       for _, name := range []string{"CGO_CFLAGS", "CGO_CPPFLAGS", "CGO_CXXFLAGS", "CGO_LDFLAGS"} {
+-                              appendSetting(name, cfg.Getenv(name))
++                              appendSetting(name, filterCompilerFlags(cfg.Getenv(name)))
+                       }
+               }
+               appendSetting("GOARCH", cfg.BuildContext.GOARCH)