diff --git a/src/hotspot/share/gc/shared/space.cpp b/src/hotspot/share/gc/shared/space.cpp index 468b2de5115..5b6b2b1c798 100644 --- a/src/hotspot/share/gc/shared/space.cpp +++ b/src/hotspot/share/gc/shared/space.cpp @@ -133,8 +133,7 @@ void DirtyCardToOopClosure::do_MemRegion(MemRegion mr) { "Only ones we deal with for now."); assert(_precision != CardTable::ObjHeadPreciseArray || - _cl->idempotent() || _last_bottom == NULL || - top <= _last_bottom, + _last_bottom == NULL || top <= _last_bottom, "Not decreasing"); NOT_PRODUCT(_last_bottom = mr.start()); @@ -172,14 +171,7 @@ void DirtyCardToOopClosure::do_MemRegion(MemRegion mr) { walk_mem_region(extended_mr, bottom_obj, top); } - // An idempotent closure might be applied in any order, so we don't - // record a _min_done for it. - if (!_cl->idempotent()) { - _min_done = bottom; - } else { - assert(_min_done == _last_explicit_min_done, - "Don't update _min_done for idempotent cl"); - } + _min_done = bottom; } DirtyCardToOopClosure* Space::new_dcto_cl(OopIterateClosure* cl, diff --git a/src/hotspot/share/memory/iterator.hpp b/src/hotspot/share/memory/iterator.hpp index 73a270f1280..149b1d7a87f 100644 --- a/src/hotspot/share/memory/iterator.hpp +++ b/src/hotspot/share/memory/iterator.hpp @@ -94,10 +94,6 @@ class OopIterateClosure : public OopClosure { virtual void do_klass(Klass* k) = 0; virtual void do_cld(ClassLoaderData* cld) = 0; - // True iff this closure may be safely applied more than once to an oop - // location without an intervening "major reset" (like the end of a GC). - virtual bool idempotent() { return false; } - #ifdef ASSERT // Default verification of each visited oop field. template void verify(T* p);