[MC/DWARF] Generate multiple .debug_line entries for adjacent .loc directives
authorUlrich Weigand <ulrich.weigand@de.ibm.com>
Wed, 19 Jun 2013 21:27:27 +0000 (21:27 +0000)
committerUlrich Weigand <ulrich.weigand@de.ibm.com>
Wed, 19 Jun 2013 21:27:27 +0000 (21:27 +0000)
commit4df4bccc71ea0477836db9a417d3da202c2baa09
treecae06e4ddbe69091a89822f65dc2c914f06769d1
parent07969dc8aed62fcd5c5760b2ec331275479f4a80
[MC/DWARF] Generate multiple .debug_line entries for adjacent .loc directives

The compiler occasionally generates multiple .loc directives in a row
(at the same instruction address).  These need to be transformed into
multple actual .debug_line table entries, since they are used to signal
certain information to the debugger (e.g. if the opening brace of a
function body is on the same line as the declaration).

The MCAsmStreamer version of EmitDwarfLocDirective handles this
correctly by emitting a .loc directive every time it is called.
However, the MCObjectStream version simply defaults to recording
the information and emitting only a single table entry later,
e.g. when EmitInstruction is called.

This patch introduces a MCAsmStreamer::EmitDwarfLocDirective
version that emits a line table entry for a .loc directive
that may already be pending before recording the new directive.
(This is similar to how this is handled in GNU as.)

With this patch (and the code alignment factor patch) applied,
I'm now getting identical DWARF .debug sections for all test-suite
object files on PowerPC for the internal and the external assembler.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184357 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/MC/MCObjectStreamer.h
lib/MC/MCObjectStreamer.cpp
test/MC/ELF/debug-line2.s [new file with mode: 0644]