OSDN Git Service

2010-04-26 Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk>
[pf3gnuchains/gcc-fork.git] / gcc / testsuite / lib / objc-torture.exp
index 7aba887..a3d1ef2 100644 (file)
 # This file was written by Rob Savoye. (rob@cygnus.com)
 
 load_lib file-format.exp
+load_lib target-supports.exp
 
-if ![info exists OBJC_RUNTIME_OPTIONS] {
-  set OBJC_RUNTIME_OPTIONS ""
-  foreach type {-fgnu-runtime -fnext-runtime} {
-    global srcdir subdir
+# Make sure that the runtime list is re-evaluated for each multilib.
+proc objc-set-runtime-options { dowhat args } {
+    global OBJC_RUNTIME_OPTIONS
+    if ![info exists OBJC_RUNTIME_OPTIONS] {
+       set rtlist [list "-fgnu-runtime" "-fnext-runtime" ]
+    } else {
+       set rtlist [list "-fgnu-runtime" "-fnext-runtime" ]
+       foreach other $OBJC_RUNTIME_OPTIONS {
+           # Don't do tests twice...
+           if { ( $other == "-fnext-runtime"  || $other == "-fgnu-runtime" ) } {
+               continue
+           }
+           lappend rtlist $other
+       }
+    }
 
-    set comp_output [objc_target_compile \
-    "$srcdir/$subdir/trivial.m" "trivial.exe" executable "additional_flags=$type"]
+    set OBJC_RUNTIME_OPTIONS ""
 
-    # If we get any error, then we failed
-    if ![string match "" $comp_output] then {
-      continue;
+    foreach type $rtlist {
+       global srcdir subdir target_triplet tmpdir
+
+       set options "additional_flags=$type"
+       if [info exists args] {
+           lappend options $args
+       }
+       verbose "options $options"
+       if [info exists dowhat] {
+          switch $dowhat {
+           "compile" {
+             set compile_type "assembly"
+             set output_file "trivial.s"
+             set comp_output [objc_target_compile \
+               "$srcdir/$subdir/trivial.m" "$output_file" "$compile_type" $options]
+
+             remote_file build delete $output_file
+             # If we get any error, then we failed.
+             if ![string match "" $comp_output] then {
+               continue;
+             }
+           }
+           "execute" {
+             set test_obj "trivial.exe"
+             set comp_output [objc_target_compile \
+               "$srcdir/$subdir/trivial.m" $test_obj "executable" $options]
+
+             # If we get any error, then we failed.
+             if ![string match "" $comp_output] then {
+               remote_file build delete $test_obj
+               continue;
+             }
+             set result [objc_load "$tmpdir/$test_obj" "" ""]
+             set status [lindex $result 0]
+             set output [lindex $result 1]
+             remote_file build delete $test_obj
+             if { $status != "pass" } {
+               verbose -log "trivial execute failed with $status $output"
+               continue;
+             }
+           }
+           default {
+             perror "$dowhat: not a valid objc-torture action"
+             return ""
+           }
+         }
+       } else {
+         set test_obj "trivial.exe"
+         set comp_output [objc_target_compile \
+         "$srcdir/$subdir/trivial.m" $test_obj executable $options]
+
+         # If we get any error, then we failed.
+         remote_file build delete $test_obj
+         if ![string match "" $comp_output] then {
+             continue;
+         }
+       }
+       lappend OBJC_RUNTIME_OPTIONS $type
     }
-    lappend OBJC_RUNTIME_OPTIONS $type
-  }
-}
-verbose -log "Using the following runtimes: $OBJC_RUNTIME_OPTIONS"
 
+    verbose -log "Using the following runtimes: $OBJC_RUNTIME_OPTIONS"
+}
 
 # The default option list can be overridden by
 # TORTURE_OPTIONS="{ { list1 } ... { listN } }"
@@ -62,7 +126,7 @@ if [info exists TORTURE_OPTIONS] {
 }
 
 if [info exists ADDITIONAL_TORTURE_OPTIONS] {
-  set OBJC_TORTURE_OPTIONS \
+    set OBJC_TORTURE_OPTIONS \
        [concat $OBJC_TORTURE_OPTIONS $ADDITIONAL_TORTURE_OPTIONS]
 }
 
@@ -150,6 +214,9 @@ proc objc-torture-execute { src args } {
     set oldstatus "foo"
     foreach option $option_list {
        if { $count > 0 } {
+           if [info exists oldexec] {
+               remote_file build delete $oldexec
+           }
            set oldexec $execname
        }
        set execname "${executable}${count}"
@@ -164,7 +231,7 @@ proc objc-torture-execute { src args } {
        # torture_execute_before_{compile,execute} can be set by the .x script
        # (if present)
        if [info exists torture_eval_before_compile] {
-            set ignore_me [eval $torture_eval_before_compile]
+         set ignore_me [eval $torture_eval_before_compile]
        }
 
        remote_file build delete $execname
@@ -188,6 +255,7 @@ proc objc-torture-execute { src args } {
        if [target_info exists no_long_long] then {
            if [expr [search_for $src "long long"]] then {
                unsupported "$testcase execution, $option"
+               remote_file build delete $execname
                continue
            }
        }
@@ -197,7 +265,7 @@ proc objc-torture-execute { src args } {
        }
 
        if [info exists torture_eval_before_execute] {
-            set ignore_me [eval $torture_eval_before_execute]
+           set ignore_me [eval $torture_eval_before_execute]
        }
 
 
@@ -218,6 +286,7 @@ proc objc-torture-execute { src args } {
        if { ![isnative] && [info exists oldexec] } {
            if { [remote_file build cmp $oldexec $execname] == 0 } {
                set skip 1
+               set status $oldstatus
            }
        }
        if { $skip == 0 } {
@@ -225,16 +294,16 @@ proc objc-torture-execute { src args } {
            set status [lindex $result 0]
            set output [lindex $result 1]
        }
-        if { $oldstatus == "pass" } {
-           remote_file build delete $oldexec
-        }
        $status "$testcase execution, $option"
        set oldstatus $status
+    # for each option
+    } 
+    # tidy up
+    if [info exists execname] {
+       remote_file build delete $execname
     }
-    if [info exists status] {
-       if { $status == "pass" } {
-           remote_file build delete $execname
-       }
+    if [info exists oldexec] {
+       remote_file build delete $oldexec
     }
 }
 
@@ -293,9 +362,9 @@ proc objc-torture { args } {
     # don't pass -funroll[-all]-loops.
     global torture_with_loops torture_without_loops
     if [expr [search_for $src "for*("]+[search_for $src "while*("]] then {
-       set option_list $torture_with_loops
+           set option_list $torture_with_loops
     } else {
-       set option_list $torture_without_loops
+           set option_list $torture_without_loops
     }
 
     # loop through all the options
@@ -307,7 +376,7 @@ proc objc-torture { args } {
 
        # torture_execute_before_compile is set by the .x script (if present)
        if [info exists torture_eval_before_compile] {
-            set ignore_me [eval $torture_eval_before_compile]
+           set ignore_me [eval $torture_eval_before_compile]
        }
 
        objc-torture-compile $src "$option $options"