This is the mail archive of the gdb-cvs@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[binutils-gdb] gdb.base/break.exp: fix last "info break" test failure on Ubuntu 16.04


https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=fc413dc467e4c46013f6e5a60dc5db24d63f72ea

commit fc413dc467e4c46013f6e5a60dc5db24d63f72ea
Author: Joel Brobecker <brobecker@adacore.com>
Date:   Mon Jan 29 23:03:09 2018 -0500

    gdb.base/break.exp: fix last "info break" test failure on Ubuntu 16.04
    
    The last test of this testcase fails when run on Ubuntu 16.04 using
    the system compiler (16.04):
    
        FAIL: gdb.base/break.exp: verify that they were cleared
    
    This is because the testcase expected that a breakpoint on line 47 of break.c...
    
        printf ("%d\n", factorial (atoi ("6")));  /* set breakpoint 1 here */
    
    ... would actually be inserted on an instruction belonging to
    that line. However, what actually happens is that system GCC on
    that version of Ubuntu ends up inlining everything, including
    the call to printf, thus reporting every instruction of generated
    for this line of code as belonging to a different function. As
    a result, GDB ends up insering the breakpoint on the next line
    of code, which is line 49:
    
        (gdb) break break.c:$l
        Breakpoint 3 at 0x4005c1: file /[...]/gdb.base/break.c, line 49.
    
    This causes a spurious failure in the "info break" test later on,
    as it assumed that the breakpoint above is inserted on line 47:
    
        gdb_test "info break" "$srcfile:$line" "verify that they were cleared"
    
    This patch fixes the issue by saving the actual source location where
    the breakpoint was inserted.
    
    gdb/testsuite/ChangeLog:
    
            * gdb.base/break.exp: Save the location where the breakpoint
            on break.c:47 was actually inserted when debugging the version
            compiled at -O2 and use it in the expected output of the "info
            break" test performed soon after.
    
    tested on x86_64-linux, with two configurations:
      - Ubuntu 16.04 with the system compiler (breakpoint lands on line 49)
      - Ubuntu 16.04 with GCC 7.3.1 (breakpoint lands on line 47)

Diff:
---
 gdb/testsuite/ChangeLog          |  7 +++++++
 gdb/testsuite/gdb.base/break.exp | 17 +++++++++++++++--
 2 files changed, 22 insertions(+), 2 deletions(-)

diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog
index 0f02f4a..52a689f 100644
--- a/gdb/testsuite/ChangeLog
+++ b/gdb/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2018-01-30  Joel Brobecker  <brobecker@adacore.com>
+
+	* gdb.base/break.exp: Save the location where the breakpoint
+	on break.c:47 was actually inserted when debugging the version
+	compiled at -O2 and use it in the expected output of the "info
+	break" test performed soon after.
+
 2018-01-22  Pedro Alves  <palves@redhat.com>
 	    Sergio Durigan Junior  <sergiodj@redhat.com>
 
diff --git a/gdb/testsuite/gdb.base/break.exp b/gdb/testsuite/gdb.base/break.exp
index 8a21222..7f035a8 100644
--- a/gdb/testsuite/gdb.base/break.exp
+++ b/gdb/testsuite/gdb.base/break.exp
@@ -847,7 +847,20 @@ gdb_test_multiple "" $test {
 #
 set line [gdb_get_line_number "set breakpoint 1 here"]
 gdb_test_no_output "set \$l = $line"
-gdb_breakpoint ${srcfile}:\$l
+
+set line_actual "-1"
+set test "break ${srcfile}:\$l"
+gdb_test_multiple "$test" $test {
+    -re "Breakpoint $decimal at $hex: file .*break\\.c, line ($decimal)\\.\r\n$gdb_prompt $" {
+        # Save the actual line number on which the breakpoint was
+        # actually set. On some systems (Eg: Ubuntu 16.04 with GCC
+        # version 5.4.0), that line gets completely inlined, including
+        # the call to printf, and so we end up inserting the breakpoint
+        # on one of the following lines instead.
+        set line_actual $expect_out(1,string)
+        pass $test
+    }
+}
 
 gdb_test_no_output "set \$foo=81.5" \
     "set convenience variable \$foo to 81.5"
@@ -865,4 +878,4 @@ gdb_test "commands\nend" ">end" "clear breakpoint commands"
 # We verify that the commands were cleared by ensuring that the last
 # breakpoint's location ends the output -- if there were commands,
 # they would have been printed after the location.
-gdb_test "info break" "$srcfile:$line" "verify that they were cleared"
+gdb_test "info break" "$srcfile:$line_actual" "verify that they were cleared"


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]