include/elf/
[deliverable/binutils-gdb.git] / gas / testsuite / gas / elf / elf.exp
index 43265d0d2fae5e7b252819907b193ca84dcb5b5d..637ce9a7d82ae6094fd495970a10f5290e06d8cd 100644 (file)
@@ -2,7 +2,7 @@
 # elf tests
 #
 
-proc run_list_test { name suffix opts readelf_opts readelf_pipe } {
+proc run_elf_list_test { name suffix opts readelf_opts readelf_pipe } {
     global READELF
     global srcdir subdir
     set testname "elf $name list"
@@ -15,7 +15,13 @@ proc run_list_test { name suffix opts readelf_opts readelf_pipe } {
        return
     }
     send_log "$READELF $readelf_opts dump.o $readelf_pipe > dump.out\n"
-    catch "exec $READELF $readelf_opts dump.o $readelf_pipe > dump.out\n" comp_output
+    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
@@ -50,34 +56,65 @@ if { ([istarget "*-*-*elf*"]
     if {[istarget m32r*-*-*]} then {
        set target_machine -m32r
     }
+    if {[istarget "score-*-*"]} then {
+       set target_machine -score
+    }
+    if {[istarget "xtensa*-*-*"]} then {
+       set target_machine -xtensa
+    }
     if { ([istarget "*arm*-*-*"]
-         || [istarget "xscale*-*-*"])
-       && ([istarget "*-*-*eabi"]
-           || [istarget "*-*-symbianelf"])} then {
-       set target_machine -armeabi
+         || [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"
     }
-    run_dump_test "ehopt0"
     run_dump_test "group0a" 
     run_dump_test "group0b" 
     run_dump_test "group1a" 
     run_dump_test "group1b" 
     case $target_triplet in {
        { alpha*-*-* } { }
+       { cr16*-*-* } { }
+       { crx*-*-* } { }
+       { h8300-*-* } { }
        { hppa*-*-* } { }
        { iq2000*-*-* } { }
        { mips*-*-* } { }
+       { mn10200-*-* } { }
+       { mn10300-*-* } { }
        { *c54x*-*-* } { }
        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 "section0" 
     run_dump_test "section1" 
-    run_list_test "section2" "$target_machine" "-al" "-s" ""
+    run_elf_list_test "section2" "$target_machine" "-al" "-s" ""
     run_dump_test "section3" 
     run_dump_test "section4"
-    run_list_test "section5" "" "-al" "-SW" "| grep \" \\\\.test\\\[0-9\\\]\""
+    run_elf_list_test "section5" "" "-al" "-SW" "| grep \" \\\\.test\\\[0-9\\\]\""
     run_dump_test "struct" 
     run_dump_test "symver" 
-    run_list_test "type" "" "" "-s" "| grep \"1 \\\[FONT\\\]\""
+    run_elf_list_test "type" "" "" "-s" "| grep \"1 \\\[FIONTC\\\]\""
+    run_dump_test "section6" 
+    run_dump_test "section7" 
 }
This page took 0.026873 seconds and 4 git commands to generate.