JDevlieghere updated this revision to Diff 244455.
JDevlieghere added a comment.
Squash commits into single diff
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D73067/new/
https://reviews.llvm.org/D73067
Files:
lldb/include/lldb/Core/PluginManager.h
lldb/source/API/SystemInitializerFull.cpp
lldb/source/Plugins/ABI/AArch64/ABIMacOSX_arm64.cpp
lldb/source/Plugins/ABI/ARC/ABISysV_arc.cpp
lldb/source/Plugins/ABI/ARM/ABIMacOSX_arm.cpp
lldb/source/Plugins/ABI/Hexagon/ABISysV_hexagon.cpp
lldb/source/Plugins/ABI/SystemZ/ABISysV_s390x.cpp
lldb/source/Plugins/CMakeLists.txt
lldb/source/Plugins/Disassembler/LLVMC/CMakeLists.txt
lldb/source/Plugins/DynamicLoader/Hexagon-DYLD/DynamicLoaderHexagonDYLD.cpp
lldb/source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp
lldb/source/Plugins/ExpressionParser/Clang/CMakeLists.txt
lldb/source/Plugins/Instruction/ARM/EmulateInstructionARM.cpp
lldb/source/Plugins/Instruction/ARM64/EmulateInstructionARM64.cpp
lldb/source/Plugins/Instruction/MIPS/EmulateInstructionMIPS.cpp
lldb/source/Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.cpp
lldb/source/Plugins/Instruction/PPC64/EmulateInstructionPPC64.cpp
lldb/source/Plugins/Language/ClangCommon/CMakeLists.txt
lldb/source/Plugins/Language/ObjC/CMakeLists.txt
lldb/source/Plugins/LanguageRuntime/CPlusPlus/CMakeLists.txt
lldb/source/Plugins/LanguageRuntime/CPlusPlus/ItaniumABI/ItaniumABILanguageRuntime.cpp
lldb/source/Plugins/LanguageRuntime/ObjC/CMakeLists.txt
lldb/source/Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.cpp
lldb/source/Plugins/ObjectFile/JIT/ObjectFileJIT.cpp
lldb/source/Plugins/Platform/POSIX/CMakeLists.txt
lldb/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp
lldb/source/Plugins/Plugins.def.in
lldb/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp
lldb/source/Plugins/Process/Utility/CMakeLists.txt
lldb/source/Plugins/SymbolFile/NativePDB/SymbolFileNativePDB.cpp
lldb/source/Plugins/UnwindAssembly/x86/UnwindAssembly-x86.cpp
lldb/tools/lldb-test/CMakeLists.txt
lldb/tools/lldb-test/SystemInitializerTest.cpp
lldb/unittests/Disassembler/CMakeLists.txt
lldb/unittests/UnwindAssembly/ARM64/CMakeLists.txt
lldb/unittests/UnwindAssembly/PPC64/CMakeLists.txt
Index: lldb/unittests/UnwindAssembly/PPC64/CMakeLists.txt
===================================================================
--- lldb/unittests/UnwindAssembly/PPC64/CMakeLists.txt
+++ lldb/unittests/UnwindAssembly/PPC64/CMakeLists.txt
@@ -5,7 +5,7 @@
lldbSymbol
lldbTarget
lldbPluginUnwindAssemblyInstEmulation
- lldbPluginDisassemblerLLVM
+ lldbPluginDisassemblerLLVMC
lldbPluginInstructionPPC64
lldbPluginProcessUtility
LINK_COMPONENTS
Index: lldb/unittests/UnwindAssembly/ARM64/CMakeLists.txt
===================================================================
--- lldb/unittests/UnwindAssembly/ARM64/CMakeLists.txt
+++ lldb/unittests/UnwindAssembly/ARM64/CMakeLists.txt
@@ -5,7 +5,7 @@
lldbSymbol
lldbTarget
lldbPluginUnwindAssemblyInstEmulation
- lldbPluginDisassemblerLLVM
+ lldbPluginDisassemblerLLVMC
lldbPluginInstructionARM64
lldbPluginProcessUtility
LINK_COMPONENTS
Index: lldb/unittests/Disassembler/CMakeLists.txt
===================================================================
--- lldb/unittests/Disassembler/CMakeLists.txt
+++ lldb/unittests/Disassembler/CMakeLists.txt
@@ -6,7 +6,7 @@
lldbCore
lldbSymbol
lldbTarget
- lldbPluginDisassemblerLLVM
+ lldbPluginDisassemblerLLVMC
lldbPluginProcessUtility
LINK_COMPONENTS
Support
Index: lldb/tools/lldb-test/SystemInitializerTest.cpp
===================================================================
--- lldb/tools/lldb-test/SystemInitializerTest.cpp
+++ lldb/tools/lldb-test/SystemInitializerTest.cpp
@@ -17,88 +17,9 @@
#include <string>
-LLDB_PLUGIN_DECLARE(ABIMacOSX_arm64)
-LLDB_PLUGIN_DECLARE(ABISysV_arm64)
-LLDB_PLUGIN_DECLARE(ABIMacOSX_arm)
-LLDB_PLUGIN_DECLARE(ABISysV_arm)
-LLDB_PLUGIN_DECLARE(ABISysV_arc)
-LLDB_PLUGIN_DECLARE(ABISysV_hexagon)
-LLDB_PLUGIN_DECLARE(ABISysV_mips)
-LLDB_PLUGIN_DECLARE(ABISysV_mips64)
-LLDB_PLUGIN_DECLARE(ABISysV_ppc)
-LLDB_PLUGIN_DECLARE(ABISysV_ppc64)
-LLDB_PLUGIN_DECLARE(ABISysV_s390x)
-LLDB_PLUGIN_DECLARE(ABIMacOSX_i386)
-LLDB_PLUGIN_DECLARE(ABISysV_i386)
-LLDB_PLUGIN_DECLARE(ABISysV_x86_64)
-LLDB_PLUGIN_DECLARE(ABIWindows_x86_64)
-LLDB_PLUGIN_DECLARE(ObjectFileBreakpad)
-LLDB_PLUGIN_DECLARE(ObjectFileELF)
-LLDB_PLUGIN_DECLARE(ObjectFileMachO)
-LLDB_PLUGIN_DECLARE(ObjectFilePECOFF)
-LLDB_PLUGIN_DECLARE(ObjectFileWasm)
-LLDB_PLUGIN_DECLARE(ObjectContainerBSDArchive)
-LLDB_PLUGIN_DECLARE(ObjectContainerUniversalMachO)
-LLDB_PLUGIN_DECLARE(ScriptInterpreterNone)
-LLDB_PLUGIN_DECLARE(PlatformFreeBSD)
-LLDB_PLUGIN_DECLARE(PlatformLinux)
-LLDB_PLUGIN_DECLARE(PlatformNetBSD)
-LLDB_PLUGIN_DECLARE(PlatformOpenBSD)
-LLDB_PLUGIN_DECLARE(PlatformWindows)
-LLDB_PLUGIN_DECLARE(PlatformAndroid)
-LLDB_PLUGIN_DECLARE(PlatformMacOSX)
-LLDB_PLUGIN_DECLARE(TypeSystemClang)
-LLDB_PLUGIN_DECLARE(ArchitectureArm)
-LLDB_PLUGIN_DECLARE(ArchitectureMips)
-LLDB_PLUGIN_DECLARE(ArchitecturePPC64)
-LLDB_PLUGIN_DECLARE(DisassemblerLLVMC)
-LLDB_PLUGIN_DECLARE(JITLoaderGDB)
-LLDB_PLUGIN_DECLARE(ProcessElfCore)
-LLDB_PLUGIN_DECLARE(ProcessMachCore)
-LLDB_PLUGIN_DECLARE(ProcessMinidump)
-LLDB_PLUGIN_DECLARE(MemoryHistoryASan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeASan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeTSan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeUBSan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeMainThreadChecker)
-LLDB_PLUGIN_DECLARE(SymbolVendorELF)
-LLDB_PLUGIN_DECLARE(SymbolFileBreakpad)
-LLDB_PLUGIN_DECLARE(SymbolFileDWARF)
-LLDB_PLUGIN_DECLARE(SymbolFilePDB)
-LLDB_PLUGIN_DECLARE(SymbolFileSymtab)
-LLDB_PLUGIN_DECLARE(SymbolVendorWasm)
-LLDB_PLUGIN_DECLARE(UnwindAssemblyInstEmulation)
-LLDB_PLUGIN_DECLARE(UnwindAssembly_x86)
-LLDB_PLUGIN_DECLARE(EmulateInstructionARM)
-LLDB_PLUGIN_DECLARE(EmulateInstructionARM64)
-LLDB_PLUGIN_DECLARE(EmulateInstructionMIPS)
-LLDB_PLUGIN_DECLARE(EmulateInstructionMIPS64)
-LLDB_PLUGIN_DECLARE(EmulateInstructionPPC64)
-LLDB_PLUGIN_DECLARE(ItaniumABILanguageRuntime)
-LLDB_PLUGIN_DECLARE(AppleObjCRuntime)
-LLDB_PLUGIN_DECLARE(SystemRuntimeMacOSX)
-LLDB_PLUGIN_DECLARE(RenderScriptRuntime)
-LLDB_PLUGIN_DECLARE(CPlusPlusLanguage)
-LLDB_PLUGIN_DECLARE(ObjCLanguage)
-LLDB_PLUGIN_DECLARE(ObjCPlusPlusLanguage)
-#if defined(_WIN32)
-LLDB_PLUGIN_DECLARE(ProcessWindows)
-#endif
-#if defined(__FreeBSD__)
-LLDB_PLUGIN_DECLARE(ProcessFreeBSD)
-#endif
-#if defined(__APPLE__)
-LLDB_PLUGIN_DECLARE(SymbolVendorMacOSX)
-LLDB_PLUGIN_DECLARE(ProcessKDP)
-LLDB_PLUGIN_DECLARE(DynamicLoaderDarwinKernel)
-#endif
-LLDB_PLUGIN_DECLARE(StructuredDataDarwinLog)
-LLDB_PLUGIN_DECLARE(PlatformRemoteGDBServer)
-LLDB_PLUGIN_DECLARE(ProcessGDBRemote)
-LLDB_PLUGIN_DECLARE(DynamicLoaderMacOSXDYLD)
-LLDB_PLUGIN_DECLARE(DynamicLoaderPOSIXDYLD)
-LLDB_PLUGIN_DECLARE(DynamicLoaderStatic)
-LLDB_PLUGIN_DECLARE(DynamicLoaderWindowsDYLD)
+#undef LLDB_PLUGIN
+#define LLDB_PLUGIN(p) LLDB_PLUGIN_DECLARE(p)
+#include "Plugins.def"
using namespace lldb_private;
@@ -106,137 +27,18 @@
SystemInitializerTest::~SystemInitializerTest() {}
-#define LLDB_PROCESS_AArch64(op) \
- op(ABIMacOSX_arm64); \
- op(ABISysV_arm64);
-#define LLDB_PROCESS_ARM(op) \
- op(ABIMacOSX_arm); \
- op(ABISysV_arm);
-#define LLDB_PROCESS_Hexagon(op) op(ABISysV_hexagon);
-#define LLDB_PROCESS_Mips(op) \
- op(ABISysV_mips); \
- op(ABISysV_mips64);
-#define LLDB_PROCESS_PowerPC(op) \
- op(ABISysV_ppc); \
- op(ABISysV_ppc64);
-#define LLDB_PROCESS_SystemZ(op) op(ABISysV_s390x);
-#define LLDB_PROCESS_X86(op) \
- op(ABIMacOSX_i386); \
- op(ABISysV_i386); \
- op(ABISysV_x86_64); \
- op(ABIWindows_x86_64);
-
-#define LLDB_PROCESS_AMDGPU(op)
-#define LLDB_PROCESS_ARC(op)
-#define LLDB_PROCESS_AVR(op)
-#define LLDB_PROCESS_BPF(op)
-#define LLDB_PROCESS_Lanai(op)
-#define LLDB_PROCESS_MSP430(op)
-#define LLDB_PROCESS_NVPTX(op)
-#define LLDB_PROCESS_RISCV(op)
-#define LLDB_PROCESS_Sparc(op)
-#define LLDB_PROCESS_WebAssembly(op)
-#define LLDB_PROCESS_XCore(op)
-
llvm::Error SystemInitializerTest::Initialize() {
if (auto e = SystemInitializerCommon::Initialize())
return e;
- LLDB_PLUGIN_INITIALIZE(ObjectFileBreakpad);
- LLDB_PLUGIN_INITIALIZE(ObjectFileELF);
- LLDB_PLUGIN_INITIALIZE(ObjectFileMachO);
- LLDB_PLUGIN_INITIALIZE(ObjectFilePECOFF);
- LLDB_PLUGIN_INITIALIZE(ObjectFileWasm);
-
- LLDB_PLUGIN_INITIALIZE(ObjectContainerBSDArchive);
- LLDB_PLUGIN_INITIALIZE(ObjectContainerUniversalMachO);
+#define LLDB_SCRIPT_PLUGIN(p)
+#define LLDB_PLUGIN(p) LLDB_PLUGIN_INITIALIZE(p);
+#include "Plugins.def"
+ // We undef'd LLDB_SCRIPT_PLUGIN so we need to initialize
+ // ScriptInterpreterNone manually.
LLDB_PLUGIN_INITIALIZE(ScriptInterpreterNone);
- LLDB_PLUGIN_INITIALIZE(PlatformFreeBSD);
- LLDB_PLUGIN_INITIALIZE(PlatformLinux);
- LLDB_PLUGIN_INITIALIZE(PlatformNetBSD);
- LLDB_PLUGIN_INITIALIZE(PlatformOpenBSD);
- LLDB_PLUGIN_INITIALIZE(PlatformWindows);
- LLDB_PLUGIN_INITIALIZE(PlatformAndroid);
- LLDB_PLUGIN_INITIALIZE(PlatformMacOSX);
-
- // Initialize LLVM and Clang
- llvm::InitializeAllTargets();
- llvm::InitializeAllAsmPrinters();
- llvm::InitializeAllTargetMCs();
- llvm::InitializeAllDisassemblers();
-
- LLDB_PLUGIN_INITIALIZE(TypeSystemClang);
-
-#define LLVM_TARGET(t) LLDB_PROCESS_##t(LLDB_PLUGIN_INITIALIZE)
-#include "llvm/Config/Targets.def"
-
- LLDB_PLUGIN_INITIALIZE(ArchitectureArm);
- LLDB_PLUGIN_INITIALIZE(ArchitectureMips);
- LLDB_PLUGIN_INITIALIZE(ArchitecturePPC64);
-
- LLDB_PLUGIN_INITIALIZE(DisassemblerLLVMC);
-
- LLDB_PLUGIN_INITIALIZE(JITLoaderGDB);
- LLDB_PLUGIN_INITIALIZE(ProcessElfCore);
- LLDB_PLUGIN_INITIALIZE(ProcessMachCore);
- LLDB_PLUGIN_INITIALIZE(ProcessMinidump);
- LLDB_PLUGIN_INITIALIZE(MemoryHistoryASan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeASan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeTSan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeUBSan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeMainThreadChecker);
-
- LLDB_PLUGIN_INITIALIZE(SymbolVendorELF);
- LLDB_PLUGIN_INITIALIZE(SymbolFileBreakpad);
- LLDB_PLUGIN_INITIALIZE(SymbolFileDWARF);
- LLDB_PLUGIN_INITIALIZE(SymbolFilePDB);
- LLDB_PLUGIN_INITIALIZE(SymbolFileSymtab);
- LLDB_PLUGIN_INITIALIZE(SymbolVendorWasm);
- LLDB_PLUGIN_INITIALIZE(UnwindAssemblyInstEmulation);
- LLDB_PLUGIN_INITIALIZE(UnwindAssembly_x86);
-
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionARM);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionARM64);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionMIPS);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionMIPS64);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionPPC64);
-
- LLDB_PLUGIN_INITIALIZE(ItaniumABILanguageRuntime);
- LLDB_PLUGIN_INITIALIZE(AppleObjCRuntime);
- LLDB_PLUGIN_INITIALIZE(SystemRuntimeMacOSX);
- LLDB_PLUGIN_INITIALIZE(RenderScriptRuntime);
-
- LLDB_PLUGIN_INITIALIZE(CPlusPlusLanguage);
- LLDB_PLUGIN_INITIALIZE(ObjCLanguage);
- LLDB_PLUGIN_INITIALIZE(ObjCPlusPlusLanguage);
-
-#if defined(_WIN32)
- LLDB_PLUGIN_INITIALIZE(ProcessWindows);
-#endif
-#if defined(__FreeBSD__)
- LLDB_PLUGIN_INITIALIZE(ProcessFreeBSD);
-#endif
-#if defined(__APPLE__)
- LLDB_PLUGIN_INITIALIZE(SymbolVendorMacOSX);
- LLDB_PLUGIN_INITIALIZE(ProcessKDP);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderDarwinKernel);
-#endif
-
- // This plugin is valid on any host that talks to a Darwin remote. It
- // shouldn't be limited to __APPLE__.
- LLDB_PLUGIN_INITIALIZE(StructuredDataDarwinLog);
-
- // Platform agnostic plugins
- LLDB_PLUGIN_INITIALIZE(PlatformRemoteGDBServer);
-
- LLDB_PLUGIN_INITIALIZE(ProcessGDBRemote);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderMacOSXDYLD);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderPOSIXDYLD);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderStatic);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderWindowsDYLD);
-
// Scan for any system or user LLDB plug-ins
PluginManager::Initialize();
@@ -258,89 +60,12 @@
// Terminate and unload and loaded system or user LLDB plug-ins
PluginManager::Terminate();
- LLDB_PLUGIN_TERMINATE(TypeSystemClang);
-
- LLDB_PLUGIN_TERMINATE(ArchitectureArm);
- LLDB_PLUGIN_TERMINATE(ArchitectureMips);
- LLDB_PLUGIN_TERMINATE(ArchitecturePPC64);
-
-#define LLVM_TARGET(t) LLDB_PROCESS_##t(LLDB_PLUGIN_TERMINATE)
-#include "llvm/Config/Targets.def"
-
- LLDB_PLUGIN_TERMINATE(DisassemblerLLVMC);
-
- LLDB_PLUGIN_TERMINATE(JITLoaderGDB);
- LLDB_PLUGIN_TERMINATE(ProcessElfCore);
- LLDB_PLUGIN_TERMINATE(ProcessMachCore);
- LLDB_PLUGIN_TERMINATE(ProcessMinidump);
- LLDB_PLUGIN_TERMINATE(MemoryHistoryASan);
-
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeASan);
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeTSan);
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeUBSan);
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeMainThreadChecker);
-
- LLDB_PLUGIN_TERMINATE(SymbolVendorWasm);
- LLDB_PLUGIN_TERMINATE(SymbolVendorELF);
- LLDB_PLUGIN_TERMINATE(SymbolFileBreakpad);
- LLDB_PLUGIN_TERMINATE(SymbolFileDWARF);
- LLDB_PLUGIN_TERMINATE(SymbolFilePDB);
- LLDB_PLUGIN_TERMINATE(SymbolFileSymtab);
- LLDB_PLUGIN_TERMINATE(UnwindAssembly_x86);
- LLDB_PLUGIN_TERMINATE(UnwindAssemblyInstEmulation);
-
- LLDB_PLUGIN_TERMINATE(EmulateInstructionARM);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionARM64);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionMIPS);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionMIPS64);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionPPC64);
-
- LLDB_PLUGIN_TERMINATE(ItaniumABILanguageRuntime);
- LLDB_PLUGIN_TERMINATE(AppleObjCRuntime);
- LLDB_PLUGIN_TERMINATE(SystemRuntimeMacOSX);
- LLDB_PLUGIN_TERMINATE(RenderScriptRuntime);
-
- LLDB_PLUGIN_TERMINATE(CPlusPlusLanguage);
- LLDB_PLUGIN_TERMINATE(ObjCLanguage);
- LLDB_PLUGIN_TERMINATE(ObjCPlusPlusLanguage);
-
-#if defined(__APPLE__)
- LLDB_PLUGIN_TERMINATE(DynamicLoaderDarwinKernel);
- LLDB_PLUGIN_TERMINATE(ProcessKDP);
- LLDB_PLUGIN_TERMINATE(SymbolVendorMacOSX);
-#endif
-
-#if defined(__FreeBSD__)
- LLDB_PLUGIN_TERMINATE(ProcessFreeBSD);
-#endif
- Debugger::SettingsTerminate();
-
- LLDB_PLUGIN_TERMINATE(PlatformRemoteGDBServer);
- LLDB_PLUGIN_TERMINATE(ProcessGDBRemote);
- LLDB_PLUGIN_TERMINATE(StructuredDataDarwinLog);
-
- LLDB_PLUGIN_TERMINATE(DynamicLoaderMacOSXDYLD);
- LLDB_PLUGIN_TERMINATE(DynamicLoaderPOSIXDYLD);
- LLDB_PLUGIN_TERMINATE(DynamicLoaderStatic);
- LLDB_PLUGIN_TERMINATE(DynamicLoaderWindowsDYLD);
-
- LLDB_PLUGIN_TERMINATE(PlatformFreeBSD);
- LLDB_PLUGIN_TERMINATE(PlatformLinux);
- LLDB_PLUGIN_TERMINATE(PlatformNetBSD);
- LLDB_PLUGIN_TERMINATE(PlatformOpenBSD);
- LLDB_PLUGIN_TERMINATE(PlatformWindows);
- LLDB_PLUGIN_TERMINATE(PlatformAndroid);
- LLDB_PLUGIN_TERMINATE(PlatformMacOSX);
-
- LLDB_PLUGIN_TERMINATE(ObjectFileBreakpad);
- LLDB_PLUGIN_TERMINATE(ObjectFileELF);
- LLDB_PLUGIN_TERMINATE(ObjectFileMachO);
- LLDB_PLUGIN_TERMINATE(ObjectFilePECOFF);
- LLDB_PLUGIN_TERMINATE(ObjectFileWasm);
-
- LLDB_PLUGIN_TERMINATE(ObjectContainerBSDArchive);
- LLDB_PLUGIN_TERMINATE(ObjectContainerUniversalMachO);
+#define LLDB_SCRIPT_PLUGIN(p)
+#define LLDB_PLUGIN(p) LLDB_PLUGIN_TERMINATE(p);
+#include "Plugins.def"
+ // We undef'd LLDB_SCRIPT_PLUGIN so we need to terminate
+ // ScriptInterpreterNone manually.
LLDB_PLUGIN_TERMINATE(ScriptInterpreterNone);
// Now shutdown the common parts, in reverse order.
Index: lldb/tools/lldb-test/CMakeLists.txt
===================================================================
--- lldb/tools/lldb-test/CMakeLists.txt
+++ lldb/tools/lldb-test/CMakeLists.txt
@@ -1,4 +1,5 @@
get_property(LLDB_ALL_PLUGINS GLOBAL PROPERTY LLDB_PLUGINS)
+get_property(LLDB_PLUGINS_INCLUDES GLOBAL PROPERTY LLDB_PLUGINS_INCLUDE_DIR)
add_lldb_tool(lldb-test
FormatUtil.cpp
@@ -23,5 +24,6 @@
LINK_COMPONENTS
Support
)
-
-include_directories(${LLDB_SOURCE_DIR}/source)
+
+target_include_directories(lldb-test PRIVATE ${LLDB_PLUGINS_INCLUDES})
+target_include_directories(lldb-test PRIVATE ${LLDB_SOURCE_DIR}/source)
Index: lldb/source/Plugins/UnwindAssembly/x86/UnwindAssembly-x86.cpp
===================================================================
--- lldb/source/Plugins/UnwindAssembly/x86/UnwindAssembly-x86.cpp
+++ lldb/source/Plugins/UnwindAssembly/x86/UnwindAssembly-x86.cpp
@@ -30,7 +30,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(UnwindAssembly_x86)
+LLDB_PLUGIN_ADV(UnwindAssembly_x86, UnwindAssemblyX86)
// UnwindAssemblyParser_x86 method definitions
Index: lldb/source/Plugins/SymbolFile/NativePDB/SymbolFileNativePDB.cpp
===================================================================
--- lldb/source/Plugins/SymbolFile/NativePDB/SymbolFileNativePDB.cpp
+++ lldb/source/Plugins/SymbolFile/NativePDB/SymbolFileNativePDB.cpp
@@ -66,6 +66,8 @@
using namespace llvm::codeview;
using namespace llvm::pdb;
+LLDB_PLUGIN(SymbolFileNativePDB)
+
char SymbolFileNativePDB::ID;
static lldb::LanguageType TranslateLanguage(PDB_Lang lang) {
Index: lldb/source/Plugins/Process/Utility/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/Process/Utility/CMakeLists.txt
+++ lldb/source/Plugins/Process/Utility/CMakeLists.txt
@@ -1,4 +1,4 @@
-add_lldb_library(lldbPluginProcessUtility PLUGIN
+add_lldb_library(lldbPluginProcessUtility
AuxVector.cpp
DynamicRegisterInfo.cpp
FreeBSDSignals.cpp
Index: lldb/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp
===================================================================
--- lldb/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp
+++ lldb/source/Plugins/Process/MacOSX-Kernel/ProcessKDP.cpp
@@ -50,7 +50,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(ProcessKDP)
+LLDB_PLUGIN_ADV(ProcessKDP, ProcessMacOSXKernel)
namespace {
Index: lldb/source/Plugins/Plugins.def.in
===================================================================
--- /dev/null
+++ lldb/source/Plugins/Plugins.def.in
@@ -0,0 +1,32 @@
+/*===- lldb/source/Plugin/Plugins.def ---------------------------*- C++ -*-===*\
+|* *|
+|* Part of the LLVM Project, under the Apache License v2.0 with LLVM *|
+|* Exceptions. *|
+|* See https://llvm.org/LICENSE.txt for license information. *|
+|* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception *|
+|* *|
+|*===----------------------------------------------------------------------===*|
+|* *|
+|* This file enumerates all of the plugins supported by this build of LLDB. *|
+|* Clients of this file should define the LLDB_PLUGIN macro to be a *|
+|* function-like macro with a single parameter (the name of the plugin) *|
+|* including this file will then enumerate all of the targets. *|
+|* *|
+|* The set of plugins supported by LLDB is generated at configuration *|
+|* time, at which point this header is generated. Do not modify this *|
+|* header directly. *|
+|* *|
+\*===----------------------------------------------------------------------===*/
+
+#ifndef LLDB_PLUGIN
+# error Please define the macro LLDB_PLUGIN(PluginName)
+#endif
+
+#ifndef LLDB_SCRIPT_PLUGIN
+#define LLDB_SCRIPT_PLUGIN(p) LLDB_PLUGIN(p)
+#endif
+
+@LLDB_ENUM_PLUGINS@
+
+#undef LLDB_PLUGIN
+#undef LLDB_SCRIPT_PLUGIN
Index: lldb/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp
===================================================================
--- lldb/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp
+++ lldb/source/Plugins/Platform/gdb-server/PlatformRemoteGDBServer.cpp
@@ -35,7 +35,7 @@
using namespace lldb_private;
using namespace lldb_private::platform_gdb_server;
-LLDB_PLUGIN(PlatformRemoteGDBServer)
+LLDB_PLUGIN_ADV(PlatformRemoteGDBServer, PlatformGDB)
static bool g_initialized = false;
Index: lldb/source/Plugins/Platform/POSIX/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/Platform/POSIX/CMakeLists.txt
+++ lldb/source/Plugins/Platform/POSIX/CMakeLists.txt
@@ -1,4 +1,4 @@
-add_lldb_library(lldbPluginPlatformPOSIX PLUGIN
+add_lldb_library(lldbPluginPlatformPOSIX
PlatformPOSIX.cpp
LINK_LIBS
Index: lldb/source/Plugins/ObjectFile/JIT/ObjectFileJIT.cpp
===================================================================
--- lldb/source/Plugins/ObjectFile/JIT/ObjectFileJIT.cpp
+++ lldb/source/Plugins/ObjectFile/JIT/ObjectFileJIT.cpp
@@ -39,6 +39,8 @@
using namespace lldb;
using namespace lldb_private;
+LLDB_PLUGIN(ObjectFileJIT)
+
char ObjectFileJIT::ID;
void ObjectFileJIT::Initialize() {
Index: lldb/source/Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.cpp
===================================================================
--- lldb/source/Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.cpp
+++ lldb/source/Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.cpp
@@ -20,7 +20,7 @@
using namespace lldb_private;
using namespace llvm::MachO;
-LLDB_PLUGIN(ObjectContainerUniversalMachO)
+LLDB_PLUGIN_ADV(ObjectContainerUniversalMachO, ObjectContainerMachOArchive)
void ObjectContainerUniversalMachO::Initialize() {
PluginManager::RegisterPlugin(GetPluginNameStatic(),
Index: lldb/source/Plugins/LanguageRuntime/ObjC/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/LanguageRuntime/ObjC/CMakeLists.txt
+++ lldb/source/Plugins/LanguageRuntime/ObjC/CMakeLists.txt
@@ -1,4 +1,4 @@
-add_lldb_library(lldbPluginObjCRuntime PLUGIN
+add_lldb_library(lldbPluginObjCRuntime
ObjCLanguageRuntime.cpp
LINK_LIBS
Index: lldb/source/Plugins/LanguageRuntime/CPlusPlus/ItaniumABI/ItaniumABILanguageRuntime.cpp
===================================================================
--- lldb/source/Plugins/LanguageRuntime/CPlusPlus/ItaniumABI/ItaniumABILanguageRuntime.cpp
+++ lldb/source/Plugins/LanguageRuntime/CPlusPlus/ItaniumABI/ItaniumABILanguageRuntime.cpp
@@ -40,7 +40,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(ItaniumABILanguageRuntime)
+LLDB_PLUGIN_ADV(ItaniumABILanguageRuntime, CXXItaniumABI)
static const char *vtable_demangled_prefix = "vtable for ";
Index: lldb/source/Plugins/LanguageRuntime/CPlusPlus/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/LanguageRuntime/CPlusPlus/CMakeLists.txt
+++ lldb/source/Plugins/LanguageRuntime/CPlusPlus/CMakeLists.txt
@@ -1,4 +1,4 @@
-add_lldb_library(lldbPluginCPPRuntime PLUGIN
+add_lldb_library(lldbPluginCPPRuntime
CPPLanguageRuntime.cpp
LINK_LIBS
Index: lldb/source/Plugins/Language/ObjC/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/Language/ObjC/CMakeLists.txt
+++ lldb/source/Plugins/Language/ObjC/CMakeLists.txt
@@ -8,7 +8,7 @@
set(EXTRA_CXXFLAGS ${EXTRA_CXXFLAGS} -Wno-nested-anon-types)
endif ()
-add_lldb_library(lldbPluginObjCLanguage PLUGIN
+add_lldb_library(lldbPluginObjCLanguage
ObjCLanguage.cpp
CF.cpp
Cocoa.cpp
Index: lldb/source/Plugins/Language/ClangCommon/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/Language/ClangCommon/CMakeLists.txt
+++ lldb/source/Plugins/Language/ClangCommon/CMakeLists.txt
@@ -1,4 +1,4 @@
-add_lldb_library(lldbPluginClangCommon PLUGIN
+add_lldb_library(lldbPluginClangCommon
ClangHighlighter.cpp
LINK_LIBS
Index: lldb/source/Plugins/Instruction/PPC64/EmulateInstructionPPC64.cpp
===================================================================
--- lldb/source/Plugins/Instruction/PPC64/EmulateInstructionPPC64.cpp
+++ lldb/source/Plugins/Instruction/PPC64/EmulateInstructionPPC64.cpp
@@ -25,7 +25,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(EmulateInstructionPPC64)
+LLDB_PLUGIN_ADV(EmulateInstructionPPC64, InstructionPPC64)
EmulateInstructionPPC64::EmulateInstructionPPC64(const ArchSpec &arch)
: EmulateInstruction(arch) {}
Index: lldb/source/Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.cpp
===================================================================
--- lldb/source/Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.cpp
+++ lldb/source/Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.cpp
@@ -40,7 +40,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(EmulateInstructionMIPS64)
+LLDB_PLUGIN_ADV(EmulateInstructionMIPS64, InstructionMIPS64)
#define UInt(x) ((uint64_t)x)
#define integer int64_t
Index: lldb/source/Plugins/Instruction/MIPS/EmulateInstructionMIPS.cpp
===================================================================
--- lldb/source/Plugins/Instruction/MIPS/EmulateInstructionMIPS.cpp
+++ lldb/source/Plugins/Instruction/MIPS/EmulateInstructionMIPS.cpp
@@ -40,7 +40,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(EmulateInstructionMIPS)
+LLDB_PLUGIN_ADV(EmulateInstructionMIPS, InstructionMIPS)
#define UInt(x) ((uint64_t)x)
#define integer int64_t
Index: lldb/source/Plugins/Instruction/ARM64/EmulateInstructionARM64.cpp
===================================================================
--- lldb/source/Plugins/Instruction/ARM64/EmulateInstructionARM64.cpp
+++ lldb/source/Plugins/Instruction/ARM64/EmulateInstructionARM64.cpp
@@ -47,7 +47,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(EmulateInstructionARM64)
+LLDB_PLUGIN_ADV(EmulateInstructionARM64, InstructionARM64)
static bool LLDBTableGetRegisterInfo(uint32_t reg_num, RegisterInfo ®_info) {
if (reg_num >= llvm::array_lengthof(g_register_infos_arm64_le))
Index: lldb/source/Plugins/Instruction/ARM/EmulateInstructionARM.cpp
===================================================================
--- lldb/source/Plugins/Instruction/ARM/EmulateInstructionARM.cpp
+++ lldb/source/Plugins/Instruction/ARM/EmulateInstructionARM.cpp
@@ -30,7 +30,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(EmulateInstructionARM)
+LLDB_PLUGIN_ADV(EmulateInstructionARM, InstructionARM)
// Convenient macro definitions.
#define APSR_C Bit32(m_opcode_cpsr, CPSR_C_POS)
Index: lldb/source/Plugins/ExpressionParser/Clang/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/ExpressionParser/Clang/CMakeLists.txt
+++ lldb/source/Plugins/ExpressionParser/Clang/CMakeLists.txt
@@ -2,7 +2,7 @@
set(tablegen_deps intrinsics_gen)
endif()
-add_lldb_library(lldbPluginExpressionParserClang PLUGIN
+add_lldb_library(lldbPluginExpressionParserClang
ASTResultSynthesizer.cpp
ASTStructExtractor.cpp
ASTUtils.cpp
Index: lldb/source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp
===================================================================
--- lldb/source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp
+++ lldb/source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp
@@ -29,7 +29,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(DynamicLoaderPOSIXDYLD)
+LLDB_PLUGIN_ADV(DynamicLoaderPOSIXDYLD, DynamicLoaderPosixDYLD)
void DynamicLoaderPOSIXDYLD::Initialize() {
PluginManager::RegisterPlugin(GetPluginNameStatic(),
Index: lldb/source/Plugins/DynamicLoader/Hexagon-DYLD/DynamicLoaderHexagonDYLD.cpp
===================================================================
--- lldb/source/Plugins/DynamicLoader/Hexagon-DYLD/DynamicLoaderHexagonDYLD.cpp
+++ lldb/source/Plugins/DynamicLoader/Hexagon-DYLD/DynamicLoaderHexagonDYLD.cpp
@@ -25,6 +25,8 @@
using namespace lldb;
using namespace lldb_private;
+LLDB_PLUGIN(DynamicLoaderHexagonDYLD)
+
// Aidan 21/05/2014
//
// Notes about hexagon dynamic loading:
Index: lldb/source/Plugins/Disassembler/LLVMC/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/Disassembler/LLVMC/CMakeLists.txt
+++ lldb/source/Plugins/Disassembler/LLVMC/CMakeLists.txt
@@ -1,4 +1,4 @@
-add_lldb_library(lldbPluginDisassemblerLLVM PLUGIN
+add_lldb_library(lldbPluginDisassemblerLLVMC PLUGIN
DisassemblerLLVMC.cpp
LINK_LIBS
Index: lldb/source/Plugins/CMakeLists.txt
===================================================================
--- lldb/source/Plugins/CMakeLists.txt
+++ lldb/source/Plugins/CMakeLists.txt
@@ -21,3 +21,25 @@
add_subdirectory(SymbolVendor)
add_subdirectory(TypeSystem)
add_subdirectory(UnwindAssembly)
+
+set(LLDB_STRIPPED_PLUGINS)
+get_property(LLDB_ALL_PLUGINS GLOBAL PROPERTY LLDB_PLUGINS)
+
+set(LLDB_ENUM_PLUGINS "")
+
+foreach(p ${LLDB_ALL_PLUGINS})
+ # Strip lldbPlugin form the plugin name.
+ string(SUBSTRING ${p} 10 -1 pStripped)
+ if(${pStripped} MATCHES "^ScriptInterpreter*")
+ set(LLDB_ENUM_PLUGINS "${LLDB_ENUM_PLUGINS}LLDB_SCRIPT_PLUGIN(${pStripped})\n")
+ else()
+ set(LLDB_ENUM_PLUGINS "${LLDB_ENUM_PLUGINS}LLDB_PLUGIN(${pStripped})\n")
+ endif()
+endforeach(p)
+
+configure_file(
+ ${CMAKE_CURRENT_SOURCE_DIR}/Plugins.def.in
+ ${CMAKE_CURRENT_BINARY_DIR}/Plugins.def
+ )
+
+set_property(GLOBAL PROPERTY LLDB_PLUGINS_INCLUDE_DIR ${CMAKE_CURRENT_BINARY_DIR})
Index: lldb/source/Plugins/ABI/SystemZ/ABISysV_s390x.cpp
===================================================================
--- lldb/source/Plugins/ABI/SystemZ/ABISysV_s390x.cpp
+++ lldb/source/Plugins/ABI/SystemZ/ABISysV_s390x.cpp
@@ -32,7 +32,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(ABISysV_s390x)
+LLDB_PLUGIN_ADV(ABISysV_s390x, ABISystemZ)
enum dwarf_regnums {
// General Purpose Registers
Index: lldb/source/Plugins/ABI/Hexagon/ABISysV_hexagon.cpp
===================================================================
--- lldb/source/Plugins/ABI/Hexagon/ABISysV_hexagon.cpp
+++ lldb/source/Plugins/ABI/Hexagon/ABISysV_hexagon.cpp
@@ -32,7 +32,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(ABISysV_hexagon)
+LLDB_PLUGIN_ADV(ABISysV_hexagon, ABIHexagon)
static RegisterInfo g_register_infos[] = {
// hexagon-core.xml
Index: lldb/source/Plugins/ABI/ARM/ABIMacOSX_arm.cpp
===================================================================
--- lldb/source/Plugins/ABI/ARM/ABIMacOSX_arm.cpp
+++ lldb/source/Plugins/ABI/ARM/ABIMacOSX_arm.cpp
@@ -34,8 +34,6 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(ABIMacOSX_arm)
-
static RegisterInfo g_register_infos[] = {
// NAME ALT SZ OFF ENCODING FORMAT EH_FRAME
// DWARF GENERIC PROCESS PLUGIN
Index: lldb/source/Plugins/ABI/ARC/ABISysV_arc.cpp
===================================================================
--- lldb/source/Plugins/ABI/ARC/ABISysV_arc.cpp
+++ lldb/source/Plugins/ABI/ARC/ABISysV_arc.cpp
@@ -55,7 +55,7 @@
using namespace lldb;
using namespace lldb_private;
-LLDB_PLUGIN(ABISysV_arc)
+LLDB_PLUGIN(ABISysV_arc, ABIARC)
namespace {
namespace dwarf {
Index: lldb/source/Plugins/ABI/AArch64/ABIMacOSX_arm64.cpp
===================================================================
--- lldb/source/Plugins/ABI/AArch64/ABIMacOSX_arm64.cpp
+++ lldb/source/Plugins/ABI/AArch64/ABIMacOSX_arm64.cpp
@@ -1665,7 +1665,7 @@
const llvm::Triple::VendorType vendor_type = arch.GetTriple().getVendor();
if (vendor_type == llvm::Triple::Apple) {
- if (arch_type == llvm::Triple::aarch64 ||
+ if (arch_type == llvm::Triple::aarch64 ||
arch_type == llvm::Triple::aarch64_32) {
return ABISP(
new ABIMacOSX_arm64(std::move(process_sp), MakeMCRegisterInfo(arch)));
Index: lldb/source/API/SystemInitializerFull.cpp
===================================================================
--- lldb/source/API/SystemInitializerFull.cpp
+++ lldb/source/API/SystemInitializerFull.cpp
@@ -24,88 +24,9 @@
#include <string>
-LLDB_PLUGIN_DECLARE(ABIAArch64);
-LLDB_PLUGIN_DECLARE(ABIARM);
-LLDB_PLUGIN_DECLARE(ABISysV_arc);
-LLDB_PLUGIN_DECLARE(ABISysV_hexagon);
-LLDB_PLUGIN_DECLARE(ABIMips);
-LLDB_PLUGIN_DECLARE(ABIPowerPC);
-LLDB_PLUGIN_DECLARE(ABISysV_s390x);
-LLDB_PLUGIN_DECLARE(ABIX86);
-LLDB_PLUGIN_DECLARE(ObjectFileBreakpad);
-LLDB_PLUGIN_DECLARE(ObjectFileELF);
-LLDB_PLUGIN_DECLARE(ObjectFileMachO);
-LLDB_PLUGIN_DECLARE(ObjectFilePECOFF);
-LLDB_PLUGIN_DECLARE(ObjectFileWasm);
-LLDB_PLUGIN_DECLARE(ObjectContainerBSDArchive);
-LLDB_PLUGIN_DECLARE(ObjectContainerUniversalMachO);
-LLDB_PLUGIN_DECLARE(ScriptInterpreterNone);
-#if LLDB_ENABLE_PYTHON
-LLDB_PLUGIN_DECLARE(OperatingSystemPython)
-LLDB_PLUGIN_DECLARE(ScriptInterpreterPython)
-#endif
-#if LLDB_ENABLE_LUA
-LLDB_PLUGIN_DECLARE(ScriptInterpreterLua)
-#endif
-LLDB_PLUGIN_DECLARE(PlatformFreeBSD)
-LLDB_PLUGIN_DECLARE(PlatformLinux)
-LLDB_PLUGIN_DECLARE(PlatformNetBSD)
-LLDB_PLUGIN_DECLARE(PlatformOpenBSD)
-LLDB_PLUGIN_DECLARE(PlatformWindows)
-LLDB_PLUGIN_DECLARE(PlatformAndroid)
-LLDB_PLUGIN_DECLARE(PlatformMacOSX)
-LLDB_PLUGIN_DECLARE(TypeSystemClang)
-LLDB_PLUGIN_DECLARE(ArchitectureArm)
-LLDB_PLUGIN_DECLARE(ArchitectureMips)
-LLDB_PLUGIN_DECLARE(ArchitecturePPC64)
-LLDB_PLUGIN_DECLARE(DisassemblerLLVMC)
-LLDB_PLUGIN_DECLARE(JITLoaderGDB)
-LLDB_PLUGIN_DECLARE(ProcessElfCore)
-LLDB_PLUGIN_DECLARE(ProcessMachCore)
-LLDB_PLUGIN_DECLARE(ProcessMinidump)
-LLDB_PLUGIN_DECLARE(MemoryHistoryASan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeASan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeTSan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeUBSan)
-LLDB_PLUGIN_DECLARE(InstrumentationRuntimeMainThreadChecker)
-LLDB_PLUGIN_DECLARE(SymbolVendorELF)
-LLDB_PLUGIN_DECLARE(SymbolFileBreakpad)
-LLDB_PLUGIN_DECLARE(SymbolFileDWARF)
-LLDB_PLUGIN_DECLARE(SymbolFilePDB)
-LLDB_PLUGIN_DECLARE(SymbolFileSymtab)
-LLDB_PLUGIN_DECLARE(SymbolVendorWasm)
-LLDB_PLUGIN_DECLARE(UnwindAssemblyInstEmulation)
-LLDB_PLUGIN_DECLARE(UnwindAssembly_x86)
-LLDB_PLUGIN_DECLARE(EmulateInstructionARM)
-LLDB_PLUGIN_DECLARE(EmulateInstructionARM64)
-LLDB_PLUGIN_DECLARE(EmulateInstructionMIPS)
-LLDB_PLUGIN_DECLARE(EmulateInstructionMIPS64)
-LLDB_PLUGIN_DECLARE(EmulateInstructionPPC64)
-LLDB_PLUGIN_DECLARE(ItaniumABILanguageRuntime)
-LLDB_PLUGIN_DECLARE(AppleObjCRuntime)
-LLDB_PLUGIN_DECLARE(SystemRuntimeMacOSX)
-LLDB_PLUGIN_DECLARE(RenderScriptRuntime)
-LLDB_PLUGIN_DECLARE(CPlusPlusLanguage)
-LLDB_PLUGIN_DECLARE(ObjCLanguage)
-LLDB_PLUGIN_DECLARE(ObjCPlusPlusLanguage)
-#if defined(_WIN32)
-LLDB_PLUGIN_DECLARE(ProcessWindows)
-#endif
-#if defined(__FreeBSD__)
-LLDB_PLUGIN_DECLARE(ProcessFreeBSD)
-#endif
-#if defined(__APPLE__)
-LLDB_PLUGIN_DECLARE(SymbolVendorMacOSX)
-LLDB_PLUGIN_DECLARE(ProcessKDP)
-LLDB_PLUGIN_DECLARE(DynamicLoaderDarwinKernel)
-#endif
-LLDB_PLUGIN_DECLARE(StructuredDataDarwinLog)
-LLDB_PLUGIN_DECLARE(PlatformRemoteGDBServer)
-LLDB_PLUGIN_DECLARE(ProcessGDBRemote)
-LLDB_PLUGIN_DECLARE(DynamicLoaderMacOSXDYLD)
-LLDB_PLUGIN_DECLARE(DynamicLoaderPOSIXDYLD)
-LLDB_PLUGIN_DECLARE(DynamicLoaderStatic)
-LLDB_PLUGIN_DECLARE(DynamicLoaderWindowsDYLD)
+#undef LLDB_PLUGIN
+#define LLDB_PLUGIN(p) LLDB_PLUGIN_DECLARE(p)
+#include "Plugins/Plugins.def"
using namespace lldb_private;
@@ -113,135 +34,18 @@
SystemInitializerFull::~SystemInitializerFull() {}
-#define LLDB_PROCESS_AArch64(op) op(ABIAArch64);
-#define LLDB_PROCESS_ARM(op) op(ABIARM);
-#define LLDB_PROCESS_ARC(op) op(ABISysV_arc);
-#define LLDB_PROCESS_Hexagon(op) op(ABISysV_hexagon);
-#define LLDB_PROCESS_Mips(op) op(ABIMips);
-#define LLDB_PROCESS_PowerPC(op) op(ABIPowerPC);
-#define LLDB_PROCESS_SystemZ(op) op(ABISysV_s390x);
-#define LLDB_PROCESS_X86(op) op(ABIX86);
-
-#define LLDB_PROCESS_AMDGPU(op)
-#define LLDB_PROCESS_AVR(op)
-#define LLDB_PROCESS_BPF(op)
-#define LLDB_PROCESS_Lanai(op)
-#define LLDB_PROCESS_MSP430(op)
-#define LLDB_PROCESS_NVPTX(op)
-#define LLDB_PROCESS_RISCV(op)
-#define LLDB_PROCESS_Sparc(op)
-#define LLDB_PROCESS_WebAssembly(op)
-#define LLDB_PROCESS_XCore(op)
-
llvm::Error SystemInitializerFull::Initialize() {
if (auto e = SystemInitializerCommon::Initialize())
return e;
- LLDB_PLUGIN_INITIALIZE(ObjectFileBreakpad);
- LLDB_PLUGIN_INITIALIZE(ObjectFileELF);
- LLDB_PLUGIN_INITIALIZE(ObjectFileMachO);
- LLDB_PLUGIN_INITIALIZE(ObjectFilePECOFF);
- LLDB_PLUGIN_INITIALIZE(ObjectFileWasm);
-
- LLDB_PLUGIN_INITIALIZE(ObjectContainerBSDArchive);
- LLDB_PLUGIN_INITIALIZE(ObjectContainerUniversalMachO);
-
- LLDB_PLUGIN_INITIALIZE(ScriptInterpreterNone);
-
-#if LLDB_ENABLE_PYTHON
- LLDB_PLUGIN_INITIALIZE(OperatingSystemPython);
-#endif
-
-#if LLDB_ENABLE_PYTHON
- LLDB_PLUGIN_INITIALIZE(ScriptInterpreterPython);
-#endif
-
-#if LLDB_ENABLE_LUA
- LLDB_PLUGIN_INITIALIZE(ScriptInterpreterLua);
-#endif
- LLDB_PLUGIN_INITIALIZE(PlatformFreeBSD);
- LLDB_PLUGIN_INITIALIZE(PlatformLinux);
- LLDB_PLUGIN_INITIALIZE(PlatformNetBSD);
- LLDB_PLUGIN_INITIALIZE(PlatformOpenBSD);
- LLDB_PLUGIN_INITIALIZE(PlatformWindows);
- LLDB_PLUGIN_INITIALIZE(PlatformAndroid);
- LLDB_PLUGIN_INITIALIZE(PlatformMacOSX);
-
// Initialize LLVM and Clang
llvm::InitializeAllTargets();
llvm::InitializeAllAsmPrinters();
llvm::InitializeAllTargetMCs();
llvm::InitializeAllDisassemblers();
- LLDB_PLUGIN_INITIALIZE(TypeSystemClang);
-
-#define LLVM_TARGET(t) LLDB_PROCESS_##t(LLDB_PLUGIN_INITIALIZE)
-#include "llvm/Config/Targets.def"
-
- LLDB_PLUGIN_INITIALIZE(ArchitectureArm);
- LLDB_PLUGIN_INITIALIZE(ArchitectureMips);
- LLDB_PLUGIN_INITIALIZE(ArchitecturePPC64);
-
- LLDB_PLUGIN_INITIALIZE(DisassemblerLLVMC);
-
- LLDB_PLUGIN_INITIALIZE(JITLoaderGDB);
- LLDB_PLUGIN_INITIALIZE(ProcessElfCore);
- LLDB_PLUGIN_INITIALIZE(ProcessMachCore);
- LLDB_PLUGIN_INITIALIZE(ProcessMinidump);
- LLDB_PLUGIN_INITIALIZE(MemoryHistoryASan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeASan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeTSan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeUBSan);
- LLDB_PLUGIN_INITIALIZE(InstrumentationRuntimeMainThreadChecker);
-
- LLDB_PLUGIN_INITIALIZE(SymbolVendorELF);
- LLDB_PLUGIN_INITIALIZE(SymbolFileBreakpad);
- LLDB_PLUGIN_INITIALIZE(SymbolFileDWARF);
- LLDB_PLUGIN_INITIALIZE(SymbolFilePDB);
- LLDB_PLUGIN_INITIALIZE(SymbolFileSymtab);
- LLDB_PLUGIN_INITIALIZE(SymbolVendorWasm);
- LLDB_PLUGIN_INITIALIZE(UnwindAssemblyInstEmulation);
- LLDB_PLUGIN_INITIALIZE(UnwindAssembly_x86);
-
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionARM);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionARM64);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionMIPS);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionMIPS64);
- LLDB_PLUGIN_INITIALIZE(EmulateInstructionPPC64);
-
- LLDB_PLUGIN_INITIALIZE(ItaniumABILanguageRuntime);
- LLDB_PLUGIN_INITIALIZE(AppleObjCRuntime);
- LLDB_PLUGIN_INITIALIZE(SystemRuntimeMacOSX);
- LLDB_PLUGIN_INITIALIZE(RenderScriptRuntime);
-
- LLDB_PLUGIN_INITIALIZE(CPlusPlusLanguage);
- LLDB_PLUGIN_INITIALIZE(ObjCLanguage);
- LLDB_PLUGIN_INITIALIZE(ObjCPlusPlusLanguage);
-
-#if defined(_WIN32)
- LLDB_PLUGIN_INITIALIZE(ProcessWindows);
-#endif
-#if defined(__FreeBSD__)
- LLDB_PLUGIN_INITIALIZE(ProcessFreeBSD);
-#endif
-#if defined(__APPLE__)
- LLDB_PLUGIN_INITIALIZE(SymbolVendorMacOSX);
- LLDB_PLUGIN_INITIALIZE(ProcessKDP);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderDarwinKernel);
-#endif
-
- // This plugin is valid on any host that talks to a Darwin remote. It
- // shouldn't be limited to __APPLE__.
- LLDB_PLUGIN_INITIALIZE(StructuredDataDarwinLog);
-
- // Platform agnostic plugins
- LLDB_PLUGIN_INITIALIZE(PlatformRemoteGDBServer);
-
- LLDB_PLUGIN_INITIALIZE(ProcessGDBRemote);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderMacOSXDYLD);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderPOSIXDYLD);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderStatic);
- LLDB_PLUGIN_INITIALIZE(DynamicLoaderWindowsDYLD);
+#define LLDB_PLUGIN(p) LLDB_PLUGIN_INITIALIZE(p);
+#include "Plugins/Plugins.def"
// Scan for any system or user LLDB plug-ins
PluginManager::Initialize();
@@ -264,102 +68,8 @@
// Terminate and unload and loaded system or user LLDB plug-ins
PluginManager::Terminate();
- LLDB_PLUGIN_TERMINATE(TypeSystemClang);
-
- LLDB_PLUGIN_TERMINATE(ArchitectureArm);
- LLDB_PLUGIN_TERMINATE(ArchitectureMips);
- LLDB_PLUGIN_TERMINATE(ArchitecturePPC64);
-
-#define LLVM_TARGET(t) LLDB_PROCESS_##t(LLDB_PLUGIN_TERMINATE)
-#include "llvm/Config/Targets.def"
-
- LLDB_PLUGIN_TERMINATE(DisassemblerLLVMC);
-
- LLDB_PLUGIN_TERMINATE(JITLoaderGDB);
- LLDB_PLUGIN_TERMINATE(ProcessElfCore);
- LLDB_PLUGIN_TERMINATE(ProcessMachCore);
- LLDB_PLUGIN_TERMINATE(ProcessMinidump);
- LLDB_PLUGIN_TERMINATE(MemoryHistoryASan);
-
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeASan);
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeTSan);
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeUBSan);
- LLDB_PLUGIN_TERMINATE(InstrumentationRuntimeMainThreadChecker);
-
- LLDB_PLUGIN_TERMINATE(SymbolVendorWasm);
- LLDB_PLUGIN_TERMINATE(SymbolVendorELF);
- LLDB_PLUGIN_TERMINATE(SymbolFileBreakpad);
- LLDB_PLUGIN_TERMINATE(SymbolFileDWARF);
- LLDB_PLUGIN_TERMINATE(SymbolFilePDB);
- LLDB_PLUGIN_TERMINATE(SymbolFileSymtab);
- LLDB_PLUGIN_TERMINATE(UnwindAssembly_x86);
- LLDB_PLUGIN_TERMINATE(UnwindAssemblyInstEmulation);
-
- LLDB_PLUGIN_TERMINATE(EmulateInstructionARM);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionARM64);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionMIPS);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionMIPS64);
- LLDB_PLUGIN_TERMINATE(EmulateInstructionPPC64);
-
- LLDB_PLUGIN_TERMINATE(ItaniumABILanguageRuntime);
- LLDB_PLUGIN_TERMINATE(AppleObjCRuntime);
- LLDB_PLUGIN_TERMINATE(SystemRuntimeMacOSX);
- LLDB_PLUGIN_TERMINATE(RenderScriptRuntime);
-
- LLDB_PLUGIN_TERMINATE(CPlusPlusLanguage);
- LLDB_PLUGIN_TERMINATE(ObjCLanguage);
- LLDB_PLUGIN_TERMINATE(ObjCPlusPlusLanguage);
-
-#if defined(__APPLE__)
- LLDB_PLUGIN_TERMINATE(DynamicLoaderDarwinKernel);
- LLDB_PLUGIN_TERMINATE(ProcessKDP);
- LLDB_PLUGIN_TERMINATE(SymbolVendorMacOSX);
-#endif
-
-#if defined(__FreeBSD__)
- LLDB_PLUGIN_TERMINATE(ProcessFreeBSD);
-#endif
- Debugger::SettingsTerminate();
-
- LLDB_PLUGIN_TERMINATE(PlatformRemoteGDBServer);
- LLDB_PLUGIN_TERMINATE(ProcessGDBRemote);
- LLDB_PLUGIN_TERMINATE(StructuredDataDarwinLog);
-
- LLDB_PLUGIN_TERMINATE(DynamicLoaderMacOSXDYLD);
- LLDB_PLUGIN_TERMINATE(DynamicLoaderPOSIXDYLD);
- LLDB_PLUGIN_TERMINATE(DynamicLoaderStatic);
- LLDB_PLUGIN_TERMINATE(DynamicLoaderWindowsDYLD);
-
- LLDB_PLUGIN_TERMINATE(PlatformFreeBSD);
- LLDB_PLUGIN_TERMINATE(PlatformLinux);
- LLDB_PLUGIN_TERMINATE(PlatformNetBSD);
- LLDB_PLUGIN_TERMINATE(PlatformOpenBSD);
- LLDB_PLUGIN_TERMINATE(PlatformWindows);
- LLDB_PLUGIN_TERMINATE(PlatformAndroid);
- LLDB_PLUGIN_TERMINATE(PlatformMacOSX);
-
- LLDB_PLUGIN_TERMINATE(ObjectFileBreakpad);
- LLDB_PLUGIN_TERMINATE(ObjectFileELF);
- LLDB_PLUGIN_TERMINATE(ObjectFileMachO);
- LLDB_PLUGIN_TERMINATE(ObjectFilePECOFF);
- LLDB_PLUGIN_TERMINATE(ObjectFileWasm);
-
- LLDB_PLUGIN_TERMINATE(ObjectContainerBSDArchive);
- LLDB_PLUGIN_TERMINATE(ObjectContainerUniversalMachO);
-
-#if LLDB_ENABLE_PYTHON
- LLDB_PLUGIN_TERMINATE(OperatingSystemPython);
-#endif
-
-#if LLDB_ENABLE_PYTHON
- LLDB_PLUGIN_TERMINATE(ScriptInterpreterPython);
-#endif
-
-#if LLDB_ENABLE_LUA
- LLDB_PLUGIN_TERMINATE(ScriptInterpreterLua);
-#endif
-
- LLDB_PLUGIN_TERMINATE(ScriptInterpreterNone);
+#define LLDB_PLUGIN(p) LLDB_PLUGIN_TERMINATE(p);
+#include "Plugins/Plugins.def"
// Now shutdown the common parts, in reverse order.
SystemInitializerCommon::Terminate();
Index: lldb/include/lldb/Core/PluginManager.h
===================================================================
--- lldb/include/lldb/Core/PluginManager.h
+++ lldb/include/lldb/Core/PluginManager.h
@@ -28,8 +28,14 @@
void lldb_terminate_##PluginName() { PluginName::Terminate(); } \
}
+#define LLDB_PLUGIN_ADV(ClassName, PluginName) \
+ namespace lldb_private { \
+ void lldb_initialize_##PluginName() { ClassName::Initialize(); } \
+ void lldb_terminate_##PluginName() { ClassName::Terminate(); } \
+ }
+
// FIXME: Generate me with CMake
-#define LLDB_PLUGIN_DECLARE(PluginName) \
+#define LLDB_PLUGIN_DECLARE(PluginName) \
namespace lldb_private { \
extern void lldb_initialize_##PluginName(); \
extern void lldb_terminate_##PluginName(); \
_______________________________________________
lldb-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-commits