Add x86_64-mingw64 target
[deliverable/binutils-gdb.git] / ld / testsuite / ld-bootstrap / bootstrap.exp
index 0e4b820cb203e5fac055cbb95a42409704cb536d..d5ed9051150c5ce77a15b062116d6b3ad2d37a16 100644 (file)
@@ -1,5 +1,6 @@
 # Expect script for LD Bootstrap Tests
-#   Copyright (C) 1993, 1994, 1995, 1996, 1997, 1998 Free Software Foundation
+#   Copyright 1993, 1994, 1995, 1996, 1997, 1998, 2000, 2001, 2002, 2004, 2006
+#   Free Software Foundation, Inc.
 #
 # This file is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -13,7 +14,7 @@
 # 
 # You should have received a copy of the GNU General Public License
 # along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
 #
 # Written by Jeffrey Wheat (cassidy@cygnus.com)
 # Rewritten by Ian Lance Taylor (ian@cygnus.com)
@@ -31,11 +32,23 @@ if ![isnative] {
 # really test -r.  Use ld1 to link a fresh ld, ld2.  Use ld2 to link a
 # new ld, ld3.  ld2 and ld3 should be identical.
 
-foreach flags {"" "--static" "--traditional-format" "--no-keep-memory"} {
-    if {"$flags" != ""} { 
+foreach flags {"" "strip" "--static" "--traditional-format"
+              "--no-keep-memory" "--relax"} {
+    set do_strip "no"
+    if {"$flags" == "strip"} { 
+       set testname "bootstrap with $flags"
+        set flags ""
+       set do_strip "yes"
+    } else { if {"$flags" != ""} { 
        set testname "bootstrap with $flags"
     } else {
        set testname "bootstrap"
+    }}
+
+    # --static is meaningless and --relax is incompatible with -r.
+    set partial_flags "$flags"
+    if { "$flags" == "--static" || "$flags" == "--relax" } {
+       set partial_flags ""
     }
 
     # This test can only be run if we have the ld build directory,
@@ -52,7 +65,7 @@ foreach flags {"" "--static" "--traditional-format" "--no-keep-memory"} {
        continue
     }
 
-    if ![ld_relocate $ld tmpdir/ld-partial.o "$flags $OFILES"] {
+    if ![ld_relocate $ld tmpdir/ld-partial.o "$partial_flags $OFILES"] {
        fail $testname
        continue
     }
@@ -60,7 +73,8 @@ foreach flags {"" "--static" "--traditional-format" "--no-keep-memory"} {
     # On AIX, you need to specify an import list when using --static.
     # You only want the import list when creating the final
     # executable.
-    if [istarget "*-*-aix*"] {
+    if { [istarget "*-*-aix*"] 
+         && ![istarget "ia64-*-aix*"]} {
        if {"$flags" == "--static"} {
            set flags "--static -bI:/lib/syscalls.exp"
        }
@@ -77,6 +91,16 @@ foreach flags {"" "--static" "--traditional-format" "--no-keep-memory"} {
        continue
     }
 
+    if {"$do_strip" == "yes"} { 
+       verbose -log "$strip tmpdir/ld1"     
+       catch "exec $strip tmpdir/ld1" exec_output
+       if ![string match "" $exec_output] then {
+           verbose -log "$exec_output"
+           fail $testname
+           continue
+       }
+    }
+
     if ![ld_link tmpdir/ld1 tmpdir/ld2 "$flags $OFILES $BFDLIB $LIBIBERTY"] {
        fail $testname
        continue
@@ -87,9 +111,53 @@ foreach flags {"" "--static" "--traditional-format" "--no-keep-memory"} {
        continue
     }
 
-    send_log "cmp tmpdir/ld2 tmpdir/ld3\n"
-    verbose "cmp tmpdir/ld2 tmpdir/ld3"
-    catch "exec cmp tmpdir/ld2 tmpdir/ld3" exec_output
+    if {"$flags" == "--static"} {
+       if { [istarget ia64-*-elf*]
+            || [istarget ia64-*-linux*] } {
+           # On ia64, tmpdir/ld2 != tmpdir/ld3 is normal since they are
+           # generated by different linkers, tmpdir/ld1 and tmpdir/ld2.
+           # So we rebuild tmpdir/ld2 with tmpdir/ld3.
+           if ![ld_link tmpdir/ld3 tmpdir/ld2 "$flags $OFILES $BFDLIB $LIBIBERTY"] {
+               fail $testname
+               continue
+           }
+       }
+    } else {
+       if { [istarget mips*-*-linux*] } {
+           # On Linux/mips, tmpdir/ld2 != tmpdir/ld3 is normal since
+           # they are generated by different linkers, tmpdir/ld1 and
+           # tmpdir/ld2. So we rebuild tmpdir/ld2 with tmpdir/ld3.
+           if ![ld_link tmpdir/ld3 tmpdir/ld2 "$flags $OFILES $BFDLIB $LIBIBERTY"] {
+               fail $testname
+               continue
+           }
+       }
+    }
+
+    send_log "compare (tail of) tmpdir/ld2 tmpdir/ld3\n"
+    verbose  "compare (tail of) tmpdir/ld2 tmpdir/ld3"
+    if {[istarget "*-*-pe"]
+       || [istarget "*-*-wince"]
+       || [istarget "*-*-cygwin*"]
+       || [istarget "*-*-winnt*"]
+       || [istarget "*-*-mingw*"]
+       || [istarget "*-*-interix*"]
+       || [istarget "*-*-beospe*"]
+       || [istarget "*-*-netbsdpe*"]} {
+        # Trim off the date present in PE binaries by only looking
+        #   at the ends of the files
+        # Although this works, a way to set the date would be better.
+        # Removing or zeroing the date stamp in the binary produced by
+        # the linker is not possible as it is required by the target OS.
+        exec tail +140 tmpdir/ld2 >tmpdir/ld2tail
+        exec tail +140 tmpdir/ld3 >tmpdir/ld3tail
+        catch "exec cmp tmpdir/ld2tail tmpdir/ld3tail" exec_output
+        exec rm tmpdir/ld2tail tmpdir/ld3tail
+    } else {
+        send_log "cmp tmpdir/ld2 tmpdir/ld3\n"
+        verbose  "cmp tmpdir/ld2 tmpdir/ld3"
+        catch "exec cmp tmpdir/ld2 tmpdir/ld3" exec_output
+    }
     set exec_output [prune_warnings $exec_output]
 
     if [string match "" $exec_output] then {
@@ -101,3 +169,6 @@ foreach flags {"" "--static" "--traditional-format" "--no-keep-memory"} {
        fail $testname
     }
 }
+
+catch "exec rm -f tmpdir/ld-partial.o tmpdir/ld1 tmpdir/ld2 tmpdir/ld3" status
+catch "exec rm -f tmpdir/ld1tail tmpdir/ld2tail tmpdir/ld3tail" status
This page took 0.028532 seconds and 4 git commands to generate.