src/share/vm/gc_implementation/g1/g1SATBCardTableModRefBS.cpp

Print this page
rev 5363 : imported patch filtering.diff
rev 5365 : [mq]: invalidate-fix


  53 }
  54 
  55 template <class T> void
  56 G1SATBCardTableModRefBS::write_ref_array_pre_work(T* dst, int count) {
  57   if (!JavaThread::satb_mark_queue_set().is_active()) return;
  58   T* elem_ptr = dst;
  59   for (int i = 0; i < count; i++, elem_ptr++) {
  60     T heap_oop = oopDesc::load_heap_oop(elem_ptr);
  61     if (!oopDesc::is_null(heap_oop)) {
  62       enqueue(oopDesc::decode_heap_oop_not_null(heap_oop));
  63     }
  64   }
  65 }
  66 
  67 bool G1SATBCardTableModRefBS::mark_card_deferred(size_t card_index) {
  68   jbyte val = _byte_map[card_index];
  69   // It's already processed
  70   if ((val & (clean_card_mask_val() | deferred_card_val())) == deferred_card_val()) {
  71     return false;
  72   }






  73   // Cached bit can be installed either on a clean card or on a claimed card.
  74   jbyte new_val = val;
  75   if (val == clean_card_val()) {
  76     new_val = (jbyte)deferred_card_val();
  77   } else {
  78     if (val & claimed_card_val()) {
  79       new_val = val | (jbyte)deferred_card_val();
  80     }
  81   }
  82   if (new_val != val) {
  83     Atomic::cmpxchg(new_val, &_byte_map[card_index], val);
  84   }
  85   return true;
  86 }
  87 













  88 G1SATBCardTableLoggingModRefBS::
  89 G1SATBCardTableLoggingModRefBS(MemRegion whole_heap,
  90                                int max_covered_regions) :
  91   G1SATBCardTableModRefBS(whole_heap, max_covered_regions),
  92   _dcqs(JavaThread::dirty_card_queue_set())
  93 {
  94   _kind = G1SATBCTLogging;
  95 }
  96 
  97 void
  98 G1SATBCardTableLoggingModRefBS::write_ref_field_work(void* field,
  99                                                      oop new_val) {
 100   jbyte* byte = byte_for(field);




 101   if (*byte != dirty_card) {
 102     *byte = dirty_card;
 103     Thread* thr = Thread::current();
 104     if (thr->is_Java_thread()) {
 105       JavaThread* jt = (JavaThread*)thr;
 106       jt->dirty_card_queue().enqueue(byte);
 107     } else {
 108       MutexLockerEx x(Shared_DirtyCardQ_lock,
 109                       Mutex::_no_safepoint_check_flag);
 110       _dcqs.shared_dirty_card_queue()->enqueue(byte);
 111     }
 112   }
 113 }
 114 
 115 void
 116 G1SATBCardTableLoggingModRefBS::write_ref_field_static(void* field,
 117                                                        oop new_val) {
 118   uintptr_t field_uint = (uintptr_t)field;
 119   uintptr_t new_val_uint = (uintptr_t)new_val;
 120   uintptr_t comb = field_uint ^ new_val_uint;
 121   comb = comb >> HeapRegion::LogOfHRGrainBytes;
 122   if (comb == 0) return;
 123   if (new_val == NULL) return;
 124   // Otherwise, log it.
 125   G1SATBCardTableLoggingModRefBS* g1_bs =
 126     (G1SATBCardTableLoggingModRefBS*)Universe::heap()->barrier_set();
 127   g1_bs->write_ref_field_work(field, new_val);
 128 }
 129 
 130 void
 131 G1SATBCardTableLoggingModRefBS::invalidate(MemRegion mr, bool whole_heap) {
 132   jbyte* byte = byte_for(mr.start());
 133   jbyte* last_byte = byte_for(mr.last());
 134   Thread* thr = Thread::current();
 135   if (whole_heap) {
 136     while (byte <= last_byte) {
 137       *byte = dirty_card;
 138       byte++;
 139     }
 140   } else {





 141     // Enqueue if necessary.
 142     if (thr->is_Java_thread()) {
 143       JavaThread* jt = (JavaThread*)thr;
 144       while (byte <= last_byte) {



 145         if (*byte != dirty_card) {
 146           *byte = dirty_card;
 147           jt->dirty_card_queue().enqueue(byte);
 148         }
 149         byte++;
 150       }
 151     } else {
 152       MutexLockerEx x(Shared_DirtyCardQ_lock,
 153                       Mutex::_no_safepoint_check_flag);
 154       while (byte <= last_byte) {



 155         if (*byte != dirty_card) {
 156           *byte = dirty_card;
 157           _dcqs.shared_dirty_card_queue()->enqueue(byte);
 158         }
 159         byte++;
 160       }
 161     }
 162   }
 163 }


  53 }
  54 
  55 template <class T> void
  56 G1SATBCardTableModRefBS::write_ref_array_pre_work(T* dst, int count) {
  57   if (!JavaThread::satb_mark_queue_set().is_active()) return;
  58   T* elem_ptr = dst;
  59   for (int i = 0; i < count; i++, elem_ptr++) {
  60     T heap_oop = oopDesc::load_heap_oop(elem_ptr);
  61     if (!oopDesc::is_null(heap_oop)) {
  62       enqueue(oopDesc::decode_heap_oop_not_null(heap_oop));
  63     }
  64   }
  65 }
  66 
  67 bool G1SATBCardTableModRefBS::mark_card_deferred(size_t card_index) {
  68   jbyte val = _byte_map[card_index];
  69   // It's already processed
  70   if ((val & (clean_card_mask_val() | deferred_card_val())) == deferred_card_val()) {
  71     return false;
  72   }
  73 
  74   if  (val == g1_young_gen) {
  75     // the card is for a young gen region. We don't need to keep track of all pointers into young
  76     return false;
  77   }
  78 
  79   // Cached bit can be installed either on a clean card or on a claimed card.
  80   jbyte new_val = val;
  81   if (val == clean_card_val()) {
  82     new_val = (jbyte)deferred_card_val();
  83   } else {
  84     if (val & claimed_card_val()) {
  85       new_val = val | (jbyte)deferred_card_val();
  86     }
  87   }
  88   if (new_val != val) {
  89     Atomic::cmpxchg(new_val, &_byte_map[card_index], val);
  90   }
  91   return true;
  92 }
  93 
  94 void G1SATBCardTableModRefBS::g1_mark_as_young(const MemRegion& mr) {
  95   jbyte *const first = byte_for(mr.start());
  96   jbyte *const last = byte_after(mr.last());
  97 
  98   memset(first, g1_young_gen, last - first);
  99 }
 100 
 101 #ifndef PRODUCT
 102 void G1SATBCardTableModRefBS::verify_g1_young_region(MemRegion mr) {
 103   verify_region(mr, g1_young_gen,  true);
 104 }
 105 #endif
 106 
 107 G1SATBCardTableLoggingModRefBS::
 108 G1SATBCardTableLoggingModRefBS(MemRegion whole_heap,
 109                                int max_covered_regions) :
 110   G1SATBCardTableModRefBS(whole_heap, max_covered_regions),
 111   _dcqs(JavaThread::dirty_card_queue_set())
 112 {
 113   _kind = G1SATBCTLogging;
 114 }
 115 
 116 void
 117 G1SATBCardTableLoggingModRefBS::write_ref_field_work(void* field,
 118                                                      oop new_val) {
 119   volatile jbyte* byte = byte_for(field);
 120   if (*byte == g1_young_gen) {
 121     return;
 122   }
 123   OrderAccess::storeload();
 124   if (*byte != dirty_card) {
 125     *byte = dirty_card;
 126     Thread* thr = Thread::current();
 127     if (thr->is_Java_thread()) {
 128       JavaThread* jt = (JavaThread*)thr;
 129       jt->dirty_card_queue().enqueue(byte);
 130     } else {
 131       MutexLockerEx x(Shared_DirtyCardQ_lock,
 132                       Mutex::_no_safepoint_check_flag);
 133       _dcqs.shared_dirty_card_queue()->enqueue(byte);
 134     }
 135   }
 136 }
 137 
 138 void
 139 G1SATBCardTableLoggingModRefBS::write_ref_field_static(void* field,
 140                                                        oop new_val) {
 141   uintptr_t field_uint = (uintptr_t)field;
 142   uintptr_t new_val_uint = (uintptr_t)new_val;
 143   uintptr_t comb = field_uint ^ new_val_uint;
 144   comb = comb >> HeapRegion::LogOfHRGrainBytes;
 145   if (comb == 0) return;
 146   if (new_val == NULL) return;
 147   // Otherwise, log it.
 148   G1SATBCardTableLoggingModRefBS* g1_bs =
 149     (G1SATBCardTableLoggingModRefBS*)Universe::heap()->barrier_set();
 150   g1_bs->write_ref_field_work(field, new_val);
 151 }
 152 
 153 void
 154 G1SATBCardTableLoggingModRefBS::invalidate(MemRegion mr, bool whole_heap) {
 155   volatile jbyte* byte = byte_for(mr.start());
 156   jbyte* last_byte = byte_for(mr.last());
 157   Thread* thr = Thread::current();
 158   if (whole_heap) {
 159     while (byte <= last_byte) {
 160       *byte = dirty_card;
 161       byte++;
 162     }
 163   } else {
 164     // skip all consecutive young cards
 165     for (; byte <= last_byte && *byte == g1_young_gen; byte++);
 166 
 167     if (byte <= last_byte) {
 168       OrderAccess::storeload();
 169       // Enqueue if necessary.
 170       if (thr->is_Java_thread()) {
 171         JavaThread* jt = (JavaThread*)thr;
 172         for (; byte <= last_byte; byte++) {
 173           if (*byte == g1_young_gen) {
 174             continue;
 175           }
 176           if (*byte != dirty_card) {
 177             *byte = dirty_card;
 178             jt->dirty_card_queue().enqueue(byte);
 179           }

 180         }
 181       } else {
 182         MutexLockerEx x(Shared_DirtyCardQ_lock,
 183                         Mutex::_no_safepoint_check_flag);
 184         for (; byte <= last_byte; byte++) {
 185           if (*byte == g1_young_gen) {
 186             continue;
 187           }
 188           if (*byte != dirty_card) {
 189             *byte = dirty_card;
 190             _dcqs.shared_dirty_card_queue()->enqueue(byte);
 191           }
 192         }
 193       }
 194     }
 195   }
 196 }