# HG changeset patch # User Gilles Duboscq # Date 1390325746 -3600 # Node ID 1834ae0bc965fbad238f1d9b389c3d5368a7f3e0 # Parent 2d4a8d3d286b03106d288b62ee096381215dddbc GuardLowering: do not use trapping accesses for guards with a speculation diff -r 2d4a8d3d286b -r 1834ae0bc965 graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/GuardLoweringPhase.java --- a/graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/GuardLoweringPhase.java Tue Jan 21 18:35:03 2014 +0100 +++ b/graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/GuardLoweringPhase.java Tue Jan 21 18:35:46 2014 +0100 @@ -27,6 +27,7 @@ import java.util.*; import java.util.Map.Entry; +import com.oracle.graal.api.meta.*; import com.oracle.graal.debug.*; import com.oracle.graal.graph.*; import com.oracle.graal.nodes.*; @@ -107,7 +108,7 @@ private void processGuard(Node node) { GuardNode guard = (GuardNode) node; - if (guard.negated() && guard.condition() instanceof IsNullNode) { + if (guard.negated() && guard.condition() instanceof IsNullNode && (guard.getSpeculation() == null || guard.getSpeculation().equals(Constant.NULL_OBJECT))) { ValueNode obj = ((IsNullNode) guard.condition()).object(); nullGuarded.put(obj, guard); }