src/hotspot/share/runtime/thread.cpp
changeset 54278 16999bd91ba6
parent 54259 d25b24c70126
child 54291 e6c86f6012bf
--- a/src/hotspot/share/runtime/thread.cpp	Tue Mar 26 07:09:10 2019 -0400
+++ b/src/hotspot/share/runtime/thread.cpp	Tue Mar 26 12:08:51 2019 +0100
@@ -2928,9 +2928,21 @@
   }
 }
 
+#ifdef ASSERT
+void JavaThread::verify_states_for_handshake() {
+  // This checks that the thread has a correct frame state during a handshake.
+  assert((!has_last_Java_frame() && java_call_counter() == 0) ||
+         (has_last_Java_frame() && java_call_counter() > 0),
+         "unexpected frame info: has_last_frame=%d, java_call_counter=%d",
+         has_last_Java_frame(), java_call_counter());
+}
+#endif
+
 void JavaThread::nmethods_do(CodeBlobClosure* cf) {
   assert((!has_last_Java_frame() && java_call_counter() == 0) ||
-         (has_last_Java_frame() && java_call_counter() > 0), "wrong java_sp info!");
+         (has_last_Java_frame() && java_call_counter() > 0),
+         "unexpected frame info: has_last_frame=%d, java_call_counter=%d",
+         has_last_Java_frame(), java_call_counter());
 
   if (has_last_Java_frame()) {
     // Traverse the execution stack