# HG changeset patch # User Doug Simon # Date 1370525752 -7200 # Node ID fbad7372eccd68c21852393143aa9ee925e6a12b # Parent 6ceff6124679bc1b69297df7eca2eb226a51229b added support for stable options diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalCompiler.java Thu Jun 06 15:35:52 2013 +0200 @@ -22,6 +22,7 @@ */ package com.oracle.graal.compiler; +import static com.oracle.graal.options.OptionValue.*; import static com.oracle.graal.phases.GraalOptions.*; import java.util.*; @@ -57,9 +58,9 @@ // @formatter:off @Option(help = "") - public static final OptionValue VerifyUsageWithEquals = new OptionValue<>(true); + public static final OptionValue VerifyUsageWithEquals = newOption(true); @Option(help = "Enable inlining") - public static final OptionValue Inline = new OptionValue<>(true); + public static final OptionValue Inline = newOption(true); // @formatter:on /** diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.compiler/src/com/oracle/graal/compiler/GraalDebugConfig.java Thu Jun 06 15:35:52 2013 +0200 @@ -22,6 +22,8 @@ */ package com.oracle.graal.compiler; +import static com.oracle.graal.options.OptionValue.*; + import java.io.*; import java.util.*; @@ -37,30 +39,30 @@ // @formatter:off @Option(help = "Enable scope-based debugging", name = "Debug") - public static final OptionValue DebugEnabled = new OptionValue<>(true); + public static final OptionValue DebugEnabled = newOption(true); @Option(help = "Scopes to be dumped") - public static final OptionValue Dump = new OptionValue<>(null); + public static final OptionValue Dump = OptionValue.newOption(null); @Option(help = "Scopes to be metered") - public static final OptionValue Meter = new OptionValue<>(null); + public static final OptionValue Meter = OptionValue.newOption(null); @Option(help = "Scopes to be timed") - public static final OptionValue Time = new OptionValue<>(null); + public static final OptionValue Time = OptionValue.newOption(null); @Option(help = "Scopes to be logged") - public static final OptionValue Log = new OptionValue<>(null); + public static final OptionValue Log = OptionValue.newOption(null); @Option(help = "Filters debug scope output by method name/pattern") - public static final OptionValue MethodFilter = new OptionValue<>(null); + public static final OptionValue MethodFilter = OptionValue.newOption(null); @Option(help = "") - public static final OptionValue PerThreadDebugValues = new OptionValue<>(false); + public static final OptionValue PerThreadDebugValues = newOption(false); @Option(help = "") - public static final OptionValue SummarizeDebugValues = new OptionValue<>(false); + public static final OptionValue SummarizeDebugValues = newOption(false); @Option(help = "") - public static final OptionValue SummarizePerPhase = new OptionValue<>(false); + public static final OptionValue SummarizePerPhase = newOption(false); @Option(help = "Send Graal IR to dump handlers on error") - public static final OptionValue DumpOnError = new OptionValue<>(false); + public static final OptionValue DumpOnError = newOption(false); @Option(help = "Enable expensive assertions") - public static final OptionValue DetailedAsserts = new OptionValue(false) { + public static final OptionValue DetailedAsserts = new OptionValue(true) { @Override protected Boolean initialValue() { - boolean enabled = value; + boolean enabled = false; // turn detailed assertions on when the general assertions are on (misusing the assert keyword for this) assert (enabled = true) == true; return enabled; diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/CompilationTask.java Thu Jun 06 15:35:52 2013 +0200 @@ -24,6 +24,7 @@ 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.*; @@ -46,7 +47,7 @@ //@formatter:off @Option(help = "") - public static final OptionValue SlowQueueCutoff = new OptionValue<>(100000); + public static final OptionValue SlowQueueCutoff = newOption(100000); //@formatter:on public static final ThreadLocal withinEnqueue = new ThreadLocal() { diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotGraalRuntime.java Thu Jun 06 15:35:52 2013 +0200 @@ -88,7 +88,7 @@ // @formatter:off @Option(help = "The runtime configuration to use") - private static final OptionValue GraalRuntime = new OptionValue<>("basic"); + private static final OptionValue GraalRuntime = OptionValue.newOption("basic"); // @formatter:on protected static HotSpotGraalRuntimeFactory findFactory(String architecture) { diff -r 6ceff6124679 -r fbad7372eccd graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotOptions.java --- a/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotOptions.java Thu Jun 06 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/HotSpotOptions.java Thu Jun 06 15:35:52 2013 +0200 @@ -50,7 +50,7 @@ } Object value = null; - String fieldName = null; + String optionName = null; String valueString = null; if (option.equals("+PrintFlags")) { @@ -60,22 +60,22 @@ char first = option.charAt(0); if (first == '+' || first == '-') { - fieldName = option.substring(1); + optionName = option.substring(1); value = (first == '+'); } else { int index = option.indexOf('='); if (index == -1) { - fieldName = option; + optionName = option; valueString = null; } else { - fieldName = option.substring(0, index); + optionName = option.substring(0, index); valueString = option.substring(index + 1); } } - OptionProvider optionProvider = options.get(fieldName); + OptionProvider optionProvider = options.get(optionName); if (optionProvider == null) { - Logger.info("Could not find option " + fieldName + " (use -G:+PrintFlags to see Graal options)"); + Logger.info("Could not find option " + optionName + " (use -G:+PrintFlags to see Graal options)"); return false; } @@ -83,12 +83,12 @@ if (value == null) { if (optionType == Boolean.TYPE || optionType == Boolean.class) { - Logger.info("Value for boolean option '" + fieldName + "' must use '-G:+" + fieldName + "' or '-G:-" + fieldName + "' format"); + Logger.info("Value for boolean option '" + optionName + "' must use '-G:+" + optionName + "' or '-G:-" + optionName + "' format"); return false; } if (valueString == null) { - Logger.info("Value for option '" + fieldName + "' must use '-G:" + fieldName + "=' format"); + Logger.info("Value for option '" + optionName + "' must use '-G:" + optionName + "=' format"); return false; } @@ -103,16 +103,17 @@ } } else { if (optionType != Boolean.class) { - Logger.info("Value for option '" + fieldName + "' must use '-G:" + fieldName + "=' format"); + Logger.info("Value for option '" + optionName + "' must use '-G:" + optionName + "=' format"); return false; } } if (value != null) { - optionProvider.getOptionValue().setValue(value); + OptionValue optionValue = optionProvider.getOptionValue(); + optionValue.setValue(value); // Logger.info("Set option " + fieldName + " to " + value); } else { - Logger.info("Wrong value \"" + valueString + "\" for option " + fieldName); + Logger.info("Wrong value \"" + valueString + "\" for option " + optionName); return false; } diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/bridge/VMToCompilerImpl.java Thu Jun 06 15:35:52 2013 +0200 @@ -28,6 +28,7 @@ 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.*; @@ -62,22 +63,22 @@ //@formatter:off @Option(help = "File to which compiler logging is sent") - private static final OptionValue LogFile = new OptionValue<>(null); + private static final OptionValue LogFile = OptionValue.newOption(null); @Option(help = "Use low priority compilation threads") - private static final OptionValue SlowCompileThreads = new OptionValue<>(false); + private static final OptionValue SlowCompileThreads = newOption(false); @Option(help = "Use priority-based compilation queue") - private static final OptionValue PriorityCompileQueue = new OptionValue<>(true); + private static final OptionValue PriorityCompileQueue = OptionValue.newOption(true); @Option(help = "Print compilation queue activity periodically") - private static final OptionValue PrintQueue = new OptionValue<>(false); + private static final OptionValue PrintQueue = OptionValue.newOption(false); @Option(help = "Time limit in milliseconds for bootstrap (-1 for no limit)") - private static final OptionValue TimedBootstrap = new OptionValue<>(-1); + private static final OptionValue TimedBootstrap = OptionValue.newOption(-1); @Option(help = "Number of compilation threads to use") - private static final OptionValue Threads = new OptionValue() { + private static final OptionValue Threads = new OptionValue(true) { @Override public Integer initialValue() { @@ -86,10 +87,10 @@ }; @Option(help = "") - private static final OptionValue GenericDynamicCounters = new OptionValue<>(false); + private static final OptionValue GenericDynamicCounters = newOption(false); @Option(help = "") - private static final OptionValue BenchmarkDynamicCounters = new OptionValue<>(null); + private static final OptionValue BenchmarkDynamicCounters = OptionValue.newOption(null); //@formatter:on private final HotSpotGraalRuntime graalRuntime; diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.hotspot/src/com/oracle/graal/hotspot/meta/HotSpotResolvedJavaField.java Thu Jun 06 15:35:52 2013 +0200 @@ -95,11 +95,20 @@ * have a non-default value. */ assert !Modifier.isStatic(flags); + Object object = receiver.asObject(); if (Modifier.isFinal(getModifiers())) { Constant value = readValue(receiver); - if (assumeNonStaticFinalFieldsAsFinal(receiver.asObject().getClass()) || !value.isDefaultForKind()) { + if (assumeNonStaticFinalFieldsAsFinal(object.getClass()) || !value.isDefaultForKind()) { return value; } + } else { + Class clazz = object.getClass(); + if (OptionValue.class.isAssignableFrom(clazz)) { + OptionValue option = (OptionValue) object; + if (option.isStable()) { + return Constant.forObject(option.getValue()); + } + } } } return null; @@ -120,9 +129,6 @@ } private static boolean assumeNonStaticFinalFieldsAsFinal(Class clazz) { - if (clazz == OptionValue.class) { - return true; - } return clazz == SnippetCounter.class; } diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.options/src/com/oracle/graal/options/OptionValue.java Thu Jun 06 15:35:52 2013 +0200 @@ -38,24 +38,47 @@ */ protected T value; + private OptionValue(boolean stable, T value) { + this.value = value; + this.stable = stable; + } + /** - * Creates an option value. + * 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 OptionValue(T value) { - this.value = value; + 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() { + protected OptionValue(boolean stable) { this.value = (T) UNINITIALIZED; + this.stable = stable; } /** @@ -72,14 +95,29 @@ if (value == UNINITIALIZED) { value = initialValue(); } + assert initGetValueCalled(); return value; } + private boolean initGetValueCalled() { + getValueCalled = true; + return true; + } + /** - * Sets the value of this option. + * 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. */ @SuppressWarnings("unchecked") public final void setValue(Object v) { + assert !getValueCalled || !stable; this.value = (T) v; } } diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.phases.common/src/com/oracle/graal/phases/common/InliningPhase.java Thu Jun 06 15:35:52 2013 +0200 @@ -22,6 +22,7 @@ */ package com.oracle.graal.phases.common; +import static com.oracle.graal.options.OptionValue.*; import static com.oracle.graal.phases.GraalOptions.*; import java.util.*; @@ -48,7 +49,7 @@ // @formatter:off @Option(help = "Unconditionally inline intrinsics") - public static final OptionValue AlwaysInlineIntrinsics = new OptionValue<>(false); + public static final OptionValue AlwaysInlineIntrinsics = newOption(false); // @formatter:on private final PhasePlan plan; diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.phases/src/com/oracle/graal/phases/GraalOptions.java Thu Jun 06 15:35:52 2013 +0200 @@ -22,6 +22,8 @@ */ package com.oracle.graal.phases; +import static com.oracle.graal.options.OptionValue.*; + import com.oracle.graal.options.*; /** @@ -31,303 +33,303 @@ public final class GraalOptions { @Option(help = "Enable use of compiler intrinsics") - public static final OptionValue Intrinsify = new OptionValue<>(true); + public static final OptionValue Intrinsify = newOption(true); @Option(help = "Enable inlining of monomorphic calls") - static final OptionValue InlineMonomorphicCalls = new OptionValue<>(true); + static final OptionValue InlineMonomorphicCalls = newOption(true); @Option(help = "Enable inlining of polymorphic calls") - static final OptionValue InlinePolymorphicCalls = new OptionValue<>(true); + static final OptionValue InlinePolymorphicCalls = newOption(true); @Option(help = "Enable inlining of megamorphic calls") - static final OptionValue InlineMegamorphicCalls = new OptionValue<>(true); + static final OptionValue InlineMegamorphicCalls = newOption(true); @Option(help = "") - public static final OptionValue MegamorphicInliningMinMethodProbability = new OptionValue<>(0.33D); + public static final OptionValue MegamorphicInliningMinMethodProbability = newOption(0.33D); @Option(help = "") - public static final OptionValue MaximumDesiredSize = new OptionValue<>(5000); + public static final OptionValue MaximumDesiredSize = newOption(5000); @Option(help = "") - public static final OptionValue MaximumRecursiveInlining = new OptionValue<>(1); + public static final OptionValue MaximumRecursiveInlining = newOption(1); // inlining settings @Option(help = "") - public static final OptionValue BoostInliningForEscapeAnalysis = new OptionValue<>(2f); + public static final OptionValue BoostInliningForEscapeAnalysis = newOption(2f); @Option(help = "") - public static final OptionValue RelevanceCapForInlining = new OptionValue<>(1f); + public static final OptionValue RelevanceCapForInlining = newOption(1f); @Option(help = "") - public static final OptionValue CapInheritedRelevance = new OptionValue<>(1f); + public static final OptionValue CapInheritedRelevance = newOption(1f); @Option(help = "") - public static final OptionValue IterativeInlining = new OptionValue<>(false); + public static final OptionValue IterativeInlining = newOption(false); @Option(help = "") - public static final OptionValue TrivialInliningSize = new OptionValue<>(10); + public static final OptionValue TrivialInliningSize = newOption(10); @Option(help = "") - public static final OptionValue MaximumInliningSize = new OptionValue<>(300); + public static final OptionValue MaximumInliningSize = newOption(300); @Option(help = "") - public static final OptionValue SmallCompiledLowLevelGraphSize = new OptionValue<>(300); + public static final OptionValue SmallCompiledLowLevelGraphSize = newOption(300); @Option(help = "") - public static final OptionValue LimitInlinedInvokes = new OptionValue<>(5.0); + public static final OptionValue LimitInlinedInvokes = newOption(5.0); // escape analysis settings @Option(help = "") - public static final OptionValue PartialEscapeAnalysis = new OptionValue<>(true); + public static final OptionValue PartialEscapeAnalysis = newOption(true); @Option(help = "") - public static final OptionValue EscapeAnalysisHistogram = new OptionValue<>(false); + public static final OptionValue EscapeAnalysisHistogram = newOption(false); @Option(help = "") - public static final OptionValue EscapeAnalysisIterations = new OptionValue<>(2); + public static final OptionValue EscapeAnalysisIterations = newOption(2); @Option(help = "") - public static final OptionValue EscapeAnalyzeOnly = new OptionValue<>(null); + public static final OptionValue EscapeAnalyzeOnly = OptionValue.newOption(null); @Option(help = "") - public static final OptionValue MaximumEscapeAnalysisArrayLength = new OptionValue<>(32); + public static final OptionValue MaximumEscapeAnalysisArrayLength = newOption(32); @Option(help = "") - public static final OptionValue PEAInliningHints = new OptionValue<>(false); + public static final OptionValue PEAInliningHints = newOption(false); @Option(help = "") - public static final OptionValue TailDuplicationProbability = new OptionValue<>(0.5); + public static final OptionValue TailDuplicationProbability = newOption(0.5); @Option(help = "") - public static final OptionValue TailDuplicationTrivialSize = new OptionValue<>(1); + public static final OptionValue TailDuplicationTrivialSize = newOption(1); // profiling information @Option(help = "") - public static final OptionValue DeoptsToDisableOptimisticOptimization = new OptionValue<>(40); + public static final OptionValue DeoptsToDisableOptimisticOptimization = newOption(40); @Option(help = "") - public static final OptionValue MatureExecutionsBranch = new OptionValue<>(1); + public static final OptionValue MatureExecutionsBranch = newOption(1); @Option(help = "") - public static final OptionValue MatureExecutionsPerSwitchCase = new OptionValue<>(1); + public static final OptionValue MatureExecutionsPerSwitchCase = newOption(1); @Option(help = "") - public static final OptionValue MatureExecutionsTypeProfile = new OptionValue<>(1); + public static final OptionValue MatureExecutionsTypeProfile = newOption(1); // comilation queue @Option(help = "") - public static final OptionValue DynamicCompilePriority = new OptionValue<>(false); + public static final OptionValue DynamicCompilePriority = newOption(false); @Option(help = "") - public static final OptionValue CompileTheWorld = new OptionValue<>(null); + public static final OptionValue CompileTheWorld = OptionValue.newOption(null); @Option(help = "") - public static final OptionValue CompileTheWorldStartAt = new OptionValue<>(1); + public static final OptionValue CompileTheWorldStartAt = newOption(1); @Option(help = "") - public static final OptionValue CompileTheWorldStopAt = new OptionValue<>(Integer.MAX_VALUE); + public static final OptionValue CompileTheWorldStopAt = newOption(Integer.MAX_VALUE); // graph caching @Option(help = "") - public static final OptionValue CacheGraphs = new OptionValue<>(true); + public static final OptionValue CacheGraphs = newOption(true); @Option(help = "") - public static final OptionValue GraphCacheSize = new OptionValue<>(1000); + public static final OptionValue GraphCacheSize = newOption(1000); @Option(help = "") - public static final OptionValue PrintGraphCache = new OptionValue<>(false); + public static final OptionValue PrintGraphCache = newOption(false); //loop transform settings TODO (gd) tune @Option(help = "") - public static final OptionValue LoopPeeling = new OptionValue<>(true); + public static final OptionValue LoopPeeling = newOption(true); @Option(help = "") - public static final OptionValue ReassociateInvariants = new OptionValue<>(true); + public static final OptionValue ReassociateInvariants = newOption(true); @Option(help = "") - public static final OptionValue FullUnroll = new OptionValue<>(true); + public static final OptionValue FullUnroll = newOption(true); @Option(help = "") - public static final OptionValue LoopUnswitch = new OptionValue<>(true); + public static final OptionValue LoopUnswitch = newOption(true); @Option(help = "") - public static final OptionValue FullUnrollMaxNodes = new OptionValue<>(300); + public static final OptionValue FullUnrollMaxNodes = newOption(300); @Option(help = "") - public static final OptionValue ExactFullUnrollMaxNodes = new OptionValue<>(1200); + public static final OptionValue ExactFullUnrollMaxNodes = newOption(1200); @Option(help = "") - public static final OptionValue MinimumPeelProbability = new OptionValue<>(0.35f); + public static final OptionValue MinimumPeelProbability = newOption(0.35f); @Option(help = "") - public static final OptionValue LoopMaxUnswitch = new OptionValue<>(3); + public static final OptionValue LoopMaxUnswitch = newOption(3); @Option(help = "") - public static final OptionValue LoopUnswitchMaxIncrease = new OptionValue<>(50); + public static final OptionValue LoopUnswitchMaxIncrease = newOption(50); @Option(help = "") - public static final OptionValue LoopUnswitchUncertaintyBoost = new OptionValue<>(5); + public static final OptionValue LoopUnswitchUncertaintyBoost = newOption(5); @Option(help = "") - public static final OptionValue UseLoopLimitChecks = new OptionValue<>(true); + public static final OptionValue UseLoopLimitChecks = newOption(true); // debugging settings @Option(help = "") - public static final OptionValue ZapStackOnMethodEntry = new OptionValue<>(false); + public static final OptionValue ZapStackOnMethodEntry = newOption(false); @Option(help = "") - public static final OptionValue DeoptALot = new OptionValue<>(false); + public static final OptionValue DeoptALot = newOption(false); @Option(help = "") - public static final OptionValue VerifyPhases = new OptionValue<>(false); + public static final OptionValue VerifyPhases = newOption(false); @Option(help = "") - public static final OptionValue PrintFilter = new OptionValue<>(null); + public static final OptionValue PrintFilter = OptionValue.newOption(null); // Debug settings: @Option(help = "") - public static final OptionValue BootstrapReplacements = new OptionValue<>(false); + public static final OptionValue BootstrapReplacements = newOption(false); // Ideal graph visualizer output settings @Option(help = "") - public static final OptionValue PrintBinaryGraphs = new OptionValue<>(true); + public static final OptionValue PrintBinaryGraphs = newOption(true); @Option(help = "") - public static final OptionValue PrintCFG = new OptionValue<>(false); + public static final OptionValue PrintCFG = newOption(false); @Option(help = "") - public static final OptionValue PrintIdealGraphFile = new OptionValue<>(false); + public static final OptionValue PrintIdealGraphFile = newOption(false); @Option(help = "") - public static final OptionValue PrintIdealGraphAddress = new OptionValue<>("127.0.0.1"); + public static final OptionValue PrintIdealGraphAddress = OptionValue.newOption("127.0.0.1"); @Option(help = "") - public static final OptionValue PrintIdealGraphPort = new OptionValue<>(4444); + public static final OptionValue PrintIdealGraphPort = newOption(4444); @Option(help = "") - public static final OptionValue PrintBinaryGraphPort = new OptionValue<>(4445); + public static final OptionValue PrintBinaryGraphPort = newOption(4445); // Other printing settings @Option(help = "") - public static final OptionValue PrintCompilation = new OptionValue<>(false); + public static final OptionValue PrintCompilation = newOption(false); @Option(help = "") - public static final OptionValue PrintProfilingInformation = new OptionValue<>(false); + public static final OptionValue PrintProfilingInformation = newOption(false); @Option(help = "") - public static final OptionValue PrintIRWithLIR = new OptionValue<>(false); + public static final OptionValue PrintIRWithLIR = newOption(false); @Option(help = "") - public static final OptionValue PrintCodeBytes = new OptionValue<>(false); + public static final OptionValue PrintCodeBytes = newOption(false); @Option(help = "") - public static final OptionValue PrintBailout = new OptionValue<>(false); + public static final OptionValue PrintBailout = newOption(false); @Option(help = "") - public static final OptionValue TraceLinearScanLevel = new OptionValue<>(0); + public static final OptionValue TraceLinearScanLevel = newOption(0); @Option(help = "") - public static final OptionValue TraceLIRGeneratorLevel = new OptionValue<>(0); + public static final OptionValue TraceLIRGeneratorLevel = newOption(0); @Option(help = "") - public static final OptionValue TraceEscapeAnalysis = new OptionValue<>(false); + public static final OptionValue TraceEscapeAnalysis = newOption(false); @Option(help = "") - public static final OptionValue TraceBytecodeParserLevel = new OptionValue<>(0); + public static final OptionValue TraceBytecodeParserLevel = newOption(0); @Option(help = "") - public static final OptionValue ExitVMOnBailout = new OptionValue<>(false); + public static final OptionValue ExitVMOnBailout = newOption(false); @Option(help = "") - public static final OptionValue ExitVMOnException = new OptionValue<>(true); + public static final OptionValue ExitVMOnException = newOption(true); @Option(help = "") - public static final OptionValue PrintStackTraceOnException = new OptionValue<>(false); + public static final OptionValue PrintStackTraceOnException = newOption(false); // HotSpot command line options @Option(help = "") - public static final OptionValue HotSpotPrintCompilation = new OptionValue<>(false); + public static final OptionValue HotSpotPrintCompilation = newOption(false); @Option(help = "") - public static final OptionValue HotSpotPrintInlining = new OptionValue<>(false); + public static final OptionValue HotSpotPrintInlining = newOption(false); // Register allocator debugging @Option(help = "") - public static final OptionValue RegisterPressure = new OptionValue<>(null); + public static final OptionValue RegisterPressure = OptionValue.newOption(null); // Code generator settings @Option(help = "") - public static final OptionValue ConditionalElimination = new OptionValue<>(true); + public static final OptionValue ConditionalElimination = newOption(true); @Option(help = "") - public static final OptionValue CullFrameStates = new OptionValue<>(false); + public static final OptionValue CullFrameStates = newOption(false); @Option(help = "") - public static final OptionValue UseProfilingInformation = new OptionValue<>(true); + public static final OptionValue UseProfilingInformation = newOption(true); @Option(help = "") - static final OptionValue RemoveNeverExecutedCode = new OptionValue<>(true); + static final OptionValue RemoveNeverExecutedCode = newOption(true); @Option(help = "") - static final OptionValue UseExceptionProbability = new OptionValue<>(true); + static final OptionValue UseExceptionProbability = newOption(true); @Option(help = "") - static final OptionValue UseExceptionProbabilityForOperations = new OptionValue<>(true); + static final OptionValue UseExceptionProbabilityForOperations = newOption(true); @Option(help = "") - public static final OptionValue OmitHotExceptionStacktrace = new OptionValue<>(false); + public static final OptionValue OmitHotExceptionStacktrace = newOption(false); @Option(help = "") - public static final OptionValue GenSafepoints = new OptionValue<>(true); + public static final OptionValue GenSafepoints = newOption(true); @Option(help = "") - public static final OptionValue GenLoopSafepoints = new OptionValue<>(true); + public static final OptionValue GenLoopSafepoints = newOption(true); @Option(help = "") - static final OptionValue UseTypeCheckHints = new OptionValue<>(true); + static final OptionValue UseTypeCheckHints = newOption(true); @Option(help = "") - public static final OptionValue InlineVTableStubs = new OptionValue<>(true); + public static final OptionValue InlineVTableStubs = newOption(true); @Option(help = "") - public static final OptionValue AlwaysInlineVTableStubs = new OptionValue<>(false); + public static final OptionValue AlwaysInlineVTableStubs = newOption(false); @Option(help = "") - public static final OptionValue GenAssertionCode = new OptionValue<>(false); + public static final OptionValue GenAssertionCode = newOption(false); @Option(help = "") - public static final OptionValue AlignCallsForPatching = new OptionValue<>(true); + public static final OptionValue AlignCallsForPatching = newOption(true); @Option(help = "") - public static final OptionValue ResolveClassBeforeStaticInvoke = new OptionValue<>(false); + public static final OptionValue ResolveClassBeforeStaticInvoke = newOption(false); @Option(help = "") - public static final OptionValue CanOmitFrame = new OptionValue<>(true); + public static final OptionValue CanOmitFrame = newOption(true); @Option(help = "") - public static final OptionValue SafepointPollOffset = new OptionValue<>(256); + public static final OptionValue SafepointPollOffset = newOption(256); @Option(help = "") - public static final OptionValue MemoryAwareScheduling = new OptionValue<>(true); + public static final OptionValue MemoryAwareScheduling = newOption(true); // Translating tableswitch instructions @Option(help = "") - public static final OptionValue MinimumJumpTableSize = new OptionValue<>(5); + public static final OptionValue MinimumJumpTableSize = newOption(5); @Option(help = "") - public static final OptionValue RangeTestsSwitchDensity = new OptionValue<>(5); + public static final OptionValue RangeTestsSwitchDensity = newOption(5); @Option(help = "") - public static final OptionValue MinTableSwitchDensity = new OptionValue<>(0.5); + public static final OptionValue MinTableSwitchDensity = newOption(0.5); // Runtime settings @Option(help = "") - public static final OptionValue StackShadowPages = new OptionValue<>(2); + public static final OptionValue StackShadowPages = newOption(2); @Option(help = "") - public static final OptionValue SupportJsrBytecodes = new OptionValue<>(true); + public static final OptionValue SupportJsrBytecodes = newOption(true); @Option(help = "") - public static final OptionValue OptAssumptions = new OptionValue<>(true); + public static final OptionValue OptAssumptions = newOption(true); @Option(help = "") - public static final OptionValue OptConvertDeoptsToGuards = new OptionValue<>(true); + public static final OptionValue OptConvertDeoptsToGuards = newOption(true); @Option(help = "") - public static final OptionValue OptReadElimination = new OptionValue<>(true); + public static final OptionValue OptReadElimination = newOption(true); @Option(help = "") - public static final OptionValue OptEarlyReadElimination = new OptionValue<>(true); + public static final OptionValue OptEarlyReadElimination = newOption(true); @Option(help = "") - public static final OptionValue OptCanonicalizer = new OptionValue<>(true); + public static final OptionValue OptCanonicalizer = newOption(true); @Option(help = "") - public static final OptionValue OptCanonicalizeReads = new OptionValue<>(true); + public static final OptionValue OptCanonicalizeReads = newOption(true); @Option(help = "") - public static final OptionValue OptScheduleOutOfLoops = new OptionValue<>(true); + public static final OptionValue OptScheduleOutOfLoops = newOption(true); @Option(help = "") - public static final OptionValue OptEliminateGuards = new OptionValue<>(true); + public static final OptionValue OptEliminateGuards = newOption(true); @Option(help = "") - public static final OptionValue OptEliminateSafepoints = new OptionValue<>(true); + public static final OptionValue OptEliminateSafepoints = newOption(true); @Option(help = "") - public static final OptionValue OptImplicitNullChecks = new OptionValue<>(true); + public static final OptionValue OptImplicitNullChecks = newOption(true); @Option(help = "") - public static final OptionValue OptLivenessAnalysis = new OptionValue<>(true); + public static final OptionValue OptLivenessAnalysis = newOption(true); @Option(help = "") - public static final OptionValue OptLoopTransform = new OptionValue<>(true); + public static final OptionValue OptLoopTransform = newOption(true); @Option(help = "") - public static final OptionValue OptFloatingReads = new OptionValue<>(true); + public static final OptionValue OptFloatingReads = newOption(true); @Option(help = "") - public static final OptionValue OptTailDuplication = new OptionValue<>(true); + public static final OptionValue OptTailDuplication = newOption(true); @Option(help = "") - public static final OptionValue OptEliminatePartiallyRedundantGuards = new OptionValue<>(true); + public static final OptionValue OptEliminatePartiallyRedundantGuards = newOption(true); @Option(help = "") - public static final OptionValue OptFilterProfiledTypes = new OptionValue<>(true); + public static final OptionValue OptFilterProfiledTypes = newOption(true); @Option(help = "") - public static final OptionValue OptDevirtualizeInvokesOptimistically = new OptionValue<>(true); + public static final OptionValue OptDevirtualizeInvokesOptimistically = newOption(true); @Option(help = "") - public static final OptionValue OptPushThroughPi = new OptionValue<>(true); + public static final OptionValue OptPushThroughPi = newOption(true); // Intrinsification settings @Option(help = "") - public static final OptionValue IntrinsifyObjectClone = new OptionValue<>(false); + public static final OptionValue IntrinsifyObjectClone = newOption(false); @Option(help = "") - public static final OptionValue IntrinsifyArrayCopy = new OptionValue<>(true); + public static final OptionValue IntrinsifyArrayCopy = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyObjectMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyObjectMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifySystemMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifySystemMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyClassMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyClassMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyThreadMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyThreadMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyUnsafeMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyUnsafeMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyMathMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyMathMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyAESMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyAESMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyReflectionMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyReflectionMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyInstalledCodeMethods = new OptionValue<>(true); + public static final OptionValue IntrinsifyInstalledCodeMethods = newOption(true); @Option(help = "") - public static final OptionValue IntrinsifyCallSiteTarget = new OptionValue<>(true); + public static final OptionValue IntrinsifyCallSiteTarget = newOption(true); /** * Counts the various paths taken through snippets. */ @Option(help = "") - public static final OptionValue SnippetCounters = new OptionValue<>(false); + public static final OptionValue SnippetCounters = newOption(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 = new OptionValue<>(0.5); + public static final OptionValue CheckcastMinHintHitProbability = newOption(0.5); /** * The maximum number of hint types that will be used when compiling a checkcast for which @@ -335,17 +337,17 @@ * also influences whether hints are used. */ @Option(help = "") - public static final OptionValue CheckcastMaxHints = new OptionValue<>(2); + public static final OptionValue CheckcastMaxHints = newOption(2); /** * @see #CheckcastMinHintHitProbability */ @Option(help = "") - public static final OptionValue InstanceOfMinHintHitProbability = new OptionValue<>(0.5); + public static final OptionValue InstanceOfMinHintHitProbability = newOption(0.5); /** * @see #CheckcastMaxHints */ @Option(help = "") - public static final OptionValue InstanceOfMaxHints = new OptionValue<>(2); + public static final OptionValue InstanceOfMaxHints = newOption(2); } diff -r 6ceff6124679 -r fbad7372eccd 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 13:09:09 2013 +0200 +++ b/graal/com.oracle.graal.phases/src/com/oracle/graal/phases/tiers/Suites.java Thu Jun 06 15:35:52 2013 +0200 @@ -32,7 +32,7 @@ // @formatter:off @Option(help = "The compiler configuration to use") - private static final OptionValue CompilerConfiguration = new OptionValue<>("basic"); + private static final OptionValue CompilerConfiguration = OptionValue.newOption("basic"); // @formatter:on public static final Suites DEFAULT;