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