From a25ce80e782a73390ae1109250dfa6fe6a48fcbe Mon Sep 17 00:00:00 2001 From: Poonam Bajaj Date: Wed, 14 Oct 2015 15:36:41 -0700 Subject: [PATCH] 8136577: Make AbortVMOnException available in product builds Reviewed-by: coleenp --- hotspot/src/share/vm/c1/c1_Runtime1.cpp | 2 +- .../vm/interpreter/bytecodeInterpreter.cpp | 5 ++-- .../vm/interpreter/interpreterRuntime.cpp | 2 +- hotspot/src/share/vm/opto/runtime.cpp | 2 +- hotspot/src/share/vm/runtime/globals.hpp | 4 +-- .../src/share/vm/runtime/sharedRuntime.cpp | 3 +- hotspot/src/share/vm/runtime/thread.cpp | 2 +- hotspot/src/share/vm/utilities/exceptions.cpp | 28 ++++++++++--------- hotspot/src/share/vm/utilities/exceptions.hpp | 5 ++-- 9 files changed, 29 insertions(+), 24 deletions(-) diff --git a/hotspot/src/share/vm/c1/c1_Runtime1.cpp b/hotspot/src/share/vm/c1/c1_Runtime1.cpp index 50fc0c47f46..74c9ce73117 100644 --- a/hotspot/src/share/vm/c1/c1_Runtime1.cpp +++ b/hotspot/src/share/vm/c1/c1_Runtime1.cpp @@ -553,7 +553,7 @@ JRT_ENTRY_NO_ASYNC(static address, exception_handler_for_pc_helper(JavaThread* t exception->print_value_string(), p2i((address)exception()), nm->method()->print_value_string(), p2i(pc), p2i(thread)); } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(exception)); + Exceptions::debug_check_abort(exception); // Clear out the exception oop and pc since looking up an // exception handler can cause class loading, which might throw an diff --git a/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp b/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp index 568ebe0ce54..a9252c2bfa7 100644 --- a/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp +++ b/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp @@ -2791,7 +2791,7 @@ run: (int)continuation_bci, p2i(THREAD)); } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(except_oop)); + Exceptions::debug_check_abort(except_oop); // Update profiling data. BI_PROFILE_ALIGN_TO_CURRENT_BCI(); @@ -2807,7 +2807,8 @@ run: p2i(THREAD)); } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(except_oop)); + Exceptions::debug_check_abort(except_oop); + // No handler in this activation, unwind and try again THREAD->set_pending_exception(except_oop(), NULL, 0); goto handle_return; diff --git a/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp b/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp index 6ffb85aa1f5..d12b845af25 100644 --- a/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp +++ b/hotspot/src/share/vm/interpreter/interpreterRuntime.cpp @@ -458,7 +458,7 @@ IRT_ENTRY(address, InterpreterRuntime::exception_handler_for_exception(JavaThrea // // warning("performance bug: should not call runtime if method has no exception handlers"); // } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(h_exception)); + Exceptions::debug_check_abort(h_exception); // exception handler lookup KlassHandle h_klass(THREAD, h_exception->klass()); diff --git a/hotspot/src/share/vm/opto/runtime.cpp b/hotspot/src/share/vm/opto/runtime.cpp index 9bcc730ed9b..d9e253a43e0 100644 --- a/hotspot/src/share/vm/opto/runtime.cpp +++ b/hotspot/src/share/vm/opto/runtime.cpp @@ -1235,7 +1235,7 @@ JRT_ENTRY_NO_ASYNC(address, OptoRuntime::handle_exception_C_helper(JavaThread* t } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(exception)); + Exceptions::debug_check_abort(exception); #ifdef ASSERT if (!(exception->is_a(SystemDictionary::Throwable_klass()))) { diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index 89fca893ef5..8891eff7ecb 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -2807,11 +2807,11 @@ public: "standard exit from VM if bytecode verify error " \ "(only in debug mode)") \ \ - notproduct(ccstr, AbortVMOnException, NULL, \ + diagnostic(ccstr, AbortVMOnException, NULL, \ "Call fatal if this exception is thrown. Example: " \ "java -XX:AbortVMOnException=java.lang.NullPointerException Foo") \ \ - notproduct(ccstr, AbortVMOnExceptionMessage, NULL, \ + diagnostic(ccstr, AbortVMOnExceptionMessage, NULL, \ "Call fatal if the exception pointed by AbortVMOnException " \ "has this message") \ \ diff --git a/hotspot/src/share/vm/runtime/sharedRuntime.cpp b/hotspot/src/share/vm/runtime/sharedRuntime.cpp index 6fd37b02110..02d8eb3d590 100644 --- a/hotspot/src/share/vm/runtime/sharedRuntime.cpp +++ b/hotspot/src/share/vm/runtime/sharedRuntime.cpp @@ -861,7 +861,8 @@ address SharedRuntime::continuation_for_implicit_exception(JavaThread* thread, assert(exception_kind == IMPLICIT_NULL || exception_kind == IMPLICIT_DIVIDE_BY_ZERO, "wrong implicit exception kind"); // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort("java.lang.NullPointerException")); + Exceptions::debug_check_abort("java.lang.NullPointerException"); + if (exception_kind == IMPLICIT_NULL) { Events::log_exception(thread, "Implicit null exception at " INTPTR_FORMAT " to " INTPTR_FORMAT, p2i(pc), p2i(target_pc)); } else { diff --git a/hotspot/src/share/vm/runtime/thread.cpp b/hotspot/src/share/vm/runtime/thread.cpp index b91ede05879..e7b12c6a7ae 100644 --- a/hotspot/src/share/vm/runtime/thread.cpp +++ b/hotspot/src/share/vm/runtime/thread.cpp @@ -2166,7 +2166,7 @@ void JavaThread::send_thread_stop(oop java_throwable) { tty->print_cr("Pending Async. exception installed of type: %s", InstanceKlass::cast(_pending_async_exception->klass())->external_name()); } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(InstanceKlass::cast(_pending_async_exception->klass())->external_name())); + Exceptions::debug_check_abort(InstanceKlass::cast(_pending_async_exception->klass())->external_name()); } } diff --git a/hotspot/src/share/vm/utilities/exceptions.cpp b/hotspot/src/share/vm/utilities/exceptions.cpp index 7e07030e34c..d6e5823b360 100644 --- a/hotspot/src/share/vm/utilities/exceptions.cpp +++ b/hotspot/src/share/vm/utilities/exceptions.cpp @@ -145,7 +145,7 @@ void Exceptions::_throw(Thread* thread, const char* file, int line, Handle h_exc p2i(h_exception()), file, line, p2i(thread)); } // for AbortVMOnException flag - NOT_PRODUCT(Exceptions::debug_check_abort(h_exception, message)); + Exceptions::debug_check_abort(h_exception, message); // Check for special boot-strapping/vm-thread handling if (special_exception(thread, file, line, h_exception)) { @@ -477,13 +477,12 @@ ExceptionMark::~ExceptionMark() { // ---------------------------------------------------------------------------------------- -#ifndef PRODUCT // caller frees value_string if necessary void Exceptions::debug_check_abort(const char *value_string, const char* message) { if (AbortVMOnException != NULL && value_string != NULL && strstr(value_string, AbortVMOnException)) { - if (AbortVMOnExceptionMessage == NULL || message == NULL || - strcmp(message, AbortVMOnExceptionMessage) == 0) { + if (AbortVMOnExceptionMessage == NULL || (message != NULL && + strstr(message, AbortVMOnExceptionMessage))) { fatal("Saw %s, aborting", value_string); } } @@ -491,14 +490,17 @@ void Exceptions::debug_check_abort(const char *value_string, const char* message void Exceptions::debug_check_abort(Handle exception, const char* message) { if (AbortVMOnException != NULL) { - ResourceMark rm; - if (message == NULL && exception->is_a(SystemDictionary::Throwable_klass())) { - oop msg = java_lang_Throwable::message(exception); - if (msg != NULL) { - message = java_lang_String::as_utf8_string(msg); - } - } - debug_check_abort(InstanceKlass::cast(exception()->klass())->external_name(), message); + debug_check_abort_helper(exception, message); } } -#endif + +void Exceptions::debug_check_abort_helper(Handle exception, const char* message) { + ResourceMark rm; + if (message == NULL && exception->is_a(SystemDictionary::Throwable_klass())) { + oop msg = java_lang_Throwable::message(exception); + if (msg != NULL) { + message = java_lang_String::as_utf8_string(msg); + } + } + debug_check_abort(InstanceKlass::cast(exception()->klass())->external_name(), message); +} diff --git a/hotspot/src/share/vm/utilities/exceptions.hpp b/hotspot/src/share/vm/utilities/exceptions.hpp index 79c87c57d04..6575090f1f4 100644 --- a/hotspot/src/share/vm/utilities/exceptions.hpp +++ b/hotspot/src/share/vm/utilities/exceptions.hpp @@ -174,8 +174,9 @@ class Exceptions { static void print_exception_counts_on_error(outputStream* st); // for AbortVMOnException flag - NOT_PRODUCT(static void debug_check_abort(Handle exception, const char* message = NULL);) - NOT_PRODUCT(static void debug_check_abort(const char *value_string, const char* message = NULL);) + static void debug_check_abort(Handle exception, const char* message = NULL); + static void debug_check_abort_helper(Handle exception, const char* message = NULL); + static void debug_check_abort(const char *value_string, const char* message = NULL); };