#!/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