PR linker/4844
authorNick Clifton <nickc@redhat.com>
Tue, 2 Oct 2007 12:47:08 +0000 (12:47 +0000)
committerNick Clifton <nickc@redhat.com>
Tue, 2 Oct 2007 12:47:08 +0000 (12:47 +0000)
* ld-auto-import/auto-import.exp: Extend test to include running the application and checking for some output.
* ld-auto-import/client.c (struct TEST): Include a variable field with an offset.
  (const_xyz): A const version of the xyz structure used to test the initialization of constant data.

ld/testsuite/ChangeLog
ld/testsuite/ld-auto-import/auto-import.exp
ld/testsuite/ld-auto-import/client.c

index cb88c523fc73af4ef8e8d435d74cf7b9ff3f6ce4..a555727ea82b37087d04e8577f1102a7c51bb554 100644 (file)
@@ -1,3 +1,13 @@
+2007-10-02  Ralf Habecker  <ralf.habacker@freenet.de>
+
+       PR linker/4844
+       * ld-auto-import/auto-import.exp: Extend test to include running
+       the application and checking for some output.
+       * ld-auto-import/client.c (struct TEST): Include a variable field
+       with an offset.
+       (const_xyz): A const version of the xyz structure used to test the
+       initialization of constant data.
+
 2007-09-30  Mike Frysinger  <vapier@gentoo.org>
 
        * ld-selective/selective.exp: Set $compiler based on $testtype and
index 98c0d757955910242ca504ef476743f6bb7f8b32..0192345e7e92738df76e3a33261ea2c38b08c22e 100644 (file)
  
 # Note: 
 # 
-# This test checks the "auto importing direct from a dll" functionality, 
-# which dramatically reduces the linking time for big libraries and applications 
-# by skipping creating/using import libraries. Instead it links directly to the 
-# related dll or to a symlinked dll for replacing regular import libraries. 
-# 
-# The test has 4 stages: 
-# 
-# 1. compile and link a test dll exporting some text and data symbols and a 
-#    standard import library
+# This script tests some auto-import functionality:
+#
+#  A. "auto importing direct from a dll" functionality, which dramatically reduces the 
+#     linking time for big libraries and applications by skipping creating/using 
+#     import libraries. Instead it links directly to the related dll or to a symlinked 
+#     dll for replacing regular import libraries. The test has 6 stages: 
+#  
+#     1. compile and link a test dll exporting some text and data symbols and a 
+#     standard import library
+#
+#     2. create a symbolic link to this dll to simulate a replaced import library. 
 #
-# 2. create a symbolic link to this dll to simulate a replaced import library. 
+#     3. compile and link a client application with the standard import library. 
+#     This should produce no errors. 
 #
-# 3. compile and link a client application with the standard import library
-#    This should produce no errors. 
+#     4. compile and link a client application with the created dll
+#     This should also produce no errors. 
 #
-# 4. compile and link a client application with the created dll
-#    This should also produce no errors. 
+#     5. compile and link a client application using the "import library"
+#     This should also produce no errors. 
 #
-# 5. compile and link a client application using the "import library". 
-#    This should also produce no errors. 
+#     6. compile and link a client application with auto-import disabled. 
+#     This should produce a linking error. 
+#
+# B. runtime check if there are no segfaults when importing const data variables 
 #
-# 6. compile and link a client application with auto-import disabled. 
-#    This should produce a linking error. 
 
 # This test can only be run if ld generates native executables.
 if ![isnative] then {return}
 
-# This test can only be run on a couple of ELF platforms.
+# This test can only be run on a couple of platforms.
 # Square bracket expressions seem to confuse istarget.
 if { ![istarget *-pc-cygwin]    
      && ![istarget *-pc-mingw*] } {
     return
 }
 
+if [istarget *-pc-mingw*] {
+    # FIXME: Add support for this target.
+    unsupported "mingw currently not supported"
+}
+
 # No compiler, no test.
 if { [which $CC] == 0 } {
-    untested "Auto import test"
+    untested "Auto import test (compiler not found)"
     return
 }
 
@@ -97,10 +105,10 @@ proc ld_special_link { ld target objects } {
 
     if [string match "" $exec_output] then {
        return 1
-    } else {
-       verbose -log "$exec_output"
-       return 0
     }
+
+    verbose -log "$exec_output"
+    return 0
 }
 
 set tmpdir tmpdir
