< prev index next >

src/hotspot/share/gc/g1/g1OopClosures.cpp

Print this page
rev 52281 : [mq]: 8212911-unify-reference-handling-during-gc


  21  * questions.
  22  *
  23  */
  24 
  25 #include "precompiled.hpp"
  26 #include "gc/g1/g1CollectedHeap.inline.hpp"
  27 #include "gc/g1/g1OopClosures.inline.hpp"
  28 #include "gc/g1/g1ParScanThreadState.hpp"
  29 #include "memory/iterator.inline.hpp"
  30 #include "utilities/stack.inline.hpp"
  31 
  32 G1ParCopyHelper::G1ParCopyHelper(G1CollectedHeap* g1h,  G1ParScanThreadState* par_scan_state) :
  33   _g1h(g1h),
  34   _par_scan_state(par_scan_state),
  35   _worker_id(par_scan_state->worker_id()),
  36   _scanned_cld(NULL),
  37   _cm(_g1h->concurrent_mark())
  38 { }
  39 
  40 G1ScanClosureBase::G1ScanClosureBase(G1CollectedHeap* g1h, G1ParScanThreadState* par_scan_state) :
  41   _g1h(g1h), _par_scan_state(par_scan_state), _from(NULL)
  42 { }
  43 
  44 void G1CLDScanClosure::do_cld(ClassLoaderData* cld) {
  45   // If the class loader data has not been dirtied we know that there's
  46   // no references into  the young gen and we can skip it.
  47   if (!_process_only_dirty || cld->has_modified_oops()) {
  48 
  49     // Tell the closure that this class loader data is the CLD to scavenge
  50     // and is the one to dirty if oops are left pointing into the young gen.
  51     _closure->set_scanned_cld(cld);
  52 
  53     // Clean the cld since we're going to scavenge all the metadata.
  54     // Clear modified oops only if this cld is claimed.
  55     cld->oops_do(_closure, _claim, /*clear_modified_oops*/true);
  56 
  57     _closure->set_scanned_cld(NULL);
  58 
  59     _closure->trim_queue_partially();
  60   }
  61   _count++;


  21  * questions.
  22  *
  23  */
  24 
  25 #include "precompiled.hpp"
  26 #include "gc/g1/g1CollectedHeap.inline.hpp"
  27 #include "gc/g1/g1OopClosures.inline.hpp"
  28 #include "gc/g1/g1ParScanThreadState.hpp"
  29 #include "memory/iterator.inline.hpp"
  30 #include "utilities/stack.inline.hpp"
  31 
  32 G1ParCopyHelper::G1ParCopyHelper(G1CollectedHeap* g1h,  G1ParScanThreadState* par_scan_state) :
  33   _g1h(g1h),
  34   _par_scan_state(par_scan_state),
  35   _worker_id(par_scan_state->worker_id()),
  36   _scanned_cld(NULL),
  37   _cm(_g1h->concurrent_mark())
  38 { }
  39 
  40 G1ScanClosureBase::G1ScanClosureBase(G1CollectedHeap* g1h, G1ParScanThreadState* par_scan_state) :
  41   _g1h(g1h), _par_scan_state(par_scan_state), _from_is_young(true)
  42 { }
  43 
  44 void G1CLDScanClosure::do_cld(ClassLoaderData* cld) {
  45   // If the class loader data has not been dirtied we know that there's
  46   // no references into  the young gen and we can skip it.
  47   if (!_process_only_dirty || cld->has_modified_oops()) {
  48 
  49     // Tell the closure that this class loader data is the CLD to scavenge
  50     // and is the one to dirty if oops are left pointing into the young gen.
  51     _closure->set_scanned_cld(cld);
  52 
  53     // Clean the cld since we're going to scavenge all the metadata.
  54     // Clear modified oops only if this cld is claimed.
  55     cld->oops_do(_closure, _claim, /*clear_modified_oops*/true);
  56 
  57     _closure->set_scanned_cld(NULL);
  58 
  59     _closure->trim_queue_partially();
  60   }
  61   _count++;
< prev index next >