Merge
This commit is contained in:
commit
673798137b
@ -3037,7 +3037,9 @@ void MacroAssembler::store_check(Register obj) {
|
|||||||
// register obj is destroyed afterwards.
|
// register obj is destroyed afterwards.
|
||||||
|
|
||||||
BarrierSet* bs = Universe::heap()->barrier_set();
|
BarrierSet* bs = Universe::heap()->barrier_set();
|
||||||
assert(bs->kind() == BarrierSet::CardTableModRef, "Wrong barrier set kind");
|
assert(bs->kind() == BarrierSet::CardTableForRS ||
|
||||||
|
bs->kind() == BarrierSet::CardTableExtension,
|
||||||
|
"Wrong barrier set kind");
|
||||||
|
|
||||||
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
||||||
assert(sizeof(*ct->byte_map_base) == sizeof(jbyte), "adjust this code");
|
assert(sizeof(*ct->byte_map_base) == sizeof(jbyte), "adjust this code");
|
||||||
|
@ -691,7 +691,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ call_VM_leaf(CAST_FROM_FN_PTR(address, BarrierSet::static_write_ref_array_pre), 2);
|
__ call_VM_leaf(CAST_FROM_FN_PTR(address, BarrierSet::static_write_ref_array_pre), 2);
|
||||||
__ pop(RegSet::range(r0, r29), sp); // integer registers except lr & sp }
|
__ pop(RegSet::range(r0, r29), sp); // integer registers except lr & sp }
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
break;
|
break;
|
||||||
@ -731,7 +731,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ pop(RegSet::range(r0, r29), sp); // integer registers except lr & sp }
|
__ pop(RegSet::range(r0, r29), sp); // integer registers except lr & sp }
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
CardTableModRefBS* ct = (CardTableModRefBS*)bs;
|
CardTableModRefBS* ct = (CardTableModRefBS*)bs;
|
||||||
|
@ -186,7 +186,7 @@ static void do_oop_store(InterpreterMacroAssembler* _masm,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
if (val == noreg) {
|
if (val == noreg) {
|
||||||
|
@ -2614,7 +2614,7 @@ void MacroAssembler::serialize_memory(Register thread, Register tmp1, Register t
|
|||||||
void MacroAssembler::card_write_barrier_post(Register Rstore_addr, Register Rnew_val, Register Rtmp) {
|
void MacroAssembler::card_write_barrier_post(Register Rstore_addr, Register Rnew_val, Register Rtmp) {
|
||||||
CardTableModRefBS* bs =
|
CardTableModRefBS* bs =
|
||||||
barrier_set_cast<CardTableModRefBS>(Universe::heap()->barrier_set());
|
barrier_set_cast<CardTableModRefBS>(Universe::heap()->barrier_set());
|
||||||
assert(bs->kind() == BarrierSet::CardTableModRef ||
|
assert(bs->kind() == BarrierSet::CardTableForRS ||
|
||||||
bs->kind() == BarrierSet::CardTableExtension, "wrong barrier");
|
bs->kind() == BarrierSet::CardTableExtension, "wrong barrier");
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
cmpdi(CCR0, Rnew_val, 0);
|
cmpdi(CCR0, Rnew_val, 0);
|
||||||
|
@ -656,7 +656,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ bind(filtered);
|
__ bind(filtered);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
break;
|
break;
|
||||||
@ -697,7 +697,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
Label Lskip_loop, Lstore_loop;
|
Label Lskip_loop, Lstore_loop;
|
||||||
|
@ -105,7 +105,7 @@ static void do_oop_store(InterpreterMacroAssembler* _masm,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
Label Lnull, Ldone;
|
Label Lnull, Ldone;
|
||||||
|
@ -3958,7 +3958,7 @@ void MacroAssembler::card_write_barrier_post(Register store_addr, Register new_v
|
|||||||
if (new_val == G0) return;
|
if (new_val == G0) return;
|
||||||
CardTableModRefBS* bs =
|
CardTableModRefBS* bs =
|
||||||
barrier_set_cast<CardTableModRefBS>(Universe::heap()->barrier_set());
|
barrier_set_cast<CardTableModRefBS>(Universe::heap()->barrier_set());
|
||||||
assert(bs->kind() == BarrierSet::CardTableModRef ||
|
assert(bs->kind() == BarrierSet::CardTableForRS ||
|
||||||
bs->kind() == BarrierSet::CardTableExtension, "wrong barrier");
|
bs->kind() == BarrierSet::CardTableExtension, "wrong barrier");
|
||||||
card_table_write(bs->byte_map_base, tmp, store_addr);
|
card_table_write(bs->byte_map_base, tmp, store_addr);
|
||||||
}
|
}
|
||||||
|
@ -981,7 +981,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ restore();
|
__ restore();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
break;
|
break;
|
||||||
@ -1014,7 +1014,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ restore();
|
__ restore();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
||||||
|
@ -91,7 +91,7 @@ static void do_oop_store(InterpreterMacroAssembler* _masm,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
if (index == noreg ) {
|
if (index == noreg ) {
|
||||||
|
@ -4284,7 +4284,9 @@ void MacroAssembler::store_check(Register obj) {
|
|||||||
// register obj is destroyed afterwards.
|
// register obj is destroyed afterwards.
|
||||||
|
|
||||||
BarrierSet* bs = Universe::heap()->barrier_set();
|
BarrierSet* bs = Universe::heap()->barrier_set();
|
||||||
assert(bs->kind() == BarrierSet::CardTableModRef, "Wrong barrier set kind");
|
assert(bs->kind() == BarrierSet::CardTableForRS ||
|
||||||
|
bs->kind() == BarrierSet::CardTableExtension,
|
||||||
|
"Wrong barrier set kind");
|
||||||
|
|
||||||
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
||||||
assert(sizeof(*ct->byte_map_base) == sizeof(jbyte), "adjust this code");
|
assert(sizeof(*ct->byte_map_base) == sizeof(jbyte), "adjust this code");
|
||||||
|
@ -722,7 +722,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ popa();
|
__ popa();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
break;
|
break;
|
||||||
@ -754,7 +754,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
||||||
|
@ -1253,7 +1253,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ popa();
|
__ popa();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
break;
|
break;
|
||||||
@ -1293,7 +1293,7 @@ class StubGenerator: public StubCodeGenerator {
|
|||||||
__ popa();
|
__ popa();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
CardTableModRefBS* ct = barrier_set_cast<CardTableModRefBS>(bs);
|
||||||
|
@ -200,7 +200,7 @@ static void do_oop_store(InterpreterMacroAssembler* _masm,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
{
|
{
|
||||||
if (val == noreg) {
|
if (val == noreg) {
|
||||||
|
@ -1425,7 +1425,7 @@ void LIRGenerator::pre_barrier(LIR_Opr addr_opr, LIR_Opr pre_val,
|
|||||||
G1SATBCardTableModRef_pre_barrier(addr_opr, pre_val, do_load, patch, info);
|
G1SATBCardTableModRef_pre_barrier(addr_opr, pre_val, do_load, patch, info);
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
// No pre barriers
|
// No pre barriers
|
||||||
break;
|
break;
|
||||||
@ -1445,7 +1445,7 @@ void LIRGenerator::post_barrier(LIR_OprDesc* addr, LIR_OprDesc* new_val) {
|
|||||||
G1SATBCardTableModRef_post_barrier(addr, new_val);
|
G1SATBCardTableModRef_post_barrier(addr, new_val);
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
CardTableModRef_post_barrier(addr, new_val);
|
CardTableModRef_post_barrier(addr, new_val);
|
||||||
break;
|
break;
|
||||||
|
@ -634,8 +634,6 @@ public:
|
|||||||
virtual HeapWord* satisfy_failed_allocation(size_t size,
|
virtual HeapWord* satisfy_failed_allocation(size_t size,
|
||||||
bool is_tlab);
|
bool is_tlab);
|
||||||
|
|
||||||
BarrierSet::Name barrier_set_name() { return BarrierSet::G1SATBCTLogging; }
|
|
||||||
|
|
||||||
bool need_to_start_conc_mark(const char* source, size_t alloc_word_size = 0);
|
bool need_to_start_conc_mark(const char* source, size_t alloc_word_size = 0);
|
||||||
|
|
||||||
// Record the start and end of an evacuation pause.
|
// Record the start and end of an evacuation pause.
|
||||||
|
@ -56,13 +56,7 @@ class CardTableExtension : public CardTableModRefBS {
|
|||||||
CardTableExtension(MemRegion whole_heap) :
|
CardTableExtension(MemRegion whole_heap) :
|
||||||
CardTableModRefBS(
|
CardTableModRefBS(
|
||||||
whole_heap,
|
whole_heap,
|
||||||
// Concrete tag should be BarrierSet::CardTableExtension.
|
BarrierSet::FakeRtti(BarrierSet::CardTableExtension))
|
||||||
// That will presently break things in a bunch of places though.
|
|
||||||
// The concrete tag is used as a dispatch key in many places, and
|
|
||||||
// CardTableExtension does not correctly dispatch in some of those
|
|
||||||
// uses. This will be addressed as part of a reorganization of the
|
|
||||||
// BarrierSet hierarchy.
|
|
||||||
BarrierSet::FakeRtti(BarrierSet::CardTableModRef, 0).add_tag(BarrierSet::CardTableExtension))
|
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
// Scavenge support
|
// Scavenge support
|
||||||
|
@ -132,6 +132,9 @@ public:
|
|||||||
// First the pre-write versions...
|
// First the pre-write versions...
|
||||||
template <class T> inline void write_ref_field_pre(T* field, oop new_val);
|
template <class T> inline void write_ref_field_pre(T* field, oop new_val);
|
||||||
private:
|
private:
|
||||||
|
// Helper for write_ref_field_pre and friends, testing for specialized cases.
|
||||||
|
bool devirtualize_reference_writes() const;
|
||||||
|
|
||||||
// Keep this private so as to catch violations at build time.
|
// Keep this private so as to catch violations at build time.
|
||||||
virtual void write_ref_field_pre_work( void* field, oop new_val) { guarantee(false, "Not needed"); };
|
virtual void write_ref_field_pre_work( void* field, oop new_val) { guarantee(false, "Not needed"); };
|
||||||
protected:
|
protected:
|
||||||
|
@ -32,8 +32,18 @@
|
|||||||
// performance-critical calls when the barrier is the most common
|
// performance-critical calls when the barrier is the most common
|
||||||
// card-table kind.
|
// card-table kind.
|
||||||
|
|
||||||
|
inline bool BarrierSet::devirtualize_reference_writes() const {
|
||||||
|
switch (kind()) {
|
||||||
|
case CardTableForRS:
|
||||||
|
case CardTableExtension:
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
template <class T> void BarrierSet::write_ref_field_pre(T* field, oop new_val) {
|
template <class T> void BarrierSet::write_ref_field_pre(T* field, oop new_val) {
|
||||||
if (kind() == CardTableModRef) {
|
if (devirtualize_reference_writes()) {
|
||||||
barrier_set_cast<CardTableModRefBS>(this)->inline_write_ref_field_pre(field, new_val);
|
barrier_set_cast<CardTableModRefBS>(this)->inline_write_ref_field_pre(field, new_val);
|
||||||
} else {
|
} else {
|
||||||
write_ref_field_pre_work(field, new_val);
|
write_ref_field_pre_work(field, new_val);
|
||||||
@ -41,7 +51,7 @@ template <class T> void BarrierSet::write_ref_field_pre(T* field, oop new_val) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BarrierSet::write_ref_field(void* field, oop new_val, bool release) {
|
void BarrierSet::write_ref_field(void* field, oop new_val, bool release) {
|
||||||
if (kind() == CardTableModRef) {
|
if (devirtualize_reference_writes()) {
|
||||||
barrier_set_cast<CardTableModRefBS>(this)->inline_write_ref_field(field, new_val, release);
|
barrier_set_cast<CardTableModRefBS>(this)->inline_write_ref_field(field, new_val, release);
|
||||||
} else {
|
} else {
|
||||||
write_ref_field_work(field, new_val, release);
|
write_ref_field_work(field, new_val, release);
|
||||||
@ -77,7 +87,7 @@ void BarrierSet::write_ref_array(HeapWord* start, size_t count) {
|
|||||||
|
|
||||||
|
|
||||||
inline void BarrierSet::write_region(MemRegion mr) {
|
inline void BarrierSet::write_region(MemRegion mr) {
|
||||||
if (kind() == CardTableModRef) {
|
if (devirtualize_reference_writes()) {
|
||||||
barrier_set_cast<CardTableModRefBS>(this)->inline_write_region(mr);
|
barrier_set_cast<CardTableModRefBS>(this)->inline_write_region(mr);
|
||||||
} else {
|
} else {
|
||||||
write_region_work(mr);
|
write_region_work(mr);
|
||||||
|
@ -31,13 +31,7 @@
|
|||||||
CardTableModRefBSForCTRS::CardTableModRefBSForCTRS(MemRegion whole_heap) :
|
CardTableModRefBSForCTRS::CardTableModRefBSForCTRS(MemRegion whole_heap) :
|
||||||
CardTableModRefBS(
|
CardTableModRefBS(
|
||||||
whole_heap,
|
whole_heap,
|
||||||
// Concrete tag should be BarrierSet::CardTableForRS.
|
BarrierSet::FakeRtti(BarrierSet::CardTableForRS)),
|
||||||
// That will presently break things in a bunch of places though.
|
|
||||||
// The concrete tag is used as a dispatch key in many places, and
|
|
||||||
// CardTableForRS does not correctly dispatch in some of those
|
|
||||||
// uses. This will be addressed as part of a reorganization of the
|
|
||||||
// BarrierSet hierarchy.
|
|
||||||
BarrierSet::FakeRtti(BarrierSet::CardTableModRef, 0).add_tag(BarrierSet::CardTableForRS)),
|
|
||||||
// LNC functionality
|
// LNC functionality
|
||||||
_lowest_non_clean(NULL),
|
_lowest_non_clean(NULL),
|
||||||
_lowest_non_clean_chunk_size(NULL),
|
_lowest_non_clean_chunk_size(NULL),
|
||||||
|
@ -150,8 +150,6 @@ class CollectorPolicy : public CHeapObj<mtGC> {
|
|||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
|
|
||||||
|
|
||||||
virtual BarrierSet::Name barrier_set_name() = 0;
|
|
||||||
|
|
||||||
virtual GenRemSet* create_rem_set(MemRegion reserved);
|
virtual GenRemSet* create_rem_set(MemRegion reserved);
|
||||||
|
|
||||||
// This method controls how a collector satisfies a request
|
// This method controls how a collector satisfies a request
|
||||||
@ -299,8 +297,6 @@ class GenCollectorPolicy : public CollectorPolicy {
|
|||||||
assert(_max_young_size == MaxNewSize, "Should be taken care of by initialize_size_info");
|
assert(_max_young_size == MaxNewSize, "Should be taken care of by initialize_size_info");
|
||||||
}
|
}
|
||||||
|
|
||||||
BarrierSet::Name barrier_set_name() { return BarrierSet::CardTableModRef; }
|
|
||||||
|
|
||||||
virtual CollectorPolicy::Name kind() {
|
virtual CollectorPolicy::Name kind() {
|
||||||
return CollectorPolicy::GenCollectorPolicyKind;
|
return CollectorPolicy::GenCollectorPolicyKind;
|
||||||
}
|
}
|
||||||
|
@ -1522,7 +1522,7 @@ void GraphKit::pre_barrier(bool do_load,
|
|||||||
g1_write_barrier_pre(do_load, obj, adr, adr_idx, val, val_type, pre_val, bt);
|
g1_write_barrier_pre(do_load, obj, adr, adr_idx, val, val_type, pre_val, bt);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
break;
|
break;
|
||||||
@ -1539,7 +1539,7 @@ bool GraphKit::can_move_pre_barrier() const {
|
|||||||
case BarrierSet::G1SATBCTLogging:
|
case BarrierSet::G1SATBCTLogging:
|
||||||
return true; // Can move it if no safepoint
|
return true; // Can move it if no safepoint
|
||||||
|
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
case BarrierSet::ModRef:
|
case BarrierSet::ModRef:
|
||||||
return true; // There is no pre-barrier
|
return true; // There is no pre-barrier
|
||||||
@ -1565,7 +1565,7 @@ void GraphKit::post_barrier(Node* ctl,
|
|||||||
g1_write_barrier_post(store, obj, adr, adr_idx, val, bt, use_precise);
|
g1_write_barrier_post(store, obj, adr, adr_idx, val, bt, use_precise);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BarrierSet::CardTableModRef:
|
case BarrierSet::CardTableForRS:
|
||||||
case BarrierSet::CardTableExtension:
|
case BarrierSet::CardTableExtension:
|
||||||
write_barrier_post(store, obj, adr, adr_idx, val, use_precise);
|
write_barrier_post(store, obj, adr, adr_idx, val, use_precise);
|
||||||
break;
|
break;
|
||||||
@ -3791,7 +3791,7 @@ void GraphKit::write_barrier_post(Node* oop_store,
|
|||||||
Node* cast = __ CastPX(__ ctrl(), adr);
|
Node* cast = __ CastPX(__ ctrl(), adr);
|
||||||
|
|
||||||
// Divide by card size
|
// Divide by card size
|
||||||
assert(Universe::heap()->barrier_set()->kind() == BarrierSet::CardTableModRef,
|
assert(Universe::heap()->barrier_set()->is_a(BarrierSet::CardTableModRef),
|
||||||
"Only one we handle so far.");
|
"Only one we handle so far.");
|
||||||
Node* card_offset = __ URShiftX( cast, __ ConI(CardTableModRefBS::card_shift) );
|
Node* card_offset = __ URShiftX( cast, __ ConI(CardTableModRefBS::card_shift) );
|
||||||
|
|
||||||
|
@ -2253,6 +2253,7 @@ typedef CompactHashtable<Symbol*, char> SymbolCompactHashTable;
|
|||||||
\
|
\
|
||||||
declare_constant(BarrierSet::ModRef) \
|
declare_constant(BarrierSet::ModRef) \
|
||||||
declare_constant(BarrierSet::CardTableModRef) \
|
declare_constant(BarrierSet::CardTableModRef) \
|
||||||
|
declare_constant(BarrierSet::CardTableForRS) \
|
||||||
declare_constant(BarrierSet::CardTableExtension) \
|
declare_constant(BarrierSet::CardTableExtension) \
|
||||||
declare_constant(BarrierSet::G1SATBCT) \
|
declare_constant(BarrierSet::G1SATBCT) \
|
||||||
declare_constant(BarrierSet::G1SATBCTLogging) \
|
declare_constant(BarrierSet::G1SATBCTLogging) \
|
||||||
|
@ -440,8 +440,10 @@ CallInst* SharkBuilder::CreateDump(Value* value) {
|
|||||||
// HotSpot memory barriers
|
// HotSpot memory barriers
|
||||||
|
|
||||||
void SharkBuilder::CreateUpdateBarrierSet(BarrierSet* bs, Value* field) {
|
void SharkBuilder::CreateUpdateBarrierSet(BarrierSet* bs, Value* field) {
|
||||||
if (bs->kind() != BarrierSet::CardTableModRef)
|
if (bs->kind() != BarrierSet::CardTableForRS &&
|
||||||
|
bs->kind() != BarrierSet::CardTableExtension) {
|
||||||
Unimplemented();
|
Unimplemented();
|
||||||
|
}
|
||||||
|
|
||||||
CreateStore(
|
CreateStore(
|
||||||
LLVMValue::jbyte_constant(CardTableModRefBS::dirty_card_val()),
|
LLVMValue::jbyte_constant(CardTableModRefBS::dirty_card_val()),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user