2001-09-14 H.J. Lu <hjl@gnu.org>
authorH.J. Lu <hjl.tools@gmail.com>
Fri, 14 Sep 2001 23:43:17 +0000 (23:43 +0000)
committerH.J. Lu <hjl.tools@gmail.com>
Fri, 14 Sep 2001 23:43:17 +0000 (23:43 +0000)
* ld-elfweak/bar.c: Updated.
* ld-elfweak/bar1a.c: Likewise.
* ld-elfweak/main.c: Likewise.
* ld-elfweak/main1.c: Likewise.
* ld-elfweak/elfweak.exp: Likewise.
* ld-elfweak/weakdata.dsym: Updated.

ld/testsuite/ChangeLog
ld/testsuite/ld-elfweak/bar.c
ld/testsuite/ld-elfweak/bar1a.c
ld/testsuite/ld-elfweak/elfweak.exp
ld/testsuite/ld-elfweak/main.c
ld/testsuite/ld-elfweak/main1.c
ld/testsuite/ld-elfweak/weakdata.dsym

index 72e9cff40c9673d988a48708130a77ef2881f657..4512ad86c8a62967f8a91149340cb7c1bc979f63 100644 (file)
@@ -1,3 +1,12 @@
+2001-09-14  H.J. Lu  <hjl@gnu.org>
+
+       * ld-elfweak/bar.c: Updated.
+       * ld-elfweak/bar1a.c: Likewise.
+       * ld-elfweak/main.c: Likewise.
+       * ld-elfweak/main1.c: Likewise.
+       * ld-elfweak/elfweak.exp: Likewise.
+       * ld-elfweak/weakdata.dsym: Updated.
+
 2001-09-11  H.J. Lu  <hjl@gnu.org>
 
        * ld-elfweak/elfweak.exp (build_lib): Take a list of object
index 2245e8da967a42e5a053ea89419de615a11a070a..631751884b663ebfa68f541dc594213a429bfe12 100644 (file)
@@ -1,9 +1,16 @@
 #include <stdio.h>
 
 extern void foo ();
+extern void foobar ();
 
 void
 foo ()
 {
   printf ("strong foo\n");
 }
+
+void
+foobar ()
+{
+  foo ();
+}
index 7ca1f0413215c450921e063e286070d4a9c621ef..daf0c58bb7d5c5356ff44817abdacd208b32607c 100644 (file)
@@ -1,6 +1,23 @@
-#pragma weak deallocate_foo
+#include <stdio.h>
 
-int deallocate_foo = 1;
+extern int deallocate_foo;
+
+extern int * bar ();
+extern int * foo ();
+extern void abort ();
+extern void foobar ();
+
+void
+foobar ()
+{
+  if (&deallocate_foo != bar () || &deallocate_foo != foo ())
+    abort ();
+
+  if (deallocate_foo)
+    printf ("weak deallocate_foo\n");
+  else
+    printf ("strong deallocate_foo\n");
+}
 
 int *
 bar()
index ea751f3684448004b851b9e81441d7b2e689b39e..bfefa115f118e152bd9c4f86af32817aad946383 100644 (file)
@@ -434,6 +434,11 @@ if {![ld_link $ld $tmpdir/libfoo1b.so "$shared $tmpdir/foo1b.o"]} {
     return
 }
 
+if {![ld_link $ld $tmpdir/libbar1a.so "$shared $tmpdir/bar1a.o $tmpdir/libfoo1a.so"]} {
+    fail "ELF weak"
+    return
+}
+
 build_lib "ELF DSO weak func first" libfoo "foo.o bar.o" dso.dsym
 build_lib "ELF DSO weak func last" libfoo "bar.o foo.o" dso.dsym
 setup_xfail "*-*-*"
@@ -450,22 +455,22 @@ build_exec "ELF weak func last DSO" foo "libbar.so main.o" "-rpath ." weak weak.
 build_lib "ELF DSO weak data first" libfoo "bar1a.o foo1a.o" dsodata.dsym
 build_lib "ELF DSO weak data last" libfoo "foo1a.o bar1a.o" dsodata.dsym
 setup_xfail "*-*-*"
-build_lib "ELF DSO weak data first DSO" libfoo "bar1a.o libfoo1a.so" dsowdata.dsym
+build_lib "ELF DSO weak data first DSO" libfoo "main1.o libfoo1a.so" dsowdata.dsym
 setup_xfail "*-*-*"
