blob: 04f2749865abfffc05616293568fdf0bc1d6a641 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
|
#
# elf tests
#
proc run_elf_list_test { name suffix opts readelf_opts readelf_pipe } {
global READELF
global srcdir subdir
set testname "elf $name list"
set file $srcdir/$subdir/$name
gas_run ${name}.s "$opts -o dump.o" ">&dump.out"
if { ![string match "" $opts]
&& [regexp_diff "dump.out" "${file}.l" ""] } then {
fail $testname
verbose "output is [file_contents "dump.out"]" 2
return
}
send_log "$READELF $readelf_opts dump.o $readelf_pipe > dump.out\n"
set status [gas_host_run "$READELF $readelf_opts dump.o" ">readelf.out"]
if { [lindex $status 0] != 0 || ![string match "" [lindex $status 1]] } then {
send_log "[lindex $status 1]\n"
fail $testname
return
}
catch "exec cat readelf.out $readelf_pipe > dump.out\n" comp_output
if ![string match "" $comp_output] then {
send_log "$comp_output\n"
fail $testname
return
}
verbose_eval {[file_contents "dump.out"]} 3
if { [regexp_diff "dump.out" "${file}.e${suffix}" ""] } then {
fail $testname
verbose "output is [file_contents "dump.out"]" 2
return
}
pass $testname
}
# We're testing bits in obj-elf -- don't run on anything else.
if { ([istarget "*-*-*elf*"]
|| [istarget "*-*-linux*"]
|| [istarget "m6811-*"]
|| [istarget "m6812-*"]
|| [istarget "sparc*-*-solaris*"]
|| [istarget "mips*-*-irix6*"]
|| [istarget "arm*-*-eabi"])
&& ![istarget *-*-linux*aout*]
&& ![istarget *-*-linux*coff*]
&& ![istarget *-*-linux*oldld*]
&& ![istarget sh64*-*-linux*]
} then {
set target_machine ""
if {[istarget "mips*-*-*"]} then {
set target_machine -mips
}
if {[istarget m32r*-*-*]} then {
set target_machine -m32r
}
if {[istarget "score-*-*"]} then {
set target_machine -score
}
if {[istarget "tic6x-*-*"]} then {
set target_machine -tic6x
}
if {[istarget "xtensa*-*-*"]} then {
set target_machine -xtensa
}
if {[istarget "rx-*-*"]} then {
set target_machine -rx
}
if { ([istarget "*arm*-*-*"]
|| [istarget "xscale*-*-*"]) } {
if { ([istarget "*-*-*eabi"]
|| [istarget "*-*-linux-*"]
|| [istarget "*-*-symbianelf"])} then {
set target_machine -armeabi
} else {
set target_machine -armelf
}
}
# The MN10300 and Xtensa ports disable the assembler's call frame
# optimization because it interfers with link-time relaxation of
# function prologues.
if {![istarget "mn10300-*-*"]
&& ![istarget "xtensa*-*-*"]
&& ![istarget "am3*-*-*"]} then {
run_dump_test "ehopt0"
}
case $target_triplet in {
{ m68k-*-* m68[03]??-*-* } {
run_dump_test "file" { { as "--defsym m68k=1" } }
}
{ mmix-*-* } {
run_dump_test "file" { { as "--defsym mmix=1" } }
}
{ xtensa*-*-* } {
run_dump_test "file" { { as "--rename-section file.s=file.c" } }
}
default {
run_dump_test "file"
}
}
run_dump_test "group0a"
run_dump_test "group0b"
run_dump_test "group1a"
run_dump_test "group1b"
run_dump_test "groupautoa"
run_dump_test "groupautob"
case $target_triplet in {
{ alpha*-*-* } { }
{ cr16*-*-* } { }
{ crx*-*-* } { }
{ h8300-*-* } { }
{ hppa*-*-* } { }
{ iq2000*-*-* } { }
{ mips*-*-* } { }
{ mn10200-*-* } { }
{ mn10300-*-* } { }
{ *c54x*-*-* } { }
{ rx-*-* } { }
default {
# The next test can fail if the target does not convert fixups
# against ordinary symbols into relocations against section symbols.
# This is usually revealed by the error message:
# symbol `sym' required but not present
run_dump_test redef
run_dump_test equ-reloc
}
}
run_dump_test "pseudo"
run_dump_test "section0"
run_dump_test "section1"
if {! [istarget "h8300-*-*"]} then {
# The h8300 port issues a warning message for
# new sections created without atrributes.
run_elf_list_test "section2" "$target_machine" "-al" "-s" ""
}
run_dump_test "section3"
run_dump_test "section4"
if {! [istarget "h8300-*-*"]} then {
# The h8300 port issues a warning message for
# new sections created without atrributes.
run_elf_list_test "section5" "" "-al" "-SW" "| grep \" \\\\.test\\\[0-9\\\]\""
}
run_dump_test "struct"
run_dump_test "symtab"
run_dump_test "symver"
# The MSP port sets the ELF header's OSABI field to ELFOSABI_STANDALONE.
# The non-eabi ARM ports sets it to ELFOSABI_ARM.
# So for these targets we cannot include an IFUNC symbol type
# in the symbol type test.
if { [istarget "msp*-*-*"]
|| [istarget "arm*-*-*"]
|| [istarget "xscale*-*-*"]} then {
run_elf_list_test "type-noifunc" "" "" "-s" "| grep \"1 *\\\[FONTC\\\]\""
} else {
run_dump_test ifunc-1
run_elf_list_test "type" "" "" "-s" "| grep \"1 *\\\[FIONTCU\\\]\""
}
run_dump_test "section6"
run_dump_test "section7"
run_dump_test "section8"
run_dump_test "dwarf2-1"
run_dump_test "dwarf2-2"
run_dump_test "dwarf2-3"
}
|