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