diff options
Diffstat (limited to 'trunk/testsuite/reloc6.sh')
-rwxr-xr-x | trunk/testsuite/reloc6.sh | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/trunk/testsuite/reloc6.sh b/trunk/testsuite/reloc6.sh new file mode 100755 index 0000000..7f72936 --- /dev/null +++ b/trunk/testsuite/reloc6.sh @@ -0,0 +1,36 @@ +#!/bin/bash +. `dirname $0`/functions.sh +rm -f reloc6 reloc6lib*.so reloc6.log +rm -f prelink.cache +$CC -shared -O2 -fpic -o reloc6lib1.so $srcdir/reloc3lib1.c +$CC -shared -O2 -fpic -o reloc6lib2.so $srcdir/reloc1lib2.c reloc6lib1.so +$CCLINK -o reloc6 $srcdir/reloc3.c -Wl,--rpath-link,. reloc6lib2.so +$CCLINK -o reloc6.nop $srcdir/reloc3.c -Wl,--rpath-link,. reloc6lib2.so +echo $PRELINK ${PRELINK_OPTS--vm} ./reloc6 > reloc6.log +$PRELINK ${PRELINK_OPTS--vm} ./reloc6 >> reloc6.log 2>&1 || exit 1 +grep -q ^`echo $PRELINK | sed 's/ .*$/: /'` reloc6.log && exit 2 +if [ "x$CROSS" = "x" ]; then + LD_LIBRARY_PATH=. ./reloc6 >> reloc6.log || exit 3 +fi +readelf -a ./reloc6 >> reloc6.log 2>&1 || exit 4 +if [ "x$CROSS" = "x" ]; then + LD_LIBRARY_PATH=. ./reloc6.nop >> reloc6.log || exit 5 +fi +if [ "x$CROSS" = "x" ]; then + LD_LIBRARY_PATH=. LD_BIND_NOW=1 ./reloc6.nop >> reloc6.log || exit 6 +fi +mv -f reloc6lib2.so reloc6lib2.so.p +$CC -shared -O2 -fpic -o reloc6lib2.so $srcdir/reloc1lib2.c reloc6lib1.so +if [ "x$CROSS" = "x" ]; then + LD_LIBRARY_PATH=. ./reloc6 >> reloc6.log || exit 7 +fi +if [ "x$CROSS" = "x" ]; then + LD_LIBRARY_PATH=. ./reloc6.nop >> reloc6.log || exit 8 +fi +if [ "x$CROSS" = "x" ]; then + LD_LIBRARY_PATH=. LD_BIND_NOW=1 ./reloc6.nop >> reloc6.log || exit 9 +fi +mv -f reloc6lib2.so reloc6lib2.so.nop +mv -f reloc6lib2.so.p reloc6lib2.so +# So that it is not prelinked again +chmod -x ./reloc6 ./reloc6.nop |