From 3f8f004daf62d1b1007e5c226e8da2dab96eea14 Mon Sep 17 00:00:00 2001 From: David Blaikie Date: Wed, 12 Dec 2018 19:34:02 +0000 Subject: [PATCH] DebugInfo/DWARF: Improve dumping of pointers to members ('int foo::*' rather than 'int*') llvm-svn: 348962 --- llvm/lib/DebugInfo/DWARF/DWARFDie.cpp | 5 +++++ .../llvm-dwarfdump/X86/prettyprint_types.s | 20 ++++++++++++++++--- 2 files changed, 22 insertions(+), 3 deletions(-) diff --git a/llvm/lib/DebugInfo/DWARF/DWARFDie.cpp b/llvm/lib/DebugInfo/DWARF/DWARFDie.cpp index c607807d822a..b70a4f09776e 100644 --- a/llvm/lib/DebugInfo/DWARF/DWARFDie.cpp +++ b/llvm/lib/DebugInfo/DWARF/DWARFDie.cpp @@ -208,6 +208,11 @@ static void dumpTypeName(raw_ostream &OS, const DWARFDie &D) { OS << '*'; break; case DW_TAG_ptr_to_member_type: + if (DWARFDie Cont = + D.getAttributeValueAsReferencedDie(DW_AT_containing_type)) { + dumpTypeName(OS << ' ', Cont); + OS << "::"; + } OS << '*'; break; case DW_TAG_reference_type: diff --git a/llvm/test/tools/llvm-dwarfdump/X86/prettyprint_types.s b/llvm/test/tools/llvm-dwarfdump/X86/prettyprint_types.s index c149373870b6..d643d11a122d 100644 --- a/llvm/test/tools/llvm-dwarfdump/X86/prettyprint_types.s +++ b/llvm/test/tools/llvm-dwarfdump/X86/prettyprint_types.s @@ -16,8 +16,7 @@ # CHECK: DW_AT_type{{.*}}"int&&" # ptr_to_member_type -# FIXME: Add the contained_type to the assembly, and test the print out is "int foo::*" -# CHECK: DW_AT_type{{.*}}"int*" +# CHECK: DW_AT_type{{.*}}"int foo::*" # array_type # Testing lower_bound, upper_bound, lower and upper, lower and count, and count separately. @@ -25,7 +24,9 @@ .section .debug_str,"MS",@progbits,1 .Lint_name: - .asciz "int" # string offset=107 + .asciz "int" +.Lfoo_name: + .asciz "foo" .section .debug_abbrev,"",@progbits .byte 1 # Abbreviation Code .byte 17 # DW_TAG_compile_unit @@ -74,6 +75,8 @@ .byte 0 # DW_CHILDREN_no .byte 73 # DW_AT_type .byte 19 # DW_FORM_ref4 + .byte 0x1d # DW_AT_type + .byte 19 # DW_FORM_ref4 .byte 0 # EOM(1) .byte 0 # EOM(2) .byte 8 # Abbreviation Code @@ -122,6 +125,13 @@ .byte 0xb # DW_FORM_data1 .byte 0 # EOM(1) .byte 0 # EOM(2) + .byte 14 # Abbreviation Code + .byte 0x13 # DW_TAG_structure_type + .byte 0 # DW_CHILDREN_no + .byte 3 # DW_AT_name + .byte 14 # DW_FORM_strp + .byte 0 # EOM(1) + .byte 0 # EOM(2) .byte 0 # EOM(3) .section .debug_info,"",@progbits .Lcu_begin: @@ -144,9 +154,13 @@ .Lrvalue_reference_type: .byte 6 # DW_TAG_rvalue_reference_type .long .Lint_type - .Lcu_begin # DW_AT_type +.Lstruct_type: + .byte 14 # DW_TAG_structure_type + .long .Lfoo_name # DW_AT_name .Lptr_to_member_type: .byte 7 # DW_TAG_ptr_to_member_type .long .Lint_type - .Lcu_begin # DW_AT_type + .long .Lstruct_type - .Lcu_begin # DW_AT_containing_type .Larray_type: .byte 8 # DW_TAG_array_type .long .Lint_type - .Lcu_begin # DW_AT_type