1e6e2bb38SZachary Turner //===-- SystemInitializerCommon.cpp -----------------------------*- C++ -*-===// 2e6e2bb38SZachary Turner // 32946cd70SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 42946cd70SChandler Carruth // See https://llvm.org/LICENSE.txt for license information. 52946cd70SChandler 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/Process/gdb-remote/ProcessGDBRemoteLog.h" 1546376966SJonas Devlieghere #include "lldb/Host/FileSystem.h" 16b9c1b51eSKate Stone #include "lldb/Host/Host.h" 17b9c1b51eSKate Stone #include "lldb/Host/HostInfo.h" 18f8a74c18SAaron Smith #include "lldb/Host/Socket.h" 196f9e6901SZachary Turner #include "lldb/Utility/Log.h" 2015eacd74SJonas Devlieghere #include "lldb/Utility/Reproducer.h" 2138d0632eSPavel Labath #include "lldb/Utility/Timer.h" 22e6e2bb38SZachary Turner 23a87101d6SKamil Rytarowski #if defined(__linux__) || defined(__FreeBSD__) || defined(__NetBSD__) 24e6e2bb38SZachary Turner #include "Plugins/Process/POSIX/ProcessPOSIXLog.h" 25e6e2bb38SZachary Turner #endif 26e6e2bb38SZachary Turner 27*d179ce99SSaleem Abdulrasool #if defined(_WIN32) 2818a9135dSAdrian McCarthy #include "Plugins/Process/Windows/Common/ProcessWindowsLog.h" 2974e08ca0SZachary Turner #include "lldb/Host/windows/windows.h" 30e6e2bb38SZachary Turner #endif 31e6e2bb38SZachary Turner 32e6e2bb38SZachary Turner #include "llvm/Support/TargetSelect.h" 33e6e2bb38SZachary Turner 34e6e2bb38SZachary Turner #include <string> 35e6e2bb38SZachary Turner 36e6e2bb38SZachary Turner using namespace lldb_private; 3715eacd74SJonas Devlieghere using namespace lldb_private::repro; 38e6e2bb38SZachary Turner 39b9c1b51eSKate Stone SystemInitializerCommon::SystemInitializerCommon() {} 40e6e2bb38SZachary Turner 41b9c1b51eSKate Stone SystemInitializerCommon::~SystemInitializerCommon() {} 42e6e2bb38SZachary Turner 43936c6242SJonas Devlieghere llvm::Error SystemInitializerCommon::Initialize() { 44*d179ce99SSaleem Abdulrasool #if defined(_WIN32) 45e6e2bb38SZachary Turner const char *disable_crash_dialog_var = getenv("LLDB_DISABLE_CRASH_DIALOG"); 46b9c1b51eSKate Stone if (disable_crash_dialog_var && 47b9c1b51eSKate Stone llvm::StringRef(disable_crash_dialog_var).equals_lower("true")) { 48b9c1b51eSKate Stone // This will prevent Windows from displaying a dialog box requiring user 49b9c1b51eSKate Stone // interaction when 50b9c1b51eSKate Stone // LLDB crashes. This is mostly useful when automating LLDB, for example 51b9c1b51eSKate Stone // via the test 52b9c1b51eSKate Stone // suite, so that a crash in LLDB does not prevent completion of the test 53b9c1b51eSKate Stone // suite. 54b9c1b51eSKate Stone ::SetErrorMode(GetErrorMode() | SEM_FAILCRITICALERRORS | 55b9c1b51eSKate Stone SEM_NOGPFAULTERRORBOX); 56e6e2bb38SZachary Turner 57e6e2bb38SZachary Turner _CrtSetReportMode(_CRT_ASSERT, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG); 58e6e2bb38SZachary Turner _CrtSetReportMode(_CRT_WARN, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG); 59e6e2bb38SZachary Turner _CrtSetReportMode(_CRT_ERROR, _CRTDBG_MODE_FILE | _CRTDBG_MODE_DEBUG); 60e6e2bb38SZachary Turner _CrtSetReportFile(_CRT_ASSERT, _CRTDBG_FILE_STDERR); 61e6e2bb38SZachary Turner _CrtSetReportFile(_CRT_WARN, _CRTDBG_FILE_STDERR); 62e6e2bb38SZachary Turner _CrtSetReportFile(_CRT_ERROR, _CRTDBG_FILE_STDERR); 63e6e2bb38SZachary Turner } 64e6e2bb38SZachary Turner #endif 65e6e2bb38SZachary Turner 66936c6242SJonas Devlieghere // If the reproducer wasn't initialized before, we can safely assume it's 67936c6242SJonas Devlieghere // off. 68936c6242SJonas Devlieghere if (!Reproducer::Initialized()) { 69936c6242SJonas Devlieghere if (auto e = Reproducer::Initialize(ReproducerMode::Off, llvm::None)) 7015eacd74SJonas Devlieghere return e; 71936c6242SJonas Devlieghere } 7215eacd74SJonas Devlieghere 7346575176SJonas Devlieghere // Initialize the file system. 7446575176SJonas Devlieghere auto &r = repro::Reproducer::Instance(); 7546575176SJonas Devlieghere if (repro::Loader *loader = r.GetLoader()) { 7646575176SJonas Devlieghere FileSpec vfs_mapping = loader->GetFile<FileInfo>(); 7746575176SJonas Devlieghere if (vfs_mapping) { 7846575176SJonas Devlieghere if (llvm::Error e = FileSystem::Initialize(vfs_mapping)) 7946575176SJonas Devlieghere return e; 8046575176SJonas Devlieghere } else { 8146376966SJonas Devlieghere FileSystem::Initialize(); 8246575176SJonas Devlieghere } 8346575176SJonas Devlieghere } else if (repro::Generator *g = r.GetGenerator()) { 8446575176SJonas Devlieghere repro::FileProvider &fp = g->GetOrCreate<repro::FileProvider>(); 8546575176SJonas Devlieghere FileSystem::Initialize(fp.GetFileCollector()); 8646575176SJonas Devlieghere } else { 8746575176SJonas Devlieghere FileSystem::Initialize(); 8846575176SJonas Devlieghere } 8946575176SJonas Devlieghere 90d813309eSPavel Labath Log::Initialize(); 91e6e2bb38SZachary Turner HostInfo::Initialize(); 92f8a74c18SAaron Smith 93f8a74c18SAaron Smith llvm::Error error = Socket::Initialize(); 94f8a74c18SAaron Smith if (error) 95f8a74c18SAaron Smith return error; 96f8a74c18SAaron Smith 97f9d16476SPavel Labath static Timer::Category func_cat(LLVM_PRETTY_FUNCTION); 98f9d16476SPavel Labath Timer scoped_timer(func_cat, LLVM_PRETTY_FUNCTION); 99e6e2bb38SZachary Turner 100e6e2bb38SZachary Turner process_gdb_remote::ProcessGDBRemoteLog::Initialize(); 101e6e2bb38SZachary Turner 102d8c338d4STamas Berghammer EmulateInstructionARM::Initialize(); 103794a4d5aSBhushan D. Attarde EmulateInstructionMIPS::Initialize(); 104cdc22a88SMohit K. Bhakkad EmulateInstructionMIPS64::Initialize(); 105d8c338d4STamas Berghammer 106a87101d6SKamil Rytarowski #if defined(__linux__) || defined(__FreeBSD__) || defined(__NetBSD__) 107c29f7ff3SPavel Labath ProcessPOSIXLog::Initialize(); 108e6e2bb38SZachary Turner #endif 109*d179ce99SSaleem Abdulrasool #if defined(_WIN32) 11042b33806SAdrian McCarthy ProcessWindowsLog::Initialize(); 11142b33806SAdrian McCarthy #endif 11215eacd74SJonas Devlieghere 11315eacd74SJonas Devlieghere return llvm::Error::success(); 114e6e2bb38SZachary Turner } 115e6e2bb38SZachary Turner 116b9c1b51eSKate Stone void SystemInitializerCommon::Terminate() { 117f9d16476SPavel Labath static Timer::Category func_cat(LLVM_PRETTY_FUNCTION); 118f9d16476SPavel Labath Timer scoped_timer(func_cat, LLVM_PRETTY_FUNCTION); 119e6e2bb38SZachary Turner 120d8c338d4STamas Berghammer EmulateInstructionARM::Terminate(); 121794a4d5aSBhushan D. Attarde EmulateInstructionMIPS::Terminate(); 122cdc22a88SMohit K. Bhakkad EmulateInstructionMIPS64::Terminate(); 123d8c338d4STamas Berghammer 124*d179ce99SSaleem Abdulrasool #if defined(_WIN32) 125610e5291SZachary Turner ProcessWindowsLog::Terminate(); 126610e5291SZachary Turner #endif 127610e5291SZachary Turner 128f8a74c18SAaron Smith Socket::Terminate(); 12941331afaSZachary Turner HostInfo::Terminate(); 130775588c0SPavel Labath Log::DisableAllLogChannels(); 13146376966SJonas Devlieghere FileSystem::Terminate(); 13215eacd74SJonas Devlieghere Reproducer::Terminate(); 133e6e2bb38SZachary Turner } 134