[gdb] Fix crash on optimized-out entry data values (BZ 1111910).

Jan Kratochvil jankratochvil at fedoraproject.org
Mon Jun 30 21:30:30 UTC 2014


commit 2a0fd8ad849b3ce9b3cfbf66342a74f20cb85c1d
Author: Jan Kratochvil <jan.kratochvil at redhat.com>
Date:   Mon Jun 30 23:30:31 2014 +0200

    Fix crash on optimized-out entry data values (BZ 1111910).

 gdb-entrydataoptimizedout.patch |  635 +++++++++++++++++++++++++++++++++++++++
 gdb.spec                        |    9 +-
 2 files changed, 643 insertions(+), 1 deletions(-)
---
diff --git a/gdb-entrydataoptimizedout.patch b/gdb-entrydataoptimizedout.patch
new file mode 100644
index 0000000..e659ebc
--- /dev/null
+++ b/gdb-entrydataoptimizedout.patch
@@ -0,0 +1,635 @@
+http://sourceware.org/ml/gdb-patches/2014-06/msg00797.html
+Subject: [patch+7.8] Fix crash on optimized-out entry data values
+
+
+--jRHKVT23PllUwdXP
+Content-Type: text/plain; charset=us-ascii
+Content-Disposition: inline
+
+Hi,
+
+https://bugzilla.redhat.com/show_bug.cgi?id=1111910
+
+this can happen for real world -O2 -g executables:
+#9  0x0000003b6e0998b2 in wxEntry (argc=@0x7fffffffd86c: 1,
+    argc at entry=@0x7fffffffd86c: <optimized out>, 
+                                ^^^^^^^^^^^^^^^
+    argv=<optimized out>) at src/common/init.cpp:460
+
+GDB did crash in such case.
+
+No regressions on {x86_64,x86_64-m32}-fedorarawhide-linux-gnu.
+
+
+
+Jan
+
+--jRHKVT23PllUwdXP
+Content-Type: text/plain; charset=us-ascii
+Content-Disposition: inline; filename="entrydataoptimizedout.patch"
+
+gdb/
+2014-06-22  Jan Kratochvil  <jan.kratochvil at redhat.com>
+
+	Fix crash on optimized-out entry data values.
+	* stack.c (read_frame_arg): Check value_optimized_out before calling
+	value_available_contents_eq.
+	* value.c (value_available_contents_bits_eq): Check OPTIMIZED_OUT for
+	VAL1 and VAL2.
+	* value.h (value_available_contents_eq): Mention optimized out values
+	in function comment.
+
+gdb/testsuite/
+2014-06-22  Jan Kratochvil  <jan.kratochvil at redhat.com>
+
+	Fix crash on optimized-out entry data values.
+	* gdb.arch/amd64-entry-value-paramref.S: New file.
+	* gdb.arch/amd64-entry-value-paramref.cc: New file.
+	* gdb.arch/amd64-entry-value-paramref.exp: New file.
+
+diff --git a/gdb/stack.c b/gdb/stack.c
+index 0d6d8e7..a0f3513 100644
+--- a/gdb/stack.c
++++ b/gdb/stack.c
+@@ -413,6 +413,7 @@ read_frame_arg (struct symbol *sym, struct frame_info *frame,
+ 		      /* If the reference addresses match but dereferenced
+ 			 content does not match print them.  */
+ 		      if (val != val_deref
++		          && !value_optimized_out (entryval_deref)
+ 			  && value_available_contents_eq (val_deref, 0,
+ 							  entryval_deref, 0,
+ 						      TYPE_LENGTH (type_deref)))
+diff --git a/gdb/value.c b/gdb/value.c
+index 557056f..74b9d56 100644
+--- a/gdb/value.c
++++ b/gdb/value.c
+@@ -700,6 +700,8 @@ value_available_contents_bits_eq (const struct value *val1, int offset1,
+ 
+   /* See function description in value.h.  */
+   gdb_assert (!val1->lazy && !val2->lazy);
++  gdb_assert (!val1->optimized_out);
++  gdb_assert (!val2->optimized_out);
+ 
+   while (length > 0)
+     {
+diff --git a/gdb/value.h b/gdb/value.h
+index c2e9faf..80a2225 100644
+--- a/gdb/value.h
++++ b/gdb/value.h
+@@ -499,7 +499,7 @@ extern void mark_value_bits_unavailable
+    read it.  As this routine is used by printing routines, which may
+    be printing values in the value history, long after the inferior is
+    gone, it works with const values.  Therefore, this routine must not
+-   be called with lazy values.  */
++   be called with lazy or optimized_out values.  */
+ 
+ extern int value_available_contents_eq (const struct value *val1, LONGEST offset1,
+ 					const struct value *val2, LONGEST offset2,
+diff --git a/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.S b/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.S
+new file mode 100644
+index 0000000..6daee63
+--- /dev/null
++++ b/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.S
+@@ -0,0 +1,459 @@
++/* This testcase is part of GDB, the GNU debugger.
++
++   Copyright 2014 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/>.  */
++
++/* This file is compiled from gdb.arch/amd64-entry-value-paramref.cc
++   using -g -dA -S -O2.
++   Additionally it has been patched.  */
++
++	.file	"amd64-entry-value-paramref.cc"
++	.text
++.Ltext0:
++	.p2align 4,,15
++	.type	_ZL3barRi.constprop.0, @function
++_ZL3barRi.constprop.0:
++.LFB2:
++	.file 1 "gdb.arch/amd64-entry-value-paramref.cc"
++	# gdb.arch/amd64-entry-value-paramref.cc:21
++	.loc 1 21 0
++	.cfi_startproc
++.LVL0:
++# BLOCK 2 freq:10000 seq:0
++# PRED: ENTRY [100.0%]  (FALLTHRU)
++	# gdb.arch/amd64-entry-value-paramref.cc:23
++	.loc 1 23 0
++	movl	vv(%rip), %eax
++	# gdb.arch/amd64-entry-value-paramref.cc:24
++	.loc 1 24 0
++	movq	%rdi, p(%rip)
++	# gdb.arch/amd64-entry-value-paramref.cc:23
++	.loc 1 23 0
++	addl	$1, %eax
++	movl	%eax, vv(%rip)
++	# gdb.arch/amd64-entry-value-paramref.cc:25
++	.loc 1 25 0
++	movl	(%rdi), %eax
++# SUCC: EXIT [100.0%] 
++	# gdb.arch/amd64-entry-value-paramref.cc:26
++	.loc 1 26 0
++	ret
++	.cfi_endproc
++.LFE2:
++	.size	_ZL3barRi.constprop.0, .-_ZL3barRi.constprop.0
++	.section	.text.startup,"ax", at progbits
++	.p2align 4,,15
++	.globl	main
++	.type	main, @function
++main:
++.LFB1:
++	# gdb.arch/amd64-entry-value-paramref.cc:30
++	.loc 1 30 0
++	.cfi_startproc
++# BLOCK 2 freq:10000 seq:0
++# PRED: ENTRY [100.0%]  (FALLTHRU)
++	subq	$16, %rsp
++	.cfi_def_cfa_offset 24
++.LBB2:
++	# gdb.arch/amd64-entry-value-paramref.cc:32
++	.loc 1 32 0
++	leaq	12(%rsp), %rdi
++	# gdb.arch/amd64-entry-value-paramref.cc:31
++	.loc 1 31 0
++	movl	$10, 12(%rsp)
++	# gdb.arch/amd64-entry-value-paramref.cc:32
++	.loc 1 32 0
++	call	_ZL3barRi.constprop.0
++.LVL1:
++.LBE2:
++	# gdb.arch/amd64-entry-value-paramref.cc:33
++	.loc 1 33 0
++	addq	$16, %rsp
++	.cfi_def_cfa_offset 8
++# SUCC: EXIT [100.0%] 
++	ret
++	.cfi_endproc
++.LFE1:
++	.size	main, .-main
++	.globl	p
++	.bss
++	.align 8
++	.type	p, @object
++	.size	p, 8
++p:
++	.zero	8
++	.globl	vv
++	.align 4
++	.type	vv, @object
++	.size	vv, 4
++vv:
++	.zero	4
++	.text
++.Letext0:
++	.section	.debug_info,"", at progbits
++.Ldebug_info0:
++	.long	.Linfo_end - .Linfo_start	# Length of Compilation Unit Info
++.Linfo_start:
++	.value	0x4	# DWARF version number
++	.long	.Ldebug_abbrev0	# Offset Into Abbrev. Section
++	.byte	0x8	# Pointer Size (in bytes)
++	.uleb128 0x1	# (DIE (0xb) DW_TAG_compile_unit)
++	.long	.LASF0	# DW_AT_producer: "GNU C++ 4.8.2 20131212 (Red Hat 4.8.2-7) -mtune=generic -march=x86-64 -g -O2"
++	.byte	0x4	# DW_AT_language
++	.long	.LASF1	# DW_AT_name: "gdb.arch/amd64-entry-value-paramref.cc"
++	.long	.LASF2	# DW_AT_comp_dir: ""
++	.long	.Ldebug_ranges0+0	# DW_AT_ranges
++	.quad	0	# DW_AT_low_pc
++	.long	.Ldebug_line0	# DW_AT_stmt_list
++DIE29:	.uleb128 0x2	# (DIE (0x29) DW_TAG_subprogram)
++	.ascii "bar\0"	# DW_AT_name
++	.byte	0x1	# DW_AT_decl_file (gdb.arch/amd64-entry-value-paramref.cc)
++	.byte	0x15	# DW_AT_decl_line
++	.long	DIE45	# DW_AT_type
++	.byte	0x1	# DW_AT_inline
++DIE39:	.uleb128 0x3	# (DIE (0x39) DW_TAG_formal_parameter)
++	.ascii "ref\0"	# DW_AT_name
++	.byte	0x1	# DW_AT_decl_file (gdb.arch/amd64-entry-value-paramref.cc)
++	.byte	0x15	# DW_AT_decl_line
++	.long	DIE4c	# DW_AT_type
++	.byte	0	# end of children of DIE 0x29
++DIE45:	.uleb128 0x4	# (DIE (0x45) DW_TAG_base_type)
++	.byte	0x4	# DW_AT_byte_size
++	.byte	0x5	# DW_AT_encoding
++	.ascii "int\0"	# DW_AT_name
++DIE4c:	.uleb128 0x5	# (DIE (0x4c) DW_TAG_const_type)
++	.long	DIE51	# DW_AT_type
++DIE51:	.uleb128 0x6	# (DIE (0x51) DW_TAG_reference_type)
++	.byte	0x8	# DW_AT_byte_size
++	.long	DIE45	# DW_AT_type
++DIE57:	.uleb128 0x7	# (DIE (0x57) DW_TAG_subprogram)
++	.long	DIE29	# DW_AT_abstract_origin
++	.quad	.LFB2	# DW_AT_low_pc
++	.quad	.LFE2-.LFB2	# DW_AT_high_pc
++	.uleb128 0x1	# DW_AT_frame_base
++	.byte	0x9c	# DW_OP_call_frame_cfa
++			# DW_AT_GNU_all_call_sites
++DIE72:	.uleb128 0x8	# (DIE (0x72) DW_TAG_formal_parameter)
++	.long	DIE39	# DW_AT_abstract_origin
++	.uleb128 0x1	# DW_AT_location
++	.byte	0x55	# DW_OP_reg5
++	.byte	0	# end of children of DIE 0x57
++DIE7a:	.uleb128 0x9	# (DIE (0x7a) DW_TAG_subprogram)
++			# DW_AT_external
++	.long	.LASF3	# DW_AT_name: "main"
++	.byte	0x1	# DW_AT_decl_file (gdb.arch/amd64-entry-value-paramref.cc)
++	.byte	0x1d	# DW_AT_decl_line
++	.long	DIE45	# DW_AT_type
++	.quad	.LFB1	# DW_AT_low_pc
++	.quad	.LFE1-.LFB1	# DW_AT_high_pc
++	.uleb128 0x1	# DW_AT_frame_base
++	.byte	0x9c	# DW_OP_call_frame_cfa
++			# DW_AT_GNU_all_call_sites
++DIE9b:	.uleb128 0xa	# (DIE (0x9b) DW_TAG_lexical_block)
++	.quad	.LBB2	# DW_AT_low_pc
++	.quad	.LBE2-.LBB2	# DW_AT_high_pc
++DIEac:	.uleb128 0xb	# (DIE (0xac) DW_TAG_variable)
++	.ascii "var\0"	# DW_AT_name
++	.byte	0x1	# DW_AT_decl_file (gdb.arch/amd64-entry-value-paramref.cc)
++	.byte	0x1f	# DW_AT_decl_line
++	.long	DIE45	# DW_AT_type
++	.uleb128 0x2	# DW_AT_location
++	.byte	0x91	# DW_OP_fbreg
++	.sleb128 -12
++DIEba:	.uleb128 0xc	# (DIE (0xba) DW_TAG_GNU_call_site)
++	.quad	.LVL1	# DW_AT_low_pc
++	.long	DIE57	# DW_AT_abstract_origin
++DIEc7:	.uleb128 0xd	# (DIE (0xc7) DW_TAG_GNU_call_site_parameter)
++	.uleb128 0x1	# DW_AT_location
++	.byte	0x55	# DW_OP_reg5
++	.uleb128 0x2	# DW_AT_GNU_call_site_value
++	.byte	0x91	# DW_OP_fbreg
++	.sleb128 -12
++#if 0
++	.uleb128 0x1	# DW_AT_GNU_call_site_data_value
++	.byte	0x3a	# DW_OP_lit10
++#else
++	.uleb128 1f - 2f	# DW_AT_GNU_call_site_data_value
++2:
++	.byte	0xf3	# DW_OP_GNU_entry_value
++	.uleb128 1f - 3f
++3:
++	.byte	0x55	# DW_OP_reg5
++1:
++#endif
++	.byte	0	# end of children of DIE 0xba
++	.byte	0	# end of children of DIE 0x9b
++	.byte	0	# end of children of DIE 0x7a
++DIEd2:	.uleb128 0xe	# (DIE (0xd2) DW_TAG_variable)
++	.ascii "vv\0"	# DW_AT_name
++	.byte	0x1	# DW_AT_decl_file (gdb.arch/amd64-entry-value-paramref.cc)
++	.byte	0x12	# DW_AT_decl_line
++	.long	DIEe6	# DW_AT_type
++			# DW_AT_external
++	.uleb128 0x9	# DW_AT_location
++	.byte	0x3	# DW_OP_addr
++	.quad	vv
++DIEe6:	.uleb128 0xf	# (DIE (0xe6) DW_TAG_volatile_type)
++	.long	DIE45	# DW_AT_type
++DIEeb:	.uleb128 0xe	# (DIE (0xeb) DW_TAG_variable)
++	.ascii "p\0"	# DW_AT_name
++	.byte	0x1	# DW_AT_decl_file (gdb.arch/amd64-entry-value-paramref.cc)
++	.byte	0x12	# DW_AT_decl_line
++	.long	DIEfe	# DW_AT_type
++			# DW_AT_external
++	.uleb128 0x9	# DW_AT_location
++	.byte	0x3	# DW_OP_addr
++	.quad	p
++DIEfe:	.uleb128 0x10	# (DIE (0xfe) DW_TAG_pointer_type)
++	.byte	0x8	# DW_AT_byte_size
++	.long	DIEe6	# DW_AT_type
++	.byte	0	# end of children of DIE 0xb
++.Linfo_end:
++	.section	.debug_abbrev,"", at progbits
++.Ldebug_abbrev0:
++	.uleb128 0x1	# (abbrev code)
++	.uleb128 0x11	# (TAG: DW_TAG_compile_unit)
++	.byte	0x1	# DW_children_yes
++	.uleb128 0x25	# (DW_AT_producer)
++	.uleb128 0xe	# (DW_FORM_strp)
++	.uleb128 0x13	# (DW_AT_language)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0xe	# (DW_FORM_strp)
++	.uleb128 0x1b	# (DW_AT_comp_dir)
++	.uleb128 0xe	# (DW_FORM_strp)
++	.uleb128 0x55	# (DW_AT_ranges)
++	.uleb128 0x17	# (DW_FORM_sec_offset)
++	.uleb128 0x11	# (DW_AT_low_pc)
++	.uleb128 0x1	# (DW_FORM_addr)
++	.uleb128 0x10	# (DW_AT_stmt_list)
++	.uleb128 0x17	# (DW_FORM_sec_offset)
++	.byte	0
++	.byte	0
++	.uleb128 0x2	# (abbrev code)
++	.uleb128 0x2e	# (TAG: DW_TAG_subprogram)
++	.byte	0x1	# DW_children_yes
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0x8	# (DW_FORM_string)
++	.uleb128 0x3a	# (DW_AT_decl_file)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3b	# (DW_AT_decl_line)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.uleb128 0x20	# (DW_AT_inline)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.byte	0
++	.byte	0
++	.uleb128 0x3	# (abbrev code)
++	.uleb128 0x5	# (TAG: DW_TAG_formal_parameter)
++	.byte	0	# DW_children_no
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0x8	# (DW_FORM_string)
++	.uleb128 0x3a	# (DW_AT_decl_file)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3b	# (DW_AT_decl_line)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.byte	0
++	.byte	0
++	.uleb128 0x4	# (abbrev code)
++	.uleb128 0x24	# (TAG: DW_TAG_base_type)
++	.byte	0	# DW_children_no
++	.uleb128 0xb	# (DW_AT_byte_size)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3e	# (DW_AT_encoding)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0x8	# (DW_FORM_string)
++	.byte	0
++	.byte	0
++	.uleb128 0x5	# (abbrev code)
++	.uleb128 0x26	# (TAG: DW_TAG_const_type)
++	.byte	0	# DW_children_no
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.byte	0
++	.byte	0
++	.uleb128 0x6	# (abbrev code)
++	.uleb128 0x10	# (TAG: DW_TAG_reference_type)
++	.byte	0	# DW_children_no
++	.uleb128 0xb	# (DW_AT_byte_size)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.byte	0
++	.byte	0
++	.uleb128 0x7	# (abbrev code)
++	.uleb128 0x2e	# (TAG: DW_TAG_subprogram)
++	.byte	0x1	# DW_children_yes
++	.uleb128 0x31	# (DW_AT_abstract_origin)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.uleb128 0x11	# (DW_AT_low_pc)
++	.uleb128 0x1	# (DW_FORM_addr)
++	.uleb128 0x12	# (DW_AT_high_pc)
++	.uleb128 0x7	# (DW_FORM_data8)
++	.uleb128 0x40	# (DW_AT_frame_base)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.uleb128 0x2117	# (DW_AT_GNU_all_call_sites)
++	.uleb128 0x19	# (DW_FORM_flag_present)
++	.byte	0
++	.byte	0
++	.uleb128 0x8	# (abbrev code)
++	.uleb128 0x5	# (TAG: DW_TAG_formal_parameter)
++	.byte	0	# DW_children_no
++	.uleb128 0x31	# (DW_AT_abstract_origin)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.uleb128 0x2	# (DW_AT_location)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.byte	0
++	.byte	0
++	.uleb128 0x9	# (abbrev code)
++	.uleb128 0x2e	# (TAG: DW_TAG_subprogram)
++	.byte	0x1	# DW_children_yes
++	.uleb128 0x3f	# (DW_AT_external)
++	.uleb128 0x19	# (DW_FORM_flag_present)
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0xe	# (DW_FORM_strp)
++	.uleb128 0x3a	# (DW_AT_decl_file)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3b	# (DW_AT_decl_line)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.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 0x7	# (DW_FORM_data8)
++	.uleb128 0x40	# (DW_AT_frame_base)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.uleb128 0x2117	# (DW_AT_GNU_all_call_sites)
++	.uleb128 0x19	# (DW_FORM_flag_present)
++	.byte	0
++	.byte	0
++	.uleb128 0xa	# (abbrev code)
++	.uleb128 0xb	# (TAG: DW_TAG_lexical_block)
++	.byte	0x1	# DW_children_yes
++	.uleb128 0x11	# (DW_AT_low_pc)
++	.uleb128 0x1	# (DW_FORM_addr)
++	.uleb128 0x12	# (DW_AT_high_pc)
++	.uleb128 0x7	# (DW_FORM_data8)
++	.byte	0
++	.byte	0
++	.uleb128 0xb	# (abbrev code)
++	.uleb128 0x34	# (TAG: DW_TAG_variable)
++	.byte	0	# DW_children_no
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0x8	# (DW_FORM_string)
++	.uleb128 0x3a	# (DW_AT_decl_file)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3b	# (DW_AT_decl_line)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.uleb128 0x2	# (DW_AT_location)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.byte	0
++	.byte	0
++	.uleb128 0xc	# (abbrev code)
++	.uleb128 0x4109	# (TAG: DW_TAG_GNU_call_site)
++	.byte	0x1	# DW_children_yes
++	.uleb128 0x11	# (DW_AT_low_pc)
++	.uleb128 0x1	# (DW_FORM_addr)
++	.uleb128 0x31	# (DW_AT_abstract_origin)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.byte	0
++	.byte	0
++	.uleb128 0xd	# (abbrev code)
++	.uleb128 0x410a	# (TAG: DW_TAG_GNU_call_site_parameter)
++	.byte	0	# DW_children_no
++	.uleb128 0x2	# (DW_AT_location)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.uleb128 0x2111	# (DW_AT_GNU_call_site_value)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.uleb128 0x2112	# (DW_AT_GNU_call_site_data_value)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.byte	0
++	.byte	0
++	.uleb128 0xe	# (abbrev code)
++	.uleb128 0x34	# (TAG: DW_TAG_variable)
++	.byte	0	# DW_children_no
++	.uleb128 0x3	# (DW_AT_name)
++	.uleb128 0x8	# (DW_FORM_string)
++	.uleb128 0x3a	# (DW_AT_decl_file)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x3b	# (DW_AT_decl_line)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.uleb128 0x3f	# (DW_AT_external)
++	.uleb128 0x19	# (DW_FORM_flag_present)
++	.uleb128 0x2	# (DW_AT_location)
++	.uleb128 0x18	# (DW_FORM_exprloc)
++	.byte	0
++	.byte	0
++	.uleb128 0xf	# (abbrev code)
++	.uleb128 0x35	# (TAG: DW_TAG_volatile_type)
++	.byte	0	# DW_children_no
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.byte	0
++	.byte	0
++	.uleb128 0x10	# (abbrev code)
++	.uleb128 0xf	# (TAG: DW_TAG_pointer_type)
++	.byte	0	# DW_children_no
++	.uleb128 0xb	# (DW_AT_byte_size)
++	.uleb128 0xb	# (DW_FORM_data1)
++	.uleb128 0x49	# (DW_AT_type)
++	.uleb128 0x13	# (DW_FORM_ref4)
++	.byte	0
++	.byte	0
++	.byte	0
++	.section	.debug_aranges,"", at progbits
++	.long	0x3c	# Length of Address Ranges Info
++	.value	0x2	# DWARF Version
++	.long	.Ldebug_info0	# Offset of Compilation Unit Info
++	.byte	0x8	# Size of Address
++	.byte	0	# Size of Segment Descriptor
++	.value	0	# Pad to 16 byte boundary
++	.value	0
++	.quad	.Ltext0	# Address
++	.quad	.Letext0-.Ltext0	# Length
++	.quad	.LFB1	# Address
++	.quad	.LFE1-.LFB1	# Length
++	.quad	0
++	.quad	0
++	.section	.debug_ranges,"", at progbits
++.Ldebug_ranges0:
++	.quad	.Ltext0	# Offset 0
++	.quad	.Letext0
++	.quad	.LFB1	# Offset 0x10
++	.quad	.LFE1
++	.quad	0
++	.quad	0
++	.section	.debug_line,"", at progbits
++.Ldebug_line0:
++	.section	.debug_str,"MS", at progbits,1
++.LASF1:
++	.string	"gdb.arch/amd64-entry-value-paramref.cc"
++.LASF2:
++	.string	""
++.LASF0:
++	.string	"GNU C++ 4.8.2 20131212 (Red Hat 4.8.2-7) -mtune=generic -march=x86-64 -g -O2"
++.LASF3:
++	.string	"main"
++	.ident	"GCC: (GNU) 4.8.2 20131212 (Red Hat 4.8.2-7)"
++	.section	.note.GNU-stack,"", at progbits
+diff --git a/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.cc b/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.cc
+new file mode 100644
+index 0000000..e3a28de
+--- /dev/null
++++ b/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.cc
+@@ -0,0 +1,33 @@
++/* This testcase is part of GDB, the GNU debugger.
++
++   Copyright 2014 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/>.  */
++
++volatile int vv, *p;
++
++static __attribute__((noinline)) int
++bar (int &ref)
++{
++  vv++; /* break-here */
++  p = &ref;
++  return ref;
++}
++
++int
++main (void)
++{
++  int var = 10;
++  return bar (var);
++}
+diff --git a/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.exp b/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.exp
+new file mode 100644
+index 0000000..f06247d
+--- /dev/null
++++ b/gdb/testsuite/gdb.arch/amd64-entry-value-paramref.exp
+@@ -0,0 +1,35 @@
++# Copyright (C) 2014 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/>.
++
++standard_testfile .S .cc
++
++if { ![istarget x86_64-*-* ] || ![is_lp64_target] } {
++    verbose "Skipping amd64-entry-value-paramref."
++    return
++}
++
++if { [prepare_for_testing ${testfile}.exp ${testfile} ${srcfile} "c++"] } {
++    return -1
++}
++
++if ![runto_main] {
++    return -1
++}
++
++set srcfile $srcfile2
++gdb_breakpoint [gdb_get_line_number "break-here"]
++
++gdb_continue_to_breakpoint "break-here" ".* break-here .*"
++gdb_test "frame" {bar \(ref=@0x[0-9a-f]+: 10, ref at entry=@0x[0-9a-f]+: <optimized out>\) at .*}
+
+--jRHKVT23PllUwdXP--
+
diff --git a/gdb.spec b/gdb.spec
index 3cbe242..11529ca 100644
--- a/gdb.spec
+++ b/gdb.spec
@@ -25,7 +25,7 @@ Version: 7.7.90.%{snapsrc}
 
 # The release always contains a leading reserved number, start it at 1.
 # `upstream' is not a part of `name' to stay fully rpm dependencies compatible for the testing.
-Release: 6%{?dist}
+Release: 7%{?dist}
 
 License: GPLv3+ and GPLv3+ with exceptions and GPLv2+ and GPLv2+ with exceptions and GPL+ and LGPLv2+ and BSD and Public Domain and GFDL
 Group: Development/Debuggers
@@ -537,6 +537,9 @@ Patch914: gdb-readline-6.3.5.patch
 # Continue backtrace even if a frame filter throws an exception (Phil Muldoon).
 Patch918: gdb-btrobust.patch
 
+# Fix crash on optimized-out entry data values (BZ 1111910).
+Patch919: gdb-entrydataoptimizedout.patch
+
 %if 0%{!?rhel:1} || 0%{?rhel} > 6
 # RL_STATE_FEDORA_GDB would not be found for:
 # Patch642: gdb-readline62-ask-more-rh.patch
@@ -835,6 +838,7 @@ find -name "*.info*"|xargs rm -f
 %patch887 -p1
 %patch914 -p1
 %patch918 -p1
+%patch919 -p1
 
 %patch848 -p1
 %if 0%{!?el6:1}
@@ -1320,6 +1324,9 @@ then
 fi
 
 %changelog
+* Mon Jun 30 2014 Jan Kratochvil <jan.kratochvil at redhat.com> - 7.7.90.20140627-7.fc21
+- Fix crash on optimized-out entry data values (BZ 1111910).
+
 * Fri Jun 27 2014 Jan Kratochvil <jan.kratochvil at redhat.com> - 7.7.90.20140627-6.fc21
 - Rebase to FSF GDB 7.7.90.20140627 (pre-7.8 snapshot).
 


More information about the scm-commits mailing list