src/hotspot/cpu/aarch64/globals_aarch64.hpp
author chegar
Thu, 17 Oct 2019 20:54:25 +0100
branchdatagramsocketimpl-branch
changeset 58679 9c3209ff7550
parent 58678 9cf78a70fa4f
parent 57804 9b7b9f16dfd9
permissions -rw-r--r--
datagramsocketimpl-branch: merge with default
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     1
/*
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52460
diff changeset
     2
 * Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.
57804
9b7b9f16dfd9 8224974: Implement JEP 352
adinn
parents: 57779
diff changeset
     3
 * Copyright (c) 2015, 2019, Red Hat Inc. All rights reserved.
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     5
 *
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     8
 * published by the Free Software Foundation.
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
     9
 *
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    14
 * accompanied this code).
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    15
 *
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    19
 *
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    22
 * questions.
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    23
 *
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    24
 */
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    25
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52460
diff changeset
    26
#ifndef CPU_AARCH64_GLOBALS_AARCH64_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52460
diff changeset
    27
#define CPU_AARCH64_GLOBALS_AARCH64_HPP
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    28
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    29
#include "utilities/globalDefinitions.hpp"
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    30
#include "utilities/macros.hpp"
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    31
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    32
// Sets the default values for platform dependent flags used by the runtime system.
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    33
// (see globals.hpp)
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    34
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    35
define_pd_global(bool, ImplicitNullChecks,       true);  // Generate code for implicit null checks
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    36
define_pd_global(bool, TrapBasedNullChecks,  false);
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    37
define_pd_global(bool, UncommonNullCast,         true);  // Uncommon-trap NULLs past to check cast
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    38
42062
473286891dd8 8166560: [s390] Basic enablement of s390 port.
goetz
parents: 40065
diff changeset
    39
define_pd_global(uintx, CodeCacheSegmentSize,    64 TIERED_ONLY(+64)); // Tiered compilation has large code-entry alignment.
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    40
define_pd_global(intx, CodeEntryAlignment,       64);
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    41
define_pd_global(intx, OptoLoopAlignment,        16);
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    42
define_pd_global(intx, InlineFrequencyCount,     100);
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    43
33222
e0a340f4ab6e 8078556: Runtime: implement ranges (optionally constraints) for those flags that have them missing.
gziemski
parents: 31783
diff changeset
    44
#define DEFAULT_STACK_YELLOW_PAGES (2)
e0a340f4ab6e 8078556: Runtime: implement ranges (optionally constraints) for those flags that have them missing.
gziemski
parents: 31783
diff changeset
    45
#define DEFAULT_STACK_RED_PAGES (1)
43290
eec57137c0a6 8173339: AArch64: Fix minimum stack size computations
adinn
parents: 42062
diff changeset
    46
// Java_java_net_SocketOutputStream_socketWrite0() uses a 64k buffer on the
eec57137c0a6 8173339: AArch64: Fix minimum stack size computations
adinn
parents: 42062
diff changeset
    47
// stack if compiled for unix and LP64. To pass stack overflow tests we need
eec57137c0a6 8173339: AArch64: Fix minimum stack size computations
adinn
parents: 42062
diff changeset
    48
// 20 shadow pages.
eec57137c0a6 8173339: AArch64: Fix minimum stack size computations
adinn
parents: 42062
diff changeset
    49
#define DEFAULT_STACK_SHADOW_PAGES (20 DEBUG_ONLY(+5))
43439
5e03c9ba74f3 8172144: AArch64: Implement "JEP 270: Reserved Stack Areas for Critical Sections"
aph
parents: 42062
diff changeset
    50
#define DEFAULT_STACK_RESERVED_PAGES (1)
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    51
38079
fd24ad51113a 8154379: MIN_STACK_SHADOW_PAGES should equal DEFAULT_STACK_SHADOW_PAGES on aarch64
cjplummer
parents: 38037
diff changeset
    52
#define MIN_STACK_YELLOW_PAGES DEFAULT_STACK_YELLOW_PAGES
fd24ad51113a 8154379: MIN_STACK_SHADOW_PAGES should equal DEFAULT_STACK_SHADOW_PAGES on aarch64
cjplummer
parents: 38037
diff changeset
    53
#define MIN_STACK_RED_PAGES    DEFAULT_STACK_RED_PAGES
fd24ad51113a 8154379: MIN_STACK_SHADOW_PAGES should equal DEFAULT_STACK_SHADOW_PAGES on aarch64
cjplummer
parents: 38037
diff changeset
    54
