[ARC] Enable .cfi_* pseudo-ops.
[deliverable/binutils-gdb.git] / gas / testsuite / gas / cfi / cfi.exp
index 88baac251502d501cf4dd235550febb19e6f51ca..4a8d3bae62afe47643a6f4a5fcda5e03234177c3 100644 (file)
-# ??? This probably shouldn't be replicated here...
-proc run_list_test { name opts } {
-    global srcdir subdir
-    set testname "cfi $name"
-    set file $srcdir/$subdir/$name
-    gas_run ${name}.s $opts ">&dump.out"
-    if { [regexp_diff "dump.out" "${file}.l"] } then {
-        fail $testname
-        verbose "output is [file_contents "dump.out"]" 2
-        return
-    }
-    pass $testname
+# Copyright (C) 2012-2016 Free Software Foundation, Inc.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+# 
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+# 
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  
+
+if { ![is_elf_format] && ![is_pecoff_format] } then {
+    return
 }
 
-set any "0"
+proc gas_x86_64_check { } {
+    global NM
+    global NMFLAGS
 
-if [istarget "x86_64-*"] then {
-    run_dump_test "cfi-x86_64"
-    set any "1"
+    set status [gas_host_run "$NM $NMFLAGS --help" ""]
+    return [regexp "targets:.*x86-64" [lindex $status 1]];
 }
 
-if [istarget "i?86-*"] then {
-    run_dump_test "cfi-i386"
-    set any "1"
+proc gas_x86_32_check { } {
+    global NM
+    global NMFLAGS
+
+    set status [gas_host_run "$NM $NMFLAGS --help" ""]
+    return [regexp "targets:.*i386" [lindex $status 1]];
 }
 
-if { [istarget alpha*-*-*] } then {
+if  { [istarget "i*86-*-*"] || [istarget "x86_64-*-*"] } then {
+
+    global ASFLAGS
+    set old_ASFLAGS "$ASFLAGS"
+
+    if { [gas_x86_64_check] } then {
+       set ASFLAGS "$ASFLAGS --64"
+       run_dump_test "cfi-x86_64"
+       set ASFLAGS "$old_ASFLAGS"
+    }
+
+    if { [gas_x86_32_check] }  then {
+       set ASFLAGS "$ASFLAGS --32"
+       run_dump_test "cfi-i386"
+       set ASFLAGS "$old_ASFLAGS"
+    }
+
+    if { [is_elf_format] } then {
+       run_dump_test "cfi-label"
+    }
+
+    if { [is_pecoff_format] } then {
+       run_dump_test "reloc-pe-i386"
+    }
+
+} elseif { [istarget alpha*-*-*] } then {
+    run_dump_test "cfi-alpha-1"
+    run_dump_test "cfi-alpha-2"
+    run_dump_test "cfi-alpha-3"
+
+} elseif { [istarget powerpc*-*-*] } then {
+    run_dump_test "cfi-ppc-1"
+
+} elseif { [istarget s390*-*-*] } then {
+    run_dump_test "cfi-s390-1"
+    if { [istarget s390x*-*-*] } then {
+       run_dump_test "cfi-s390x-1"
+    }
+
+} elseif { [istarget "m68*-*"] && ![istarget "m68hc1*-*"] } then {
+    run_dump_test "cfi-m68k"
 
-    set elf [expr [istarget *-*-elf*] \
-                  || [istarget *-*-linux*] \
-                  || [istarget *-*-freebsd*] \
-                  || [istarget *-*-netbsd*] ]
+} elseif { [istarget sparc*-*-*] } then {
+    global NM
+    global NMFLAGS
 
-    if $elf {
-       run_dump_test "cfi-alpha-1"
-       run_dump_test "cfi-alpha-2"
-       run_dump_test "cfi-alpha-3"
-       set any "1"
+    set nm_status [gas_host_run "$NM $NMFLAGS --help" ""]
+    run_dump_test "cfi-sparc-1"
+    if { [regexp "elf64\[_-\]sparc" [lindex $nm_status 1]] } then {
+       run_dump_test "cfi-sparc64-1"
     }
+
+} elseif [istarget "sh*-*"] then {
+    if { [istarget sh64*-*-*] || [istarget sh5*-*-*] } then {
+    } else {
+       run_dump_test "cfi-sh-1"
+    }
+} elseif { [istarget "arc*-*-*"] } then {
+    run_dump_test "cfi-arc-1"
+} elseif { [istarget "arm*-*"] } then {
+    # Only ELF based ARM targets support CFI.
+    if { [is_pecoff_format] } then {
+       return
+    }
+    run_dump_test "cfi-arm-1"
+
+} elseif { [istarget "mips*-*"] } then {
+    run_dump_test "cfi-mips-1"
+} elseif { [istarget "hppa*-linux*"] } then {
+    run_dump_test "cfi-hppa-1"
+} else {
+    return
 }
 
-if $any {
-    run_list_test "cfi-diag-1" ""
-    run_dump_test "cfi-common-1"
-    run_dump_test "cfi-common-2"
+run_list_test "cfi-diag-1" ""
+
+# HPPA64 uses 64-bit relocations, which results in all of the dump
+# offset numbers not matching up.
+if { ![istarget "hppa64*-*"] } then {
+  run_dump_test "cfi-common-1"
+  run_dump_test "cfi-common-2"
+  run_dump_test "cfi-common-3"
+  run_dump_test "cfi-common-4"
+  if { ![is_pecoff_format] } then {
+    # This test uses .subsection/.previous which are elf-specific.
+    run_dump_test "cfi-common-5"
+  }
+  # Some targets don't support PC relative cfi directives
+  if { ![istarget "mips*-*"] &&
+       !([istarget powerpc*-*-*] && [is_pecoff_format]) } then {
+    run_dump_test "cfi-common-6"
+  }
+  run_dump_test "cfi-common-7"
 }
This page took 0.035463 seconds and 4 git commands to generate.