Skip to content

Commit

Permalink
[Support] Move the static initializer install_out_memory_new_handler …
Browse files Browse the repository at this point in the history
…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
  • Loading branch information
MaskRay committed Jul 12, 2019
1 parent f72fd0f commit e99dee8
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 18 deletions.
5 changes: 4 additions & 1 deletion llvm/include/llvm/Support/InitLLVM.h
Original file line number Diff line number Diff line change
Expand Up @@ -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.
Expand Down
22 changes: 5 additions & 17 deletions llvm/lib/Support/ErrorHandling.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down
1 change: 1 addition & 0 deletions llvm/lib/Support/InitLLVM.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down

0 comments on commit e99dee8

Please sign in to comment.