public inbox for ipfire-scm@lists.ipfire.org
 help / color / mirror / Atom feed
* [git.ipfire.org] IPFire 3.x development tree branch, master, updated. c2ee3456c5f23447d56074ae449f9d59a5a9bc53
@ 2023-03-25 11:42 Stefan Schantl
  0 siblings, 0 replies; only message in thread
From: Stefan Schantl @ 2023-03-25 11:42 UTC (permalink / raw)
  To: ipfire-scm

[-- Attachment #1: Type: text/plain, Size: 3383 bytes --]

This is an automated email from the git hooks/post-receive script. It was
generated because a ref change was pushed to the repository containing
the project "IPFire 3.x development tree".

The branch, master has been updated
       via  c2ee3456c5f23447d56074ae449f9d59a5a9bc53 (commit)
      from  48c0a8414ddae2a6e443a0fdd253f7944cb6a8a7 (commit)

Those revisions listed above that are new to this repository have
not appeared on any other notification email; so we list those
revisions in full, below.

- Log -----------------------------------------------------------------
commit c2ee3456c5f23447d56074ae449f9d59a5a9bc53
Author: Michael Tremer <michael.tremer(a)ipfire.org>
Date:   Fri Mar 24 17:15:02 2023 +0000

    glibc: Fix runtime linker path chaos
    
    Some architectures have a specific path for their runtime linker
    hardcoded and in order to avoid installing them into /lib or /lib64
    instead of /usr/lib or /usr/lib64, we are adding artificial provides.
    
    Signed-off-by: Michael Tremer <michael.tremer(a)ipfire.org>

-----------------------------------------------------------------------

Summary of changes:
 glibc/glibc.nm | 33 +++++++++++++++++----------------
 1 file changed, 17 insertions(+), 16 deletions(-)

Difference in files:
diff --git a/glibc/glibc.nm b/glibc/glibc.nm
index 3b1362d4d..b86d06a83 100644
--- a/glibc/glibc.nm
+++ b/glibc/glibc.nm
@@ -5,7 +5,7 @@
 
 name       = glibc
 version    = 2.37
-release    = 5
+release    = 6
 
 maintainer = Michael Tremer <michael.tremer(a)ipfire.org>
 groups     = System/Base
@@ -52,6 +52,9 @@ build
 	# Disable LTO
 	LTO_CFLAGS =
 
+	# Path to put the runtime linker
+	rtlddir = %{libdir}
+
 	configure_options = \
 		--build=%{DISTRO_BUILDTARGET} \
 		--prefix=/usr \
@@ -73,28 +76,26 @@ build
 	if "%{DISTRO_ARCH}" == "aarch64"
 		configure_options += \
 			--enable-memory-tagging
+
+		# The runtime linker on aarch64 for whatever braindead reason is in /usr/lib
+		rtlddir = %{prefix}/lib
+
+		# Runtime Linker
+		rtld = /lib/ld-linux-aarch64.so.1
 	end
 
 	if "%{DISTRO_ARCH}" == "x86_64"
 		configure_options += \
 			--enable-cet
+
+		# Runtime Linker
+		rtld = /lib64/ld-linux-x86-64.so.2
 	end
 
 	install
 		# Install everything
 		make install install_root=%{BUILDROOT} \
-			rtlddir=%{libdir} rootsbindir=%{sbindir} slibdir=%{libdir}
-
-		if [ "%{DISTRO_ARCH}" = "aarch64" ]; then
-			# On aarch64, we did link various binaries against
-			# an incorrect linker in /lib. In order to migrate
-			# away from this, we are creating a symlink which
-			# can hopefully go after we drop the bootstrap repositories.
-			mkdir -pv %{BUILDROOT}%{prefix}/lib
-			ln -svf --relative \
-				%{BUILDROOT}%{libdir}/ld-linux-aarch64.so.1 \
-				%{BUILDROOT}%{prefix}/lib/ld-linux-aarch64.so.1
-		fi
+			rtlddir=%{rtlddir} rootsbindir=%{sbindir} slibdir=%{libdir}
 
 		# Locales
 		mkdir -pv %{BUILDROOT}/usr/lib/locale
@@ -141,9 +142,9 @@ end
 
 packages
 	package glibc
-		if "%{DISTRO_ARCH}" == "aarch64"
-			provides += /lib/ld-linux-aarch64.so.1
-		end
+		# Export the path to the runtime linker which is actually
+		# installed into /usr, but is being searched for elsewhere
+		provides += %{rtld}
 
 		requires
 			tzdata


hooks/post-receive
--
IPFire 3.x development tree

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2023-03-25 11:42 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-03-25 11:42 [git.ipfire.org] IPFire 3.x development tree branch, master, updated. c2ee3456c5f23447d56074ae449f9d59a5a9bc53 Stefan Schantl

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox