Use Windows style directory separators when running sysroot tests under MinGW and...
authorIgor Kudrin <ikudrin@accesssoftek.com>
Wed, 15 Feb 2017 09:13:56 +0000 (09:13 +0000)
committerNick Clifton <nickc@redhat.com>
Wed, 15 Feb 2017 09:13:56 +0000 (09:13 +0000)
* testsuite/ld-scripts/sysroot-prefix.exp
(get_base_dir_for_scripts): New function.
(run_sysroot_prefix_test): Use get_base_dir_for_scripts.

ld/ChangeLog
ld/testsuite/ld-scripts/sysroot-prefix.exp

index 4bb505dac58b125766c0425eaa9d3799d1c4177a..618ae819ef04a97d13bf1c58ecb7fe0a06c481fe 100644 (file)
@@ -1,3 +1,9 @@
+2017-02-15  Igor Kudrin  <ikudrin@accesssoftek.com>
+
+       * testsuite/ld-scripts/sysroot-prefix.exp
+       (get_base_dir_for_scripts): New function.
+       (run_sysroot_prefix_test): Use get_base_dir_for_scripts.
+
 2017-02-13  Palmer Dabbelt  <palmer@dabbelt.com>
 
        * emulparams/elf32lriscv-defs.sh (SDATA_START_SYMBOLS): Change
index 2bb67e46958cbd2bcef8eedac12feb90752955fc..0fc322eb5c7cc176bc184617e5fe7836b97d53d3 100644 (file)
@@ -39,6 +39,24 @@ if {$ld_sysroot == "/"} {
     set with_sysroot 3
 }
 
+# The linker on Windows expects Windows style paths.
+# MSYS2 runtime converts paths in the command line automatically.
+# However, for our test linker scripts, we have to prepare
+# the correct paths manually.
+proc get_base_dir_for_scripts {} {
+    global base_dir
+    global get_base_dir_for_scripts_saved
+
+    if { ![info exists get_base_dir_for_scripts_saved] } {
+       set get_base_dir_for_scripts_saved $base_dir
+       if { ([ishost *-*-cygwin] || [ishost *-*-mingw*] )
+            && ![catch "exec cygpath -m $base_dir" base_dir_converted] } {
+           set get_base_dir_for_scripts_saved $base_dir_converted
+       }
+    }
+    return $get_base_dir_for_scripts_saved
+}
+
 # Entries in the array-tables:
 # 0: Testtype; an inclusive bitmask indicating that the test should run on a
 # build configured for: 1: non-sysroot, 2: sysroot != "/", 4: sysroot == "/".
@@ -160,7 +178,7 @@ proc run_sysroot_prefix_test { type name templ p ldopt errstr } {
     set qlist { { "quoted" "\"" } { "unquoted" {} } }
 
     regsub -all "@p@" $templ $p templ
-    regsub -all "@cwd@" $templ "$base_dir/tmpdir" templ
+    regsub -all "@cwd@" $templ "[get_base_dir_for_scripts]/tmpdir" templ
     regsub -all "@cwd@" $ldopt "$base_dir/tmpdir" ldopt
     regsub -all "@cwd@" $name "<CWD>" name