2017-08-31 10:00:28 +02:00
|
|
|
/*
|
2020-04-01 14:54:44 +02:00
|
|
|
* Copyright (c) 2017, 2020, Oracle and/or its affiliates. All rights reserved.
|
2017-08-31 10:00:28 +02:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-01-10 15:13:51 -05:00
|
|
|
#ifndef SHARE_RUNTIME_SAFEPOINTMECHANISM_INLINE_HPP
|
|
|
|
#define SHARE_RUNTIME_SAFEPOINTMECHANISM_INLINE_HPP
|
2017-08-31 10:00:28 +02:00
|
|
|
|
2020-10-09 08:40:33 +00:00
|
|
|
#include "runtime/atomic.hpp"
|
2017-08-31 10:00:28 +02:00
|
|
|
#include "runtime/safepointMechanism.hpp"
|
|
|
|
#include "runtime/safepoint.hpp"
|
|
|
|
#include "runtime/thread.inline.hpp"
|
|
|
|
|
2020-10-09 08:40:33 +00:00
|
|
|
// Caller is responsible for using a memory barrier if needed.
|
|
|
|
inline void SafepointMechanism::ThreadData::set_polling_page(uintptr_t poll_value) {
|
|
|
|
Atomic::store(&_polling_page, poll_value);
|
|
|
|
}
|
|
|
|
|
|
|
|
// The acquire makes sure reading of polling page is done before
|
|
|
|
// the reading the handshake operation or the global state
|
|
|
|
inline uintptr_t SafepointMechanism::ThreadData::get_polling_page() {
|
|
|
|
return Atomic::load_acquire(&_polling_page);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Caller is responsible for using a memory barrier if needed.
|
|
|
|
inline void SafepointMechanism::ThreadData::set_polling_word(uintptr_t poll_value) {
|
|
|
|
Atomic::store(&_polling_word, poll_value);
|
|
|
|
}
|
|
|
|
|
|
|
|
// The acquire makes sure reading of polling page is done before
|
|
|
|
// the reading the handshake operation or the global state
|
|
|
|
inline uintptr_t SafepointMechanism::ThreadData::get_polling_word() {
|
|
|
|
return Atomic::load_acquire(&_polling_word);
|
|
|
|
}
|
|
|
|
|
2017-08-31 10:00:28 +02:00
|
|
|
bool SafepointMechanism::local_poll_armed(JavaThread* thread) {
|
2020-10-09 08:40:33 +00:00
|
|
|
return thread->poll_data()->get_polling_word() & poll_bit();
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool SafepointMechanism::global_poll() {
|
2019-02-15 14:15:10 +01:00
|
|
|
return (SafepointSynchronize::_state != SafepointSynchronize::_not_synchronized);
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bool SafepointMechanism::local_poll(Thread* thread) {
|
|
|
|
if (thread->is_Java_thread()) {
|
2020-09-11 01:31:32 +00:00
|
|
|
return local_poll_armed(thread->as_Java_thread());
|
2017-08-31 10:00:28 +02:00
|
|
|
} else {
|
|
|
|
// If the poll is on a non-java thread we can only check the global state.
|
|
|
|
return global_poll();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-07 13:59:24 +00:00
|
|
|
bool SafepointMechanism::should_process(Thread* thread) {
|
2020-04-01 14:54:44 +02:00
|
|
|
return local_poll(thread);
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
|
|
|
|
2020-09-07 13:59:24 +00:00
|
|
|
void SafepointMechanism::process_if_requested(JavaThread *thread) {
|
2020-04-01 14:54:44 +02:00
|
|
|
if (!local_poll_armed(thread)) {
|
2019-02-04 21:42:47 +01:00
|
|
|
return;
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
2020-09-07 13:59:24 +00:00
|
|
|
process_if_requested_slow(thread);
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void SafepointMechanism::arm_local_poll(JavaThread* thread) {
|
2020-10-09 08:40:33 +00:00
|
|
|
thread->poll_data()->set_polling_word(_poll_word_armed_value);
|
|
|
|
thread->poll_data()->set_polling_page(_poll_page_armed_value);
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void SafepointMechanism::disarm_local_poll(JavaThread* thread) {
|
2020-10-09 08:40:33 +00:00
|
|
|
thread->poll_data()->set_polling_word(_poll_word_disarmed_value);
|
|
|
|
thread->poll_data()->set_polling_page(_poll_page_disarmed_value);
|
2017-08-31 10:00:28 +02:00
|
|
|
}
|
|
|
|
|
2018-07-02 11:46:15 +02:00
|
|
|
void SafepointMechanism::arm_local_poll_release(JavaThread* thread) {
|
2020-10-09 08:40:33 +00:00
|
|
|
OrderAccess::release();
|
|
|
|
thread->poll_data()->set_polling_word(_poll_word_armed_value);
|
|
|
|
thread->poll_data()->set_polling_page(_poll_page_armed_value);
|
2018-07-02 11:46:15 +02:00
|
|
|
}
|
|
|
|
|
2019-01-10 15:13:51 -05:00
|
|
|
#endif // SHARE_RUNTIME_SAFEPOINTMECHANISM_INLINE_HPP
|