This commit is contained in:
Kim Barrett 2015-08-28 23:57:26 +02:00
commit 673798137b
23 changed files with 50 additions and 48 deletions

View File

@ -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");

View File

@ -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;

View File

@ -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) {

View File

@ -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);

View File

@ -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;

View File

@ -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;

View File

@ -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);
} }

View File

@ -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);

View File

@ -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 ) {

View File

@ -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");

View File

@ -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);

View File

@ -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);

View File

@ -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) {

View File

@ -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;

View File

@ -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.

View File

@ -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

View File

@ -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:

View File

@ -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);

View File

@ -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),

View File

@ -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;
} }

View File

@ -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) );

View File

@ -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) \

View File

@ -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()),