mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 18:54:02 +01:00
[Support] Move the static initializer install_out_memory_new_handler to InitLLVM
An application linking against LLVMSupport should not get the gratuitous set::std_new_handler call. Reviewed By: jfb Differential Revision: https://reviews.llvm.org/D64505 llvm-svn: 365915
This commit is contained in:
parent
ff5c1896b1
commit
9aeee7bc57
@ -19,7 +19,10 @@
|
||||
// 1. Setting up a signal handler so that pretty stack trace is printed out
|
||||
// if a process crashes.
|
||||
//
|
||||
// 2. If running on Windows, obtain command line arguments using a
|
||||
// 2. Set up the global new-handler which is called when a memory allocation
|
||||
// attempt fails.
|
||||
//
|
||||
// 3. If running on Windows, obtain command line arguments using a
|
||||
// multibyte character-aware API and convert arguments into UTF-8
|
||||
// encoding, so that you can assume that command line arguments are
|
||||
// always encoded in UTF-8 on any platform.
|
||||
|
@ -186,25 +186,13 @@ static void out_of_memory_new_handler() {
|
||||
llvm::report_bad_alloc_error("Allocation failed");
|
||||
}
|
||||
|
||||
// Installs new handler that causes crash on allocation failure. It does not
|
||||
// need to be called explicitly, if this file is linked to application, because
|
||||
// in this case it is called during construction of 'new_handler_installer'.
|
||||
// Installs new handler that causes crash on allocation failure. It is called by
|
||||
// InitLLVM.
|
||||
void llvm::install_out_of_memory_new_handler() {
|
||||
static bool out_of_memory_new_handler_installed = false;
|
||||
if (!out_of_memory_new_handler_installed) {
|
||||
std::set_new_handler(out_of_memory_new_handler);
|
||||
out_of_memory_new_handler_installed = true;
|
||||
}
|
||||
std::new_handler old = std::set_new_handler(out_of_memory_new_handler);
|
||||
(void)old;
|
||||
assert(old == nullptr && "new-handler already installed");
|
||||
}
|
||||
|
||||
// Static object that causes installation of 'out_of_memory_new_handler' before
|
||||
// execution of 'main'.
|
||||
static class NewHandlerInstaller {
|
||||
public:
|
||||
NewHandlerInstaller() {
|
||||
install_out_of_memory_new_handler();
|
||||
}
|
||||
} new_handler_installer;
|
||||
#endif
|
||||
|
||||
void llvm::llvm_unreachable_internal(const char *msg, const char *file,
|
||||
|
@ -23,6 +23,7 @@ using namespace llvm::sys;
|
||||
|
||||
InitLLVM::InitLLVM(int &Argc, const char **&Argv) : StackPrinter(Argc, Argv) {
|
||||
sys::PrintStackTraceOnErrorSignal(Argv[0]);
|
||||
install_out_of_memory_new_handler();
|
||||
|
||||
#ifdef _WIN32
|
||||
// We use UTF-8 as the internal character encoding. On Windows,
|
||||
|
Loading…
Reference in New Issue
Block a user