diff --git a/src/hotspot/share/memory/heapInspection.cpp b/src/hotspot/share/memory/heapInspection.cpp index b51ba6269c5..8fe5fc52e4d 100644 --- a/src/hotspot/share/memory/heapInspection.cpp +++ b/src/hotspot/share/memory/heapInspection.cpp @@ -121,6 +121,11 @@ void KlassInfoEntry::print_on(outputStream* st) const { } KlassInfoEntry* KlassInfoBucket::lookup(Klass* const k) { + // Can happen if k is an archived class that we haven't loaded yet. + if (k->java_mirror() == NULL) { + return NULL; + } + KlassInfoEntry* elt = _list; while (elt != NULL) { if (elt->is_equal(k)) { @@ -202,7 +207,8 @@ KlassInfoEntry* KlassInfoTable::lookup(Klass* k) { assert(_buckets != NULL, "Allocation failure should have been caught"); KlassInfoEntry* e = _buckets[idx].lookup(k); // Lookup may fail if this is a new klass for which we - // could not allocate space for an new entry. + // could not allocate space for an new entry, or if it's + // an archived class that we haven't loaded yet. assert(e == NULL || k == e->klass(), "must be equal"); return e; } diff --git a/src/hotspot/share/services/heapDumper.cpp b/src/hotspot/share/services/heapDumper.cpp index 4f2ff5898e5..9b9868c2f42 100644 --- a/src/hotspot/share/services/heapDumper.cpp +++ b/src/hotspot/share/services/heapDumper.cpp @@ -958,6 +958,11 @@ void DumperSupport::dump_instance_field_descriptors(DumpWriter* writer, Klass* k // creates HPROF_GC_INSTANCE_DUMP record for the given object void DumperSupport::dump_instance(DumpWriter* writer, oop o) { Klass* k = o->klass(); + if (k->java_mirror() == NULL) { + // Ignoring this object since the corresponding java mirror is not loaded. + // Might be a dormant archive object. + return; + } writer->write_u1(HPROF_GC_INSTANCE_DUMP); writer->write_objectID(o);