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