You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
136 lines
3.6 KiB
136 lines
3.6 KiB
6 years ago
|
#!/bin/bash
|
||
|
|
||
|
# Date: April 2, 2014
|
||
|
# by Aldy Hernandez
|
||
|
|
||
|
# Attempt to fix any "-m elf64ppc" linker checks in configure and
|
||
|
# libtool.m4 files.
|
||
|
#
|
||
|
# This script is meant to run silently as part of rpm's %configure
|
||
|
# macro. It either fixes the problem, or we silently ignore it, in
|
||
|
# which case it is up to the package maintainer to add support for
|
||
|
# ppc64le.
|
||
|
|
||
|
# Our two attempts at fixing the problem.
|
||
|
PATCH1=/tmp/$$.patch1
|
||
|
PATCH2=/tmp/$$.patch2
|
||
|
|
||
|
cleanup() {
|
||
|
rm -f $PATCH1 $PATCH2
|
||
|
}
|
||
|
|
||
|
trap cleanup 0 1 2 3 4 5 6 7 8 9 11 13 14 15
|
||
|
|
||
|
# There are two variants in RHEL7 so far. The first version, handled
|
||
|
# with $PATCH1, currently handles all but 3 packages. The $PATCH2
|
||
|
# version handles the remnant.
|
||
|
#
|
||
|
cat > $PATCH1 <<EOF
|
||
|
--- configure.orig 2014-03-18 15:56:15.575070238 -0500
|
||
|
+++ configure 2014-03-18 16:05:50.877861163 -0500
|
||
|
@@ -7714,6 +7714,9 @@
|
||
|
x86_64-*linux*)
|
||
|
LD="\${LD-ld} -m elf_i386"
|
||
|
;;
|
||
|
+ ppc64le-*linux*|powerpc64le-*linux*)
|
||
|
+ LD="\${LD-ld} -m elf32lppclinux"
|
||
|
+ ;;
|
||
|
ppc64-*linux*|powerpc64-*linux*)
|
||
|
LD="\${LD-ld} -m elf32ppclinux"
|
||
|
;;
|
||
|
@@ -7733,6 +7736,9 @@
|
||
|
x86_64-*linux*)
|
||
|
LD="\${LD-ld} -m elf_x86_64"
|
||
|
;;
|
||
|
+ ppc*le-*linux*|powerpc*le-*linux*)
|
||
|
+ LD="\${LD-ld} -m elf64lppc"
|
||
|
+ ;;
|
||
|
ppc*-*linux*|powerpc*-*linux*)
|
||
|
LD="\${LD-ld} -m elf64ppc"
|
||
|
;;
|
||
|
EOF
|
||
|
|
||
|
cat > $PATCH2 <<EOF
|
||
|
--- configure.orig 2014-03-18 16:35:28.942799967 -0500
|
||
|
+++ configure 2014-03-18 16:34:35.608519090 -0500
|
||
|
@@ -3798,6 +3798,9 @@
|
||
|
x86_64-*linux*)
|
||
|
LD="\${LD-ld} -m elf_i386"
|
||
|
;;
|
||
|
+ ppc64le-*linux*)
|
||
|
+ LD="\${LD-ld} -m elf32lppclinux"
|
||
|
+ ;;
|
||
|
ppc64-*linux*)
|
||
|
LD="\${LD-ld} -m elf32ppclinux"
|
||
|
;;
|
||
|
@@ -3814,6 +3817,9 @@
|
||
|
x86_64-*linux*)
|
||
|
LD="\${LD-ld} -m elf_x86_64"
|
||
|
;;
|
||
|
+ ppc*le-*linux*|powerpc*le-*linux*)
|
||
|
+ LD="\${LD-ld} -m elf64lppc"
|
||
|
+ ;;
|
||
|
ppc*-*linux*|powerpc*-*linux*)
|
||
|
LD="\${LD-ld} -m elf64ppc"
|
||
|
;;
|
||
|
EOF
|
||
|
|
||
|
|
||
|
FILES=`find . -name configure -o -name libtool.m4`
|
||
|
for f in $FILES; do
|
||
|
# Filter out candidates that already handle ppc64le.
|
||
|
if grep -s -e '-m elf64lppc' $f >/dev/null; then
|
||
|
continue
|
||
|
fi
|
||
|
|
||
|
# Filter out candidates that don't handle PPC.
|
||
|
if ! grep -s -e '-m elf64ppc' $f >/dev/null; then
|
||
|
continue
|
||
|
fi
|
||
|
|
||
|
echo "Broken -m elf64ppc use in $f should handle elf64lppc."
|
||
|
echo "Attempting automatic fix."
|
||
|
|
||
|
# Attempt to fix the offended file.
|
||
|
basename=`basename $f`
|
||
|
dirname=`dirname $f`
|
||
|
for p in $PATCH1 $PATCH2; do
|
||
|
# This is an all for nothing affair. The patch either
|
||
|
# applies entirely clean, or we don't even try.
|
||
|
#
|
||
|
# Tentatively try either patch cleanly, and if we succeed then
|
||
|
# do it for real.
|
||
|
pushd $dirname 2>&1 > /dev/null
|
||
|
if [ $basename = libtool.m4 ]; then
|
||
|
sed s/configure/libtool.m4/ < $p | patch --dry-run --follow-symlinks -l 2>&1 >/dev/null
|
||
|
else
|
||
|
patch --dry-run --follow-symlinks -l < $p 2>&1 > /dev/null
|
||
|
fi
|
||
|
if [ $? != 0 ]; then
|
||
|
echo -n "$p approach did not work for $dirname/$basename: "
|
||
|
pwd
|
||
|
# This approach didn't work, try the next one.
|
||
|
popd 2>&1 > /dev/null
|
||
|
continue
|
||
|
fi
|
||
|
|
||
|
# Seriously now...
|
||
|
if [ $basename = libtool.m4 ]; then
|
||
|
# Save the timestamp.
|
||
|
cp -p $basename /tmp/tmp.$$
|
||
|
sed s/configure/libtool.m4/ < $p | patch --follow-symlinks -l -s 2>&1 > /dev/null
|
||
|
# Use the old timestamp, to avoid anyone noticing changes
|
||
|
# to libtool.m4.
|
||
|
touch --reference=/tmp/tmp.$$ $basename
|
||
|
rm -f /tmp/tmp.$$
|
||
|
else
|
||
|
patch --follow-symlinks -l -s < $p 2>&1 > /dev/null
|
||
|
fi
|
||
|
echo "Fixed $f for ld -m ppc64le support."
|
||
|
popd 2>&1 > /dev/null
|
||
|
break
|
||
|
done
|
||
|
done
|
||
|
|
||
|
rm -f $PATCH1 $PATCH2
|