From: Yao Qi Date: Wed, 25 Jan 2017 16:24:44 +0000 (+0000) Subject: Handle DW_OP_GNU_implicit_pointer in dwarf assembler X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=5ac95241162bf4729ecaf3c880cdaa846a3aded4;p=binutils-gdb.git Handle DW_OP_GNU_implicit_pointer in dwarf assembler DW_OP_GNU_implicit_pointer refers to a DIE with an offset of different sizes in different dwarf versions. In v2, the size is the pointer size, while in v3 and above, it is the ref_addr size. This patch fixes dwarf assembler to emit the correct size of offset. We've already fixed this size issue in gdb, https://sourceware.org/ml/gdb-patches/2011-09/msg00451.html gdb/testsuite: 2017-01-25 Yao Qi * lib/dwarf.exp (Dwarf::_location): Handle DW_OP_GNU_implicit_pointer with proper size. --- diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 4d197116132..aa272e345de 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2017-01-25 Yao Qi + + * lib/dwarf.exp (Dwarf::_location): Handle + DW_OP_GNU_implicit_pointer with proper size. + 2017-01-20 Luis Machado * gdb.python/py-xmethods.exp: Fix test names starting with lowercase diff --git a/gdb/testsuite/lib/dwarf.exp b/gdb/testsuite/lib/dwarf.exp index 9f5fa6ca09f..03ae63746cb 100644 --- a/gdb/testsuite/lib/dwarf.exp +++ b/gdb/testsuite/lib/dwarf.exp @@ -840,6 +840,7 @@ namespace eval Dwarf { proc _location {body} { variable _constants variable _cu_label + variable _cu_version variable _cu_addr_size variable _cu_offset_size @@ -913,7 +914,11 @@ namespace eval Dwarf { # Here label is a section offset. set label [lindex $line 1] - _op .${_cu_offset_size}byte $label + if { $_cu_version == 2 } { + _op .${_cu_addr_size}byte $label + } else { + _op .${_cu_offset_size}byte $label + } _op .sleb128 [lindex $line 2] }