[PATCH] D129392: llvm-dwarfdump: Don't crash if DW_AT_{decl,call}_{file,line} uses signed form
David Blaikie via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Jul 8 16:06:13 PDT 2022
dblaikie added inline comments.
================
Comment at: llvm/lib/DebugInfo/DWARF/DWARFDie.cpp:139-149
+ if (const auto *LT = U->getContext().getLineTableForUnit(U)) {
+ if (Optional<uint64_t> Val = FormValue.getAsUnsignedConstant()) {
+ if (LT->getFileNameByIndex(
+ *Val, U->getCompilationDir(),
+ DILineInfoSpecifier::FileLineInfoKind::AbsoluteFilePath,
+ File)) {
+ File = '"' + File + '"';
----------------
clayborg wrote:
> dblaikie wrote:
> > I /think/ LLVM's style guide now doesn't encourage omitting braces from single statement but multi-line blocks like this, so I left these ones in.
> Do we want to dump the attribute as a number if we can't get the lint table of the value as unsigned here? What happens when we dump a DW_AT_decl_file or DW_AT_call_file that has a signed integer encoding? Nothing comes out? Seems like we should do a "FormValue.dump(OS, DumpOpts);" if either the lit table or optional uint64_t fail to get extracted
> Do we want to dump the attribute as a number if we can't get the lint table of the value as unsigned here?
I believe we do that - at least looks like it according to the test touched in this patch & the fallback at the end of the if/else if/else chain below.
================
Comment at: llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp:707-708
}
+ case DW_AT_call_line:
+ case DW_AT_decl_line: {
+ if (!AttrValue.Value.getAsUnsignedConstant()) {
----------------
clayborg wrote:
> Do we want to handle DW_AT_decl_column and DW_AT_call_column here as well?
Sure - I'd be open to that.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D129392/new/
https://reviews.llvm.org/D129392
More information about the llvm-commits
mailing list