aboutsummaryrefslogtreecommitdiffstats
path: root/testsuite/tls4.sh
diff options
context:
space:
mode:
Diffstat (limited to 'testsuite/tls4.sh')
-rwxr-xr-xtestsuite/tls4.sh28
1 files changed, 28 insertions, 0 deletions
diff --git a/testsuite/tls4.sh b/testsuite/tls4.sh
new file mode 100755
index 0000000..889f0cc
--- /dev/null
+++ b/testsuite/tls4.sh
@@ -0,0 +1,28 @@
+#!/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 tls4 tls4lib*.so tls4.log
+rm -f prelink.cache
+$RUN_HOST $CC -shared -O2 -fpic -o tls4lib1.so $srcdir/tls4lib1.c
+$RUN_HOST $CC -shared -O2 -fpic -o tls4lib2.so $srcdir/tls4lib2.c \
+ tls4lib1.so 2>/dev/null
+BINS="tls4"
+LIBS="tls4lib1.so tls4lib2.so"
+$RUN_HOST $CCLINK -o tls4 $srcdir/tls4.c -Wl,--rpath-link,. tls4lib2.so -lc tls4lib1.so
+savelibs
+echo $PRELINK ${PRELINK_OPTS--vm} ./tls4 > tls4.log
+$RUN_HOST $PRELINK ${PRELINK_OPTS--vm} ./tls4 >> tls4.log 2>&1 || exit 1
+grep -q ^`echo $PRELINK | sed 's/ .*$/: /'` tls4.log && exit 2
+if [ "x$CROSS" = "x" ]; then
+ $RUN LD_LIBRARY_PATH=. ./tls4 || exit 3
+fi
+$RUN_HOST $READELF -a ./tls4 >> tls4.log 2>&1 || exit 4
+# So that it is not prelinked again
+chmod -x ./tls4
+comparelibs >> tls4.log 2>&1 || exit 5