InterpreterRuntime 以外の Runtime クラス (e.g. SharedRuntime, Runtime1, OptoRuntime, SharkRuntime) において, その Runtime クラス外から呼び出される可能性がある関数 (= Runtime 外からの entry point になるもの) については, 呼び出し時に明示的に SafepointSynchronize::_state のチェックが行われる. この時点で Safepoint が開始されていた場合, そのスレッドはその場で停止する.
より具体的に言うと, 上記のような関数は定義時に以下のマクロを用いて定義されている.
これらのマクロが生成するコードから ThreadInVMfromJava のコンストラクタ/デストラクタが呼び出され, その中で SafepointSynchronize::_state の値を確認している.
非常に簡単な Runtime 関数用に, Safepoint チェックを行わない JRT_LEAF というマクロも用意されている.
また, 一部の Runtime 関数のために JRT_ENTRY_NO_ASYNC というマクロも用意されている. JRT_ENTRY マクロとの違いは, ThreadInVMfromJava ではなく ThreadInVMfromJavaNoAsyncException を用いる点 (これは, JavaThread::handle_special_runtime_exit_condition() 内での asynchronous exception 用の処理を省略した高速版).
また, 関数全体ではなく関数内の一部でだけ JavaThreadState を変化させたいという場合のために, JRT_BLOCK/JRT_BLOCK_END というマクロも用意されている.
(なお JRT_BLOCK を使う場合, それを含む関数自体は JRT_BLOCK_ENTRY マクロと JRT_END マクロを使って定義する. これらは, ただし, その必要が無ければ Deoptimization::fetch_unroll_info_helper() のように JRT_BLOCK() / JRT_BLOCK_END() だけで使ってもいい.)
JRT_ENTRY マクロ -> ThreadInVMfromJava::ThreadInVMfromJava() -> (See: here for details)
JRT_END マクロ (JRT_ENTRY マクロで宣言されていた ThreadInVMfromJava のデストラクタが呼ばれる) -> ThreadInVMfromJava::~ThreadInVMfromJava() -> (See: here for details)
(Safepoint チェック処理はない)
JRT_BLOCK マクロ -> ThreadInVMfromJava::ThreadInVMfromJava() -> (See: here for details)
JRT_BLOCK_END マクロ (JRT_BLOCK マクロで宣言されていた ThreadInVMfromJava のデストラクタが呼ばれる) -> ThreadInVMfromJava::~ThreadInVMfromJava() -> (See: here for details)
JRT_ENTRY_NO_ASYNC マクロ -> ThreadInVMfromJavaNoAsyncException::ThreadInVMfromJavaNoAsyncException() -> (See: here for details)
JRT_END マクロ (JRT_ENTRY_NO_ASYNC マクロで宣言されていた ThreadInVMfromJavaNoAsyncException のデストラクタが呼ばれる) -> ThreadInVMfromJavaNoAsyncException::~ThreadInVMfromJavaNoAsyncException() -> (See: here for details)
See: here for details
See: here for details
See: here for details
See: here for details
See: here for details
See: here for details
See: here for details
This document is available under the GNU GENERAL PUBLIC LICENSE Version 2.