From def3b63b626e950eaa7a3ffba981cce95d169394 Mon Sep 17 00:00:00 2001 From: David Lindholm Date: Wed, 7 Oct 2015 15:27:02 +0200 Subject: [PATCH] 8138832: CreateCoredumpOnCrash on linux ARM causes assert message to be repeated Reviewed-by: jwilhelm, mgerdin --- hotspot/src/share/vm/utilities/vmError.cpp | 8 ++++---- hotspot/src/share/vm/utilities/vmError.hpp | 6 ++---- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/hotspot/src/share/vm/utilities/vmError.cpp b/hotspot/src/share/vm/utilities/vmError.cpp index 77b0ed6eb8a..6fa6b9b397d 100644 --- a/hotspot/src/share/vm/utilities/vmError.cpp +++ b/hotspot/src/share/vm/utilities/vmError.cpp @@ -796,7 +796,7 @@ void VMError::report(outputStream* st, bool _verbose) { # undef END } -volatile jlong VMError::first_error_tid = -1; +volatile intptr_t VMError::first_error_tid = -1; // An error could happen before tty is initialized or after it has been // destroyed. Here we use a very simple unbuffered fdStream for printing. @@ -925,9 +925,9 @@ void VMError::report_and_die(int id, const char* message, const char* detail_fmt if (SuppressFatalErrorMessage) { os::abort(CreateCoredumpOnCrash); } - jlong mytid = os::current_thread_id(); + intptr_t mytid = os::current_thread_id(); if (first_error_tid == -1 && - Atomic::cmpxchg(mytid, &first_error_tid, -1) == -1) { + Atomic::cmpxchg_ptr(mytid, &first_error_tid, -1) == -1) { _id = id; _message = message; @@ -968,7 +968,7 @@ void VMError::report_and_die(int id, const char* message, const char* detail_fmt if (first_error_tid != mytid) { char msgbuf[64]; jio_snprintf(msgbuf, sizeof(msgbuf), - "[thread " INT64_FORMAT " also had an error]", + "[thread " INTX_FORMAT " also had an error]", mytid); out.print_raw_cr(msgbuf); diff --git a/hotspot/src/share/vm/utilities/vmError.hpp b/hotspot/src/share/vm/utilities/vmError.hpp index 8f3213d3334..aa1d89ecea6 100644 --- a/hotspot/src/share/vm/utilities/vmError.hpp +++ b/hotspot/src/share/vm/utilities/vmError.hpp @@ -63,7 +63,7 @@ class VMError : public AllStatic { // Thread id of the first error. We must be able to handle native thread, // so use thread id instead of Thread* to identify thread. - static volatile jlong first_error_tid; + static volatile intptr_t first_error_tid; // Core dump status, false if we have been unable to write a core/minidump for some reason static bool coredump_status; @@ -141,9 +141,7 @@ public: // check to see if fatal error reporting is in progress static bool fatal_error_in_progress() { return first_error_tid != -1; } - static jlong get_first_error_tid() { - return first_error_tid; - } + static intptr_t get_first_error_tid() { return first_error_tid; } }; #endif // SHARE_VM_UTILITIES_VMERROR_HPP