diff -r 23348e42fb34 -r af8578e25d17 src/hotspot/share/runtime/safepoint.hpp --- a/src/hotspot/share/runtime/safepoint.hpp Mon Feb 26 10:20:06 2018 -0500 +++ b/src/hotspot/share/runtime/safepoint.hpp Mon Feb 26 11:28:05 2018 -0500 @@ -94,7 +94,6 @@ int _nof_total_threads; // total number of Java threads int _nof_initial_running_threads; // total number of initially seen running threads int _nof_threads_wait_to_block; // total number of threads waiting for to block - bool _page_armed; // true if polling page is armed, false otherwise int _nof_threads_hit_page_trap; // total number of threads hitting the page trap jlong _time_to_spin; // total time in millis spent in spinning jlong _time_to_wait_to_block; // total time in millis spent in waiting for to block @@ -107,6 +106,7 @@ static volatile SynchronizeState _state; // Threads might read this flag directly, without acquiring the Threads_lock static volatile int _waiting_to_block; // number of threads we are waiting for to block static int _current_jni_active_count; // Counts the number of active critical natives during the safepoint + static int _defer_thr_suspend_loop_count; // Iterations before blocking VM threads // This counter is used for fast versions of jni_GetField. // An even value means there is no ongoing safepoint operations. @@ -202,6 +202,11 @@ static address address_of_state() { return (address)&_state; } static address safepoint_counter_addr() { return (address)&_safepoint_counter; } + + // This method is only used for -Xconcurrentio support. + static void set_defer_thr_suspend_loop_count() { + _defer_thr_suspend_loop_count = 1; + } }; // State class for a thread suspended at a safepoint