< prev index next >
src/hotspot/share/oops/constantPool.cpp
Print this page
rev 48471 : [mq]: RFE_Access_constantPoolCache_new_decorator
@@ -47,13 +47,10 @@
#include "runtime/init.hpp"
#include "runtime/javaCalls.hpp"
#include "runtime/signature.hpp"
#include "runtime/vframe.hpp"
#include "utilities/copy.hpp"
-#if INCLUDE_ALL_GCS
-#include "gc/g1/g1SATBCardTableModRefBS.hpp"
-#endif // INCLUDE_ALL_GCS
ConstantPool* ConstantPool::allocate(ClassLoaderData* loader_data, int length, TRAPS) {
Array<u1>* tags = MetadataFactory::new_array<u1>(loader_data, length, 0, CHECK_NULL);
int size = ConstantPool::size(length);
return new (loader_data, size, MetaspaceObj::ConstantPoolType, THREAD) ConstantPool(tags);
@@ -328,21 +325,17 @@
restore_vtable();
if (SystemDictionary::Object_klass_loaded()) {
ClassLoaderData* loader_data = pool_holder()->class_loader_data();
#if INCLUDE_CDS_JAVA_HEAP
- if (MetaspaceShared::open_archive_heap_region_mapped() &&
- _cache->archived_references() != NULL) {
+ if (MetaspaceShared::open_archive_heap_region_mapped()) {
oop archived = _cache->archived_references();
- // Make sure GC knows the cached object is now live. This is necessary after
- // initial GC marking and during concurrent marking as strong roots are only
- // scanned during initial marking (at the start of the GC marking).
- assert(UseG1GC, "Requires G1 GC");
- G1SATBCardTableModRefBS::enqueue(archived);
+ if (archived != NULL) {
// Create handle for the archived resolved reference array object
- Handle refs_handle(THREAD, (oop)archived);
+ Handle refs_handle(THREAD, archived);
set_resolved_references(loader_data->add_handle(refs_handle));
+ }
} else
#endif
{
// No mapped archived resolved reference array
// Recreate the object array and add to ClassLoaderData.
< prev index next >