@@ -111,53 +119,59 @@ if [istarget *-pc-cygwin] {
     set MYLIBS "-L/usr/lib -lcygwin -L/usr/lib/w32api -lkernel32"
     
     # Compile the dll.
-    if ![ld_compile "$CC $CFLAGS $SHCFLAG" $srcdir/$subdir/dll.c $tmpdir/dll.o ] {
+    if ![ld_compile "$CC $CFLAGS $SHCFLAG" $srcdir/$subdir/dll.c $tmpdir/dll.o] {
        fail "compiling shared lib"
-    } elseif ![ld_special_link "$ld -shared --out-implib=$tmpdir/libstandard.dll.a" $tmpdir/dll.dll "$tmpdir/dll.o $MYLIBS" ] {
+    }
+    if ![ld_special_link "$CC -shared --enable-auto-import --out-implib=$tmpdir/libstandard.dll.a" $tmpdir/dll.dll "$tmpdir/dll.o $MYLIBS"] {
        fail "linking shared lib"
+    }
+
+    # Create symbolic link.
+    catch "exec ln -fs dll.dll $tmpdir/libsymlinked_dll.dll.a" ln_catch
+
+    # Compile and link the client program.
+    if ![ld_compile "$CC $CFLAGS $SHCFLAG" $srcdir/$subdir/client.c $tmpdir/client.o] {
+        fail "compiling client"
+    }
+
+    # Check linking with import library.
+    set msg "linking auto-import client using a standard import library"
+    if [ld_special_link $ld $tmpdir/client-linklib.exe "--enable-auto-import --enable-runtime-pseudo-reloc /lib/crt0.o $tmpdir/client.o -L$tmpdir -lstandard $MYLIBS"] {
+       pass $msg
     } else {
-       # Create symbolic link.
-       catch "exec ln -fs dll.dll $tmpdir/libsymlinked_dll.dll.a" ln_catch
-       
-       # Compile and link the client program.
-       if ![ld_compile "$CC $CFLAGS $SHCFLAG" $srcdir/$subdir/client.c $tmpdir/client.o ] {
-           fail "compiling client"
-       } else {
-           # Check linking with import library.
-           set msg "linking auto-import client using a standard import library"
-           if [ld_special_link $ld $tmpdir/client.exe "--enable-auto-import /lib/crt0.o $tmpdir/client.o -L$tmpdir -lstandard $MYLIBS" ] {
-               pass $msg
-           } else {
-               fail $msg 
-           }
-
-           # Check linking directly with dll.
-           set msg "linking auto-import client using the dll"
-           if [ld_special_link $ld $tmpdir/client.exe "--enable-auto-import /lib/crt0.o $tmpdir/client.o -L$tmpdir -ldll $MYLIBS" ] {
-               pass $msg
-           } else {
-               fail $msg 
-           }
-
-           # Check linking with symlinked dll.
-           set msg "linking auto-import client using symbolic linked dll"
-           if [ld_special_link $ld $tmpdir/clientimport.exe "--enable-auto-import /lib/crt0.o $tmpdir/client.o -L$tmpdir -lsymlinked_dll $MYLIBS" ] {
-               pass $msg
-           }   else {
-               fail $msg 
-           }
-
-           # Check linking with disabled auto-import, this must produce linking error.
-           set msg "linking with disabled auto-import"
-           if ![ld_special_link $ld $tmpdir/clientimport.exe "--disable-auto-import /lib/crt0.o $tmpdir/client.o -L$tmpdir -ldll $MYLIBS" ] {
-               pass $msg
-           }   else {
-               fail $msg
-           }
-       }
+       fail $msg 
     }
-}
 
-if [istarget *-pc-mingw*] {
-    unsupported "mingw currently not supported"
+    # Check linking directly with dll.
+    set msg "linking auto-import client using the dll"
+    if [ld_special_link $ld $tmpdir/client-linkdll.exe "--enable-auto-import --enable-runtime-pseudo-reloc /lib/crt0.o $tmpdir/client.o -L$tmpdir -ldll $MYLIBS"] {
+       pass $msg
+    } else {
+       fail $msg 
+    }
+
+    # Check linking with symlinked dll.
+    set msg "linking auto-import client using symbolic linked dll"
+    if [ld_special_link $ld $tmpdir/client-symlinkeddll.exe "--enable-auto-import --enable-runtime-pseudo-reloc /lib/crt0.o $tmpdir/client.o -L$tmpdir -lsymlinked_dll $MYLIBS"] {
+       pass $msg
+    } else {
+       fail $msg 
+    }
+
+    # Check linking with disabled auto-import, this must produce linking error.
+    set msg "linking with disabled auto-import"
+    if ![ld_special_link $ld $tmpdir/client-failed.exe "--disable-auto-import --enable-runtime-pseudo-reloc /lib/crt0.o $tmpdir/client.o -L$tmpdir -ldll $MYLIBS"] {
+       pass $msg
+    } else {
+       fail $msg
+    }
+
+    # Check that the app works - ie that there is output when the applications runs.
+    set msg "application runtime segfault check" 
+    catch "exec $tmpdir/client-linklib.exe" exec_output
+    if ![string match "" $exec_output] then {
+       pass $msg
+    } else {
+       fail $msg
+    }
 }
index 9ed80c5844b454d0ce7fb9a44d27b3600d62b2ab..b883fdbd17b64fdc3f8c145389ce40bfdb2b7fc5 100644 (file)
@@ -11,10 +11,13 @@ typedef struct
 {\r
   int *   var;\r
   void (* func_ptr)(void);\r
+  int *   var_with_offset;\r
 }\r
 TEST;\r
 \r
-TEST xyz = { &var, print_var };\r
+TEST xyz = { & var, print_var, & var };\r
+\r
+const TEST const_xyz = { & var, print_var, & var };\r
 \r
 int\r
 main (void)\r
@@ -51,5 +54,7 @@ main (void)
 \r
   printf ("We see var2[0] = %d\n\n", var2[0]);\r
 \r
+  printf ("We see const xyz %x %x\n", const_xyz.var, const_xyz.var_with_offset);\r
+\r
   return 0;\r
 }\r