Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 13 Nov 2023 23:39:35 GMT
From:      Konstantin Belousov <kib@FreeBSD.org>
To:        src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org
Subject:   git: 99132daf6f70 - main - rc.d/ldconfig: Prepend rtld stdlib paths to ldconfig(32)_paths
Message-ID:  <202311132339.3ADNdZKF081019@gitrepo.freebsd.org>

next in thread | raw e-mail | index | archive | help
The branch main has been updated by kib:

URL: https://cgit.FreeBSD.org/src/commit/?id=99132daf6f70cb0cc969c555d3612547fa3cf1db

commit 99132daf6f70cb0cc969c555d3612547fa3cf1db
Author:     John W. O'Brien <john@saltant.com>
AuthorDate: 2023-11-12 22:45:27 +0000
Commit:     Konstantin Belousov <kib@FreeBSD.org>
CommitDate: 2023-11-13 23:39:17 +0000

    rc.d/ldconfig: Prepend rtld stdlib paths to ldconfig(32)_paths
    
    Ensure that ldconfig-managed elf and elf32 hints always include
    the standard library paths that are known independently to rtld.
    
    PR:                     275031
    Reviewed by:            kib
    MFC after:              2 weeks
    Sponsored by:           Saltant Solutions LLC
    Differential Revision:  https://reviews.freebsd.org/D42557
---
 libexec/rc/rc.d/ldconfig | 5 ++++-
 1 file changed, 4 insertions(+), 1 deletion(-)

diff --git a/libexec/rc/rc.d/ldconfig b/libexec/rc/rc.d/ldconfig
index 178a8a987be4..ecbbca210ea0 100755
--- a/libexec/rc/rc.d/ldconfig
+++ b/libexec/rc/rc.d/ldconfig
@@ -22,7 +22,7 @@ ldconfig_start()
 	ldconfig=${ldconfig_command}
 	checkyesno ldconfig_insecure && _ins="-i"
 	if [ -x "${ldconfig_command}" ]; then
-		_LDC="/lib /usr/lib"
+		_LDC=$(/libexec/ld-elf.so.1 -v | sed -n -e '/^Default lib path /s///p' | tr : ' ')
 		for i in ${ldconfig_local_dirs}; do
 			if [ -d "${i}" ]; then
 				_files=`find ${i} -type f`
@@ -52,6 +52,9 @@ ldconfig_start()
 				fi
 			done
 			_LDC=""
+			if [ -x /libexec/ld-elf32.so.1 ]; then
+				_LDC=$(/libexec/ld-elf32.so.1 -v | sed -n -e '/^Default lib path /s///p' | tr : ' ')
+			fi
 			for i in ${ldconfig32_paths}; do
 				if [ -r "${i}" ]; then
 					_LDC="${_LDC} ${i}"



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202311132339.3ADNdZKF081019>