diff options
Diffstat (limited to 'testsuite/tls6.sh')
-rwxr-xr-x | testsuite/tls6.sh | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/testsuite/tls6.sh b/testsuite/tls6.sh new file mode 100755 index 0000000..54d4666 --- /dev/null +++ b/testsuite/tls6.sh @@ -0,0 +1,38 @@ +#!/bin/bash +. `dirname $0`/functions.sh +# First check if __thread is supported by ld.so/gcc/ld/as: +rm -f tlstest +echo '__thread int a; int main (void) { return a; }' \ + | $RUN_HOST $CCLINK -xc - -o tlstest > /dev/null 2>&1 || exit 77 +if [ "x$CROSS" = "x" ]; then + ( $RUN LD_LIBRARY_PATH=. ./tlstest || { rm -f tlstest; exit 77; } ) 2>/dev/null || exit 77 +fi +rm -f tls6 tls6lib*.so tls6.log +rm -f prelink.cache +echo 'int tls6;' | $RUN_HOST $CC -shared -O2 -fpic -xc - -o tls6lib3.so +$RUN_HOST $CC -shared -O2 -fpic -o tls6lib1.so $srcdir/tls6lib1.c tls6lib3.so +$RUN_HOST $CC -shared -O2 -fpic -o tls6lib2.so $srcdir/tls1lib2.c \ + -Wl,--rpath-link,. tls6lib1.so +BINS="tls6" +LIBS="tls6lib1.so tls6lib2.so tls6lib3.so" +$RUN_HOST $CCLINK -o tls6 $srcdir/tls2.c -Wl,--rpath-link,. tls6lib2.so -lc tls6lib1.so +savelibs +echo $PRELINK ${PRELINK_OPTS--vm} ./tls6 > tls6.log +$RUN_HOST $PRELINK ${PRELINK_OPTS--vm} ./tls6 >> tls6.log 2>&1 || exit 1 +grep -v 'has undefined non-weak symbols' tls6.log \ + | grep -q ^`echo $PRELINK | sed 's/ .*$/: /'` && exit 2 +if [ "x$CROSS" = "x" ]; then + $RUN LD_LIBRARY_PATH=. ./tls6 || exit 3 +fi +$RUN_HOST $PRELINK -u tls6lib3.so || exit 4 +echo $PRELINK ${PRELINK_OPTS--vm} ./tls6 >> tls6.log +$RUN_HOST $PRELINK ${PRELINK_OPTS--vm} ./tls6 >> tls6.log 2>&1 || exit 5 +grep -v 'has undefined non-weak symbols' tls6.log \ + | grep -q ^`echo $PRELINK | sed 's/ .*$/: /'` && exit 6 +if [ "x$CROSS" = "x" ]; then + $RUN LD_LIBRARY_PATH=. ./tls6 || exit 7 +fi +$RUN_HOST $READELF -a ./tls6 >> tls6.log 2>&1 || exit 8 +# So that it is not prelinked again +chmod -x ./tls6 +comparelibs >> tls6.log 2>&1 || exit 9 |