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