Skip to content

Commit

Permalink
Merge pull request eclipse-omr#7170 from amicic/revert-7159-criu-seri…
Browse files Browse the repository at this point in the history
…alization

Revert "Clear Inactive Objects at Checkpoint"
  • Loading branch information
babsingh authored Nov 8, 2023
2 parents a3f8c05 + 618bca3 commit 01e77f6
Show file tree
Hide file tree
Showing 11 changed files with 16 additions and 106 deletions.
10 changes: 0 additions & 10 deletions gc/base/GCCode.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -262,13 +262,3 @@ MM_GCCode::isRASDumpGC() const
{
return J9MMCONSTANT_EXPLICIT_GC_RASDUMP_COMPACT == _gcCode;
}

/**
* Determine if the GC should clear bits for objects marked as deleted.
* @return true if we should clear the heap (currently only at snapshot)
*/
bool
MM_GCCode::shouldClearHeap() const
{
return J9MMCONSTANT_EXPLICIT_GC_PREPARE_FOR_CHECKPOINT == _gcCode;
}
6 changes: 0 additions & 6 deletions gc/base/GCCode.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -85,12 +85,6 @@ class MM_GCCode {
* @return true if OOM can be thrown at the end of this GC
*/
bool isOutOfMemoryGC() const;

/**
* Determine if the GC should clear bits for objects marked as deleted.
* @return true if we should clear the heap (currently only at snapshot)
*/
bool shouldClearHeap() const;
};

#endif /* GCCODE_HPP_ */
4 changes: 2 additions & 2 deletions gc/base/ParallelHeapWalker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ MM_ParallelHeapWalker::allObjectsDoParallel(MM_EnvironmentBase *env, MM_HeapWalk
* otherwise walk all objects in the heap in a single threaded linear fashion.
*/
void
MM_ParallelHeapWalker::allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk, bool includeDeadObjects)
MM_ParallelHeapWalker::allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk)
{
if (parallel) {
GC_OMRVMInterface::flushCachesForWalk(env->getOmrVM());
Expand All @@ -158,7 +158,7 @@ MM_ParallelHeapWalker::allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObject
MM_ParallelObjectDoTask objectDoTask(env, this, function, userData, walkFlags, parallel);
env->getExtensions()->dispatcher->run(env, &objectDoTask);
} else {
MM_HeapWalker::allObjectsDo(env, function, userData, walkFlags, parallel, prepareHeapForWalk, includeDeadObjects);
MM_HeapWalker::allObjectsDo(env, function, userData, walkFlags, parallel, prepareHeapForWalk);
}
}

Expand Down
2 changes: 1 addition & 1 deletion gc/base/ParallelHeapWalker.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ class MM_ParallelHeapWalker : public MM_HeapWalker
* If parallel is set to true, task is dispatched to GC threads and walks the heap segments in parallel,
* otherwise walk all objects in the heap in a single threaded linear fashion.
*/
virtual void allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk, bool includeDeadObjects);
virtual void allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk);

