Details
Diff Detail
Event Timeline
Some parts of this could be extracted into a separate NFC (or mostly NFC) patch:
- The Dwarf.h part
- In DWARFAcceleratorTable.h, merging the Header and HeaderPOD structs, and removing the Padding field. (Adding the Format field would still be part of the functional patch.)
- In DWARFAcceleratorTable.cpp, eliminating the Padding field, and introducing CommonHeaderSize in DWARFDebugNames::Header::extract()
That would make the rest of the patch a little more focused. (Which overall looks pretty reasonable, although I'd prefer to wait for the next round before approving.)
llvm/lib/DebugInfo/DWARF/DWARFAcceleratorTable.cpp | ||
---|---|---|
380 | Could this be constexpr ? | |
631 | Is this line too long? (Did you run clang-format-diff?) |
- Extract accompanying fixes into separate patches.
- Make expressions constexpr where possible.
- Rebase, update.
DWARF64HeaderFixedPartSize cannot be constexpr because dwarf::getUnitLengthFieldByteSize() connot be constexpr because not all compilers allow llvm_unreachanble() to be used in a constexpr function.
llvm/lib/DebugInfo/DWARF/DWARFAcceleratorTable.cpp | ||
---|---|---|
391–394 | Perhaps this could be refactored to common the length test? uint64_t StartingOffset = *Offset); UnitLength = ...; Format = UnitLength == dwarf::DW_LENGTH_DWARF64 ? dwarf::DWARF64 : dwarf::DWARF32; if (!AS.isValidOffsetForDataOfSize(StartingOffset, dwarf::getUnitLengthFieldByteSize(Format) + CommonHeaderSize)) return createStringError(...); if (Format == dwarf::DWARF64) { UnitLength = AS.getU64(Offset); } else if (...) { return createStringError(...); } I'm not super convinced it's so much better - but it does avoid the quirky "- 4" and such. Alternatively we could skip all this and use the Error second parameter to the DataExtractor functions, and handle the error after the read attempts? More like the way DWARFUnitHeader::extract works, for example. |
- Avoid the quirky "- 4" by using StartingOffset.
@dblaikie, what do you think about this variant?
llvm/lib/DebugInfo/DWARF/DWARFAcceleratorTable.cpp | ||
---|---|---|
391–394 | I like the idea to check the remaining length before reading more than using the Error parameter. That makes the code more straightforward and allows producing more expressive error messages. So, for my taste, I would better rework DWARFUnitHeader::extract(). |
- Make the checking for the remaining length closer to what @dblaikie suggested.
David, which variant looks better to you?
Close enough. Whole thing'll hopefully be revisited/refactored with a constrained DWARFDataExtractor at some point soon (@labath - FYI)
Could this be constexpr ?