OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [gdb-7.2/] [gdb/] [testsuite/] [gdb.mi/] [mi2-syn-frame.exp] - Blame information for rev 330

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 330 jeremybenn
# Copyright 2002, 2003, 2005, 2007, 2008, 2009, 2010
2
# Free Software Foundation, Inc.
3
 
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 3 of the License, or
7
# (at your option) any later version.
8
#
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
#
14
# You should have received a copy of the GNU General Public License
15
# along with this program.  If not, see .
16
 
17
# Test MI output with synthetic frames on the stack (call dummies,
18
# signal handlers).
19
 
20
if [target_info exists gdb,nosignals] {
21
    verbose "Skipping mi-syn-frame.exp because of nosignals."
22
    continue
23
}
24
 
25
load_lib mi-support.exp
26
set MIFLAGS "-i=mi2"
27
 
28
set testfile "mi-syn-frame"
29
set srcfile ${testfile}.c
30
set binfile ${objdir}/${subdir}/${testfile}
31
if  { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}" executable {debug additional_flags=-DFAKEARGV}] != "" } {
32
     untested mi2-syn-frame.exp
33
     return -1
34
}
35
 
36
set my_mi_gdb_prompt "\\(gdb\\)\[ \]*\[\r\n\]*"
37
 
38
mi_gdb_exit
39
mi_gdb_start
40
mi_run_to_main
41
 
42
mi_create_breakpoint "foo" 2 keep foo ".*mi-syn-frame.c" $decimal $hex \
43
    "insert breakpoint foo"
44
 
45
#
46
# Call foo() by hand, where we'll hit a breakpoint.
47
#
48
 
49
mi_gdb_test "401-data-evaluate-expression foo()" ".*401\\^error,msg=\"The program being debugged stopped while in a function called from GDB.\\\\nEvaluation of the expression containing the function\\\\n\\(foo\\) will be abandoned.\\\\nWhen the function is done executing, GDB will silently stop.\"" \
50
    "call inferior's function with a breakpoint set in it"
51
 
52
mi_gdb_test "402-stack-list-frames" "402\\^done,stack=\\\[frame=\{level=\"0\",addr=\"$hex\",func=\"foo\",file=\".*mi-syn-frame.c\",line=\"$decimal\"\},frame=\{level=\"1\",addr=\"$hex\",func=\"\"\},frame=\{level=\"2\",addr=\"$hex\",func=\"main\",file=\".*mi-syn-frame.c\",line=\"$decimal\"\}.*\\\]" "backtrace from inferior function stopped at bp, showing gdb dummy frame"
53
 
54
#
55
# Continue back to main()
56
#
57
 
58
mi_send_resuming_command "exec-continue" "testing exec continue"
59
 
60
mi_expect_stop "really-no-reason" "" "" "" "" "" "finished exec continue"
61
 
62
mi_gdb_test "404-stack-list-frames 0 0" \
63
  "404\\^done,stack=\\\[frame=\{level=\"0\",addr=\"$hex\",func=\"main\",file=\".*mi-syn-frame.c\",fullname=\"${fullname_syntax}${srcfile}\",line=\"$decimal\"\}.*\\\]" \
64
  "list stack frames"
65
 
66
 
67
#
68
# Call have_a_very_merry_interrupt() which will eventually raise a signal
69
# that's caught by handler() which calls subroutine().
70
 
71
mi_create_breakpoint "subroutine" 3 keep subroutine ".*mi-syn-frame.c" $decimal $hex \
72
    "insert breakpoint subroutine"
73
 
74
mi_gdb_test "406-data-evaluate-expression have_a_very_merry_interrupt()" \
75
  ".*406\\^error,msg=\"The program being debugged stopped while in a function called from GDB.\\\\nEvaluation of the expression containing the function\\\\n\\(have_a_very_merry_interrupt\\) will be abandoned.\\\\nWhen the function is done executing, GDB will silently stop.\"" \
76
  "evaluate expression have_a_very_merry_interrupt"
77
 
78
# We should have both a signal handler and a call dummy frame
79
# in this next output.
80
 
81
mi_gdb_test "407-stack-list-frames" \
82
  "407\\^done,stack=\\\[frame=\{level=\"0\",addr=\"$hex\",func=\"subroutine\",file=\".*mi-syn-frame.c\",line=\"$decimal\"\},frame=\{level=\"1\",addr=\"$hex\",func=\"handler\",file=\".*mi-syn-frame.c\",line=\"$decimal\"\},frame=\{level=\"2\",addr=\"$hex\",func=\"\"\},.*frame=\{level=\"$decimal\",addr=\"$hex\",func=\"have_a_very_merry_interrupt\",file=\".*mi-syn-frame.c\",line=\"$decimal\"\},frame=\{level=\"$decimal\",addr=\"$hex\",func=\"\"\},frame=\{level=\"$decimal\",addr=\"$hex\",func=\"main\",file=\".*mi-syn-frame.c\",line=\"$decimal\"\}.*\\\]" \
83
  "list stack frames"
84
 
85
mi_send_resuming_command "exec-continue" "testing exec continue"
86
 
87
mi_expect_stop "really-no-reason" "" "" "" "" "" "finished exec continue"
88
 
89
mi_gdb_test "409-stack-list-frames 0 0" \
90
  "409\\^done,stack=\\\[frame=\{level=\"0\",addr=\"$hex\",func=\"main\",file=\".*mi-syn-frame.c\",fullname=\"${fullname_syntax}${srcfile}\",line=\"$decimal\"\}.*\\\]" \
91
  "list stack frames"
92
 
93
#
94
# Call bar() by hand, which should get an exception while running.
95
#
96
 
97
mi_gdb_test "410-data-evaluate-expression bar()" ".*410\\^error,msg=\"The program being debugged was signaled while in a function called from GDB.\\\\nGDB remains in the frame where the signal was received.\\\\nTo change this behavior use \\\\\"set unwindonsignal on\\\\\".\\\\nEvaluation of the expression containing the function\\\\n\\(bar\\) will be abandoned.\\\\nWhen the function is done executing, GDB will silently stop.\"" "call inferior function which raises exception"
98
 
99
mi_gdb_test "411-stack-list-frames" "411\\^done,stack=\\\[frame=\{level=\"0\",addr=\"$hex\",func=\"bar\",file=\".*mi-syn-frame.c\",fullname=\"${fullname_syntax}${srcfile}\",line=\"$decimal\"},frame=\{level=\"1\",addr=\"$hex\",func=\"\"\},frame=\{level=\"2\",addr=\"$hex\",func=\"main\",file=\".*mi-syn-frame.c\",fullname=\"${fullname_syntax}${srcfile}\",line=\"$decimal\"}.*\\\]" "backtrace from inferior function at exception"
100
 
101
mi_gdb_exit
102
 
103
return 0

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.