Skip to content

Commit

Permalink
Merge pull request #362 from adrian-prantl/57294211-1
Browse files Browse the repository at this point in the history
Cherry-pick DwarfExpression bugfix.
  • Loading branch information
adrian-prantl authored Nov 21, 2019
2 parents 7cc97aa + 7743452 commit 7ca2386
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 13 deletions.
17 changes: 8 additions & 9 deletions llvm/lib/CodeGen/AsmPrinter/DwarfExpression.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -155,20 +155,18 @@ bool DwarfExpression::addMachineReg(const TargetRegisterInfo &TRI,
CurSubReg.set(Offset, Offset + Size);

// If this sub-register has a DWARF number and we haven't covered
// its range, emit a DWARF piece for it.
if (CurSubReg.test(Coverage)) {
// its range, and its range covers the value, emit a DWARF piece for it.
if (Offset < MaxSize && CurSubReg.test(Coverage)) {
// Emit a piece for any gap in the coverage.
if (Offset > CurPos)
DwarfRegs.push_back({-1, Offset - CurPos, "no DWARF register encoding"});
DwarfRegs.push_back(
{-1, Offset - CurPos, "no DWARF register encoding"});
DwarfRegs.push_back(
{Reg, std::min<unsigned>(Size, MaxSize - Offset), "sub-register"});
if (Offset >= MaxSize)
break;

// Mark it as emitted.
Coverage.set(Offset, Offset + Size);
CurPos = Offset + Size;
}
// Mark it as emitted.
Coverage.set(Offset, Offset + Size);
CurPos = Offset + Size;
}
// Failed to find any DWARF encoding.
if (CurPos == 0)
Expand Down Expand Up @@ -391,6 +389,7 @@ void DwarfExpression::addExpression(DIExpressionCursor &&ExprCursor,
// empty DW_OP_piece / DW_OP_bit_piece before we emitted the base
// location.
assert(OffsetInBits >= FragmentOffset && "fragment offset not added?");
assert(SizeInBits >= OffsetInBits - FragmentOffset && "size underflow");

// If addMachineReg already emitted DW_OP_piece operations to represent
// a super-register by splicing together sub-registers, subtract the size
Expand Down
36 changes: 36 additions & 0 deletions llvm/test/DebugInfo/MIR/ARM/larger-subregister.mir
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# RUN: llc -start-before=livedebugvalues -filetype=obj -o - %s | \
# RUN: llvm-dwarfdump -debug-info - | FileCheck %s
#
# In this test the first DBG_VALUE is 32 bits large and sits in 128-bit register Q8,
# which has to be decomposed into two 64-bit register D16, D17.
# This test ensures that the unused D17 is suppressed in the output.
#
# CHECK: .debug_info contents:
# CHECK: DW_TAG_formal_parameter
# CHECK-NEXT: DW_AT_location
# CHECK-NEXT: DW_OP_regx D16, DW_OP_piece 0x4, DW_OP_regx D15, DW_OP_bit_piece 0x20 0x20
# CHECK-NEXT: DW_AT_name {{.*}}"boundingRect"
--- |
target triple = "thumbv7k-apple-watchos"
define swiftcc void @f() !dbg !5 {
ret void
}
!llvm.module.flags = !{!0}
!llvm.dbg.cu = !{!2}
!0 = !{i32 2, !"Debug Info Version", i32 3}
!2 = distinct !DICompileUnit(language: DW_LANG_Swift, file: !3,
isOptimized: true, runtimeVersion: 5, emissionKind: FullDebug, enums: !4, globals: !4, imports: !4)
!3 = !DIFile(filename: "t.swift", directory: "/")
!4 = !{}
!5 = distinct !DISubprogram(name: "f", scope: !3, file: !3, line: 388, type: !9, scopeLine: 388, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !2, retainedNodes: !4)
!9 = !DISubroutineType(types: !4)
!10 = !DILocation(line: 0, scope: !5)
!12 = !DILocalVariable(name: "boundingRect", arg: 1, scope: !5, file: !3, line: 388, type: !13)
!13 = !DIDerivedType(tag: DW_TAG_const_type, baseType: !14)
!14 = !DICompositeType(tag: DW_TAG_structure_type, name: "CGRect", scope: !5, file: !3, line: 46, size: 128, elements: !4, runtimeLang: DW_LANG_Swift, identifier: "$sSo6CGRectVD")
name: 'f'
body: |
bb.0:
DBG_VALUE $s31, $noreg, !12, !DIExpression(DW_OP_LLVM_fragment, 32, 32), debug-location !10
DBG_VALUE $q8, $noreg, !12, !DIExpression(DW_OP_LLVM_fragment, 0, 32), debug-location !10
renamable $r0 = t2ADDri $r6, 144, 14, $noreg, $noreg, debug-location !10
8 changes: 4 additions & 4 deletions llvm/test/MC/X86/dwarf-size-field-overflow.test
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
# This test generates too many debug location entries to fit into 65KB required
# by DWARF < 5. Check that the location is set to 0 instead of crashing.
#
# RUN: %python %s 4000 | llc -mtriple=x86_64-apple-darwin -filetype=obj -o %t
# RUN: llvm-dwarfdump %t | FileCheck %s
# RUN: %python %s 5750 | llc -mtriple=x86_64-apple-darwin -filetype=obj -o - \
# RUN: | llvm-dwarfdump - | FileCheck %s
#
# CHECK: 0x0000004d: DW_TAG_formal_parameter
# CHECK-NEXT: DW_AT_location (0x00000000
Expand Down Expand Up @@ -39,11 +39,11 @@ attributes #0 = {{ nounwind readnone speculatable }}
!34 = !DILocation(line: 12, column: 8, scope: !24)
"""

CALL = "call void @llvm.dbg.value(metadata i64 {0}, metadata !30, metadata !DIExpression(DW_OP_LLVM_fragment, {0}, 64)), !dbg !34"
CALL = "call void @llvm.dbg.value(metadata i64 {0}, metadata !30, metadata !DIExpression(DW_OP_LLVM_fragment, {1}, 8)), !dbg !34"

if __name__ == '__main__':
N = int(sys.argv[1])
calls = []
for i in range(0, N):
calls.append(CALL.format(i * 10**12))
calls.append(CALL.format(i * 10**12, i*8))
print(SKELETON.format('\n'.join(calls)))

0 comments on commit 7ca2386

Please sign in to comment.