From 6737135b14fcf9c8e2acb9c29b7aa5b64df9ef51 Mon Sep 17 00:00:00 2001 From: Alex Menkov Date: Fri, 19 Mar 2021 20:13:05 +0000 Subject: [PATCH] 8262083: vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001/TestDescription.java failed with "No notification: event JVMTI_EVENT_FRAME_POP (61)" Reviewed-by: lmesnik, cjplummer --- .../SetEventNotificationMode/setnotif001.java | 6 +-- .../setnotif001/setnotif001.cpp | 38 ++++++++++--------- 2 files changed, 24 insertions(+), 20 deletions(-) diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001.java b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001.java index 5cfb4207cb7..a3aed031ff7 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001.java +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -40,7 +40,7 @@ public class setnotif001 { } } - native static void enableEv(); + native static void enableEv(Thread notifyFramePopThread); native static int getRes(); static int fld = 1; @@ -55,7 +55,7 @@ public class setnotif001 { public static int run(String argv[], PrintStream ref) { setnotif001 t = new setnotif001(); fld++; - enableEv(); + enableEv(Thread.currentThread()); t.meth(); Thread thr = new Thread(new setnotif001a()); thr.start(); diff --git a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001/setnotif001.cpp b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001/setnotif001.cpp index a6cfb430097..135f51a86f9 100644 --- a/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001/setnotif001.cpp +++ b/test/hotspot/jtreg/vmTestbase/nsk/jvmti/SetEventNotificationMode/setnotif001/setnotif001.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -38,6 +38,7 @@ static jvmtiEnv *jvmti = NULL; static jvmtiCapabilities caps; static jvmtiEventCallbacks callbacks; static jrawMonitorID access_lock; +static jobject notifyFramePopThread = NULL; static jint result = PASSED; static jboolean printdump = JNI_FALSE; static int flag = 0; @@ -188,25 +189,27 @@ void JNICALL MethodEntry(jvmtiEnv *jvmti_env, JNIEnv *env, if (flag) { mark(jvmti_env, JVMTI_EVENT_METHOD_ENTRY); - err = jvmti_env->IsMethodNative(method, &isNative); - if (err != JVMTI_ERROR_NONE) { - result = STATUS_FAILED; - printf("(IsMethodNative) unexpected error: %s (%d)\n", - TranslateError(err), err); - } - if (isNative == JNI_FALSE) { - err = jvmti_env->NotifyFramePop(thr, 0); - if (err == JVMTI_ERROR_NONE) { - enable(jvmti_env, JVMTI_EVENT_FRAME_POP); - } else { + if (env->IsSameObject(notifyFramePopThread, thr)) { + err = jvmti_env->IsMethodNative(method, &isNative); + if (err != JVMTI_ERROR_NONE) { result = STATUS_FAILED; - printf("(NotifyFramePop) unexpected error: %s (%d)\n", + printf("(IsMethodNative) unexpected error: %s (%d)\n", TranslateError(err), err); } + if (isNative == JNI_FALSE) { + err = jvmti_env->NotifyFramePop(thr, 0); + if (err == JVMTI_ERROR_NONE) { + enable(jvmti_env, JVMTI_EVENT_FRAME_POP); + } else { + result = STATUS_FAILED; + printf("(NotifyFramePop) unexpected error: %s (%d)\n", + TranslateError(err), err); + } + } + enable(jvmti_env, JVMTI_EVENT_CLASS_LOAD); + enable(jvmti_env, JVMTI_EVENT_CLASS_PREPARE); + disable(jvmti_env, JVMTI_EVENT_METHOD_ENTRY); } - enable(jvmti_env, JVMTI_EVENT_CLASS_LOAD); - enable(jvmti_env, JVMTI_EVENT_CLASS_PREPARE); - disable(jvmti_env, JVMTI_EVENT_METHOD_ENTRY); } } @@ -392,8 +395,9 @@ jint Agent_Initialize(JavaVM *jvm, char *options, void *reserved) { JNIEXPORT void JNICALL Java_nsk_jvmti_SetEventNotificationMode_setnotif001_enableEv(JNIEnv *env, - jclass cls) { + jclass cls, jobject framePopThread) { setWatches(jvmti, env, cls); + notifyFramePopThread = env->NewGlobalRef(framePopThread); enable(jvmti, JVMTI_EVENT_METHOD_ENTRY); enable(jvmti, JVMTI_EVENT_METHOD_EXIT); enable(jvmti, JVMTI_EVENT_THREAD_START);