2000-07-16 H.J. Lu (hjl@gnu.org)
authorH.J. Lu <hjl.tools@gmail.com>
Sun, 16 Jul 2000 21:29:32 +0000 (21:29 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Sun, 16 Jul 2000 21:29:32 +0000 (21:29 +0000)
* ld-elfvsb/elfvsb.exp (support_protected): New variable. Check
and set to "yes" if the protected visibility is expected to
pass.
(visibility_run): Set expected to fail for the "protected"
and "protected_undef_def" tests only if $support_protected is
"no".

* ld-elfvsb/main.c (PROTECTED_CHECK): Check for the protected
visibility support if defined.

ld/testsuite/ChangeLog
ld/testsuite/ld-elfvsb/elfvsb.exp
ld/testsuite/ld-elfvsb/main.c

index 58a112417d08169031088d4337b4a0fb90fc98a3..8f9bb2c391b9fdde6dcf5216833a5ba9eea34045 100644 (file)
@@ -1,3 +1,15 @@
+2000-07-16  H.J. Lu  (hjl@gnu.org)
+
+       * ld-elfvsb/elfvsb.exp (support_protected): New variable. Check
+       and set to "yes" if the protected visibility is expected to
+       pass.
+       (visibility_run): Set expected to fail for the "protected"
+       and "protected_undef_def" tests only if $support_protected is
+       "no".
+
+       * ld-elfvsb/main.c (PROTECTED_CHECK): Check for the protected
+       visibility support if defined.
+
 2000-07-15  H.J. Lu  (hjl@gnu.org)
 
        * ld-elfvsb/elfvsb.exp (visibility_run): Set expected failure
index e3a010ed10c74054c191d3b4cc87d42d854f24a3..e437a560be7265576f2371d5d0252cc0d3f6487e 100644 (file)
@@ -74,6 +74,16 @@ if { [istarget rs6000*-*-aix*] || [istarget powerpc*-*-aix*] } {
     close $file
 }
 
+set support_protected "no"
+
+if [istarget *-*-linux*] {
+    if [ld_compile "$CC $CFLAGS -DPROTECTED_CHECK" $srcdir/$subdir/main.c $tmpdir/main.o] {
+      if [ld_link $ld $tmpdir/main "$tmpdir/main.o"] {
+       catch "exec $tmpdir/main" support_protected
+      }
+    }
+}
+
 # The test procedure.
 proc visibility_test { visibility progname testname main sh1 sh2 dat args } {
     global ld
@@ -171,6 +181,7 @@ proc visibility_run {visibility} {
     global tmpdir
     global picflag
     global target_triplet
+    global support_protected
 
     if [ string match $visibility "hidden" ] {
        set VSBCFLAG "-DHIDDEN_TEST"
@@ -215,7 +226,9 @@ proc visibility_run {visibility} {
            # overriding.
            if { [ string match $visibility "protected" ]
                 || [ string match $visibility "protected_undef_def" ] } {
-               setup_xfail $target_triplet
+               if [ string match $support_protected "no" ] {
+                   setup_xfail $target_triplet
+               }
            } else {
                setup_xfail "*-*-sunos4*"
            }
@@ -227,7 +240,9 @@ proc visibility_run {visibility} {
            # the load address is not zero (which is the default).
            if { [ string match $visibility "protected" ]
                 || [ string match $visibility "protected_undef_def" ] } {
-               setup_xfail $target_triplet
+               if [ string match $support_protected "no" ] {
+                   setup_xfail $target_triplet
+               }
            } else {
                setup_xfail "*-*-sunos4*"
                setup_xfail "*-*-linux*libc1"
@@ -245,7 +260,9 @@ proc visibility_run {visibility} {
        } else {
            if { [ string match $visibility "protected" ]
                 || [ string match $visibility "protected_undef_def" ] } {
-               setup_xfail $target_triplet
+               if [ string match $support_protected "no" ] {
+                   setup_xfail $target_triplet
+               }
            }
            # SunOS can not compare function pointers correctly
            if [istarget "*-*-sunos4*"] {
@@ -271,7 +288,9 @@ proc visibility_run {visibility} {
                # overriding.
                if { [ string match $visibility "protected" ]
                     || [ string match $visibility "protected_undef_def" ] } {
-                   setup_xfail $target_triplet
+                   if [ string match $support_protected "no" ] {
+                       setup_xfail $target_triplet
+                   }
                } else {
                    setup_xfail "*-*-sunos4*"
                }
@@ -284,7 +303,9 @@ proc visibility_run {visibility} {
        if { [file exists $tmpdir/sh1p.o ] && [ file exists $tmpdir/sh2p.o ] } {
            if { [ string match $visibility "protected" ]
                 || [ string match $visibility "protected_undef_def" ] } {
-               setup_xfail $target_triplet
+               if [ string match $support_protected "no" ] {
+                   setup_xfail $target_triplet
+               }
            }
            if { [istarget rs6000*-*-aix*] || [istarget powerpc*-*-aix*] } {
                visibility_test $visibility vmpp "visibility ($visibility) (PIC main)" mainp.o sh1p.o sh2p.o xcoff
index 0aaa83515a75a93f4704e4a437de584752819fbe..a00b70feddb1505d08e5318e5052f101e0414700 100644 (file)
@@ -1,3 +1,21 @@
+#ifdef PROTECTED_CHECK
+#include <features.h>
+
+int
+main (argc, argv)
+  int argc;
+  char *argv[];
+{
+#if defined (__GLIBC__) && (__GLIBC__ > 2 \
+                           || (__GLIBC__ == 2 \
+                               &&  __GLIBC_MINOR__ >= 2))
+  puts ("yes");
+#else
+  puts ("no");
+#endif
+  return 0;
+}
+#else
 /* This is the main program for the shared library test.  */
 
 #include <stdio.h>
@@ -158,3 +176,4 @@ main ()
          main_visibility_checkvar ());
   return 0;
 }
+#endif