#define MIN_STACK_SHADOW_PAGES DEFAULT_STACK_SHADOW_PAGES
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 33628
diff changeset
    55
#define MIN_STACK_RESERVED_PAGES (0)
33222
e0a340f4ab6e 8078556: Runtime: implement ranges (optionally constraints) for those flags that have them missing.
gziemski
parents: 31783
diff changeset
    56
e0a340f4ab6e 8078556: Runtime: implement ranges (optionally constraints) for those flags that have them missing.
gziemski
parents: 31783
diff changeset
    57
define_pd_global(intx, StackYellowPages, DEFAULT_STACK_YELLOW_PAGES);
e0a340f4ab6e 8078556: Runtime: implement ranges (optionally constraints) for those flags that have them missing.
gziemski
parents: 31783
diff changeset
    58
define_pd_global(intx, StackRedPages, DEFAULT_STACK_RED_PAGES);
e0a340f4ab6e 8078556: Runtime: implement ranges (optionally constraints) for those flags that have them missing.
gziemski
parents: 31783
diff changeset
    59
define_pd_global(intx, StackShadowPages, DEFAULT_STACK_SHADOW_PAGES);
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 33628
diff changeset
    60
define_pd_global(intx, StackReservedPages, DEFAULT_STACK_RESERVED_PAGES);
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    61
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    62
define_pd_global(bool, RewriteBytecodes,     true);
30889
325a4db0d161 8081289: aarch64: add support for RewriteFrequentPairs in interpreter
enevill
parents: 30429
diff changeset
    63
define_pd_global(bool, RewriteFrequentPairs, true);
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    64
30305
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 29183
diff changeset
    65
define_pd_global(bool, PreserveFramePointer, false);
b92a97e1e9cb 8068945: Use RBP register as proper frame pointer in JIT compiled code on x86
zmajo
parents: 29183
diff changeset
    66
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    67
// GC Ergo Flags
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    68
define_pd_global(uintx, CMSYoungGenPerWorker, 64*M);  // default max size of CMS young gen, per GC worker thread
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    69
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    70
define_pd_global(uintx, TypeProfileLevel, 111);
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    71
40065
dc29d43b51b5 8159467: AArch64: Enable compact strings
aph
parents: 40023
diff changeset
    72
define_pd_global(bool, CompactStrings, true);
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    73
38037
31c22b526d30 8153713: aarch64: improve short array clearing using store pair
fyang
parents: 36564
diff changeset
    74
// Clear short arrays bigger than one word in an arch-specific way
31c22b526d30 8153713: aarch64: improve short array clearing using store pair
fyang
parents: 36564
diff changeset
    75
define_pd_global(intx, InitArrayShortSize, BytesPerLong);
36554
a7eb9ee4680c 8146801: Allocating short arrays of non-constant size is slow
shade
parents: 36103
diff changeset
    76
48127
efc459cf351e 8189596: AArch64: implementation for Thread-local handshakes
aph
parents: 47881
diff changeset
    77
define_pd_global(bool, ThreadLocalHandshakes, true);
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
    78
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    79
#if defined(COMPILER1) || defined(COMPILER2)
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    80
define_pd_global(intx, InlineSmallCode,          1000);
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    81
#endif
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    82
38273
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    83
#define ARCH_FLAGS(develop, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    84
                   product, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    85
                   diagnostic, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    86
                   experimental, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    87
                   notproduct, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    88
                   range, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    89
                   constraint, \
2634194d7555 8073500: Prevent certain commercial flags from being changed at runtime
gziemski
parents: 38144
diff changeset
    90
                   writeable) \
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    91
                                                                        \
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    92
  product(bool, NearCpool, true,                                        \
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    93
         "constant pool is close to instructions")                      \
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    94
                                                                        \
30429
c980154ed1a3 8079203: AARCH64: Need to cater for different partner implementations
enevill
parents: 30305
diff changeset
    95
  product(bool, UseBarriersForVolatile, false,                          \
c980154ed1a3 8079203: AARCH64: Need to cater for different partner implementations
enevill
parents: 30305
diff changeset
    96
          "Use memory barriers to implement volatile accesses")         \
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    97
  product(bool, UseNeon, false,                                         \
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    98
          "Use Neon for CRC32 computation")                             \
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
    99
  product(bool, UseCRC32, false,                                        \
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
   100
          "Use CRC32 instructions for CRC32 computation")               \
