diff --git a/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp b/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp --- a/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp +++ b/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp @@ -50,6 +50,9 @@ DWARFVerifier::DieRangeInfo::die_range_info_iterator DWARFVerifier::DieRangeInfo::insert(const DieRangeInfo &RI) { + if (RI.Ranges.empty()) + return Children.end(); + auto End = Children.end(); auto Iter = Children.begin(); while (Iter != End) { @@ -383,7 +386,7 @@ return NumErrors; } - DWARFAddressRangesVector Ranges = RangesOrError.get(); + const DWARFAddressRangesVector &Ranges = RangesOrError.get(); // Build RI for this DIE and check that ranges within this DIE do not // overlap. DieRangeInfo RI(Die); @@ -444,7 +447,7 @@ } // Verify that ranges are contained within their parent. - bool ShouldBeContained = !Ranges.empty() && !ParentRI.Ranges.empty() && + bool ShouldBeContained = !RI.Ranges.empty() && !ParentRI.Ranges.empty() && !(Die.getTag() == DW_TAG_subprogram && ParentRI.Die.getTag() == DW_TAG_subprogram); if (ShouldBeContained && !ParentRI.contains(RI)) { diff --git a/llvm/test/tools/llvm-dwarfdump/X86/verify_cu_ranges.yaml b/llvm/test/tools/llvm-dwarfdump/X86/verify_cu_ranges.yaml new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-dwarfdump/X86/verify_cu_ranges.yaml @@ -0,0 +1,214 @@ +# This test verifies that if a DW_TAG_compile_unit has children not having +# ranges llvm-dwarfdump stll correctly verifies other dies with normal +# ranges. +# +# The DWARF looks like: +# 0x0000000b: DW_TAG_compile_unit +# DW_AT_name ("/tmp/main.c") +# DW_AT_language (DW_LANG_C) +# DW_AT_low_pc (0x0000000000000000) +# DW_AT_ranges (0x00000000 +# [0x0000000000002000, 0x0000000000003000) +# [0x0000000000001000, 0x0000000000002000)) +# +# 0x0000001e: DW_TAG_subprogram +# DW_AT_name ("no_range1") +# +# 0x00000044: DW_TAG_subprogram +# DW_AT_name ("main") +# DW_AT_low_pc (0x0000000000001000) +# DW_AT_high_pc (0x0000000000002000) +# +# 0x00000055: DW_TAG_subprogram +# DW_AT_name ("foo") +# DW_AT_low_pc (0x0000000000002000) +# DW_AT_high_pc (0x0000000000003000) +# +# # 0x0000001e: DW_TAG_subprogram +# DW_AT_name ("no_range2") +# +# 0x00000066: NULL + +# RUN: yaml2obj %s | llvm-dwarfdump --verify - | FileCheck %s + +# CHECK: Verifying -: file format Mach-O 64-bit x86-64 +# CHECK: Verifying .debug_abbrev... +# CHECK: Verifying .debug_info Unit Header Chain... +# CHECK: Verifying .debug_info references... +# CHECK: Verifying .debug_types Unit Header Chain... +# CHECK: No errors. + +--- !mach-o +FileHeader: + magic: 0xFEEDFACF + cputype: 0x01000007 + cpusubtype: 0x00000003 + filetype: 0x00000001 + ncmds: 4 + sizeofcmds: 464 + flags: 0x00002000 + reserved: 0x00000000 +LoadCommands: + - cmd: LC_SEGMENT_64 + cmdsize: 392 + segname: '' + vmaddr: 0 + vmsize: 261 + fileoff: 528 + filesize: 261 + maxprot: 7 + initprot: 7 + nsects: 4 + flags: 0 + Sections: + - sectname: __debug_abbrev + segname: __DWARF + addr: 0x0000000000000000 + size: 36 + offset: 0x00000210 + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - sectname: __debug_info + segname: __DWARF + addr: 0x0000000000000024 + size: 75 + offset: 0x00000234 + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - sectname: __debug_ranges + segname: __DWARF + addr: 0x000000000000008B + size: 48 + offset: 0x0000029B + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - sectname: __debug_str + segname: __DWARF + addr: 0x00000000000000DB + size: 42 + offset: 0x000002EB + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - cmd: LC_SYMTAB + cmdsize: 24 + symoff: 0 + nsyms: 0 + stroff: 792 + strsize: 8 + - cmd: LC_BUILD_VERSION + cmdsize: 32 + platform: 1 + minos: 658944 + sdk: 658944 + ntools: 1 + Tools: + - tool: 3 + version: 34734080 + - cmd: LC_DATA_IN_CODE + cmdsize: 16 + dataoff: 792 + datasize: 0 +LinkEditData: + StringTable: + - ' ' + - '' + - '' + - '' + - '' + - '' + - '' +DWARF: + debug_str: + - '' + - '/tmp/main.c' + - no_range1 + - no_range2 + - main + - foo + debug_abbrev: + - Table: + - Code: 0x00000001 + Tag: DW_TAG_compile_unit + Children: DW_CHILDREN_yes + Attributes: + - Attribute: DW_AT_name + Form: DW_FORM_strp + - Attribute: DW_AT_language + Form: DW_FORM_data2 + - Attribute: DW_AT_low_pc + Form: DW_FORM_addr + - Attribute: DW_AT_ranges + Form: DW_FORM_sec_offset + - Code: 0x00000002 + Tag: DW_TAG_subprogram + Children: DW_CHILDREN_no + Attributes: + - Attribute: DW_AT_name + Form: DW_FORM_strp + - Attribute: DW_AT_low_pc + Form: DW_FORM_addr + - Attribute: DW_AT_high_pc + Form: DW_FORM_data4 + - Code: 0x00000003 + Tag: DW_TAG_subprogram + Children: DW_CHILDREN_no + Attributes: + - Attribute: DW_AT_name + Form: DW_FORM_strp + + debug_ranges: + - Offset: 0x00000000 + AddrSize: 0x08 + Entries: + - LowOffset: 0x0000000000002000 + HighOffset: 0x0000000000003000 + - LowOffset: 0x0000000000001000 + HighOffset: 0x0000000000002000 + debug_info: + - Version: 4 + AddrSize: 8 + Entries: + - AbbrCode: 0x00000001 + Values: + - Value: 0x0000000000000001 + - Value: 0x0000000000000002 + - Value: 0x0000000000000000 + - Value: 0x0000000000000000 + - AbbrCode: 0x00000003 + Values: + - Value: 0x000000000000000D + - AbbrCode: 0x00000002 + Values: + - Value: 0x0000000000000021 + - Value: 0x0000000000001000 + - Value: 0x0000000000001000 + - AbbrCode: 0x00000002 + Values: + - Value: 0x0000000000000026 + - Value: 0x0000000000002000 + - Value: 0x0000000000001000 + - AbbrCode: 0x00000003 + Values: + - Value: 0x0000000000000017 + - AbbrCode: 0x00000000 +... diff --git a/llvm/test/tools/llvm-dwarfdump/X86/verify_parent_zero_length.yaml b/llvm/test/tools/llvm-dwarfdump/X86/verify_parent_zero_length.yaml new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-dwarfdump/X86/verify_parent_zero_length.yaml @@ -0,0 +1,236 @@ +# This test verifies that if a parent die(DW_TAG_subprogram) has zero +# length address range and have a child with normal address range - +# the "DIE address ranges are not contained in its parent's ranges" +# error is reported. It also checks that if a parent die has zero +# length address range and have children with overlapped addresses +# the error "DIEs have overlapping address ranges" is reported. +# +# The DWARF looks like: +# 0x0000000b: DW_TAG_compile_unit +# DW_AT_name ("/tmp/main.c") +# DW_AT_language (DW_LANG_C) +# DW_AT_low_pc (0x0000000000000000) +# DW_AT_ranges (0x00000000 +# [0x0000000000001000, 0x0000000000002000)) +# +# 0x0000001e: DW_TAG_subprogram +# DW_AT_name ("main") +# DW_AT_low_pc (0x0000000000000000) +# DW_AT_high_pc (0x0000000000000000) +# +# 0x00000033: DW_TAG_lexical_block +# DW_AT_low_pc (0x0000000000001000) +# DW_AT_high_pc (0x0000000000002000) +# +# 0x00000044: DW_TAG_lexical_block +# DW_AT_low_pc (0x0000000000001000) +# DW_AT_high_pc (0x0000000000002000) +# 0x00000055: NULL +# +# 0x00000056: NULL + + +# RUN: yaml2obj %s | not llvm-dwarfdump --verify - | FileCheck %s --implicit-check-not=error: + +# CHECK: Verifying -: file format Mach-O 64-bit x86-64 +# CHECK: Verifying .debug_abbrev... +# CHECK: Verifying .debug_info Unit Header Chain... +# CHECK: error: DIE address ranges are not contained in its parent's ranges: +# CHECK: 0x0000001e: DW_TAG_subprogram +# CHECK: DW_AT_name ("main") +# CHECK: DW_AT_low_pc (0x0000000000000000) +# CHECK: DW_AT_high_pc (0x0000000000000000) + +# CHECK: 0x00000033: DW_TAG_lexical_block +# CHECK: DW_AT_low_pc (0x0000000000001000) +# CHECK: DW_AT_high_pc (0x0000000000002000) + +# CHECK: error: DIEs have overlapping address ranges: +# CHECK: 0x00000044: DW_TAG_lexical_block +# CHECK: DW_AT_low_pc (0x0000000000001000) +# CHECK: DW_AT_high_pc (0x0000000000002000) + +# CHECK: 0x00000033: DW_TAG_lexical_block +# CHECK: DW_AT_low_pc (0x0000000000001000) +# CHECK: DW_AT_high_pc (0x0000000000002000) + +# CHECK: error: DIE address ranges are not contained in its parent's ranges: +# CHECK: 0x0000001e: DW_TAG_subprogram +# CHECK: DW_AT_name ("main") +# CHECK: DW_AT_low_pc (0x0000000000000000) +# CHECK: DW_AT_high_pc (0x0000000000000000) + +# CHECK: 0x00000044: DW_TAG_lexical_block +# CHECK: DW_AT_low_pc (0x0000000000001000) +# CHECK: DW_AT_high_pc (0x0000000000002000) + + +--- !mach-o +FileHeader: + magic: 0xFEEDFACF + cputype: 0x01000007 + cpusubtype: 0x00000003 + filetype: 0x00000001 + ncmds: 4 + sizeofcmds: 464 + flags: 0x00002000 + reserved: 0x00000000 +LoadCommands: + - cmd: LC_SEGMENT_64 + cmdsize: 392 + segname: '' + vmaddr: 0 + vmsize: 261 + fileoff: 528 + filesize: 261 + maxprot: 7 + initprot: 7 + nsects: 4 + flags: 0 + Sections: + - sectname: __debug_abbrev + segname: __DWARF + addr: 0x0000000000000000 + size: 36 + offset: 0x00000210 + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - sectname: __debug_info + segname: __DWARF + addr: 0x0000000000000024 + size: 87 + offset: 0x00000234 + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - sectname: __debug_ranges + segname: __DWARF + addr: 0x000000000000008B + size: 32 + offset: 0x0000029B + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - sectname: __debug_str + segname: __DWARF + addr: 0x00000000000000DB + size: 18 + offset: 0x000002EB + align: 0 + reloff: 0x00000000 + nreloc: 0 + flags: 0x00000000 + reserved1: 0x00000000 + reserved2: 0x00000000 + reserved3: 0x00000000 + - cmd: LC_SYMTAB + cmdsize: 24 + symoff: 0 + nsyms: 0 + stroff: 792 + strsize: 8 + - cmd: LC_BUILD_VERSION + cmdsize: 32 + platform: 1 + minos: 658944 + sdk: 658944 + ntools: 1 + Tools: + - tool: 3 + version: 34734080 + - cmd: LC_DATA_IN_CODE + cmdsize: 16 + dataoff: 792 + datasize: 0 +LinkEditData: + StringTable: + - ' ' + - '' + - '' + - '' + - '' + - '' + - '' +DWARF: + debug_str: + - '' + - '/tmp/main.c' + - main + debug_abbrev: + - Table: + - Code: 0x00000001 + Tag: DW_TAG_compile_unit + Children: DW_CHILDREN_yes + Attributes: + - Attribute: DW_AT_name + Form: DW_FORM_strp + - Attribute: DW_AT_language + Form: DW_FORM_data2 + - Attribute: DW_AT_low_pc + Form: DW_FORM_addr + - Attribute: DW_AT_ranges + Form: DW_FORM_sec_offset + - Code: 0x00000002 + Tag: DW_TAG_subprogram + Children: DW_CHILDREN_yes + Attributes: + - Attribute: DW_AT_name + Form: DW_FORM_strp + - Attribute: DW_AT_low_pc + Form: DW_FORM_addr + - Attribute: DW_AT_high_pc + Form: DW_FORM_addr + - Code: 0x00000003 + Tag: DW_TAG_lexical_block + Children: DW_CHILDREN_no + Attributes: + - Attribute: DW_AT_low_pc + Form: DW_FORM_addr + - Attribute: DW_AT_high_pc + Form: DW_FORM_addr + + debug_ranges: + - Offset: 0x00000000 + AddrSize: 0x08 + Entries: + - LowOffset: 0x0000000000001000 + HighOffset: 0x0000000000002000 + debug_info: + - Version: 4 + AddrSize: 8 + Entries: + - AbbrCode: 0x00000001 + Values: + - Value: 0x0000000000000001 + - Value: 0x0000000000000002 + - Value: 0x0000000000000000 + - Value: 0x0000000000000000 + - AbbrCode: 0x00000002 + Values: + - Value: 0x000000000000000D + - Value: 0x0000000000000000 + - Value: 0x0000000000000000 + - AbbrCode: 0x00000003 + Values: + - Value: 0x0000000000001000 + - Value: 0x0000000000002000 + - AbbrCode: 0x00000003 + Values: + - Value: 0x0000000000001000 + - Value: 0x0000000000002000 + - AbbrCode: 0x00000000 + - AbbrCode: 0x00000000 +...