< prev index next >
src/hotspot/share/prims/jvmtiRedefineClasses.cpp
Print this page
*** 143,154 ****
_res = JVMTI_ERROR_NULL_POINTER;
return false;
}
oop mirror = JNIHandles::resolve_non_null(_class_defs[i].klass);
! // classes for primitives and arrays and vm unsafe anonymous classes cannot be redefined
! // check here so following code can assume these classes are InstanceKlass
if (!is_modifiable_class(mirror)) {
_res = JVMTI_ERROR_UNMODIFIABLE_CLASS;
return false;
}
}
--- 143,155 ----
_res = JVMTI_ERROR_NULL_POINTER;
return false;
}
oop mirror = JNIHandles::resolve_non_null(_class_defs[i].klass);
! // classes for primitives, arrays, hidden and vm unsafe anonymous classes
! // cannot be redefined. Check here so following code can assume these classes
! // are InstanceKlass.
if (!is_modifiable_class(mirror)) {
_res = JVMTI_ERROR_UNMODIFIABLE_CLASS;
return false;
}
}
*** 286,297 ****
// classes for arrays cannot be redefined
if (k == NULL || !k->is_instance_klass()) {
return false;
}
! // Cannot redefine or retransform an unsafe anonymous class.
! if (InstanceKlass::cast(k)->is_unsafe_anonymous()) {
return false;
}
return true;
}
--- 287,299 ----
// classes for arrays cannot be redefined
if (k == NULL || !k->is_instance_klass()) {
return false;
}
! // Cannot redefine or retransform a hidden or an unsafe anonymous class.
! if (InstanceKlass::cast(k)->is_hidden() ||
! InstanceKlass::cast(k)->is_unsafe_anonymous()) {
return false;
}
return true;
}
*** 1163,1177 ****
// Set redefined class handle in JvmtiThreadState class.
// This redefined class is sent to agent event handler for class file
// load hook event.
state->set_class_being_redefined(the_class, _class_load_kind);
InstanceKlass* scratch_class = SystemDictionary::parse_stream(
the_class_sym,
the_class_loader,
- protection_domain,
&st,
THREAD);
// Clear class_being_redefined just to be sure.
state->clear_class_being_redefined();
// TODO: if this is retransform, and nothing changed we can skip it
--- 1165,1180 ----
// Set redefined class handle in JvmtiThreadState class.
// This redefined class is sent to agent event handler for class file
// load hook event.
state->set_class_being_redefined(the_class, _class_load_kind);
+ ClassLoadInfo cl_info(protection_domain);
InstanceKlass* scratch_class = SystemDictionary::parse_stream(
the_class_sym,
the_class_loader,
&st,
+ cl_info,
THREAD);
// Clear class_being_redefined just to be sure.
state->clear_class_being_redefined();
// TODO: if this is retransform, and nothing changed we can skip it
< prev index next >