philipc opened PR #9132 from philipc:split-dwarf
to bytecodealliance:main
:
The DWARF sections in
DebugInputContext
were always set to the DWARF sections from the .wasm file. However, when parsing split DWARF, most of the time we want to be using the sections from the .dwp file instead. We were already passinggimli::Dwarf
to most places already so having the sections inDebugInputContext
was no benefit. So a lot of this commit is replacingcontext
withdwarf
.Next, sometimes we were using the wrong
gimli::Dwarf
. In general, we want to use the skeleton unit for parsing line info, and the split unit for everything else.clone_unit
was wrongly using the DWARF associated with the skeleton unit in many places. Instead of changing all of those places, I've kept the variable namesdwarf
andunit
, but changed which DWARF they refer to. This also fits better with the non-split operation. So some of the changes in this commit are updating places that were already correct to use the new variable meanings.Finally, this commit adds a call to
copy_relocated_attributes
. This copies some info from the skeleton unit that is needed when parsing the split unit.For testing, the existing
dwarf_fission.dwp
is too simple for this to make any difference. I've been testing with one of my own C projects, but that's not something I want to add to wasmtime. Additionally, further fixes are required. I'm open to suggestions for a suitable small but non-trivial project to use for testing purposes.
philipc requested wasmtime-core-reviewers for a review on PR #9132.
philipc requested fitzgen for a review on PR #9132.
philipc updated PR #9132.
alexcrichton submitted PR review:
Thank you for taking the time to review this, it's much appreciated!
I've been testing with one of my own C projects, but that's not something I want to add to wasmtime. Additionally, further fixes are required. I'm open to suggestions for a suitable small but non-trivial project to use for testing purposes.
Would you happen to have a suggestion about how we can best organize tests here? Should we for example check in C files to get compiled in CI with various clang flags? Or is there a text format for DWARF which we could exploit? (or something else more clever you've done in gimli?)
alexcrichton merged PR #9132.
philipc commented on PR #9132:
I'm not aware of any text format for DWARF. gimli's testing is nearly all artificial DWARF that the tests manually assemble while running. I think it would be tedious to extend that to manually generating the associated Wasm too.
Compiling a C file in CI would be an option for functionality testing (can I step a debugger to this line and see the correct variables), but for regression tests it becomes dependent on the compiler version installed on the test system (changing the compiler may give different DWARF, so it may no longer be testing the original bug).
Maybe I can come up with a contrived C file that manages to result in a variety of DWARF. Or more likely it would need to be C++.
Last updated: Jan 24 2025 at 00:11 UTC