This builds on the work in https://reviews.llvm.org/D133534 where support for a platform binary in live process debugging was added, and adds it to the Mach-O corefile loading as well. It has five changes:
- Add a name field to DynamicLoader::LoadBinaryWithUUIDAndAddress when we have a name, but may end up reading the binary out of memory, so we can use the name instead of a generic placeholder.
- In ObjectFileMachO::LoadCoreFileImages, check if the image address is a platform binary, load it and set the Platform/DynamicLoader as appropriate.
- Clean up the different cases in LoadCoreFileImages that handle corefile binary loading so it is clearer to read.
- Separate ProcessMachCore::DoLoadCore into half a dozen smaller helper methods. This method had grown quite large and it was difficult to trace the code flow through the different parts, and the complexity was unnecessary.
- In the new ProcessMachCore::LoadBinariesViaMetadata method which handles LC_NOTE type hints about binaries, when we have a main bin spec LC_NOTE that is explicitly a kernel, don't load the binary here -- just save the address and note that this will be a DynamicLoaderDarwinKernel dynamic loader, and leave the loading up to DynamicLoaderDarwinKernel to do correctly.
The minor cleanups in ObjectFileMachO::LoadCoreFileImages are easy to read in the phabracator if you only read the new version of the code. The (seriously needed) separation of ObjectFileMachO::LoadCoreFileImages into separate methods has made the diff very difficult to read. In my own reviewing of the patch, I've settled on simply reading through the new version of the file. Most of it is simple code movement, but I did make some cleanups to how sections of code were working -- for instance in the exhaustive search for a dyld or kernel binary, when multiple images that appear to be a kernel are found, I handle this better now by allowing DynamicLoaderDarwinKernel to pick the kernel image. It's common that we get fragments in a corefile that look similar to a kernel and can confuse the exhaustive search algorithm.
Similar to the problem of testing this with a live process, to test this I'd need to construct a corefile with a Mach-O fileset with a kernel image in it. It would not be easy to construct a test case without a corefile writer that synthesized all of this together, a not small bit of code, and it would also need to modify a test binary's mach header to look enough like a kernel that lldb would be tricked into using it.
Can you list what it might be constructed from? My guess: