src/hotspot/share/c1/c1_globals.hpp
author pliden
Mon, 14 May 2018 15:42:59 +0200
changeset 50102 454fa295105c
parent 47216 71c04702a3d5
child 53244 9807daeb47c4
permissions -rw-r--r--
8202976: Add C1 lea patching support for x86 Reviewed-by: kvn, neliasso
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
38273
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
     2
 * Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5353
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5353
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5353
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
    25
#ifndef SHARE_VM_C1_C1_GLOBALS_HPP
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
    26
#define SHARE_VM_C1_C1_GLOBALS_HPP
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
    27
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
    28
#include "runtime/globals.hpp"
40010
e32d5e545789 8161258: Simplify including platform files.
goetz
parents: 39117
diff changeset
    29
#include "utilities/macros.hpp"
e32d5e545789 8161258: Simplify including platform files.
goetz
parents: 39117
diff changeset
    30
e32d5e545789 8161258: Simplify including platform files.
goetz
parents: 39117
diff changeset
    31
#include CPU_HEADER(c1_globals)
e32d5e545789 8161258: Simplify including platform files.
goetz
parents: 39117
diff changeset
    32
#include OS_HEADER(c1_globals)
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
    33
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
// Defines all global flags used by the client compiler.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
//
38273
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    37
#define C1_FLAGS(develop, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    38
                 develop_pd, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    39
                 product, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    40
                 product_pd, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    41
                 diagnostic, \
39117
59fa99a45873 8150900: Implement diagnostic_pd
csahu
parents: 38289
diff changeset
    42
                 diagnostic_pd, \
38273
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    43
                 notproduct, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    44
                 range, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    45
                 constraint, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
    46
                 writeable) \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
  /* Printing */                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
  notproduct(bool, PrintC1Statistics, false,                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
          "Print Compiler1 statistics" )                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
  notproduct(bool, PrintInitialBlockList, false,                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
          "Print block list of BlockListBuilder")                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
  notproduct(bool, PrintCFG, false,                                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
          "Print control flow graph after each change")                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
  notproduct(bool, PrintCFG0, false,                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
          "Print control flow graph after construction")                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
  notproduct(bool, PrintCFG1, false,                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
          "Print control flow graph after optimizations")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
  notproduct(bool, PrintCFG2, false,                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
          "Print control flow graph before code generation")                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
  notproduct(bool, PrintIRDuringConstruction, false,                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
          "Print IR as it's being constructed (helpful for debugging frontend)")\
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
    70
  notproduct(bool, PrintPhiFunctions, false,                                \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
          "Print phi functions when they are created and simplified")       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
  notproduct(bool, PrintIR, false,                                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
          "Print full intermediate representation after each change")       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
  notproduct(bool, PrintIR0, false,                                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
          "Print full intermediate representation after construction")      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  notproduct(bool, PrintIR1, false,                                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
          "Print full intermediate representation after optimizations")     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
  notproduct(bool, PrintIR2, false,                                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
          "Print full intermediate representation before code generation")  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
  notproduct(bool, PrintSimpleStubs, false,                                 \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
          "Print SimpleStubs")                                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
  /* C1 optimizations */                                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
  develop(bool, UseC1Optimizations, true,                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
          "Turn on C1 optimizations")                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
  develop(bool, SelectivePhiFunctions, true,                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
          "create phi functions at loop headers only when necessary")       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
                                                                            \
7100
6bcf9255d470 6991577: add IfOp optimization to C1
roland
parents: 6745
diff changeset
    96
  develop(bool, OptimizeIfOps, true,                                        \
6bcf9255d470 6991577: add IfOp optimization to C1
roland
parents: 6745
diff changeset
    97
          "Optimize multiple IfOps")                                        \
6bcf9255d470 6991577: add IfOp optimization to C1
roland
parents: 6745
diff changeset
    98
                                                                            \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
  develop(bool, DoCEE, true,                                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
          "Do Conditional Expression Elimination to simplify CFG")          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
  develop(bool, PrintCEE, false,                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
          "Print Conditional Expression Elimination")                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
  develop(bool, UseLocalValueNumbering, true,                               \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
          "Use Local Value Numbering (embedded in GraphBuilder)")           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
  develop(bool, UseGlobalValueNumbering, true,                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
          "Use Global Value Numbering (separate phase)")                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
                                                                            \
16611
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   111
  product(bool, UseLoopInvariantCodeMotion, true,                           \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   112
          "Simple loop invariant code motion for short loops during GVN")   \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   113
                                                                            \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   114
  develop(bool, TracePredicateFailedTraps, false,                           \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   115
          "trace runtime traps caused by predicate failure")                \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   116
                                                                            \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   117
  develop(bool, StressLoopInvariantCodeMotion, false,                       \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   118
          "stress loop invariant code motion")                              \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   119
                                                                            \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   120
  develop(bool, TraceRangeCheckElimination, false,                          \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   121
          "Trace Range Check Elimination")                                  \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   122
                                                                            \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   123
  develop(bool, AssertRangeCheckElimination, false,                         \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   124
          "Assert Range Check Elimination")                                 \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   125
                                                                            \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   126
  develop(bool, StressRangeCheckElimination, false,                         \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   127
          "stress Range Check Elimination")                                 \
6807a703dd6b 7153771: array bound check elimination for c1
roland
parents: 15200
diff changeset
   128
                                                                            \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
  develop(bool, PrintValueNumbering, false,                                 \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
          "Print Value Numbering")                                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
  product(intx, ValueMapInitialSize, 11,                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
          "Initial size of a value map")                                    \
31371
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   134
          range(1, NOT_LP64(1*K) LP64_ONLY(32*K))                           \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
  product(intx, ValueMapMaxLoopSize, 8,                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
          "maximum size of a loop optimized by global value numbering")     \
33163
9e128b399e48 8078554: Compiler: implement ranges (optionally constraints) for those flags that have them missing
zmajo
parents: 31371
diff changeset
   138
          range(0, 128)                                                     \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
  develop(bool, EliminateBlocks, true,                                      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
          "Eliminate unneccessary basic blocks")                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
  develop(bool, PrintBlockElimination, false,                               \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
          "Print basic block elimination")                                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
  develop(bool, EliminateNullChecks, true,                                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
          "Eliminate unneccessary null checks")                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
  develop(bool, PrintNullCheckElimination, false,                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
          "Print null check elimination")                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
  develop(bool, EliminateFieldAccess, true,                                 \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
          "Optimize field loads and stores")                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
  develop(bool, InlineMethodsWithExceptionHandlers, true,                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
          "Inline methods containing exception handlers "                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
          "(NOTE: does not work with current backend)")                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
                                                                            \
15200
73bac1831823 8005639: Move InlineSynchronizedMethods flag from develop to product
vladidan
parents: 13728
diff changeset
   159
  product(bool, InlineSynchronizedMethods, true,                            \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
          "Inline synchronized methods")                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
                                                                            \
38285
20b85a0ba796 8153655: Make intrinsics flags diagnostic and update intrinsics tests to enable diagnostic options
rraghavan
parents: 37268
diff changeset
   162
  diagnostic(bool, InlineNIOCheckIndex, true,                               \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
          "Intrinsify java.nio.Buffer.checkIndex")                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
  develop(bool, CanonicalizeNodes, true,                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
          "Canonicalize graph nodes")                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
  develop(bool, PrintCanonicalization, false,                               \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
          "Print graph node canonicalization")                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
  develop(bool, UseTableRanges, true,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
          "Faster versions of lookup table using ranges")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
  develop_pd(bool, RoundFPResults,                                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
          "Indicates whether rounding is needed for floating point results")\
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
  develop(intx, NestedInliningSizeRatio, 90,                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
          "Percentage of prev. allowed inline size in recursive inlining")  \
