| # Copyright 2003, 2004 |
| # 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 |
| # (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 |
| |
| # This file was created by Jeff Johnston. (jjohnstn@redhat.com) |
| # The shared library compilation portion was copied from shlib-call.exp which was |
| # written by Elena Zannoni (ezannoni@redhat.com). |
| |
| if $tracelevel then { |
| strace $tracelevel |
| } |
| |
| # |
| # test running programs |
| # |
| set prms_id 0 |
| set bug_id 0 |
| |
| # are we on a target board? |
| if ![isnative] then { |
| return 0 |
| } |
| |
| set testfile "pending" |
| set libfile "pendshr" |
| set srcfile ${testfile}.c |
| set binfile ${objdir}/${subdir}/${testfile} |
| |
| if [get_compiler_info ${binfile}] { |
| return -1 |
| } |
| |
| if { [gdb_compile "${srcdir}/${subdir}/${srcfile}" "${binfile}.o" object {debug}] != "" } { |
| gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." |
| } |
| |
| # Build the shared libraries this test case needs. |
| # |
| |
| if {$gcc_compiled == 0} { |
| if [istarget "hppa*-hp-hpux*"] then { |
| set additional_flags "additional_flags=+z" |
| } elseif { [istarget "mips-sgi-irix*"] } { |
| # Disable SGI compiler's implicit -Dsgi |
| set additional_flags "additional_flags=-Usgi" |
| } else { |
| # don't know what the compiler is... |
| set additional_flags "" |
| } |
| } else { |
| if { ([istarget "powerpc*-*-aix*"] |
| || [istarget "rs6000*-*-aix*"]) } { |
| set additional_flags "" |
| } else { |
| set additional_flags "additional_flags=-fpic" |
| } |
| } |
| |
| if {[gdb_compile "${srcdir}/${subdir}/${libfile}.c" "${objdir}/${subdir}/${libfile}.o" object [list debug $additional_flags]] != ""} { |
| gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." |
| } |
| |
| if [istarget "hppa*-*-hpux*"] { |
| remote_exec build "ld -b ${objdir}/${subdir}/${libfile}.o -o ${objdir}/${subdir}/${libfile}.sl" |
| } else { |
| set additional_flags "additional_flags=-shared" |
| if {[gdb_compile "${objdir}/${subdir}/${libfile}.o" "${objdir}/${subdir}/${libfile}.sl" executable [list debug $additional_flags]] != ""} { |
| gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." |
| } |
| } |
| |
| if { ($gcc_compiled |
| && ([istarget "powerpc*-*-aix*"] |
| || [istarget "rs6000*-*-aix*"] )) } { |
| set additional_flags "additional_flags=-L${objdir}/${subdir}" |
| } elseif { [istarget "mips-sgi-irix*"] } { |
| set additional_flags "additional_flags=-rpath ${objdir}/${subdir}" |
| } else { |
| set additional_flags "" |
| } |
| if {[gdb_compile "${objdir}/${subdir}/${testfile}.o ${objdir}/${subdir}/${libfile}.sl" "${binfile}" executable [list debug $additional_flags]] != ""} { |
| gdb_suppress_entire_file "Testcase compile failed, so all tests in this file will automatically fail." |
| } |
| |
| gdb_exit |
| gdb_start |
| gdb_reinitialize_dir $srcdir/$subdir |
| gdb_load ${binfile} |
| |
| if [target_info exists gdb_stub] { |
| gdb_step_for_stub; |
| } |
| # |
| # Test setting, querying, and modifying pending breakpoints |
| # |
| |
| gdb_test_multiple "break pendfunc1" "set pending breakpoint" { |
| -re ".*Make breakpoint pending.*y or \\\[n\\\]. $" { |
| gdb_test "y" "Breakpoint.*pendfunc1.*pending." "set pending breakpoint" |
| } |
| } |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*pendfunc1.*" \ |
| "single pending breakpoint info" |
| |
| # |
| # Test breaking at existing function |
| # |
| |
| set mainline [gdb_get_line_number "break main here"] |
| |
| gdb_test "break main" \ |
| "Breakpoint.*at.* file .*$srcfile, line $mainline.*" \ |
| "breakpoint function" |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*pendfunc1.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline" \ |
| "pending plus real breakpoint info" |
| |
| |
| # |
| # Test not setting a pending breakpoint |
| # |
| gdb_test_multiple "break pendfunc2" "Don't set pending breakpoint" { |
| -re ".*Make breakpoint pending.*y or \\\[n\\\]. $" { |
| gdb_test "n" "" "Don't set pending breakpoint" |
| } |
| } |
| |
| # |
| # Add condition to pending breakpoint |
| # |
| |
| gdb_test "condition 1 k == 1" "" |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*pendfunc1.* |
| \[\t \]+stop only if k == 1.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline" \ |
| "pending plus condition" |
| |
| # |
| # Disable pending breakpoint |
| # |
| |
| gdb_test "disable 1" "" |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep n.*PENDING.*pendfunc1.* |
| \[\t \]+stop only if k == 1.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline" \ |
| "pending disabled" |
| |
| # |
| # Add commands to pending breakpoint |
| # |
| gdb_test "commands 1\nprint k\nend" "" \ |
| "Set commands for pending breakpoint" |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep n.*PENDING.*pendfunc1.* |
| \[\t \]+stop only if k == 1.* |
| \[\t \]+print k.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline" \ |
| "pending disabled plus commands" |
| |
| # |
| # Try a pending break for a line in a source file with a condition |
| # |
| |
| gdb_test_multiple "break pendshr.c:26 if x > 3" "Set pending breakpoint 2" { |
| -re ".*Make breakpoint pending.*y or \\\[n\\\]. $" { |
| gdb_test "y" "Breakpoint.*pendshr.c:26.*pending." \ |
| "Set pending breakpoint 2" |
| } |
| } |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep n.*PENDING.*pendfunc1.* |
| \[\t \]+stop only if k == 1.* |
| \[\t \]+print k.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*pendshr.c:26 if x > 3.*" \ |
| "multiple pending breakpoints" |
| |
| |
| # |
| # Try a pending break for a line in a source file with ignore count: |
| # |
| |
| gdb_test_multiple "break pendshr.c:27" "Set pending breakpoint 3" { |
| -re ".*Make breakpoint pending.*y or \\\[n\\\]. $" { |
| gdb_test "y" "Breakpoint.*pendshr.c:27.*pending." \ |
| "Set pending breakpoint 3" |
| } |
| } |
| |
| gdb_test {ignore $bpnum 2} "Will ignore next 2 crossings of breakpoint .*" \ |
| "set ignore count on pending breakpoint 3" |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep n.*PENDING.*pendfunc1.* |
| \[\t \]+stop only if k == 1.* |
| \[\t \]+print k.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*pendshr.c:26 if x > 3.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*pendshr.c:27.*ignore next 2 hits.*" \ |
| "multiple pending breakpoints 2" |
| |
| # |
| # Run to main which should resolve a pending breakpoint |
| # |
| |
| gdb_test "run" \ |
| "Breakpoint.*at.* |
| Pending breakpoint \"pendshr.c:26 if x > 3\" resolved.* |
| Breakpoint.*, main.*$mainline.*" \ |
| "running to main" |
| |
| # |
| # Re-enable the first pending breakpoint which should resolve |
| # |
| |
| gdb_test "enable 1" \ |
| "Breakpoint.*at.* |
| Pending breakpoint \"pendfunc1.* resolved.*" \ |
| "re-enabling pending breakpoint that can resolve instantly" |
| |
| # |
| # Continue to verify conditionals and commands for breakpoints are honored |
| # |
| |
| gdb_test "continue" \ |
| ".*Breakpoint.*pendfunc1.*at.*pendshr.c:26.*4;" \ |
| "continue to resolved breakpoint 2" |
| |
| gdb_test "continue" \ |
| ".*Breakpoint.*pendfunc1.*at.*pendshr.c:26.* |
| \[$\]1 = 1." \ |
| "continue to resolved breakpoint 1" |
| |
| # |
| # Disable the other two breakpoints, and continue to the one with |
| # the ignore count. Make sure you hit it the third time, x should |
| # be 3 then. |
| # |
| |
| gdb_test "disable 7" "" "Disable other breakpoints" |
| gdb_test "disable 5" "" "Disable other breakpoints" |
| |
| gdb_test "continue" \ |
| {.*Breakpoint.*pendfunc1.*\(x=3\) at.*pendshr.c:27.*printf.*;} \ |
| "continue to resolved breakpoint 3" |
| |
| delete_breakpoints |
| |
| gdb_breakpoint "main" |
| |
| # |
| # Set non-existent pending breakpoint |
| # |
| gdb_test_multiple "break imaginary" "set imaginary pending breakpoint" { |
| -re ".*Make breakpoint pending.*y or \\\[n\\\]. $" { |
| gdb_test "y" "Breakpoint.*imaginary.*pending." \ |
| "set imaginary pending breakpoint" |
| } |
| } |
| |
| # |
| # rerun program and make sure that any pending breakpoint remains and no |
| # error messages are issued for the missing function |
| # |
| |
| rerun_to_main |
| |
| gdb_test "info break" \ |
| "Num Type\[ \]+Disp Enb Address\[ \]+What.* |
| \[0-9\]+\[\t \]+breakpoint keep y.* in main at .*$srcfile:$mainline.* |
| \[0-9\]+\[\t \]+breakpoint keep y.*PENDING.*imaginary.*" \ |
| "verify pending breakpoint after restart" |