-build_lib "ELF DSO weak data last DSO" libfoo "libfoo1a.so bar1a.o" dsowdata.dsym
+build_lib "ELF DSO weak data last DSO" libfoo "libfoo1a.so main1.o" dsowdata.dsym
 setup_xfail "*-*-*"
-build_lib "ELF DSO weak data first DSO common" libfoo "bar1a.o libfoo1b.so" dsowdata.dsym
+build_lib "ELF DSO weak data first DSO common" libfoo "main1.o libfoo1b.so" dsowdata.dsym
 setup_xfail "*-*-*"
-build_lib "ELF DSO weak data last DSO common" libfoo "libfoo1b.so bar1a.o" dsowdata.dsym
+build_lib "ELF DSO weak data last DSO common" libfoo "libfoo1b.so main1.o" dsowdata.dsym
 build_exec "ELF weak data first" foo "main1.o bar1a.o foo1a.o" "" strongdata "" strongdata.sym
 build_exec "ELF weak data last" foo "foo1a.o main1.o bar1a.o" "" strongdata "" strongdata.sym
 build_exec "ELF weak data first common" foo "main1.o bar1a.o foo1b.o" "" strongdata "" strongcomm.sym
 build_exec "ELF weak data last common" foo "foo1b.o main1.o bar1a.o" "" strongdata "" strongcomm.sym
 setup_xfail "*-*-*"
-build_exec "ELF weak data first DSO" foo "main1.o bar1a.o libfoo1a.so" "-rpath ." weakdata weakdata.dsym ""
+build_exec "ELF weak data first DSO" foo "main1.o libbar1a.so libfoo1a.so" "-rpath ." weakdata weakdata.dsym ""
 setup_xfail "*-*-*"
-build_exec "ELF weak data last DSO" foo "libfoo1a.so main1.o bar1a.o" "-rpath ." weakdata weakdata.dsym ""
+build_exec "ELF weak data last DSO" foo "libfoo1a.so main1.o libbar1a.so" "-rpath ." weakdata weakdata.dsym ""
 setup_xfail "*-*-*"
-build_exec "ELF weak data first DSO common" foo "main1.o bar1a.o libfoo1b.so" "-rpath ." weakdata weakdata.dsym ""
+build_exec "ELF weak data first DSO common" foo "main1.o libbar1a.so libfoo1b.so" "-rpath ." weakdata weakdata.dsym ""
 setup_xfail "*-*-*"
-build_exec "ELF weak data last DSO common" foo "libfoo1b.so main1.o bar1a.o" "-rpath ." weakdata weakdata.dsym ""
+build_exec "ELF weak data last DSO common" foo "libfoo1b.so main1.o libbar1a.so" "-rpath ." weakdata weakdata.dsym ""
index 9daaceb685c97baf135711e633259972e9213bda..5ea170c8b0556ebe0b39b32e9cf1b048fd815675 100644 (file)
@@ -3,6 +3,7 @@
 #pragma weak foo
 
 extern void foo ();
+extern void foobar ();
 
 void
 foo ()
@@ -13,6 +14,6 @@ foo ()
 int
 main ()
 {
-  foo ();
+  foobar ();
   return 0;
 }
index 8a897a291414309b63bf31ad1ccb9254f3026cbc..39f819eb930df14b2aa52134b8d8639a64b688ea 100644 (file)
@@ -1,22 +1,11 @@
-#include <stdio.h>
-
 #pragma weak deallocate_foo
 int deallocate_foo = 1;
 
-extern int * bar ();
-extern int * foo ();
-extern void abort ();
+extern void foobar ();
 
 int
 main ()
 {
-  if (&deallocate_foo != bar () || &deallocate_foo != foo ())
-    abort ();
-
-  if (deallocate_foo)
-    printf ("weak deallocate_foo\n");
-  else
-    printf ("strong deallocate_foo\n");
-
+  foobar ();
   return 0;
 }
index 4f1873b9a5bcc0ec0c9e07de8de99e7ee094511d..0b5cca3a15c13b9bea2d703239197f8050e972ec 100644 (file)
@@ -1,2 +1 @@
 [0-9a-f]*[     ]+w[    ]+DO[   ]+.data[        ]+[0-9a-f]*[    ]+(Base[        ]+|[    ]*)deallocate_foo
-[0-9a-f]*[     ]+DF[   ]+\*UND\*[      ]+[0-9a-f]*[    ]+(Base[        ]+|[    ]*)foo