# HG changeset patch # User Doug Simon # Date 1370532548 -7200 # Node ID 84890660eefb24d14396d678d46a4423042d02be # Parent 35f93560b1f0fe7f2152b957b2bf83886de05c9d cleaner implementation of stable options diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalCompiler.java --- a/graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalCompiler.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalCompiler.java Thu Jun 06 17:29:08 2013 +0200 @@ -22,7 +22,6 @@ */ package com.oracle.graal.compiler; -import static com.oracle.graal.options.OptionValue.*; import static com.oracle.graal.phases.GraalOptions.*; import java.util.*; @@ -58,9 +57,9 @@ // @formatter:off @Option(help = "") - public static final OptionValue VerifyUsageWithEquals = newOption(true); + public static final OptionValue VerifyUsageWithEquals = new OptionValue<>(true); @Option(help = "Enable inlining") - public static final OptionValue Inline = newOption(true); + public static final OptionValue Inline = new OptionValue<>(true); // @formatter:on /** diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalDebugConfig.java --- a/graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalDebugConfig.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalDebugConfig.java Thu Jun 06 17:29:08 2013 +0200 @@ -22,8 +22,6 @@ */ package com.oracle.graal.compiler; -import static com.oracle.graal.options.OptionValue.*; - import java.io.*; import java.util.*; @@ -39,27 +37,27 @@ // @formatter:off @Option(help = "Enable scope-based debugging", name = "Debug") - public static final OptionValue DebugEnabled = newOption(true); + public static final OptionValue DebugEnabled = new OptionValue<>(true); @Option(help = "Scopes to be dumped") - public static final OptionValue Dump = OptionValue.newOption(null); + public static final OptionValue Dump = new OptionValue<>(null); @Option(help = "Scopes to be metered") - public static final OptionValue Meter = OptionValue.newOption(null); + public static final OptionValue Meter = new OptionValue<>(null); @Option(help = "Scopes to be timed") - public static final OptionValue Time = OptionValue.newOption(null); + public static final OptionValue Time = new OptionValue<>(null); @Option(help = "Scopes to be logged") - public static final OptionValue Log = OptionValue.newOption(null); + public static final OptionValue Log = new OptionValue<>(null); @Option(help = "Filters debug scope output by method name/pattern") - public static final OptionValue MethodFilter = OptionValue.newOption(null); + public static final OptionValue MethodFilter = new OptionValue<>(null); @Option(help = "") - public static final OptionValue PerThreadDebugValues = newOption(false); + public static final OptionValue PerThreadDebugValues = new OptionValue<>(false); @Option(help = "") - public static final OptionValue SummarizeDebugValues = newOption(false); + public static final OptionValue SummarizeDebugValues = new OptionValue<>(false); @Option(help = "") - public static final OptionValue SummarizePerPhase = newOption(false); + public static final OptionValue SummarizePerPhase = new OptionValue<>(false); @Option(help = "Send Graal IR to dump handlers on error") - public static final OptionValue DumpOnError = newOption(false); + public static final OptionValue DumpOnError = new OptionValue<>(false); @Option(help = "Enable expensive assertions") - public static final OptionValue DetailedAsserts = new OptionValue(true) { + public static final OptionValue DetailedAsserts = new StableOptionValue() { @Override protected Boolean initialValue() { boolean enabled = false; diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/CompilationTask.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/CompilationTask.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/CompilationTask.java Thu Jun 06 17:29:08 2013 +0200 @@ -24,7 +24,6 @@ import static com.oracle.graal.api.code.CodeUtil.*; import static com.oracle.graal.nodes.StructuredGraph.*; -import static com.oracle.graal.options.OptionValue.*; import static com.oracle.graal.phases.GraalOptions.*; import java.lang.reflect.*; @@ -47,7 +46,7 @@ //@formatter:off @Option(help = "") - public static final OptionValue SlowQueueCutoff = newOption(100000); + public static final OptionValue SlowQueueCutoff = new OptionValue<>(100000); //@formatter:on public static final ThreadLocal withinEnqueue = new ThreadLocal() { diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotGraalRuntime.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotGraalRuntime.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotGraalRuntime.java Thu Jun 06 17:29:08 2013 +0200 @@ -23,7 +23,6 @@ package com.oracle.graal.hotspot; import static com.oracle.graal.graph.UnsafeAccess.*; -//import static com.oracle.graal.phases.GraalOptions.*; import java.lang.reflect.*; import java.util.*; @@ -39,6 +38,8 @@ import com.oracle.graal.options.*; import com.oracle.graal.phases.*; +//import static com.oracle.graal.phases.GraalOptions.*; + /** * Singleton class holding the instance of the {@link GraalRuntime}. * @@ -88,7 +89,7 @@ // @formatter:off @Option(help = "The runtime configuration to use") - private static final OptionValue GraalRuntime = OptionValue.newOption("basic"); + private static final OptionValue GraalRuntime = new OptionValue<>("basic"); // @formatter:on protected static HotSpotGraalRuntimeFactory findFactory(String architecture) { diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/bridge/VMToCompilerImpl.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/bridge/VMToCompilerImpl.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/bridge/VMToCompilerImpl.java Thu Jun 06 17:29:08 2013 +0200 @@ -28,7 +28,6 @@ import static com.oracle.graal.hotspot.CompilationTask.*; import static com.oracle.graal.hotspot.HotSpotGraalRuntime.*; import static com.oracle.graal.java.GraphBuilderPhase.*; -import static com.oracle.graal.options.OptionValue.*; import static com.oracle.graal.phases.GraalOptions.*; import java.io.*; @@ -63,22 +62,22 @@ //@formatter:off @Option(help = "File to which compiler logging is sent") - private static final OptionValue LogFile = OptionValue.newOption(null); + private static final OptionValue LogFile = new OptionValue<>(null); @Option(help = "Use low priority compilation threads") - private static final OptionValue SlowCompileThreads = newOption(false); + private static final OptionValue SlowCompileThreads = new OptionValue<>(false); @Option(help = "Use priority-based compilation queue") - private static final OptionValue PriorityCompileQueue = OptionValue.newOption(true); + private static final OptionValue PriorityCompileQueue = new OptionValue<>(true); @Option(help = "Print compilation queue activity periodically") - private static final OptionValue PrintQueue = OptionValue.newOption(false); + private static final OptionValue PrintQueue = new OptionValue<>(false); @Option(help = "Time limit in milliseconds for bootstrap (-1 for no limit)") - private static final OptionValue TimedBootstrap = OptionValue.newOption(-1); + private static final OptionValue TimedBootstrap = new OptionValue<>(-1); @Option(help = "Number of compilation threads to use") - private static final OptionValue Threads = new OptionValue(true) { + private static final StableOptionValue Threads = new StableOptionValue() { @Override public Integer initialValue() { @@ -87,10 +86,10 @@ }; @Option(help = "") - private static final OptionValue GenericDynamicCounters = newOption(false); + private static final OptionValue GenericDynamicCounters = new OptionValue<>(false); @Option(help = "") - private static final OptionValue BenchmarkDynamicCounters = OptionValue.newOption(null); + private static final OptionValue BenchmarkDynamicCounters = new OptionValue<>(null); //@formatter:on private final HotSpotGraalRuntime graalRuntime; diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/meta/HotSpotResolvedJavaField.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/meta/HotSpotResolvedJavaField.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/meta/HotSpotResolvedJavaField.java Thu Jun 06 17:29:08 2013 +0200 @@ -103,11 +103,9 @@ } } else { Class clazz = object.getClass(); - if (OptionValue.class.isAssignableFrom(clazz)) { - OptionValue option = (OptionValue) object; - if (option.isStable()) { - return Constant.forObject(option.getValue()); - } + if (StableOptionValue.class.isAssignableFrom(clazz)) { + StableOptionValue option = (StableOptionValue) object; + return Constant.forObject(option.getValue()); } } } diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.options/src/com/oracle/graal/options/OptionValue.java --- a/graal/com.oracle.graal.options/src/com/oracle/graal/options/OptionValue.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.options/src/com/oracle/graal/options/OptionValue.java Thu Jun 06 17:29:08 2013 +0200 @@ -38,47 +38,19 @@ */ protected T value; - private OptionValue(boolean stable, T value) { + public OptionValue(T value) { this.value = value; - this.stable = stable; - } - - /** - * Used to assert the invariant for {@link #isStable()} options. Without using locks, this check - * is not safe against races and so it's only an assertion. - */ - private boolean getValueCalled; - - /** - * Creates a {@link #isStable() non-stable} option value. - * - * @param value the initial/default value of the option - */ - public static OptionValue newOption(T value) { - return new OptionValue<>(false, value); - } - - /** - * Creates a {@link #isStable() stable} option value. - * - * @param value the initial/default value of the option - */ - public static OptionValue newStableOption(T value) { - return new OptionValue<>(true, value); } private static final Object UNINITIALIZED = "UNINITIALIZED"; - private final boolean stable; - /** * Creates an uninitialized option value for a subclass that initializes itself * {@link #initialValue() lazily}. */ @SuppressWarnings("unchecked") - protected OptionValue(boolean stable) { + protected OptionValue() { this.value = (T) UNINITIALIZED; - this.stable = stable; } /** @@ -91,33 +63,18 @@ /** * Gets the value of this option. */ - public final T getValue() { + public T getValue() { if (value == UNINITIALIZED) { value = initialValue(); } - assert initGetValueCalled(); return value; } - private boolean initGetValueCalled() { - getValueCalled = true; - return true; - } - /** - * Determines if this option always returns the same {@linkplain #getValue() value}. - */ - public boolean isStable() { - return stable; - } - - /** - * Sets the value of this option. This can only be called for a {@linkplain #isStable() stable} - * option if {@link #getValue()} has never been called. + * Sets the value of this option. */ @SuppressWarnings("unchecked") - public final void setValue(Object v) { - assert !getValueCalled || !stable; + public void setValue(Object v) { this.value = (T) v; } } diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.options/src/com/oracle/graal/options/StableOptionValue.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/graal/com.oracle.graal.options/src/com/oracle/graal/options/StableOptionValue.java Thu Jun 06 17:29:08 2013 +0200 @@ -0,0 +1,75 @@ +/* + * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ +package com.oracle.graal.options; + +/** + * A settable option that always returns the same {@linkplain #getValue() value}. + */ +public class StableOptionValue extends OptionValue { + + /** + * Creates a stable option value. + */ + public StableOptionValue(T value) { + super(value); + } + + /** + * Used to assert the invariant for stability. Without using locks, this check is not safe + * against races and so it's only an assertion. + */ + private boolean getValueCalled; + + /** + * Creates an uninitialized stable option value for a subclass that initializes itself + * {@link #initialValue() lazily}. + */ + public StableOptionValue() { + } + + /** + * Gets the value of this option. + */ + @Override + public final T getValue() { + T result = super.getValue(); + assert initGetValueCalled(); + return result; + } + + private boolean initGetValueCalled() { + getValueCalled = true; + return true; + } + + /** + * {@inheritDoc} + *

