8291830: jvmti/RedefineClasses/StressRedefine failed: assert(!is_null(v)) failed: narrow klass value can never be zero
Reviewed-by: sspitsyn, eosterlund, kbarrett
This commit is contained in:
parent
1b924659c8
commit
fb6fd03233
@ -824,6 +824,7 @@ void ClassLoaderData::add_to_deallocate_list(Metadata* m) {
|
|||||||
_deallocate_list = new (mtClass) GrowableArray<Metadata*>(100, mtClass);
|
_deallocate_list = new (mtClass) GrowableArray<Metadata*>(100, mtClass);
|
||||||
}
|
}
|
||||||
_deallocate_list->append_if_missing(m);
|
_deallocate_list->append_if_missing(m);
|
||||||
|
ResourceMark rm;
|
||||||
log_debug(class, loader, data)("deallocate added for %s", m->print_value_string());
|
log_debug(class, loader, data)("deallocate added for %s", m->print_value_string());
|
||||||
ClassLoaderDataGraph::set_should_clean_deallocate_lists();
|
ClassLoaderDataGraph::set_should_clean_deallocate_lists();
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
#include "cds/heapShared.hpp"
|
#include "cds/heapShared.hpp"
|
||||||
#include "classfile/classLoaderData.inline.hpp"
|
#include "classfile/classLoaderData.inline.hpp"
|
||||||
#include "classfile/classLoaderDataGraph.inline.hpp"
|
#include "classfile/classLoaderDataGraph.inline.hpp"
|
||||||
#include "classfile/javaClasses.hpp"
|
#include "classfile/javaClasses.inline.hpp"
|
||||||
#include "classfile/moduleEntry.hpp"
|
#include "classfile/moduleEntry.hpp"
|
||||||
#include "classfile/systemDictionary.hpp"
|
#include "classfile/systemDictionary.hpp"
|
||||||
#include "classfile/systemDictionaryShared.hpp"
|
#include "classfile/systemDictionaryShared.hpp"
|
||||||
@ -65,10 +65,6 @@ oop Klass::java_mirror_no_keepalive() const {
|
|||||||
return _java_mirror.peek();
|
return _java_mirror.peek();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Klass::replace_java_mirror(oop mirror) {
|
|
||||||
_java_mirror.replace(mirror);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool Klass::is_cloneable() const {
|
bool Klass::is_cloneable() const {
|
||||||
return _access_flags.is_cloneable_fast() ||
|
return _access_flags.is_cloneable_fast() ||
|
||||||
is_subtype_of(vmClasses::Cloneable_klass());
|
is_subtype_of(vmClasses::Cloneable_klass());
|
||||||
@ -788,7 +784,7 @@ void Klass::verify_on(outputStream* st) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (java_mirror_no_keepalive() != NULL) {
|
if (java_mirror_no_keepalive() != NULL) {
|
||||||
guarantee(oopDesc::is_oop(java_mirror_no_keepalive()), "should be instance");
|
guarantee(java_lang_Class::is_instance(java_mirror_no_keepalive()), "should be instance");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -269,7 +269,8 @@ protected:
|
|||||||
void set_archived_java_mirror(oop m) NOT_CDS_JAVA_HEAP_RETURN;
|
void set_archived_java_mirror(oop m) NOT_CDS_JAVA_HEAP_RETURN;
|
||||||
|
|
||||||
// Temporary mirror switch used by RedefineClasses
|
// Temporary mirror switch used by RedefineClasses
|
||||||
void replace_java_mirror(oop mirror);
|
OopHandle java_mirror_handle() const { return _java_mirror; }
|
||||||
|
void swap_java_mirror_handle(OopHandle& mirror) { _java_mirror.swap(mirror); }
|
||||||
|
|
||||||
// Set java mirror OopHandle to NULL for CDS
|
// Set java mirror OopHandle to NULL for CDS
|
||||||
// This leaves the OopHandle in the CLD, but that's ok, you can't release them.
|
// This leaves the OopHandle in the CLD, but that's ok, you can't release them.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2017, 2020, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2017, 2022, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -55,6 +55,10 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void swap(OopHandle& copy) {
|
||||||
|
::swap(_obj, copy._obj);
|
||||||
|
}
|
||||||
|
|
||||||
inline oop resolve() const;
|
inline oop resolve() const;
|
||||||
inline oop peek() const;
|
inline oop peek() const;
|
||||||
|
|
||||||
|
@ -1324,7 +1324,7 @@ class RedefineVerifyMark : public StackObj {
|
|||||||
private:
|
private:
|
||||||
JvmtiThreadState* _state;
|
JvmtiThreadState* _state;
|
||||||
Klass* _scratch_class;
|
Klass* _scratch_class;
|
||||||
Handle _scratch_mirror;
|
OopHandle _scratch_mirror;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -1332,14 +1332,14 @@ class RedefineVerifyMark : public StackObj {
|
|||||||
JvmtiThreadState* state) : _state(state), _scratch_class(scratch_class)
|
JvmtiThreadState* state) : _state(state), _scratch_class(scratch_class)
|
||||||
{
|
{
|
||||||
_state->set_class_versions_map(the_class, scratch_class);
|
_state->set_class_versions_map(the_class, scratch_class);
|
||||||
_scratch_mirror = Handle(_state->get_thread(), _scratch_class->java_mirror());
|
_scratch_mirror = the_class->java_mirror_handle(); // this is a copy that is swapped
|
||||||
_scratch_class->replace_java_mirror(the_class->java_mirror());
|
_scratch_class->swap_java_mirror_handle(_scratch_mirror);
|
||||||
}
|
}
|
||||||
|
|
||||||
~RedefineVerifyMark() {
|
~RedefineVerifyMark() {
|
||||||
// Restore the scratch class's mirror, so when scratch_class is removed
|
// Restore the scratch class's mirror, so when scratch_class is removed
|
||||||
// the correct mirror pointing to it can be cleared.
|
// the correct mirror pointing to it can be cleared.
|
||||||
_scratch_class->replace_java_mirror(_scratch_mirror());
|
_scratch_class->swap_java_mirror_handle(_scratch_mirror);
|
||||||
_state->clear_class_versions_map();
|
_state->clear_class_versions_map();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user