daily update
[external/binutils.git] / gdb / testsuite / gdb.base / miscexprs.exp
index d42e5ab..e92a0bb 100644 (file)
@@ -1,21 +1,17 @@
-# Copyright (C) 1998 Free Software Foundation, Inc.
+# Copyright 1998, 1999, 2000, 2007, 2008, 2009 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 2 of the License, or
+# 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  
-
-# Please email any bugs, comments, and/or additions to this file to:
-# bug-gdb@prep.ai.mit.edu
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
 
 # This file is part of the gdb testsuite
@@ -30,6 +26,17 @@ if $tracelevel then {
         strace $tracelevel
         }
 
+# By default, the datastructures are allocated on the stack.  For targets
+# with very small stack, that will not work.  In that case, just set
+# storage to `-DSTORAGE=static' which changes the datastructures to be
+# allocated in data segment.
+set storage "-DSTORAGE="
+if [target_info exists gdb,small_stack_section] {
+    set storage "-DSTORAGE=static"
+}
+
+set additional_flags "additional_flags=${storage}"
+
 #
 # test running programs
 #
@@ -40,10 +47,14 @@ set testfile "miscexprs"
 set srcfile ${testfile}.c
 set binfile ${objdir}/${subdir}/${testfile}
 
-if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-w}] != "" } {
-    gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail."
+if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable [list debug ${additional_flags} nowarnings]] != "" } {
+    untested miscexprs.exp
+    return -1
 }
 
+if [get_compiler_info ${binfile}] {
+    return -1;
+}
 
 gdb_exit
 gdb_start
@@ -66,8 +77,13 @@ send_gdb "break marker1\n" ; gdb_expect -re ".*$gdb_prompt $"
         -re "Break.* marker1 \\(\\) at .*:$decimal.*$gdb_prompt $" {
             send_gdb "up\n"
             gdb_expect {
-                -re ".*$gdb_prompt $" {}
-                timeout { fail "up from marker1" }
+               -re ".*main.*$gdb_prompt $" {
+                   pass "up from marker1"
+               }
+                -re ".*$gdb_prompt $" {
+                   fail "up from marker1"
+               }
+                timeout { fail "up from marker1 (timeout)" }
             }
         }
         -re "$gdb_prompt $" { fail "continue to marker1"  }
@@ -90,6 +106,9 @@ gdb_expect {
     -re ".\[0-9\]* = $hex \"\".*$gdb_prompt $" {
         pass "print value of &cbig.c\[0\]"
       }
+    -re ".\[0-9\]* = $hex \"*\".*$gdb_prompt $" {
+        pass "print value of &cbig.c\[0\]"
+      }
     -re ".*$gdb_prompt $" { fail "print value of &cbig.c\[0\]" }
     timeout           { fail "(timeout) print value of &cbig.c\[0\]" }
   }
@@ -158,7 +177,7 @@ gdb_expect {
 
 send_gdb "print !ibig.i\[100\]\n"
 gdb_expect {
-    -re ".\[0-9\]* = 0.*$gdb_prompt $" {
+    -re ".\[0-9\]* = $false.*$gdb_prompt $" {
         pass "print value of !ibig.i\[100\]"
       }
     -re ".*$gdb_prompt $" { fail "print value of !ibig.i\[100\]" }
@@ -167,7 +186,7 @@ gdb_expect {
 
 send_gdb "print !sbig.s\[90\]\n"
 gdb_expect {
-    -re ".\[0-9\]* = 0.*$gdb_prompt $" {
+    -re ".\[0-9\]* = $false.*$gdb_prompt $" {
         pass "print value of !sbig.s\[90\]"
       }
     -re ".*$gdb_prompt $" { fail "print value of !sbig.s\[90\]" }
@@ -177,7 +196,7 @@ gdb_expect {
 
 send_gdb "print !fbig.f\[100\]\n"
 gdb_expect {
-    -re ".\[0-9\]* = 0.*$gdb_prompt $" {
+    -re ".\[0-9\]* = $false.*$gdb_prompt $" {
         pass "print value of !ibig.i\[100\]"
       }
     -re ".*$gdb_prompt $" { fail "print value of !ibig.i\[100\]" }
@@ -186,7 +205,7 @@ gdb_expect {
 
 send_gdb "print !dbig.d\[202\]\n"
 gdb_expect {
-    -re ".\[0-9\]* = 0.*$gdb_prompt $" {
+    -re ".\[0-9\]* = $false.*$gdb_prompt $" {
         pass "print value of !ibig.i\[100\]"
       }
     -re ".*$gdb_prompt $" { fail "print value of !ibig.i\[100\]" }
@@ -224,7 +243,7 @@ gdb_expect {
 
 send_gdb "print !(sbig.s\[90\] * 2)\n"
 gdb_expect {
-    -re ".\[0-9\]* = 0.*$gdb_prompt $" {
+    -re ".\[0-9\]* = $false.*$gdb_prompt $" {
         pass "print value of !(sbig.s\[90\] * 2)"
       }
     -re ".*$gdb_prompt $" { fail "print value of !(sbig.s\[90\] * 2)" }
@@ -252,13 +271,13 @@ gdb_expect {
   }
 
 
-send_gdb "print sizeof(lbig)\n"
+send_gdb "print sizeof(lbig)/sizeof(long)\n"
 gdb_expect {
-    -re ".\[0-9\]* = 3600.*$gdb_prompt $" {
-        pass "print value of sizeof(lbig)"
+    -re ".\[0-9\]* = 900.*$gdb_prompt $" {
+        pass "print value of sizeof(lbig)/sizeof(long)"
       }
-    -re ".*$gdb_prompt $" { fail "print value of sizeof(lbig)" }
-    timeout           { fail "(timeout) print value of sizeof(lbig)" }
+    -re ".*$gdb_prompt $" { fail "print value of sizeof(lbig)/sizeof(long)" }
+    timeout     { fail "(timeout) print value of sizeof(lbig)/sizeof(long)" }
   }
 
 send_gdb "print ibig.i\[100\] << 2\n"