LLVM 20.0.0git
InitLLVM.cpp
Go to the documentation of this file.
1//===-- InitLLVM.cpp -----------------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
10#include "llvm/ADT/StringRef.h"
12#include "llvm/Support/Error.h"
16
17#ifdef _WIN32
19#endif
20
21#ifdef __MVS__
22#include <unistd.h>
23
24void CleanupStdHandles(void *Cookie) {
25 llvm::raw_ostream *Outs = &llvm::outs(), *Errs = &llvm::errs();
26 Outs->flush();
27 Errs->flush();
28 llvm::restorezOSStdHandleAutoConversion(STDIN_FILENO);
29 llvm::restorezOSStdHandleAutoConversion(STDOUT_FILENO);
30 llvm::restorezOSStdHandleAutoConversion(STDERR_FILENO);
31}
32#endif
33
34using namespace llvm;
35using namespace llvm::sys;
36
37InitLLVM::InitLLVM(int &Argc, const char **&Argv,
38 bool InstallPipeSignalExitHandler) {
39#ifndef NDEBUG
40 static std::atomic<bool> Initialized{false};
41 assert(!Initialized && "InitLLVM was already initialized!");
42 Initialized = true;
43#endif
44#ifdef __MVS__
45 // Bring stdin/stdout/stderr into a known state.
46 sys::AddSignalHandler(CleanupStdHandles, nullptr);
47#endif
48 if (InstallPipeSignalExitHandler)
49 // The pipe signal handler must be installed before any other handlers are
50 // registered. This is because the Unix \ref RegisterHandlers function does
51 // not perform a sigaction() for SIGPIPE unless a one-shot handler is
52 // present, to allow long-lived processes (like lldb) to fully opt-out of
53 // llvm's SIGPIPE handling and ignore the signal safely.
55 // Initialize the stack printer after installing the one-shot pipe signal
56 // handler, so we can perform a sigaction() for SIGPIPE on Unix if requested.
57 StackPrinter.emplace(Argc, Argv);
60
61#ifdef __MVS__
62
63 // We use UTF-8 as the internal character encoding. On z/OS, all external
64 // output is encoded in EBCDIC. In order to be able to read all
65 // error messages, we turn conversion to EBCDIC on for stderr fd.
66 std::string Banner = std::string(Argv[0]) + ": ";
67 ExitOnError ExitOnErr(Banner);
68
69 // If turning on conversion for stderr fails then the error message
70 // may be garbled. There is no solution to this problem.
71 ExitOnErr(errorCodeToError(llvm::enablezOSAutoConversion(STDERR_FILENO)));
72 ExitOnErr(errorCodeToError(llvm::enablezOSAutoConversion(STDOUT_FILENO)));
73#endif
74
75#ifdef _WIN32
76 // We use UTF-8 as the internal character encoding. On Windows,
77 // arguments passed to main() may not be encoded in UTF-8. In order
78 // to reliably detect encoding of command line arguments, we use an
79 // Windows API to obtain arguments, convert them to UTF-8, and then
80 // write them back to the Argv vector.
81 //
82 // There's probably other way to do the same thing (e.g. using
83 // wmain() instead of main()), but this way seems less intrusive
84 // than that.
85 std::string Banner = std::string(Argv[0]) + ": ";
86 ExitOnError ExitOnErr(Banner);
87
89
90 // GetCommandLineArguments doesn't terminate the vector with a
91 // nullptr. Do it to make it compatible with the real argv.
92 Args.push_back(nullptr);
93
94 Argc = Args.size() - 1;
95 Argv = Args.data();
96#endif
97}
98
100#ifdef __MVS__
101 CleanupStdHandles(nullptr);
102#endif
104}
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
Helper for check-and-exit error handling.
Definition: Error.h:1413
InitLLVM(int &Argc, const char **&Argv, bool InstallPipeSignalExitHandler=true)
Definition: InitLLVM.cpp:37
size_t size() const
Definition: SmallVector.h:78
void push_back(const T &Elt)
Definition: SmallVector.h:413
pointer data()
Return a pointer to the vector's buffer, even if empty().
Definition: SmallVector.h:286
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition: raw_ostream.h:52
std::error_code GetCommandLineArguments(SmallVectorImpl< const char * > &Args, BumpPtrAllocator &Alloc)
void SetOneShotPipeSignalFunction(void(*Handler)())
Registers a function to be called in a "one-shot" manner when a pipe signal is delivered to the proce...
void DefaultOneShotPipeSignalHandler()
On Unix systems and Windows, this function exits with an "IO error" exit code.
void AddSignalHandler(SignalHandlerCallback FnPtr, void *Cookie)
Add a function to be called when an abort/kill signal is delivered to the process.
void PrintStackTraceOnErrorSignal(StringRef Argv0, bool DisableCrashReporting=false)
When an error signal (such as SIGABRT or SIGSEGV) is delivered to the process, print a stack trace an...
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
raw_fd_ostream & outs()
This returns a reference to a raw_fd_ostream for standard output.
void install_out_of_memory_new_handler()
raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
void llvm_shutdown()
llvm_shutdown - Deallocate and destroy all ManagedStatic variables.
Error errorCodeToError(std::error_code EC)
Helper for converting an std::error_code to a Error.
Definition: Error.cpp:111