8183127: UpdateRSetDeferred should not enqueue cards for NULL references
Filter out NULL references during generating cards for an object. Reviewed-by: mgerdin, ehelin
This commit is contained in:
parent
0be0ab5955
commit
10afb6f4f0
@ -40,27 +40,30 @@ private:
|
|||||||
G1CollectedHeap* _g1;
|
G1CollectedHeap* _g1;
|
||||||
DirtyCardQueue *_dcq;
|
DirtyCardQueue *_dcq;
|
||||||
G1SATBCardTableModRefBS* _ct_bs;
|
G1SATBCardTableModRefBS* _ct_bs;
|
||||||
HeapRegion* _from;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
UpdateRSetDeferred(DirtyCardQueue* dcq) :
|
UpdateRSetDeferred(DirtyCardQueue* dcq) :
|
||||||
_g1(G1CollectedHeap::heap()), _ct_bs(_g1->g1_barrier_set()), _dcq(dcq), _from(NULL) {}
|
_g1(G1CollectedHeap::heap()), _ct_bs(_g1->g1_barrier_set()), _dcq(dcq) {}
|
||||||
|
|
||||||
virtual void do_oop(narrowOop* p) { do_oop_work(p); }
|
virtual void do_oop(narrowOop* p) { do_oop_work(p); }
|
||||||
virtual void do_oop( oop* p) { do_oop_work(p); }
|
virtual void do_oop( oop* p) { do_oop_work(p); }
|
||||||
template <class T> void do_oop_work(T* p) {
|
template <class T> void do_oop_work(T* p) {
|
||||||
assert(_from->is_in_reserved(p), "paranoia");
|
assert(_g1->heap_region_containing(p)->is_in_reserved(p), "paranoia");
|
||||||
assert(!_from->is_survivor(), "Unexpected evac failure in survivor region");
|
assert(!_g1->heap_region_containing(p)->is_survivor(), "Unexpected evac failure in survivor region");
|
||||||
|
|
||||||
if (!_from->is_in_reserved(oopDesc::load_decode_heap_oop(p))) {
|
T const o = oopDesc::load_heap_oop(p);
|
||||||
|
if (oopDesc::is_null(o)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (HeapRegion::is_in_same_region(p, oopDesc::decode_heap_oop(o))) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
size_t card_index = _ct_bs->index_for(p);
|
size_t card_index = _ct_bs->index_for(p);
|
||||||
if (_ct_bs->mark_card_deferred(card_index)) {
|
if (_ct_bs->mark_card_deferred(card_index)) {
|
||||||
_dcq->enqueue((jbyte*)_ct_bs->byte_for_index(card_index));
|
_dcq->enqueue((jbyte*)_ct_bs->byte_for_index(card_index));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void set_region(HeapRegion* from) { _from = from; }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class RemoveSelfForwardPtrObjClosure: public ObjectClosure {
|
class RemoveSelfForwardPtrObjClosure: public ObjectClosure {
|
||||||
@ -210,7 +213,6 @@ public:
|
|||||||
&_update_rset_cl,
|
&_update_rset_cl,
|
||||||
during_initial_mark,
|
during_initial_mark,
|
||||||
_worker_id);
|
_worker_id);
|
||||||
_update_rset_cl.set_region(hr);
|
|
||||||
hr->object_iterate(&rspc);
|
hr->object_iterate(&rspc);
|
||||||
// Need to zap the remainder area of the processed region.
|
// Need to zap the remainder area of the processed region.
|
||||||
rspc.zap_remainder();
|
rspc.zap_remainder();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user