1 //===-- PlatformDarwinKernel.h ----------------------------------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #ifndef LLDB_SOURCE_PLUGINS_PLATFORM_MACOSX_PLATFORMDARWINKERNEL_H
10 #define LLDB_SOURCE_PLUGINS_PLATFORM_MACOSX_PLATFORMDARWINKERNEL_H
12 #include "PlatformDarwin.h"
13 #include "lldb/Host/FileSystem.h"
14 #include "lldb/Utility/ConstString.h"
15 #include "lldb/Utility/FileSpec.h"
16 #include "lldb/Utility/Status.h"
17 #include "lldb/Utility/UUID.h"
18 #include "lldb/lldb-forward.h"
19 #include "lldb/lldb-private-enumerations.h"
20 #include "llvm/ADT/SmallVector.h"
21 #include "llvm/ADT/StringRef.h"
22 #include "llvm/Support/FileSystem.h"
26 namespace lldb_private
{
34 #if defined(__APPLE__) // This Plugin uses the Mac-specific
35 // source/Host/macosx/cfcpp utilities
37 class PlatformDarwinKernel
: public PlatformDarwin
{
39 static lldb::PlatformSP
CreateInstance(bool force
, const ArchSpec
*arch
);
41 static void DebuggerInitialize(Debugger
&debugger
);
43 static void Initialize();
45 static void Terminate();
47 static llvm::StringRef
GetPluginNameStatic() { return "darwin-kernel"; }
49 static llvm::StringRef
GetDescriptionStatic();
51 PlatformDarwinKernel(LazyBool is_ios_debug_session
);
53 ~PlatformDarwinKernel() override
;
55 llvm::StringRef
GetPluginName() override
{ return GetPluginNameStatic(); }
57 llvm::StringRef
GetDescription() override
{ return GetDescriptionStatic(); }
59 void GetStatus(Stream
&strm
) override
;
61 Status
GetSharedModule(const ModuleSpec
&module_spec
, Process
*process
,
62 lldb::ModuleSP
&module_sp
,
63 const FileSpecList
*module_search_paths_ptr
,
64 llvm::SmallVectorImpl
<lldb::ModuleSP
> *old_modules
,
65 bool *did_create_ptr
) override
;
68 GetSupportedArchitectures(const ArchSpec
&process_host_arch
) override
;
70 bool SupportsModules() override
{ return false; }
72 void CalculateTrapHandlerSymbolNames() override
;
75 // Map from kext bundle ID ("com.apple.filesystems.exfat") to FileSpec for
76 // the kext bundle on the host
77 // ("/System/Library/Extensions/exfat.kext/Contents/Info.plist").
78 typedef std::multimap
<ConstString
, FileSpec
> BundleIDToKextMap
;
79 typedef BundleIDToKextMap::iterator BundleIDToKextIterator
;
81 typedef std::vector
<FileSpec
> KernelBinaryCollection
;
83 // Array of directories that were searched for kext bundles (used only for
84 // reporting to user).
85 typedef std::vector
<FileSpec
> DirectoriesSearchedCollection
;
86 typedef DirectoriesSearchedCollection::iterator DirectoriesSearchedIterator
;
88 // Populate m_search_directories and m_search_directories_no_recursing
89 // vectors of directories.
90 void CollectKextAndKernelDirectories();
92 void GetUserSpecifiedDirectoriesToSearch();
94 static void AddRootSubdirsToSearchPaths(PlatformDarwinKernel
*thisp
,
95 const std::string
&dir
);
97 void AddSDKSubdirsToSearchPaths(const std::string
&dir
);
99 static FileSystem::EnumerateDirectoryResult
100 FindKDKandSDKDirectoriesInDirectory(void *baton
, llvm::sys::fs::file_type ft
,
101 llvm::StringRef path
);
103 void SearchForKextsAndKernelsRecursively();
105 static FileSystem::EnumerateDirectoryResult
106 GetKernelsAndKextsInDirectoryWithRecursion(void *baton
,
107 llvm::sys::fs::file_type ft
,
108 llvm::StringRef path
);
110 static FileSystem::EnumerateDirectoryResult
111 GetKernelsAndKextsInDirectoryNoRecursion(void *baton
,
112 llvm::sys::fs::file_type ft
,
113 llvm::StringRef path
);
115 static FileSystem::EnumerateDirectoryResult
116 GetKernelsAndKextsInDirectoryHelper(void *baton
, llvm::sys::fs::file_type ft
,
117 llvm::StringRef path
, bool recurse
);
119 static std::vector
<FileSpec
>
120 SearchForExecutablesRecursively(const std::string
&dir
);
122 static void AddKextToMap(PlatformDarwinKernel
*thisp
,
123 const FileSpec
&file_spec
);
125 // Returns true if there is a .dSYM bundle next to the kext, or next to the
126 // binary inside the kext.
127 static bool KextHasdSYMSibling(const FileSpec
&kext_bundle_filepath
);
129 // Returns true if there is a .dSYM bundle next to the kernel
130 static bool KernelHasdSYMSibling(const FileSpec
&kernel_filepath
);
132 // Returns true if there is a .dSYM bundle with NO kernel binary next to it
134 KerneldSYMHasNoSiblingBinary(const FileSpec
&kernel_dsym_filepath
);
136 // Given a dsym_bundle argument ('.../foo.dSYM'), return a FileSpec
137 // with the binary inside it ('.../foo.dSYM/Contents/Resources/DWARF/foo').
138 // A dSYM bundle may have multiple DWARF binaries in them, so a vector
139 // of matches is returned.
140 static std::vector
<FileSpec
>
141 GetDWARFBinaryInDSYMBundle(const FileSpec
&dsym_bundle
);
143 Status
GetSharedModuleKext(const ModuleSpec
&module_spec
, Process
*process
,
144 lldb::ModuleSP
&module_sp
,
145 const FileSpecList
*module_search_paths_ptr
,
146 llvm::SmallVectorImpl
<lldb::ModuleSP
> *old_modules
,
147 bool *did_create_ptr
);
149 Status
GetSharedModuleKernel(
150 const ModuleSpec
&module_spec
, Process
*process
,
151 lldb::ModuleSP
&module_sp
, const FileSpecList
*module_search_paths_ptr
,
152 llvm::SmallVectorImpl
<lldb::ModuleSP
> *old_modules
, bool *did_create_ptr
);
154 Status
ExamineKextForMatchingUUID(const FileSpec
&kext_bundle_path
,
155 const UUID
&uuid
, const ArchSpec
&arch
,
156 lldb::ModuleSP
&exe_module_sp
);
158 bool LoadPlatformBinaryAndSetup(Process
*process
, lldb::addr_t addr
,
159 bool notify
) override
;
161 void UpdateKextandKernelsLocalScan();
163 // Most of the ivars are assembled under FileSystem::EnumerateDirectory calls
164 // where the function being called for each file/directory must be static.
165 // We'll pass a this pointer as a baton and access the ivars directly.
166 // Toss-up whether this should just be a struct at this point.
169 /// Multimap of CFBundleID to FileSpec on local filesystem, kexts with dSYMs
171 BundleIDToKextMap m_name_to_kext_path_map_with_dsyms
;
173 /// Multimap of CFBundleID to FileSpec on local filesystem, kexts without
174 /// dSYMs next to them.
175 BundleIDToKextMap m_name_to_kext_path_map_without_dsyms
;
177 /// List of directories we search for kexts/kernels.
178 DirectoriesSearchedCollection m_search_directories
;
180 /// List of directories we search for kexts/kernels, no recursion.
181 DirectoriesSearchedCollection m_search_directories_no_recursing
;
183 /// List of kernel binaries we found on local filesystem, without dSYMs next
185 KernelBinaryCollection m_kernel_binaries_with_dsyms
;
187 /// List of kernel binaries we found on local filesystem, with dSYMs next to
189 KernelBinaryCollection m_kernel_binaries_without_dsyms
;
191 /// List of kernel dsyms with no binaries next to them.
192 KernelBinaryCollection m_kernel_dsyms_no_binaries
;
194 /// List of kernel .dSYM.yaa files.
195 KernelBinaryCollection m_kernel_dsyms_yaas
;
197 LazyBool m_ios_debug_session
;
199 std::once_flag m_kext_scan_flag
;
201 PlatformDarwinKernel(const PlatformDarwinKernel
&) = delete;
202 const PlatformDarwinKernel
&operator=(const PlatformDarwinKernel
&) = delete;
207 // Since DynamicLoaderDarwinKernel is compiled in for all systems, and relies
208 // on PlatformDarwinKernel for the plug-in name, we compile just the plug-in
209 // name in here to avoid issues. We are tracking an internal bug to resolve
210 // this issue by either not compiling in DynamicLoaderDarwinKernel for
211 // non-apple builds, or to make PlatformDarwinKernel build on all systems.
213 // PlatformDarwinKernel is currently not compiled on other platforms due to the
214 // use of the Mac-specific source/Host/macosx/cfcpp utilities.
216 class PlatformDarwinKernel
{
218 static llvm::StringRef
GetPluginNameStatic() { return "darwin-kernel"; }
223 } // namespace lldb_private
225 #endif // LLDB_SOURCE_PLUGINS_PLATFORM_MACOSX_PLATFORMDARWINKERNEL_H