This is an archive of the discontinued LLVM Phabricator instance.

[DebugInfo/DWARF] [1/4] De-segregate type units and compile units. NFC
ClosedPublic

Authored by probinson on Jul 24 2018, 10:12 AM.

Details

Summary

This is Patch 1 of 4 NFC refactorings to handle type units and compile
units more consistently and with less concern about the object-file
section that they came from.

Patch 1 replaces the templated DWARFUnitSection with a non-templated
version. That is, instead of being a SmallVector of pointers to a
specific unit kind, it is now a SmallVector of pointers to the base
class for both type and compile units. Virtual methods are magic.

Patch 2 takes the existing std::deque<DWARFUnitSection> for type units
and makes it a simple DWARFUnitSection, simplifying the handling of
type units and making it more consistent with compile units.

Patch 3 simply renames DWARFUnitSection to DWARFUnitVector, as the
object-file section of a unit is nearly irrelevant now.

Patch 4 combines separate DWARFUnitVectors for compile and type units
into a single DWARFUnitVector that contains both. For now the
implementation distinguishes compile units from type units by putting
all compile units at the front of the vector, reflecting the DWARF v4
distinction between .debug_info and .debug_types sections. A future
patch will change this to allow the free mixing of unit kinds, as is
specified by DWARF v5.

Diff Detail

Repository
rL LLVM

Event Timeline

probinson created this revision.Jul 24 2018, 10:12 AM

The de-templatization will reduce the code size and I doubt that the virtual method overhead will be measurable. Looks like a good direction to me.

llvm/include/llvm/DebugInfo/DWARF/DWARFCompileUnit.h
29 ↗(On Diff #157068)

///

32 ↗(On Diff #157068)

///

llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp
63 ↗(On Diff #157068)

I understand you only moved this function, but if you happen to know it would be nice to add a comment here explaining why the parser may be null? Is this a lazy initialization?

probinson added inline comments.Jul 30 2018, 10:40 AM
llvm/include/llvm/DebugInfo/DWARF/DWARFCompileUnit.h
29 ↗(On Diff #157068)

OK, but most methods in this hierarchy don't.

32 ↗(On Diff #157068)

OK, but most methods in this hierarchy don't.

llvm/lib/DebugInfo/DWARF/DWARFUnit.cpp
63 ↗(On Diff #157068)

It is lazy initialization. This allows DWARFUnitSection to be constructed before knowing what all the section-related data will be; the Parse function needs to have all the sections available to it.

aprantl accepted this revision.Jul 30 2018, 11:50 AM
aprantl added inline comments.
llvm/include/llvm/DebugInfo/DWARF/DWARFCompileUnit.h
29 ↗(On Diff #157068)

Might be a useful NFC refactoring at some point.

This revision is now accepted and ready to land.Jul 30 2018, 11:50 AM
probinson updated this revision to Diff 158300.Jul 31 2018, 9:25 AM

Rebase. Update some commentary.

probinson marked 3 inline comments as done.Jul 31 2018, 9:26 AM
probinson added inline comments.
llvm/include/llvm/DebugInfo/DWARF/DWARFCompileUnit.h
29 ↗(On Diff #157068)

Will add that to the task list.

aprantl accepted this revision.Jul 31 2018, 10:00 AM

Thanks!

This revision was automatically updated to reflect the committed changes.