Commit | Line | Data |
---|---|---|
252b5132 RH |
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 | ||
b96d3a20 JH |
17 | proc gas_64_check { } { |
18 | global NM | |
19 | global NMFLAGS | |
20 | global srcdir | |
252b5132 | 21 | |
b96d3a20 | 22 | catch "exec $srcdir/lib/run $NM $NMFLAGS --help" nm_help |
6e0b89ee | 23 | return [regexp "targets:.*x86-64" $nm_help]; |
b96d3a20 | 24 | } |
6e0b89ee | 25 | |
b96d3a20 JH |
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 | ||
36 | if [expr ([istarget "i*86-*-*"] || [istarget "x86_64-*-*"]) && [gas_32_check]] then { | |
37 | ||
38 | global ASFLAGS | |
39 | set old_ASFLAGS "$ASFLAGS" | |
40 | set ASFLAGS "$ASFLAGS --32" | |
252b5132 RH |
41 | |
42 | run_list_test "float" "-al" | |
43 | run_list_test "general" "-al --listing-lhs-width=2" | |
44 | run_list_test "inval" "-al" | |
45 | run_list_test "modrm" "-al --listing-lhs-width=2" | |
3f9ed93b | 46 | run_dump_test "naked" |
252b5132 | 47 | run_dump_test "opcode" |
cc5ca5ce | 48 | run_dump_test "intel" |
252b5132 RH |
49 | run_dump_test "prefix" |
50 | run_dump_test "amd" | |
c608c12e | 51 | run_dump_test "katmai" |
a3d1c52b | 52 | run_dump_test "jump" |
de9d65b5 JH |
53 | run_dump_test "ssemmx2" |
54 | run_dump_test "sse2" | |
252b5132 | 55 | |
64cbbfae L |
56 | # PIC is only supported on ELF targets. |
57 | if { ([istarget "*-*-elf*"] || [istarget "*-*-linux*"] ) | |
58 | && ![istarget *-*-linux*aout*] | |
59 | && ![istarget *-*-linux*oldld*] } then { | |
60 | run_dump_test "intelpic" | |
61 | } | |
62 | ||
a3d1c52b AM |
63 | # These tests require support for 8 and 16 bit relocs, |
64 | # so we only run them for ELF and COFF targets. | |
b7be1db6 | 65 | if {[istarget "*-*-elf*"] || [istarget "*-*-linux*"] || [istarget "*-*-coff*"]} then { |
252b5132 | 66 | run_dump_test "reloc" |
a3d1c52b | 67 | run_dump_test "jump16" |
252b5132 RH |
68 | run_list_test "white" "-al --listing-lhs-width=3" |
69 | } | |
00687228 L |
70 | |
71 | # Do they only work for ELF? | |
72 | if { ([istarget "*-*-elf*"] | |
73 | || [istarget "*-*-linux*"] | |
74 | && ![istarget *-*-linux*aout*] | |
75 | && ![istarget *-*-linux*oldld*]) | |
76 | } then { | |
77 | run_dump_test "relax" | |
13ae64f3 JJ |
78 | run_dump_test "tlsd" |
79 | run_dump_test "tlspic" | |
80 | run_dump_test "tlsnopic" | |
00687228 L |
81 | } |
82 | ||
b96d3a20 JH |
83 | set ASFLAGS "$old_ASFLAGS" |
84 | } | |
6e0b89ee | 85 | |
fc847f15 | 86 | if [expr ([istarget "i*86-*-*"] || [istarget "x86_64-*-*"]) && [gas_64_check]] then { |
b96d3a20 JH |
87 | |
88 | global ASFLAGS | |
89 | set old_ASFLAGS "$ASFLAGS" | |
90 | set ASFLAGS "$ASFLAGS --64" | |
91 | ||
92 | run_dump_test "x86_64" | |
831b02f6 NC |
93 | run_dump_test "x86-64-opcode" |
94 | run_list_test "x86-64-inval" "-al" | |
b96d3a20 JH |
95 | |
96 | set ASFLAGS "$old_ASFLAGS" | |
252b5132 | 97 | } |