Author: Jonas Devlieghere Date: 2022-05-02T21:07:11-07:00 New Revision: e53019a8ff778048dd83aee29dd659af8b771920
URL: https://github.com/llvm/llvm-project/commit/e53019a8ff778048dd83aee29dd659af8b771920 DIFF: https://github.com/llvm/llvm-project/commit/e53019a8ff778048dd83aee29dd659af8b771920.diff LOG: [lldb] Make GetSharedModuleWithLocalCache consider the device support directory Make GetSharedModuleWithLocalCache consider the device support directory. In the past we only needed the device support directory to debug remote processes. Since the introduction of Apple Silicon and Rosetta this stopped being true. When debugging a Rosetta process on macOS we need to consider the Rosetta expanded shared cache. This patch and it dependencies move that logic out of PlatfromRemoteDarwinDevice into a new abstract class called PlatfromDarwinDevice. The new platform sit in between PlatformDarwin and PlatformMacOSX and PlatformRemoteDarwinDevice and has all the necessary logic to deal with the device support directory. Technically I could have moved everything in PlatfromDarwinDevice into PlatfromDarwin but decided that this logic is sufficiently self contained that it warrants its own abstraction. rdar://91966349 Differential revision: https://reviews.llvm.org/D124801 Added: Modified: lldb/source/Plugins/Platform/MacOSX/PlatformDarwinDevice.cpp Removed: ################################################################################ diff --git a/lldb/source/Plugins/Platform/MacOSX/PlatformDarwinDevice.cpp b/lldb/source/Plugins/Platform/MacOSX/PlatformDarwinDevice.cpp index d4173e4c812b9..7feaef95ea8c3 100644 --- a/lldb/source/Plugins/Platform/MacOSX/PlatformDarwinDevice.cpp +++ b/lldb/source/Plugins/Platform/MacOSX/PlatformDarwinDevice.cpp @@ -328,6 +328,29 @@ lldb_private::Status PlatformDarwinDevice::GetSharedModuleWithLocalCache( return err; } } + + // We failed to find the module in our shared cache. Let's see if we have a + // copy in our device support directory. + FileSpec device_support_spec(GetDeviceSupportDirectoryForOSVersion()); + device_support_spec.AppendPathComponent("Symbols"); + device_support_spec.AppendPathComponent( + module_spec.GetFileSpec().GetPath()); + FileSystem::Instance().Resolve(device_support_spec); + if (FileSystem::Instance().Exists(device_support_spec)) { + ModuleSpec local_spec(device_support_spec, module_spec.GetUUID()); + err = ModuleList::GetSharedModule(local_spec, module_sp, + module_search_paths_ptr, old_modules, + did_create_ptr); + if (module_sp) { + LLDB_LOGF(log, + "[%s] module %s was found in Device Support " + "directory: %s", + (IsHost() ? "host" : "remote"), + module_spec.GetFileSpec().GetPath().c_str(), + local_spec.GetFileSpec().GetPath().c_str()); + return err; + } + } } err = ModuleList::GetSharedModule(module_spec, module_sp, _______________________________________________ lldb-commits mailing list lldb-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits