6766316: assert(!nocreate,"Cannot build a phi for a block already parsed.")
Don't use the invariant local information if there are irreducible loops. Reviewed-by: never
This commit is contained in:
parent
f2c8d25c73
commit
893d1c4148
@ -175,7 +175,7 @@ class Parse : public GraphKit {
|
|||||||
bool is_SEL_backedge(Block* pred) const{ return is_SEL_head() && pred->rpo() >= rpo(); }
|
bool is_SEL_backedge(Block* pred) const{ return is_SEL_head() && pred->rpo() >= rpo(); }
|
||||||
bool is_invariant_local(uint i) const {
|
bool is_invariant_local(uint i) const {
|
||||||
const JVMState* jvms = start_map()->jvms();
|
const JVMState* jvms = start_map()->jvms();
|
||||||
if (!jvms->is_loc(i)) return false;
|
if (!jvms->is_loc(i) || flow()->outer()->has_irreducible_entry()) return false;
|
||||||
return flow()->is_invariant_local(i - jvms->locoff());
|
return flow()->is_invariant_local(i - jvms->locoff());
|
||||||
}
|
}
|
||||||
bool can_elide_SEL_phi(uint i) const { assert(is_SEL_head(),""); return is_invariant_local(i); }
|
bool can_elide_SEL_phi(uint i) const { assert(is_SEL_head(),""); return is_invariant_local(i); }
|
||||||
|
Loading…
Reference in New Issue
Block a user