提交 491540d9 编写于 作者: S sspitsyn

8028126: nsk/jvmti/scenarios/hotswap/HS101/hs101t006 Crashed the vm on...

8028126: nsk/jvmti/scenarios/hotswap/HS101/hs101t006 Crashed the vm on Solaris-sparc64 fastdebug builds: only current thread can flush its registers
Summary: Fix a race between VMOp_GetCurrentLocation reaching a safepoint and arget thread exiting from Java execution
Reviewed-by: sla, dholmes, dsamersoff
Contributed-by: serguei.spitsyn@oracle.com
上级 7e476f9e
...@@ -269,11 +269,20 @@ class VM_GetCurrentLocation : public VM_Operation { ...@@ -269,11 +269,20 @@ class VM_GetCurrentLocation : public VM_Operation {
void doit() { void doit() {
ResourceMark rmark; // _thread != Thread::current() ResourceMark rmark; // _thread != Thread::current()
RegisterMap rm(_thread, false); RegisterMap rm(_thread, false);
// There can be a race condition between a VM_Operation reaching a safepoint
// and the target thread exiting from Java execution.
// We must recheck the last Java frame still exists.
if (_thread->has_last_Java_frame()) {
javaVFrame* vf = _thread->last_java_vframe(&rm); javaVFrame* vf = _thread->last_java_vframe(&rm);
assert(vf != NULL, "must have last java frame"); assert(vf != NULL, "must have last java frame");
Method* method = vf->method(); Method* method = vf->method();
_method_id = method->jmethod_id(); _method_id = method->jmethod_id();
_bci = vf->bci(); _bci = vf->bci();
} else {
// Clear current location as the target thread has no Java frames anymore.
_method_id = (jmethodID)NULL;
_bci = 0;
}
} }
void get_current_location(jmethodID *method_id, int *bci) { void get_current_location(jmethodID *method_id, int *bci) {
*method_id = _method_id; *method_id = _method_id;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册