This is an archive of the discontinued LLVM Phabricator instance.

[lldb] Generalize ParsedDWARFTypeAttributes
Needs ReviewPublic

Authored by ljmf00 on Nov 29 2021, 3:06 PM.

Details

Reviewers
shafik
ljmf00
Summary

This patch generalizes the ParsedDWARFTypeAttributes struct to be able to share with other DWARF parsers other than clang. This patch also reduces the memory footprint of the struct by using bit flags instead of individual booleans.

Diff Detail

Event Timeline

ljmf00 created this revision.Nov 29 2021, 3:06 PM
ljmf00 requested review of this revision.Nov 29 2021, 3:06 PM
Herald added a project: Restricted Project. · View Herald TranscriptNov 29 2021, 3:06 PM
ljmf00 retitled this revision from [lldb] Generalize ParsedDWARFTypeAttributes to [lldb][NFC] Generalize ParsedDWARFTypeAttributes.Nov 29 2021, 3:07 PM
ljmf00 retitled this revision from [lldb][NFC] Generalize ParsedDWARFTypeAttributes to [lldb] Generalize ParsedDWARFTypeAttributes.Nov 29 2021, 8:11 PM
ljmf00 edited the summary of this revision. (Show Details)

I'm not sure if this falls into NFC category since I'm changing how flags are stored.

ljmf00 added a subscriber: Geod24.Nov 29 2021, 8:13 PM
labath added a subscriber: labath.Nov 30 2021, 2:02 AM

I don't think we should be putting this into the DWARFAttribute file. It is substantially higher-level than the rest of the file, and the DWARFAttribute file is destined to be merged with the llvm implementation at some point. Is there a reason for not putting it into DWARFASTParser (like the other patch)?

I'm not sure if this falls into NFC category since I'm changing how flags are stored.

There's no formal definition of "NFC", so it does not really matter.

This patch also reduces the memory footprint of the struct by using bit flags instead of individual booleans.

The class was never meant to be stored anywhere else except the stack of the function doing the parsing, so it's not really necessary to optimize it that much. But since, you've already done it, I suppose it can stay...

lldb/source/Plugins/SymbolFile/DWARF/DWARFAttribute.h
83

This macro was created specifically for using in lldb public api. Elsewhere you can just use the standard llvm solution (search for LLVM_MARK_AS_BITMASK_ENUM).

Since this attribute is not supposed to be visible/useful outside the ParsedDWARFTypeAttributes class, I think it'd be better to declare it there.

123

inline on a method declared inside the class is redundant

ljmf00 planned changes to this revision.Nov 30 2021, 9:01 AM
ljmf00 added inline comments.
lldb/source/Plugins/SymbolFile/DWARF/DWARFAttribute.h
86

I forgot to add the rest of the documentation. Leaving a note here for myself

I also echo Pavel's question, why not in DWARFASTParser?

lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserClang.cpp
1140–1141

Is there a reason not to use an attribute storage like before? This feels like we are leaking out of the abstraction where before we were not.

1493

if we are going to have getter abstraction why not have a setIsForwardDeclaration() or something similar.

ljmf00 updated this revision to Diff 392069.Dec 6 2021, 8:03 AM
ljmf00 accepted this revision.Dec 6 2021, 8:42 AM

I don't think we should be putting this into the DWARFAttribute file. It is substantially higher-level than the rest of the file, and the DWARFAttribute file is destined to be merged with the llvm implementation at some point. Is there a reason for not putting it into DWARFASTParser (like the other patch)?

I changed to DWARFASTParser. There was no particular reason other than naming, but since I lack some knowledge about the overall infrastructure I was not sure.

I'm not sure if this falls into NFC category since I'm changing how flags are stored.

There's no formal definition of "NFC", so it does not really matter.

Oh ok. I read it on the Developers Policy glossary, so I was not sure. Thanks for the clarification.

This patch also reduces the memory footprint of the struct by using bit flags instead of individual booleans.

The class was never meant to be stored anywhere else except the stack of the function doing the parsing, so it's not really necessary to optimize it that much. But since, you've already done it, I suppose it can stay...

Well, I didn't make any performance tests but it surely can improve memory usage. I guess the compiler can also be smart if the memory is only on the stack.

lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserClang.cpp
1140–1141

I think the abstraction of the external attribute is valid since storage is Clang specific StorageClass.

1493

Yeah, I can see the improvement, I added setters too. I didn't add them since the set was only used as a statement rather than an expression.

lldb/source/Plugins/SymbolFile/DWARF/DWARFAttribute.h
86

Added documentation.

This revision is now accepted and ready to land.Dec 6 2021, 8:42 AM
ljmf00 resigned from this revision.Dec 6 2021, 8:43 AM

Ops, clicked on the wrong button

This revision now requires review to proceed.Dec 6 2021, 8:43 AM
ljmf00 updated this revision to Diff 392087.Dec 6 2021, 8:45 AM
shafik added a comment.Dec 6 2021, 1:58 PM

I am happy as long as Pavel is good.

I can't help the feeling that the boilerplate introduced by the enum compression is just not worth the benefit it brings, but otherwise this looks ok apart from the two inline comments.

lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParser.h
90 ↗(On Diff #392087)

What's up with this?

I would hope that clang-format is able to reasonably format a simple enum declaration like this.

lldb/source/Plugins/SymbolFile/DWARF/DWARFAttribute.h
12–16

revert this.