31371
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   179
          range(0, 100)                                                     \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
  notproduct(bool, PrintIRWithLIR, false,                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
          "Print IR instructions with generated LIR")                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
  notproduct(bool, PrintLIRWithAssembly, false,                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
          "Show LIR instruction with generated assembly")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
  develop(bool, CommentedAssembly, trueInDebug,                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
          "Show extra info in PrintNMethods output")                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
  develop(bool, LIRTracePeephole, false,                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
          "Trace peephole optimizer")                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
  develop(bool, LIRTraceExecution, false,                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
          "add LIR code which logs the execution of blocks")                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
  product_pd(bool, LIRFillDelaySlots,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
             "fill delays on on SPARC with LIR")                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
  develop_pd(bool, CSEArrayLength,                                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
          "Create separate nodes for length in array accesses")             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   202
  develop_pd(bool, TwoOperandLIRForm,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   203
          "true if LIR requires src1 and dst to match in binary LIR ops")   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   204
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   205
  develop(intx, TraceLinearScanLevel, 0,                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
          "Debug levels for the linear scan allocator")                     \
33163
9e128b399e48 8078554: Compiler: implement ranges (optionally constraints) for those flags that have them missing
zmajo
parents: 31371
diff changeset
   207
          range(0, 4)                                                       \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   208
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
  develop(bool, StressLinearScan, false,                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   210
          "scramble block order used by LinearScan (stress test)")          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   211
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
  product(bool, TimeLinearScan, false,                                      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
          "detailed timing of LinearScan phases")                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
  develop(bool, TimeEachLinearScan, false,                                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
          "print detailed timing of each LinearScan run")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
  develop(bool, CountLinearScan, false,                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
          "collect statistic counters during LinearScan")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
  /* C1 variable */                                                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
  develop(bool, C1Breakpoint, false,                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
          "Sets a breakpoint at entry of each compiled method")             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
  develop(bool, ImplicitDiv0Checks, true,                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
          "Use implicit division by zero checks")                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
  develop(bool, PinAllInstructions, false,                                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
          "All instructions are pinned")                                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
  develop(bool, UseFastNewInstance, true,                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
          "Use fast inlined instance allocation")                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
  develop(bool, UseFastNewTypeArray, true,                                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
          "Use fast inlined type array allocation")                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
  develop(bool, UseFastNewObjectArray, true,                                \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
          "Use fast inlined object array allocation")                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
  develop(bool, UseFastLocking, true,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
          "Use fast inlined locking code")                                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
  develop(bool, UseSlowPath, false,                                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
          "For debugging: test slow cases by always using them")            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
  develop(bool, GenerateArrayStoreCheck, true,                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
          "Generates code for array store checks")                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
  develop(bool, DeoptC1, true,                                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
          "Use deoptimization in C1")                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
  develop(bool, PrintBailouts, false,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
          "Print bailout and its reason")                                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
  develop(bool, TracePatching, false,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
         "Trace patching of field access on uninitialized classes")         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
  develop(bool, PatchALot, false,                                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
          "Marks all fields as having unloaded classes")                    \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
  develop(bool, PrintNotLoaded, false,                                      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
          "Prints where classes are not loaded during code generation")     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
  develop(bool, PrintLIR, false,                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
          "print low-level IR")                                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
  develop(bool, BailoutAfterHIR, false,                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
          "bailout of compilation after building of HIR")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
  develop(bool, BailoutAfterLIR, false,                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
          "bailout of compilation after building of LIR")                   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
  develop(bool, BailoutOnExceptionHandlers, false,                          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
          "bailout of compilation for methods with exception handlers")     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
  develop(bool, InstallMethods, true,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
          "Install methods at the end of successful compilations")          \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
                                                                            \
