# HG changeset patch # User Lukas Stadler # Date 1374160576 -7200 # Node ID 3d6bd17da6e1bf0808fb1e4cb3d6167f8b7ff1d3 # Parent dd95ee93c8939a6d4fdd7a5e0b118f265fdb01d8 fix problem in PEReadEliminationClosure (could lead to unschedulable graph) diff -r dd95ee93c893 -r 3d6bd17da6e1 graal/com.oracle.graal.virtual/src/com/oracle/graal/virtual/phases/ea/PEReadEliminationClosure.java --- a/graal/com.oracle.graal.virtual/src/com/oracle/graal/virtual/phases/ea/PEReadEliminationClosure.java Thu Jul 18 17:15:32 2013 +0200 +++ b/graal/com.oracle.graal.virtual/src/com/oracle/graal/virtual/phases/ea/PEReadEliminationClosure.java Thu Jul 18 17:16:16 2013 +0200 @@ -69,12 +69,13 @@ ValueNode object = GraphUtil.unproxify(store.object()); ValueNode cachedValue = state.getReadCache(object, store.field()); - if (state.getScalarAlias(store.value()) == cachedValue) { + ValueNode value = state.getScalarAlias(store.value()); + if (value == cachedValue) { effects.deleteFixedNode(store); deleted = true; } state.killReadCache(store.field()); - state.addReadCache(object, store.field(), store.value()); + state.addReadCache(object, store.field(), value); } else if (node instanceof MemoryCheckpoint.Single) { METRIC_MEMORYCHECKOINT.increment(); LocationIdentity identity = ((MemoryCheckpoint.Single) node).getLocationIdentity();