8342334: CDS: Scratch mirrors should not point to dead klasses
Reviewed-by: adinn, coleenp, iklam
This commit is contained in:
parent
680dc5d896
commit
aa060f22d3
@ -386,6 +386,13 @@ void HeapShared::set_scratch_java_mirror(Klass* k, oop mirror) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void HeapShared::remove_scratch_objects(Klass* k) {
|
void HeapShared::remove_scratch_objects(Klass* k) {
|
||||||
|
// Klass is being deallocated. Java mirror can still be alive, and it should not
|
||||||
|
// point to dead klass. We need to break the link from mirror to the Klass.
|
||||||
|
// See how InstanceKlass::deallocate_contents does it for normal mirrors.
|
||||||
|
oop mirror = _scratch_java_mirror_table->get_oop(k);
|
||||||
|
if (mirror != nullptr) {
|
||||||
|
java_lang_Class::set_klass(mirror, nullptr);
|
||||||
|
}
|
||||||
_scratch_java_mirror_table->remove_oop(k);
|
_scratch_java_mirror_table->remove_oop(k);
|
||||||
if (k->is_instance_klass()) {
|
if (k->is_instance_klass()) {
|
||||||
_scratch_references_table->remove(InstanceKlass::cast(k)->constants());
|
_scratch_references_table->remove(InstanceKlass::cast(k)->constants());
|
||||||
|
Loading…
Reference in New Issue
Block a user