This patch adds support for generating accelerator tables in dsymutil.
This feature was already present in our internal repository but not yet
upstreamed because it requires changes to the Apple accelerator table
implementation.
Details
Diff Detail
Event Timeline
Looks mostly good, the test coverage could probably be a little better.
tools/dsymutil/CMakeLists.txt | ||
---|---|---|
4 | What's the dependency that makes this necessary? | |
tools/dsymutil/DwarfLinker.cpp | ||
924 | This comment should be on the declaration instead. | |
1313–1317 | The + 1 is for a \NUL? And it's guaranteed to exist? | |
1574–1575 | . | |
2043 | Is there a PR/radar about this? |
Thanks for having a look, Adrian! I'm planning on extending the existing test with the other .apple_* sections. A bunch more tests will be added when upstreaming the -update functionality as well, but that's for another diff.
tools/dsymutil/CMakeLists.txt | ||
---|---|---|
4 | The call to dwarf::djbHash() | |
tools/dsymutil/DwarfLinker.cpp | ||
1313–1317 | I'll double check! |
tools/dsymutil/DwarfLinker.cpp | ||
---|---|---|
104 | It seems odd to have this implementation live in DwarfLinker. I would have expected this to be part of AsmPrinter. Out of curiosity: Why is it not needed there? Is there something else that is only on opensource.apple.com and should really be on llvm.org? | |
465 | . | |
642 | These comments are not strictly necessary and basically just repeat the function name :-) | |
1597 | Does moving this field improve the layout somehow? | |
tools/dsymutil/dsymutil.h | ||
43 | It looks like this option is entirely untested? |
Thanks Adrian, I'll address your comments before committing this tomorrow morning.
tools/dsymutil/DwarfLinker.cpp | ||
---|---|---|
104 | I left it here as it was only used by the DwarfLinker, but happy to move it. I'm not sure what you mean by your last two questions? The AppleAccelTableStaticOffsetData is the template argument for the new accelerator tables. Dsymutil generates different tables from the AsmPrinter; both have static offsets (the implementation in AsmPrinter queries the DIE for it's offset) and for types we emit two more atoms (QualifiedNameHash and whether it's a ObjCClassIsImplementation). | |
1597 | No, this seems unintentional. Actually it makes things worse :( | |
tools/dsymutil/dsymutil.h | ||
43 | Because the value is always false actually it *is* tested, as this implies we always generate the pubnames and pubtypes section. I added it so I didn't have to remove the output, only to add it again once I implement the command line flag that will control this. When doing so I will also add a test that check the output for when the value is set to true. |
@adrian: looks like I was mistaken and you didn't accept yet, so updating the patch to address your comments.
Almost there. Thanks for bearing with me!
include/llvm/CodeGen/AccelTable.h | ||
---|---|---|
453 ↗ | (On Diff #131518) | Doesn't need to happen in this commit, but I think we should move the implementation of the print functions into the cpp file. |
tools/dsymutil/CMakeLists.txt | ||
4 | That is silly :-) and dsymutil is already huge. MD5 is in Support, so let's this function to Support too, and remove it from the dwarf namespace. | |
tools/dsymutil/DwarfLinker.cpp | ||
1313–1317 | Is there no EmitInt8() or EmitByte() ? |
include/llvm/CodeGen/AccelTable.h | ||
---|---|---|
453 ↗ | (On Diff #131518) | Agree. I’ll do that in a follow-up commit. |
tools/dsymutil/CMakeLists.txt | ||
4 | Yesterday I noticed that there’s another use that needed this. Anyway, it will trigger a linker error and I’ll see if I can move that into support too. | |
tools/dsymutil/DwarfLinker.cpp | ||
1313–1317 | Makes more sense indeed. I mindlessly copied this from somewhere else... |
What's the dependency that makes this necessary?