From: Tom Tromey Date: Thu, 31 Jan 2013 17:41:09 +0000 (+0000) Subject: PR c++/14998: X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7078baeb174ad00adf66ba9ec53056834dbaf7e3;p=binutils-gdb.git PR c++/14998: * dwarf2read.c (read_tag_ptr_to_member_type): Handle TYPE_CODE_FUNC. gdb/testsuite * gdb.dwarf2/method-ptr.cc: New file. * gdb.dwarf2/method-ptr.exp: New file. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index b35247eb0c4..23fa044b3ed 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,9 @@ +2013-01-31 Tom Tromey + + PR c++/14998: + * dwarf2read.c (read_tag_ptr_to_member_type): Handle + TYPE_CODE_FUNC. + 2013-01-31 Aleksandar Ristovski * target.c (target_read_string): Remove unused origlen. diff --git a/gdb/dwarf2read.c b/gdb/dwarf2read.c index d2dd149ce76..cef20e2a9a3 100644 --- a/gdb/dwarf2read.c +++ b/gdb/dwarf2read.c @@ -12270,6 +12270,15 @@ read_tag_ptr_to_member_type (struct die_info *die, struct dwarf2_cu *cu) if (TYPE_CODE (check_typedef (to_type)) == TYPE_CODE_METHOD) type = lookup_methodptr_type (to_type); + else if (TYPE_CODE (check_typedef (to_type)) == TYPE_CODE_FUNC) + { + struct type *new_type = alloc_type (cu->objfile); + + smash_to_method_type (new_type, domain, TYPE_TARGET_TYPE (to_type), + TYPE_FIELDS (to_type), TYPE_NFIELDS (to_type), + TYPE_VARARGS (to_type)); + type = lookup_methodptr_type (new_type); + } else type = lookup_memberptr_type (to_type, domain); diff --git a/gdb/testsuite/ChangeLog b/gdb/testsuite/ChangeLog index 3b53031068b..6366a13ce25 100644 --- a/gdb/testsuite/ChangeLog +++ b/gdb/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-01-31 Tom Tromey + + * gdb.dwarf2/method-ptr.cc: New file. + * gdb.dwarf2/method-ptr.exp: New file. + 2013-01-31 Tom Tromey * lib/dwarf.exp (namespace Dwarf): New. diff --git a/gdb/testsuite/gdb.dwarf2/method-ptr.cc b/gdb/testsuite/gdb.dwarf2/method-ptr.cc new file mode 100644 index 00000000000..563c443d1aa --- /dev/null +++ b/gdb/testsuite/gdb.dwarf2/method-ptr.cc @@ -0,0 +1,21 @@ +/* This testcase is part of GDB, the GNU debugger. + + Copyright 2013 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 . */ + +int main () +{ + return 0; +} diff --git a/gdb/testsuite/gdb.dwarf2/method-ptr.exp b/gdb/testsuite/gdb.dwarf2/method-ptr.exp new file mode 100644 index 00000000000..fcd1d694eb9 --- /dev/null +++ b/gdb/testsuite/gdb.dwarf2/method-ptr.exp @@ -0,0 +1,97 @@ +# Copyright 2013 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 . +load_lib dwarf.exp + +# This test can only be run on targets which support DWARF-2 and use gas. +if {![dwarf2_support]} { + return 0 +} + +if { [skip_cplus_tests] } { continue } + +standard_testfile .cc method-ptr-dw.S + +# Make some DWARF for the test. +set asm_file [standard_output_file $srcfile2] +Dwarf::assemble $asm_file { + declare_labels int_label float_label struct_label + declare_labels ptr_label subr_label memptr_label + + cu 0 2 8 { + compile_unit {{language @DW_LANG_C_plus_plus}} { + int_label: base_type { + {name int} + {encoding @DW_ATE_signed} + {byte_size 4} + } + + float_label: base_type { + {name float} + {encoding @DW_ATE_float} + {byte_size 4} + } + + struct_label: structure_type { + {name S} + {byte_size 1} + } + + ptr_label: pointer_type { + {type :$struct_label} + } + + subr_label: subroutine_type { + {type :$int_label} + } { + formal_parameter { + {type :$ptr_label} + {artificial 1} + } + formal_parameter { + {type :$float_label} + } + } + + memptr_label: ptr_to_member_type { + {type :$subr_label} + {containing_type :$struct_label} + } + + typedef { + {name the_typedef} + {type :$memptr_label} + } + } + } +} + +if {[gdb_compile ${srcdir}/${subdir}/${srcfile} ${binfile}1.o \ + object {nodebug}] != ""} { + return -1 +} + +if {[gdb_compile $asm_file ${binfile}2.o object {nodebug}] != ""} { + return -1 +} + +if {[gdb_compile [list ${binfile}1.o ${binfile}2.o] \ + "${binfile}" executable {}] != ""} { + return -1 +} + +clean_restart ${testfile} + +gdb_test "ptype the_typedef" \ + "type = int \\(S::\\*\\)\\(S \\* const, float\\)"