# Copyright 2008-2022 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 .
standard_testfile .c inline-markers.c
if {[prepare_for_testing "failed to prepare" $testfile \
[list $srcfile $srcfile2] {debug additional_flags=-Winline}]} {
return -1
}
runto_main
get_compiler_info
get_debug_format
if { [skip_inline_var_tests] } {
untested inline-bt.exp
return
}
set no_frames [skip_inline_frame_tests]
set line1 [gdb_get_line_number "set breakpoint 1 here" ${srcfile2}]
gdb_breakpoint $srcfile2:$line1
gdb_test "continue" ".*set breakpoint 1 here.*" "continue to bar 1"
gdb_test "continue" ".*set breakpoint 1 here.*" "continue to bar 2"
if { ! $no_frames } {
gdb_test "backtrace" "#0 bar.*#1 .*func1.*#2 .*main.*" \
"backtrace from bar 2"
gdb_test "up" "#1 .*func1 .* at .*" "up from bar 2"
gdb_test "info frame" ".*inlined into frame.*" "func1 inlined 2"
set pass_re "array = \\{0 \\}"
set kfail_re [multi_line $pass_re \
"array = "]
gdb_test_multiple "info locals" "info locals above bar 2" {
-re -wrap $pass_re {
pass $gdb_test_name
}
-re -wrap $kfail_re {
kfail gdb/25695 $gdb_test_name
}
}
set msg "info args above bar 2"
gdb_test_multiple "info args" $msg {
-re "arg1 = $decimal\r\n$gdb_prompt $" {
pass $msg
}
-re "arg1 = \r\n$gdb_prompt $" {
# GCC 4.3 and later lose location information for arg1. GCC 4.2 is OK.
if { [test_compiler_info "gcc-4-3-*"] || [test_compiler_info "gcc-4-4-*"]} {
setup_xfail *-*-*
}
fail $msg
}
}
} else {
gdb_test "up" "#1 .*main .* at .*" "up from bar 2"
gdb_test "info locals" ".*arg1 = 0.*" "info locals above bar 2"
}
# Make sure that locals on the stack are found. This is an array to
# prevent it from living in a register.
gdb_test "print array\[0\]" "\\\$$decimal = 0" "print local 2"
if { ! $no_frames } {
# Verify that we do not print out variables from the inlined
# function's caller.
gdb_test "print val" "No symbol \"val\" in current context\\." \
"print out of scope local"
}
# Repeat the tests from a depth of two inlined functions, and with a
# more interesting value in the local array.
gdb_test "continue" ".*set breakpoint 1 here.*" "continue to bar 3"
if { ! $no_frames } {
gdb_test "backtrace" "#0 bar.*#1 .*func1.*#2 .*func2.*#3 .*main.*" \
"backtrace from bar 3"
gdb_test "up" "#1 .*func1 .* at .*" "up from bar 3"
gdb_test "info frame" ".*inlined into frame.*" "func1 inlined 3"
set pass_re "array = {$decimal, \[^\r\n\]*}"
set kfail_re [multi_line $pass_re \
"array = "]
gdb_test_multiple "info locals" "info locals above bar 3" {
-re -wrap $pass_re {
pass $gdb_test_name
}
-re -wrap $kfail_re {
kfail gdb/25695 $gdb_test_name
}
}
set msg "info args above bar 3"
gdb_test_multiple "info args" $msg {
-re "arg1 = $decimal\r\n$gdb_prompt $" {
pass $msg
}
-re "arg1 = \r\n$gdb_prompt $" {
# GCC 4.3 and later lose location information for arg1. GCC 4.2 is OK.
if { [test_compiler_info "gcc-4-3-*"] || [test_compiler_info "gcc-4-4-*"]} {
setup_xfail *-*-*
}
fail $msg
}
}
} else {
gdb_test "up" "#1 .*main .* at .*" "up from bar 3"
gdb_test "info locals" ".*arg1 = 1.*" "info locals above bar (3a)"
gdb_test "info locals" ".*arg2 = 184.*" "info locals above bar (3b)"
}
gdb_test "print array\[0\]" "\\\$$decimal = 184" "print local 3"
# Test printing scoped local variables.
proc check_scoped_locals {bp_label pass_re} {
global srcfile
set locals_bp [gdb_get_line_number $bp_label ${srcfile}]
gdb_breakpoint $srcfile:$locals_bp
gdb_continue_to_breakpoint "$bp_label" ".*$srcfile:$locals_bp.*"
set kfail_re [multi_line $pass_re ".*"]
gdb_test_multiple "info locals" "scoped info locals at $bp_label" {
-re -wrap $pass_re {
pass $gdb_test_name
}
-re -wrap $kfail_re {
if {[test_compiler_info {gcc-[0-8]-*-*}]} {
kfail gdb/25695 $gdb_test_name
} else {
fail $gdb_test_name
}
}
}
}
if {! $no_frames } {
check_scoped_locals "bp for locals 1" "loc2 = 20\r\nloc1 = 10"
check_scoped_locals "bp for locals 2" "loc3 = 30\r\nloc2 = 20\r\nloc1 = 10"
check_scoped_locals "bp for locals 3" "loc1 = 10"
}