8186789: CDS dump crashes at ConstantPool::resolve_class_constants

ConstantPool::resolve_class_constants needs to check for NULL _cache.

Reviewed-by: sspitsyn, coleenp, iklam
This commit is contained in:
Jiangli Zhou 2017-09-27 20:40:33 -04:00
parent 92ad2630a1
commit ba16fabd20
2 changed files with 23 additions and 17 deletions

View File

@ -294,6 +294,28 @@ void ConstantPool::archive_resolved_references(Thread* THREAD) {
set_resolved_references(NULL); set_resolved_references(NULL);
} }
} }
void ConstantPool::resolve_class_constants(TRAPS) {
assert(DumpSharedSpaces, "used during dump time only");
// The _cache may be NULL if the _pool_holder klass fails verification
// at dump time due to missing dependencies.
if (cache() == NULL || reference_map() == NULL) {
return; // nothing to do
}
constantPoolHandle cp(THREAD, this);
for (int index = 1; index < length(); index++) { // Index 0 is unused
if (tag_at(index).is_string()) {
Symbol* sym = cp->unresolved_string_at(index);
// Look up only. Only resolve references to already interned strings.
oop str = StringTable::lookup(sym);
if (str != NULL) {
int cache_index = cp->cp_to_object_index(index);
cp->string_at_put(index, cache_index, str);
}
}
}
}
#endif #endif
// CDS support. Create a new resolved_references array. // CDS support. Create a new resolved_references array.
@ -722,22 +744,6 @@ void ConstantPool::resolve_string_constants_impl(const constantPoolHandle& this_
} }
} }
bool ConstantPool::resolve_class_constants(TRAPS) {
constantPoolHandle cp(THREAD, this);
for (int index = 1; index < length(); index++) { // Index 0 is unused
if (tag_at(index).is_string()) {
Symbol* sym = cp->unresolved_string_at(index);
// Look up only. Only resolve references to already interned strings.
oop str = StringTable::lookup(sym);
if (str != NULL) {
int cache_index = cp->cp_to_object_index(index);
cp->string_at_put(index, cache_index, str);
}
}
}
return true;
}
Symbol* ConstantPool::exception_message(const constantPoolHandle& this_cp, int which, constantTag tag, oop pending_exception) { Symbol* ConstantPool::exception_message(const constantPoolHandle& this_cp, int which, constantTag tag, oop pending_exception) {
// Dig out the detailed message to reuse if possible // Dig out the detailed message to reuse if possible
Symbol* message = java_lang_Throwable::detail_message(pending_exception); Symbol* message = java_lang_Throwable::detail_message(pending_exception);

View File

@ -717,9 +717,9 @@ class ConstantPool : public Metadata {
// CDS support // CDS support
void archive_resolved_references(Thread *THREAD) NOT_CDS_JAVA_HEAP_RETURN; void archive_resolved_references(Thread *THREAD) NOT_CDS_JAVA_HEAP_RETURN;
void resolve_class_constants(TRAPS) NOT_CDS_JAVA_HEAP_RETURN;
void remove_unshareable_info(); void remove_unshareable_info();
void restore_unshareable_info(TRAPS); void restore_unshareable_info(TRAPS);
bool resolve_class_constants(TRAPS);
// The ConstantPool vtable is restored by this call when the ConstantPool is // The ConstantPool vtable is restored by this call when the ConstantPool is
// in the shared archive. See patch_klass_vtables() in metaspaceShared.cpp for // in the shared archive. See patch_klass_vtables() in metaspaceShared.cpp for
// all the gory details. SA, dtrace and pstack helpers distinguish metadata // all the gory details. SA, dtrace and pstack helpers distinguish metadata