From 5ce7eb34e4eecfa29ab48af020218de70d477757 Mon Sep 17 00:00:00 2001 From: Aleksey Shipilev Date: Fri, 1 Feb 2019 16:03:16 +0100 Subject: [PATCH] 8218151: Simplify JavaThread::thread_state definition Reviewed-by: stefank, dholmes, kbarrett --- src/hotspot/share/runtime/thread.hpp | 7 ------- src/hotspot/share/runtime/thread.inline.hpp | 14 ++++++++++++-- 2 files changed, 12 insertions(+), 9 deletions(-) diff --git a/src/hotspot/share/runtime/thread.hpp b/src/hotspot/share/runtime/thread.hpp index 185236f6ece..86f26b25c7b 100644 --- a/src/hotspot/share/runtime/thread.hpp +++ b/src/hotspot/share/runtime/thread.hpp @@ -1280,15 +1280,8 @@ class JavaThread: public Thread { address last_Java_pc(void) { return _anchor.last_Java_pc(); } // Safepoint support -#if !(defined(PPC64) || defined(AARCH64)) - JavaThreadState thread_state() const { return _thread_state; } - void set_thread_state(JavaThreadState s) { _thread_state = s; } -#else - // Use membars when accessing volatile _thread_state. See - // Threads::create_vm() for size checks. inline JavaThreadState thread_state() const; inline void set_thread_state(JavaThreadState s); -#endif inline ThreadSafepointState* safepoint_state() const; inline void set_safepoint_state(ThreadSafepointState* state); inline bool is_at_poll_safepoint(); diff --git a/src/hotspot/share/runtime/thread.inline.hpp b/src/hotspot/share/runtime/thread.inline.hpp index 270447860bb..efb5c665267 100644 --- a/src/hotspot/share/runtime/thread.inline.hpp +++ b/src/hotspot/share/runtime/thread.inline.hpp @@ -121,15 +121,25 @@ inline void JavaThread::set_pending_async_exception(oop e) { set_has_async_exception(); } -#if defined(PPC64) || defined (AARCH64) inline JavaThreadState JavaThread::thread_state() const { +#if defined(PPC64) || defined (AARCH64) + // Use membars when accessing volatile _thread_state. See + // Threads::create_vm() for size checks. return (JavaThreadState) OrderAccess::load_acquire((volatile jint*)&_thread_state); +#else + return _thread_state; +#endif } inline void JavaThread::set_thread_state(JavaThreadState s) { +#if defined(PPC64) || defined (AARCH64) + // Use membars when accessing volatile _thread_state. See + // Threads::create_vm() for size checks. OrderAccess::release_store((volatile jint*)&_thread_state, (jint)s); -} +#else + _thread_state = s; #endif +} ThreadSafepointState* JavaThread::safepoint_state() const { return _safepoint_state;