MM_MarkMap *getMarkMap() {
return _markMap;
Expand Down
2 changes: 0 additions & 2 deletions gc/base/j9mm.tdf
Original file line number Diff line number Diff line change
Expand Up @@ -1025,5 +1025,3 @@ TraceEvent=Trc_MM_MSSSS_flip_backout Overhead=1 Level=1 Group=scavenger Template
TraceEvent=Trc_MM_MSSSS_flip_restore_tilt_after_percolate Overhead=1 Level=1 Group=scavenger Template="MSSSS::flip restore_tilt_after_percolate last free entry %zx size %zu"
TraceEvent=Trc_MM_MSSSS_flip_restore_tilt_after_percolate_with_stats Overhead=1 Level=1 Group=scavenge Template="MSSSS::flip restore_tilt_after_percolate heapAlignedLastFreeEntry %zu section (%zu) aligned size %zu"
TraceEvent=Trc_MM_MSSSS_flip_restore_tilt_after_percolate_current_status Overhead=1 Level=1 Group=scavenge Template="MSSSS::flip restore_tilt_after_percolate %sallocateSize %zu survivorSize %zu"

TraceEvent=Trc_MM_clearheap Overhead=1 Level=1 Template="clearheap with free memory size: %zu, object size: %zu"
6 changes: 3 additions & 3 deletions gc/base/standard/HeapWalker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,7 @@ MM_HeapWalker::allObjectSlotsDo(MM_EnvironmentBase *env, MM_HeapWalkerSlotFunc f
modifiedWalkFlags &= ~J9_MU_WALK_NEW_AND_REMEMBERED_ONLY;
}

allObjectsDo(env, heapWalkerObjectSlotsDo, (void *)&slotObjectDoUserData, modifiedWalkFlags, parallel, prepareHeapForWalk, false);
allObjectsDo(env, heapWalkerObjectSlotsDo, (void *)&slotObjectDoUserData, modifiedWalkFlags, parallel, prepareHeapForWalk);

#if defined(OMR_GC_MODRON_SCAVENGER)
/* If J9_MU_WALK_NEW_AND_REMEMBERED_ONLY is specified, allObjectsDo will only walk
Expand All @@ -205,7 +205,7 @@ MM_HeapWalker::allObjectSlotsDo(MM_EnvironmentBase *env, MM_HeapWalkerSlotFunc f
* Walk all objects in the heap in a single threaded linear fashion.
*/
void
MM_HeapWalker::allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk, bool includeDeadObjects)
MM_HeapWalker::allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk)
{
uintptr_t typeFlags = 0;

Expand All @@ -225,7 +225,7 @@ MM_HeapWalker::allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc fun
if (typeFlags == (region->getTypeFlags() & typeFlags)) {
/* Optimization to avoid virtual dispatch for every slot in the system */
omrobjectptr_t object = NULL;
GC_ObjectHeapIteratorAddressOrderedList liveObjectIterator(extensions, region, includeDeadObjects);
GC_ObjectHeapIteratorAddressOrderedList liveObjectIterator(extensions, region, false);

while (NULL != (object = liveObjectIterator.nextObject())) {
function(omrVMThread, region, object, userData);
Expand Down
2 changes: 1 addition & 1 deletion gc/base/standard/HeapWalker.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ class MM_HeapWalker : public MM_BaseVirtual

public:
virtual void allObjectSlotsDo(MM_EnvironmentBase *env, MM_HeapWalkerSlotFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk);
virtual void allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk, bool includeDeadObjects);
virtual void allObjectsDo(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc function, void *userData, uintptr_t walkFlags, bool parallel, bool prepareHeapForWalk);

static MM_HeapWalker *newInstance(MM_EnvironmentBase *env);
virtual void kill(MM_EnvironmentBase *env);
Expand Down
84 changes: 8 additions & 76 deletions gc/base/standard/ParallelGlobalGC.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -185,38 +185,6 @@ fixObject(OMR_VMThread *omrVMThread, MM_HeapRegionDescriptor *region, omrobjectp
}
}

struct HeapSizes {
uintptr_t freeBytes;
uintptr_t objectBytes;
};

static void
clearFreeEntry(OMR_VMThread *omrVMThread, MM_HeapRegionDescriptor *region, omrobjectptr_t object, void *userData)
{
MM_GCExtensionsBase *extensions = MM_GCExtensionsBase::getExtensions(omrVMThread->_vm);
MM_ParallelGlobalGC *collector = (MM_ParallelGlobalGC *)extensions->getGlobalCollector();
HeapSizes *counter = (HeapSizes *)userData;

if (extensions->objectModel.isDeadObject(object)) {
if (extensions->objectModel.isSingleSlotDeadObject(object)) {
counter->freeBytes += extensions->objectModel.getSizeInBytesSingleSlotDeadObject(object);
} else {
/* Clear both linked and unlinked free entries. */
memset(
(void *)((uintptr_t)object + sizeof(MM_HeapLinkedFreeHeader)),
0,
extensions->objectModel.getSizeInBytesMultiSlotDeadObject(object) - sizeof(MM_HeapLinkedFreeHeader));

counter->freeBytes += extensions->objectModel.getSizeInBytesMultiSlotDeadObject(object);
}
} else {
/* An assertion is used to ensure that for every object which is not
* a hole (not cleared), it must be a marked object.
*/
counter->objectBytes += extensions->objectModel.getConsumedSizeInBytesWithHeader(object);
Assert_MM_true(collector->getMarkingScheme()->isMarked(object));
}
}
#if defined(OMR_GC_MODRON_SCAVENGER)
/**
* Fix the heap if the remembered set for the scavenger is in an overflow state.
Expand Down Expand Up @@ -510,7 +478,7 @@ MM_ParallelGlobalGC::mainThreadGarbageCollect(MM_EnvironmentBase *env, MM_Alloca
_collectionStatistics._tenureFragmentation |= MACRO_FRAGMENTATION;
}

mainThreadCompact(env, allocDescription, rebuildMarkBits || env->_cycleState->_gcCode.shouldClearHeap());
mainThreadCompact(env, allocDescription, rebuildMarkBits);
_collectionStatistics._tenureFragmentation = NO_FRAGMENTATION;
if (_extensions->processLargeAllocateStats) {
processLargeAllocateStatsAfterCompact(env);
Expand Down Expand Up @@ -538,11 +506,8 @@ MM_ParallelGlobalGC::mainThreadGarbageCollect(MM_EnvironmentBase *env, MM_Alloca
compactedThisCycle = _compactThisCycle;
#endif /* OMR_GC_MODRON_COMPACTION */

/* If the delegate has isAllowUserHeapWalk set, or should prepare for a snapshot,
* fix the heap so that it can be walked
*/
MM_GCCode gcCode = env->_cycleState->_gcCode;
if (_delegate.isAllowUserHeapWalk() || gcCode.isRASDumpGC() || gcCode.shouldClearHeap()) {
/* If the delegate has isAllowUserHeapWalk set, fix the heap so that it can be walked */
if (_delegate.isAllowUserHeapWalk() || env->_cycleState->_gcCode.isRASDumpGC()) {
if (!_fixHeapForWalkCompleted) {
#if defined(OMR_GC_MODRON_COMPACTION)
if (compactedThisCycle) {
Expand All @@ -558,6 +523,7 @@ MM_ParallelGlobalGC::mainThreadGarbageCollect(MM_EnvironmentBase *env, MM_Alloca
_fixHeapForWalkCompleted = true;
}
}

_delegate.mainThreadGarbageCollectFinished(env, compactedThisCycle);

#if defined(OMR_GC_MODRON_COMPACTION)
Expand Down Expand Up @@ -1126,10 +1092,6 @@ MM_ParallelGlobalGC::internalPostCollect(MM_EnvironmentBase *env, MM_MemorySubSp
MM_GlobalCollector::internalPostCollect(env, subSpace);

tenureMemoryPoolPostCollect(env);
/* The clear pass should execute before reporting the cycle end, where heap walks and fixups are reported */
if (env->_cycleState->_gcCode.shouldClearHeap()) {
clearHeap(env, clearFreeEntry);
}

reportGCCycleFinalIncrementEnding(env);
reportGlobalGCIncrementEnd(env);
Expand Down Expand Up @@ -1157,6 +1119,7 @@ MM_ParallelGlobalGC::internalPostCollect(MM_EnvironmentBase *env, MM_MemorySubSp
_extensions->lastGlobalGCFreeBytesLOA = _extensions->heap->getApproximateActiveFreeLOAMemorySize(MEMORY_TYPE_OLD);
#endif /* defined (OMR_GC_LARGE_OBJECT_AREA) */


#if defined(OMR_ENV_DATA64) && defined(OMR_GC_FULL_POINTERS)
if (!env->compressObjectReferences()) {
if (1 == _extensions->fvtest_enableReadBarrierVerification) {
Expand Down Expand Up @@ -1319,7 +1282,7 @@ MM_ParallelGlobalGC::fixHeapForWalk(MM_EnvironmentBase *env, UDATA walkFlags, ui
OMRPORT_ACCESS_FROM_ENVIRONMENT(env);
U_64 startTime = omrtime_hires_clock();

_heapWalker->allObjectsDo(env, walkFunction, &fixedObjectCount, walkFlags, true, false, false);
_heapWalker->allObjectsDo(env, walkFunction, &fixedObjectCount, walkFlags, true, false);

_extensions->globalGCStats.fixHeapForWalkTime = omrtime_hires_delta(startTime, omrtime_hires_clock(), OMRPORT_TIME_DELTA_IN_MICROSECONDS);
_extensions->globalGCStats.fixHeapForWalkReason = walkReason;
Expand All @@ -1329,37 +1292,6 @@ MM_ParallelGlobalGC::fixHeapForWalk(MM_EnvironmentBase *env, UDATA walkFlags, ui
return fixedObjectCount;
}

/**
* Clearing all dead multi-slot objects, whether linked or unlinked.
* Currently only called at snapshot time.
* @param[in] env The environment for the calling thread
* @param[in] walkFunction the callback function to operate on each object
*/
void
MM_ParallelGlobalGC::clearHeap(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc walkFunction)
{
HeapSizes counter = {0, 0};
OMRPORT_ACCESS_FROM_ENVIRONMENT(env);
U_64 startTime = omrtime_hires_clock();

/* This is the second heap walk which clears all holes. */
_heapWalker->allObjectsDo(env, walkFunction, &counter, MEMORY_TYPE_RAM, false, false, true);
/* Report clearing as one pass with the cumulative time of the two heap walks
* including fixHeapForWalk, and clearHeap runs.
*/
MM_GlobalGCStats stats = _extensions->globalGCStats;
stats.fixHeapForWalkTime += omrtime_hires_delta(startTime, omrtime_hires_clock(), OMRPORT_TIME_DELTA_IN_MICROSECONDS);
Assert_MM_true(FIXUP_NONE != stats.fixHeapForWalkReason);
stats.fixHeapForWalkReason = FIXUP_AND_CLEAR_HEAP;

Trc_MM_clearheap(env->getLanguageVMThread(), counter.freeBytes, counter.objectBytes);
/* Assertion to ensure that all items of the heap are visited, so that
* the sum of sizes of all marked objects and holes is equal to the
* heap size.
*/
Assert_MM_true(counter.freeBytes + counter.objectBytes == _extensions->heap->getMemorySize());
}

/* (non-doxygen)
* @see MM_GlobalCollector::heapAddRange()
*/
Expand Down Expand Up @@ -1967,14 +1899,14 @@ void
MM_ParallelGlobalGC::poisonHeap(MM_EnvironmentBase *env)
{
/* This will poison only the heap slots */
_heapWalker->allObjectsDo(env, poisonReferenceSlots, NULL, 0, true, false, false);
_heapWalker->allObjectsDo(env, poisonReferenceSlots, NULL, 0, true, false);
}

void
MM_ParallelGlobalGC::healHeap(MM_EnvironmentBase *env)
{
/* This will heal only the heap slots */
_heapWalker->allObjectsDo(env, healReferenceSlots, NULL, 0, false, false, false);
_heapWalker->allObjectsDo(env, healReferenceSlots, NULL, 0, false, false);
/* Don't have the mark map at the start of gc so we'll have to iterate over
* in a sequential manner
*/
Expand Down
1 change: 0 additions & 1 deletion gc/base/standard/ParallelGlobalGC.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -284,7 +284,6 @@ class MM_ParallelGlobalGC : public MM_GlobalCollector
* @param reason fix heap reason
*/
uintptr_t fixHeapForWalk(MM_EnvironmentBase *env, UDATA walkFlags, uintptr_t walkReason, MM_HeapWalkerObjectFunc walkFunction);
void clearHeap(MM_EnvironmentBase *env, MM_HeapWalkerObjectFunc walkFunction);
MM_HeapWalker *getHeapWalker() { return _heapWalker; }
virtual void prepareHeapForWalk(MM_EnvironmentBase *env);

Expand Down
2 changes: 0 additions & 2 deletions gc/verbose/VerboseHandlerOutput.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -279,8 +279,6 @@ MM_VerboseHandlerOutput::getHeapFixupReasonString(uintptr_t reason)
return "class unloading";
case FIXUP_DEBUG_TOOLING:
return "debug tooling";
case FIXUP_AND_CLEAR_HEAP:
return "fixup and clear heap";
default:
return "unknown";
}
Expand Down
3 changes: 1 addition & 2 deletions include_core/omrgcconsts.h
Original file line number Diff line number Diff line change
Expand Up @@ -465,8 +465,7 @@ typedef enum {
typedef enum {
FIXUP_NONE = 0,
FIXUP_CLASS_UNLOADING,
FIXUP_DEBUG_TOOLING,
FIXUP_AND_CLEAR_HEAP
FIXUP_DEBUG_TOOLING
} FixUpReason;

typedef enum {
Expand Down

0 comments on commit 01e77f6

Please sign in to comment.