36564
9442bb67de26 8150313: aarch64: optimise array copy using SIMD instructions
enevill
parents: 36562
diff changeset
   101
  product(bool, UseSIMDForMemoryOps, false,                             \
9442bb67de26 8150313: aarch64: optimise array copy using SIMD instructions
enevill
parents: 36562
diff changeset
   102
          "Use SIMD instructions in generated memory move code")        \
49724
bf7f42f2f025 8187472: AARCH64: array_equals intrinsic doesn't use prefetch for large arrays
dpochepk
parents: 48127
diff changeset
   103
  product(bool, UseSIMDForArrayEquals, true,                            \
bf7f42f2f025 8187472: AARCH64: array_equals intrinsic doesn't use prefetch for large arrays
dpochepk
parents: 48127
diff changeset
   104
          "Use SIMD instructions in generated array equals code")       \
bf7f42f2f025 8187472: AARCH64: array_equals intrinsic doesn't use prefetch for large arrays
dpochepk
parents: 48127
diff changeset
   105
  product(bool, UseSimpleArrayEquals, false,                            \
bf7f42f2f025 8187472: AARCH64: array_equals intrinsic doesn't use prefetch for large arrays
dpochepk
parents: 48127
diff changeset
   106
          "Use simpliest and shortest implementation for array equals") \
40023
49d647eeb7f0 8159063: aarch64: optimise unaligned array copy long
enevill
parents: 38273
diff changeset
   107
  product(bool, AvoidUnalignedAccesses, false,                          \
49d647eeb7f0 8159063: aarch64: optimise unaligned array copy long
enevill
parents: 38273
diff changeset
   108
          "Avoid generating unaligned memory accesses")                 \
36562
4d1e93624d6a 8150394: aarch64: add support for 8.1 LSE CAS instructions
enevill
parents: 36554
diff changeset
   109
  product(bool, UseLSE, false,                                          \
4d1e93624d6a 8150394: aarch64: add support for 8.1 LSE CAS instructions
enevill
parents: 36554
diff changeset
   110
          "Use LSE instructions")                                       \
38143
3b732f17ea7d 8155617: aarch64: ClearArray does not use DC ZVA
enevill
parents: 38037
diff changeset
   111
  product(bool, UseBlockZeroing, true,                                  \
3b732f17ea7d 8155617: aarch64: ClearArray does not use DC ZVA
enevill
parents: 38037
diff changeset
   112
          "Use DC ZVA for block zeroing")                               \
3b732f17ea7d 8155617: aarch64: ClearArray does not use DC ZVA
enevill
parents: 38037
diff changeset
   113
  product(intx, BlockZeroingLowLimit, 256,                              \
3b732f17ea7d 8155617: aarch64: ClearArray does not use DC ZVA
enevill
parents: 38037
diff changeset
   114
          "Minimum size in bytes when block zeroing will be used")      \
3b732f17ea7d 8155617: aarch64: ClearArray does not use DC ZVA
enevill
parents: 38037
diff changeset
   115
          range(1, max_jint)                                            \
46814
2e45cd2fdcb6 8184943: AARCH64: Intrinsify hasNegatives
dpochepk
parents: 43491
diff changeset
   116
  product(bool, TraceTraps, false, "Trace all traps the signal handler")\
2e45cd2fdcb6 8184943: AARCH64: Intrinsify hasNegatives
dpochepk
parents: 43491
diff changeset
   117
  product(int, SoftwarePrefetchHintDistance, -1,                        \
2e45cd2fdcb6 8184943: AARCH64: Intrinsify hasNegatives
dpochepk
parents: 43491
diff changeset
   118
          "Use prfm hint with specified distance in compiled code."     \
2e45cd2fdcb6 8184943: AARCH64: Intrinsify hasNegatives
dpochepk
parents: 43491
diff changeset
   119
          "Value -1 means off.")                                        \
51093
4db6e8715e35 8206265: aarch64 jtreg: assert in TestOptionsWithRanges.jtr
dsamersoff
parents: 49724
diff changeset
   120
          range(-1, 4096)
29183
0cc8699f7372 8068054: AARCH64: Assembler interpreter, shared runtime
aph
parents:
diff changeset
   121
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 52460
diff changeset
   122
#endif // CPU_AARCH64_GLOBALS_AARCH64_HPP