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