10505
df3cc194efc5 7085279: C1 overflows code buffer with VerifyOops and CompressedOops
iveresov
parents: 8921
diff changeset
   280
  develop(intx, NMethodSizeLimit, (64*K)*wordSize,                          \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
          "Maximum size of a compiled method.")                             \
33163
9e128b399e48 8078554: Compiler: implement ranges (optionally constraints) for those flags that have them missing
zmajo
parents: 31371
diff changeset
   282
          range(0, max_jint)                                                \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
  develop(bool, TraceFPUStack, false,                                       \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
          "Trace emulation of the FPU stack (intel only)")                  \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
  develop(bool, TraceFPURegisterUsage, false,                               \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
          "Trace usage of FPU registers at start of blocks (intel only)")   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
  develop(bool, OptimizeUnsafes, true,                                      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
          "Optimize raw unsafe ops")                                        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
  develop(bool, PrintUnsafeOptimization, false,                             \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
          "Print optimization of raw unsafe ops")                           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
  develop(intx, InstructionCountCutoff, 37000,                              \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
          "If GraphBuilder adds this many instructions, bails out")         \
33163
9e128b399e48 8078554: Compiler: implement ranges (optionally constraints) for those flags that have them missing
zmajo
parents: 31371
diff changeset
   298
          range(0, max_jint)                                                \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
  develop(bool, ComputeExactFPURegisterUsage, true,                         \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
          "Compute additional live set for fpu registers to simplify fpu stack merge (Intel only)") \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   303
  product(bool, C1ProfileCalls, true,                                       \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
          "Profile calls when generating code for updating MDOs")           \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   306
  product(bool, C1ProfileVirtualCalls, true,                                \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
          "Profile virtual calls when generating code for updating MDOs")   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   309
  product(bool, C1ProfileInlinedCalls, true,                                \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
          "Profile inlined calls when generating code for updating MDOs")   \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   312
  product(bool, C1ProfileBranches, true,                                    \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
          "Profile branches when generating code for updating MDOs")        \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   315
  product(bool, C1ProfileCheckcasts, true,                                  \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
          "Profile checkcasts when generating code for updating MDOs")      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   318
  product(bool, C1OptimizeVirtualCallProfiling, true,                       \
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   319
          "Use CHA and exact type results at call sites when updating MDOs")\
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
                                                                            \
6453
970dc585ab63 6953144: Tiered compilation
iveresov
parents: 5547
diff changeset
   321
  product(bool, C1UpdateMethodData, trueInTiered,                           \
19710
2f8ca425504e 7199175: JSR 292: C1 needs patching when invokedynamic/invokehandle call site is not linked
roland
parents: 16611
diff changeset
   322
          "Update MethodData*s in Tier1-generated code")                    \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
  develop(bool, PrintCFGToFile, false,                                      \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
          "print control flow graph to a separate file during compilation") \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
                                                                            \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
// Read default values for c1 globals
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
31371
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   329
C1_FLAGS(DECLARE_DEVELOPER_FLAG, \
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   330
         DECLARE_PD_DEVELOPER_FLAG, \
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   331
         DECLARE_PRODUCT_FLAG, \
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   332
         DECLARE_PD_PRODUCT_FLAG, \
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   333
         DECLARE_DIAGNOSTIC_FLAG, \
39117
59fa99a45873 8150900: Implement diagnostic_pd
csahu
parents: 38289
diff changeset
   334
         DECLARE_PD_DIAGNOSTIC_FLAG, \
31371
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   335
         DECLARE_NOTPRODUCT_FLAG, \
311143309e73 8122937: [JEP 245] Validate JVM Command-Line Flag Arguments.
gziemski
parents: 29180
diff changeset
   336
         IGNORE_RANGE, \
38273
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
   337
         IGNORE_CONSTRAINT, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 37268
diff changeset
   338
         IGNORE_WRITEABLE)
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
   339
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7100
diff changeset
   340
#endif // SHARE_VM_C1_C1_GLOBALS_HPP