[DebugInfo] Add support for DWARF5 call site-related attributes
authorVedant Kumar <vsk@apple.com>
Fri, 5 Oct 2018 20:37:17 +0000 (20:37 +0000)
committerVedant Kumar <vsk@apple.com>
Fri, 5 Oct 2018 20:37:17 +0000 (20:37 +0000)
commit5931b4e5b5de31bd366cbeb773f53357a0985e68
treec94a56afe545ae7bee551621c391f27a1abc94f5
parentf84ece68ca3e0630500ae2dd2a383cb3fa127568
[DebugInfo] Add support for DWARF5 call site-related attributes

DWARF v5 introduces DW_AT_call_all_calls, a subprogram attribute which
indicates that all calls (both regular and tail) within the subprogram
have call site entries. The information within these call site entries
can be used by a debugger to populate backtraces with synthetic tail
call frames.

Tail calling frames go missing in backtraces because the frame of the
caller is reused by the callee. Call site entries allow a debugger to
reconstruct a sequence of (tail) calls which led from one function to
another. This improves backtrace quality. There are limitations: tail
recursion isn't handled, variables within synthetic frames may not
survive to be inspected, etc. This approach is not novel, see:

  https://gcc.gnu.org/wiki/summit2010?action=AttachFile&do=get&target=jelinek.pdf

This patch adds an IR-level flag (DIFlagAllCallsDescribed) which lowers
to DW_AT_call_all_calls. It adds the minimal amount of DWARF generation
support needed to emit standards-compliant call site entries. For easier
deployment, when the debugger tuning is LLDB, the DWARF requirement is
adjusted to v4.

Testing: Apart from check-{llvm, clang}, I built a stage2 RelWithDebInfo
clang binary. Its dSYM passed verification and grew by 1.4% compared to
the baseline. 151,879 call site entries were added.

rdar://42001377

Differential Revision: https://reviews.llvm.org/D49887

llvm-svn: 343883
16 files changed:
clang/lib/CodeGen/CGDebugInfo.cpp
clang/lib/CodeGen/CGDebugInfo.h
clang/test/CodeGenCXX/dbg-info-all-calls-described.cpp [new file with mode: 0644]
llvm/include/llvm/DebugInfo/DWARF/DWARFVerifier.h
llvm/include/llvm/IR/DebugInfoFlags.def
llvm/include/llvm/IR/DebugInfoMetadata.h
llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.h
llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp
llvm/lib/CodeGen/AsmPrinter/DwarfDebug.h
llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp
llvm/lib/IR/Verifier.cpp
llvm/test/DebugInfo/Generic/callsite-attr-invalid.ll [new file with mode: 0644]
llvm/test/DebugInfo/X86/dwarf-callsite-related-attrs.ll [new file with mode: 0644]
llvm/test/tools/llvm-dwarfdump/X86/callsite-invalid.s [new file with mode: 0644]
llvm/tools/llvm-dwarfdump/Statistics.cpp