From 8530ef0e4dda328d5b9856b03e29b764d06229fb Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Thu, 7 Jan 2021 17:13:41 +0000 Subject: [PATCH] 8259375: JvmtiExport::jni_Get/SetField_probe calls do not need ResetNoHandleMark Reviewed-by: lfoltan, dcubed --- src/hotspot/share/prims/jni.cpp | 8 +------- src/hotspot/share/prims/jvmtiExport.cpp | 14 +++----------- 2 files changed, 4 insertions(+), 18 deletions(-) diff --git a/src/hotspot/share/prims/jni.cpp b/src/hotspot/share/prims/jni.cpp index a87b9446dc1..82561c5a28d 100644 --- a/src/hotspot/share/prims/jni.cpp +++ b/src/hotspot/share/prims/jni.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2021, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012 Red Hat, Inc. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * @@ -1941,8 +1941,6 @@ JNI_ENTRY_NO_PRESERVE(Return, jni_Get##Result##Field(JNIEnv *env, jobject obj, j Klass* k = o->klass(); \ int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID); \ /* Keep JVMTI addition small and only check enabled flag here. */ \ - /* jni_GetField_probe_nh() assumes that is not okay to create handles */ \ - /* and creates a ResetNoHandleMark. */ \ if (JvmtiExport::should_post_field_access()) { \ o = JvmtiExport::jni_GetField_probe_nh(thread, obj, o, k, fieldID, false); \ } \ @@ -2008,8 +2006,6 @@ JNI_ENTRY_NO_PRESERVE(void, jni_SetObjectField(JNIEnv *env, jobject obj, jfieldI Klass* k = o->klass(); int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID); // Keep JVMTI addition small and only check enabled flag here. - // jni_SetField_probe_nh() assumes that is not okay to create handles - // and creates a ResetNoHandleMark. if (JvmtiExport::should_post_field_modification()) { jvalue field_value; field_value.l = value; @@ -2032,8 +2028,6 @@ JNI_ENTRY_NO_PRESERVE(void, jni_Set##Result##Field(JNIEnv *env, jobject obj, jfi Klass* k = o->klass(); \ int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID); \ /* Keep JVMTI addition small and only check enabled flag here. */ \ - /* jni_SetField_probe_nh() assumes that is not okay to create handles */ \ - /* and creates a ResetNoHandleMark. */ \ if (JvmtiExport::should_post_field_modification()) { \ jvalue field_value; \ field_value.unionType = value; \ diff --git a/src/hotspot/share/prims/jvmtiExport.cpp b/src/hotspot/share/prims/jvmtiExport.cpp index 14766c61468..73c07b876fd 100644 --- a/src/hotspot/share/prims/jvmtiExport.cpp +++ b/src/hotspot/share/prims/jvmtiExport.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 @@ -1886,11 +1886,7 @@ oop JvmtiExport::jni_GetField_probe(JavaThread *thread, jobject jobj, oop obj, oop JvmtiExport::jni_GetField_probe_nh(JavaThread *thread, jobject jobj, oop obj, Klass* klass, jfieldID fieldID, bool is_static) { if (*((int *)get_field_access_count_addr()) > 0 && thread->has_last_Java_frame()) { - // At least one field access watch is set so we have more work - // to do. This wrapper is used by "quick" entry points that don't - // allow us to create handles in post_field_access_by_jni(). We - // override that with a ResetNoHandleMark. - ResetNoHandleMark rnhm; + // At least one field access watch is set so we have more work to do. post_field_access_by_jni(thread, obj, klass, fieldID, is_static); // event posting can block so refetch oop if we were passed a jobj if (jobj != NULL) return JNIHandles::resolve_non_null(jobj); @@ -1981,11 +1977,7 @@ oop JvmtiExport::jni_SetField_probe_nh(JavaThread *thread, jobject jobj, oop obj Klass* klass, jfieldID fieldID, bool is_static, char sig_type, jvalue *value) { if (*((int *)get_field_modification_count_addr()) > 0 && thread->has_last_Java_frame()) { - // At least one field modification watch is set so we have more work - // to do. This wrapper is used by "quick" entry points that don't - // allow us to create handles in post_field_modification_by_jni(). We - // override that with a ResetNoHandleMark. - ResetNoHandleMark rnhm; + // At least one field modification watch is set so we have more work to do. post_field_modification_by_jni(thread, obj, klass, fieldID, is_static, sig_type, value); // event posting can block so refetch oop if we were passed a jobj if (jobj != NULL) return JNIHandles::resolve_non_null(jobj);