2023-02-21 15:42:39 +00:00
|
|
|
From fd03e31c7d789413700db84af02894d5be70b5ee Mon Sep 17 00:00:00 2001
|
2020-06-30 17:17:15 +00:00
|
|
|
From: Debarshi Ray <rishi@fedoraproject.org>
|
|
|
|
Date: Mon, 29 Jun 2020 17:57:47 +0200
|
|
|
|
Subject: [PATCH] build: Make the build flags match Fedora's %{gobuild}
|
|
|
|
|
|
|
|
The Go toolchain doesn't play well with passing compiler and linker
|
|
|
|
flags via environment variables. The linker flags require a second
|
|
|
|
level of quoting, which leaves the build system without a quote level
|
|
|
|
to assign the flags to an environment variable like GOFLAGS.
|
|
|
|
|
|
|
|
This is one reason why Fedora doesn't have a RPM macro with only the
|
|
|
|
flags. The %{gobuild} RPM macro includes the entire 'go build ...'
|
|
|
|
invocation.
|
|
|
|
|
|
|
|
The Go toolchain also doesn't like the LDFLAGS environment variable as
|
|
|
|
exported by Fedora's %{meson} RPM macro.
|
|
|
|
|
|
|
|
Note that these flags are meant for every CPU architecture other than
|
|
|
|
PPC64, and should be kept updated to match Fedora's Go guidelines. Use
|
|
|
|
'rpm --eval "%{gobuild}"' to expand the %{gobuild} macro.
|
|
|
|
---
|
2021-12-10 03:46:24 +00:00
|
|
|
src/go-build-wrapper | 14 ++++++++++----
|
|
|
|
1 file changed, 10 insertions(+), 4 deletions(-)
|
2020-06-30 17:17:15 +00:00
|
|
|
|
|
|
|
diff --git a/src/go-build-wrapper b/src/go-build-wrapper
|
2023-02-21 15:42:39 +00:00
|
|
|
index c572d6dfb02b..0e6a2efa6853 100755
|
2020-06-30 17:17:15 +00:00
|
|
|
--- a/src/go-build-wrapper
|
|
|
|
+++ b/src/go-build-wrapper
|
2023-02-21 15:42:39 +00:00
|
|
|
@@ -33,9 +33,9 @@ if ! cd "$1"; then
|
2020-06-30 17:17:15 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2021-12-10 03:46:24 +00:00
|
|
|
-tags=""
|
|
|
|
+tags="-tags rpm_crashtraceback,${BUILDTAGS:-}"
|
2023-02-21 15:42:39 +00:00
|
|
|
if $7; then
|
2021-12-10 03:46:24 +00:00
|
|
|
- tags="-tags migration_path_for_coreos_toolbox"
|
|
|
|
+ tags="$tags,migration_path_for_coreos_toolbox"
|
|
|
|
fi
|
|
|
|
|
2023-02-21 15:42:39 +00:00
|
|
|
if ! libc_dir=$("$5" --print-file-name=libc.so); then
|
|
|
|
@@ -70,11 +70,17 @@ fi
|
2021-12-10 03:46:24 +00:00
|
|
|
|
|
|
|
dynamic_linker="/run/host$dynamic_linker_canonical_dirname/$dynamic_linker_basename"
|
|
|
|
|
2020-06-30 17:17:15 +00:00
|
|
|
+unset LDFLAGS
|
2021-12-10 03:46:24 +00:00
|
|
|
+
|
|
|
|
# shellcheck disable=SC2086
|
|
|
|
go build \
|
|
|
|
+ -buildmode pie \
|
|
|
|
+ -compiler gc \
|
|
|
|
$tags \
|
|
|
|
- -trimpath \
|
2023-02-21 15:42:39 +00:00
|
|
|
- -ldflags "-extldflags '-Wl,-dynamic-linker,$dynamic_linker -Wl,-rpath,/run/host$libc_dir_canonical_dirname' -linkmode external -X github.com/containers/toolbox/pkg/version.currentVersion=$4" \
|
|
|
|
+ -ldflags "${LDFLAGS:-} -B 0x$(head -c20 /dev/urandom|od -An -tx1|tr -d ' \n') -compressdwarf=false -extldflags '-Wl,-z,relro -Wl,--as-needed -Wl,-z,now -specs=/usr/lib/rpm/redhat/redhat-hardened-ld -specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -Wl,--build-id=sha1 -Wl,-dynamic-linker,$dynamic_linker -Wl,-rpath,/run/host$libc_dir_canonical_dirname' -linkmode external -X github.com/containers/toolbox/pkg/version.currentVersion=$4" \
|
2021-12-10 03:46:24 +00:00
|
|
|
+ -a \
|
|
|
|
+ -v \
|
|
|
|
+ -x \
|
2023-02-21 15:42:39 +00:00
|
|
|
-o "$2/$3"
|
2021-10-22 00:17:56 +00:00
|
|
|
|
2021-12-10 03:46:24 +00:00
|
|
|
exit "$?"
|
2020-06-30 17:17:15 +00:00
|
|
|
--
|
2023-02-21 15:42:39 +00:00
|
|
|
2.39.1
|
2020-06-30 17:17:15 +00:00
|
|
|
|