# HG changeset patch # User Gilles Duboscq # Date 1371204679 -7200 # Node ID 92cbc5e8848450b57c635ac230d39ea0a9442bc7 # Parent 9645cfaffc62504e7464ff0213f07db7e6aca1aa Do not virtualize when locks do not match at merge diff -r 9645cfaffc62 -r 92cbc5e88484 graal/com.oracle.graal.virtual/src/com/oracle/graal/virtual/phases/ea/PartialEscapeClosure.java --- a/graal/com.oracle.graal.virtual/src/com/oracle/graal/virtual/phases/ea/PartialEscapeClosure.java Fri Jun 14 11:16:08 2013 +0200 +++ b/graal/com.oracle.graal.virtual/src/com/oracle/graal/virtual/phases/ea/PartialEscapeClosure.java Fri Jun 14 12:11:19 2013 +0200 @@ -349,9 +349,7 @@ locksMatch &= obj.locksEqual(startObj); } - assert virtual < states.size() || locksMatch : "mismatching lock counts at " + merge; - - if (virtual < states.size()) { + if (virtual < states.size() || !locksMatch) { if (singleValue == null) { PhiNode materializedValuePhi = getCachedPhi(object, Kind.Object); mergeEffects.addFloatingNode(materializedValuePhi, "materializedPhi");