1 # Expect script
for ld-sh tests
2 # Copyright
1995, 1996, 1997, 2001, 2002, 2003, 2007
3 # Free Software Foundation
, Inc.
5 # This file is part of the GNU Binutils.
7 # This
program is free software
; you can redistribute it and
/or modify
8 # it under the terms of the GNU General Public License as published by
9 # the Free Software Foundation
; either version
3 of the License
, or
10 #
(at your option
) any later version.
12 # This
program is distributed in the hope that it will be useful
,
13 # but WITHOUT
ANY WARRANTY
; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License
for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with this
program; if not
, write to the Free Software
19 # Foundation
, Inc.
, 51 Franklin Street
- Fifth Floor
, Boston
,
22 # Written by Ian Lance Taylor
(ian@cygnus.com
)
25 # Test SH relaxing. This tests the compiler and assembler as well as
28 if ![istarget sh
*-*-*] {
32 if { ([istarget sh64
*-*-*] ||
[istarget sh5
*-*-*])} {
33 # relaxing not supported
on sh64 yet.
37 set testsimple
"SH simple relaxing"
39 if ![ld_assemble $as
"-relax $srcdir/$subdir/sh1.s" tmpdir/sh1.o] {
40 unresolved $testsimple
41 } else { if ![ld_simple_link $
ld tmpdir
/sh1
"-relax tmpdir/sh1.o"] {
44 if ![ld_nm $nm
"" tmpdir/sh1] {
45 unresolved $testsimple
47 if {![info exists nm_output
(bar
)] \
48 ||
![info exists nm_output
(foo
)]} {
49 send_log
"bad output from nm\n"
50 verbose
"bad output from nm"
53 if {$nm_output
(bar
) != $nm_output
(foo
) + 4} {
54 send_log
"foo == $nm_output(foo)\n"
55 verbose
"foo == $nm_output(foo)"
56 send_log
"bar == $nm_output(bar)\n"
57 verbose
"bar == $nm_output(bar)"
66 set testsrec
"SH relaxing to S-records"
68 if { [istarget sh
*-linux
-*] ||
[istarget sh
-*-vxworks
] } {
69 #
On these
"non-embedded" targets, the default ELF and srec start
70 # addresses will be SIZEOF_HEADERS bytes apart. Ensure consistency
71 # by feeding the ELF start address to the srec link line.
72 catch
"exec $objdump -x tmpdir/sh1 | grep start\\ address | sed s/start\\ address//" entry_addr
73 set srec_relax_arg
"-Ttext $entry_addr -relax --oformat srec tmpdir/sh1.o"
75 set srec_relax_arg
"-relax --oformat srec tmpdir/sh1.o"
77 if ![ld_simple_link $
ld tmpdir
/sh1.s1 $srec_relax_arg
] {
80 # The file
name is embedded in the S
-records
, so create both
81 # files with the same
name.
82 catch
"exec rm -f tmpdir/sh1.s2" exec_output
83 send_log
"mv tmpdir/sh1.s1 tmpdir/sh1.s2\n"
84 verbose
"mv tmpdir/sh1.s1 tmpdir/sh1.s2"
85 catch
"exec mv tmpdir/sh1.s1 tmpdir/sh1.s2" exec_output
86 if ![string match
"" $exec_output] {
87 send_log
"$exec_output\n"
88 verbose
"$exec_output"
91 send_log
"$objcopy -O srec tmpdir/sh1 tmpdir/sh1.s1"
92 verbose
"$objcopy -O srec tmpdir/sh1 tmpdir/sh1.s1"
93 catch
"exec $objcopy -O srec tmpdir/sh1 tmpdir/sh1.s1" exec_output
94 if ![string match
"" $exec_output] {
95 send_log
"$exec_output\n"
96 verbose
"$exec_output"
99 send_log
"cmp tmpdir/sh1.s1 tmpdir/sh1.s2\n"
100 verbose
"cmp tmpdir/sh1.s1 tmpdir/sh1.s2"
101 catch
"exec cmp tmpdir/sh1.s1 tmpdir/sh1.s2" exec_output
102 set exec_output
[prune_warnings $exec_output
]
103 if ![string match
"" $exec_output] {
104 send_log
"$exec_output\n"
105 verbose
"$exec_output"
114 set testlink
"SH relaxing"
115 set testjsr
"SH confirm relaxing"
116 set testrun
"SH relaxing execution"
118 if { [which $CC
] == 0 } {
125 if [istarget sh
*-linux
-*] {
126 exec sed
-e s
/_main
/main
/ -e s
/_trap
/trap/ -e s
/_stack
/stack
/ \
127 < $srcdir
/$subdir
/start.s
>tmpdir
/start.s
129 exec cp $srcdir
/$subdir
/start.s tmpdir
/start.s
132 if {![ld_assemble $as
"-relax tmpdir/start.s" tmpdir/start.o] \
133 ||
![ld_compile $CC
"-O -mrelax $srcdir/$subdir/sh2.c" tmpdir/sh2.o]} {
140 if ![ld_simple_link $
ld tmpdir
/sh2
"-relax tmpdir/start.o tmpdir/sh2.o"] {
149 send_log
"$objdump -d tmpdir/sh2\n"
150 verbose
"$objdump -d tmpdir/sh2"
151 catch
"exec $objdump -d tmpdir/sh2" exec_output
152 if [string match
"*jsr*" $exec_output] {
158 if { ![info exists SIM
] ||
[which $SIM
] == 0 } {
163 set status [catch
"exec $SIM tmpdir/sh2" exec_output]
164 if { $
status == 0 } {