+ * This must only be called if {@link #getValue()} has never been called. + */ + @Override + public final void setValue(Object v) { + assert !getValueCalled; + super.setValue(v); + } +} diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/InliningPhase.java --- a/graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/InliningPhase.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/InliningPhase.java Thu Jun 06 17:29:08 2013 +0200 @@ -22,7 +22,6 @@ */ package com.oracle.graal.phases.common; -import static com.oracle.graal.options.OptionValue.*; import static com.oracle.graal.phases.GraalOptions.*; import java.util.*; @@ -49,7 +48,7 @@ // @formatter:off @Option(help = "Unconditionally inline intrinsics") - public static final OptionValue AlwaysInlineIntrinsics = newOption(false); + public static final OptionValue AlwaysInlineIntrinsics = new OptionValue<>(false); // @formatter:on private final PhasePlan plan; diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.phases/src/com/oracle/graal/phases/GraalOptions.java --- a/graal/com.oracle.graal.phases/src/com/oracle/graal/phases/GraalOptions.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.phases/src/com/oracle/graal/phases/GraalOptions.java Thu Jun 06 17:29:08 2013 +0200 @@ -22,8 +22,6 @@ */ package com.oracle.graal.phases; -import static com.oracle.graal.options.OptionValue.*; - import com.oracle.graal.options.*; /** @@ -33,303 +31,303 @@ public final class GraalOptions { @Option(help = "Enable use of compiler intrinsics") - public static final OptionValue Intrinsify = newOption(true); + public static final OptionValue Intrinsify = new OptionValue<>(true); @Option(help = "Enable inlining of monomorphic calls") - static final OptionValue InlineMonomorphicCalls = newOption(true); + static final OptionValue InlineMonomorphicCalls = new OptionValue<>(true); @Option(help = "Enable inlining of polymorphic calls") - static final OptionValue InlinePolymorphicCalls = newOption(true); + static final OptionValue InlinePolymorphicCalls = new OptionValue<>(true); @Option(help = "Enable inlining of megamorphic calls") - static final OptionValue InlineMegamorphicCalls = newOption(true); + static final OptionValue InlineMegamorphicCalls = new OptionValue<>(true); @Option(help = "") - public static final OptionValue MegamorphicInliningMinMethodProbability = newOption(0.33D); + public static final OptionValue MegamorphicInliningMinMethodProbability = new OptionValue<>(0.33D); @Option(help = "") - public static final OptionValue MaximumDesiredSize = newOption(5000); + public static final OptionValue MaximumDesiredSize = new OptionValue<>(5000); @Option(help = "") - public static final OptionValue MaximumRecursiveInlining = newOption(1); + public static final OptionValue MaximumRecursiveInlining = new OptionValue<>(1); // inlining settings @Option(help = "") - public static final OptionValue BoostInliningForEscapeAnalysis = newOption(2f); + public static final OptionValue BoostInliningForEscapeAnalysis = new OptionValue<>(2f); @Option(help = "") - public static final OptionValue RelevanceCapForInlining = newOption(1f); + public static final OptionValue RelevanceCapForInlining = new OptionValue<>(1f); @Option(help = "") - public static final OptionValue CapInheritedRelevance = newOption(1f); + public static final OptionValue CapInheritedRelevance = new OptionValue<>(1f); @Option(help = "") - public static final OptionValue IterativeInlining = newOption(false); + public static final OptionValue IterativeInlining = new OptionValue<>(false); @Option(help = "") - public static final OptionValue TrivialInliningSize = newOption(10); + public static final OptionValue TrivialInliningSize = new OptionValue<>(10); @Option(help = "") - public static final OptionValue MaximumInliningSize = newOption(300); + public static final OptionValue MaximumInliningSize = new OptionValue<>(300); @Option(help = "") - public static final OptionValue SmallCompiledLowLevelGraphSize = newOption(300); + public static final OptionValue SmallCompiledLowLevelGraphSize = new OptionValue<>(300); @Option(help = "") - public static final OptionValue LimitInlinedInvokes = newOption(5.0); + public static final OptionValue LimitInlinedInvokes = new OptionValue<>(5.0); // escape analysis settings @Option(help = "") - public static final OptionValue PartialEscapeAnalysis = newOption(true); + public static final OptionValue PartialEscapeAnalysis = new OptionValue<>(true); @Option(help = "") - public static final OptionValue EscapeAnalysisHistogram = newOption(false); + public static final OptionValue EscapeAnalysisHistogram = new OptionValue<>(false); @Option(help = "") - public static final OptionValue EscapeAnalysisIterations = newOption(2); + public static final OptionValue EscapeAnalysisIterations = new OptionValue<>(2); @Option(help = "") - public static final OptionValue EscapeAnalyzeOnly = OptionValue.newOption(null); + public static final OptionValue EscapeAnalyzeOnly = new OptionValue<>(null); @Option(help = "") - public static final OptionValue MaximumEscapeAnalysisArrayLength = newOption(32); + public static final OptionValue MaximumEscapeAnalysisArrayLength = new OptionValue<>(32); @Option(help = "") - public static final OptionValue PEAInliningHints = newOption(false); + public static final OptionValue PEAInliningHints = new OptionValue<>(false); @Option(help = "") - public static final OptionValue TailDuplicationProbability = newOption(0.5); + public static final OptionValue TailDuplicationProbability = new OptionValue<>(0.5); @Option(help = "") - public static final OptionValue TailDuplicationTrivialSize = newOption(1); + public static final OptionValue TailDuplicationTrivialSize = new OptionValue<>(1); // profiling information @Option(help = "") - public static final OptionValue DeoptsToDisableOptimisticOptimization = newOption(40); + public static final OptionValue DeoptsToDisableOptimisticOptimization = new OptionValue<>(40); @Option(help = "") - public static final OptionValue MatureExecutionsBranch = newOption(1); + public static final OptionValue MatureExecutionsBranch = new OptionValue<>(1); @Option(help = "") - public static final OptionValue MatureExecutionsPerSwitchCase = newOption(1); + public static final OptionValue MatureExecutionsPerSwitchCase = new OptionValue<>(1); @Option(help = "") - public static final OptionValue MatureExecutionsTypeProfile = newOption(1); + public static final OptionValue MatureExecutionsTypeProfile = new OptionValue<>(1); // comilation queue @Option(help = "") - public static final OptionValue DynamicCompilePriority = newOption(false); + public static final OptionValue DynamicCompilePriority = new OptionValue<>(false); @Option(help = "") - public static final OptionValue CompileTheWorld = OptionValue.newOption(null); + public static final OptionValue CompileTheWorld = new OptionValue<>(null); @Option(help = "") - public static final OptionValue CompileTheWorldStartAt = newOption(1); + public static final OptionValue CompileTheWorldStartAt = new OptionValue<>(1); @Option(help = "") - public static final OptionValue CompileTheWorldStopAt = newOption(Integer.MAX_VALUE); + public static final OptionValue CompileTheWorldStopAt = new OptionValue<>(Integer.MAX_VALUE); // graph caching @Option(help = "") - public static final OptionValue CacheGraphs = newOption(true); + public static final OptionValue CacheGraphs = new OptionValue<>(true); @Option(help = "") - public static final OptionValue GraphCacheSize = newOption(1000); + public static final OptionValue GraphCacheSize = new OptionValue<>(1000); @Option(help = "") - public static final OptionValue PrintGraphCache = newOption(false); + public static final OptionValue PrintGraphCache = new OptionValue<>(false); //loop transform settings TODO (gd) tune @Option(help = "") - public static final OptionValue LoopPeeling = newOption(true); + public static final OptionValue LoopPeeling = new OptionValue<>(true); @Option(help = "") - public static final OptionValue ReassociateInvariants = newOption(true); + public static final OptionValue ReassociateInvariants = new OptionValue<>(true); @Option(help = "") - public static final OptionValue FullUnroll = newOption(true); + public static final OptionValue FullUnroll = new OptionValue<>(true); @Option(help = "") - public static final OptionValue LoopUnswitch = newOption(true); + public static final OptionValue LoopUnswitch = new OptionValue<>(true); @Option(help = "") - public static final OptionValue FullUnrollMaxNodes = newOption(300); + public static final OptionValue FullUnrollMaxNodes = new OptionValue<>(300); @Option(help = "") - public static final OptionValue ExactFullUnrollMaxNodes = newOption(1200); + public static final OptionValue ExactFullUnrollMaxNodes = new OptionValue<>(1200); @Option(help = "") - public static final OptionValue MinimumPeelProbability = newOption(0.35f); + public static final OptionValue MinimumPeelProbability = new OptionValue<>(0.35f); @Option(help = "") - public static final OptionValue LoopMaxUnswitch = newOption(3); + public static final OptionValue LoopMaxUnswitch = new OptionValue<>(3); @Option(help = "") - public static final OptionValue LoopUnswitchMaxIncrease = newOption(50); + public static final OptionValue LoopUnswitchMaxIncrease = new OptionValue<>(50); @Option(help = "") - public static final OptionValue LoopUnswitchUncertaintyBoost = newOption(5); + public static final OptionValue LoopUnswitchUncertaintyBoost = new OptionValue<>(5); @Option(help = "") - public static final OptionValue UseLoopLimitChecks = newOption(true); + public static final OptionValue UseLoopLimitChecks = new OptionValue<>(true); // debugging settings @Option(help = "") - public static final OptionValue ZapStackOnMethodEntry = newOption(false); + public static final OptionValue ZapStackOnMethodEntry = new OptionValue<>(false); @Option(help = "") - public static final OptionValue DeoptALot = newOption(false); + public static final OptionValue DeoptALot = new OptionValue<>(false); @Option(help = "") - public static final OptionValue VerifyPhases = newOption(false); + public static final OptionValue VerifyPhases = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintFilter = OptionValue.newOption(null); + public static final OptionValue PrintFilter = new OptionValue<>(null); // Debug settings: @Option(help = "") - public static final OptionValue BootstrapReplacements = newOption(false); + public static final OptionValue BootstrapReplacements = new OptionValue<>(false); // Ideal graph visualizer output settings @Option(help = "") - public static final OptionValue PrintBinaryGraphs = newOption(true); + public static final OptionValue PrintBinaryGraphs = new OptionValue<>(true); @Option(help = "") - public static final OptionValue PrintCFG = newOption(false); + public static final OptionValue PrintCFG = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintIdealGraphFile = newOption(false); + public static final OptionValue PrintIdealGraphFile = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintIdealGraphAddress = OptionValue.newOption("127.0.0.1"); + public static final OptionValue PrintIdealGraphAddress = new OptionValue<>("127.0.0.1"); @Option(help = "") - public static final OptionValue PrintIdealGraphPort = newOption(4444); + public static final OptionValue PrintIdealGraphPort = new OptionValue<>(4444); @Option(help = "") - public static final OptionValue PrintBinaryGraphPort = newOption(4445); + public static final OptionValue PrintBinaryGraphPort = new OptionValue<>(4445); // Other printing settings @Option(help = "") - public static final OptionValue PrintCompilation = newOption(false); + public static final OptionValue PrintCompilation = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintProfilingInformation = newOption(false); + public static final OptionValue PrintProfilingInformation = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintIRWithLIR = newOption(false); + public static final OptionValue PrintIRWithLIR = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintCodeBytes = newOption(false); + public static final OptionValue PrintCodeBytes = new OptionValue<>(false); @Option(help = "") - public static final OptionValue PrintBailout = newOption(false); + public static final OptionValue PrintBailout = new OptionValue<>(false); @Option(help = "") - public static final OptionValue TraceLinearScanLevel = newOption(0); + public static final OptionValue TraceLinearScanLevel = new OptionValue<>(0); @Option(help = "") - public static final OptionValue TraceLIRGeneratorLevel = newOption(0); + public static final OptionValue TraceLIRGeneratorLevel = new OptionValue<>(0); @Option(help = "") - public static final OptionValue TraceEscapeAnalysis = newOption(false); + public static final OptionValue TraceEscapeAnalysis = new OptionValue<>(false); @Option(help = "") - public static final OptionValue TraceBytecodeParserLevel = newOption(0); + public static final OptionValue TraceBytecodeParserLevel = new OptionValue<>(0); @Option(help = "") - public static final OptionValue ExitVMOnBailout = newOption(false); + public static final OptionValue ExitVMOnBailout = new OptionValue<>(false); @Option(help = "") - public static final OptionValue ExitVMOnException = newOption(true); + public static final OptionValue ExitVMOnException = new OptionValue<>(true); @Option(help = "") - public static final OptionValue PrintStackTraceOnException = newOption(false); + public static final OptionValue PrintStackTraceOnException = new OptionValue<>(false); // HotSpot command line options @Option(help = "") - public static final OptionValue HotSpotPrintCompilation = newOption(false); + public static final OptionValue HotSpotPrintCompilation = new OptionValue<>(false); @Option(help = "") - public static final OptionValue HotSpotPrintInlining = newOption(false); + public static final OptionValue HotSpotPrintInlining = new OptionValue<>(false); // Register allocator debugging @Option(help = "") - public static final OptionValue RegisterPressure = OptionValue.newOption(null); + public static final OptionValue RegisterPressure = new OptionValue<>(null); // Code generator settings @Option(help = "") - public static final OptionValue ConditionalElimination = newOption(true); + public static final OptionValue ConditionalElimination = new OptionValue<>(true); @Option(help = "") - public static final OptionValue CullFrameStates = newOption(false); + public static final OptionValue CullFrameStates = new OptionValue<>(false); @Option(help = "") - public static final OptionValue UseProfilingInformation = newOption(true); + public static final OptionValue UseProfilingInformation = new OptionValue<>(true); @Option(help = "") - static final OptionValue RemoveNeverExecutedCode = newOption(true); + static final OptionValue RemoveNeverExecutedCode = new OptionValue<>(true); @Option(help = "") - static final OptionValue UseExceptionProbability = newOption(true); + static final OptionValue UseExceptionProbability = new OptionValue<>(true); @Option(help = "") - static final OptionValue UseExceptionProbabilityForOperations = newOption(true); + static final OptionValue UseExceptionProbabilityForOperations = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OmitHotExceptionStacktrace = newOption(false); + public static final OptionValue OmitHotExceptionStacktrace = new OptionValue<>(false); @Option(help = "") - public static final OptionValue GenSafepoints = newOption(true); + public static final OptionValue GenSafepoints = new OptionValue<>(true); @Option(help = "") - public static final OptionValue GenLoopSafepoints = newOption(true); + public static final OptionValue GenLoopSafepoints = new OptionValue<>(true); @Option(help = "") - static final OptionValue UseTypeCheckHints = newOption(true); + static final OptionValue UseTypeCheckHints = new OptionValue<>(true); @Option(help = "") - public static final OptionValue InlineVTableStubs = newOption(true); + public static final OptionValue InlineVTableStubs = new OptionValue<>(true); @Option(help = "") - public static final OptionValue AlwaysInlineVTableStubs = newOption(false); + public static final OptionValue AlwaysInlineVTableStubs = new OptionValue<>(false); @Option(help = "") - public static final OptionValue GenAssertionCode = newOption(false); + public static final OptionValue GenAssertionCode = new OptionValue<>(false); @Option(help = "") - public static final OptionValue AlignCallsForPatching = newOption(true); + public static final OptionValue AlignCallsForPatching = new OptionValue<>(true); @Option(help = "") - public static final OptionValue ResolveClassBeforeStaticInvoke = newOption(false); + public static final OptionValue ResolveClassBeforeStaticInvoke = new OptionValue<>(false); @Option(help = "") - public static final OptionValue CanOmitFrame = newOption(true); + public static final OptionValue CanOmitFrame = new OptionValue<>(true); @Option(help = "") - public static final OptionValue SafepointPollOffset = newOption(256); + public static final OptionValue SafepointPollOffset = new OptionValue<>(256); @Option(help = "") - public static final OptionValue MemoryAwareScheduling = newOption(true); + public static final OptionValue MemoryAwareScheduling = new OptionValue<>(true); // Translating tableswitch instructions @Option(help = "") - public static final OptionValue MinimumJumpTableSize = newOption(5); + public static final OptionValue MinimumJumpTableSize = new OptionValue<>(5); @Option(help = "") - public static final OptionValue RangeTestsSwitchDensity = newOption(5); + public static final OptionValue RangeTestsSwitchDensity = new OptionValue<>(5); @Option(help = "") - public static final OptionValue MinTableSwitchDensity = newOption(0.5); + public static final OptionValue MinTableSwitchDensity = new OptionValue<>(0.5); // Runtime settings @Option(help = "") - public static final OptionValue StackShadowPages = newOption(2); + public static final OptionValue StackShadowPages = new OptionValue<>(2); @Option(help = "") - public static final OptionValue SupportJsrBytecodes = newOption(true); + public static final OptionValue SupportJsrBytecodes = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptAssumptions = newOption(true); + public static final OptionValue OptAssumptions = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptConvertDeoptsToGuards = newOption(true); + public static final OptionValue OptConvertDeoptsToGuards = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptReadElimination = newOption(true); + public static final OptionValue OptReadElimination = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptEarlyReadElimination = newOption(true); + public static final OptionValue OptEarlyReadElimination = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptCanonicalizer = newOption(true); + public static final OptionValue OptCanonicalizer = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptCanonicalizeReads = newOption(true); + public static final OptionValue OptCanonicalizeReads = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptScheduleOutOfLoops = newOption(true); + public static final OptionValue OptScheduleOutOfLoops = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptEliminateGuards = newOption(true); + public static final OptionValue OptEliminateGuards = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptEliminateSafepoints = newOption(true); + public static final OptionValue OptEliminateSafepoints = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptImplicitNullChecks = newOption(true); + public static final OptionValue OptImplicitNullChecks = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptLivenessAnalysis = newOption(true); + public static final OptionValue OptLivenessAnalysis = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptLoopTransform = newOption(true); + public static final OptionValue OptLoopTransform = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptFloatingReads = newOption(true); + public static final OptionValue OptFloatingReads = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptTailDuplication = newOption(true); + public static final OptionValue OptTailDuplication = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptEliminatePartiallyRedundantGuards = newOption(true); + public static final OptionValue OptEliminatePartiallyRedundantGuards = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptFilterProfiledTypes = newOption(true); + public static final OptionValue OptFilterProfiledTypes = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptDevirtualizeInvokesOptimistically = newOption(true); + public static final OptionValue OptDevirtualizeInvokesOptimistically = new OptionValue<>(true); @Option(help = "") - public static final OptionValue OptPushThroughPi = newOption(true); + public static final OptionValue OptPushThroughPi = new OptionValue<>(true); // Intrinsification settings @Option(help = "") - public static final OptionValue IntrinsifyObjectClone = newOption(false); + public static final OptionValue IntrinsifyObjectClone = new OptionValue<>(false); @Option(help = "") - public static final OptionValue IntrinsifyArrayCopy = newOption(true); + public static final OptionValue IntrinsifyArrayCopy = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyObjectMethods = newOption(true); + public static final OptionValue IntrinsifyObjectMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifySystemMethods = newOption(true); + public static final OptionValue IntrinsifySystemMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyClassMethods = newOption(true); + public static final OptionValue IntrinsifyClassMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyThreadMethods = newOption(true); + public static final OptionValue IntrinsifyThreadMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyUnsafeMethods = newOption(true); + public static final OptionValue IntrinsifyUnsafeMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyMathMethods = newOption(true); + public static final OptionValue IntrinsifyMathMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyAESMethods = newOption(true); + public static final OptionValue IntrinsifyAESMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyReflectionMethods = newOption(true); + public static final OptionValue IntrinsifyReflectionMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyInstalledCodeMethods = newOption(true); + public static final OptionValue IntrinsifyInstalledCodeMethods = new OptionValue<>(true); @Option(help = "") - public static final OptionValue IntrinsifyCallSiteTarget = newOption(true); + public static final OptionValue IntrinsifyCallSiteTarget = new OptionValue<>(true); /** * Counts the various paths taken through snippets. */ @Option(help = "") - public static final OptionValue SnippetCounters = newOption(false); + public static final OptionValue SnippetCounters = new OptionValue<>(false); /** * If the probability that a checkcast will hit one the profiled types (up to {@link #CheckcastMaxHints}) * is below this value, the checkcast will be compiled without hints. */ @Option(help = "") - public static final OptionValue CheckcastMinHintHitProbability = newOption(0.5); + public static final OptionValue CheckcastMinHintHitProbability = new OptionValue<>(0.5); /** * The maximum number of hint types that will be used when compiling a checkcast for which @@ -337,17 +335,17 @@ * also influences whether hints are used. */ @Option(help = "") - public static final OptionValue CheckcastMaxHints = newOption(2); + public static final OptionValue CheckcastMaxHints = new OptionValue<>(2); /** * @see #CheckcastMinHintHitProbability */ @Option(help = "") - public static final OptionValue InstanceOfMinHintHitProbability = newOption(0.5); + public static final OptionValue InstanceOfMinHintHitProbability = new OptionValue<>(0.5); /** * @see #CheckcastMaxHints */ @Option(help = "") - public static final OptionValue InstanceOfMaxHints = newOption(2); + public static final OptionValue InstanceOfMaxHints = new OptionValue<>(2); } diff -r 35f93560b1f0 -r 84890660eefb graal/com.oracle.graal.phases/src/com/oracle/graal/phases/tiers/Suites.java --- a/graal/com.oracle.graal.phases/src/com/oracle/graal/phases/tiers/Suites.java Thu Jun 06 17:27:07 2013 +0200 +++ b/graal/com.oracle.graal.phases/src/com/oracle/graal/phases/tiers/Suites.java Thu Jun 06 17:29:08 2013 +0200 @@ -32,7 +32,7 @@ // @formatter:off @Option(help = "The compiler configuration to use") - private static final OptionValue CompilerConfiguration = OptionValue.newOption("basic"); + private static final OptionValue CompilerConfiguration = new OptionValue<>("basic"); // @formatter:on public static final Suites DEFAULT;