1e6e2bb38SZachary Turner //===-- SystemInitializerCommon.cpp -----------------------------*- C++ -*-===// 2e6e2bb38SZachary Turner // 3*2946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*2946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information. 5*2946cd70SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6e6e2bb38SZachary Turner // 7e6e2bb38SZachary Turner //===----------------------------------------------------------------------===// 8e6e2bb38SZachary Turner 9e6e2bb38SZachary Turner #include "lldb/Initialization/SystemInitializerCommon.h" 10e6e2bb38SZachary Turner 11d8c338d4STamas Berghammer #include "Plugins/Instruction/ARM/EmulateInstructionARM.h" 12794a4d5aSBhushan D. Attarde #include "Plugins/Instruction/MIPS/EmulateInstructionMIPS.h" 13cdc22a88SMohit K. Bhakkad #include "Plugins/Instruction/MIPS64/EmulateInstructionMIPS64.h" 14e6e2bb38SZachary Turner #include "Plugins/ObjectContainer/BSD-Archive/ObjectContainerBSDArchive.h" 15e6e2bb38SZachary Turner #include "Plugins/ObjectContainer/Universal-Mach-O/ObjectContainerUniversalMachO.h" 16e6e2bb38SZachary Turner #include "Plugins/Process/gdb-remote/ProcessGDBRemoteLog.h" 1746376966SJonas Devlieghere #include "lldb/Host/FileSystem.h" 18b9c1b51eSKate Stone #include "lldb/Host/Host.h" 19b9c1b51eSKate Stone #include "lldb/Host/HostInfo.h" 206f9e6901SZachary Turner #include "lldb/Utility/Log.h" 2115eacd74SJonas Devlieghere #include "lldb/Utility/Reproducer.h" 2238d0632eSPavel Labath #include "lldb/Utility/Timer.h" 23e6e2bb38SZachary Turner 24a87101d6SKamil Rytarowski #if defined(__linux__) || defined(__FreeBSD__) || defined(__NetBSD__) 25e6e2bb38SZachary Turner #include "Plugins/Process/POSIX/ProcessPOSIXLog.h" 26e6e2bb38SZachary Turner #endif 27e6e2bb38SZachary Turner 28e6e2bb38SZachary Turner #if defined(_MSC_VER) 2918a9135dSAdrian McCarthy #include "Plugins/Process/Windows/Common/ProcessWindowsLog.h" 3074e08ca0SZachary Turner #include "lldb/Host/windows/windows.h" 31e6e2bb38SZachary Turner #endif 32e6e2bb38SZachary Turner 33e6e2bb38SZachary Turner #include "llvm/Support/TargetSelect.h" 34e6e2bb38SZachary Turner 35e6e2bb38SZachary Turner #include <string> 36e6e2bb38SZachary Turner 37e6e2bb38SZachary Turner using namespace lldb_private; 3815eacd74SJonas Devlieghere using namespace lldb_private::repro; 39e6e2bb38SZachary Turner 40b9c1b51eSKate Stone SystemInitializerCommon::SystemInitializerCommon() {} 41e6e2bb38SZachary Turner 42b9c1b51eSKate Stone SystemInitializerCommon::~SystemInitializerCommon() {} 43e6e2bb38SZachary Turner 4415eacd74SJonas Devlieghere llvm::Error 4515eacd74SJonas Devlieghere SystemInitializerCommon::Initialize(const InitializerOptions &options) { 46e6e2bb38SZachary Turner #if defined(_MSC_VER) 47e6e2bb38SZachary Turner const char *disable_crash_dialog_var = getenv("LLDB_DISABLE_CRASH_DIALOG"); 48b9c1b51eSKate Stone if (disable_crash_dialog_var && 49b9c1b51eSKate Stone llvm::StringRef(disable_crash_dialog_var).equals_lower("true")) { 50b9c1b51eSKate Stone // This will prevent Windows from displaying a dialog box requiring user 51b9c1b51eSKate Stone // interaction when 52b9c1b51eSKate Stone // LLDB crashes. This is mostly useful when automating LLDB, for example 53b9c1b51eSKate Stone // via the test 54b9c1b51eSKate Stone // suite, so that a crash in LLDB does not prevent completion of the test 55b9c1b51eSKate Stone // suite. 56b9c1b51eSKate Stone ::SetErrorMode(GetErrorMode() | SEM_FAILCRITICALERRORS | 57b9c1b51eSKate Stone SEM_NOGPFAULTERRORBOX); 58e6e2bb38SZachary Turner 59e6e2bb38SZachary Turner _CrtSetReportMode(_CRT_ASSERT, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG); 60e6e2bb38SZachary Turner _CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG); 61e6e2bb38SZachary Turner _CrtSetReportMode(_CRT_ERROR, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG); 62e6e2bb38SZachary Turner _CrtSetReportFile(_CRT_ASSERT, _CRTDBG_FILE_STDERR); 63e6e2bb38SZachary Turner _CrtSetReportFile(_CRT_WARN, _CRTDBG_FILE_STDERR); 64e6e2bb38SZachary Turner _CrtSetReportFile(_CRT_ERROR, _CRTDBG_FILE_STDERR); 65e6e2bb38SZachary Turner } 66e6e2bb38SZachary Turner #endif 67e6e2bb38SZachary Turner 6815eacd74SJonas Devlieghere ReproducerMode mode = ReproducerMode::Off; 6915eacd74SJonas Devlieghere if (options.reproducer_capture) 7015eacd74SJonas Devlieghere mode = ReproducerMode::Capture; 7115eacd74SJonas Devlieghere if (options.reproducer_replay) 7215eacd74SJonas Devlieghere mode = ReproducerMode::Replay; 7315eacd74SJonas Devlieghere 7415eacd74SJonas Devlieghere if (auto e = Reproducer::Initialize(mode, FileSpec(options.reproducer_path))) 7515eacd74SJonas Devlieghere return e; 7615eacd74SJonas Devlieghere 7746376966SJonas Devlieghere FileSystem::Initialize(); 78d813309eSPavel Labath Log::Initialize(); 79e6e2bb38SZachary Turner HostInfo::Initialize(); 80f9d16476SPavel Labath static Timer::Category func_cat(LLVM_PRETTY_FUNCTION); 81f9d16476SPavel Labath Timer scoped_timer(func_cat, LLVM_PRETTY_FUNCTION); 82e6e2bb38SZachary Turner 83e6e2bb38SZachary Turner process_gdb_remote::ProcessGDBRemoteLog::Initialize(); 84e6e2bb38SZachary Turner 85e6e2bb38SZachary Turner // Initialize plug-ins 86e6e2bb38SZachary Turner ObjectContainerBSDArchive::Initialize(); 87e6e2bb38SZachary Turner 88d8c338d4STamas Berghammer EmulateInstructionARM::Initialize(); 89794a4d5aSBhushan D. Attarde EmulateInstructionMIPS::Initialize(); 90cdc22a88SMohit K. Bhakkad EmulateInstructionMIPS64::Initialize(); 91d8c338d4STamas Berghammer 92e6e2bb38SZachary Turner //---------------------------------------------------------------------- 93e6e2bb38SZachary Turner // Apple/Darwin hosted plugins 94e6e2bb38SZachary Turner //---------------------------------------------------------------------- 95e6e2bb38SZachary Turner ObjectContainerUniversalMachO::Initialize(); 96e6e2bb38SZachary Turner 97a87101d6SKamil Rytarowski #if defined(__linux__) || defined(__FreeBSD__) || defined(__NetBSD__) 98c29f7ff3SPavel Labath ProcessPOSIXLog::Initialize(); 99e6e2bb38SZachary Turner #endif 10042b33806SAdrian McCarthy #if defined(_MSC_VER) 10142b33806SAdrian McCarthy ProcessWindowsLog::Initialize(); 10242b33806SAdrian McCarthy #endif 10315eacd74SJonas Devlieghere 10415eacd74SJonas Devlieghere return llvm::Error::success(); 105e6e2bb38SZachary Turner } 106e6e2bb38SZachary Turner 107b9c1b51eSKate Stone void SystemInitializerCommon::Terminate() { 108f9d16476SPavel Labath static Timer::Category func_cat(LLVM_PRETTY_FUNCTION); 109f9d16476SPavel Labath Timer scoped_timer(func_cat, LLVM_PRETTY_FUNCTION); 110e6e2bb38SZachary Turner ObjectContainerBSDArchive::Terminate(); 111e6e2bb38SZachary Turner 112d8c338d4STamas Berghammer EmulateInstructionARM::Terminate(); 113794a4d5aSBhushan D. Attarde EmulateInstructionMIPS::Terminate(); 114cdc22a88SMohit K. Bhakkad EmulateInstructionMIPS64::Terminate(); 115d8c338d4STamas Berghammer 116f1763537SPavel Labath ObjectContainerUniversalMachO::Terminate(); 117e6e2bb38SZachary Turner 11823a4df27SHafiz Abid Qadeer #if defined(_MSC_VER) 119610e5291SZachary Turner ProcessWindowsLog::Terminate(); 120610e5291SZachary Turner #endif 121610e5291SZachary Turner 12241331afaSZachary Turner HostInfo::Terminate(); 123775588c0SPavel Labath Log::DisableAllLogChannels(); 12446376966SJonas Devlieghere FileSystem::Terminate(); 12515eacd74SJonas Devlieghere Reproducer::Terminate(); 126e6e2bb38SZachary Turner } 127