diff options
author | Jan Kratochvil <jan.kratochvil@redhat.com> | 2011-10-09 19:34:19 +0000 |
---|---|---|
committer | Jan Kratochvil <jan.kratochvil@redhat.com> | 2011-10-09 19:34:19 +0000 |
commit | e18b27534c2181c92dc9b685adc05bcf6b685817 (patch) | |
tree | 2098d8656520c417bd086ec4b4e37d601665ea45 /gdb/testsuite | |
parent | 93d86cefdf1902d003f0d54f27777b8ea4f75b13 (diff) | |
download | gdb-e18b27534c2181c92dc9b685adc05bcf6b685817.zip gdb-e18b27534c2181c92dc9b685adc05bcf6b685817.tar.gz gdb-e18b27534c2181c92dc9b685adc05bcf6b685817.tar.bz2 |
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
Diffstat (limited to 'gdb/testsuite')
-rw-r--r-- | gdb/testsuite/ChangeLog | 19 | ||||
-rw-r--r-- | gdb/testsuite/gdb.arch/amd64-entry-value.cc | 65 | ||||
-rw-r--r-- | gdb/testsuite/gdb.arch/amd64-entry-value.exp | 111 | ||||
-rw-r--r-- | gdb/testsuite/gdb.base/break.exp | 6 | ||||
-rw-r--r-- | gdb/testsuite/gdb.mi/Makefile.in | 3 | ||||
-rw-r--r-- | gdb/testsuite/gdb.mi/mi2-amd64-entry-value.c | 70 | ||||
-rw-r--r-- | gdb/testsuite/gdb.mi/mi2-amd64-entry-value.exp | 171 |
7 files changed, 438 insertions, 7 deletions
diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 86fe0e9..74826cf 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,5 +1,24 @@ 2011-10-09 Jan Kratochvil <jan.kratochvil@redhat.com> + Display @entry parameter values (without references). + * gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2) + (different, validity, invalid): New functions. + (main): Call them. + * gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr, + stacktest, breakhere_stacktest, different, breakhere_different, + breakhere_validity and breakhere_invalid. + (entry: bt): Update for @entry. + (entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *) + (entry_validity: *, entry_invalid: *): Many new tests. + * gdb.base/break.exp + (run until breakpoint set at small function, optimized file): Accept + also the @entry suffix. + * gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value. + * gdb.mi/mi2-amd64-entry-value.c: New files. + * gdb.mi/mi2-amd64-entry-value.exp: New files. + +2011-10-09 Jan Kratochvil <jan.kratochvil@redhat.com> + Protect entry values against self tail calls. * gdb.arch/amd64-entry-value.cc (self2, self): New. (main): Call self. diff --git a/gdb/testsuite/gdb.arch/amd64-entry-value.cc b/gdb/testsuite/gdb.arch/amd64-entry-value.cc index 44b7564..7b7d050 100644 --- a/gdb/testsuite/gdb.arch/amd64-entry-value.cc +++ b/gdb/testsuite/gdb.arch/amd64-entry-value.cc @@ -35,6 +35,13 @@ asm ("breakhere:"); } static void __attribute__((noinline, noclone)) +locexpr (int i) +{ + i = i; +asm ("breakhere_locexpr:"); +} + +static void __attribute__((noinline, noclone)) c (int i, double j) { d (i * 10, j * 10); @@ -114,10 +121,68 @@ self (int i) } } +static void __attribute__((noinline, noclone)) +stacktest (int r1, int r2, int r3, int r4, int r5, int r6, int s1, int s2, + double d1, double d2, double d3, double d4, double d5, double d6, + double d7, double d8, double d9, double da) +{ + s1 = 3; + s2 = 4; + d9 = 3.5; + da = 4.5; + e (v, v); +asm ("breakhere_stacktest:"); + e (v, v); +} + +static int __attribute__((noinline, noclone)) +data (void) +{ + return 10; +} + +static int __attribute__((noinline, noclone)) +data2 (void) +{ + return 20; +} + +static int __attribute__((noinline, noclone)) +different (int val) +{ + val++; + e (val, val); +asm ("breakhere_different:"); + return val; +} + +static int __attribute__((noinline, noclone)) +validity (int lost, int born) +{ + lost = data (); + e (0, 0.0); +asm ("breakhere_validity:"); + return born; +} + +static void __attribute__((noinline, noclone)) +invalid (int inv) +{ + e (0, 0.0); +asm ("breakhere_invalid:"); +} + int main () { d (30, 30.5); + locexpr (30); + stacktest (1, 2, 3, 4, 5, 6, 11, 12, + 1.5, 2.5, 3.5, 4.5, 5.5, 6.5, 7.5, 8.5, 11.5, 12.5); + different (5); + validity (5, data ()); + invalid (data2 ()); + if (v) a (1, 1.25); else diff --git a/gdb/testsuite/gdb.arch/amd64-entry-value.exp b/gdb/testsuite/gdb.arch/amd64-entry-value.exp index fdf8040..fcccdd8 100644 --- a/gdb/testsuite/gdb.arch/amd64-entry-value.exp +++ b/gdb/testsuite/gdb.arch/amd64-entry-value.exp @@ -35,23 +35,128 @@ if ![runto_main] { } gdb_breakpoint "breakhere" +gdb_breakpoint "breakhere_locexpr" +gdb_breakpoint "stacktest" +gdb_breakpoint "breakhere_stacktest" +gdb_breakpoint "different" +gdb_breakpoint "breakhere_different" +gdb_breakpoint "breakhere_validity" +gdb_breakpoint "breakhere_invalid" # Test @entry values for register passed parameters. gdb_continue_to_breakpoint "entry: breakhere" -gdb_test "bt" "^bt\r\n#0 +d *\\(i=31, j=31\\.5\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in main .*" \ +gdb_test "bt" "^bt\r\n#0 +d *\\(i=31, i@entry=30, j=31\\.5, j@entry=30\\.5\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in main .*" \ "entry: bt" gdb_test "p i" " = 31" "entry: p i" gdb_test "p j" { = 31\.5} "entry: p j" +# Test @entry values when parameter in function is locexpr (and not loclist). + +gdb_continue_to_breakpoint "entry_locexpr: breakhere_locexpr" +gdb_test "p i" " = 30" "entry_locexpr: p i" +gdb_test_no_output "set variable i = 0" "entry_locexpr: set variable i = 0" +gdb_test "bt" "^bt\r\n#0 +locexpr *\\(i=0, i@entry=30\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in main .*" \ + "entry_locexpr: bt" + + +# Test @entry values for stack passed parameters. + +gdb_continue_to_breakpoint "entry_stack: stacktest" + +gdb_test "bt" "^bt\r\n#0 +stacktest *\\(r1=r1@entry=1, r2=r2@entry=2, \[^\r\n\]+, s1=s1@entry=11, s2=s2@entry=12, \[^\r\n\]+, d9=d9@entry=11\\.5, da=da@entry=12\\.5\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in main .*" \ + "entry_stack: bt at entry" + +gdb_continue_to_breakpoint "entry_stack: breakhere_stacktest" + +gdb_test "bt" "^bt\r\n#0 +stacktest *\\(r1=r1@entry=1, r2=r2@entry=2, \[^\r\n\]+, s1=3, s1@entry=11, s2=4, s2@entry=12, \[^\r\n\]+, d9=3\\.5, d9@entry=11\\.5, da=4\\.5, da@entry=12\\.5\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in main .*" \ + "entry_stack: bt" + +gdb_test "p s1" " = 3" "entry_stack: p s1" +gdb_test "p s2" " = 4" "entry_stack: p s2" +gdb_test "p d9" " = 3\\.5" "entry_stack: p d9" +gdb_test "p da" " = 4\\.5" "entry_stack: p da" + + +# Test various kinds of `set print entry-values'. + +gdb_continue_to_breakpoint "entry_equal: breakhere" + +gdb_test_no_output "set print entry-values no" "entry_equal: set print entry-values no" +gdb_test "frame" {\(val=5\).*} "entry_equal: frame: no" +gdb_test_no_output "set print entry-values only" "entry_equal: set print entry-values only" +gdb_test "frame" {\(val@entry=5\).*} "entry_equal: frame: only" +gdb_test_no_output "set print entry-values preferred" "entry_equal: set print entry-values preferred" +gdb_test "frame" {\(val@entry=5\).*} "entry_equal: frame: preferred" +gdb_test_no_output "set print entry-values if-needed" "entry_equal: set print entry-values if-needed" +gdb_test "frame" {\(val=5\).*} "entry_equal: frame: if-needed" +gdb_test_no_output "set print entry-values both" "entry_equal: set print entry-values both" +gdb_test "frame" {\(val=5, val@entry=5\).*} "entry_equal: frame: both" +gdb_test_no_output "set print entry-values compact" "entry_equal: set print entry-values compact" +gdb_test "frame" {\(val=val@entry=5\).*} "entry_equal: frame: compact" +gdb_test_no_output "set print entry-values default" "entry_equal: set print entry-values default" +gdb_test "frame" {\(val=val@entry=5\).*} "entry_equal: frame: default" + +gdb_continue_to_breakpoint "entry_different: breakhere" + +gdb_test_no_output "set print entry-values no" "entry_different: set print entry-values no" +gdb_test "frame" {\(val=6\).*} "entry_different: frame: no" +gdb_test_no_output "set print entry-values only" "entry_different: set print entry-values only" +gdb_test "frame" {\(val@entry=5\).*} "entry_different: frame: only" +gdb_test_no_output "set print entry-values preferred" "entry_different: set print entry-values preferred" +gdb_test "frame" {\(val@entry=5\).*} "entry_different: frame: preferred" +gdb_test_no_output "set print entry-values if-needed" "entry_different: set print entry-values if-needed" +gdb_test "frame" {\(val=6\).*} "entry_different: frame: if-needed" +gdb_test_no_output "set print entry-values both" "entry_different: set print entry-values both" +gdb_test "frame" {\(val=6, val@entry=5\).*} "entry_different: frame: both" +gdb_test_no_output "set print entry-values compact" "entry_different: set print entry-values compact" +gdb_test "frame" {\(val=6, val@entry=5\).*} "entry_different: frame: compact" +gdb_test_no_output "set print entry-values default" "entry_different: set print entry-values default" +gdb_test "frame" {\(val=6, val@entry=5\).*} "entry_different: frame: default" + +gdb_continue_to_breakpoint "entry_validity: breakhere" + +gdb_test_no_output "set print entry-values no" "entry_validity: set print entry-values no" +gdb_test "frame" {\(lost=<optimized out>, born=10\).*} "entry_validity: frame: no" +gdb_test_no_output "set print entry-values only" "entry_validity: set print entry-values only" +gdb_test "frame" {\(lost@entry=5, born@entry=<optimized out>\).*} "entry_validity: frame: only" +gdb_test_no_output "set print entry-values preferred" "entry_validity: set print entry-values preferred" +gdb_test "frame" {\(lost@entry=5, born=10\).*} "entry_validity: frame: preferred" +gdb_test_no_output "set print entry-values if-needed" "entry_validity: set print entry-values if-needed" +gdb_test "frame" {\(lost@entry=5, born=10\).*} "entry_validity: frame: if-needed" +gdb_test_no_output "set print entry-values both" "entry_validity: set print entry-values both" +gdb_test "frame" {\(lost=<optimized out>, lost@entry=5, born=10, born@entry=<optimized out>\).*} "entry_validity: frame: both" +gdb_test_no_output "set print entry-values compact" "entry_validity: set print entry-values compact" +gdb_test "frame" {\(lost@entry=5, born=10\).*} "entry_validity: frame: compact" +gdb_test_no_output "set print entry-values default" "entry_validity: set print entry-values default" +gdb_test "frame" {\(lost=<optimized out>, lost@entry=5, born=10\).*} "entry_validity: frame: default" + +gdb_continue_to_breakpoint "entry_invalid: breakhere" + +gdb_test_no_output "set print entry-values no" "entry_invalid: set print entry-values no" +gdb_test "frame" {\(inv=<optimized out>\).*} "entry_invalid: frame: no" +gdb_test_no_output "set print entry-values only" "entry_invalid: set print entry-values only" +gdb_test "frame" {\(inv@entry=<optimized out>\).*} "entry_invalid: frame: only" +gdb_test_no_output "set print entry-values preferred" "entry_invalid: set print entry-values preferred" +gdb_test "frame" {\(inv@entry=<optimized out>\).*} "entry_invalid: frame: preferred" +gdb_test_no_output "set print entry-values if-needed" "entry_invalid: set print entry-values if-needed" +gdb_test "frame" {\(inv=<optimized out>\).*} "entry_invalid: frame: if-needed" +gdb_test_no_output "set print entry-values both" "entry_invalid: set print entry-values both" +gdb_test "frame" {\(inv=<optimized out>, inv@entry=<optimized out>\).*} "entry_invalid: frame: both" +gdb_test_no_output "set print entry-values compact" "entry_invalid: set print entry-values compact" +gdb_test "frame" {\(inv=<optimized out>\).*} "entry_invalid: frame: compact" +gdb_test_no_output "set print entry-values default" "entry_invalid: set print entry-values default" +gdb_test "frame" {\(inv=<optimized out>\).*} "entry_invalid: frame: default" + + # Test virtual tail call frames. gdb_continue_to_breakpoint "tailcall: breakhere" -gdb_test "bt" "^bt\r\n#0 +d *\\(i=71, j=73\\.5\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in c \\(i=7, j=7\\.25\\) \[^\r\n\]*\r\n#2 +0x\[0-9a-f\]+ in b \\(i=5, j=5\\.25\\) \[^\r\n\]*\r\n#3 +0x\[0-9a-f\]+ in main \[^\r\n\]*" \ +gdb_test "bt" "^bt\r\n#0 +d *\\(i=71, i@entry=70, j=73\\.5, j@entry=72\\.5\\) \[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in c \\(i=i@entry=7, j=j@entry=7\\.25\\) \[^\r\n\]*\r\n#2 +0x\[0-9a-f\]+ in b \\(i=i@entry=5, j=j@entry=5\\.25\\) \[^\r\n\]*\r\n#3 +0x\[0-9a-f\]+ in main \[^\r\n\]*" \ "tailcall: bt" gdb_test "p i" " = 71" "tailcall: p i" gdb_test "p j" " = 73\\.5" "tailcall: p j" @@ -71,7 +176,7 @@ gdb_test {p $sp0 + sizeof (void *) == $sp} " = true" gdb_continue_to_breakpoint "ambiguous: breakhere" -gdb_test "bt" "^bt\r\n#0 +d \\(i=<optimized out>, j=<optimized out>\\)\[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in amb_z \\(i=<optimized out>\\)\[^\r\n\]*\r\n#2 +0x\[0-9a-f\]+ in amb_y \\(i=<optimized out>\\)\[^\r\n\]*\r\n#3 +0x\[0-9a-f\]+ in amb_x \\(i=<optimized out>\\)\[^\r\n\]*\r\n#4 +0x\[0-9a-f\]+ in amb_b \\(i=101\\)\[^\r\n\]*\r\n#5 +0x\[0-9a-f\]+ in amb_a \\(i=100\\)\[^\r\n\]*\r\n#6 +0x\[0-9a-f\]+ in main \\(\\)\[^\r\n\]*" \ +gdb_test "bt" "^bt\r\n#0 +d \\(i=<optimized out>, j=<optimized out>\\)\[^\r\n\]*\r\n#1 +0x\[0-9a-f\]+ in amb_z \\(i=<optimized out>\\)\[^\r\n\]*\r\n#2 +0x\[0-9a-f\]+ in amb_y \\(i=<optimized out>\\)\[^\r\n\]*\r\n#3 +0x\[0-9a-f\]+ in amb_x \\(i=<optimized out>\\)\[^\r\n\]*\r\n#4 +0x\[0-9a-f\]+ in amb_b \\(i=i@entry=101\\)\[^\r\n\]*\r\n#5 +0x\[0-9a-f\]+ in amb_a \\(i=i@entry=100\\)\[^\r\n\]*\r\n#6 +0x\[0-9a-f\]+ in main \\(\\)\[^\r\n\]*" \ "ambiguous: bt" diff --git a/gdb/testsuite/gdb.base/break.exp b/gdb/testsuite/gdb.base/break.exp index 15227bc..92fcc69 100644 --- a/gdb/testsuite/gdb.base/break.exp +++ b/gdb/testsuite/gdb.base/break.exp @@ -916,13 +916,13 @@ set bp_location14 [gdb_get_line_number "set breakpoint 14 here" $srcfile1] gdb_test_multiple "continue" \ "run until breakpoint set at small function, optimized file" { - -re "Breakpoint $decimal, marker4 \\(d=177601976\\) at .*$srcfile1:$bp_location13\[\r\n\]+$bp_location13\[\t \]+void marker4.*" { + -re "Breakpoint $decimal, marker4 \\(d=(d@entry=)?177601976\\) at .*$srcfile1:$bp_location13\[\r\n\]+$bp_location13\[\t \]+void marker4.*" { pass "run until breakpoint set at small function, optimized file" } - -re "Breakpoint $decimal, $hex in marker4 \\(d=177601976\\) at .*$srcfile1:$bp_location13\[\r\n\]+$bp_location13\[\t \]+void marker4.*" { + -re "Breakpoint $decimal, $hex in marker4 \\(d=(d@entry=)?177601976\\) at .*$srcfile1:$bp_location13\[\r\n\]+$bp_location13\[\t \]+void marker4.*" { pass "run until breakpoint set at small function, optimized file" } - -re "Breakpoint $decimal, marker4 \\(d=177601976\\) at .*$srcfile1:$bp_location14\[\r\n\]+$bp_location14\[\t \]+void marker4.*" { + -re "Breakpoint $decimal, marker4 \\(d=(d@entry=)?177601976\\) at .*$srcfile1:$bp_location14\[\r\n\]+$bp_location14\[\t \]+void marker4.*" { # marker4() is defined at line 46 when compiled with -DPROTOTYPES pass "run until breakpoint set at small function, optimized file (line bp_location14)" } diff --git a/gdb/testsuite/gdb.mi/Makefile.in b/gdb/testsuite/gdb.mi/Makefile.in index e8754f4..dc1f1a3 100644 --- a/gdb/testsuite/gdb.mi/Makefile.in +++ b/gdb/testsuite/gdb.mi/Makefile.in @@ -9,7 +9,8 @@ PROGS = basics c_variable cpp_variable var-cmd dw2-ref-missing-frame \ mi-pending mi-pthreads mi-read-memory mi-regs mi-return \ mi-reverse mi-simplerun mi-stack mi-stepi mi-syn-frame \ mi-var-block mi-var-child mi-var-cmd mi-var-cp mi-var-display \ - mi-var-invalidate mi-var-invalidate_bis mi-watch mi2-basics \ + mi-var-invalidate mi-var-invalidate_bis mi-watch \ + mi2-amd64-entry-value mi2-basics \ mi2-break mi2-cli mi2-disassemble mi2-eval mi2-file \ mi2-pthreads mi2-regs mi2-return mi2-simplerun mi2-stepi \ mi2-var-block mi2-var-child mi2-var-cmd mi2-var-display \ diff --git a/gdb/testsuite/gdb.mi/mi2-amd64-entry-value.c b/gdb/testsuite/gdb.mi/mi2-amd64-entry-value.c new file mode 100644 index 0000000..5c73a68 --- /dev/null +++ b/gdb/testsuite/gdb.mi/mi2-amd64-entry-value.c @@ -0,0 +1,70 @@ +/* This testcase is part of GDB, the GNU debugger. + + Copyright 2011 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, see <http://www.gnu.org/licenses/>. */ + +static volatile int v; + +static void __attribute__((noinline, noclone)) +e (int i, double j) +{ + v = 0; +} + +static int __attribute__((noinline, noclone)) +data (void) +{ + return 10; +} + +static int __attribute__((noinline, noclone)) +data2 (void) +{ + return 20; +} + +static int __attribute__((noinline, noclone)) +different (int val) +{ + val++; + e (val, val); +asm ("breakhere_different:"); + return val; +} + +static int __attribute__((noinline, noclone)) +validity (int lost, int born) +{ + lost = data (); + e (0, 0.0); +asm ("breakhere_validity:"); + return born; +} + +static void __attribute__((noinline, noclone)) +invalid (int inv) +{ + e (0, 0.0); +asm ("breakhere_invalid:"); +} + +int +main () +{ + different (5); + validity (5, data ()); + invalid (data2 ()); + return 0; +} diff --git a/gdb/testsuite/gdb.mi/mi2-amd64-entry-value.exp b/gdb/testsuite/gdb.mi/mi2-amd64-entry-value.exp new file mode 100644 index 0000000..6cfcabf --- /dev/null +++ b/gdb/testsuite/gdb.mi/mi2-amd64-entry-value.exp @@ -0,0 +1,171 @@ +# Copyright (C) 2011 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, see <http://www.gnu.org/licenses/>. + +load_lib mi-support.exp +set MIFLAGS "-i=mi2" + +gdb_exit +if [mi_gdb_start] { + continue +} + +set testfile mi2-amd64-entry-value +set srcfile ${testfile}.s +set opts {} + +if [info exists COMPILE] { + # make check RUNTESTFLAGS="gdb.mi/mi2-amd64-entry-value.exp COMPILE=1" + set srcfile ${testfile}.c + lappend opts debug optimize=-O2 +} elseif { ![istarget x86_64-*-* ] || ![is_lp64_target] } { + verbose "Skipping mi2-amd64-entry-value." + return +} + +set executable ${testfile} +set binfile ${objdir}/${subdir}/${executable} + +if [build_executable ${testfile}.exp ${executable} ${srcfile} $opts] { + return -1 +} + +mi_gdb_reinitialize_dir $srcdir/$subdir +mi_gdb_load ${binfile} + +foreach name {different breakhere_different breakhere_validity breakhere_invalid} { + mi_create_breakpoint $name .* .* .* .* .* .* "break $name" +} + + +# Test various kinds of `set print entry-values'. + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values no" {\^done} "no: set print entry-values" +mi_send_resuming_command "exec-continue" "no: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="5"}} .* .* {.* disp="keep"} "no: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="5"}\]} "no: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "no: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="6"}} .* .* {.* disp="keep"} "no: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="6"}\]} "no: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "no: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost",value="<optimized out>"},{name="born",value="10"}} .* .* {.* disp="keep"} "no: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost",arg="1",value="<optimized out>"},{name="born",arg="1",value="10"}\]} "no: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "no: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv",value="<optimized out>"}} .* .* {.* disp="keep"} "no: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv",arg="1",value="<optimized out>"}\]} "no: invalid: -stack-list-variables" + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values only" {\^done} "only: set print entry-values" +mi_send_resuming_command "exec-continue" "only: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val@entry",value="5"}} .* .* {.* disp="keep"} "only: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val@entry",arg="1",value="5"}\]} "only: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "only: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val@entry",value="5"}} .* .* {.* disp="keep"} "only: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val@entry",arg="1",value="5"}\]} "only: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "only: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost@entry",value="5"},{name="born@entry",value="<optimized out>"}} .* .* {.* disp="keep"} "only: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost@entry",arg="1",value="5"},{name="born@entry",arg="1",value="<optimized out>"}\]} "only: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "only: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv@entry",value="<optimized out>"}} .* .* {.* disp="keep"} "only: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv@entry",arg="1",value="<optimized out>"}\]} "only: invalid: -stack-list-variables" + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values preferred" {\^done} "preferred: set print entry-values" +mi_send_resuming_command "exec-continue" "preferred: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val@entry",value="5"}} .* .* {.* disp="keep"} "preferred: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val@entry",arg="1",value="5"}\]} "preferred: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "preferred: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val@entry",value="5"}} .* .* {.* disp="keep"} "preferred: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val@entry",arg="1",value="5"}\]} "preferred: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "preferred: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost@entry",value="5"},{name="born",value="10"}} .* .* {.* disp="keep"} "preferred: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost@entry",arg="1",value="5"},{name="born",arg="1",value="10"}\]} "preferred: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "preferred: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv@entry",value="<optimized out>"}} .* .* {.* disp="keep"} "preferred: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv@entry",arg="1",value="<optimized out>"}\]} "preferred: invalid: -stack-list-variables" + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values if-needed" {\^done} "if-needed: set print entry-values" +mi_send_resuming_command "exec-continue" "if-needed: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="5"}} .* .* {.* disp="keep"} "if-needed: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="5"}\]} "if-needed: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "if-needed: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="6"}} .* .* {.* disp="keep"} "if-needed: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="6"}\]} "if-needed: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "if-needed: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost@entry",value="5"},{name="born",value="10"}} .* .* {.* disp="keep"} "if-needed: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost@entry",arg="1",value="5"},{name="born",arg="1",value="10"}\]} "if-needed: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "if-needed: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv",value="<optimized out>"}} .* .* {.* disp="keep"} "if-needed: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv",arg="1",value="<optimized out>"}\]} "if-needed: invalid: -stack-list-variables" + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values both" {\^done} "both: set print entry-values" +mi_send_resuming_command "exec-continue" "both: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="5"},{name="val@entry",value="5"}} .* .* {.* disp="keep"} "both: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="5"},{name="val@entry",arg="1",value="5"}\]} "both: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "both: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="6"},{name="val@entry",value="5"}} .* .* {.* disp="keep"} "both: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="6"},{name="val@entry",arg="1",value="5"}\]} "both: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "both: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost",value="<optimized out>"},{name="lost@entry",value="5"},{name="born",value="10"},{name="born@entry",value="<optimized out>"}} .* .* {.* disp="keep"} "both: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost",arg="1",value="<optimized out>"},{name="lost@entry",arg="1",value="5"},{name="born",arg="1",value="10"},{name="born@entry",arg="1",value="<optimized out>"}\]} "both: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "both: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv",value="<optimized out>"},{name="inv@entry",value="<optimized out>"}} .* .* {.* disp="keep"} "both: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv",arg="1",value="<optimized out>"},{name="inv@entry",arg="1",value="<optimized out>"}\]} "both: invalid: -stack-list-variables" + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values compact" {\^done} "compact: set print entry-values" +mi_send_resuming_command "exec-continue" "compact: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="5"},{name="val@entry",value="5"}} .* .* {.* disp="keep"} "compact: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="5"},{name="val@entry",arg="1",value="5"}\]} "compact: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "compact: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="6"},{name="val@entry",value="5"}} .* .* {.* disp="keep"} "compact: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="6"},{name="val@entry",arg="1",value="5"}\]} "compact: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "compact: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost@entry",value="5"},{name="born",value="10"}} .* .* {.* disp="keep"} "compact: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost@entry",arg="1",value="5"},{name="born",arg="1",value="10"}\]} "compact: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "compact: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv",value="<optimized out>"}} .* .* {.* disp="keep"} "compact: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv",arg="1",value="<optimized out>"}\]} "compact: invalid: -stack-list-variables" + +if {[mi_runto main] == -1} { + return -1 +} +mi_gdb_test "-gdb-set print entry-values default" {\^done} "default: set print entry-values" +mi_send_resuming_command "exec-continue" "default: entry_equal: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="5"},{name="val@entry",value="5"}} .* .* {.* disp="keep"} "default: entry_equal: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="5"},{name="val@entry",arg="1",value="5"}\]} "default: entry_equal: -stack-list-variables" +mi_send_resuming_command "exec-continue" "default: entry_different: continue" +mi_expect_stop "breakpoint-hit" .* {{name="val",value="6"},{name="val@entry",value="5"}} .* .* {.* disp="keep"} "default: entry_different: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="val",arg="1",value="6"},{name="val@entry",arg="1",value="5"}\]} "default: entry_different: -stack-list-variables" +mi_send_resuming_command "exec-continue" "default: validity: continue" +mi_expect_stop "breakpoint-hit" .* {{name="lost",value="<optimized out>"},{name="lost@entry",value="5"},{name="born",value="10"}} .* .* {.* disp="keep"} "default: validity: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="lost",arg="1",value="<optimized out>"},{name="lost@entry",arg="1",value="5"},{name="born",arg="1",value="10"}\]} "default: validity: -stack-list-variables" +mi_send_resuming_command "exec-continue" "default: invalid: continue" +mi_expect_stop "breakpoint-hit" .* {{name="inv",value="<optimized out>"}} .* .* {.* disp="keep"} "default: invalid: stop" +mi_gdb_test "-stack-list-variables --all-values" {\^done,variables=\[{name="inv",arg="1",value="<optimized out>"}\]} "default: invalid: -stack-list-variables" |