Merge branch '411-build-system-review-code-to-set-rpath' into 'master'

Resolve "build-system: review code to set RPATH"

Closes #411

See merge request Pmodules/src!443
This commit is contained in:
2025-04-09 16:27:00 +02:00
2 changed files with 14 additions and 15 deletions
+8 -15
View File
@@ -1040,24 +1040,15 @@ _build_module() {
return 0
}
patch_elf_exe_and_libs(){
patch_elf64_files(){
local -- libdir="${OverlayInfo[${ol_name}:install_root]}/lib64"
[[ -d "${libdir}" ]] || return 0
local -a bin_objects=()
mapfile -t bin_objects < <(std::find_executables '.')
mapfile -t files < <(std::find_elf64_binaries '.')
local -- fname=''
local -- rpath=''
local -i depth=0
for fname in "${bin_objects[@]}"; do
# don't override existing RPATH
rpath=$(patchelf --print-rpath "${fname}")
[[ -z "${rpath}" ]] || continue
(( depth=$(std::get_dir_depth "${fname}") + group_depth + 3 ))
rpath='$ORIGIN/'$(printf "../%.0s" $(${seq} 1 ${depth}))lib64
${patchelf} --force-rpath --set-rpath "${rpath}" "${fname}"
done
mapfile -t bin_objects < <(std::find_shared_objects '.')
for fname in "${bin_objects[@]}"; do
for fname in "${files[@]}"; do
# don't override existing RPATH
rpath=$(patchelf --print-rpath "${fname}")
[[ -z "${rpath}" ]] || continue
@@ -1075,9 +1066,11 @@ _build_module() {
"%s " \
"${module_name}/${module_version}:" \
"running post-installation for ${KernelName} ..."
cd "${PREFIX}"
[[ -d "lib" ]] && [[ ! -d "lib64" ]] && ln -s lib lib64
patch_elf_exe_and_libs
{
cd "${PREFIX}"
[[ -d "lib" ]] && [[ ! -d "lib64" ]] && ln -s lib lib64
patch_elf64_files
};
return 0
}
+6
View File
@@ -423,6 +423,12 @@ std::is_member_of_array(){
return 1
}
std::find_elf64_binaries(){
${find} "$@" -type f -not -name '*.pyc' -not -name '*.sh' -executable | \
file -f - | \
awk '/ELF 64-bit/ {print substr($1, 1, length($1)-1)}'
}
std::find_executables(){
${find} "$@" -type f -printf "%i %P\n" | \
${sort} -n -k1 -u | \