6793828: G1: invariant: queues are empty when activated

Reviewed-by: jrose, kvn
This commit is contained in:
Tom Rodriguez 2009-02-05 11:42:10 -08:00
parent 61c259aeb5
commit 275a0bfb42
2 changed files with 4 additions and 3 deletions

View File

@ -3233,12 +3233,11 @@ void GraphKit::g1_write_barrier_pre(Node* obj,
// Now some of the values // Now some of the values
Node* marking = __ load(no_ctrl, marking_adr, TypeInt::INT, active_type, Compile::AliasIdxRaw); Node* marking = __ load(__ ctrl(), marking_adr, TypeInt::INT, active_type, Compile::AliasIdxRaw);
Node* index = __ load(no_ctrl, index_adr, TypeInt::INT, T_INT, Compile::AliasIdxRaw);
Node* buffer = __ load(no_ctrl, buffer_adr, TypeRawPtr::NOTNULL, T_ADDRESS, Compile::AliasIdxRaw);
// if (!marking) // if (!marking)
__ if_then(marking, BoolTest::ne, zero); { __ if_then(marking, BoolTest::ne, zero); {
Node* index = __ load(__ ctrl(), index_adr, TypeInt::INT, T_INT, Compile::AliasIdxRaw);
const Type* t1 = adr->bottom_type(); const Type* t1 = adr->bottom_type();
const Type* t2 = val->bottom_type(); const Type* t2 = val->bottom_type();
@ -3246,6 +3245,7 @@ void GraphKit::g1_write_barrier_pre(Node* obj,
Node* orig = __ load(no_ctrl, adr, val_type, bt, alias_idx); Node* orig = __ load(no_ctrl, adr, val_type, bt, alias_idx);
// if (orig != NULL) // if (orig != NULL)
__ if_then(orig, BoolTest::ne, null()); { __ if_then(orig, BoolTest::ne, null()); {
Node* buffer = __ load(__ ctrl(), buffer_adr, TypeRawPtr::NOTNULL, T_ADDRESS, Compile::AliasIdxRaw);
// load original value // load original value
// alias_idx correct?? // alias_idx correct??

View File

@ -1303,6 +1303,7 @@ Node *LoadNode::Ideal(PhaseGVN *phase, bool can_reshape) {
Node* base = AddPNode::Ideal_base_and_offset(address, phase, ignore); Node* base = AddPNode::Ideal_base_and_offset(address, phase, ignore);
if (base != NULL if (base != NULL
&& phase->type(base)->higher_equal(TypePtr::NOTNULL) && phase->type(base)->higher_equal(TypePtr::NOTNULL)
&& phase->C->get_alias_index(phase->type(address)->is_ptr()) != Compile::AliasIdxRaw
&& all_controls_dominate(base, phase->C->start())) { && all_controls_dominate(base, phase->C->start())) {
// A method-invariant, non-null address (constant or 'this' argument). // A method-invariant, non-null address (constant or 'this' argument).
set_req(MemNode::Control, NULL); set_req(MemNode::Control, NULL);