[llvm] 7a9d00f - [DebugInfo] Fix parsing DWARF64 units in DWP.
Igor Kudrin via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 28 00:38:00 PST 2020
Author: Igor Kudrin
Date: 2020-02-28T15:35:51+07:00
New Revision: 7a9d00f261a5fcc739fcde86849374c86bc9420b
URL: https://github.com/llvm/llvm-project/commit/7a9d00f261a5fcc739fcde86849374c86bc9420b
DIFF: https://github.com/llvm/llvm-project/commit/7a9d00f261a5fcc739fcde86849374c86bc9420b.diff
LOG: [DebugInfo] Fix parsing DWARF64 units in DWP.
The integrity check code allowed only DWARF32 units.
Differential Revision: https://reviews.llvm.org/D75178
Added:
llvm/test/DebugInfo/X86/dwp-dwarf64.s
Modified:
llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp
Removed:
################################################################################
diff --git a/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp b/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp
index d3bbe20c3e94..f3fd48c6ba75 100644
--- a/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp
+++ b/llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp
@@ -299,7 +299,8 @@ bool DWARFUnitHeader::extract(DWARFContext &Context,
if (AbbrOffset)
return false;
auto *UnitContrib = IndexEntry->getOffset();
- if (!UnitContrib || UnitContrib->Length != (Length + 4))
+ if (!UnitContrib ||
+ UnitContrib->Length != (Length + getUnitLengthFieldByteSize()))
return false;
auto *AbbrEntry = IndexEntry->getOffset(DW_SECT_ABBREV);
if (!AbbrEntry)
diff --git a/llvm/test/DebugInfo/X86/dwp-dwarf64.s b/llvm/test/DebugInfo/X86/dwp-dwarf64.s
new file mode 100644
index 000000000000..792786cdfc9d
--- /dev/null
+++ b/llvm/test/DebugInfo/X86/dwp-dwarf64.s
@@ -0,0 +1,70 @@
+# RUN: llvm-mc -triple x86_64-unknown-linux %s -filetype=obj -o - | \
+# RUN: llvm-dwarfdump -debug-info - | \
+# RUN: FileCheck %s
+
+# CHECK: .debug_info.dwo contents:
+
+# CHECK: 0x00000000: Compile Unit:
+# CHECK-SAME: length = 0x00000018
+# CHECK-SAME: version = 0x0004
+# CHECK-SAME: abbr_offset = 0x0000
+# CHECK-SAME: addr_size = 0x04
+
+# CHECK: 0x00000017: DW_TAG_compile_unit
+# CHECK-NEXT: DW_AT_name ("a.c")
+# CHECK-NEXT: DW_AT_GNU_dwo_id (0x1100001122222222)
+
+ .section .debug_abbrev.dwo, "e", @progbits
+.LAbbrBegin:
+ .uleb128 1 # Abbreviation Code
+ .uleb128 17 # DW_TAG_compile_unit
+ .byte 0 # DW_CHILDREN_no
+ .uleb128 3 # DW_AT_name
+ .uleb128 8 # DW_FORM_string
+ .uleb128 0x2131 # DW_AT_GNU_dwo_id
+ .uleb128 7 # DW_FORM_data8
+ .byte 0 # EOM(1)
+ .byte 0 # EOM(2)
+ .byte 0 # EOM(3)
+.LAbbrEnd:
+
+ .section .debug_info.dwo, "e", @progbits
+.LCUBegin:
+ .long 0xffffffff # DWARF64 mark
+ .quad .LCUEnd-.LCUVersion # Length
+.LCUVersion:
+ .short 4 # Version
+ .quad 0 # Abbrev offset
+ .byte 4 # Address size
+ .uleb128 1 # Abbrev [1] DW_TAG_compile_unit
+ .asciz "a.c" # DW_AT_name
+ .quad 0x1100001122222222 # DW_AT_GNU_dwo_id
+.LCUEnd:
+
+ .section .debug_cu_index, "", @progbits
+## Header:
+ .short 2 # Version
+ .space 2 # Padding
+ .long 2 # Section count
+ .long 1 # Unit count
+ .long 4 # Slot count
+## Hash Table of Signatures:
+ .quad 0
+ .quad 0
+ .quad 0x1100001122222222
+ .quad 0
+## Parallel Table of Indexes:
+ .long 0
+ .long 0
+ .long 1
+ .long 0
+## Table of Section Offsets:
+## Row 0:
+ .long 1 # DW_SECT_INFO
+ .long 3 # DW_SECT_ABBREV
+# Row 1:
+ .long .LCUBegin-.debug_info.dwo # Offset in .debug_info.dwo
+ .long .LAbbrBegin-.debug_abbrev.dwo # Offset in .debug_abbrev.dwo
+## Table of Section Sizes:
+ .long .LCUEnd-.LCUBegin
+ .long .LAbbrEnd-.LAbbrBegin
More information about the llvm-commits
mailing list