1 //===-- SystemInitializerFull.cpp -------------------------------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 
10 #if !defined(LLDB_DISABLE_PYTHON)
11 #include "Plugins/ScriptInterpreter/Python/lldb-python.h"
12 #endif
13 
14 #include "SystemInitializerFull.h"
15 
16 #include "lldb/API/SBCommandInterpreter.h"
17 
18 #if !defined(LLDB_DISABLE_PYTHON)
19 #include "Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.h"
20 #endif
21 
22 #include "lldb/Core/Debugger.h"
23 #include "lldb/Host/Host.h"
24 #include "lldb/Initialization/SystemInitializerCommon.h"
25 #include "lldb/Interpreter/CommandInterpreter.h"
26 #include "lldb/Symbol/ClangASTContext.h"
27 #include "lldb/Utility/Timer.h"
28 
29 #include "Plugins/ABI/MacOSX-arm/ABIMacOSX_arm.h"
30 #include "Plugins/ABI/MacOSX-arm64/ABIMacOSX_arm64.h"
31 #include "Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h"
32 #include "Plugins/ABI/SysV-arm/ABISysV_arm.h"
33 #include "Plugins/ABI/SysV-arm64/ABISysV_arm64.h"
34 #include "Plugins/ABI/SysV-hexagon/ABISysV_hexagon.h"
35 #include "Plugins/ABI/SysV-i386/ABISysV_i386.h"
36 #include "Plugins/ABI/SysV-mips/ABISysV_mips.h"
37 #include "Plugins/ABI/SysV-mips64/ABISysV_mips64.h"
38 #include "Plugins/ABI/SysV-ppc/ABISysV_ppc.h"
39 #include "Plugins/ABI/SysV-ppc64/ABISysV_ppc64.h"
40 #include "Plugins/ABI/SysV-s390x/ABISysV_s390x.h"
41 #include "Plugins/ABI/SysV-x86_64/ABISysV_x86_64.h"
42 #include "Plugins/Architecture/Arm/ArchitectureArm.h"
43 #include "Plugins/Architecture/PPC64/ArchitecturePPC64.h"
44 #include "Plugins/Disassembler/llvm/DisassemblerLLVMC.h"
45 #include "Plugins/DynamicLoader/MacOSX-DYLD/DynamicLoaderMacOS.h"
46 #include "Plugins/DynamicLoader/MacOSX-DYLD/DynamicLoaderMacOSXDYLD.h"
47 #include "Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.h"
48 #include "Plugins/DynamicLoader/Static/DynamicLoaderStatic.h"
49 #include "Plugins/DynamicLoader/Windows-DYLD/DynamicLoaderWindowsDYLD.h"
50 #include "Plugins/Instruction/ARM64/EmulateInstructionARM64.h"
51 #include "Plugins/Instruction/PPC64/EmulateInstructionPPC64.h"
52 #include "Plugins/InstrumentationRuntime/ASan/ASanRuntime.h"
53 #include "Plugins/InstrumentationRuntime/MainThreadChecker/MainThreadCheckerRuntime.h"
54 #include "Plugins/InstrumentationRuntime/TSan/TSanRuntime.h"
55 #include "Plugins/InstrumentationRuntime/UBSan/UBSanRuntime.h"
56 #include "Plugins/JITLoader/GDB/JITLoaderGDB.h"
57 #include "Plugins/Language/CPlusPlus/CPlusPlusLanguage.h"
58 #include "Plugins/Language/ObjC/ObjCLanguage.h"
59 #include "Plugins/Language/ObjCPlusPlus/ObjCPlusPlusLanguage.h"
60 #include "Plugins/LanguageRuntime/CPlusPlus/ItaniumABI/ItaniumABILanguageRuntime.h"
61 #include "Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCRuntimeV1.h"
62 #include "Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCRuntimeV2.h"
63 #include "Plugins/LanguageRuntime/RenderScript/RenderScriptRuntime/RenderScriptRuntime.h"
64 #include "Plugins/MemoryHistory/asan/MemoryHistoryASan.h"
65 #include "Plugins/ObjectFile/ELF/ObjectFileELF.h"
66 #include "Plugins/ObjectFile/Mach-O/ObjectFileMachO.h"
67 #include "Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h"
68 #include "Plugins/OperatingSystem/Python/OperatingSystemPython.h"
69 #include "Plugins/Platform/Android/PlatformAndroid.h"
70 #include "Plugins/Platform/FreeBSD/PlatformFreeBSD.h"
71 #include "Plugins/Platform/Kalimba/PlatformKalimba.h"
72 #include "Plugins/Platform/Linux/PlatformLinux.h"
73 #include "Plugins/Platform/MacOSX/PlatformMacOSX.h"
74 #include "Plugins/Platform/MacOSX/PlatformRemoteiOS.h"
75 #include "Plugins/Platform/NetBSD/PlatformNetBSD.h"
76 #include "Plugins/Platform/OpenBSD/PlatformOpenBSD.h"
77 #include "Plugins/Platform/Windows/PlatformWindows.h"
78 #include "Plugins/Platform/gdb-server/PlatformRemoteGDBServer.h"
79 #include "Plugins/Process/elf-core/ProcessElfCore.h"
80 #include "Plugins/Process/gdb-remote/ProcessGDBRemote.h"
81 #include "Plugins/Process/mach-core/ProcessMachCore.h"
82 #include "Plugins/Process/minidump/ProcessMinidump.h"
83 #include "Plugins/ScriptInterpreter/None/ScriptInterpreterNone.h"
84 #include "Plugins/SymbolFile/DWARF/SymbolFileDWARF.h"
85 #include "Plugins/SymbolFile/DWARF/SymbolFileDWARFDebugMap.h"
86 #include "Plugins/SymbolFile/PDB/SymbolFilePDB.h"
87 #include "Plugins/SymbolFile/Symtab/SymbolFileSymtab.h"
88 #include "Plugins/SymbolVendor/ELF/SymbolVendorELF.h"
89 #include "Plugins/SystemRuntime/MacOSX/SystemRuntimeMacOSX.h"
90 #include "Plugins/UnwindAssembly/InstEmulation/UnwindAssemblyInstEmulation.h"
91 #include "Plugins/UnwindAssembly/x86/UnwindAssembly-x86.h"
92 
93 #if defined(__APPLE__)
94 #include "Plugins/DynamicLoader/Darwin-Kernel/DynamicLoaderDarwinKernel.h"
95 #include "Plugins/Platform/MacOSX/PlatformAppleTVSimulator.h"
96 #include "Plugins/Platform/MacOSX/PlatformAppleWatchSimulator.h"
97 #include "Plugins/Platform/MacOSX/PlatformDarwinKernel.h"
98 #include "Plugins/Platform/MacOSX/PlatformRemoteAppleTV.h"
99 #include "Plugins/Platform/MacOSX/PlatformRemoteAppleWatch.h"
100 #include "Plugins/Platform/MacOSX/PlatformRemoteAppleBridge.h"
101 #include "Plugins/Platform/MacOSX/PlatformiOSSimulator.h"
102 #include "Plugins/Process/MacOSX-Kernel/ProcessKDP.h"
103 #include "Plugins/SymbolVendor/MacOSX/SymbolVendorMacOSX.h"
104 #endif
105 #include "Plugins/StructuredData/DarwinLog/StructuredDataDarwinLog.h"
106 
107 #if defined(__FreeBSD__)
108 #include "Plugins/Process/FreeBSD/ProcessFreeBSD.h"
109 #endif
110 
111 #if defined(_WIN32)
112 #include "Plugins/Process/Windows/Common/ProcessWindows.h"
113 #include "lldb/Host/windows/windows.h"
114 #endif
115 
116 #include "llvm/Support/TargetSelect.h"
117 
118 #include <string>
119 
120 using namespace lldb_private;
121 
122 #ifndef LLDB_DISABLE_PYTHON
123 
124 // Defined in the SWIG source file
125 #if PY_MAJOR_VERSION >= 3
126 extern "C" PyObject *PyInit__lldb(void);
127 
128 #define LLDBSwigPyInit PyInit__lldb
129 
130 #else
131 extern "C" void init_lldb(void);
132 
133 #define LLDBSwigPyInit init_lldb
134 #endif
135 
136 // these are the Pythonic implementations of the required callbacks these are
137 // scripting-language specific, which is why they belong here we still need to
138 // use function pointers to them instead of relying on linkage-time resolution
139 // because the SWIG stuff and this file get built at different times
140 extern "C" bool LLDBSwigPythonBreakpointCallbackFunction(
141     const char *python_function_name, const char *session_dictionary_name,
142     const lldb::StackFrameSP &sb_frame,
143     const lldb::BreakpointLocationSP &sb_bp_loc);
144 
145 extern "C" bool LLDBSwigPythonWatchpointCallbackFunction(
146     const char *python_function_name, const char *session_dictionary_name,
147     const lldb::StackFrameSP &sb_frame, const lldb::WatchpointSP &sb_wp);
148 
149 extern "C" bool LLDBSwigPythonCallTypeScript(
150     const char *python_function_name, void *session_dictionary,
151     const lldb::ValueObjectSP &valobj_sp, void **pyfunct_wrapper,
152     const lldb::TypeSummaryOptionsSP &options_sp, std::string &retval);
153 
154 extern "C" void *
155 LLDBSwigPythonCreateSyntheticProvider(const char *python_class_name,
156                                       const char *session_dictionary_name,
157                                       const lldb::ValueObjectSP &valobj_sp);
158 
159 extern "C" void *
160 LLDBSwigPythonCreateCommandObject(const char *python_class_name,
161                                   const char *session_dictionary_name,
162                                   const lldb::DebuggerSP debugger_sp);
163 
164 extern "C" void *LLDBSwigPythonCreateScriptedThreadPlan(
165     const char *python_class_name, const char *session_dictionary_name,
166     const lldb::ThreadPlanSP &thread_plan_sp);
167 
168 extern "C" bool LLDBSWIGPythonCallThreadPlan(void *implementor,
169                                              const char *method_name,
170                                              Event *event_sp, bool &got_error);
171 
172 extern "C" void *LLDBSwigPythonCreateScriptedBreakpointResolver(
173     const char *python_class_name,
174     const char *session_dictionary_name,
175     lldb_private::StructuredDataImpl *args,
176     lldb::BreakpointSP &bkpt_sp);
177 
178 extern "C" unsigned int LLDBSwigPythonCallBreakpointResolver(
179     void *implementor,
180     const char *method_name,
181     lldb_private::SymbolContext *sym_ctx
182 );
183 
184 extern "C" size_t LLDBSwigPython_CalculateNumChildren(void *implementor,
185                                                       uint32_t max);
186 
187 extern "C" void *LLDBSwigPython_GetChildAtIndex(void *implementor,
188                                                 uint32_t idx);
189 
190 extern "C" int LLDBSwigPython_GetIndexOfChildWithName(void *implementor,
191                                                       const char *child_name);
192 
193 extern "C" void *LLDBSWIGPython_CastPyObjectToSBValue(void *data);
194 
195 extern lldb::ValueObjectSP
196 LLDBSWIGPython_GetValueObjectSPFromSBValue(void *data);
197 
198 extern "C" bool LLDBSwigPython_UpdateSynthProviderInstance(void *implementor);
199 
200 extern "C" bool
201 LLDBSwigPython_MightHaveChildrenSynthProviderInstance(void *implementor);
202 
203 extern "C" void *
204 LLDBSwigPython_GetValueSynthProviderInstance(void *implementor);
205 
206 extern "C" bool
207 LLDBSwigPythonCallCommand(const char *python_function_name,
208                           const char *session_dictionary_name,
209                           lldb::DebuggerSP &debugger, const char *args,
210                           lldb_private::CommandReturnObject &cmd_retobj,
211                           lldb::ExecutionContextRefSP exe_ctx_ref_sp);
212 
213 extern "C" bool
214 LLDBSwigPythonCallCommandObject(void *implementor, lldb::DebuggerSP &debugger,
215                                 const char *args,
216                                 lldb_private::CommandReturnObject &cmd_retobj,
217                                 lldb::ExecutionContextRefSP exe_ctx_ref_sp);
218 
219 extern "C" bool
220 LLDBSwigPythonCallModuleInit(const char *python_module_name,
221                              const char *session_dictionary_name,
222                              lldb::DebuggerSP &debugger);
223 
224 extern "C" void *
225 LLDBSWIGPythonCreateOSPlugin(const char *python_class_name,
226                              const char *session_dictionary_name,
227                              const lldb::ProcessSP &process_sp);
228 
229 extern "C" void *LLDBSWIGPython_CreateFrameRecognizer(
230     const char *python_class_name,
231     const char *session_dictionary_name);
232 
233 extern "C" void *LLDBSwigPython_GetRecognizedArguments(void *implementor,
234     const lldb::StackFrameSP& frame_sp);
235 
236 extern "C" bool LLDBSWIGPythonRunScriptKeywordProcess(
237     const char *python_function_name, const char *session_dictionary_name,
238     lldb::ProcessSP &process, std::string &output);
239 
240 extern "C" bool LLDBSWIGPythonRunScriptKeywordThread(
241     const char *python_function_name, const char *session_dictionary_name,
242     lldb::ThreadSP &thread, std::string &output);
243 
244 extern "C" bool LLDBSWIGPythonRunScriptKeywordTarget(
245     const char *python_function_name, const char *session_dictionary_name,
246     lldb::TargetSP &target, std::string &output);
247 
248 extern "C" bool LLDBSWIGPythonRunScriptKeywordFrame(
249     const char *python_function_name, const char *session_dictionary_name,
250     lldb::StackFrameSP &frame, std::string &output);
251 
252 extern "C" bool LLDBSWIGPythonRunScriptKeywordValue(
253     const char *python_function_name, const char *session_dictionary_name,
254     lldb::ValueObjectSP &value, std::string &output);
255 
256 extern "C" void *
257 LLDBSWIGPython_GetDynamicSetting(void *module, const char *setting,
258                                  const lldb::TargetSP &target_sp);
259 
260 #endif
261 
262 SystemInitializerFull::SystemInitializerFull() {}
263 
264 SystemInitializerFull::~SystemInitializerFull() {}
265 
266 void SystemInitializerFull::Initialize() {
267   SystemInitializerCommon::Initialize();
268 
269   ObjectFileELF::Initialize();
270   ObjectFileMachO::Initialize();
271   ObjectFilePECOFF::Initialize();
272 
273   ScriptInterpreterNone::Initialize();
274 
275 #ifndef LLDB_DISABLE_PYTHON
276   OperatingSystemPython::Initialize();
277 #endif
278 
279 #if !defined(LLDB_DISABLE_PYTHON)
280   InitializeSWIG();
281 
282   // ScriptInterpreterPython::Initialize() depends on things like HostInfo
283   // being initialized so it can compute the python directory etc, so we need
284   // to do this after SystemInitializerCommon::Initialize().
285   ScriptInterpreterPython::Initialize();
286 #endif
287 
288   platform_freebsd::PlatformFreeBSD::Initialize();
289   platform_linux::PlatformLinux::Initialize();
290   platform_netbsd::PlatformNetBSD::Initialize();
291   platform_openbsd::PlatformOpenBSD::Initialize();
292   PlatformWindows::Initialize();
293   PlatformKalimba::Initialize();
294   platform_android::PlatformAndroid::Initialize();
295   PlatformRemoteiOS::Initialize();
296   PlatformMacOSX::Initialize();
297 #if defined(__APPLE__)
298   PlatformiOSSimulator::Initialize();
299   PlatformDarwinKernel::Initialize();
300 #endif
301 
302   // Initialize LLVM and Clang
303   llvm::InitializeAllTargets();
304   llvm::InitializeAllAsmPrinters();
305   llvm::InitializeAllTargetMCs();
306   llvm::InitializeAllDisassemblers();
307 
308   ClangASTContext::Initialize();
309 
310   ABIMacOSX_i386::Initialize();
311   ABIMacOSX_arm::Initialize();
312   ABIMacOSX_arm64::Initialize();
313   ABISysV_arm::Initialize();
314   ABISysV_arm64::Initialize();
315   ABISysV_hexagon::Initialize();
316   ABISysV_i386::Initialize();
317   ABISysV_x86_64::Initialize();
318   ABISysV_ppc::Initialize();
319   ABISysV_ppc64::Initialize();
320   ABISysV_mips::Initialize();
321   ABISysV_mips64::Initialize();
322   ABISysV_s390x::Initialize();
323 
324   ArchitectureArm::Initialize();
325   ArchitecturePPC64::Initialize();
326 
327   DisassemblerLLVMC::Initialize();
328 
329   JITLoaderGDB::Initialize();
330   ProcessElfCore::Initialize();
331   ProcessMachCore::Initialize();
332   minidump::ProcessMinidump::Initialize();
333   MemoryHistoryASan::Initialize();
334   AddressSanitizerRuntime::Initialize();
335   ThreadSanitizerRuntime::Initialize();
336   UndefinedBehaviorSanitizerRuntime::Initialize();
337   MainThreadCheckerRuntime::Initialize();
338 
339   SymbolVendorELF::Initialize();
340   SymbolFileDWARF::Initialize();
341   SymbolFilePDB::Initialize();
342   SymbolFileSymtab::Initialize();
343   UnwindAssemblyInstEmulation::Initialize();
344   UnwindAssembly_x86::Initialize();
345   EmulateInstructionARM64::Initialize();
346   EmulateInstructionPPC64::Initialize();
347   SymbolFileDWARFDebugMap::Initialize();
348   ItaniumABILanguageRuntime::Initialize();
349   AppleObjCRuntimeV2::Initialize();
350   AppleObjCRuntimeV1::Initialize();
351   SystemRuntimeMacOSX::Initialize();
352   RenderScriptRuntime::Initialize();
353 
354   CPlusPlusLanguage::Initialize();
355   ObjCLanguage::Initialize();
356   ObjCPlusPlusLanguage::Initialize();
357 
358 #if defined(_WIN32)
359   ProcessWindows::Initialize();
360 #endif
361 #if defined(__FreeBSD__)
362   ProcessFreeBSD::Initialize();
363 #endif
364 #if defined(__APPLE__)
365   SymbolVendorMacOSX::Initialize();
366   ProcessKDP::Initialize();
367   PlatformAppleTVSimulator::Initialize();
368   PlatformAppleWatchSimulator::Initialize();
369   PlatformRemoteAppleTV::Initialize();
370   PlatformRemoteAppleWatch::Initialize();
371   PlatformRemoteAppleBridge::Initialize();
372   DynamicLoaderDarwinKernel::Initialize();
373 #endif
374 
375   // This plugin is valid on any host that talks to a Darwin remote. It
376   // shouldn't be limited to __APPLE__.
377   StructuredDataDarwinLog::Initialize();
378 
379   //----------------------------------------------------------------------
380   // Platform agnostic plugins
381   //----------------------------------------------------------------------
382   platform_gdb_server::PlatformRemoteGDBServer::Initialize();
383 
384   process_gdb_remote::ProcessGDBRemote::Initialize();
385   DynamicLoaderMacOSXDYLD::Initialize();
386   DynamicLoaderMacOS::Initialize();
387   DynamicLoaderPOSIXDYLD::Initialize();
388   DynamicLoaderStatic::Initialize();
389   DynamicLoaderWindowsDYLD::Initialize();
390 
391   // Scan for any system or user LLDB plug-ins
392   PluginManager::Initialize();
393 
394   // The process settings need to know about installed plug-ins, so the
395   // Settings must be initialized
396   // AFTER PluginManager::Initialize is called.
397 
398   Debugger::SettingsInitialize();
399 }
400 
401 void SystemInitializerFull::InitializeSWIG() {
402 #if !defined(LLDB_DISABLE_PYTHON)
403   ScriptInterpreterPython::InitializeInterpreter(
404       LLDBSwigPyInit, LLDBSwigPythonBreakpointCallbackFunction,
405       LLDBSwigPythonWatchpointCallbackFunction, LLDBSwigPythonCallTypeScript,
406       LLDBSwigPythonCreateSyntheticProvider, LLDBSwigPythonCreateCommandObject,
407       LLDBSwigPython_CalculateNumChildren, LLDBSwigPython_GetChildAtIndex,
408       LLDBSwigPython_GetIndexOfChildWithName,
409       LLDBSWIGPython_CastPyObjectToSBValue,
410       LLDBSWIGPython_GetValueObjectSPFromSBValue,
411       LLDBSwigPython_UpdateSynthProviderInstance,
412       LLDBSwigPython_MightHaveChildrenSynthProviderInstance,
413       LLDBSwigPython_GetValueSynthProviderInstance, LLDBSwigPythonCallCommand,
414       LLDBSwigPythonCallCommandObject, LLDBSwigPythonCallModuleInit,
415       LLDBSWIGPythonCreateOSPlugin, LLDBSWIGPython_CreateFrameRecognizer,
416       LLDBSwigPython_GetRecognizedArguments,
417       LLDBSWIGPythonRunScriptKeywordProcess,
418       LLDBSWIGPythonRunScriptKeywordThread,
419       LLDBSWIGPythonRunScriptKeywordTarget, LLDBSWIGPythonRunScriptKeywordFrame,
420       LLDBSWIGPythonRunScriptKeywordValue, LLDBSWIGPython_GetDynamicSetting,
421       LLDBSwigPythonCreateScriptedThreadPlan, LLDBSWIGPythonCallThreadPlan,
422       LLDBSwigPythonCreateScriptedBreakpointResolver, LLDBSwigPythonCallBreakpointResolver);
423 #endif
424 }
425 
426 void SystemInitializerFull::Terminate() {
427   static Timer::Category func_cat(LLVM_PRETTY_FUNCTION);
428   Timer scoped_timer(func_cat, LLVM_PRETTY_FUNCTION);
429 
430   Debugger::SettingsTerminate();
431 
432   // Terminate and unload and loaded system or user LLDB plug-ins
433   PluginManager::Terminate();
434 
435   ClangASTContext::Terminate();
436 
437   ABIMacOSX_i386::Terminate();
438   ABIMacOSX_arm::Terminate();
439   ABIMacOSX_arm64::Terminate();
440   ABISysV_arm::Terminate();
441   ABISysV_arm64::Terminate();
442   ABISysV_hexagon::Terminate();
443   ABISysV_i386::Terminate();
444   ABISysV_x86_64::Terminate();
445   ABISysV_ppc::Terminate();
446   ABISysV_ppc64::Terminate();
447   ABISysV_mips::Terminate();
448   ABISysV_mips64::Terminate();
449   ABISysV_s390x::Terminate();
450   DisassemblerLLVMC::Terminate();
451 
452   JITLoaderGDB::Terminate();
453   ProcessElfCore::Terminate();
454   ProcessMachCore::Terminate();
455   minidump::ProcessMinidump::Terminate();
456   MemoryHistoryASan::Terminate();
457   AddressSanitizerRuntime::Terminate();
458   ThreadSanitizerRuntime::Terminate();
459   UndefinedBehaviorSanitizerRuntime::Terminate();
460   MainThreadCheckerRuntime::Terminate();
461   SymbolVendorELF::Terminate();
462   SymbolFileDWARF::Terminate();
463   SymbolFilePDB::Terminate();
464   SymbolFileSymtab::Terminate();
465   UnwindAssembly_x86::Terminate();
466   UnwindAssemblyInstEmulation::Terminate();
467   EmulateInstructionARM64::Terminate();
468   EmulateInstructionPPC64::Terminate();
469   SymbolFileDWARFDebugMap::Terminate();
470   ItaniumABILanguageRuntime::Terminate();
471   AppleObjCRuntimeV2::Terminate();
472   AppleObjCRuntimeV1::Terminate();
473   SystemRuntimeMacOSX::Terminate();
474   RenderScriptRuntime::Terminate();
475 
476   CPlusPlusLanguage::Terminate();
477   ObjCLanguage::Terminate();
478   ObjCPlusPlusLanguage::Terminate();
479 
480 #if defined(__APPLE__)
481   DynamicLoaderDarwinKernel::Terminate();
482   ProcessKDP::Terminate();
483   SymbolVendorMacOSX::Terminate();
484   PlatformAppleTVSimulator::Terminate();
485   PlatformAppleWatchSimulator::Terminate();
486   PlatformRemoteAppleTV::Terminate();
487   PlatformRemoteAppleWatch::Terminate();
488   PlatformRemoteAppleBridge::Terminate();
489 #endif
490 
491 #if defined(__FreeBSD__)
492   ProcessFreeBSD::Terminate();
493 #endif
494   Debugger::SettingsTerminate();
495 
496   platform_gdb_server::PlatformRemoteGDBServer::Terminate();
497   process_gdb_remote::ProcessGDBRemote::Terminate();
498   StructuredDataDarwinLog::Terminate();
499 
500   DynamicLoaderMacOSXDYLD::Terminate();
501   DynamicLoaderMacOS::Terminate();
502   DynamicLoaderPOSIXDYLD::Terminate();
503   DynamicLoaderStatic::Terminate();
504   DynamicLoaderWindowsDYLD::Terminate();
505 
506 #ifndef LLDB_DISABLE_PYTHON
507   OperatingSystemPython::Terminate();
508 #endif
509 
510   platform_freebsd::PlatformFreeBSD::Terminate();
511   platform_linux::PlatformLinux::Terminate();
512   platform_netbsd::PlatformNetBSD::Terminate();
513   platform_openbsd::PlatformOpenBSD::Terminate();
514   PlatformWindows::Terminate();
515   PlatformKalimba::Terminate();
516   platform_android::PlatformAndroid::Terminate();
517   PlatformMacOSX::Terminate();
518   PlatformRemoteiOS::Terminate();
519 #if defined(__APPLE__)
520   PlatformiOSSimulator::Terminate();
521   PlatformDarwinKernel::Terminate();
522 #endif
523 
524   ObjectFileELF::Terminate();
525   ObjectFileMachO::Terminate();
526   ObjectFilePECOFF::Terminate();
527 
528   // Now shutdown the common parts, in reverse order.
529   SystemInitializerCommon::Terminate();
530 }
531