2015-04-01 05:03:22 +08:00
|
|
|
//===-- SystemInitializerCommon.cpp -----------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "lldb/Initialization/SystemInitializerCommon.h"
|
|
|
|
|
|
|
|
#include "lldb/Host/Host.h"
|
|
|
|
#include "lldb/Host/HostInfo.h"
|
|
|
|
#include "lldb/Core/Log.h"
|
|
|
|
#include "lldb/Core/Timer.h"
|
TypeSystem is now a plugin interface and removed any "ClangASTContext &Class::GetClangASTContext()" functions.
This cleans up type systems to be more pluggable. Prior to this we had issues:
- Module, SymbolFile, and many others has "ClangASTContext &GetClangASTContext()" functions. All have been switched over to use "TypeSystem *GetTypeSystemForLanguage()"
- Cleaned up any places that were using the GetClangASTContext() functions to use TypeSystem
- Cleaned up Module so that it no longer has dedicated type system member variables:
lldb::ClangASTContextUP m_ast; ///< The Clang AST context for this module.
lldb::GoASTContextUP m_go_ast; ///< The Go AST context for this module.
Now we have a type system map:
typedef std::map<lldb::LanguageType, lldb::TypeSystemSP> TypeSystemMap;
TypeSystemMap m_type_system_map; ///< A map of any type systems associated with this module
- Many places in code were using ClangASTContext static functions to place with CompilerType objects and add modifiers (const, volatile, restrict) and to make typedefs, L and R value references and more. These have been made into CompilerType functions that are abstract:
class CompilerType
{
...
//----------------------------------------------------------------------
// Return a new CompilerType that is a L value reference to this type if
// this type is valid and the type system supports L value references,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
GetLValueReferenceType () const;
//----------------------------------------------------------------------
// Return a new CompilerType that is a R value reference to this type if
// this type is valid and the type system supports R value references,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
GetRValueReferenceType () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a const modifier to this type if
// this type is valid and the type system supports const modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddConstModifier () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a volatile modifier to this type if
// this type is valid and the type system supports volatile modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddVolatileModifier () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a restrict modifier to this type if
// this type is valid and the type system supports restrict modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddRestrictModifier () const;
//----------------------------------------------------------------------
// Create a typedef to this type using "name" as the name of the typedef
// this type is valid and the type system supports typedefs, else return
// an invalid type.
//----------------------------------------------------------------------
CompilerType
CreateTypedef (const char *name, const CompilerDeclContext &decl_ctx) const;
};
Other changes include:
- Removed "CompilerType TypeSystem::GetIntTypeFromBitSize(...)" and CompilerType TypeSystem::GetFloatTypeFromBitSize(...) and replaced it with "CompilerType TypeSystem::GetBuiltinTypeForEncodingAndBitSize(lldb::Encoding encoding, size_t bit_size);"
- Fixed code in Type.h to not request the full type for a type for no good reason, just request the forward type and let the type expand as needed
llvm-svn: 247953
2015-09-18 06:23:34 +08:00
|
|
|
#include "lldb/Symbol/GoASTContext.h"
|
|
|
|
#include "lldb/Symbol/ClangASTContext.h"
|
2015-04-01 05:03:22 +08:00
|
|
|
#include "Plugins/DynamicLoader/MacOSX-DYLD/DynamicLoaderMacOSXDYLD.h"
|
|
|
|
#include "Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.h"
|
2015-07-09 02:07:13 +08:00
|
|
|
#include "Plugins/DynamicLoader/Windows-DYLD/DynamicLoaderWindowsDYLD.h"
|
2015-04-15 17:47:02 +08:00
|
|
|
#include "Plugins/Instruction/ARM/EmulateInstructionARM.h"
|
2015-05-15 14:53:30 +08:00
|
|
|
#include "Plugins/Instruction/MIPS/EmulateInstructionMIPS.h"
|
2015-05-07 13:56:27 +08:00
|
|
|
#include "Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.h"
|
2015-04-01 05:03:22 +08:00
|
|
|
#include "Plugins/ObjectContainer/BSD-Archive/ObjectContainerBSDArchive.h"
|
|
|
|
#include "Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.h"
|
|
|
|
#include "Plugins/ObjectFile/ELF/ObjectFileELF.h"
|
|
|
|
#include "Plugins/ObjectFile/PECOFF/ObjectFilePECOFF.h"
|
|
|
|
#include "Plugins/OperatingSystem/Python/OperatingSystemPython.h"
|
2015-09-17 05:20:44 +08:00
|
|
|
#include "Plugins/OperatingSystem/Go/OperatingSystemGo.h"
|
2015-04-01 05:03:22 +08:00
|
|
|
#include "Plugins/Platform/Android/PlatformAndroid.h"
|
|
|
|
#include "Plugins/Platform/FreeBSD/PlatformFreeBSD.h"
|
|
|
|
#include "Plugins/Platform/Kalimba/PlatformKalimba.h"
|
|
|
|
#include "Plugins/Platform/Linux/PlatformLinux.h"
|
|
|
|
#include "Plugins/Platform/MacOSX/PlatformiOSSimulator.h"
|
|
|
|
#include "Plugins/Platform/MacOSX/PlatformMacOSX.h"
|
|
|
|
#include "Plugins/Platform/MacOSX/PlatformRemoteiOS.h"
|
|
|
|
#include "Plugins/Platform/Windows/PlatformWindows.h"
|
|
|
|
#include "Plugins/Process/gdb-remote/ProcessGDBRemoteLog.h"
|
|
|
|
|
|
|
|
#if defined(__APPLE__)
|
|
|
|
#include "Plugins/DynamicLoader/Darwin-Kernel/DynamicLoaderDarwinKernel.h"
|
|
|
|
#include "Plugins/ObjectFile/Mach-O/ObjectFileMachO.h"
|
|
|
|
#include "Plugins/Platform/MacOSX/PlatformDarwinKernel.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(__linux__)
|
|
|
|
#include "Plugins/Process/POSIX/ProcessPOSIXLog.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
#include "lldb/Host/windows/windows.h"
|
2015-08-25 00:00:51 +08:00
|
|
|
#include "Plugins/Process/Windows/Live/ProcessWindowsLog.h"
|
2015-04-01 05:03:22 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "llvm/Support/TargetSelect.h"
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
using namespace lldb_private;
|
|
|
|
|
|
|
|
static void
|
|
|
|
fatal_error_handler(void *user_data, const std::string &reason, bool gen_crash_diag)
|
|
|
|
{
|
|
|
|
Host::SetCrashDescription(reason.c_str());
|
|
|
|
::abort();
|
|
|
|
}
|
|
|
|
|
|
|
|
SystemInitializerCommon::SystemInitializerCommon()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
SystemInitializerCommon::~SystemInitializerCommon()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SystemInitializerCommon::Initialize()
|
|
|
|
{
|
|
|
|
#if defined(_MSC_VER)
|
|
|
|
const char *disable_crash_dialog_var = getenv("LLDB_DISABLE_CRASH_DIALOG");
|
|
|
|
if (disable_crash_dialog_var && llvm::StringRef(disable_crash_dialog_var).equals_lower("true"))
|
|
|
|
{
|
|
|
|
// This will prevent Windows from displaying a dialog box requiring user interaction when
|
|
|
|
// LLDB crashes. This is mostly useful when automating LLDB, for example via the test
|
|
|
|
// suite, so that a crash in LLDB does not prevent completion of the test suite.
|
|
|
|
::SetErrorMode(GetErrorMode() | SEM_FAILCRITICALERRORS | SEM_NOGPFAULTERRORBOX);
|
|
|
|
|
|
|
|
_CrtSetReportMode(_CRT_ASSERT, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG);
|
|
|
|
_CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG);
|
|
|
|
_CrtSetReportMode(_CRT_ERROR, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG);
|
|
|
|
_CrtSetReportFile(_CRT_ASSERT, _CRTDBG_FILE_STDERR);
|
|
|
|
_CrtSetReportFile(_CRT_WARN, _CRTDBG_FILE_STDERR);
|
|
|
|
_CrtSetReportFile(_CRT_ERROR, _CRTDBG_FILE_STDERR);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
Log::Initialize();
|
|
|
|
HostInfo::Initialize();
|
|
|
|
Timer::Initialize();
|
|
|
|
Timer scoped_timer(__PRETTY_FUNCTION__, __PRETTY_FUNCTION__);
|
|
|
|
|
|
|
|
llvm::install_fatal_error_handler(fatal_error_handler, 0);
|
|
|
|
|
|
|
|
process_gdb_remote::ProcessGDBRemoteLog::Initialize();
|
|
|
|
|
|
|
|
// Initialize plug-ins
|
TypeSystem is now a plugin interface and removed any "ClangASTContext &Class::GetClangASTContext()" functions.
This cleans up type systems to be more pluggable. Prior to this we had issues:
- Module, SymbolFile, and many others has "ClangASTContext &GetClangASTContext()" functions. All have been switched over to use "TypeSystem *GetTypeSystemForLanguage()"
- Cleaned up any places that were using the GetClangASTContext() functions to use TypeSystem
- Cleaned up Module so that it no longer has dedicated type system member variables:
lldb::ClangASTContextUP m_ast; ///< The Clang AST context for this module.
lldb::GoASTContextUP m_go_ast; ///< The Go AST context for this module.
Now we have a type system map:
typedef std::map<lldb::LanguageType, lldb::TypeSystemSP> TypeSystemMap;
TypeSystemMap m_type_system_map; ///< A map of any type systems associated with this module
- Many places in code were using ClangASTContext static functions to place with CompilerType objects and add modifiers (const, volatile, restrict) and to make typedefs, L and R value references and more. These have been made into CompilerType functions that are abstract:
class CompilerType
{
...
//----------------------------------------------------------------------
// Return a new CompilerType that is a L value reference to this type if
// this type is valid and the type system supports L value references,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
GetLValueReferenceType () const;
//----------------------------------------------------------------------
// Return a new CompilerType that is a R value reference to this type if
// this type is valid and the type system supports R value references,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
GetRValueReferenceType () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a const modifier to this type if
// this type is valid and the type system supports const modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddConstModifier () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a volatile modifier to this type if
// this type is valid and the type system supports volatile modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddVolatileModifier () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a restrict modifier to this type if
// this type is valid and the type system supports restrict modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddRestrictModifier () const;
//----------------------------------------------------------------------
// Create a typedef to this type using "name" as the name of the typedef
// this type is valid and the type system supports typedefs, else return
// an invalid type.
//----------------------------------------------------------------------
CompilerType
CreateTypedef (const char *name, const CompilerDeclContext &decl_ctx) const;
};
Other changes include:
- Removed "CompilerType TypeSystem::GetIntTypeFromBitSize(...)" and CompilerType TypeSystem::GetFloatTypeFromBitSize(...) and replaced it with "CompilerType TypeSystem::GetBuiltinTypeForEncodingAndBitSize(lldb::Encoding encoding, size_t bit_size);"
- Fixed code in Type.h to not request the full type for a type for no good reason, just request the forward type and let the type expand as needed
llvm-svn: 247953
2015-09-18 06:23:34 +08:00
|
|
|
ClangASTContext::Initialize();
|
|
|
|
GoASTContext::Initialize();
|
|
|
|
|
2015-04-01 05:03:22 +08:00
|
|
|
ObjectContainerBSDArchive::Initialize();
|
|
|
|
ObjectFileELF::Initialize();
|
|
|
|
ObjectFilePECOFF::Initialize();
|
|
|
|
DynamicLoaderPOSIXDYLD::Initialize();
|
2015-07-09 02:07:13 +08:00
|
|
|
DynamicLoaderWindowsDYLD::Initialize();
|
2015-07-03 01:35:22 +08:00
|
|
|
platform_freebsd::PlatformFreeBSD::Initialize();
|
2015-04-01 05:03:22 +08:00
|
|
|
platform_linux::PlatformLinux::Initialize();
|
|
|
|
PlatformWindows::Initialize();
|
|
|
|
PlatformKalimba::Initialize();
|
|
|
|
platform_android::PlatformAndroid::Initialize();
|
|
|
|
|
2015-04-15 17:47:02 +08:00
|
|
|
EmulateInstructionARM::Initialize();
|
2015-05-15 14:53:30 +08:00
|
|
|
EmulateInstructionMIPS::Initialize();
|
2015-05-07 13:56:27 +08:00
|
|
|
EmulateInstructionMIPS64::Initialize();
|
2015-04-15 17:47:02 +08:00
|
|
|
|
2015-04-01 05:03:22 +08:00
|
|
|
//----------------------------------------------------------------------
|
|
|
|
// Apple/Darwin hosted plugins
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
DynamicLoaderMacOSXDYLD::Initialize();
|
|
|
|
ObjectContainerUniversalMachO::Initialize();
|
|
|
|
|
|
|
|
PlatformRemoteiOS::Initialize();
|
|
|
|
PlatformMacOSX::Initialize();
|
|
|
|
PlatformiOSSimulator::Initialize();
|
|
|
|
|
|
|
|
#if defined(__APPLE__)
|
|
|
|
DynamicLoaderDarwinKernel::Initialize();
|
|
|
|
PlatformDarwinKernel::Initialize();
|
|
|
|
ObjectFileMachO::Initialize();
|
|
|
|
#endif
|
|
|
|
#if defined(__linux__)
|
|
|
|
static ConstString g_linux_log_name("linux");
|
|
|
|
ProcessPOSIXLog::Initialize(g_linux_log_name);
|
|
|
|
#endif
|
2015-04-11 00:18:08 +08:00
|
|
|
#if defined(_MSC_VER)
|
|
|
|
ProcessWindowsLog::Initialize();
|
|
|
|
#endif
|
2015-04-01 05:03:22 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
|
|
|
OperatingSystemPython::Initialize();
|
|
|
|
#endif
|
2015-09-17 05:20:44 +08:00
|
|
|
OperatingSystemGo::Initialize();
|
2015-04-01 05:03:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
SystemInitializerCommon::Terminate()
|
|
|
|
{
|
|
|
|
Timer scoped_timer(__PRETTY_FUNCTION__, __PRETTY_FUNCTION__);
|
|
|
|
ObjectContainerBSDArchive::Terminate();
|
|
|
|
ObjectFileELF::Terminate();
|
|
|
|
ObjectFilePECOFF::Terminate();
|
|
|
|
DynamicLoaderPOSIXDYLD::Terminate();
|
2015-07-09 02:07:13 +08:00
|
|
|
DynamicLoaderWindowsDYLD::Terminate();
|
2015-07-03 01:35:22 +08:00
|
|
|
platform_freebsd::PlatformFreeBSD::Terminate();
|
2015-04-01 05:03:22 +08:00
|
|
|
platform_linux::PlatformLinux::Terminate();
|
|
|
|
PlatformWindows::Terminate();
|
|
|
|
PlatformKalimba::Terminate();
|
|
|
|
platform_android::PlatformAndroid::Terminate();
|
|
|
|
DynamicLoaderMacOSXDYLD::Terminate();
|
|
|
|
ObjectContainerUniversalMachO::Terminate();
|
|
|
|
PlatformMacOSX::Terminate();
|
|
|
|
PlatformRemoteiOS::Terminate();
|
|
|
|
PlatformiOSSimulator::Terminate();
|
|
|
|
|
TypeSystem is now a plugin interface and removed any "ClangASTContext &Class::GetClangASTContext()" functions.
This cleans up type systems to be more pluggable. Prior to this we had issues:
- Module, SymbolFile, and many others has "ClangASTContext &GetClangASTContext()" functions. All have been switched over to use "TypeSystem *GetTypeSystemForLanguage()"
- Cleaned up any places that were using the GetClangASTContext() functions to use TypeSystem
- Cleaned up Module so that it no longer has dedicated type system member variables:
lldb::ClangASTContextUP m_ast; ///< The Clang AST context for this module.
lldb::GoASTContextUP m_go_ast; ///< The Go AST context for this module.
Now we have a type system map:
typedef std::map<lldb::LanguageType, lldb::TypeSystemSP> TypeSystemMap;
TypeSystemMap m_type_system_map; ///< A map of any type systems associated with this module
- Many places in code were using ClangASTContext static functions to place with CompilerType objects and add modifiers (const, volatile, restrict) and to make typedefs, L and R value references and more. These have been made into CompilerType functions that are abstract:
class CompilerType
{
...
//----------------------------------------------------------------------
// Return a new CompilerType that is a L value reference to this type if
// this type is valid and the type system supports L value references,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
GetLValueReferenceType () const;
//----------------------------------------------------------------------
// Return a new CompilerType that is a R value reference to this type if
// this type is valid and the type system supports R value references,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
GetRValueReferenceType () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a const modifier to this type if
// this type is valid and the type system supports const modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddConstModifier () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a volatile modifier to this type if
// this type is valid and the type system supports volatile modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddVolatileModifier () const;
//----------------------------------------------------------------------
// Return a new CompilerType adds a restrict modifier to this type if
// this type is valid and the type system supports restrict modifiers,
// else return an invalid type.
//----------------------------------------------------------------------
CompilerType
AddRestrictModifier () const;
//----------------------------------------------------------------------
// Create a typedef to this type using "name" as the name of the typedef
// this type is valid and the type system supports typedefs, else return
// an invalid type.
//----------------------------------------------------------------------
CompilerType
CreateTypedef (const char *name, const CompilerDeclContext &decl_ctx) const;
};
Other changes include:
- Removed "CompilerType TypeSystem::GetIntTypeFromBitSize(...)" and CompilerType TypeSystem::GetFloatTypeFromBitSize(...) and replaced it with "CompilerType TypeSystem::GetBuiltinTypeForEncodingAndBitSize(lldb::Encoding encoding, size_t bit_size);"
- Fixed code in Type.h to not request the full type for a type for no good reason, just request the forward type and let the type expand as needed
llvm-svn: 247953
2015-09-18 06:23:34 +08:00
|
|
|
ClangASTContext::Terminate();
|
|
|
|
GoASTContext::Terminate();
|
|
|
|
|
2015-04-15 17:47:02 +08:00
|
|
|
EmulateInstructionARM::Terminate();
|
2015-05-15 14:53:30 +08:00
|
|
|
EmulateInstructionMIPS::Terminate();
|
2015-05-07 13:56:27 +08:00
|
|
|
EmulateInstructionMIPS64::Terminate();
|
2015-04-15 17:47:02 +08:00
|
|
|
|
2015-04-01 05:03:22 +08:00
|
|
|
#if defined(__APPLE__)
|
|
|
|
DynamicLoaderDarwinKernel::Terminate();
|
|
|
|
ObjectFileMachO::Terminate();
|
|
|
|
PlatformDarwinKernel::Terminate();
|
|
|
|
#endif
|
|
|
|
|
2015-09-05 00:34:19 +08:00
|
|
|
#if defined(_MSC_VER)
|
2015-05-08 05:39:33 +08:00
|
|
|
ProcessWindowsLog::Terminate();
|
|
|
|
#endif
|
|
|
|
|
2015-04-01 05:03:22 +08:00
|
|
|
#ifndef LLDB_DISABLE_PYTHON
|
|
|
|
OperatingSystemPython::Terminate();
|
|
|
|
#endif
|
2015-09-17 05:20:44 +08:00
|
|
|
OperatingSystemGo::Terminate();
|
2015-04-01 05:03:22 +08:00
|
|
|
|
|
|
|
Log::Terminate();
|
|
|
|
}
|