OSDN Git Service

gas/
[pf3gnuchains/pf3gnuchains3x.git] / gas / testsuite / gas / i386 / i386.exp
1 #
2 # i386 tests
3 #
4 proc run_list_test { name opts } {
5     global srcdir subdir
6     set testname "i386 $name"
7     set file $srcdir/$subdir/$name
8     gas_run ${name}.s $opts ">&dump.out"
9     if { [regexp_diff "dump.out" "${file}.l"] } then {
10         fail $testname
11         verbose "output is [file_contents "dump.out"]" 2
12         return
13     }
14     pass $testname
15 }
16
17 proc gas_64_check { } {
18     global NM
19     global NMFLAGS
20     global srcdir
21
22     catch "exec $srcdir/lib/run $NM $NMFLAGS --help" nm_help
23     return [regexp "targets:.*x86-64" $nm_help]
24 }
25
26 proc gas_32_check { } {
27     global NM
28     global NMFLAGS
29     global srcdir
30
31     catch "exec $srcdir/lib/run $NM $NMFLAGS --help" nm_help
32     return [regexp "targets:.*i386" $nm_help]
33 }
34
35 if [expr ([istarget "i*86-*-*"] ||  [istarget "x86_64-*-*"]) && [gas_32_check]]  then {
36
37     global ASFLAGS
38     set old_ASFLAGS "$ASFLAGS"
39     set ASFLAGS "$ASFLAGS --32"
40
41     run_list_test "float" "-al"
42     run_list_test "general" "-al --listing-lhs-width=2"
43     run_list_test "inval" "-al"
44     run_list_test "segment" "-al"
45     run_list_test "inval-seg" "-al"
46     run_list_test "modrm" "-al --listing-lhs-width=2"
47     run_dump_test "naked"
48     run_dump_test "opcode"
49     run_dump_test "opcode-intel"
50     run_dump_test "opcode-suffix"
51     run_dump_test "intel"
52     run_dump_test "intel16"
53     run_list_test "intelbad" ""
54     run_dump_test "intelok"
55     run_dump_test "prefix"
56     run_dump_test "amd"
57     run_dump_test "katmai"
58     run_dump_test "jump"
59     run_dump_test "ssemmx2"
60     run_dump_test "sse2"
61     run_dump_test "sub"
62     run_dump_test "prescott"
63     run_dump_test "sib"
64     run_dump_test "vmx"
65     run_dump_test "suffix"
66     run_dump_test "immed32"
67     run_dump_test "equ"
68     run_dump_test "divide"
69     run_dump_test "padlock"
70     run_dump_test "crx"
71     run_list_test "cr-err" ""
72     run_dump_test "svme"
73     run_dump_test "amdfam10"
74     run_dump_test "merom"
75     run_dump_test "rep"
76     run_dump_test "rep-suffix"
77     run_dump_test "fp"
78     run_dump_test "nops"
79     run_dump_test "nops-1"
80     run_dump_test "nops-1-i386"
81     run_dump_test "nops-1-i686"
82     run_dump_test "nops-1-merom"
83     run_dump_test "nops-2"
84     run_dump_test "nops-2-i386"
85     run_dump_test "nops-2-merom"
86     run_dump_test "nops-3"
87     run_dump_test "addr16"
88     run_dump_test "addr32"
89     run_dump_test "sse4_1"
90     run_dump_test "sse4_2"
91     run_dump_test "crc32"
92     run_dump_test "crc32-intel"
93     run_list_test "inval-crc32" "-al"
94
95     # These tests require support for 8 and 16 bit relocs,
96     # so we only run them for ELF and COFF targets.
97     if {[is_elf_format] || [istarget "*-*-coff*"]} then {
98         run_dump_test "reloc"
99         run_dump_test "jump16"
100         run_list_test "white" "-al --listing-lhs-width=3"
101
102         # These tests should in theory work for PE targets as well,
103         # but the relocs we currently produce are slightly different
104         # from those produced for ELF/COFF based toolchains.
105         # So for now we ignore PE targets.
106         run_dump_test "pcrel"
107         run_dump_test "absrel"
108     }
109
110     # ELF specific tests
111     if [is_elf_format] then {
112         # PIC is only supported on ELF targets.
113         run_dump_test "intelpic"
114
115         run_dump_test "relax"
116         run_dump_test "gotpc"
117         run_dump_test "tlsd"
118         run_dump_test "tlspic"
119         run_dump_test "tlsnopic"
120         run_dump_test "bss"
121         run_dump_test "reloc32"
122         run_list_test "reloc32" "--defsym _bad_=1"
123         run_dump_test "mixed-mode-reloc32"
124     }
125
126     # This is a PE specific test.
127     if { [istarget "*-*-cygwin*"] || [istarget "*-*-pe"]
128          || [istarget "*-*-mingw*"]
129     } then {
130         run_dump_test "secrel"
131     }
132
133     set ASFLAGS "$old_ASFLAGS"
134 }
135
136 if [expr ([istarget "i*86-*-*"] || [istarget "x86_64-*-*"]) && [gas_64_check]] then {
137
138     global ASFLAGS
139     set old_ASFLAGS "$ASFLAGS"
140     set ASFLAGS "$ASFLAGS --64"
141
142     run_dump_test "x86_64"
143     run_dump_test "x86-64-addr32"
144     run_dump_test "x86-64-addr32-intel"
145     run_dump_test "x86-64-opcode"
146     run_dump_test "x86-64-pcrel"
147     run_dump_test "x86-64-rip"
148     run_dump_test "x86-64-rip-intel"
149     run_dump_test "x86-64-stack"
150     run_dump_test "x86-64-stack-intel"
151     run_dump_test "x86-64-stack-suffix"
152     run_list_test "x86-64-inval" "-al"
153     run_list_test "x86-64-segment" "-al"
154     run_list_test "x86-64-inval-seg" "-al"
155     run_dump_test "x86-64-branch"
156     run_dump_test "svme64"
157     run_dump_test "x86-64-amdfam10"
158     run_dump_test "x86-64-vmx"
159     run_dump_test "immed64"
160     run_dump_test "x86-64-prescott"
161     run_dump_test "x86-64-crx"
162     run_dump_test "x86-64-crx-suffix"
163     run_dump_test "x86-64-drx"
164     run_dump_test "x86-64-drx-suffix"
165     run_dump_test "x86-64-merom"
166     run_dump_test "x86-64-rep"
167     run_dump_test "x86-64-rep-suffix"
168     run_dump_test "x86-64-cbw"
169     run_dump_test "x86-64-cbw-intel"
170     run_dump_test "x86-64-io"
171     run_dump_test "x86-64-io-intel"
172     run_dump_test "x86-64-io-suffix"
173     run_dump_test "x86-64-gidt"
174     run_dump_test "x86-64-nops"
175     if ![istarget "x86_64-*-mingw*"] then {
176         run_dump_test "x86-64-nops-1"
177     }
178     run_dump_test "x86-64-nops-1-k8"
179     run_dump_test "x86-64-nops-1-nocona"
180     run_dump_test "x86-64-nops-1-merom"
181     run_dump_test "x86-64-sse4_1"
182     run_dump_test "x86-64-sse4_2"
183     run_dump_test "x86-64-crc32"
184     run_dump_test "x86-64-crc32-intel"
185     run_list_test "x86-64-inval-crc32" "-al"
186
187     if { ![istarget "*-*-aix*"]
188       && ![istarget "*-*-beos*"]
189       && ![istarget "*-*-*bsd*"]
190       && ![istarget "*-*-chaos*"]
191       && ![istarget "*-*-kaos*"]
192       && ![istarget "*-*-lynx*"]
193       && ![istarget "*-*-moss*"]
194       && ![istarget "*-*-nto-qnx*"]
195       && ![istarget "*-*-rtems*"]
196       && ![istarget "*-*-sco*"]
197       && ![istarget "*-*-solaris*"]
198       && ![istarget "*-*-sysv*"] } then {
199         run_dump_test "rex"
200     }
201
202     # For ELF targets verify that @unwind works.
203     if { ([istarget "*-*-elf*"] || [istarget "*-*-linux*"]
204           || [istarget "*-*-solaris2.*"])
205          && ![istarget *-*-linux*aout*]
206          && ![istarget *-*-linux*oldld*] } then {
207         run_dump_test "x86-64-unwind"
208     }
209
210     # ELF specific tests
211     if [is_elf_format] then {
212         run_dump_test "reloc64"
213         run_list_test "reloc64" "--defsym _bad_=1"
214         run_dump_test "mixed-mode-reloc64"
215     }
216
217     set ASFLAGS "$old_ASFLAGS"
218 }