g1RemSet.hpp 6.4 KB
Newer Older
1
/*
2
 * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved.
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 *
 * This code is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 only, as
 * published by the Free Software Foundation.
 *
 * This code is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
 * version 2 for more details (a copy is included in the LICENSE file that
 * accompanied this code).
 *
 * You should have received a copy of the GNU General Public License version
 * 2 along with this work; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
 *
19 20 21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
 * or visit www.oracle.com if you need additional information or have any
 * questions.
22 23 24
 *
 */

25 26 27
#ifndef SHARE_VM_GC_IMPLEMENTATION_G1_G1REMSET_HPP
#define SHARE_VM_GC_IMPLEMENTATION_G1_G1REMSET_HPP

28 29 30 31 32 33 34
// A G1RemSet provides ways of iterating over pointers into a selected
// collection set.

class G1CollectedHeap;
class CardTableModRefBarrierSet;
class ConcurrentG1Refine;

35 36 37 38
// A G1RemSet in which each heap region has a rem set that records the
// external heap references into it.  Uses a mod ref bs to track updates,
// so that they can be used to update the individual region remsets.

Z
zgu 已提交
39
class G1RemSet: public CHeapObj<mtGC> {
40 41 42
protected:
  G1CollectedHeap* _g1;
  unsigned _conc_refine_cards;
43
  uint n_workers();
44 45 46 47 48 49 50 51 52 53 54 55

protected:
  enum SomePrivateConstants {
    UpdateRStoMergeSync  = 0,
    MergeRStoDoDirtySync = 1,
    DoDirtySync          = 2,
    LastSync             = 3,

    SeqTask              = 0,
    NumSeqTasks          = 1
  };

56 57 58
  CardTableModRefBS*     _ct_bs;
  SubTasksDone*          _seq_task;
  G1CollectorPolicy*     _g1p;
59

60
  ConcurrentG1Refine*    _cg1r;
61

62 63
  size_t*                _cards_scanned;
  size_t                 _total_cards_scanned;
64

J
johnc 已提交
65 66 67
  // Used for caching the closure that is responsible for scanning
  // references into the collection set.
  OopsInHeapRegionClosure** _cset_rs_update_cl;
68

69 70 71 72 73 74
public:
  // This is called to reset dual hash tables after the gc pause
  // is finished and the initial hash table is no longer being
  // scanned.
  void cleanupHRRS();

75 76
  G1RemSet(G1CollectedHeap* g1, CardTableModRefBS* ct_bs);
  ~G1RemSet();
77

78 79 80 81 82 83 84
  // Invoke "blk->do_oop" on all pointers into the CS in objects in regions
  // outside the CS (having invoked "blk->set_region" to set the "from"
  // region correctly beforehand.) The "worker_i" param is for the
  // parallel case where the number of the worker thread calling this
  // function can be helpful in partitioning the work to be done. It
  // should be the same as the "i" passed to the calling thread's
  // work(i) function. In the sequential case this param will be ingored.
85
  void oops_into_collection_set_do(OopsInHeapRegionClosure* blk, int worker_i);
86

87 88 89 90 91
  // Prepare for and cleanup after an oops_into_collection_set_do
  // call.  Must call each of these once before and after (in sequential
  // code) any threads call oops_into_collection_set_do.  (This offers an
  // opportunity to sequential setup and teardown of structures needed by a
  // parallel iteration over the CS's RS.)
92 93
  void prepare_for_oops_into_collection_set_do();
  void cleanup_after_oops_into_collection_set_do();
94

95
  void scanRS(OopsInHeapRegionClosure* oc, int worker_i);
J
johnc 已提交
96
  void updateRS(DirtyCardQueue* into_cset_dcq, int worker_i);
97 98 99 100 101 102

  CardTableModRefBS* ct_bs() { return _ct_bs; }
  size_t cardsScanned() { return _total_cards_scanned; }

  // Record, if necessary, the fact that *p (where "p" is in region "from",
  // which is required to be non-NULL) has changed to a new non-NULL value.
103 104
  template <class T> void write_ref(HeapRegion* from, T* p);
  template <class T> void par_write_ref(HeapRegion* from, T* p, int tid);
105

106 107 108 109
  // Requires "region_bm" and "card_bm" to be bitmaps with 1 bit per region
  // or card, respectively, such that a region or card with a corresponding
  // 0 bit contains no part of any live object.  Eliminates any remembered
  // set entries that correspond to dead heap ranges.
110
  void scrub(BitMap* region_bm, BitMap* card_bm);
111 112 113 114

  // Like the above, but assumes is called in parallel: "worker_num" is the
  // parallel thread id of the current thread, and "claim_val" is the
  // value that should be used to claim heap regions.
115
  void scrub_par(BitMap* region_bm, BitMap* card_bm,
116
                 uint worker_num, int claim_val);
117

118
  // Refine the card corresponding to "card_ptr".
119 120 121
  // If check_for_refs_into_cset is true, a true result is returned
  // if the given card contains oops that have references into the
  // current collection set.
122 123 124
  virtual bool refine_card(jbyte* card_ptr,
                           int worker_i,
                           bool check_for_refs_into_cset);
125

126
  // Print any relevant summary info.
127
  virtual void print_summary_info();
128 129

  // Prepare remembered set for verification.
130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
  virtual void prepare_for_verify();
};

class CountNonCleanMemRegionClosure: public MemRegionClosure {
  G1CollectedHeap* _g1;
  int _n;
  HeapWord* _start_first;
public:
  CountNonCleanMemRegionClosure(G1CollectedHeap* g1) :
    _g1(g1), _n(0), _start_first(NULL)
  {}
  void do_MemRegion(MemRegion mr);
  int n() { return _n; };
  HeapWord* start_first() { return _start_first; }
};
145

146
class UpdateRSOopClosure: public ExtendedOopClosure {
147
  HeapRegion* _from;
148
  G1RemSet* _rs;
149
  int _worker_i;
150 151 152

  template <class T> void do_oop_work(T* p);

153
public:
154
  UpdateRSOopClosure(G1RemSet* rs, int worker_i = 0) :
155 156
    _from(NULL), _rs(rs), _worker_i(worker_i)
  {}
157 158 159 160 161 162

  void set_from(HeapRegion* from) {
    assert(from != NULL, "from region must be non-NULL");
    _from = from;
  }

163 164
  virtual void do_oop(narrowOop* p) { do_oop_work(p); }
  virtual void do_oop(oop* p)       { do_oop_work(p); }
165 166 167 168 169

  // Override: this closure is idempotent.
  //  bool idempotent() { return true; }
  bool apply_to_weak_ref_discovered_field() { return true; }
};
J
johnc 已提交
170 171 172 173 174 175 176 177 178 179 180 181 182

class UpdateRSetImmediate: public OopsInHeapRegionClosure {
private:
  G1RemSet* _g1_rem_set;

  template <class T> void do_oop_work(T* p);
public:
  UpdateRSetImmediate(G1RemSet* rs) :
    _g1_rem_set(rs) {}

  virtual void do_oop(narrowOop* p) { do_oop_work(p); }
  virtual void do_oop(      oop* p) { do_oop_work(p); }
};
183

184 185

#endif // SHARE_VM_GC_IMPLEMENTATION_G1_G1REMSET_HPP