]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
This commit was manufactured by cvs2svn to create branch 'gdb_7_3-branch'.
authornobody <>
Fri, 6 May 2011 15:06:50 +0000 (15:06 +0000)
committernobody <>
Fri, 6 May 2011 15:06:50 +0000 (15:06 +0000)
Cherrypick from master 2011-05-06 15:06:49 UTC Jan Kratochvil <jan.kratochvil@redhat.com> 'gdb/':
    gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.S
    gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.c
    gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.exp

gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.S [new file with mode: 0644]
gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.c [new file with mode: 0644]
gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.exp [new file with mode: 0644]

diff --git a/gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.S b/gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.S
new file mode 100644 (file)
index 0000000..78d866d
--- /dev/null
@@ -0,0 +1,391 @@
+/* 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/>.  */
+
+       .section .debug_info
+.Lcu1_begin:
+       /* CU header */
+       .4byte  .Lcu1_end - .Lcu1_start         /* Length of Compilation Unit */
+.Lcu1_start:
+       .2byte  2                               /* DWARF Version */
+       .4byte  .Labbrev1_begin                 /* Offset into abbrev section */
+       .byte   4                               /* Pointer size */
+
+       /* CU die */
+       .uleb128 1                              /* Abbrev: DW_TAG_compile_unit */
+       .4byte  .Lline1_begin                   /* DW_AT_stmt_list */
+       .4byte  func_start                      /* DW_AT_low_pc */
+       .4byte  func_end                        /* DW_AT_high_pc */
+       .ascii  "main.c\0"                      /* DW_AT_name */
+       .ascii  "GNU C 4.0.0\0"                 /* DW_AT_producer must be >= 4.0  */
+       .byte   2                               /* DW_AT_language (DW_LANG_C) */
+
+       .uleb128        2                       /* Abbrev: DW_TAG_subprogram */
+       .byte           1                       /* DW_AT_external */
+       .ascii          "func\0"                /* DW_AT_name */
+       .4byte          .Ltype_int-.Lcu1_begin  /* DW_AT_type */
+       .4byte          func_start              /* DW_AT_low_pc */
+       .4byte          func_end                /* DW_AT_high_pc */
+
+/* GDB `has_loclist' detection of -O2 -g code needs to see a DW_AT_location
+   location list.  There may exist -O2 -g CUs still not needing/using any such
+   location list - exactly like this CU.  Make one up.  */
+
+       .uleb128        0x7                     /* (DIE (0x42) DW_TAG_formal_parameter) */
+       .ascii          "param\0"               /* DW_AT_name */
+       .long           .Ltype_int - .Lcu1_begin        /* DW_AT_type */
+       .long           loclist                 /* DW_AT_location */
+
+       .uleb128        4                       /* Abbrev: DW_TAG_inlined_subroutine */
+       .ascii          "inlined\0"             /* DW_AT_name */
+       .4byte          func0                   /* DW_AT_low_pc */
+       .4byte          func1                   /* DW_AT_high_pc */
+       .byte           3                       /* DW_AT_inline (DW_INL_declared_inlined) */
+       .byte           1                       /* DW_AT_call_file */
+       .byte           8                       /* DW_AT_call_line */
+
+       .uleb128        4                       /* Abbrev: DW_TAG_inlined_subroutine */
+       .ascii          "inlined2\0"            /* DW_AT_name */
+       .4byte          func2                   /* DW_AT_low_pc */
+       .4byte          func3                   /* DW_AT_high_pc */
+       .byte           3                       /* DW_AT_inline (DW_INL_declared_inlined) */
+       .byte           1                       /* DW_AT_call_file */
+       .byte           11                      /* DW_AT_call_line */
+
+#ifdef INLINED
+       .uleb128        4                       /* Abbrev: DW_TAG_inlined_subroutine */
+       .ascii          "otherinline\0"         /* DW_AT_name */
+       .4byte          func3                   /* DW_AT_low_pc */
+       .4byte          func_end                /* DW_AT_high_pc */
+       .byte           3                       /* DW_AT_inline (DW_INL_declared_inlined) */
+       .byte           1                       /* DW_AT_call_file */
+       .byte           9                       /* DW_AT_call_line */
+#endif
+
+#ifdef LEXICAL
+       .uleb128        5                       /* Abbrev: DW_TAG_lexical_block */
+       .4byte          func3                   /* DW_AT_low_pc */
+       .4byte          func_end                /* DW_AT_high_pc */
+
+       /* GDB would otherwise ignore the DW_TAG_lexical_block.  */
+       .uleb128        6                       /* Abbrev: DW_TAG_variable */
+       .ascii          "lexicalvar\0"          /* DW_AT_name */
+       .4byte          .Ltype_int-.Lcu1_begin  /* DW_AT_type */
+
+       .byte           0                       /* End of children of DW_TAG_lexical_block */
+#endif
+
+       .byte           0                       /* End of children of DW_TAG_subprogram */
+
+/* Simulate `fund' is also named `func' so that the function name matches and
+   fund's SAL is not discarded in expand_line_sal_maybe.  */
+
+       .uleb128        2                       /* Abbrev: DW_TAG_subprogram */
+       .byte           1                       /* DW_AT_external */
+       .ascii          "func\0"                /* DW_AT_name */
+       .4byte          .Ltype_int-.Lcu1_begin  /* DW_AT_type */
+       .4byte          fund_start              /* DW_AT_low_pc */
+       .4byte          fund_end                /* DW_AT_high_pc */
+
+       .byte           0                       /* End of children of DW_TAG_subprogram */
+
+.Ltype_int:
+       .uleb128        3                       /* Abbrev: DW_TAG_base_type */
+       .ascii          "int\0"                 /* DW_AT_name */
+       .byte           4                       /* DW_AT_byte_size */
+       .byte           5                       /* DW_AT_encoding */
+
+       .byte           0                       /* End of children of CU */
+
+.Lcu1_end:
+
+       .section        .debug_loc
+loclist:
+       /* Reset the location list base address first.  */
+       .long           -1, 0
+
+       .long           func_start, func_end
+       .2byte          2f-1f
+1:     .byte           0x50    /* DW_OP_reg0 */
+2:
+       /* Location list end.  */
+       .long   0, 0
+
+/* Abbrev table */
+       .section .debug_abbrev
+.Labbrev1_begin:
+       .uleb128        1                       /* Abbrev code */
+       .uleb128        0x11                    /* DW_TAG_compile_unit */
+       .byte           1                       /* has_children */
+       .uleb128        0x10                    /* DW_AT_stmt_list */
+       .uleb128        0x6                     /* DW_FORM_data4 */
+       .uleb128        0x11                    /* DW_AT_low_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .uleb128        0x12                    /* DW_AT_high_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .uleb128        0x3                     /* DW_AT_name */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0x25                    /* DW_AT_producer */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0x13                    /* DW_AT_language */
+       .uleb128        0xb                     /* DW_FORM_data1 */
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+       .uleb128        2                       /* Abbrev code */
+       .uleb128        0x2e                    /* DW_TAG_subprogram */
+       .byte           1                       /* has_children */
+       .uleb128        0x3f                    /* DW_AT_external */
+       .uleb128        0xc                     /* DW_FORM_flag */
+       .uleb128        0x3                     /* DW_AT_name */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0x49                    /* DW_AT_type */
+       .uleb128        0x13                    /* DW_FORM_ref4 */
+       .uleb128        0x11                    /* DW_AT_low_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .uleb128        0x12                    /* DW_AT_high_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+       .uleb128        3                       /* Abbrev code */
+       .uleb128        0x24                    /* DW_TAG_base_type */
+       .byte           0                       /* has_children */
+       .uleb128        0x3                     /* DW_AT_name */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0xb                     /* DW_AT_byte_size */
+       .uleb128        0xb                     /* DW_FORM_data1 */
+       .uleb128        0x3e                    /* DW_AT_encoding */
+       .uleb128        0xb                     /* DW_FORM_data1 */
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+       .uleb128        4                       /* Abbrev code */
+       .uleb128        0x1d                    /* DW_TAG_inlined_subroutine */
+       .byte           0                       /* has_children */
+       .uleb128        0x3                     /* DW_AT_name */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0x11                    /* DW_AT_low_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .uleb128        0x12                    /* DW_AT_high_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .uleb128        0x20                    /* DW_AT_inline */
+       .uleb128        0xb                     /* DW_FORM_data1 */
+       .uleb128        0x58                    /* DW_AT_call_file */
+       .uleb128        0xb                     /* DW_FORM_data1 */
+       .uleb128        0x59                    /* DW_AT_call_line */
+       .uleb128        0xb                     /* DW_FORM_data1 */
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+       .uleb128        5                       /* Abbrev code */
+       .uleb128        0x0b                    /* DW_TAG_lexical_block */
+       .byte           1                       /* has_children */
+       .uleb128        0x11                    /* DW_AT_low_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .uleb128        0x12                    /* DW_AT_high_pc */
+       .uleb128        0x1                     /* DW_FORM_addr */
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+       .uleb128        6                       /* Abbrev code */
+       .uleb128        0x34                    /* DW_TAG_variable */
+       .byte           0                       /* has_children */
+       .uleb128        0x3                     /* DW_AT_name */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0x49                    /* DW_AT_type */
+       .uleb128        0x13                    /* DW_FORM_ref4 */
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+       .uleb128        0x7                     /* (abbrev code) */
+       .uleb128        0x5                     /* (TAG: DW_TAG_formal_parameter) */
+       .byte           0x0                     /* DW_children_no */
+       .uleb128        0x3                     /* DW_AT_name */
+       .uleb128        0x8                     /* DW_FORM_string */
+       .uleb128        0x49                    /* (DW_AT_type) */
+       .uleb128        0x13                    /* (DW_FORM_ref4) */
+       .uleb128        0x02                    /* (DW_AT_location) */
+       .uleb128        0x06                    /* (DW_FORM_data4) */
+       .byte           0x0
+       .byte           0x0
+
+       .byte           0x0                     /* Terminator */
+       .byte           0x0                     /* Terminator */
+
+/* Line table */
+       .section .debug_line
+.Lline1_begin:
+       .4byte          .Lline1_end - .Lline1_start     /* Initial length */
+.Lline1_start:
+       .2byte          2                       /* Version */
+       .4byte          .Lline1_lines - .Lline1_hdr     /* header_length */
+.Lline1_hdr:
+       .byte           1                       /* Minimum insn length */
+       .byte           1                       /* default_is_stmt */
+       .byte           1                       /* line_base */
+       .byte           1                       /* line_range */
+       .byte           0x10                    /* opcode_base */
+
+       /* Standard lengths */
+       .byte           0
+       .byte           1
+       .byte           1
+       .byte           1
+       .byte           1
+       .byte           0
+       .byte           0
+       .byte           0
+       .byte           1
+       .byte           0
+       .byte           0
+       .byte           1
+       .byte           0
+       .byte           0
+       .byte           0
+
+       /* Include directories */
+       .byte           0
+
+       /* File names */
+       .ascii          "main.c\0"
+       .uleb128        0
+       .uleb128        0
+       .uleb128        0
+
+       .ascii          "other.c\0"
+       .uleb128        0
+       .uleb128        0
+       .uleb128        0
+
+       .byte           0
+
+.Lline1_lines:
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          func_start
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        4       /* ... to 5 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          func0
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        2
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        -4      /* ... to 1 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          func1
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        1
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        8       /* ... to 9 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          func2
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        2
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        -8      /* ... to 1 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          func3
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        1
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        8       /* ... to 9 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          func_end
+
+/* Equivalent copy but renamed s/func/fund/.  */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          fund_start
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        -4      /* ... to 5 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          fund0
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        2
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        -4      /* ... to 1 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          fund1
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        1
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        8       /* ... to 9 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          fund2
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        2
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        -8      /* ... to 1 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          fund3
+       .byte           4       /* DW_LNS_set_file */
+       .uleb128        1
+       .byte           3       /* DW_LNS_advance_line */
+       .sleb128        8       /* ... to 9 */
+       .byte           1       /* DW_LNS_copy */
+
+       .byte           0       /* DW_LNE_set_address */
+       .uleb128        5
+       .byte           2
+       .4byte          fund_end
+
+/* Line numbering end.  */
+
+       .byte           0       /* DW_LNE_end_of_sequence */
+       .uleb128        1
+       .byte           1
+
+.Lline1_end:
diff --git a/gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.c b/gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.c
new file mode 100644 (file)
index 0000000..fe814f2
--- /dev/null
@@ -0,0 +1,58 @@
+/* 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;
+
+asm ("func_start: .globl func_start\n");
+static int
+func (void)
+{
+  v++;
+asm ("func0: .globl func0\n");
+  v++;
+asm ("func1: .globl func1\n");
+  v++;
+asm ("func2: .globl func2\n");
+  v++;
+asm ("func3: .globl func3\n");
+  return v;
+}
+asm ("func_end: .globl func_end\n");
+
+/* Equivalent copy but renamed s/func/fund/.  */
+
+asm ("fund_start: .globl fund_start\n");
+static int
+fund (void)
+{
+  v++;
+asm ("fund0: .globl fund0\n");
+  v++;
+asm ("fund1: .globl fund1\n");
+  v++;
+asm ("fund2: .globl fund2\n");
+  v++;
+asm ("fund3: .globl fund3\n");
+  return v;
+}
+asm ("fund_end: .globl fund_end\n");
+
+int
+main (void)
+{
+  return func () + fund ();
+}
diff --git a/gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.exp b/gdb/testsuite/gdb.dwarf2/dw2-skip-prologue.exp
new file mode 100644 (file)
index 0000000..a1b0fb9
--- /dev/null
@@ -0,0 +1,74 @@
+# 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/>.
+load_lib dwarf.exp
+
+# Test multiple location breakpoints vs. prologue analysis on -O2 -g code.
+# when the first statement of a function is an inlined function GDB could
+# crash.  Map of this testcase:
+# 
+# File name                            Line number    Starting address
+# main.c                                         5    func_start
+# other.c                                        1    func0
+#      `inlined' called at main.c line 8
+# main.c                                         9    func1
+#      func1 = Breakpoint location 1
+# other.c                                        1    func2
+#      `inlined2' called at main.c line 11
+# main.c                                         9    func3
+#      func3 = Breakpoint location 2
+#      `otherinline' called at main.c line 9
+# end of main                                         func_end
+
+# This test can only be run on targets which support DWARF-2 and use gas.
+if {![dwarf2_support]} {
+    return 0  
+}
+
+set testfile "dw2-skip-prologue"
+set executable ${testfile}
+set binfile ${objdir}/${subdir}/${executable}
+
+if {[build_executable ${testfile}.exp ${executable} "${testfile}.c ${testfile}.S" {additional_flags=-DINLINED}] == -1} {
+    return -1
+}
+
+# We need those symbols global to access them from the .S file.
+set test "strip stub symbols"
+set objcopy_program [transform objcopy]
+set result [catch "exec $objcopy_program                                                       \
+                       -N func0 -N func1 -N func2 -N func3         -N func_start -N func_end   \
+                       -N fund0 -N fund1 -N fund2 -N fund3 -N fund -N fund_start               \
+                       ${binfile}" output]
+verbose "result is $result"
+verbose "output is $output"
+if {$result != 0} {
+    fail $test
+    return
+}
+pass $test
+
+clean_restart $executable
+
+if ![runto_main] {
+    return -1
+}
+
+gdb_breakpoint "func"
+gdb_continue_to_breakpoint "func"
+
+# Sanity check GDB has really found 2 locations
+gdb_test {info break $bpnum} "\r\n2\\.1\[ \t\]\[^\n\]*\r\n2\\.2\[ \t\]\[^\n\]*" "2 locations found"
+
+gdb_test "p v" " = 0" "no statement got executed"