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 #include "SystemInitializerFull.h"
10 #include "lldb/API/SBCommandInterpreter.h"
11 #include "lldb/Host/Config.h"
12 
13 #if !defined(LLDB_DISABLE_PYTHON)
14 #include "Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.h"
15 #endif
16 
17 #include "lldb/Core/Debugger.h"
18 #include "lldb/Host/Host.h"
19 #include "lldb/Initialization/SystemInitializerCommon.h"
20 #include "lldb/Interpreter/CommandInterpreter.h"
21 #include "lldb/Symbol/ClangASTContext.h"
22 #include "lldb/Utility/Timer.h"
23 
24 #include "Plugins/ABI/MacOSX-arm/ABIMacOSX_arm.h"
25 #include "Plugins/ABI/MacOSX-arm64/ABIMacOSX_arm64.h"
26 #include "Plugins/ABI/MacOSX-i386/ABIMacOSX_i386.h"
27 #include "Plugins/ABI/SysV-arc/ABISysV_arc.h"
28 #include "Plugins/ABI/SysV-arm/ABISysV_arm.h"
29 #include "Plugins/ABI/SysV-arm64/ABISysV_arm64.h"
30 #include "Plugins/ABI/SysV-hexagon/ABISysV_hexagon.h"
31 #include "Plugins/ABI/SysV-i386/ABISysV_i386.h"
32 #include "Plugins/ABI/SysV-mips/ABISysV_mips.h"
33 #include "Plugins/ABI/SysV-mips64/ABISysV_mips64.h"
34 #include "Plugins/ABI/SysV-ppc/ABISysV_ppc.h"
35 #include "Plugins/ABI/SysV-ppc64/ABISysV_ppc64.h"
36 #include "Plugins/ABI/SysV-s390x/ABISysV_s390x.h"
37 #include "Plugins/ABI/SysV-x86_64/ABISysV_x86_64.h"
38 #include "Plugins/ABI/Windows-x86_64/ABIWindows_x86_64.h"
39 #include "Plugins/Architecture/Arm/ArchitectureArm.h"
40 #include "Plugins/Architecture/Mips/ArchitectureMips.h"
41 #include "Plugins/Architecture/PPC64/ArchitecturePPC64.h"
42 #include "Plugins/Disassembler/llvm/DisassemblerLLVMC.h"
43 #include "Plugins/DynamicLoader/MacOSX-DYLD/DynamicLoaderMacOS.h"
44 #include "Plugins/DynamicLoader/MacOSX-DYLD/DynamicLoaderMacOSXDYLD.h"
45 #include "Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.h"
46 #include "Plugins/DynamicLoader/Static/DynamicLoaderStatic.h"
47 #include "Plugins/DynamicLoader/Windows-DYLD/DynamicLoaderWindowsDYLD.h"
48 #include "Plugins/Instruction/ARM/EmulateInstructionARM.h"
49 #include "Plugins/Instruction/ARM64/EmulateInstructionARM64.h"
50 #include "Plugins/Instruction/MIPS/EmulateInstructionMIPS.h"
51 #include "Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.h"
52 #include "Plugins/Instruction/PPC64/EmulateInstructionPPC64.h"
53 #include "Plugins/InstrumentationRuntime/ASan/ASanRuntime.h"
54 #include "Plugins/InstrumentationRuntime/MainThreadChecker/MainThreadCheckerRuntime.h"
55 #include "Plugins/InstrumentationRuntime/TSan/TSanRuntime.h"
56 #include "Plugins/InstrumentationRuntime/UBSan/UBSanRuntime.h"
57 #include "Plugins/JITLoader/GDB/JITLoaderGDB.h"
58 #include "Plugins/Language/CPlusPlus/CPlusPlusLanguage.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/ObjC/AppleObjCRuntime/AppleObjCRuntimeV1.h"
63 #include "Plugins/LanguageRuntime/ObjC/AppleObjCRuntime/AppleObjCRuntimeV2.h"
64 #include "Plugins/LanguageRuntime/RenderScript/RenderScriptRuntime/RenderScriptRuntime.h"
65 #include "Plugins/MemoryHistory/asan/MemoryHistoryASan.h"
66 #include "Plugins/ObjectContainer/BSD-Archive/ObjectContainerBSDArchive.h"
67 #include "Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.h"
68 #include "Plugins/ObjectFile/Breakpad/ObjectFileBreakpad.h"
69 #include "Plugins/ObjectFile/ELF/ObjectFileELF.h"
70 #include "Plugins/ObjectFile/Mach-O/ObjectFileMachO.h"
71 #include "Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h"
72 #include "Plugins/OperatingSystem/Python/OperatingSystemPython.h"
73 #include "Plugins/Platform/Android/PlatformAndroid.h"
74 #include "Plugins/Platform/FreeBSD/PlatformFreeBSD.h"
75 #include "Plugins/Platform/Linux/PlatformLinux.h"
76 #include "Plugins/Platform/MacOSX/PlatformMacOSX.h"
77 #include "Plugins/Platform/MacOSX/PlatformRemoteiOS.h"
78 #include "Plugins/Platform/NetBSD/PlatformNetBSD.h"
79 #include "Plugins/Platform/OpenBSD/PlatformOpenBSD.h"
80 #include "Plugins/Platform/Windows/PlatformWindows.h"
81 #include "Plugins/Platform/gdb-server/PlatformRemoteGDBServer.h"
82 #include "Plugins/Process/elf-core/ProcessElfCore.h"
83 #include "Plugins/Process/gdb-remote/ProcessGDBRemote.h"
84 #include "Plugins/Process/mach-core/ProcessMachCore.h"
85 #include "Plugins/Process/minidump/ProcessMinidump.h"
86 #include "Plugins/ScriptInterpreter/None/ScriptInterpreterNone.h"
87 #include "Plugins/SymbolFile/Breakpad/SymbolFileBreakpad.h"
88 #include "Plugins/SymbolFile/DWARF/SymbolFileDWARF.h"
89 #include "Plugins/SymbolFile/DWARF/SymbolFileDWARFDebugMap.h"
90 #include "Plugins/SymbolFile/PDB/SymbolFilePDB.h"
91 #include "Plugins/SymbolFile/Symtab/SymbolFileSymtab.h"
92 #include "Plugins/SymbolVendor/ELF/SymbolVendorELF.h"
93 #include "Plugins/SystemRuntime/MacOSX/SystemRuntimeMacOSX.h"
94 #include "Plugins/UnwindAssembly/InstEmulation/UnwindAssemblyInstEmulation.h"
95 #include "Plugins/UnwindAssembly/x86/UnwindAssembly-x86.h"
96 
97 #if defined(__APPLE__)
98 #include "Plugins/DynamicLoader/Darwin-Kernel/DynamicLoaderDarwinKernel.h"
99 #include "Plugins/Platform/MacOSX/PlatformAppleTVSimulator.h"
100 #include "Plugins/Platform/MacOSX/PlatformAppleWatchSimulator.h"
101 #include "Plugins/Platform/MacOSX/PlatformDarwinKernel.h"
102 #include "Plugins/Platform/MacOSX/PlatformRemoteAppleBridge.h"
103 #include "Plugins/Platform/MacOSX/PlatformRemoteAppleTV.h"
104 #include "Plugins/Platform/MacOSX/PlatformRemoteAppleWatch.h"
105 #include "Plugins/Platform/MacOSX/PlatformiOSSimulator.h"
106 #include "Plugins/Process/MacOSX-Kernel/ProcessKDP.h"
107 #include "Plugins/SymbolVendor/MacOSX/SymbolVendorMacOSX.h"
108 #endif
109 #include "Plugins/StructuredData/DarwinLog/StructuredDataDarwinLog.h"
110 
111 #if defined(__FreeBSD__)
112 #include "Plugins/Process/FreeBSD/ProcessFreeBSD.h"
113 #endif
114 
115 #if defined(_WIN32)
116 #include "Plugins/Process/Windows/Common/ProcessWindows.h"
117 #include "lldb/Host/windows/windows.h"
118 #endif
119 
120 #include "llvm/Support/TargetSelect.h"
121 
122 #pragma clang diagnostic push
123 #pragma clang diagnostic ignored "-Wglobal-constructors"
124 #include "llvm/ExecutionEngine/MCJIT.h"
125 #pragma clang diagnostic pop
126 
127 #include <string>
128 
129 using namespace lldb_private;
130 
131 SystemInitializerFull::SystemInitializerFull() {}
132 
133 SystemInitializerFull::~SystemInitializerFull() {}
134 
135 #define LLDB_PROCESS_AArch64(op)                                               \
136   ABIMacOSX_arm64::op();                                                       \
137   ABISysV_arm64::op();
138 #define LLDB_PROCESS_ARM(op)                                                   \
139   ABIMacOSX_arm::op();                                                         \
140   ABISysV_arm::op();
141 #define LLDB_PROCESS_ARC(op)                                                   \
142   ABISysV_arc::op();
143 #define LLDB_PROCESS_Hexagon(op) ABISysV_hexagon::op();
144 #define LLDB_PROCESS_Mips(op)                                                  \
145   ABISysV_mips::op();                                                          \
146   ABISysV_mips64::op();
147 #define LLDB_PROCESS_PowerPC(op)                                               \
148   ABISysV_ppc::op();                                                          \
149   ABISysV_ppc64::op();
150 #define LLDB_PROCESS_SystemZ(op) ABISysV_s390x::op();
151 #define LLDB_PROCESS_X86(op)                                                   \
152   ABIMacOSX_i386::op();                                                        \
153   ABISysV_i386::op();                                                          \
154   ABISysV_x86_64::op();                                                        \
155   ABIWindows_x86_64::op();
156 
157 #define LLDB_PROCESS_AMDGPU(op)
158 #define LLDB_PROCESS_AVR(op)
159 #define LLDB_PROCESS_BPF(op)
160 #define LLDB_PROCESS_Lanai(op)
161 #define LLDB_PROCESS_MSP430(op)
162 #define LLDB_PROCESS_NVPTX(op)
163 #define LLDB_PROCESS_RISCV(op)
164 #define LLDB_PROCESS_Sparc(op)
165 #define LLDB_PROCESS_WebAssembly(op)
166 #define LLDB_PROCESS_XCore(op)
167 
168 llvm::Error SystemInitializerFull::Initialize() {
169   if (auto e = SystemInitializerCommon::Initialize())
170     return e;
171 
172   breakpad::ObjectFileBreakpad::Initialize();
173   ObjectFileELF::Initialize();
174   ObjectFileMachO::Initialize();
175   ObjectFilePECOFF::Initialize();
176 
177   ObjectContainerBSDArchive::Initialize();
178   ObjectContainerUniversalMachO::Initialize();
179 
180   ScriptInterpreterNone::Initialize();
181 
182 #ifndef LLDB_DISABLE_PYTHON
183   OperatingSystemPython::Initialize();
184 #endif
185 
186 #if !defined(LLDB_DISABLE_PYTHON)
187   ScriptInterpreterPython::Initialize();
188 #endif
189 
190   platform_freebsd::PlatformFreeBSD::Initialize();
191   platform_linux::PlatformLinux::Initialize();
192   platform_netbsd::PlatformNetBSD::Initialize();
193   platform_openbsd::PlatformOpenBSD::Initialize();
194   PlatformWindows::Initialize();
195   platform_android::PlatformAndroid::Initialize();
196   PlatformRemoteiOS::Initialize();
197   PlatformMacOSX::Initialize();
198 #if defined(__APPLE__)
199   PlatformiOSSimulator::Initialize();
200   PlatformDarwinKernel::Initialize();
201 #endif
202 
203   // Initialize LLVM and Clang
204   llvm::InitializeAllTargets();
205   llvm::InitializeAllAsmPrinters();
206   llvm::InitializeAllTargetMCs();
207   llvm::InitializeAllDisassemblers();
208 
209   ClangASTContext::Initialize();
210 
211 #define LLVM_TARGET(t) LLDB_PROCESS_ ## t(Initialize)
212 #include "llvm/Config/Targets.def"
213 
214   ArchitectureArm::Initialize();
215   ArchitectureMips::Initialize();
216   ArchitecturePPC64::Initialize();
217 
218   DisassemblerLLVMC::Initialize();
219 
220   JITLoaderGDB::Initialize();
221   ProcessElfCore::Initialize();
222   ProcessMachCore::Initialize();
223   minidump::ProcessMinidump::Initialize();
224   MemoryHistoryASan::Initialize();
225   AddressSanitizerRuntime::Initialize();
226   ThreadSanitizerRuntime::Initialize();
227   UndefinedBehaviorSanitizerRuntime::Initialize();
228   MainThreadCheckerRuntime::Initialize();
229 
230   SymbolVendorELF::Initialize();
231   breakpad::SymbolFileBreakpad::Initialize();
232   SymbolFileDWARF::Initialize();
233   SymbolFilePDB::Initialize();
234   SymbolFileSymtab::Initialize();
235   UnwindAssemblyInstEmulation::Initialize();
236   UnwindAssembly_x86::Initialize();
237 
238   EmulateInstructionARM::Initialize();
239   EmulateInstructionARM64::Initialize();
240   EmulateInstructionMIPS::Initialize();
241   EmulateInstructionMIPS64::Initialize();
242   EmulateInstructionPPC64::Initialize();
243 
244   SymbolFileDWARFDebugMap::Initialize();
245   ItaniumABILanguageRuntime::Initialize();
246   AppleObjCRuntimeV2::Initialize();
247   AppleObjCRuntimeV1::Initialize();
248   SystemRuntimeMacOSX::Initialize();
249   RenderScriptRuntime::Initialize();
250 
251   CPlusPlusLanguage::Initialize();
252   ObjCLanguage::Initialize();
253   ObjCPlusPlusLanguage::Initialize();
254 
255 #if defined(_WIN32)
256   ProcessWindows::Initialize();
257 #endif
258 #if defined(__FreeBSD__)
259   ProcessFreeBSD::Initialize();
260 #endif
261 #if defined(__APPLE__)
262   SymbolVendorMacOSX::Initialize();
263   ProcessKDP::Initialize();
264   PlatformAppleTVSimulator::Initialize();
265   PlatformAppleWatchSimulator::Initialize();
266   PlatformRemoteAppleTV::Initialize();
267   PlatformRemoteAppleWatch::Initialize();
268   PlatformRemoteAppleBridge::Initialize();
269   DynamicLoaderDarwinKernel::Initialize();
270 #endif
271 
272   // This plugin is valid on any host that talks to a Darwin remote. It
273   // shouldn't be limited to __APPLE__.
274   StructuredDataDarwinLog::Initialize();
275 
276   // Platform agnostic plugins
277   platform_gdb_server::PlatformRemoteGDBServer::Initialize();
278 
279   process_gdb_remote::ProcessGDBRemote::Initialize();
280   DynamicLoaderMacOSXDYLD::Initialize();
281   DynamicLoaderMacOS::Initialize();
282   DynamicLoaderPOSIXDYLD::Initialize();
283   DynamicLoaderStatic::Initialize();
284   DynamicLoaderWindowsDYLD::Initialize();
285 
286   // Scan for any system or user LLDB plug-ins
287   PluginManager::Initialize();
288 
289   // The process settings need to know about installed plug-ins, so the
290   // Settings must be initialized
291   // AFTER PluginManager::Initialize is called.
292 
293   Debugger::SettingsInitialize();
294 
295   return llvm::Error::success();
296 }
297 
298 void SystemInitializerFull::Terminate() {
299   static Timer::Category func_cat(LLVM_PRETTY_FUNCTION);
300   Timer scoped_timer(func_cat, LLVM_PRETTY_FUNCTION);
301 
302   Debugger::SettingsTerminate();
303 
304   // Terminate and unload and loaded system or user LLDB plug-ins
305   PluginManager::Terminate();
306 
307   ClangASTContext::Terminate();
308 
309   ArchitectureArm::Terminate();
310   ArchitectureMips::Terminate();
311   ArchitecturePPC64::Terminate();
312 
313 #define LLVM_TARGET(t) LLDB_PROCESS_ ## t(Terminate)
314 #include "llvm/Config/Targets.def"
315 
316   DisassemblerLLVMC::Terminate();
317 
318   JITLoaderGDB::Terminate();
319   ProcessElfCore::Terminate();
320   ProcessMachCore::Terminate();
321   minidump::ProcessMinidump::Terminate();
322   MemoryHistoryASan::Terminate();
323   AddressSanitizerRuntime::Terminate();
324   ThreadSanitizerRuntime::Terminate();
325   UndefinedBehaviorSanitizerRuntime::Terminate();
326   MainThreadCheckerRuntime::Terminate();
327   SymbolVendorELF::Terminate();
328   breakpad::SymbolFileBreakpad::Terminate();
329   SymbolFileDWARF::Terminate();
330   SymbolFilePDB::Terminate();
331   SymbolFileSymtab::Terminate();
332   UnwindAssembly_x86::Terminate();
333   UnwindAssemblyInstEmulation::Terminate();
334 
335   EmulateInstructionARM::Terminate();
336   EmulateInstructionARM64::Terminate();
337   EmulateInstructionMIPS::Terminate();
338   EmulateInstructionMIPS64::Terminate();
339   EmulateInstructionPPC64::Terminate();
340 
341   SymbolFileDWARFDebugMap::Terminate();
342   ItaniumABILanguageRuntime::Terminate();
343   AppleObjCRuntimeV2::Terminate();
344   AppleObjCRuntimeV1::Terminate();
345   SystemRuntimeMacOSX::Terminate();
346   RenderScriptRuntime::Terminate();
347 
348   CPlusPlusLanguage::Terminate();
349   ObjCLanguage::Terminate();
350   ObjCPlusPlusLanguage::Terminate();
351 
352 #if defined(__APPLE__)
353   DynamicLoaderDarwinKernel::Terminate();
354   ProcessKDP::Terminate();
355   SymbolVendorMacOSX::Terminate();
356   PlatformAppleTVSimulator::Terminate();
357   PlatformAppleWatchSimulator::Terminate();
358   PlatformRemoteAppleTV::Terminate();
359   PlatformRemoteAppleWatch::Terminate();
360   PlatformRemoteAppleBridge::Terminate();
361 #endif
362 
363 #if defined(__FreeBSD__)
364   ProcessFreeBSD::Terminate();
365 #endif
366   Debugger::SettingsTerminate();
367 
368   platform_gdb_server::PlatformRemoteGDBServer::Terminate();
369   process_gdb_remote::ProcessGDBRemote::Terminate();
370   StructuredDataDarwinLog::Terminate();
371 
372   DynamicLoaderMacOSXDYLD::Terminate();
373   DynamicLoaderMacOS::Terminate();
374   DynamicLoaderPOSIXDYLD::Terminate();
375   DynamicLoaderStatic::Terminate();
376   DynamicLoaderWindowsDYLD::Terminate();
377 
378 #ifndef LLDB_DISABLE_PYTHON
379   OperatingSystemPython::Terminate();
380 #endif
381 
382   platform_freebsd::PlatformFreeBSD::Terminate();
383   platform_linux::PlatformLinux::Terminate();
384   platform_netbsd::PlatformNetBSD::Terminate();
385   platform_openbsd::PlatformOpenBSD::Terminate();
386   PlatformWindows::Terminate();
387   platform_android::PlatformAndroid::Terminate();
388   PlatformMacOSX::Terminate();
389   PlatformRemoteiOS::Terminate();
390 #if defined(__APPLE__)
391   PlatformiOSSimulator::Terminate();
392   PlatformDarwinKernel::Terminate();
393 #endif
394 
395   breakpad::ObjectFileBreakpad::Terminate();
396   ObjectFileELF::Terminate();
397   ObjectFileMachO::Terminate();
398   ObjectFilePECOFF::Terminate();
399 
400   ObjectContainerBSDArchive::Terminate();
401   ObjectContainerUniversalMachO::Terminate();
402 
403   // Now shutdown the common parts, in reverse order.
404   SystemInitializerCommon::Terminate();
405 }
406