typo fixes
[deliverable/binutils-gdb.git] / ld / testsuite / lib / ld-lib.exp
CommitLineData
a2b64bed 1# Support routines for LD testsuite.
25629536 2# Copyright 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003,
5a68afcf 3# 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012
8c5fc800 4# Free Software Foundation, Inc.
a2b64bed 5#
f96b4a7b
NC
6# This file is part of the GNU Binutils.
7#
a2b64bed
NC
8# This file is free software; you can redistribute it and/or modify
9# it under the terms of the GNU General Public License as published by
f96b4a7b 10# the Free Software Foundation; either version 3 of the License, or
a2b64bed 11# (at your option) any later version.
3e8cba19 12#
a2b64bed
NC
13# This program is distributed in the hope that it will be useful,
14# but WITHOUT ANY WARRANTY; without even the implied warranty of
15# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16# GNU General Public License for more details.
3e8cba19 17#
a2b64bed
NC
18# You should have received a copy of the GNU General Public License
19# along with this program; if not, write to the Free Software
f96b4a7b
NC
20# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
21# MA 02110-1301, USA.
3b6fe0cc 22
f3097f33
RS
23proc load_common_lib { name } {
24 global srcdir
25 load_file $srcdir/../../binutils/testsuite/lib/$name
26}
27
28load_common_lib binutils-common.exp
29
fb35d3d8
DD
30# Returns 1 if the gcc for the target is at least version MAJOR.MINOR
31# Returns 0 otherwise.
32#
33proc at_least_gcc_version { major minor } {
5a68afcf 34
fb35d3d8
DD
35 if {![info exists CC]} {
36 set CC [find_gcc]
37 }
38 if { $CC == "" } {
39 return 0
40 }
41 set state [remote_exec host $CC --version]
42 set tmp "[lindex $state 1]\n"
43 # Look for (eg) 4.6.1 in the version output.
44 regexp " .* (\[1-9\])\\.(\[0-9\])\\.\[0-9\]* .*" "$tmp" fred maj min
45 verbose "gcc version: $tmp"
46 verbose "major gcc version is $maj, want at least $major"
47 if { $maj == $major } then {
48 verbose "minor gcc version is $min, want at least $minor"
49 return [expr $min >= $minor ]
50 } else {
51 return [expr $maj > $major ]
52 }
53}
54
3b6fe0cc 55# Extract and print the version number of ld.
252b5132
RH
56#
57proc default_ld_version { ld } {
58 global host_triplet
59
7f6a71ff 60 if { ![is_remote host] && [which $ld] == 0 } then {
252b5132
RH
61 perror "$ld does not exist"
62 exit 1
63 }
3e8cba19 64
7f6a71ff
JM
65 remote_exec host "$ld --version" "" "/dev/null" "ld.version"
66 remote_upload host "ld.version"
67 set tmp [prune_warnings [file_contents "ld.version"]]
68 remote_file build delete "ld.version"
69 remote_file host delete "ld.version"
70
252b5132
RH
71 regexp "\[^\n\]* (cygnus-|)(\[-0-9.a-zA-Z-\]+)\[\r\n\].*" $tmp version cyg number
72 if [info exists number] then {
73 clone_output "$ld $number\n"
74 }
75}
76
7f6a71ff
JM
77proc run_host_cmd { prog command } {
78 global link_output
3e8cba19 79
7f6a71ff
JM
80 if { ![is_remote host] && [which "$prog"] == 0 } then {
81 perror "$prog does not exist"
252b5132
RH
82 return 0
83 }
3e8cba19 84
7f6a71ff
JM
85 verbose -log "$prog $command"
86 set status [remote_exec host [concat sh -c [list "$prog $command 2>&1"]] "" "/dev/null" "ld.tmp"]
87 remote_upload host "ld.tmp"
88 set link_output [file_contents "ld.tmp"]
89 regsub "\n$" $link_output "" link_output
90 if { [lindex $status 0] != 0 && [string match "" $link_output] } then {
91 append link_output "child process exited abnormally"
92 }
93 remote_file build delete ld.tmp
94 remote_file host delete ld.tmp
fab4a87f 95
7f6a71ff
JM
96 if [string match "" $link_output] then {
97 return ""
98 }
3e8cba19 99
7f6a71ff
JM
100 verbose -log "$link_output"
101 return "$link_output"
102}
103
104proc run_host_cmd_yesno { prog command } {
105 global exec_output
106
107 set exec_output [prune_warnings [run_host_cmd "$prog" "$command"]]
252b5132 108 if [string match "" $exec_output] then {
7f6a71ff 109 return 1;
252b5132 110 }
7f6a71ff
JM
111 return 0;
112}
113
114# Link an object using relocation.
115#
116proc default_ld_relocate { ld target objects } {
117 global HOSTING_EMU
118
119 remote_file host delete $target
120 return [run_host_cmd_yesno "$ld" "$HOSTING_EMU -o $target -r $objects"]
252b5132
RH
121}
122
1688b748 123# Check to see if ld is being invoked with a non-endian output format
3b6fe0cc 124#
1688b748
MH
125proc is_endian_output_format { object_flags } {
126
127 if {[string match "*-oformat binary*" $object_flags] || \
128 [string match "*-oformat ieee*" $object_flags] || \
129 [string match "*-oformat ihex*" $object_flags] || \
130 [string match "*-oformat netbsd-core*" $object_flags] || \
131 [string match "*-oformat srec*" $object_flags] || \
132 [string match "*-oformat tekhex*" $object_flags] || \
133 [string match "*-oformat trad-core*" $object_flags] } then {
134 return 0
135 } else {
136 return 1
137 }
138}
139
38e31547
NC
140# Look for big-endian or little-endian switches in the multlib
141# options and translate these into a -EB or -EL switch. Note
142# we cannot rely upon proc process_multilib_options to do this
143# for us because for some targets the compiler does not support
144# -EB/-EL but it does support -mbig-endian/-mlittle-endian, and
145# the site.exp file will include the switch "-mbig-endian"
146# (rather than "big-endian") which is not detected by proc
147# process_multilib_options.
3b6fe0cc 148#
38e31547 149proc big_or_little_endian {} {
3e8cba19 150
38e31547 151 if [board_info [target_info name] exists multilib_flags] {
b24f926d 152 set tmp_flags " [board_info [target_info name] multilib_flags]"
38e31547
NC
153
154 foreach x $tmp_flags {
155 case $x in {
906156c4 156 {*big*endian eb EB -eb -EB -mb -meb} {
38e31547
NC
157 set flags " -EB"
158 return $flags
159 }
906156c4 160 {*little*endian el EL -el -EL -ml -mel} {
38e31547
NC
161 set flags " -EL"
162 return $flags
163 }
164 }
165 }
166 }
167
168 set flags ""
169 return $flags
170}
252b5132 171
3b6fe0cc 172# Link a program using ld.
252b5132
RH
173#
174proc default_ld_link { ld target objects } {
175 global HOSTING_EMU
176 global HOSTING_CRT0
177 global HOSTING_LIBS
d1bcade6 178 global LIBS
252b5132 179 global host_triplet
6fc49d28 180 global link_output
fab4a87f 181 global exec_output
3e8cba19 182
252b5132 183 set objs "$HOSTING_CRT0 $objects"
d1bcade6 184 set libs "$LIBS $HOSTING_LIBS"
3e8cba19 185
1688b748
MH
186 if [is_endian_output_format $objects] then {
187 set flags [big_or_little_endian]
188 } else {
189 set flags ""
190 }
fab4a87f 191
7f6a71ff 192 remote_file host delete $target
fab4a87f 193
7f6a71ff 194 return [run_host_cmd_yesno "$ld" "$HOSTING_EMU $flags -o $target $objs $libs"]
252b5132
RH
195}
196
3b6fe0cc 197# Link a program using ld, without including any libraries.
252b5132
RH
198#
199proc default_ld_simple_link { ld target objects } {
200 global host_triplet
b765d4e3 201 global gcc_ld_flag
fab4a87f 202 global exec_output
7cda33a1 203
1688b748
MH
204 if [is_endian_output_format $objects] then {
205 set flags [big_or_little_endian]
206 } else {
207 set flags ""
208 }
3e8cba19 209
b765d4e3
L
210 # If we are compiling with gcc, we want to add gcc_ld_flag to
211 # flags. Rather than determine this in some complex way, we guess
212 # based on the name of the compiler.
b0fe1bf3
AM
213 set ldexe $ld
214 set ldparm [string first " " $ld]
cef3d14b 215 set ldflags ""
b0fe1bf3 216 if { $ldparm > 0 } then {
cef3d14b 217 set ldflags [string range $ld $ldparm end]
b0fe1bf3 218 set ldexe [string range $ld 0 $ldparm]
cef3d14b 219 set ld $ldexe
b0fe1bf3
AM
220 }
221 set ldexe [string replace $ldexe 0 [string last "/" $ldexe] ""]
0f84fde1 222 if {[string match "*gcc*" $ldexe] || [string match "*++*" $ldexe]} then {
cef3d14b 223 set ldflags "$gcc_ld_flag $ldflags"
b765d4e3
L
224 }
225
7f6a71ff 226 remote_file host delete $target
fab4a87f 227
cef3d14b 228 set exec_output [run_host_cmd "$ld" "$ldflags $flags -o $target $objects"]
7f6a71ff 229 set exec_output [prune_warnings $exec_output]
252b5132
RH
230
231 # We don't care if we get a warning about a non-existent start
232 # symbol, since the default linker script might use ENTRY.
233 regsub -all "(^|\n)(\[^\n\]*: warning: cannot find entry symbol\[^\n\]*\n?)" $exec_output "\\1" exec_output
234
235 if [string match "" $exec_output] then {
236 return 1
237 } else {
252b5132
RH
238 return 0
239 }
240}
241
3b6fe0cc 242# Compile an object using cc.
252b5132
RH
243#
244proc default_ld_compile { cc source object } {
245 global CFLAGS
58ffc3bd 246 global CXXFLAGS
252b5132
RH
247 global srcdir
248 global subdir
249 global host_triplet
250 global gcc_gas_flag
251
252 set cc_prog $cc
253 if {[llength $cc_prog] > 1} then {
254 set cc_prog [lindex $cc_prog 0]
255 }
7f6a71ff 256 if {![is_remote host] && [which $cc_prog] == 0} then {
252b5132
RH
257 perror "$cc_prog does not exist"
258 return 0
259 }
260
7f6a71ff
JM
261 remote_file build delete "$object"
262 remote_file host delete "$object"
252b5132 263
58ffc3bd 264 set flags "-I$srcdir/$subdir"
252b5132
RH
265
266 # If we are compiling with gcc, we want to add gcc_gas_flag to
267 # flags. Rather than determine this in some complex way, we guess
268 # based on the name of the compiler.
b0fe1bf3
AM
269 set ccexe $cc
270 set ccparm [string first " " $cc]
dec20c9e 271 set ccflags ""
b0fe1bf3 272 if { $ccparm > 0 } then {
dec20c9e 273 set ccflags [string range $cc $ccparm end]
b0fe1bf3 274 set ccexe [string range $cc 0 $ccparm]
dec20c9e 275 set cc $ccexe
b0fe1bf3
AM
276 }
277 set ccexe [string replace $ccexe 0 [string last "/" $ccexe] ""]
0f84fde1 278 if {[string match "*gcc*" $ccexe] || [string match "*++*" $ccexe]} then {
252b5132
RH
279 set flags "$gcc_gas_flag $flags"
280 }
281
58ffc3bd
MF
282 if {[string match "*++*" $ccexe]} {
283 set flags "$flags $CXXFLAGS"
284 } else {
285 set flags "$flags $CFLAGS"
286 }
287
38e31547 288 if [board_info [target_info name] exists multilib_flags] {
b24f926d 289 append flags " [board_info [target_info name] multilib_flags]"
38e31547
NC
290 }
291
dec20c9e 292 verbose -log "$cc $flags $ccflags -c $source -o $object"
252b5132 293
7f6a71ff
JM
294 set status [remote_exec host [concat sh -c [list "$cc $flags $ccflags -c $source -o $object 2>&1"]] "" "/dev/null" "ld.tmp"]
295 remote_upload host "ld.tmp"
296 set exec_output [file_contents "ld.tmp"]
297 remote_file build delete "ld.tmp"
298 remote_file host delete "ld.tmp"
252b5132
RH
299 set exec_output [prune_warnings $exec_output]
300 if [string match "" $exec_output] then {
301 if {![file exists $object]} then {
302 regexp ".*/(\[^/\]*)$" $source all dobj
303 regsub "\\.c" $dobj ".o" realobj
304 verbose "looking for $realobj"
7f6a71ff 305 if {[remote_file host exists $realobj]} then {
252b5132 306 verbose -log "mv $realobj $object"
7f6a71ff 307 remote_upload "$realobj" "$object"
252b5132
RH
308 } else {
309 perror "$object not found after compilation"
310 return 0
311 }
312 }
313 return 1
314 } else {
315 verbose -log "$exec_output"
316 perror "$source: compilation failed"
317 return 0
318 }
319}
320
3b6fe0cc 321# Assemble a file.
252b5132 322#
de1491f0 323proc default_ld_assemble { as in_flags source object } {
252b5132
RH
324 global ASFLAGS
325 global host_triplet
3e8cba19 326
252b5132
RH
327 if ![info exists ASFLAGS] { set ASFLAGS "" }
328
38e31547 329 set flags [big_or_little_endian]
de1491f0 330 set exec_output [run_host_cmd "$as" "$flags $in_flags $ASFLAGS -o $object $source"]
252b5132
RH
331 set exec_output [prune_warnings $exec_output]
332 if [string match "" $exec_output] then {
333 return 1
334 } else {
252b5132
RH
335 perror "$source: assembly failed"
336 return 0
337 }
338}
339
3b6fe0cc 340# Run nm on a file, putting the result in the array nm_output.
252b5132 341#
992c450d 342proc default_ld_nm { nm nmflags object } {
252b5132
RH
343 global NMFLAGS
344 global nm_output
345 global host_triplet
346
77e0b0ef
ILT
347 if {[info exists nm_output]} {
348 unset nm_output
349 }
350
252b5132
RH
351 if ![info exists NMFLAGS] { set NMFLAGS "" }
352
3e8cba19
AM
353 # Ensure consistent sorting of symbols
354 if {[info exists env(LC_ALL)]} {
355 set old_lc_all $env(LC_ALL)
356 }
357 set env(LC_ALL) "C"
7f6a71ff 358
992c450d 359 verbose -log "$nm $NMFLAGS $nmflags $object >tmpdir/nm.out"
252b5132 360
7f6a71ff 361 set status [remote_exec host [concat sh -c [list "$nm $NMFLAGS $nmflags $object 2>ld.stderr"]] "" "/dev/null" "tmpdir/nm.out"]
3e8cba19
AM
362 if {[info exists old_lc_all]} {
363 set env(LC_ALL) $old_lc_all
364 } else {
365 unset env(LC_ALL)
366 }
7f6a71ff
JM
367 remote_upload host "ld.stderr"
368 remote_upload host "tmpdir/nm.out" "tmpdir/nm.out"
369 set exec_output [prune_warnings [file_contents "ld.stderr"]]
370 remote_file host delete "ld.stderr"
371 remote_file build delete "ld.stderr"
252b5132
RH
372 if [string match "" $exec_output] then {
373 set file [open tmpdir/nm.out r]
374 while { [gets $file line] != -1 } {
375 verbose "$line" 2
dbc37f89 376 if [regexp "^(\[0-9a-fA-F\]+) \[a-zA-Z0-9\] \\.*(.+)$" $line whole value name] {
252b5132
RH
377 set name [string trimleft $name "_"]
378 verbose "Setting nm_output($name) to 0x$value" 2
379 set nm_output($name) 0x$value
380 }
381 }
382 close $file
383 return 1
384 } else {
385 verbose -log "$exec_output"
386 perror "$object: nm failed"
387 return 0
388 }
389}
390
1b662205
AM
391# Define various symbols needed when not linking against all
392# target libs.
393proc ld_simple_link_defsyms {} {
394
395 set flags "--defsym __stack_chk_fail=0"
396
397 # ARM targets call __gccmain
8c5fc800 398 if {[istarget arm*-*-*]} {
1b662205
AM
399 append flags " --defsym __gccmain=0"
400 }
401
36fe835f
DK
402 # Windows targets need __main, prefixed with underscore.
403 if {[istarget *-*-cygwin* ] || [istarget *-*-mingw*]} {
404 append flags " --defsym ___main=0"
405 }
406
1b662205
AM
407 # PowerPC EABI code calls __eabi.
408 if {[istarget powerpc*-*-eabi*] || [istarget powerpc*-*-rtems*]} {
409 append flags " --defsym __eabi=0"
410 }
411
412 # mn10200 code calls __truncsipsi2_d0_d2.
413 if {[istarget mn10200*-*-*]} then {
414 append flags " --defsym __truncsipsi2_d0_d2=0"
415 }
416
417 # m6811/m6812 code has references to soft registers.
32d79e68 418 if {[istarget m6811-*-*] || [istarget m6812-*-*] || [istarget m68hc1*-*-*]} {
1b662205
AM
419 append flags " --defsym _.frame=0 --defsym _.d1=0 --defsym _.d2=0"
420 append flags " --defsym _.d3=0 --defsym _.d4=0"
421 append flags " --defsym _.tmp=0 --defsym _.xy=0 --defsym _.z=0"
422 }
423
424 # Some OpenBSD targets have ProPolice and reference __guard and
425 # __stack_smash_handler.
426 if [istarget *-*-openbsd*] {
427 append flags " --defsym __guard=0"
428 append flags " --defsym __stack_smash_handler=0"
429 }
430
431 return $flags
432}
433
3e8cba19 434# run_dump_test FILE
261def70
HPN
435# Copied from gas testsuite, tweaked and further extended.
436#
437# Assemble a .s file, then run some utility on it and check the output.
3e8cba19 438#
261def70
HPN
439# There should be an assembly language file named FILE.s in the test
440# suite directory, and a pattern file called FILE.d. `run_dump_test'
441# will assemble FILE.s, run some tool like `objdump', `objcopy', or
442# `nm' on the .o file to produce textual output, and then analyze that
443# with regexps. The FILE.d file specifies what program to run, and
444# what to expect in its output.
445#
446# The FILE.d file begins with zero or more option lines, which specify
447# flags to pass to the assembler, the program to run to dump the
448# assembler's output, and the options it wants. The option lines have
449# the syntax:
3e8cba19 450#
261def70 451# # OPTION: VALUE
3e8cba19 452#
261def70
HPN
453# OPTION is the name of some option, like "name" or "objdump", and
454# VALUE is OPTION's value. The valid options are described below.
455# Whitespace is ignored everywhere, except within VALUE. The option
456# list ends with the first line that doesn't match the above syntax
457# (hmm, not great for error detection).
458#
459# The interesting options are:
3e8cba19 460#
261def70
HPN
461# name: TEST-NAME
462# The name of this test, passed to DejaGNU's `pass' and `fail'
463# commands. If omitted, this defaults to FILE, the root of the
464# .s and .d files' names.
3e8cba19 465#
261def70
HPN
466# as: FLAGS
467# When assembling, pass FLAGS to the assembler.
468# If assembling several files, you can pass different assembler
469# options in the "source" directives. See below.
470#
471# ld: FLAGS
472# Link assembled files using FLAGS, in the order of the "source"
473# directives, when using multiple files.
474#
d6e0b160
HPN
475# ld_after_inputfiles: FLAGS
476# Similar to "ld", but put after all input files.
477#
cfe5266f
HPN
478# objcopy_linked_file: FLAGS
479# Run objcopy on the linked file with the specified flags.
480# This lets you transform the linked file using objcopy, before the
481# result is analyzed by an analyzer program specified below (which
482# may in turn *also* be objcopy).
483#
261def70
HPN
484# PROG: PROGRAM-NAME
485# The name of the program to run to analyze the .o file produced
486# by the assembler or the linker output. This can be omitted;
487# run_dump_test will guess which program to run by seeing which of
488# the flags options below is present.
489#
490# objdump: FLAGS
491# nm: FLAGS
492# objcopy: FLAGS
493# Use the specified program to analyze the assembler or linker
494# output file, and pass it FLAGS, in addition to the output name.
3e8cba19
AM
495# Note that they are run with LC_ALL=C in the environment to give
496# consistent sorting of symbols.
261def70
HPN
497#
498# source: SOURCE [FLAGS]
499# Assemble the file SOURCE.s using the flags in the "as" directive
500# and the (optional) FLAGS. If omitted, the source defaults to
501# FILE.s.
502# This is useful if several .d files want to share a .s file.
503# More than one "source" directive can be given, which is useful
504# when testing linking.
505#
506# xfail: TARGET
507# The test is expected to fail on TARGET. This may occur more than
508# once.
509#
510# target: TARGET
511# Only run the test for TARGET. This may occur more than once; the
33aa234e
JK
512# target being tested must match at least one. You may provide target
513# name "cfi" for any target supporting the CFI statements.
261def70
HPN
514#
515# notarget: TARGET
516# Do not run the test for TARGET. This may occur more than once;
517# the target being tested must not match any of them.
518#
519# error: REGEX
520# An error with message matching REGEX must be emitted for the test
521# to pass. The PROG, objdump, nm and objcopy options have no
164de317
HPN
522# meaning and need not supplied if this is present. Multiple "error"
523# directives append to the expected linker error message.
261def70 524#
bb00e284
HPN
525# warning: REGEX
526# Expect a linker warning matching REGEX. It is an error to issue
164de317
HPN
527# both "error" and "warning". Multiple "warning" directives
528# append to the expected linker warning message.
bb00e284 529#
261def70
HPN
530# Each option may occur at most once unless otherwise mentioned.
531#
532# After the option lines come regexp lines. `run_dump_test' calls
533# `regexp_diff' to compare the output of the dumping tool against the
eb22018c
RS
534# regexps in FILE.d. `regexp_diff' is defined in binutils-common.exp;
535# see further comments there.
3b6fe0cc 536#
261def70
HPN
537proc run_dump_test { name } {
538 global subdir srcdir
539 global OBJDUMP NM AS OBJCOPY READELF LD
540 global OBJDUMPFLAGS NMFLAGS ASFLAGS OBJCOPYFLAGS READELFFLAGS LDFLAGS
541 global host_triplet runtests
9a2ee7fc 542 global env verbose
261def70
HPN
543
544 if [string match "*/*" $name] {
545 set file $name
546 set name [file tail $name]
547 } else {
548 set file "$srcdir/$subdir/$name"
549 }
550
551 if ![runtest_file_p $runtests $name] then {
552 return
553 }
554
555 set opt_array [slurp_options "${file}.d"]
556 if { $opt_array == -1 } {
557 perror "error reading options from $file.d"
558 unresolved $subdir/$name
559 return
560 }
561 set dumpfile tmpdir/dump.out
562 set run_ld 0
cfe5266f 563 set run_objcopy 0
261def70
HPN
564 set opts(as) {}
565 set opts(ld) {}
d6e0b160 566 set opts(ld_after_inputfiles) {}
261def70
HPN
567 set opts(xfail) {}
568 set opts(target) {}
569 set opts(notarget) {}
570 set opts(objdump) {}
571 set opts(nm) {}
572 set opts(objcopy) {}
573 set opts(readelf) {}
574 set opts(name) {}
575 set opts(PROG) {}
576 set opts(source) {}
577 set opts(error) {}
bb00e284 578 set opts(warning) {}
cfe5266f 579 set opts(objcopy_linked_file) {}
261def70
HPN
580
581 foreach i $opt_array {
582 set opt_name [lindex $i 0]
583 set opt_val [lindex $i 1]
584 if ![info exists opts($opt_name)] {
585 perror "unknown option $opt_name in file $file.d"
586 unresolved $subdir/$name
587 return
588 }
589
590 switch -- $opt_name {
591 xfail {}
592 target {}
593 notarget {}
164de317
HPN
594 warning {}
595 error {}
261def70 596 source {
df58fc94 597 # Move any source-specific as-flags to a separate list to
261def70
HPN
598 # simplify processing.
599 if { [llength $opt_val] > 1 } {
df58fc94 600 lappend asflags [lrange $opt_val 1 end]
261def70
HPN
601 set opt_val [lindex $opt_val 0]
602 } else {
df58fc94 603 lappend asflags {}
261def70
HPN
604 }
605 }
606 default {
607 if [string length $opts($opt_name)] {
608 perror "option $opt_name multiply set in $file.d"
609 unresolved $subdir/$name
610 return
611 }
612
613 # A single "# ld:" with no options should do the right thing.
614 if { $opt_name == "ld" } {
615 set run_ld 1
616 }
cfe5266f
HPN
617 # Likewise objcopy_linked_file.
618 if { $opt_name == "objcopy_linked_file" } {
619 set run_objcopy 1
620 }
261def70
HPN
621 }
622 }
7f6a71ff
JM
623 if { $opt_name == "as" || $opt_name == "ld" } {
624 set opt_val [subst $opt_val]
625 }
261def70
HPN
626 set opts($opt_name) [concat $opts($opt_name) $opt_val]
627 }
3935e1af
RS
628 foreach opt { as ld } {
629 regsub {\[big_or_little_endian\]} $opts($opt) \
630 [big_or_little_endian] opts($opt)
631 }
261def70
HPN
632
633 # Decide early whether we should run the test for this target.
634 if { [llength $opts(target)] > 0 } {
635 set targmatch 0
636 foreach targ $opts(target) {
637 if [istarget $targ] {
638 set targmatch 1
639 break
640 }
641 }
642 if { $targmatch == 0 } {
643 return
644 }
645 }
646 foreach targ $opts(notarget) {
647 if [istarget $targ] {
648 return
649 }
650 }
651
f364d1ca
AM
652 set program ""
653 # It's meaningless to require an output-testing method when we
654 # expect an error.
655 if { $opts(error) == "" } {
656 if {$opts(PROG) != ""} {
657 switch -- $opts(PROG) {
658 objdump { set program objdump }
659 nm { set program nm }
660 objcopy { set program objcopy }
661 readelf { set program readelf }
662 default
261def70
HPN
663 { perror "unrecognized program option $opts(PROG) in $file.d"
664 unresolved $subdir/$name
665 return }
f364d1ca
AM
666 }
667 } else {
261def70 668 # Guess which program to run, by seeing which option was specified.
f364d1ca
AM
669 foreach p {objdump objcopy nm readelf} {
670 if {$opts($p) != ""} {
671 if {$program != ""} {
672 perror "ambiguous dump program in $file.d"
673 unresolved $subdir/$name
674 return
675 } else {
676 set program $p
677 }
261def70
HPN
678 }
679 }
680 }
f364d1ca 681 if { $program == "" && $opts(warning) == "" } {
261def70
HPN
682 perror "dump program unspecified in $file.d"
683 unresolved $subdir/$name
684 return
685 }
686 }
687
261def70
HPN
688 if { $opts(name) == "" } {
689 set testname "$subdir/$name"
690 } else {
691 set testname $opts(name)
692 }
693
694 if { $opts(source) == "" } {
695 set sourcefiles [list ${file}.s]
df58fc94 696 set asflags [list ""]
261def70
HPN
697 } else {
698 set sourcefiles {}
699 foreach sf $opts(source) {
b7b0b729
HPN
700 if { [string match "/*" $sf] } {
701 lappend sourcefiles "$sf"
f364d1ca 702 } else {
b7b0b729
HPN
703 lappend sourcefiles "$srcdir/$subdir/$sf"
704 }
261def70
HPN
705 }
706 }
707
708 # Time to setup xfailures.
709 foreach targ $opts(xfail) {
710 setup_xfail $targ
711 }
712
713 # Assemble each file.
714 set objfiles {}
715 for { set i 0 } { $i < [llength $sourcefiles] } { incr i } {
716 set sourcefile [lindex $sourcefiles $i]
df58fc94 717 set sourceasflags [lindex $asflags $i]
261def70
HPN
718
719 set objfile "tmpdir/dump$i.o"
30dabe8a 720 catch "exec rm -f $objfile" exec_output
261def70 721 lappend objfiles $objfile
df58fc94 722 set cmd "$AS $ASFLAGS $opts(as) $sourceasflags -o $objfile $sourcefile"
261def70
HPN
723
724 send_log "$cmd\n"
7f6a71ff
JM
725 set cmdret [remote_exec host [concat sh -c [list "$cmd 2>&1"]] "" "/dev/null" "ld.tmp"]
726 remote_upload host "ld.tmp"
727 set comp_output [prune_warnings [file_contents "ld.tmp"]]
728 remote_file host delete "ld.tmp"
729 remote_file build delete "ld.tmp"
261def70 730
7f6a71ff 731 if { [lindex $cmdret 0] != 0 || ![string match "" $comp_output] } then {
261def70
HPN
732 send_log "$comp_output\n"
733 verbose "$comp_output" 3
f364d1ca
AM
734
735 set exitstat "succeeded"
736 if { $cmdret != 0 } { set exitstat "failed" }
737 verbose -log "$exitstat with: <$comp_output>"
261def70
HPN
738 fail $testname
739 return
740 }
741 }
742
f364d1ca
AM
743 set expmsg $opts(error)
744 if { $opts(warning) != "" } {
745 if { $expmsg != "" } {
746 perror "$testname: mixing error and warning test-directives"
747 return
748 }
749 set expmsg $opts(warning)
750 }
751
261def70
HPN
752 # Perhaps link the file(s).
753 if { $run_ld } {
754 set objfile "tmpdir/dump"
30dabe8a 755 catch "exec rm -f $objfile" exec_output
3e3f011f
RS
756
757 # Add -L$srcdir/$subdir so that the linker command can use
758 # linker scripts in the source directory.
759 set cmd "$LD $LDFLAGS -L$srcdir/$subdir \
d6e0b160 760 $opts(ld) -o $objfile $objfiles $opts(ld_after_inputfiles)"
261def70
HPN
761
762 send_log "$cmd\n"
7f6a71ff
JM
763 set cmdret [remote_exec host [concat sh -c [list "$cmd 2>&1"]] "" "/dev/null" "ld.tmp"]
764 remote_upload host "ld.tmp"
d3746675 765 set comp_output [file_contents "ld.tmp"]
7f6a71ff
JM
766 remote_file host delete "ld.tmp"
767 remote_file build delete "ld.tmp"
768 set cmdret [lindex $cmdret 0]
cfe5266f 769
f364d1ca 770 if { $cmdret == 0 && $run_objcopy } {
cfe5266f
HPN
771 set infile $objfile
772 set objfile "tmpdir/dump1"
7f6a71ff 773 remote_file host delete $objfile
cfe5266f
HPN
774
775 # Note that we don't use OBJCOPYFLAGS here; any flags must be
776 # explicitly specified.
777 set cmd "$OBJCOPY $opts(objcopy_linked_file) $infile $objfile"
778
779 send_log "$cmd\n"
7f6a71ff
JM
780 set cmdret [remote_exec host [concat sh -c [list "$cmd 2>&1"]] "" "/dev/null" "ld.tmp"]
781 remote_upload host "ld.tmp"
d3746675 782 append comp_output [file_contents "ld.tmp"]
7f6a71ff
JM
783 remote_file host delete "ld.tmp"
784 remote_file build delete "ld.tmp"
785 set cmdret [lindex $cmdret 0]
f364d1ca
AM
786 }
787
7f6a71ff 788 regsub "\n$" $comp_output "" comp_output
f364d1ca
AM
789 if { $cmdret != 0 || $comp_output != "" || $expmsg != "" } then {
790 set exitstat "succeeded"
791 if { $cmdret != 0 } { set exitstat "failed" }
792 verbose -log "$exitstat with: <$comp_output>, expected: <$expmsg>"
793 send_log "$comp_output\n"
794 verbose "$comp_output" 3
795
164de317
HPN
796 if { ($expmsg == "") == ($comp_output == "") \
797 && [regexp $expmsg $comp_output] \
798 && (($cmdret == 0) == ($opts(error) == "")) } {
f364d1ca
AM
799 # We have the expected output from ld.
800 if { $opts(error) != "" || $program == "" } {
801 pass $testname
802 return
cfe5266f 803 }
f364d1ca
AM
804 } else {
805 verbose -log "$exitstat with: <$comp_output>, expected: <$expmsg>"
cfe5266f
HPN
806 fail $testname
807 return
808 }
809 }
261def70
HPN
810 } else {
811 set objfile "tmpdir/dump0.o"
812 }
813
814 # We must not have expected failure if we get here.
815 if { $opts(error) != "" } {
816 fail $testname
cfe5266f 817 return
261def70
HPN
818 }
819
f364d1ca
AM
820 set progopts1 $opts($program)
821 eval set progopts \$[string toupper $program]FLAGS
822 eval set binary \$[string toupper $program]
823
7f6a71ff 824 if { ![is_remote host] && [which $binary] == 0 } {
261def70
HPN
825 untested $testname
826 return
827 }
828
829 if { $progopts1 == "" } { set $progopts1 "-r" }
830 verbose "running $binary $progopts $progopts1" 3
831
832 # Objcopy, unlike the other two, won't send its output to stdout,
833 # so we have to run it specially.
3e8cba19 834 set cmd "$binary $progopts $progopts1 $objfile > $dumpfile"
261def70
HPN
835 if { $program == "objcopy" } {
836 set cmd "$binary $progopts $progopts1 $objfile $dumpfile"
3e8cba19
AM
837 }
838
839 # Ensure consistent sorting of symbols
840 if {[info exists env(LC_ALL)]} {
841 set old_lc_all $env(LC_ALL)
842 }
843 set env(LC_ALL) "C"
844 send_log "$cmd\n"
7f6a71ff 845 set cmdret [remote_exec host [concat sh -c [list "$cmd 2>ld.tmp"]] "" "/dev/null"]
164de317 846 set cmdret [lindex $cmdret 0]
7f6a71ff
JM
847 remote_upload host "ld.tmp"
848 set comp_output [prune_warnings [file_contents "ld.tmp"]]
849 remote_file host delete "ld.tmp"
850 remote_file build delete "ld.tmp"
3e8cba19
AM
851 if {[info exists old_lc_all]} {
852 set env(LC_ALL) $old_lc_all
261def70 853 } else {
3e8cba19
AM
854 unset env(LC_ALL)
855 }
164de317
HPN
856 if { $cmdret != 0 || $comp_output != "" } {
857 send_log "exited abnormally with $cmdret, output:$comp_output\n"
3e8cba19
AM
858 fail $testname
859 return
261def70
HPN
860 }
861
9a2ee7fc 862 if { $verbose > 2 } then { verbose "output is [file_contents $dumpfile]" 3 }
261def70
HPN
863 if { [regexp_diff $dumpfile "${file}.d"] } then {
864 fail $testname
9a2ee7fc 865 if { $verbose == 2 } then { verbose "output is [file_contents $dumpfile]" 2 }
261def70
HPN
866 return
867 }
868
869 pass $testname
870}
871
872proc slurp_options { file } {
5a68afcf
RM
873 # If options_regsub(foo) is set to {a b}, then the contents of a
874 # "#foo:" line will have regsub -all applied to replace a with b.
875 global options_regsub
876
261def70
HPN
877 if [catch { set f [open $file r] } x] {
878 #perror "couldn't open `$file': $x"
879 perror "$x"
880 return -1
881 }
882 set opt_array {}
883 # whitespace expression
884 set ws {[ ]*}
885 set nws {[^ ]*}
886 # whitespace is ignored anywhere except within the options list;
cfe5266f
HPN
887 # option names are alphabetic plus underscore only.
888 set pat "^#${ws}(\[a-zA-Z_\]*)$ws:${ws}(.*)$ws\$"
261def70
HPN
889 while { [gets $f line] != -1 } {
890 set line [string trim $line]
891 # Whitespace here is space-tab.
892 if [regexp $pat $line xxx opt_name opt_val] {
893 # match!
5a68afcf
RM
894 if [info exists options_regsub($opt_name)] {
895 set subst $options_regsub($opt_name)
896 regsub -all -- [lindex $subst 0] $opt_val [lindex $subst 1] \
897 opt_val
898 }
261def70
HPN
899 lappend opt_array [list $opt_name $opt_val]
900 } else {
901 break
902 }
903 }
904 close $f
905 return $opt_array
906}
907
261def70
HPN
908proc file_contents { filename } {
909 set file [open $filename r]
910 set contents [read $file]
911 close $file
912 return $contents
913}
bffbf940 914
5d3236ee
DK
915proc set_file_contents { filename contents } {
916 set file [open $filename w]
917 puts $file "$contents"
918 close $file
919}
920
d8880531
L
921# Create an archive using ar
922#
fa0a16b1 923proc ar_simple_create { ar aropts target objects } {
d8880531
L
924 remote_file host delete $target
925
fa0a16b1 926 set exec_output [run_host_cmd "$ar" "$aropts rc $target $objects"]
d8880531
L
927 set exec_output [prune_warnings $exec_output]
928
929 if [string match "" $exec_output] then {
930 send_log "$exec_output\n"
931 return 1
932 } else {
933 return 0
934 }
935}
936
9147e853
JJ
937# List contains test-items with 3 items followed by 2 lists, one item and
938# one optional item:
894891db
NC
939# 0:name
940# 1:ld/ar options
941# 2:assembler options
942# 3:filenames of assembler files
943# 4:list of actions, options and expected outputs.
944# 5:name of output file
945# 6:compiler flags (optional)
3b6fe0cc 946#
894891db
NC
947# Actions: { command command-line-options file-containg-expected-output-regexps }
948# Commands:
949# objdump: Apply objdump options on result.
950# nm: Apply nm options on result.
951# readelf: Apply readelf options on result.
5a68afcf 952# ld: Don't apply anything on result. Compare output during linking with
894891db
NC
953# the file containing regexps (which is the second arg, not the third).
954# Note that this *must* be the first action if it is to be used at all;
955# in all other cases, any output from the linker during linking is
956# treated as a sign of an error and FAILs the test.
3b6fe0cc 957#
bffbf940
JJ
958proc run_ld_link_tests { ldtests } {
959 global ld
960 global as
961 global nm
d8880531 962 global ar
bffbf940
JJ
963 global objdump
964 global READELF
965 global srcdir
966 global subdir
967 global env
9147e853
JJ
968 global CC
969 global CFLAGS
eca41774 970 global runtests
5d3236ee 971 global exec_output
bffbf940
JJ
972
973 foreach testitem $ldtests {
974 set testname [lindex $testitem 0]
eca41774
DK
975
976 if ![runtest_file_p $runtests $testname] then {
977 continue
978 }
979
bffbf940
JJ
980 set ld_options [lindex $testitem 1]
981 set as_options [lindex $testitem 2]
9147e853 982 set src_files [lindex $testitem 3]
bffbf940
JJ
983 set actions [lindex $testitem 4]
984 set binfile tmpdir/[lindex $testitem 5]
9147e853 985 set cflags [lindex $testitem 6]
bffbf940
JJ
986 set objfiles {}
987 set is_unresolved 0
988 set failed 0
5d3236ee
DK
989 set maybe_failed 0
990 set ld_output ""
bffbf940
JJ
991
992# verbose -log "Testname is $testname"
993# verbose -log "ld_options is $ld_options"
994# verbose -log "as_options is $as_options"
9147e853 995# verbose -log "src_files is $src_files"
bffbf940
JJ
996# verbose -log "actions is $actions"
997# verbose -log "binfile is $binfile"
998
999 # Assemble each file in the test.
9147e853 1000 foreach src_file $src_files {
74d44110
MR
1001 set fileroot "[file rootname [file tail $src_file]]"
1002 set objfile "tmpdir/$fileroot.o"
bffbf940
JJ
1003 lappend objfiles $objfile
1004
9147e853 1005 if { [file extension $src_file] == ".c" } {
74d44110 1006 set as_file "tmpdir/$fileroot.s"
9147e853
JJ
1007 if ![ld_compile "$CC -S $CFLAGS $cflags" $srcdir/$subdir/$src_file $as_file] {
1008 set is_unresolved 1
1009 break
1010 }
1011 } else {
1012 set as_file "$srcdir/$subdir/$src_file"
1013 }
1014 if ![ld_assemble $as "$as_options $as_file" $objfile] {
bffbf940
JJ
1015 set is_unresolved 1
1016 break
1017 }
1018 }
1019
1020 # Catch assembler errors.
77c56f44 1021 if { $is_unresolved } {
bffbf940
JJ
1022 unresolved $testname
1023 continue
1024 }
1025
a7470592 1026 if { [regexp ".*\\.a$" $binfile] } {
fa0a16b1 1027 if { ![ar_simple_create $ar $ld_options $binfile "$objfiles"] } {
d8880531 1028 set failed 1
d8880531 1029 }
fa0a16b1 1030 } elseif { ![ld_simple_link $ld $binfile "-L$srcdir/$subdir $ld_options $objfiles"] } {
5d3236ee
DK
1031 set maybe_failed 1
1032 set ld_output "$exec_output"
d8880531
L
1033 }
1034
77c56f44 1035 if { !$failed } {
bffbf940
JJ
1036 foreach actionlist $actions {
1037 set action [lindex $actionlist 0]
1038 set progopts [lindex $actionlist 1]
1039
1040 # There are actions where we run regexp_diff on the
1041 # output, and there are other actions (presumably).
1042 # Handling of the former look the same.
1043 set dump_prog ""
1044 switch -- $action {
1045 objdump
1046 { set dump_prog $objdump }
1047 nm
1048 { set dump_prog $nm }
1049 readelf
1050 { set dump_prog $READELF }
5d3236ee
DK
1051 ld
1052 { set dump_prog "ld" }
bffbf940
JJ
1053 default
1054 {
1055 perror "Unrecognized action $action"
1056 set is_unresolved 1
1057 break
1058 }
1059 }
1060
5d3236ee 1061 if { $action == "ld" } {
894891db
NC
1062 set regexpfile $progopts
1063 verbose "regexpfile is $srcdir/$subdir/$regexpfile"
5d3236ee
DK
1064 set_file_contents "tmpdir/ld.messages" "$ld_output"
1065 verbose "ld.messages has '[file_contents tmpdir/ld.messages]'"
894891db 1066 if { [regexp_diff "tmpdir/ld.messages" "$srcdir/$subdir/$regexpfile"] } then {
5d3236ee
DK
1067 verbose "output is $ld_output" 2
1068 set failed 1
1069 break
1070 }
1071 set maybe_failed 0
77c56f44 1072 } elseif { !$maybe_failed && $dump_prog != "" } {
bffbf940
JJ
1073 set dumpfile [lindex $actionlist 2]
1074 set binary $dump_prog
1075
1076 # Ensure consistent sorting of symbols
1077 if {[info exists env(LC_ALL)]} {
1078 set old_lc_all $env(LC_ALL)
1079 }
1080 set env(LC_ALL) "C"
7f6a71ff
JM
1081 set cmd "$binary $progopts $binfile"
1082 set status [remote_exec host [concat sh -c [list "$cmd >dump.out 2>ld.stderr"]] "" "/dev/null"]
bffbf940 1083 send_log "$cmd\n"
7f6a71ff
JM
1084 remote_upload host "ld.stderr"
1085 set comp_output [prune_warnings [file_contents "ld.stderr"]]
1086 remote_file host delete "ld.stderr"
1087 remote_file build delete "ld.stderr"
5a68afcf 1088
bffbf940
JJ
1089 if {[info exists old_lc_all]} {
1090 set env(LC_ALL) $old_lc_all
1091 } else {
1092 unset env(LC_ALL)
1093 }
bffbf940
JJ
1094
1095 if ![string match "" $comp_output] then {
1096 send_log "$comp_output\n"
1097 set failed 1
1098 break
1099 }
1100
7f6a71ff
JM
1101 remote_upload host "dump.out"
1102
bffbf940
JJ
1103 if { [regexp_diff "dump.out" "$srcdir/$subdir/$dumpfile"] } then {
1104 verbose "output is [file_contents "dump.out"]" 2
1105 set failed 1
7f6a71ff
JM
1106 remote_file build delete "dump.out"
1107 remote_file host delete "dump.out"
bffbf940
JJ
1108 break
1109 }
7f6a71ff
JM
1110 remote_file build delete "dump.out"
1111 remote_file host delete "dump.out"
bffbf940
JJ
1112 }
1113 }
bffbf940
JJ
1114 }
1115
77c56f44 1116 if { $is_unresolved } {
bffbf940 1117 unresolved $testname
77c56f44
RS
1118 } elseif { $maybe_failed || $failed } {
1119 fail $testname
1120 } else {
1121 pass $testname
bffbf940
JJ
1122 }
1123 }
1124}
1125
252b5132
RH
1126# This definition is taken from an unreleased version of DejaGnu. Once
1127# that version gets released, and has been out in the world for a few
1128# months at least, it may be safe to delete this copy.
1129if ![string length [info proc prune_warnings]] {
1130 #
1131 # prune_warnings -- delete various system verbosities from TEXT
1132 #
1133 # An example is:
1134 # ld.so: warning: /usr/lib/libc.so.1.8.1 has older revision than expected 9
1135 #
1136 # Sites with particular verbose os's may wish to override this in site.exp.
1137 #
1138 proc prune_warnings { text } {
1139 # This is from sun4's. Do it for all machines for now.
1140 # The "\\1" is to try to preserve a "\n" but only if necessary.
1141 regsub -all "(^|\n)(ld.so: warning:\[^\n\]*\n?)+" $text "\\1" text
1142
1143 # It might be tempting to get carried away and delete blank lines, etc.
1144 # Just delete *exactly* what we're ask to, and that's it.
1145 return $text
1146 }
1147}
24edc24d 1148
c8c140d9
BE
1149# targets_to_xfail is a list of target triplets to be xfailed.
1150# ldtests contains test-items with 3 items followed by 1 lists, 2 items
fab4a87f 1151# and 3 optional items:
c8c140d9
BE
1152# 0:name
1153# 1:ld options
1154# 2:assembler options
55255dae 1155# 3:filenames of source files
c8c140d9
BE
1156# 4:name of output file
1157# 5:expected output
1158# 6:compiler flags (optional)
55255dae 1159# 7:language (optional)
fab4a87f 1160# 8:linker warning (optional)
c8c140d9
BE
1161
1162proc run_ld_link_exec_tests { targets_to_xfail ldtests } {
24edc24d
L
1163 global ld
1164 global as
1165 global srcdir
1166 global subdir
1167 global env
1168 global CC
55255dae 1169 global CXX
24edc24d 1170 global CFLAGS
58ffc3bd 1171 global CXXFLAGS
22ec3bd1 1172 global errcnt
fab4a87f 1173 global exec_output
24edc24d
L
1174
1175 foreach testitem $ldtests {
c8c140d9
BE
1176 foreach target $targets_to_xfail {
1177 setup_xfail $target
1178 }
24edc24d
L
1179 set testname [lindex $testitem 0]
1180 set ld_options [lindex $testitem 1]
1181 set as_options [lindex $testitem 2]
1182 set src_files [lindex $testitem 3]
1183 set binfile tmpdir/[lindex $testitem 4]
1184 set expfile [lindex $testitem 5]
1185 set cflags [lindex $testitem 6]
55255dae 1186 set lang [lindex $testitem 7]
fab4a87f 1187 set warning [lindex $testitem 8]
24edc24d 1188 set objfiles {}
24edc24d
L
1189 set failed 0
1190
1191# verbose -log "Testname is $testname"
1192# verbose -log "ld_options is $ld_options"
1193# verbose -log "as_options is $as_options"
1194# verbose -log "src_files is $src_files"
1195# verbose -log "actions is $actions"
1196# verbose -log "binfile is $binfile"
1197
1198 # Assemble each file in the test.
1199 foreach src_file $src_files {
74d44110
MR
1200 set fileroot "[file rootname [file tail $src_file]]"
1201 set objfile "tmpdir/$fileroot.o"
24edc24d
L
1202 lappend objfiles $objfile
1203
a10e6b21
L
1204 # We ignore warnings since some compilers may generate
1205 # incorrect section attributes and the assembler will warn
1206 # them.
58ffc3bd
MF
1207 if { [ string match "c++" $lang ] } {
1208 ld_compile "$CXX -c $CXXFLAGS $cflags" $srcdir/$subdir/$src_file $objfile
1209 } else {
1210 ld_compile "$CC -c $CFLAGS $cflags" $srcdir/$subdir/$src_file $objfile
1211 }
a10e6b21
L
1212
1213 # We have to use $CC to build PIE and shared library.
55255dae
L
1214 if { [ string match "c" $lang ] } {
1215 set link_proc ld_simple_link
1216 set link_cmd $CC
1217 } elseif { [ string match "c++" $lang ] } {
1218 set link_proc ld_simple_link
1219 set link_cmd $CXX
1220 } elseif { [ string match "-shared" $ld_options ] \
a10e6b21
L
1221 || [ string match "-pie" $ld_options ] } {
1222 set link_proc ld_simple_link
1223 set link_cmd $CC
1224 } else {
1225 set link_proc ld_link
1226 set link_cmd $ld
1227 }
24edc24d 1228
a10e6b21 1229 if ![$link_proc $link_cmd $binfile "-L$srcdir/$subdir $ld_options $objfiles"] {
24edc24d
L
1230 set failed 1
1231 } else {
a10e6b21 1232 set failed 0
fab4a87f
L
1233 }
1234
1235 # Check if exec_output is expected.
1236 if { $warning != "" } then {
1237 verbose -log "returned with: <$exec_output>, expected: <$warning>"
1238 if { [regexp $warning $exec_output] } then {
1239 set failed 0
1240 } else {
1241 set failed 1
1242 }
1243 }
1244
1245 if { $failed == 0 } {
a10e6b21
L
1246 send_log "Running: $binfile > $binfile.out\n"
1247 verbose "Running: $binfile > $binfile.out"
1248 catch "exec $binfile > $binfile.out" exec_output
5a68afcf 1249
24edc24d
L
1250 if ![string match "" $exec_output] then {
1251 send_log "$exec_output\n"
1252 verbose "$exec_output" 1
1253 set failed 1
a10e6b21
L
1254 } else {
1255 send_log "diff $binfile.out $srcdir/$subdir/$expfile\n"
1256 verbose "diff $binfile.out $srcdir/$subdir/$expfile"
1257 catch "exec diff $binfile.out $srcdir/$subdir/$expfile" exec_output
1258 set exec_output [prune_warnings $exec_output]
1259
1260 if ![string match "" $exec_output] then {
1261 send_log "$exec_output\n"
1262 verbose "$exec_output" 1
1263 set failed 1
1264 }
24edc24d
L
1265 }
1266 }
1267
1268 if { $failed != 0 } {
1269 fail $testname
22ec3bd1
L
1270 } else {
1271 set errcnt 0
24edc24d 1272 pass $testname
a10e6b21 1273 }
24edc24d 1274 }
24edc24d
L
1275 }
1276}
d2dee3b2
L
1277
1278# List contains test-items with 3 items followed by 2 lists, one item and
1279# one optional item:
55255dae 1280# 0:name
fa0a16b1 1281# 1:ld or ar options
55255dae
L
1282# 2:compile options
1283# 3:filenames of source files
1284# 4:action and options.
1285# 5:name of output file
1286# 6:language (optional)
dd98f8d2 1287# 7:linker warnings (optional)
d2dee3b2
L
1288#
1289# Actions:
1290# objdump: Apply objdump options on result. Compare with regex (last arg).
1291# nm: Apply nm options on result. Compare with regex (last arg).
1292# readelf: Apply readelf options on result. Compare with regex (last arg).
1293#
1294proc run_cc_link_tests { ldtests } {
1295 global nm
1296 global objdump
1297 global READELF
1298 global srcdir
1299 global subdir
1300 global env
1301 global CC
55255dae 1302 global CXX
d2dee3b2 1303 global CFLAGS
58ffc3bd 1304 global CXXFLAGS
d8880531 1305 global ar
dd98f8d2 1306 global exec_output
d2dee3b2
L
1307
1308 foreach testitem $ldtests {
1309 set testname [lindex $testitem 0]
1310 set ldflags [lindex $testitem 1]
1311 set cflags [lindex $testitem 2]
1312 set src_files [lindex $testitem 3]
1313 set actions [lindex $testitem 4]
1314 set binfile tmpdir/[lindex $testitem 5]
55255dae 1315 set lang [lindex $testitem 6]
dd98f8d2 1316 set warnings [lindex $testitem 7]
d2dee3b2
L
1317 set objfiles {}
1318 set is_unresolved 0
1319 set failed 0
1320
1321 # Compile each file in the test.
1322 foreach src_file $src_files {
74d44110
MR
1323 set fileroot "[file rootname [file tail $src_file]]"
1324 set objfile "tmpdir/$fileroot.o"
d2dee3b2
L
1325 lappend objfiles $objfile
1326
1327 # We ignore warnings since some compilers may generate
1328 # incorrect section attributes and the assembler will warn
1329 # them.
58ffc3bd
MF
1330 if { [ string match "c++" $lang ] } {
1331 ld_compile "$CXX -c $CXXFLAGS $cflags" $srcdir/$subdir/$src_file $objfile
1332 } else {
1333 ld_compile "$CC -c $CFLAGS $cflags" $srcdir/$subdir/$src_file $objfile
1334 }
d2dee3b2
L
1335 }
1336
1337 # Clear error and warning counts.
1338 reset_vars
1339
55255dae
L
1340 if { [ string match "c++" $lang ] } {
1341 set cc_cmd $CXX
1342 } else {
1343 set cc_cmd $CC
1344 }
1345
a7470592 1346 if { [regexp ".*\\.a$" $binfile] } {
fa0a16b1 1347 if { ![ar_simple_create $ar $ldflags $binfile "$objfiles"] } {
d8880531
L
1348 fail $testname
1349 set failed 1
1350 } else {
1351 set failed 0
1352 }
fa0a16b1 1353 } elseif { ![ld_simple_link $cc_cmd $binfile "-L$srcdir/$subdir $ldflags $objfiles"] } {
dd98f8d2
NC
1354 # Check if exec_output is expected.
1355 if { $warnings != "" } then {
1356 verbose -log "returned with: <$exec_output>, expected: <$warnings>"
1357 if { [regexp $warnings $exec_output] } then {
1358 set failed 0
1359 } else {
1360 set failed 1
1361 }
1362 } else {
1363 fail $testname
1364 set failed 1
1365 }
d2dee3b2
L
1366 } else {
1367 set failed 0
d8880531
L
1368 }
1369
1370 if { $failed == 0 } {
d2dee3b2
L
1371 foreach actionlist $actions {
1372 set action [lindex $actionlist 0]
1373 set progopts [lindex $actionlist 1]
1374
1375 # There are actions where we run regexp_diff on the
1376 # output, and there are other actions (presumably).
1377 # Handling of the former look the same.
1378 set dump_prog ""
1379 switch -- $action {
1380 objdump
1381 { set dump_prog $objdump }
1382 nm
1383 { set dump_prog $nm }
1384 readelf
1385 { set dump_prog $READELF }
1386 default
1387 {
1388 perror "Unrecognized action $action"
1389 set is_unresolved 1
1390 break
1391 }
1392 }
1393
1394 if { $dump_prog != "" } {
1395 set dumpfile [lindex $actionlist 2]
1396 set binary $dump_prog
1397
1398 # Ensure consistent sorting of symbols
1399 if {[info exists env(LC_ALL)]} {
1400 set old_lc_all $env(LC_ALL)
1401 }
1402 set env(LC_ALL) "C"
1403 set cmd "$binary $progopts $binfile > dump.out"
1404 send_log "$cmd\n"
1405 catch "exec $cmd" comp_output
1406 if {[info exists old_lc_all]} {
1407 set env(LC_ALL) $old_lc_all
1408 } else {
1409 unset env(LC_ALL)
1410 }
1411 set comp_output [prune_warnings $comp_output]
1412
1413 if ![string match "" $comp_output] then {
1414 send_log "$comp_output\n"
1415 set failed 1
1416 break
1417 }
1418
1419 if { [regexp_diff "dump.out" "$srcdir/$subdir/$dumpfile"] } then {
1420 verbose "output is [file_contents "dump.out"]" 2
1421 set failed 1
1422 break
1423 }
1424 }
1425 }
1426
1427 if { $failed != 0 } {
1428 fail $testname
1429 } else { if { $is_unresolved == 0 } {
1430 pass $testname
1431 } }
1432 }
1433
1434 # Catch action errors.
1435 if { $is_unresolved != 0 } {
1436 unresolved $testname
1437 continue
1438 }
1439 }
1440}
430a16a5
NC
1441
1442# Returns true if --gc-sections is supported on the target.
1443
1444proc check_gc_sections_available { } {
1445 global gc_sections_available_saved
1446 global ld
5a68afcf 1447
430a16a5
NC
1448 if {![info exists gc_sections_available_saved]} {
1449 # Some targets don't support gc-sections despite whatever's
1450 # advertised by ld's options.
de5c4ae2
AM
1451 if {[istarget arc-*-*]
1452 || [istarget d30v-*-*]
1453 || [istarget dlx-*-*]
1454 || [istarget i960-*-*]
1455 || [istarget or32-*-*]
1456 || [istarget pj*-*-*]
1457 || [istarget alpha-*-*]
1d5316ab 1458 || [istarget hppa*64-*-*]
de5c4ae2
AM
1459 || [istarget i370-*-*]
1460 || [istarget i860-*-*]
5a7c5e86 1461 || [istarget ia64-*-*]
de5c4ae2
AM
1462 || [istarget mep-*-*]
1463 || [istarget mn10200-*-*]
b1435da1 1464 || [istarget *-*-cygwin]
5a7c5e86 1465 || [istarget *-*-mingw*] } {
430a16a5
NC
1466 set gc_sections_available_saved 0
1467 return 0
1468 }
1469
1470 # elf2flt uses -q (--emit-relocs), which is incompatible with
1471 # --gc-sections.
1472 if { [board_info target exists ldflags]
1473 && [regexp " -elf2flt\[ =\]" " [board_info target ldflags] "] } {
1474 set gc_sections_available_saved 0
1475 return 0
1476 }
1477
430a16a5 1478 # Check if the ld used by gcc supports --gc-sections.
1d5316ab
AM
1479 # FIXME: this test is useless since ld --help always says
1480 # --gc-sections is available
430a16a5
NC
1481 set ld_output [remote_exec host $ld "--help"]
1482 if { [ string first "--gc-sections" $ld_output ] >= 0 } {
1483 set gc_sections_available_saved 1
1484 } else {
1485 set gc_sections_available_saved 0
1486 }
1487 }
1488 return $gc_sections_available_saved
1489}
33aa234e 1490
1d5316ab
AM
1491# Returns true if -shared is supported on the target
1492# Only used and accurate for ELF targets at the moment
1493
1494proc check_shared_lib_support { } {
1495 if {![istarget arc-*-*]
1496 && ![istarget avr-*-*]
1497 && ![istarget cr16-*-*]
1498 && ![istarget cris*-*-*]
1499 && ![istarget crx-*-*]
1500 && ![istarget d10v-*-*]
1501 && ![istarget d30v-*-*]
1502 && ![istarget dlx-*-*]
cfb8c092 1503 && ![istarget epiphany-*-*]
1d5316ab
AM
1504 && ![istarget fr30-*-*]
1505 && ![istarget frv-*-*]
1506 && ![istarget h8300-*-*]
1507 && ![istarget i860-*-*]
1508 && ![istarget i960-*-*]
1509 && ![istarget ip2k-*-*]
1510 && ![istarget iq2000-*-*]
1511 && ![istarget lm32-*-*]
1512 && ![istarget m32c-*-*]
1513 && ![istarget m32r-*-*]
32d79e68
AM
1514 && ![istarget m6811-*-*]
1515 && ![istarget m6812-*-*]
1d5316ab
AM
1516 && ![istarget m68hc1*-*-*]
1517 && ![istarget mcore*-*-*]
1518 && ![istarget mep-*-*]
1519 && ![istarget microblaze-*-*]
1520 && ![istarget mn10200-*-*]
1521 && ![istarget moxie-*-*]
1522 && ![istarget msp430-*-*]
1523 && ![istarget mt-*-*]
1524 && ![istarget openrisc-*-*]
1525 && ![istarget or32-*-*]
1526 && ![istarget pj-*-*]
1527 && ![istarget rx-*-*]
1528 && ![istarget spu-*-*]
1529 && ![istarget v850*-*-*]
1530 && ![istarget xstormy16-*-*]
1531 && ![istarget *-*-irix*]
1532 && ![istarget *-*-rtems] } {
1533 return 1
1534 }
1535 return 0
1536}
1537
5d3236ee
DK
1538# Returns true if the target ld supports the plugin API.
1539proc check_plugin_api_available { } {
1540 global plugin_api_available_saved
1541 global ld
1542 if {![info exists plugin_api_available_saved]} {
1543 # Check if the ld used by gcc supports --plugin.
1544 set ld_output [remote_exec host $ld "--help"]
1545 if { [ string first "-plugin" $ld_output ] >= 0 } {
1546 set plugin_api_available_saved 1
1547 } else {
1548 set plugin_api_available_saved 0
1549 }
1550 }
1551 return $plugin_api_available_saved
1552}
1553
33aa234e
JK
1554# Check if the assembler supports CFI statements.
1555
1556proc check_as_cfi { } {
1557 global check_as_cfi_result
1558 global as
1559 if [info exists check_as_cfi_result] {
1560 return $check_as_cfi_result
1561 }
1562 set as_file "tmpdir/check_as_cfi.s"
1563 set as_fh [open $as_file w 0666]
1564 puts $as_fh "# Generated file. DO NOT EDIT"
1565 puts $as_fh "\t.cfi_startproc"
1566 puts $as_fh "\t.cfi_endproc"
1567 close $as_fh
1568 remote_download host $as_file
1569 verbose -log "Checking CFI support:"
1570 rename "perror" "check_as_cfi_perror"
1571 proc perror { args } { }
1572 set success [ld_assemble $as $as_file "/dev/null"]
1573 rename "perror" ""
1574 rename "check_as_cfi_perror" "perror"
1575 #remote_file host delete $as_file
1576 set check_as_cfi_result $success
1577 return $success
1578}
1579
1580# Provide virtual target "cfi" for targets supporting CFI.
1581
1582rename "istarget" "istarget_ld"
1583proc istarget { target } {
1584 if {$target == "cfi"} {
1585 return [check_as_cfi]
1586 }
1587 return [istarget_ld $target]
1588}
This page took 0.633563 seconds and 4 git commands to generate.