hotspot/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.core/src/org/graalvm/compiler/core/phases/MidTier.java
--- a/hotspot/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.core/src/org/graalvm/compiler/core/phases/MidTier.java Mon Dec 12 16:16:27 2016 +0300
+++ b/hotspot/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.core/src/org/graalvm/compiler/core/phases/MidTier.java Wed Mar 22 13:42:45 2017 -0700
@@ -25,17 +25,14 @@
import static org.graalvm.compiler.core.common.GraalOptions.ConditionalElimination;
import static org.graalvm.compiler.core.common.GraalOptions.ImmutableCode;
import static org.graalvm.compiler.core.common.GraalOptions.OptDeoptimizationGrouping;
-import static org.graalvm.compiler.core.common.GraalOptions.OptEliminatePartiallyRedundantGuards;
import static org.graalvm.compiler.core.common.GraalOptions.OptFloatingReads;
-import static org.graalvm.compiler.core.common.GraalOptions.OptPushThroughPi;
-import static org.graalvm.compiler.core.common.GraalOptions.OptReadElimination;
import static org.graalvm.compiler.core.common.GraalOptions.ReassociateInvariants;
-import static org.graalvm.compiler.core.common.GraalOptions.UseGraalInstrumentation;
import static org.graalvm.compiler.core.common.GraalOptions.VerifyHeapAtReturn;
import org.graalvm.compiler.loop.phases.LoopSafepointEliminationPhase;
import org.graalvm.compiler.loop.phases.ReassociateInvariantPhase;
import org.graalvm.compiler.nodes.spi.LoweringTool;
+import org.graalvm.compiler.options.OptionValues;
import org.graalvm.compiler.phases.PhaseSuite;
import org.graalvm.compiler.phases.common.CanonicalizerPhase;
import org.graalvm.compiler.phases.common.DeoptimizationGroupingPhase;
@@ -47,79 +44,46 @@
import org.graalvm.compiler.phases.common.LockEliminationPhase;
import org.graalvm.compiler.phases.common.LoopSafepointInsertionPhase;
import org.graalvm.compiler.phases.common.LoweringPhase;
-import org.graalvm.compiler.phases.common.OptimizeGuardAnchorsPhase;
-import org.graalvm.compiler.phases.common.PushThroughPiPhase;
-import org.graalvm.compiler.phases.common.RemoveValueProxyPhase;
-import org.graalvm.compiler.phases.common.ValueAnchorCleanupPhase;
import org.graalvm.compiler.phases.common.VerifyHeapAtReturnPhase;
-import org.graalvm.compiler.phases.common.instrumentation.MidTierReconcileInstrumentationPhase;
import org.graalvm.compiler.phases.tiers.MidTierContext;
-import org.graalvm.compiler.virtual.phases.ea.EarlyReadEliminationPhase;
public class MidTier extends PhaseSuite<MidTierContext> {
- public MidTier() {
+ public MidTier(OptionValues options) {
CanonicalizerPhase canonicalizer = new CanonicalizerPhase();
- if (ImmutableCode.getValue()) {
+ if (ImmutableCode.getValue(options)) {
canonicalizer.disableReadCanonicalization();
}
- if (OptPushThroughPi.getValue()) {
- appendPhase(new PushThroughPiPhase());
- }
-
- appendPhase(canonicalizer);
-
- appendPhase(new ValueAnchorCleanupPhase());
appendPhase(new LockEliminationPhase());
- if (OptReadElimination.getValue()) {
- appendPhase(new EarlyReadEliminationPhase(canonicalizer));
+ if (OptFloatingReads.getValue(options)) {
+ appendPhase(new IncrementalCanonicalizerPhase<>(canonicalizer, new FloatingReadPhase()));
}
- if (OptFloatingReads.getValue()) {
- appendPhase(new IncrementalCanonicalizerPhase<>(canonicalizer, new FloatingReadPhase()));
- }
- appendPhase(new RemoveValueProxyPhase());
-
- appendPhase(canonicalizer);
-
- if (OptEliminatePartiallyRedundantGuards.getValue()) {
- appendPhase(new OptimizeGuardAnchorsPhase());
- }
-
- if (ConditionalElimination.getValue()) {
+ if (ConditionalElimination.getValue(options)) {
appendPhase(new IterativeConditionalEliminationPhase(canonicalizer, true));
}
- if (OptEliminatePartiallyRedundantGuards.getValue()) {
- appendPhase(new OptimizeGuardAnchorsPhase());
- }
-
- appendPhase(canonicalizer);
-
- appendPhase(new IncrementalCanonicalizerPhase<>(canonicalizer, new LoopSafepointEliminationPhase()));
+ appendPhase(new LoopSafepointEliminationPhase());
appendPhase(new LoopSafepointInsertionPhase());
- appendPhase(new IncrementalCanonicalizerPhase<>(canonicalizer, new GuardLoweringPhase()));
+ appendPhase(new GuardLoweringPhase());
- if (VerifyHeapAtReturn.getValue()) {
+ if (VerifyHeapAtReturn.getValue(options)) {
appendPhase(new VerifyHeapAtReturnPhase());
}
appendPhase(new LoweringPhase(canonicalizer, LoweringTool.StandardLoweringStage.MID_TIER));
- if (UseGraalInstrumentation.getValue()) {
- appendPhase(new MidTierReconcileInstrumentationPhase());
- }
appendPhase(new FrameStateAssignmentPhase());
- if (ReassociateInvariants.getValue()) {
+ if (ReassociateInvariants.getValue(options)) {
appendPhase(new ReassociateInvariantPhase());
}
- if (OptDeoptimizationGrouping.getValue()) {
+ if (OptDeoptimizationGrouping.getValue(options)) {
appendPhase(new DeoptimizationGroupingPhase());
}