src/hotspot/share/runtime/thread.hpp
author mgronlun
Wed, 25 Sep 2019 22:40:41 +0200
branchJEP-349-branch
changeset 58343 ca19b94eac7a
parent 58249 e17143e28542
parent 58291 a013100f7a35
child 58495 465ba4fefe62
permissions -rw-r--r--
Merge
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
53149
259c36ef27df 8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents: 53103
diff changeset
     2
 * Copyright (c) 1997, 2019, 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: 5252
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5252
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: 5252
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
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53149
diff changeset
    25
#ifndef SHARE_RUNTIME_THREAD_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53149
diff changeset
    26
#define SHARE_RUNTIME_THREAD_HPP
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    27
47659
a8e9aff89f7b 8189608: Remove duplicated jni.h
ihse
parents: 47637
diff changeset
    28
#include "jni.h"
52673
61b3b58a1d1d 8214181: safepoint header cleanup
rehn
parents: 52431
diff changeset
    29
#include "code/compiledMethod.hpp"
49752
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
    30
#include "gc/shared/gcThreadLocalData.hpp"
30764
fec48bf5a827 8079792: GC directory structure cleanup
pliden
parents: 30614
diff changeset
    31
#include "gc/shared/threadLocalAllocBuffer.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    32
#include "memory/allocation.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    33
#include "oops/oop.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    34
#include "prims/jvmtiExport.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    35
#include "runtime/frame.hpp"
49982
9042ffe5b7fe 8200729: Conditional compilation of GCs
stefank
parents: 49956
diff changeset
    36
#include "runtime/globals.hpp"
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
    37
#include "runtime/handshake.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    38
#include "runtime/javaFrameAnchor.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    39
#include "runtime/jniHandles.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    40
#include "runtime/mutexLocker.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    41
#include "runtime/os.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    42
#include "runtime/osThread.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    43
#include "runtime/park.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    44
#include "runtime/stubRoutines.hpp"
50578
e2a7f431f65c 8203394: Implementation of JEP 331: Low-Overhead Heap Profiling
jcbeyler
parents: 50113
diff changeset
    45
#include "runtime/threadHeapSampler.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    46
#include "runtime/threadLocalStorage.hpp"
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
    47
#include "runtime/threadStatisticalInfo.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    48
#include "runtime/unhandledOops.hpp"
46625
edefffab74e2 8183552: Move align functions to align.hpp
stefank
parents: 46619
diff changeset
    49
#include "utilities/align.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    50
#include "utilities/exceptions.hpp"
27247
99db666dbe8e 8056240: Investigate increased GC remark time after class unloading changes in CRM Fuse
stefank
parents: 26834
diff changeset
    51
#include "utilities/macros.hpp"
40010
e32d5e545789 8161258: Simplify including platform files.
goetz
parents: 38734
diff changeset
    52
#ifdef ZERO
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    53
# include "stack_zero.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    54
#endif
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
    55
#if INCLUDE_JFR
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
    56
#include "jfr/support/jfrThreadExtension.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
    57
#endif
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
    58
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
    59
49956
a87f2e7a527c 8191798: redo nested ThreadsListHandle to drop Threads_lock
dcubed
parents: 49848
diff changeset
    60
class SafeThreadsListPtr;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
class ThreadSafepointState;
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
    62
class ThreadsList;
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
    63
class ThreadsSMRSupport;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
class JvmtiThreadState;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
class ThreadStatistics;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
class ConcurrentLocksDump;
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
    68
class ParkEvent;
6975
dc9b63952682 6988353: refactor contended sync subsystem
acorn
parents: 6769
diff changeset
    69
class Parker;
53149
259c36ef27df 8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents: 53103
diff changeset
    70
class MonitorInfo;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
class ciEnv;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
class CompileThread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
class CompileLog;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
class CompileTask;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
class CompileQueue;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
class CompilerCounters;
53149
259c36ef27df 8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents: 53103
diff changeset
    78
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
class vframeArray;
53149
259c36ef27df 8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents: 53103
diff changeset
    80
class vframe;
259c36ef27df 8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents: 53103
diff changeset
    81
class javaVFrame;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
class DeoptResourceMark;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
class jvmtiDeferredLocalVariableSet;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
class ThreadClosure;
53084
293cec2f7670 8215500: ICRefillVerifierMark does not set the provided verfier as current
eosterlund
parents: 52955
diff changeset
    87
class ICRefillVerifier;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
class IdealGraphPrinter;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54647
diff changeset
    90
class JVMCIEnv;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54647
diff changeset
    91
class JVMCIPrimitiveArray;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54647
diff changeset
    92
27247
99db666dbe8e 8056240: Investigate increased GC remark time after class unloading changes in CRM Fuse
stefank
parents: 26834
diff changeset
    93
class Metadata;
53149
259c36ef27df 8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents: 53103
diff changeset
    94
class ResourceArea;
27247
99db666dbe8e 8056240: Investigate increased GC remark time after class unloading changes in CRM Fuse
stefank
parents: 26834
diff changeset
    95
18928
ac0163dd0a50 7143807: ResourceMark nesting problem in stringStream
fparain
parents: 18025
diff changeset
    96
DEBUG_ONLY(class ResourceMark;)
ac0163dd0a50 7143807: ResourceMark nesting problem in stringStream
fparain
parents: 18025
diff changeset
    97
7399
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
    98
class WorkerThread;
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
    99
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
// Class hierarchy
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
// - Thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
//   - JavaThread
38290
6b194cfc1557 8154715: Missing destructor and/or TLS clearing calls for terminating threads
dholmes
parents: 38144
diff changeset
   103
//     - various subclasses eg CompilerThread, ServiceThread
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   104
//   - NonJavaThread
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   105
//     - NamedThread
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   106
//       - VMThread
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   107
//       - ConcurrentGCThread
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   108
//       - WorkerThread
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   109
//         - GangWorker
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   110
//     - WatcherThread
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   111
//     - JfrThreadSampler
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   112
//
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   113
// All Thread subclasses must be either JavaThread or NonJavaThread.
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   114
// This means !t->is_Java_thread() iff t is a NonJavaThread, or t is
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   115
// a partially constructed/destroyed Thread.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   117
// Thread execution sequence and actions:
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   118
// All threads:
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   119
//  - thread_native_entry  // per-OS native entry point
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   120
//    - stack initialization
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   121
//    - other OS-level initialization (signal masks etc)
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   122
//    - handshake with creating thread (if not started suspended)
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   123
//    - this->call_run()  // common shared entry point
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   124
//      - shared common initialization
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   125
//      - this->pre_run()  // virtual per-thread-type initialization
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   126
//      - this->run()      // virtual per-thread-type "main" logic
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   127
//      - shared common tear-down
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   128
//      - this->post_run()  // virtual per-thread-type tear-down
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   129
//      - // 'this' no longer referenceable
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   130
//    - OS-level tear-down (minimal)
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   131
//    - final logging
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   132
//
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   133
// For JavaThread:
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   134
//   - this->run()  // virtual but not normally overridden
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   135
//     - this->thread_main_inner()  // extra call level to ensure correct stack calculations
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   136
//       - this->entry_point()  // set differently for each kind of JavaThread
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   137
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
class Thread: public ThreadShadow {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
  friend class VMStructs;
35123
b0b89d83bcf5 8134994: use separate VMStructs databases for SA and JVMCI
twisti
parents: 33792
diff changeset
   140
  friend class JVMCIVMStructs;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
 private:
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   142
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   143
#ifndef USE_LIBRARY_BASED_TLS_ONLY
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   144
  // Current thread is maintained as a thread-local variable
58124
dc792fa77da0 8230877: Rename THREAD_LOCAL_DECL to THREAD_LOCAL
pliden
parents: 58095
diff changeset
   145
  static THREAD_LOCAL Thread* _thr_current;
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   146
#endif
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   147
49752
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   148
  // Thread local data area available to the GC. The internal
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   149
  // structure and contents of this data area is GC-specific.
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   150
  // Only GC and GC barrier code should access this data area.
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   151
  GCThreadLocalData _gc_data;
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   152
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   153
 public:
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   154
  static ByteSize gc_data_offset() {
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   155
    return byte_offset_of(Thread, _gc_data);
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   156
  }
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   157
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   158
  template <typename T> T* gc_data() {
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   159
    STATIC_ASSERT(sizeof(T) <= sizeof(_gc_data));
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   160
    return reinterpret_cast<T*>(&_gc_data);
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   161
  }
93d84f667d12 8201318: Introduce GCThreadLocalData to abstract GC-specific data belonging to a thread
pliden
parents: 49751
diff changeset
   162
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
  // Exception handling
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
  // (Note: _pending_exception and friends are in ThreadShadow)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
  //oop       _pending_exception;                // pending exception for current thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
  // const char* _exception_file;                   // file information for exception (debugging only)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
  // int         _exception_line;                   // line information for exception (debugging only)
13195
be27e1b6a4b9 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 12108
diff changeset
   168
 protected:
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   169
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   170
  DEBUG_ONLY(static Thread* _starting_thread;)
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   171
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
  // Support for forcing alignment of thread objects for biased locking
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
  void*       _real_malloc_address;
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
   174
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   175
  // JavaThread lifecycle support:
49956
a87f2e7a527c 8191798: redo nested ThreadsListHandle to drop Threads_lock
dcubed
parents: 49848
diff changeset
   176
  friend class SafeThreadsListPtr;  // for _threads_list_ptr, cmpxchg_threads_hazard_ptr(), {dec_,inc_,}nested_threads_hazard_ptr_cnt(), {g,s}et_threads_hazard_ptr(), inc_nested_handle_cnt(), tag_hazard_ptr() access
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
   177
  friend class ScanHazardPtrGatherProtectedThreadsClosure;  // for cmpxchg_threads_hazard_ptr(), get_threads_hazard_ptr(), is_hazard_ptr_tagged() access
49956
a87f2e7a527c 8191798: redo nested ThreadsListHandle to drop Threads_lock
dcubed
parents: 49848
diff changeset
   178
  friend class ScanHazardPtrGatherThreadsListClosure;  // for get_threads_hazard_ptr(), untag_hazard_ptr() access
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
   179
  friend class ScanHazardPtrPrintMatchingThreadsClosure;  // for get_threads_hazard_ptr(), is_hazard_ptr_tagged() access
49956
a87f2e7a527c 8191798: redo nested ThreadsListHandle to drop Threads_lock
dcubed
parents: 49848
diff changeset
   180
  friend class ThreadsSMRSupport;  // for _nested_threads_hazard_ptr_cnt, _threads_hazard_ptr, _threads_list_ptr access
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
   181
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   182
  ThreadsList* volatile _threads_hazard_ptr;
49956
a87f2e7a527c 8191798: redo nested ThreadsListHandle to drop Threads_lock
dcubed
parents: 49848
diff changeset
   183
  SafeThreadsListPtr*   _threads_list_ptr;
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   184
  ThreadsList*          cmpxchg_threads_hazard_ptr(ThreadsList* exchange_value, ThreadsList* compare_value);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   185
  ThreadsList*          get_threads_hazard_ptr();
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   186
  void                  set_threads_hazard_ptr(ThreadsList* new_list);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   187
  static bool           is_hazard_ptr_tagged(ThreadsList* list) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   188
    return (intptr_t(list) & intptr_t(1)) == intptr_t(1);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   189
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   190
  static ThreadsList*   tag_hazard_ptr(ThreadsList* list) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   191
    return (ThreadsList*)(intptr_t(list) | intptr_t(1));
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   192
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   193
  static ThreadsList*   untag_hazard_ptr(ThreadsList* list) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   194
    return (ThreadsList*)(intptr_t(list) & ~intptr_t(1));
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   195
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   196
  // This field is enabled via -XX:+EnableThreadSMRStatistics:
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   197
  uint _nested_threads_hazard_ptr_cnt;
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   198
  void dec_nested_threads_hazard_ptr_cnt() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   199
    assert(_nested_threads_hazard_ptr_cnt != 0, "mismatched {dec,inc}_nested_threads_hazard_ptr_cnt()");
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   200
    _nested_threads_hazard_ptr_cnt--;
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   201
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   202
  void inc_nested_threads_hazard_ptr_cnt() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   203
    _nested_threads_hazard_ptr_cnt++;
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   204
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   205
  uint nested_threads_hazard_ptr_cnt() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   206
    return _nested_threads_hazard_ptr_cnt;
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   207
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   208
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
 public:
19696
bd5a0131bde1 8021954: VM SIGSEGV during classloading on MacOS; hs_err_pid file produced
coleenp
parents: 18943
diff changeset
   210
  void* operator new(size_t size) throw() { return allocate(size, true); }
bd5a0131bde1 8021954: VM SIGSEGV during classloading on MacOS; hs_err_pid file produced
coleenp
parents: 18943
diff changeset
   211
  void* operator new(size_t size, const std::nothrow_t& nothrow_constant) throw() {
bd5a0131bde1 8021954: VM SIGSEGV during classloading on MacOS; hs_err_pid file produced
coleenp
parents: 18943
diff changeset
   212
    return allocate(size, false); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
  void  operator delete(void* p);
13195
be27e1b6a4b9 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 12108
diff changeset
   214
be27e1b6a4b9 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 12108
diff changeset
   215
 protected:
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   216
  static void* allocate(size_t size, bool throw_excpt, MEMFLAGS flags = mtThread);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
  // ***************************************************************
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
  // Suspend and resume support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
  // ***************************************************************
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
  // VM suspend/resume no longer exists - it was once used for various
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
  // things including safepoints but was deprecated and finally removed
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
  // in Java 7. Because VM suspension was considered "internal" Java-level
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
  // suspension was considered "external", and this legacy naming scheme
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
  // remains.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
  // External suspend/resume requests come from JVM_SuspendThread,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
  // JVM_ResumeThread, JVMTI SuspendThread, and finally JVMTI
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
  // ResumeThread. External
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
  // suspend requests cause _external_suspend to be set and external
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
  // resume requests cause _external_suspend to be cleared.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
  // External suspend requests do not nest on top of other external
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
  // suspend requests. The higher level APIs reject suspend requests
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
  // for already suspended threads.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
  // The external_suspend
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
  // flag is checked by has_special_runtime_exit_condition() and java thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
  // will self-suspend when handle_special_runtime_exit_condition() is
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
  // called. Most uses of the _thread_blocked state in JavaThreads are
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
  // considered the same as being externally suspended; if the blocking
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
  // condition lifts, the JavaThread will self-suspend. Other places
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
  // where VM checks for external_suspend include:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
  //   + mutex granting (do not enter monitors when thread is suspended)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
  //   + state transitions from _thread_in_native
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
  // In general, java_suspend() does not wait for an external suspend
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
  // request to complete. When it returns, the only guarantee is that
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
  // the _external_suspend field is true.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
  // wait_for_ext_suspend_completion() is used to wait for an external
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
  // suspend request to complete. External suspend requests are usually
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
  // followed by some other interface call that requires the thread to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
  // be quiescent, e.g., GetCallTrace(). By moving the "wait time" into
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
  // the interface that requires quiescence, we give the JavaThread a
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
  // chance to self-suspend before we need it to be quiescent. This
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
  // improves overall suspend/query performance.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
  // _suspend_flags controls the behavior of java_ suspend/resume.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
  // It must be set under the protection of SR_lock. Read from the flag is
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
  // OK without SR_lock as long as the value is only used as a hint.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
  // (e.g., check _external_suspend first without lock and then recheck
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
  // inside SR_lock and finish the suspension)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
  // _suspend_flags is also overloaded for other "special conditions" so
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
  // that a single check indicates whether any special action is needed
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
  // eg. for async exceptions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
  // -------------------------------------------------------------------
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
  // Notes:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
  // 1. The suspend/resume logic no longer uses ThreadState in OSThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
  // but we still update its value to keep other part of the system (mainly
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
  // JVMTI) happy. ThreadState is legacy code (see notes in
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
  // osThread.hpp).
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
  // 2. It would be more natural if set_external_suspend() is private and
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
  // part of java_suspend(), but that probably would affect the suspend/query
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
  // performance. Need more investigation on this.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
  // suspend/resume lock: used for self-suspend
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   281
  Monitor* _SR_lock;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
 protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
  enum SuspendFlags {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
    // NOTE: avoid using the sign-bit as cc generates different test code
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
    //       when the sign-bit is used, and sometimes incorrectly - see CR 6398077
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
    _external_suspend       = 0x20000000U, // thread is asked to self suspend
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
    _ext_suspended          = 0x40000000U, // thread has self-suspended
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
   291
    _has_async_exception    = 0x00000001U, // there is a pending async exception
46643
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   292
    _critical_native_unlock = 0x00000002U, // Must call back to unlock JNI critical lock
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   293
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   294
    _trace_flag             = 0x00000004U  // call tracing backend
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
  // various suspension related flags - atomically updated
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
  // overloaded for async exception checking in check_special_condition_for_native_trans.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
  volatile uint32_t _suspend_flags;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
  int _num_nested_signal;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
30610
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   304
  DEBUG_ONLY(bool _suspendible_thread;)
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   305
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
  void enter_signal_handler() { _num_nested_signal++; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
  void leave_signal_handler() { _num_nested_signal--; }
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   309
  bool is_inside_signal_handler() const { return _num_nested_signal > 0; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
52033
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   311
  // Determines if a heap allocation failure will be retried
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   312
  // (e.g., by deoptimizing and re-executing in the interpreter).
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   313
  // In this case, the failed allocation must raise
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   314
  // Universe::out_of_memory_error_retry() and omit side effects
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   315
  // such as JVMTI events and handling -XX:+HeapDumpOnOutOfMemoryError
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   316
  // and -XX:OnOutOfMemoryError.
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   317
  virtual bool in_retryable_allocation() const { return false; }
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
   318
30610
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   319
#ifdef ASSERT
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   320
  void set_suspendible_thread() {
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   321
    _suspendible_thread = true;
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   322
  }
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   323
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   324
  void clear_suspendible_thread() {
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   325
    _suspendible_thread = false;
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   326
  }
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   327
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   328
  bool is_suspendible_thread() { return _suspendible_thread; }
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   329
#endif
d4f41f692503 7006810: G1: Introduce peace-of-mind checking in the Suspendible Thread Set
jprovino
parents: 30175
diff changeset
   330
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
  // Active_handles points to a block of handles
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
  JNIHandleBlock* _active_handles;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   334
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
  // One-element thread local free list
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
  JNIHandleBlock* _free_handle_block;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
  // Point to the last handle mark
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
  HandleMark* _last_handle_mark;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   341
  // Claim value for parallel iteration over threads.
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   342
  uintx _threads_do_token;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
49800
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   344
  // Support for GlobalCounter
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   345
 private:
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   346
  volatile uintx _rcu_counter;
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   347
 public:
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   348
  volatile uintx* get_rcu_counter() {
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   349
    return &_rcu_counter;
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   350
  }
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   351
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   352
 public:
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   353
  void set_last_handle_mark(HandleMark* mark)   { _last_handle_mark = mark; }
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   354
  HandleMark* last_handle_mark() const          { return _last_handle_mark; }
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   355
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
52896
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   357
#ifdef ASSERT
53084
293cec2f7670 8215500: ICRefillVerifierMark does not set the provided verfier as current
eosterlund
parents: 52955
diff changeset
   358
  ICRefillVerifier* _missed_ic_stub_refill_verifier;
52896
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   359
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   360
 public:
53084
293cec2f7670 8215500: ICRefillVerifierMark does not set the provided verfier as current
eosterlund
parents: 52955
diff changeset
   361
  ICRefillVerifier* missed_ic_stub_refill_verifier() {
293cec2f7670 8215500: ICRefillVerifierMark does not set the provided verfier as current
eosterlund
parents: 52955
diff changeset
   362
    return _missed_ic_stub_refill_verifier;
52896
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   363
  }
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   364
53084
293cec2f7670 8215500: ICRefillVerifierMark does not set the provided verfier as current
eosterlund
parents: 52955
diff changeset
   365
  void set_missed_ic_stub_refill_verifier(ICRefillVerifier* verifier) {
293cec2f7670 8215500: ICRefillVerifierMark does not set the provided verfier as current
eosterlund
parents: 52955
diff changeset
   366
    _missed_ic_stub_refill_verifier = verifier;
52896
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   367
  }
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   368
#endif // ASSERT
52896
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   369
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   370
 private:
98408c7c0b73 8214936: assert(_needs_refill == 0) failed: Forgot to handle a failed IC transition requiring IC stubs
eosterlund
parents: 52673
diff changeset
   371
57603
f9d9bed12d1a 8228630: Remove always true parameter to NoSafepointVerifier
coleenp
parents: 57501
diff changeset
   372
  // Debug support for checking if code allows safepoints or not.
f9d9bed12d1a 8228630: Remove always true parameter to NoSafepointVerifier
coleenp
parents: 57501
diff changeset
   373
  // Safepoints in the VM can happen because of allocation, invoking a VM operation, or blocking on
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
  // mutex, or blocking on an object synchronizer (Java locking).
57603
f9d9bed12d1a 8228630: Remove always true parameter to NoSafepointVerifier
coleenp
parents: 57501
diff changeset
   375
  // If _no_safepoint_count is non-zero, then an assertion failure will happen in any of
f9d9bed12d1a 8228630: Remove always true parameter to NoSafepointVerifier
coleenp
parents: 57501
diff changeset
   376
  // the above cases.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
  //
57501
a297f7ab46c3 8228484: Remove NoAllocVerifier because nothing uses it
coleenp
parents: 55490
diff changeset
   378
  // The class NoSafepointVerifier is used to set this counter.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
  //
57603
f9d9bed12d1a 8228630: Remove always true parameter to NoSafepointVerifier
coleenp
parents: 57501
diff changeset
   380
  NOT_PRODUCT(int _no_safepoint_count;)         // If 0, thread allow a safepoint to happen
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   381
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   382
 private:
2995
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   383
  // Used by SkipGCALot class.
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   384
  NOT_PRODUCT(bool _skip_gcalot;)               // Should we elide gc-a-lot?
2995
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   385
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   386
  friend class GCLocker;
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35481
diff changeset
   387
  friend class NoSafepointVerifier;
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35481
diff changeset
   388
  friend class PauseNoSafepointVerifier;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
   390
  volatile void* _polling_page;                 // Thread local polling page
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
   391
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   392
  ThreadLocalAllocBuffer _tlab;                 // Thread-local eden
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   393
  jlong _allocated_bytes;                       // Cumulative number of bytes allocated on
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   394
                                                // the Java heap
50578
e2a7f431f65c 8203394: Implementation of JEP 331: Low-Overhead Heap Profiling
jcbeyler
parents: 50113
diff changeset
   395
  ThreadHeapSampler _heap_sampler;              // For use when sampling the memory.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
   397
  ThreadStatisticalInfo _statistical_info;      // Statistics about the thread
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
   398
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
   399
  JFR_ONLY(DEFINE_THREAD_LOCAL_FIELD_JFR;)      // Thread-local data for jfr
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 10739
diff changeset
   400
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   401
  int   _vm_operation_started_count;            // VM_Operation support
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   402
  int   _vm_operation_completed_count;          // VM_Operation support
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   404
  ObjectMonitor* _current_pending_monitor;      // ObjectMonitor this thread
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   405
                                                // is waiting to lock
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   406
  bool _current_pending_monitor_is_from_java;   // locking is from Java code
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
489c9b5090e2 Initial load
duke
parents:
diff changeset
   408
  // ObjectMonitor on which this thread called Object.wait()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   409
  ObjectMonitor* _current_waiting_monitor;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
57906
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   411
  // Per-thread ObjectMonitor lists:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   412
 public:
57906
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   413
  ObjectMonitor* om_free_list;                  // SLL of free ObjectMonitors
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   414
  int om_free_count;                            // # on om_free_list
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   415
  int om_free_provision;                        // # to try to allocate next
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   416
  ObjectMonitor* om_in_use_list;                // SLL of in-use ObjectMonitors
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   417
  int om_in_use_count;                          // # on om_in_use_list
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
12108
b2ee55606008 7150390: JFR test crashed on assert(_jni_lock_count == count) failed: must be equal
never
parents: 11637
diff changeset
   419
#ifdef ASSERT
b2ee55606008 7150390: JFR test crashed on assert(_jni_lock_count == count) failed: must be equal
never
parents: 11637
diff changeset
   420
 private:
53775
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   421
  volatile uint64_t _visited_for_critical_count;
12108
b2ee55606008 7150390: JFR test crashed on assert(_jni_lock_count == count) failed: must be equal
never
parents: 11637
diff changeset
   422
b2ee55606008 7150390: JFR test crashed on assert(_jni_lock_count == count) failed: must be equal
never
parents: 11637
diff changeset
   423
 public:
53775
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   424
  void set_visited_for_critical_count(uint64_t safepoint_id) {
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   425
    assert(_visited_for_critical_count == 0, "Must be reset before set");
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   426
    assert((safepoint_id & 0x1) == 1, "Must be odd");
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   427
    _visited_for_critical_count = safepoint_id;
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   428
  }
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   429
  void reset_visited_for_critical_count(uint64_t safepoint_id) {
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   430
    assert(_visited_for_critical_count == safepoint_id, "Was not visited");
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   431
    _visited_for_critical_count = 0;
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   432
  }
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   433
  bool was_visited_for_critical_count(uint64_t safepoint_id) const {
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   434
    return _visited_for_critical_count == safepoint_id;
5d20b085d893 8203469: Faster safepoints
rehn
parents: 53646
diff changeset
   435
  }
12108
b2ee55606008 7150390: JFR test crashed on assert(_jni_lock_count == count) failed: must be equal
never
parents: 11637
diff changeset
   436
#endif
b2ee55606008 7150390: JFR test crashed on assert(_jni_lock_count == count) failed: must be equal
never
parents: 11637
diff changeset
   437
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   438
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   439
  enum {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
    is_definitely_current_thread = true
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
  // Constructor
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
  Thread();
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   445
  virtual ~Thread() = 0;        // Thread is abstract.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   447
  // Manage Thread::current()
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   448
  void initialize_thread_current();
52302
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   449
  static void clear_thread_current(); // TLS cleanup needed before threads terminate
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   450
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   451
 protected:
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   452
  // To be implemented by children.
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   453
  virtual void run() = 0;
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   454
  virtual void pre_run() = 0;
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   455
  virtual void post_run() = 0;  // Note: Thread must not be deleted prior to calling this!
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   456
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   457
#ifdef ASSERT
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   458
  enum RunState {
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   459
    PRE_CALL_RUN,
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   460
    CALL_RUN,
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   461
    PRE_RUN,
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   462
    RUN,
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   463
    POST_RUN
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   464
    // POST_CALL_RUN - can't define this one as 'this' may be deleted when we want to set it
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   465
  };
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   466
  RunState _run_state;  // for lifecycle checks
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   467
#endif
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   468
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
49800
69d7398038c5 8195099: Concurrent safe-memory-reclamation mechanism
rehn
parents: 49756
diff changeset
   470
 public:
52302
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   471
  // invokes <ChildThreadClass>::run(), with common preparations and cleanups.
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   472
  void call_run();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
  // Testers
489c9b5090e2 Initial load
duke
parents:
diff changeset
   475
  virtual bool is_VM_thread()       const            { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
  virtual bool is_Java_thread()     const            { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
  virtual bool is_Compiler_thread() const            { return false; }
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
   478
  virtual bool is_Code_cache_sweeper_thread() const  { return false; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
  virtual bool is_hidden_from_external_view() const  { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
  virtual bool is_jvmti_agent_thread() const         { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
  // True iff the thread can perform GC operations at a safepoint.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
  // Generally will be true only of VM thread and parallel GC WorkGang
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
  // threads.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
  virtual bool is_GC_task_thread() const             { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
  virtual bool is_Watcher_thread() const             { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
  virtual bool is_ConcurrentGC_thread() const        { return false; }
4489
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   487
  virtual bool is_Named_thread() const               { return false; }
7399
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   488
  virtual bool is_Worker_thread() const              { return false; }
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   489
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
   490
  // Can this thread make Java upcalls
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
   491
  virtual bool can_call_java() const                 { return false; }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
   492
57699
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
   493
  // Is this a JavaThread that is on the VM's current ThreadsList?
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
   494
  // If so it must participate in the safepoint protocol.
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
   495
  virtual bool is_active_Java_thread() const         { return false; }
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
   496
7399
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   497
  // Casts
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   498
  virtual WorkerThread* as_Worker_thread() const     { return NULL; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
  virtual char* name() const { return (char*)"Unknown thread"; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   502
  // Returns the current thread (ASSERTS if NULL)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
  static inline Thread* current();
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   504
  // Returns the current thread, or NULL if not attached
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   505
  static inline Thread* current_or_null();
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   506
  // Returns the current thread, or NULL if not attached, and is
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   507
  // safe for use from signal-handlers
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   508
  static inline Thread* current_or_null_safe();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
  // Common thread operations
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   511
#ifdef ASSERT
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   512
  static void check_for_dangling_thread_pointer(Thread *thread);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   513
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   514
  static void set_priority(Thread* thread, ThreadPriority priority);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
  static ThreadPriority get_priority(const Thread* const thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
  static void start(Thread* thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   517
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   518
  void set_native_thread_name(const char *name) {
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   519
    assert(Thread::current() == this, "set_native_thread_name can only be called on the current thread");
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   520
    os::set_native_thread_name(name);
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   521
  }
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   522
57906
e17f768b3b71 8230184: rename, whitespace, indent and comments changes in preparation for lock free Monitor lists
dcubed
parents: 57840
diff changeset
   523
  ObjectMonitor** om_in_use_list_addr()          { return (ObjectMonitor **)&om_in_use_list; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
  Monitor* SR_lock() const                       { return _SR_lock; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
  bool has_async_exception() const { return (_suspend_flags & _has_async_exception) != 0; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
   528
  inline void set_suspend_flag(SuspendFlags f);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
   529
  inline void clear_suspend_flag(SuspendFlags f);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   530
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
   531
  inline void set_has_async_exception();
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
   532
  inline void clear_has_async_exception();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
   534
  bool do_critical_native_unlock() const { return (_suspend_flags & _critical_native_unlock) != 0; }
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
   535
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
   536
  inline void set_critical_native_unlock();
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
   537
  inline void clear_critical_native_unlock();
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
   538
46643
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   539
  inline void set_trace_flag();
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   540
  inline void clear_trace_flag();
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   541
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
  // Support for Unhandled Oop detection
32575
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   543
  // Add the field for both, fastdebug and debug, builds to keep
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   544
  // Thread's fields layout the same.
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   545
  // Note: CHECK_UNHANDLED_OOPS is defined only for fastdebug build.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   546
#ifdef CHECK_UNHANDLED_OOPS
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
 private:
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   548
  UnhandledOops* _unhandled_oops;
32575
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   549
#elif defined(ASSERT)
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   550
 private:
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   551
  void* _unhandled_oops;
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   552
#endif
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   553
#ifdef CHECK_UNHANDLED_OOPS
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   554
 public:
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   555
  UnhandledOops* unhandled_oops() { return _unhandled_oops; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   556
  // Mark oop safe for gc.  It may be stack allocated but won't move.
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   557
  void allow_unhandled_oop(oop *op) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
    if (CheckUnhandledOops) unhandled_oops()->allow_unhandled_oop(op);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   560
  // Clear oops at safepoint so crashes point to unhandled oop violator
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   561
  void clear_unhandled_oops() {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   562
    if (CheckUnhandledOops) unhandled_oops()->clear_unhandled_oops();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   563
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   564
#endif // CHECK_UNHANDLED_OOPS
489c9b5090e2 Initial load
duke
parents:
diff changeset
   565
32575
059965be379b 8134898: Small fixes found during JVMCI work
kvn
parents: 30764
diff changeset
   566
 public:
2995
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   567
#ifndef PRODUCT
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   568
  bool skip_gcalot()           { return _skip_gcalot; }
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   569
  void set_skip_gcalot(bool v) { _skip_gcalot = v;    }
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   570
#endif
d8283445992a 6820167: GCALotAtAllSafepoints + FullGCALot(ScavengeALot) options crash JVM
ysr
parents: 2526
diff changeset
   571
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
  // Installs a pending exception to be inserted later
489c9b5090e2 Initial load
duke
parents:
diff changeset
   573
  static void send_async_exception(oop thread_oop, oop java_throwable);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   574
489c9b5090e2 Initial load
duke
parents:
diff changeset
   575
  // Resource area
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
  ResourceArea* resource_area() const            { return _resource_area; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   577
  void set_resource_area(ResourceArea* area)     { _resource_area = area; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   578
489c9b5090e2 Initial load
duke
parents:
diff changeset
   579
  OSThread* osthread() const                     { return _osthread;   }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   580
  void set_osthread(OSThread* thread)            { _osthread = thread; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   581
489c9b5090e2 Initial load
duke
parents:
diff changeset
   582
  // JNI handle support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   583
  JNIHandleBlock* active_handles() const         { return _active_handles; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   584
  void set_active_handles(JNIHandleBlock* block) { _active_handles = block; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   585
  JNIHandleBlock* free_handle_block() const      { return _free_handle_block; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   586
  void set_free_handle_block(JNIHandleBlock* block) { _free_handle_block = block; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   587
489c9b5090e2 Initial load
duke
parents:
diff changeset
   588
  // Internal handle support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   589
  HandleArea* handle_area() const                { return _handle_area; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   590
  void set_handle_area(HandleArea* area)         { _handle_area = area; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   592
  GrowableArray<Metadata*>* metadata_handles() const          { return _metadata_handles; }
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   593
  void set_metadata_handles(GrowableArray<Metadata*>* handles){ _metadata_handles = handles; }
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   594
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
  // Thread-Local Allocation Buffer (TLAB) support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   596
  ThreadLocalAllocBuffer& tlab()                 { return _tlab; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
  void initialize_tlab() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
    if (UseTLAB) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   599
      tlab().initialize();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   600
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   601
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   602
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   603
  jlong allocated_bytes()               { return _allocated_bytes; }
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   604
  void set_allocated_bytes(jlong value) { _allocated_bytes = value; }
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   605
  void incr_allocated_bytes(jlong size) { _allocated_bytes += size; }
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 23855
diff changeset
   606
  inline jlong cooked_allocated_bytes();
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   607
50578
e2a7f431f65c 8203394: Implementation of JEP 331: Low-Overhead Heap Profiling
jcbeyler
parents: 50113
diff changeset
   608
  ThreadHeapSampler& heap_sampler()     { return _heap_sampler; }
e2a7f431f65c 8203394: Implementation of JEP 331: Low-Overhead Heap Profiling
jcbeyler
parents: 50113
diff changeset
   609
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
   610
  ThreadStatisticalInfo& statistical_info() { return _statistical_info; }
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
   611
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
   612
  JFR_ONLY(DEFINE_THREAD_LOCAL_ACCESSOR_JFR;)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
   613
46643
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
   614
  bool is_trace_suspend()               { return (_suspend_flags & _trace_flag) != 0; }
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 10739
diff changeset
   615
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
  // VM operation support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
  int vm_operation_ticket()                      { return ++_vm_operation_started_count; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   618
  int vm_operation_completed_count()             { return _vm_operation_completed_count; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
  void increment_vm_operation_completed_count()  { _vm_operation_completed_count++; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
  // For tracking the heavyweight monitor the thread is pending on.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   622
  ObjectMonitor* current_pending_monitor() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   623
    return _current_pending_monitor;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
  void set_current_pending_monitor(ObjectMonitor* monitor) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
    _current_pending_monitor = monitor;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   628
  void set_current_pending_monitor_is_from_java(bool from_java) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   629
    _current_pending_monitor_is_from_java = from_java;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
  bool current_pending_monitor_is_from_java() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
    return _current_pending_monitor_is_from_java;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
  // For tracking the ObjectMonitor on which this thread called Object.wait()
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
  ObjectMonitor* current_waiting_monitor() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
    return _current_waiting_monitor;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
  void set_current_waiting_monitor(ObjectMonitor* monitor) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
    _current_waiting_monitor = monitor;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
489c9b5090e2 Initial load
duke
parents:
diff changeset
   643
  // GC support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   644
  // Apply "f->do_oop" to all root oops in "this".
14582
490bb6c0df7c 8003720: NPG: Method in interpreter stack frame can be deallocated
stefank
parents: 14390
diff changeset
   645
  //   Used by JavaThread::oops_do.
3908
24b55ad4c228 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 3261
diff changeset
   646
  // Apply "cf->do_code_blob" (if !NULL) to all code blobs active in frames
38074
8475fdc6dcc3 8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents: 37474
diff changeset
   647
  virtual void oops_do(OopClosure* f, CodeBlobClosure* cf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   648
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   649
  // Handles the parallel case for claim_threads_do.
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   650
 private:
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   651
  bool claim_par_threads_do(uintx claim_token);
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   652
 public:
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   653
  // Requires that "claim_token" is that of the current iteration.
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   654
  // If "is_par" is false, sets the token of "this" to
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   655
  // "claim_token", and returns "true".  If "is_par" is true,
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   656
  // uses an atomic instruction to set the current thread's token to
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   657
  // "claim_token", if it is not already.  Returns "true" iff the
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   658
  // calling thread does the update, this indicates that the calling thread
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   659
  // has claimed the thread in the current iteration.
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   660
  bool claim_threads_do(bool is_par, uintx claim_token) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   661
    if (!is_par) {
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   662
      _threads_do_token = claim_token;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   663
      return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   664
    } else {
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   665
      return claim_par_threads_do(claim_token);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   666
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   667
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   668
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   669
  uintx threads_do_token() const { return _threads_do_token; }
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
   670
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   671
  // jvmtiRedefineClasses support
29576
c223b0a9872e 8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents: 29362
diff changeset
   672
  void metadata_handles_do(void f(Metadata*));
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   673
2526
39a58a50be35 6699669: Hotspot server leaves synchronized block with monitor in bad state
xlu
parents: 2135
diff changeset
   674
  // Used by fast lock support
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   675
  virtual bool is_lock_owned(address adr) const;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   676
489c9b5090e2 Initial load
duke
parents:
diff changeset
   677
  // Check if address is in the stack of the thread (not just for locks).
2526
39a58a50be35 6699669: Hotspot server leaves synchronized block with monitor in bad state
xlu
parents: 2135
diff changeset
   678
  // Warning: the method can only be used on the running thread
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   679
  bool is_in_stack(address adr) const;
18938
ff8f8cec9434 8016131: nsk/sysdict/vm/stress/chain tests crash the VM in 'entry_frame_is_first()'
rbackman
parents: 18928
diff changeset
   680
  // Check if address is in the usable part of the stack (excludes protected
ff8f8cec9434 8016131: nsk/sysdict/vm/stress/chain tests crash the VM in 'entry_frame_is_first()'
rbackman
parents: 18928
diff changeset
   681
  // guard pages)
ff8f8cec9434 8016131: nsk/sysdict/vm/stress/chain tests crash the VM in 'entry_frame_is_first()'
rbackman
parents: 18928
diff changeset
   682
  bool is_in_usable_stack(address adr) const;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   683
489c9b5090e2 Initial load
duke
parents:
diff changeset
   684
  // Sets this thread as starting thread. Returns failure if thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   685
  // creation fails due to lack of memory, too many threads etc.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   686
  bool set_as_starting_thread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   687
27247
99db666dbe8e 8056240: Investigate increased GC remark time after class unloading changes in CRM Fuse
stefank
parents: 26834
diff changeset
   688
protected:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   689
  // OS data associated with the thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   690
  OSThread* _osthread;  // Platform-specific thread information
489c9b5090e2 Initial load
duke
parents:
diff changeset
   691
489c9b5090e2 Initial load
duke
parents:
diff changeset
   692
  // Thread local resource area for temporary allocation within the VM
489c9b5090e2 Initial load
duke
parents:
diff changeset
   693
  ResourceArea* _resource_area;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   694
18928
ac0163dd0a50 7143807: ResourceMark nesting problem in stringStream
fparain
parents: 18025
diff changeset
   695
  DEBUG_ONLY(ResourceMark* _current_resource_mark;)
ac0163dd0a50 7143807: ResourceMark nesting problem in stringStream
fparain
parents: 18025
diff changeset
   696
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   697
  // Thread local handle area for allocation of handles within the VM
489c9b5090e2 Initial load
duke
parents:
diff changeset
   698
  HandleArea* _handle_area;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   699
  GrowableArray<Metadata*>* _metadata_handles;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   700
489c9b5090e2 Initial load
duke
parents:
diff changeset
   701
  // Support for stack overflow handling, get_thread, etc.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   702
  address          _stack_base;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   703
  size_t           _stack_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   704
  int              _lgrp_id;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   705
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
   706
  volatile void** polling_page_addr() { return &_polling_page; }
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
   707
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   708
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   709
  // Stack overflow support
489c9b5090e2 Initial load
duke
parents:
diff changeset
   710
  address stack_base() const           { assert(_stack_base != NULL,"Sanity check"); return _stack_base; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   711
  void    set_stack_base(address base) { _stack_base = base; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   712
  size_t  stack_size() const           { return _stack_size; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   713
  void    set_stack_size(size_t size)  { _stack_size = size; }
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   714
  address stack_end()  const           { return stack_base() - stack_size(); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   715
  void    record_stack_base_and_size();
52302
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 52033
diff changeset
   716
  void    register_thread_stack_with_NMT() NOT_NMT_RETURN;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   717
6183
4c74cfe14f20 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 5920
diff changeset
   718
  bool    on_local_stack(address adr) const {
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
   719
    // QQQ this has knowledge of direction, ought to be a stack method
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   720
    return (_stack_base >= adr && adr >= stack_end());
6183
4c74cfe14f20 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 5920
diff changeset
   721
  }
4c74cfe14f20 6975078: assert(allocated_on_res_area() || allocated_on_C_heap() || allocated_on_arena()
kvn
parents: 5920
diff changeset
   722
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   723
  int     lgrp_id() const        { return _lgrp_id; }
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   724
  void    set_lgrp_id(int value) { _lgrp_id = value; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   725
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
  // Printing
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
   727
  void print_on(outputStream* st, bool print_extended_info) const;
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
   728
  virtual void print_on(outputStream* st) const { print_on(st, false); }
54807
33fe50b6d707 8223626: move print() functions to cpp files
coleenp
parents: 54732
diff changeset
   729
  void print() const;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   730
  virtual void print_on_error(outputStream* st, char* buf, int buflen) const;
46742
24ec8a039c90 8184994: Add Dictionary size logging and jcmd
coleenp
parents: 46702
diff changeset
   731
  void print_value_on(outputStream* st) const;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
489c9b5090e2 Initial load
duke
parents:
diff changeset
   733
  // Debug-only code
489c9b5090e2 Initial load
duke
parents:
diff changeset
   734
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   735
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
  // Deadlock detection support for Mutex locks. List of locks own by thread.
57840
4863a802a7c1 8230003: Make Monitor inherit from Mutex
coleenp
parents: 57773
diff changeset
   737
  Mutex* _owned_locks;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
  // Mutex::set_owner_implementation is the only place where _owned_locks is modified,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
  // thus the friendship
489c9b5090e2 Initial load
duke
parents:
diff changeset
   740
  friend class Mutex;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   741
  friend class Monitor;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   744
  void print_owned_locks_on(outputStream* st) const;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   745
  void print_owned_locks() const                 { print_owned_locks_on(tty);    }
57840
4863a802a7c1 8230003: Make Monitor inherit from Mutex
coleenp
parents: 57773
diff changeset
   746
  Mutex* owned_locks() const                     { return _owned_locks;          }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   747
  bool owns_locks() const                        { return owned_locks() != NULL; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   748
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
  // Deadlock detection
18928
ac0163dd0a50 7143807: ResourceMark nesting problem in stringStream
fparain
parents: 18025
diff changeset
   750
  ResourceMark* current_resource_mark()          { return _current_resource_mark; }
ac0163dd0a50 7143807: ResourceMark nesting problem in stringStream
fparain
parents: 18025
diff changeset
   751
  void set_current_resource_mark(ResourceMark* rm) { _current_resource_mark = rm; }
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   752
#endif // ASSERT
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   753
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   754
  // These functions check conditions on a JavaThread before possibly going to a safepoint,
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   755
  // including NoSafepointVerifier.
58291
a013100f7a35 8213150: Add verification for locking by VMThread
coleenp
parents: 58282
diff changeset
   756
  void check_for_valid_safepoint_state() NOT_DEBUG_RETURN;
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
   757
  void check_possible_safepoint() NOT_DEBUG_RETURN;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
  volatile int _jvmti_env_iteration_count;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   761
489c9b5090e2 Initial load
duke
parents:
diff changeset
   762
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   763
  void entering_jvmti_env_iteration()            { ++_jvmti_env_iteration_count; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   764
  void leaving_jvmti_env_iteration()             { --_jvmti_env_iteration_count; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   765
  bool is_inside_jvmti_env_iteration()           { return _jvmti_env_iteration_count > 0; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   766
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
  // Code generation
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   768
  static ByteSize exception_file_offset()        { return byte_offset_of(Thread, _exception_file); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   769
  static ByteSize exception_line_offset()        { return byte_offset_of(Thread, _exception_line); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   770
  static ByteSize active_handles_offset()        { return byte_offset_of(Thread, _active_handles); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   771
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   772
  static ByteSize stack_base_offset()            { return byte_offset_of(Thread, _stack_base); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   773
  static ByteSize stack_size_offset()            { return byte_offset_of(Thread, _stack_size); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   774
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
   775
  static ByteSize polling_page_offset()          { return byte_offset_of(Thread, _polling_page); }
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
   776
51743
47466ac8dcf0 8210711: Remove unused offset getters in ThreadLocalAllocBuffer
pliden
parents: 51600
diff changeset
   777
  static ByteSize tlab_start_offset()            { return byte_offset_of(Thread, _tlab) + ThreadLocalAllocBuffer::start_offset(); }
47466ac8dcf0 8210711: Remove unused offset getters in ThreadLocalAllocBuffer
pliden
parents: 51600
diff changeset
   778
  static ByteSize tlab_end_offset()              { return byte_offset_of(Thread, _tlab) + ThreadLocalAllocBuffer::end_offset(); }
47466ac8dcf0 8210711: Remove unused offset getters in ThreadLocalAllocBuffer
pliden
parents: 51600
diff changeset
   779
  static ByteSize tlab_top_offset()              { return byte_offset_of(Thread, _tlab) + ThreadLocalAllocBuffer::top_offset(); }
47466ac8dcf0 8210711: Remove unused offset getters in ThreadLocalAllocBuffer
pliden
parents: 51600
diff changeset
   780
  static ByteSize tlab_pf_top_offset()           { return byte_offset_of(Thread, _tlab) + ThreadLocalAllocBuffer::pf_top_offset(); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   781
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   782
  static ByteSize allocated_bytes_offset()       { return byte_offset_of(Thread, _allocated_bytes); }
7724
a92d706dbdd5 7003271: Hotspot should track cumulative Java heap bytes allocated on a per-thread basis
phh
parents: 7399
diff changeset
   783
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
   784
  JFR_ONLY(DEFINE_THREAD_LOCAL_OFFSET_JFR;)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 50058
diff changeset
   785
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
 public:
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   787
  volatile intptr_t _Stalled;
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   788
  volatile int _TypeTag;
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   789
  ParkEvent * _ParkEvent;                     // for synchronized()
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   790
  ParkEvent * _MuxEvent;                      // for low-level muxAcquire-muxRelease
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   791
  int NativeSyncRecursion;                    // diagnostic
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   792
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   793
  volatile int _OnTrap;                       // Resume-at IP delta
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   794
  jint _hashStateW;                           // Marsaglia Shift-XOR thread-local RNG
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   795
  jint _hashStateX;                           // thread-specific hashCode generator state
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   796
  jint _hashStateY;
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   797
  jint _hashStateZ;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   798
489c9b5090e2 Initial load
duke
parents:
diff changeset
   799
  // Low-level leaf-lock primitives used to implement synchronization
489c9b5090e2 Initial load
duke
parents:
diff changeset
   800
  // and native monitor-mutex infrastructure.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
  // Not for general synchronization use.
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   802
  static void SpinAcquire(volatile int * Lock, const char * Name);
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   803
  static void SpinRelease(volatile int * Lock);
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   804
  static void muxAcquire(volatile intptr_t * Lock, const char * Name);
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
   805
  static void muxRelease(volatile intptr_t * Lock);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   806
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
// Inline implementation of Thread::current()
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   809
inline Thread* Thread::current() {
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   810
  Thread* current = current_or_null();
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   811
  assert(current != NULL, "Thread::current() called on detached thread");
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   812
  return current;
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   813
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   815
inline Thread* Thread::current_or_null() {
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   816
#ifndef USE_LIBRARY_BASED_TLS_ONLY
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   817
  return _thr_current;
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   818
#else
46688
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   819
  if (ThreadLocalStorage::is_initialized()) {
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   820
    return ThreadLocalStorage::thread();
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   821
  }
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   822
  return NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
#endif
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   824
}
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   825
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
   826
inline Thread* Thread::current_or_null_safe() {
46688
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   827
  if (ThreadLocalStorage::is_initialized()) {
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   828
    return ThreadLocalStorage::thread();
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   829
  }
d33b4d593f9b 8184339: Thread::current_or_null() shall not assert if Posix TLS is not yet initialized
stuefe
parents: 46644
diff changeset
   830
  return NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   831
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   832
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   833
class NonJavaThread: public Thread {
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   834
  friend class VMStructs;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   835
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   836
  NonJavaThread* volatile _next;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   837
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   838
  class List;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   839
  static List _the_list;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   840
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   841
  void add_to_the_list();
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   842
  void remove_from_the_list();
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   843
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   844
 protected:
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   845
  virtual void pre_run();
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   846
  virtual void post_run();
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   847
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   848
 public:
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   849
  NonJavaThread();
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   850
  ~NonJavaThread();
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   851
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   852
  class Iterator;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   853
};
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   854
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   855
// Provides iteration over the list of NonJavaThreads.
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   856
// List addition occurs in pre_run(), and removal occurs in post_run(),
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   857
// so that only live fully-initialized threads can be found in the list.
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   858
// Threads created after an iterator is constructed will not be visited
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   859
// by the iterator. The scope of an iterator is a critical section; there
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   860
// must be no safepoint checks in that scope.
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   861
class NonJavaThread::Iterator : public StackObj {
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   862
  uint _protect_enter;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   863
  NonJavaThread* _current;
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   864
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   865
  // Noncopyable.
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   866
  Iterator(const Iterator&);
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   867
  Iterator& operator=(const Iterator&);
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   868
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   869
public:
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   870
  Iterator();
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   871
  ~Iterator();
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   872
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   873
  bool end() const { return _current == NULL; }
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   874
  NonJavaThread* current() const { return _current; }
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   875
  void step();
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   876
};
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   877
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   878
// Name support for threads.  non-JavaThread subclasses with multiple
489c9b5090e2 Initial load
duke
parents:
diff changeset
   879
// uniquely named instances should derive from this.
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   880
class NamedThread: public NonJavaThread {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   881
  friend class VMStructs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   882
  enum {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   883
    max_name_len = 64
489c9b5090e2 Initial load
duke
parents:
diff changeset
   884
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   886
  char* _name;
4489
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   887
  // log JavaThread being processed by oops_do
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   888
  JavaThread* _processed_thread;
33107
77bf0d2069a3 8134953: Make the GC ID available in a central place
brutisso
parents: 32575
diff changeset
   889
  uint _gc_id; // The current GC id when a thread takes part in GC
4489
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   890
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
  NamedThread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
  ~NamedThread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   894
  // May only be called once per thread.
24424
2658d7834c6e 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 24352
diff changeset
   895
  void set_name(const char* format, ...)  ATTRIBUTE_PRINTF(2, 3);
4489
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   896
  virtual bool is_Named_thread() const { return true; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
  virtual char* name() const { return _name == NULL ? (char*)"Unknown Thread" : _name; }
4489
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   898
  JavaThread *processed_thread() { return _processed_thread; }
514173c9a0c2 6361589: Print out stack trace for target thread of GC crash
minqi
parents: 4030
diff changeset
   899
  void set_processed_thread(JavaThread *thread) { _processed_thread = thread; }
24331
c0bc7e5653fb 6885993: Named Thread: introduce print() and print_on(outputStream* st) methods
zgu
parents: 23855
diff changeset
   900
  virtual void print_on(outputStream* st) const;
33107
77bf0d2069a3 8134953: Make the GC ID available in a central place
brutisso
parents: 32575
diff changeset
   901
77bf0d2069a3 8134953: Make the GC ID available in a central place
brutisso
parents: 32575
diff changeset
   902
  void set_gc_id(uint gc_id) { _gc_id = gc_id; }
77bf0d2069a3 8134953: Make the GC ID available in a central place
brutisso
parents: 32575
diff changeset
   903
  uint gc_id() { return _gc_id; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   904
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   905
489c9b5090e2 Initial load
duke
parents:
diff changeset
   906
// Worker threads are named and have an id of an assigned work.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   907
class WorkerThread: public NamedThread {
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   908
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   909
  uint _id;
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
   910
 public:
7399
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   911
  WorkerThread() : _id(0)               { }
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   912
  virtual bool is_Worker_thread() const { return true; }
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   913
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   914
  virtual WorkerThread* as_Worker_thread() const {
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   915
    assert(is_Worker_thread(), "Dubious cast to WorkerThread*?");
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   916
    return (WorkerThread*) this;
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   917
  }
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   918
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   919
  void set_id(uint work_id)             { _id = work_id; }
4ecd771fa2d1 6983204: G1: Nightly test nsk/regression/b4958615 failing with +ExplicitGCInvokesConcurrent
johnc
parents: 7397
diff changeset
   920
  uint id() const                       { return _id; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
489c9b5090e2 Initial load
duke
parents:
diff changeset
   923
// A single WatcherThread is used for simulating timer interrupts.
51548
35a6956f4243 8209976: Improve iteration over non-JavaThreads
kbarrett
parents: 51530
diff changeset
   924
class WatcherThread: public NonJavaThread {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   925
  friend class VMStructs;
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
   926
 protected:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
  virtual void run();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
  static WatcherThread* _watcher_thread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
14390
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   932
  static bool _startable;
29321
b7582a690cb9 8072439: fix for 8047720 may need more work
dcubed
parents: 28039
diff changeset
   933
  // volatile due to at least one lock-free read
b7582a690cb9 8072439: fix for 8047720 may need more work
dcubed
parents: 28039
diff changeset
   934
  volatile static bool _should_terminate;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   936
  enum SomeConstants {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   937
    delay_interval = 10                          // interrupt delay in milliseconds
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
  // Constructor
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
  WatcherThread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
38290
6b194cfc1557 8154715: Missing destructor and/or TLS clearing calls for terminating threads
dholmes
parents: 38144
diff changeset
   943
  // No destruction allowed
6b194cfc1557 8154715: Missing destructor and/or TLS clearing calls for terminating threads
dholmes
parents: 38144
diff changeset
   944
  ~WatcherThread() {
6b194cfc1557 8154715: Missing destructor and/or TLS clearing calls for terminating threads
dholmes
parents: 38144
diff changeset
   945
    guarantee(false, "WatcherThread deletion must fix the race with VM termination");
6b194cfc1557 8154715: Missing destructor and/or TLS clearing calls for terminating threads
dholmes
parents: 38144
diff changeset
   946
  }
6b194cfc1557 8154715: Missing destructor and/or TLS clearing calls for terminating threads
dholmes
parents: 38144
diff changeset
   947
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
  // Tester
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
  bool is_Watcher_thread() const                 { return true; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   950
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
  // Printing
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
  char* name() const { return (char*)"VM Periodic Task Thread"; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
  void print_on(outputStream* st) const;
14390
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   954
  void unpark();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   955
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
  // Returns the single instance of WatcherThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   957
  static WatcherThread* watcher_thread()         { return _watcher_thread; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   958
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
  // Create and start the single instance of WatcherThread, or stop it on shutdown
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
  static void start();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
  static void stop();
14390
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   962
  // Only allow start once the VM is sufficiently initialized
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   963
  // Otherwise the first task to enroll will trigger the start
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   964
  static void make_startable();
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   965
 private:
bd0d881cf1c5 7127792: Add the ability to change an existing PeriodicTask's execution interval
rbackman
parents: 14083
diff changeset
   966
  int sleep() const;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   967
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   968
489c9b5090e2 Initial load
duke
parents:
diff changeset
   969
489c9b5090e2 Initial load
duke
parents:
diff changeset
   970
class CompilerThread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   971
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
typedef void (*ThreadFunction)(JavaThread*, TRAPS);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
489c9b5090e2 Initial load
duke
parents:
diff changeset
   974
class JavaThread: public Thread {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   975
  friend class VMStructs;
35123
b0b89d83bcf5 8134994: use separate VMStructs databases for SA and JVMCI
twisti
parents: 33792
diff changeset
   976
  friend class JVMCIVMStructs;
27917
c5937f7b4e8b 8064669: compiler/whitebox/AllocationCodeBlobTest.java crashes / asserts
iignatyev
parents: 27651
diff changeset
   977
  friend class WhiteBox;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   978
 private:
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
   979
  bool           _on_thread_list;                // Is set when this JavaThread is added to the Threads list
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
  oop            _threadObj;                     // The Java level thread object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   983
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   984
  int _java_call_counter;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
  int  java_call_counter()                       { return _java_call_counter; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
  void inc_java_call_counter()                   { _java_call_counter++; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
  void dec_java_call_counter() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
    assert(_java_call_counter > 0, "Invalid nesting of JavaCallWrapper");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
    _java_call_counter--;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
 private:  // restore original namespace restriction
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
#endif  // ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   995
489c9b5090e2 Initial load
duke
parents:
diff changeset
   996
#ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   997
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   998
  enum {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   999
    jump_ring_buffer_size = 16
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1000
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1001
 private:  // restore original namespace restriction
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1002
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1003
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1004
  JavaFrameAnchor _anchor;                       // Encapsulation of current java frame and it state
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1005
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1006
  ThreadFunction _entry_point;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1007
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1008
  JNIEnv        _jni_environment;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1009
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1010
  // Deopt support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1011
  DeoptResourceMark*  _deopt_mark;               // Holds special ResourceMark for deoptimization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1012
38133
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  1013
  CompiledMethod*       _deopt_nmethod;         // CompiledMethod that is currently being deoptimized
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1014
  vframeArray*  _vframe_array_head;              // Holds the heap of the active vframeArrays
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
  vframeArray*  _vframe_array_last;              // Holds last vFrameArray we popped
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1016
  // Because deoptimization is lazy we must save jvmti requests to set locals
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1017
  // in compiled frames until we deoptimize and we have an interpreter frame.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
  // This holds the pointer to array (yeah like there might be more than one) of
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1019
  // description of compiled vframes that have locals that need to be updated.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1020
  GrowableArray<jvmtiDeferredLocalVariableSet*>* _deferred_locals_updates;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1021
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1022
  // Handshake value for fixing 6243940. We need a place for the i2c
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1023
  // adapter to store the callee Method*. This value is NEVER live
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1024
  // across a gc point so it does NOT have to be gc'd
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1025
  // The handshake is open ended since we can't be certain that it will
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1026
  // be NULLed. This is because we rarely ever see the race and end up
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1027
  // in handle_wrong_method which is the backend of the handshake. See
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1028
  // code in i2c adapters and handle_wrong_method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1029
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1030
  Method*       _callee_target;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1031
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1032
  // Used to pass back results to the interpreter or generated code running Java code.
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1033
  oop           _vm_result;    // oop result is GC-preserved
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1034
  Metadata*     _vm_result_2;  // non-oop result
4030
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1035
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1036
  // See ReduceInitialCardMarks: this holds the precise space interval of
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1037
  // the most recent slow path allocation for which compiled code has
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1038
  // elided card-marks for performance along the fast-path.
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1039
  MemRegion     _deferred_card_mark;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1040
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1041
  MonitorChunk* _monitor_chunks;                 // Contains the off stack monitors
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1042
                                                 // allocated during deoptimization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1043
                                                 // and by JNI_MonitorEnter/Exit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1044
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1045
  // Async. requests support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1046
  enum AsyncRequests {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
    _no_async_condition = 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
    _async_exception,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1049
    _async_unsafe_access_error
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1050
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1051
  AsyncRequests _special_runtime_exit_condition; // Enum indicating pending async. request
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1052
  oop           _pending_async_exception;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1053
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1054
  // Safepoint support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1055
 public:                                         // Expose _thread_state for SafeFetchInt()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1056
  volatile JavaThreadState _thread_state;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
 private:
52673
61b3b58a1d1d 8214181: safepoint header cleanup
rehn
parents: 52431
diff changeset
  1058
  ThreadSafepointState* _safepoint_state;        // Holds information about a thread during a safepoint
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1059
  address               _saved_exception_pc;     // Saved pc of instruction where last implicit exception happened
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1060
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1061
  // JavaThread termination support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1062
  enum TerminatedTypes {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1063
    _not_terminated = 0xDEAD - 2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1064
    _thread_exiting,                             // JavaThread::exit() has been called for this thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1065
    _thread_terminated,                          // JavaThread is removed from thread list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1066
    _vm_exited                                   // JavaThread is still executing native code, but VM is terminated
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1067
                                                 // only VM_Exit can set _vm_exited
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1068
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1070
  // In general a JavaThread's _terminated field transitions as follows:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1071
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1072
  //   _not_terminated => _thread_exiting => _thread_terminated
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1073
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1074
  // _vm_exited is a special value to cover the case of a JavaThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1075
  // executing native code after the VM itself is terminated.
7897
201a8b00ec91 6814943: getcpool001 catches more than one JvmtiThreadState problem
kamg
parents: 7724
diff changeset
  1076
  volatile TerminatedTypes _terminated;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1077
  // suspend/resume support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1078
  volatile bool         _suspend_equivalent;     // Suspend equivalent condition
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1079
  jint                  _in_deopt_handler;       // count of deoptimization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1080
                                                 // handlers thread is in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
  volatile bool         _doing_unsafe_access;    // Thread may fault due to unsafe access
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1082
  bool                  _do_not_unlock_if_synchronized;  // Do not unlock the receiver of a synchronized method (since it was
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1083
                                                         // never locked) when throwing an exception. Used by interpreter only.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1084
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1085
  // JNI attach states:
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1086
  enum JNIAttachStates {
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1087
    _not_attaching_via_jni = 1,  // thread is not attaching via JNI
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1088
    _attaching_via_jni,          // thread is attaching via JNI
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1089
    _attached_via_jni            // thread has attached via JNI
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1090
  };
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1091
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1092
  // A regular JavaThread's _jni_attach_state is _not_attaching_via_jni.
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1093
  // A native thread that is attaching via JNI starts with a value
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1094
  // of _attaching_via_jni and transitions to _attached_via_jni.
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1095
  volatile JNIAttachStates _jni_attach_state;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1096
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1097
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1098
  // State of the stack guard pages for this thread.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1099
  enum StackGuardState {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1100
    stack_guard_unused,         // not needed
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1101
    stack_guard_reserved_disabled,
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1102
    stack_guard_yellow_reserved_disabled,// disabled (temporarily) after stack overflow
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1103
    stack_guard_enabled         // enabled
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1104
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1105
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1106
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1107
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1108
#if INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1109
  // The _pending_* fields below are used to communicate extra information
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1110
  // from an uncommon trap in JVMCI compiled code to the uncommon trap handler.
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1111
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1112
  // Communicates the DeoptReason and DeoptAction of the uncommon trap
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1113
  int       _pending_deoptimization;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1114
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1115
  // Specifies whether the uncommon trap is to bci 0 of a synchronized method
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1116
  // before the monitor has been acquired.
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1117
  bool      _pending_monitorenter;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1118
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1119
  // Specifies if the DeoptReason for the last uncommon trap was Reason_transfer_to_interpreter
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1120
  bool      _pending_transfer_to_interpreter;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1121
52033
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1122
  // True if in a runtime call from compiled code that will deoptimize
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1123
  // and re-execute a failed heap allocation in the interpreter.
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1124
  bool      _in_retryable_allocation;
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1125
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50785
diff changeset
  1126
  // An id of a speculation that JVMCI compiled code can use to further describe and
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1127
  // uniquely identify the  speculative optimization guarded by the uncommon trap
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54647
diff changeset
  1128
  jlong     _pending_failed_speculation;
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1129
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1130
  // These fields are mutually exclusive in terms of live ranges.
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1131
  union {
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1132
    // Communicates the pc at which the most recent implicit exception occurred
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1133
    // from the signal handler to a deoptimization stub.
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1134
    address   _implicit_exception_pc;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1135
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1136
    // Communicates an alternative call target to an i2c stub from a JavaCall .
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1137
    address   _alternate_call_target;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1138
  } _jvmci;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1139
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1140
  // Support for high precision, thread sensitive counters in JVMCI compiled code.
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1141
  jlong*    _jvmci_counters;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1142
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1143
 public:
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1144
  static jlong* _jvmci_old_thread_counters;
54732
2d012a75d35c 8223332: Update JVMCI
kvn
parents: 54669
diff changeset
  1145
  static void collect_counters(jlong* array, int length);
58282
03fce7b04b42 8230395: Code checks for NULL value returned from NEW_C_HEAP_ARRAY which can not happen
dholmes
parents: 58243
diff changeset
  1146
  void resize_counters(int current_size, int new_size);
03fce7b04b42 8230395: Code checks for NULL value returned from NEW_C_HEAP_ARRAY which can not happen
dholmes
parents: 58243
diff changeset
  1147
  static void resize_all_jvmci_counters(int new_size);
55206
2fe2063fe567 8225019: Update JVMCI
kvn
parents: 55005
diff changeset
  1148
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1149
 private:
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1150
#endif // INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1151
22810
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1152
  StackGuardState  _stack_guard_state;
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1153
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1154
  // Precompute the limit of the stack as used in stack overflow checks.
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1155
  // We load it from here to simplify the stack overflow check in assembly.
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1156
  address          _stack_overflow_limit;
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1157
  address          _reserved_stack_activation;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
  // Compiler exception handling (NOTE: The _exception_oop is *NOT* the same as _pending_exception. It is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1160
  // used to temp. parsing values into and out of the runtime system during exception handling for compiled
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
  // code)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
  volatile oop     _exception_oop;               // Exception thrown in compiled code
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
  volatile address _exception_pc;                // PC where exception happened
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1164
  volatile address _exception_handler_pc;        // PC for handler of exception
5252
58f23871a5b6 6941529: SharedRuntime::raw_exception_handler_for_return_address must reset thread MethodHandle flag
twisti
parents: 4761
diff changeset
  1165
  volatile int     _is_method_handle_return;     // true (== 1) if the current exception PC is a MethodHandle call site.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1167
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
  // support for JNI critical regions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
  jint    _jni_active_critical;                  // count of entries into JNI critical region
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
25058
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1171
  // Checked JNI: function name requires exception check
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1172
  char* _pending_jni_exception_check_fn;
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1173
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
  // For deadlock detection.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
  int _depth_first_number;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
  // JVMTI PopFrame support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
  // This is set to popframe_pending to signal that top Java frame should be popped immediately
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
  int _popframe_condition;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1180
28039
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1181
  // If reallocation of scalar replaced objects fails, we throw OOM
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1182
  // and during exception propagation, pop the top
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1183
  // _frames_to_pop_failed_realloc frames, the ones that reference
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1184
  // failed reallocations.
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1185
  int _frames_to_pop_failed_realloc;
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1186
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
  friend class VMThread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
  friend class ThreadWaitTransition;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
  friend class VM_Exit;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1190
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1191
  void initialize();                             // Initialized the instance variables
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
  // Constructor
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1195
  JavaThread(bool is_attaching_via_jni = false); // for main thread and JNI attached threads
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1196
  JavaThread(ThreadFunction entry_point, size_t stack_size = 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1197
  ~JavaThread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
  // verify this JavaThread hasn't be published in the Threads::list yet
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
  void verify_not_published();
57745
789e967c2731 5103339: Strengthen NoSafepointVerifier
coleenp
parents: 57699
diff changeset
  1202
#endif // ASSERT
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
  //JNI functiontable getter/setter for JVMTI jni function table interception API.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
  void set_jni_functions(struct JNINativeInterface_* functionTable) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1206
    _jni_environment.functions = functionTable;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
  struct JNINativeInterface_* get_jni_functions() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
    return (struct JNINativeInterface_ *)_jni_environment.functions;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1211
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5920
diff changeset
  1212
  // This function is called at thread creation to allow
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5920
diff changeset
  1213
  // platform specific thread variables to be initialized.
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5920
diff changeset
  1214
  void cache_global_variables();
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5920
diff changeset
  1215
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1216
  // Executes Shutdown.shutdown()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1217
  void invoke_shutdown_hooks();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1218
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1219
  // Cleanup on thread exit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1220
  enum ExitType {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1221
    normal_exit,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1222
    jni_detach
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1223
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1224
  void exit(bool destroy_vm, ExitType exit_type = normal_exit);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1225
54416
b788c494aa46 8218483: Crash in "assert(_daemon_threads_count->get_value() > daemon_count) failed: thread count mismatch 5 : 5"
dholmes
parents: 54385
diff changeset
  1226
  void cleanup_failed_attach_current_thread(bool is_daemon);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1227
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
  // Testers
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
  virtual bool is_Java_thread() const            { return true;  }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1230
  virtual bool can_call_java() const             { return true; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1231
57699
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
  1232
  virtual bool is_active_Java_thread() const {
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
  1233
    return on_thread_list() && !is_terminated();
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
  1234
  }
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57603
diff changeset
  1235
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1236
  // Thread oop. threadObj() can be NULL for initial JavaThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1237
  // (or for threads attached via JNI)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1238
  oop threadObj() const                          { return _threadObj; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1239
  void set_threadObj(oop p)                      { _threadObj = p; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1240
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1241
  // Prepare thread and add to priority queue.  If a priority is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
  // not specified, use the priority of the thread object. Threads_lock
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
  // must be held while this function is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
  void prepare(jobject jni_thread, ThreadPriority prio=NoPriority);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1245
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
  void set_saved_exception_pc(address pc)        { _saved_exception_pc = pc; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1247
  address saved_exception_pc()                   { return _saved_exception_pc; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
  ThreadFunction entry_point() const             { return _entry_point; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1251
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1252
  // Allocates a new Java level thread object for this thread. thread_name may be NULL.
27917
c5937f7b4e8b 8064669: compiler/whitebox/AllocationCodeBlobTest.java crashes / asserts
iignatyev
parents: 27651
diff changeset
  1253
  void allocate_threadObj(Handle thread_group, const char* thread_name, bool daemon, TRAPS);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
  // Last frame anchor routines
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
22870
f939d9a0440d 8032634: Add #ifdef PPC64 around OrderAccess operations on _thread_state.
goetz
parents: 22859
diff changeset
  1257
  JavaFrameAnchor* frame_anchor(void)            { return &_anchor; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
  // last_Java_sp
22870
f939d9a0440d 8032634: Add #ifdef PPC64 around OrderAccess operations on _thread_state.
goetz
parents: 22859
diff changeset
  1260
  bool has_last_Java_frame() const               { return _anchor.has_last_Java_frame(); }
f939d9a0440d 8032634: Add #ifdef PPC64 around OrderAccess operations on _thread_state.
goetz
parents: 22859
diff changeset
  1261
  intptr_t* last_Java_sp() const                 { return _anchor.last_Java_sp(); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1262
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
  // last_Java_pc
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
22870
f939d9a0440d 8032634: Add #ifdef PPC64 around OrderAccess operations on _thread_state.
goetz
parents: 22859
diff changeset
  1265
  address last_Java_pc(void)                     { return _anchor.last_Java_pc(); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
  // Safepoint support
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 23855
diff changeset
  1268
  inline JavaThreadState thread_state() const;
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 23855
diff changeset
  1269
  inline void set_thread_state(JavaThreadState s);
54495
941db9c0b5b5 8222231: Clean up interfaceSupport.inline.hpp duplicated code
coleenp
parents: 54416
diff changeset
  1270
  inline void set_thread_state_fence(JavaThreadState s);  // fence after setting thread state
52673
61b3b58a1d1d 8214181: safepoint header cleanup
rehn
parents: 52431
diff changeset
  1271
  inline ThreadSafepointState* safepoint_state() const;
61b3b58a1d1d 8214181: safepoint header cleanup
rehn
parents: 52431
diff changeset
  1272
  inline void set_safepoint_state(ThreadSafepointState* state);
61b3b58a1d1d 8214181: safepoint header cleanup
rehn
parents: 52431
diff changeset
  1273
  inline bool is_at_poll_safepoint();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1274
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1275
  // JavaThread termination and lifecycle support:
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1276
  void smr_delete();
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1277
  bool on_thread_list() const { return _on_thread_list; }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1278
  void set_on_thread_list() { _on_thread_list = true; }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1279
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
  // thread has called JavaThread::exit() or is terminated
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1281
  bool is_exiting() const;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1282
  // thread is terminated (no longer on the threads list); we compare
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
  // against the two non-terminated values so that a freed JavaThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
  // will also be considered terminated.
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1285
  bool check_is_terminated(TerminatedTypes l_terminated) const {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1286
    return l_terminated != _not_terminated && l_terminated != _thread_exiting;
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1287
  }
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1288
  bool is_terminated() const;
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1289
  void set_terminated(TerminatedTypes t);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
  // special for Threads::remove() which is static:
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1291
  void set_terminated_value();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
  void block_if_vm_exited();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1293
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
  bool doing_unsafe_access()                     { return _doing_unsafe_access; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
  void set_doing_unsafe_access(bool val)         { _doing_unsafe_access = val; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1297
  bool do_not_unlock_if_synchronized()             { return _do_not_unlock_if_synchronized; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
  void set_do_not_unlock_if_synchronized(bool val) { _do_not_unlock_if_synchronized = val; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
50921
7f462e8383f6 8206003: SafepointSynchronize with TLH: StoreStore barriers should be moved out of the loop
mdoerr
parents: 50858
diff changeset
  1300
  inline void set_polling_page_release(void* poll_value);
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1301
  inline void set_polling_page(void* poll_value);
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1302
  inline volatile void* get_polling_page();
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1303
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1304
 private:
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1305
  // Support for thread handshake operations
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1306
  HandshakeState _handshake;
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1307
 public:
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1308
  void set_handshake_operation(HandshakeOperation* op) {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1309
    _handshake.set_operation(this, op);
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1310
  }
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1311
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1312
  bool has_handshake() const {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1313
    return _handshake.has_operation();
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1314
  }
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1315
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1316
  void handshake_process_by_self() {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1317
    _handshake.process_by_self(this);
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1318
  }
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1319
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1320
  void handshake_process_by_vmthread() {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1321
    _handshake.process_by_vmthread(this);
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1322
  }
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47765
diff changeset
  1323
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1324
  // Suspend/resume support for JavaThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
 private:
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
  1326
  inline void set_ext_suspended();
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
  1327
  inline void clear_ext_suspended();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
 public:
54259
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1330
  void java_suspend(); // higher-level suspension logic called by the public APIs
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1331
  void java_resume();  // higher-level resume logic called by the public APIs
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1332
  int  java_suspend_self(); // low-level self-suspension mechanics
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
54259
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1334
 private:
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1335
  // mid-level wrapper around java_suspend_self to set up correct state and
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1336
  // check for a pending safepoint at the end
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1337
  void java_suspend_self_with_safepoint_check();
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1338
d25b24c70126 8221207: Redo JDK-8218446 - SuspendAtExit hangs
dholmes
parents: 54209
diff changeset
  1339
 public:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
  void check_and_wait_while_suspended() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
    assert(JavaThread::current() == this, "sanity check");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1342
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1343
    bool do_self_suspend;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1344
    do {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
      // were we externally suspended while we were waiting?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
      do_self_suspend = handle_special_suspend_equivalent_condition();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
      if (do_self_suspend) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1348
        // don't surprise the thread that suspended us by returning
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1349
        java_suspend_self();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
        set_suspend_equivalent();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
    } while (do_self_suspend);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
  static void check_safepoint_and_suspend_for_native_trans(JavaThread *thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
  // Check for async exception in addition to safepoint and suspend request.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
  static void check_special_condition_for_native_trans(JavaThread *thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
11637
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
  1358
  // Same as check_special_condition_for_native_trans but finishes the
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
  1359
  // transition into thread_in_Java mode so that it can potentially
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
  1360
  // block.
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
  1361
  static void check_special_condition_for_native_trans_and_transition(JavaThread *thread);
030466036615 7013347: allow crypto functions to be called inline to enhance performance
never
parents: 11631
diff changeset
  1362
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
  bool is_ext_suspend_completed(bool called_by_wait, int delay, uint32_t *bits);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1364
  bool is_ext_suspend_completed_with_lock(uint32_t *bits) {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 54562
diff changeset
  1365
    MutexLocker ml(SR_lock(), Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
    // Warning: is_ext_suspend_completed() may temporarily drop the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
    // SR_lock to allow the thread to reach a stable thread state if
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1368
    // it is currently in a transient thread state.
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1369
    return is_ext_suspend_completed(false /* !called_by_wait */,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1370
                                    SuspendRetryDelay, bits);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
  // We cannot allow wait_for_ext_suspend_completion() to run forever or
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1374
  // we could hang. SuspendRetryCount and SuspendRetryDelay are normally
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1375
  // passed as the count and delay parameters. Experiments with specific
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1376
  // calls to wait_for_ext_suspend_completion() can be done by passing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1377
  // other values in the code. Experiments with all calls can be done
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1378
  // via the appropriate -XX options.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1379
  bool wait_for_ext_suspend_completion(int count, int delay, uint32_t *bits);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1380
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1381
  // test for suspend - most (all?) of these should go away
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1382
  bool is_thread_fully_suspended(bool wait_for_suspend, uint32_t *bits);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  1383
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
  1384
  inline void set_external_suspend();
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
  1385
  inline void clear_external_suspend();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1386
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1387
  bool is_external_suspend() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1388
    return (_suspend_flags & _external_suspend) != 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1389
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1390
  // Whenever a thread transitions from native to vm/java it must suspend
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1391
  // if external|deopt suspend is present.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1392
  bool is_suspend_after_native() const {
54631
3a3e4e473622 8222637: Obsolete NeedsDeoptSuspend
rehn
parents: 54623
diff changeset
  1393
    return (_suspend_flags & (_external_suspend JFR_ONLY(| _trace_flag))) != 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1394
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1395
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1396
  // external suspend request is completed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1397
  bool is_ext_suspended() const {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1398
    return (_suspend_flags & _ext_suspended) != 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1399
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1400
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1401
  bool is_external_suspend_with_lock() const {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 54562
diff changeset
  1402
    MutexLocker ml(SR_lock(), Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1403
    return is_external_suspend();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1404
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1405
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1406
  // Special method to handle a pending external suspend request
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1407
  // when a suspend equivalent condition lifts.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1408
  bool handle_special_suspend_equivalent_condition() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
    assert(is_suspend_equivalent(),
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  1410
           "should only be called in a suspend equivalence condition");
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 54562
diff changeset
  1411
    MutexLocker ml(SR_lock(), Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1412
    bool ret = is_external_suspend();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1413
    if (!ret) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1414
      // not about to self-suspend so clear suspend equivalence
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1415
      clear_suspend_equivalent();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1416
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1417
    // implied else:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1418
    // We have a pending external suspend request so we leave the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1419
    // suspend_equivalent flag set until java_suspend_self() sets
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1420
    // the ext_suspended flag and clears the suspend_equivalent
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1421
    // flag. This insures that wait_for_ext_suspend_completion()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1422
    // will return consistent values.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1423
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1424
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1425
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1426
  // utility methods to see if we are doing some kind of suspension
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1427
  bool is_being_ext_suspended() const            {
54623
1126f0607c70 8222811: Consolidate MutexLockerEx and MutexLocker
coleenp
parents: 54562
diff changeset
  1428
    MutexLocker ml(SR_lock(), Mutex::_no_safepoint_check_flag);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1429
    return is_ext_suspended() || is_external_suspend();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1430
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1431
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1432
  bool is_suspend_equivalent() const             { return _suspend_equivalent; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1433
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1434
  void set_suspend_equivalent()                  { _suspend_equivalent = true; }
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1435
  void clear_suspend_equivalent()                { _suspend_equivalent = false; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1436
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1437
  // Thread.stop support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1438
  void send_thread_stop(oop throwable);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1439
  AsyncRequests clear_special_runtime_exit_condition() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1440
    AsyncRequests x = _special_runtime_exit_condition;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1441
    _special_runtime_exit_condition = _no_async_condition;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1442
    return x;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1443
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1444
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1445
  // Are any async conditions present?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1446
  bool has_async_condition() { return (_special_runtime_exit_condition != _no_async_condition); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1447
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1448
  void check_and_handle_async_exceptions(bool check_unsafe_error = true);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1449
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1450
  // these next two are also used for self-suspension and async exception support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1451
  void handle_special_runtime_exit_condition(bool check_asyncs = true);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1452
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1453
  // Return true if JavaThread has an asynchronous condition or
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1454
  // if external suspension is requested.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1455
  bool has_special_runtime_exit_condition() {
46643
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 46625
diff changeset
  1456
    // Because we don't use is_external_suspend_with_lock
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1457
    // it is possible that we won't see an asynchronous external suspend
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1458
    // request that has just gotten started, i.e., SR_lock grabbed but
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1459
    // _external_suspend field change either not made yet or not visible
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1460
    // yet. However, this is okay because the request is asynchronous and
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1461
    // we will see the new flag value the next time through. It's also
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1462
    // possible that the external suspend request is dropped after
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1463
    // we have checked is_external_suspend(), we will recheck its value
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1464
    // under SR_lock in java_suspend_self().
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1465
    return (_special_runtime_exit_condition != _no_async_condition) ||
47699
068d316e905e 6523512: has_special_runtime_exit_condition checks for is_deopt_suspend needlessly
jcm
parents: 47659
diff changeset
  1466
            is_external_suspend() || is_trace_suspend();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1467
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1468
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1469
  void set_pending_unsafe_access_error()          { _special_runtime_exit_condition = _async_unsafe_access_error; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1470
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 25064
diff changeset
  1471
  inline void set_pending_async_exception(oop e);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1472
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1473
  // Fast-locking support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1474
  bool is_lock_owned(address adr) const;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1475
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1476
  // Accessors for vframe array top
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1477
  // The linked list of vframe arrays are sorted on sp. This means when we
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1478
  // unpack the head must contain the vframe array to unpack.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1479
  void set_vframe_array_head(vframeArray* value) { _vframe_array_head = value; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1480
  vframeArray* vframe_array_head() const         { return _vframe_array_head;  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1481
22551
9bf46d16dcc6 8025856: Fix typos in the GC code
jwilhelm
parents: 20707
diff changeset
  1482
  // Side structure for deferring update of java frame locals until deopt occurs
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1483
  GrowableArray<jvmtiDeferredLocalVariableSet*>* deferred_locals() const { return _deferred_locals_updates; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1484
  void set_deferred_locals(GrowableArray<jvmtiDeferredLocalVariableSet *>* vf) { _deferred_locals_updates = vf; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1485
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1486
  // These only really exist to make debugging deopt problems simpler
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1487
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1488
  void set_vframe_array_last(vframeArray* value) { _vframe_array_last = value; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1489
  vframeArray* vframe_array_last() const         { return _vframe_array_last;  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1490
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1491
  // The special resourceMark used during deoptimization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1492
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1493
  void set_deopt_mark(DeoptResourceMark* value)  { _deopt_mark = value; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1494
  DeoptResourceMark* deopt_mark(void)            { return _deopt_mark; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1495
38133
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  1496
  void set_deopt_compiled_method(CompiledMethod* nm)  { _deopt_nmethod = nm; }
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  1497
  CompiledMethod* deopt_compiled_method()        { return _deopt_nmethod; }
6740
2bc601284215 6986270: guarantee(*bcp != Bytecodes::_monitorenter || exec_mode != Deoptimization::Unpack_exception) fails
iveresov
parents: 6184
diff changeset
  1498
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1499
  Method*    callee_target() const               { return _callee_target; }
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1500
  void set_callee_target  (Method* x)          { _callee_target   = x; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1501
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1502
  // Oop results of vm runtime calls
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1503
  oop  vm_result() const                         { return _vm_result; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1504
  void set_vm_result  (oop x)                    { _vm_result   = x; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1505
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1506
  Metadata*    vm_result_2() const               { return _vm_result_2; }
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1507
  void set_vm_result_2  (Metadata* x)          { _vm_result_2   = x; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1508
4030
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1509
  MemRegion deferred_card_mark() const           { return _deferred_card_mark; }
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1510
  void set_deferred_card_mark(MemRegion mr)      { _deferred_card_mark = mr;   }
4c471254865e 6888898: CMS: ReduceInitialCardMarks unsafe in the presence of cms precleaning
ysr
parents: 3916
diff changeset
  1511
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1512
#if INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1513
  int  pending_deoptimization() const             { return _pending_deoptimization; }
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54647
diff changeset
  1514
  jlong pending_failed_speculation() const        { return _pending_failed_speculation; }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1515
  bool has_pending_monitorenter() const           { return _pending_monitorenter; }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1516
  void set_pending_monitorenter(bool b)           { _pending_monitorenter = b; }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1517
  void set_pending_deoptimization(int reason)     { _pending_deoptimization = reason; }
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54647
diff changeset
  1518
  void set_pending_failed_speculation(jlong failed_speculation) { _pending_failed_speculation = failed_speculation; }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1519
  void set_pending_transfer_to_interpreter(bool b) { _pending_transfer_to_interpreter = b; }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1520
  void set_jvmci_alternate_call_target(address a) { assert(_jvmci._alternate_call_target == NULL, "must be"); _jvmci._alternate_call_target = a; }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1521
  void set_jvmci_implicit_exception_pc(address a) { assert(_jvmci._implicit_exception_pc == NULL, "must be"); _jvmci._implicit_exception_pc = a; }
52033
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1522
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1523
  virtual bool in_retryable_allocation() const    { return _in_retryable_allocation; }
d6aa9ea2405d 8208686: [AOT] JVMTI ResourceExhausted event repeated for same allocation
dnsimon
parents: 51743
diff changeset
  1524
  void set_in_retryable_allocation(bool b)        { _in_retryable_allocation = b; }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1525
#endif // INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1526
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1527
  // Exception handling for compiled methods
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1528
  oop      exception_oop() const                 { return _exception_oop; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1529
  address  exception_pc() const                  { return _exception_pc; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1530
  address  exception_handler_pc() const          { return _exception_handler_pc; }
5252
58f23871a5b6 6941529: SharedRuntime::raw_exception_handler_for_return_address must reset thread MethodHandle flag
twisti
parents: 4761
diff changeset
  1531
  bool     is_method_handle_return() const       { return _is_method_handle_return == 1; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1532
20282
7f9cbdf89af2 7195622: CheckUnhandledOops has limited usefulness now
hseigel
parents: 19696
diff changeset
  1533
  void set_exception_oop(oop o)                  { (void)const_cast<oop&>(_exception_oop = o); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1534
  void set_exception_pc(address a)               { _exception_pc = a; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1535
  void set_exception_handler_pc(address a)       { _exception_handler_pc = a; }
5252
58f23871a5b6 6941529: SharedRuntime::raw_exception_handler_for_return_address must reset thread MethodHandle flag
twisti
parents: 4761
diff changeset
  1536
  void set_is_method_handle_return(bool value)   { _is_method_handle_return = value ? 1 : 0; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1537
20703
2de7fe0e9693 8005173: assert(false) failed: DEBUG MESSAGE: exception oop must be empty (macroAssembler_x86.cpp:625)
twisti
parents: 20282
diff changeset
  1538
  void clear_exception_oop_and_pc() {
2de7fe0e9693 8005173: assert(false) failed: DEBUG MESSAGE: exception oop must be empty (macroAssembler_x86.cpp:625)
twisti
parents: 20282
diff changeset
  1539
    set_exception_oop(NULL);
2de7fe0e9693 8005173: assert(false) failed: DEBUG MESSAGE: exception oop must be empty (macroAssembler_x86.cpp:625)
twisti
parents: 20282
diff changeset
  1540
    set_exception_pc(NULL);
2de7fe0e9693 8005173: assert(false) failed: DEBUG MESSAGE: exception oop must be empty (macroAssembler_x86.cpp:625)
twisti
parents: 20282
diff changeset
  1541
  }
2de7fe0e9693 8005173: assert(false) failed: DEBUG MESSAGE: exception oop must be empty (macroAssembler_x86.cpp:625)
twisti
parents: 20282
diff changeset
  1542
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1543
  // Stack overflow support
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1544
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1545
  //  (small addresses)
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1546
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1547
  //  --  <-- stack_end()                   ---
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1548
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1549
  //  |  red pages                           |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1550
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1551
  //  --  <-- stack_red_zone_base()          |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1552
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1553
  //  |                                     guard
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1554
  //  |  yellow pages                       zone
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1555
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1556
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1557
  //  --  <-- stack_yellow_zone_base()       |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1558
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1559
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1560
  //  |  reserved pages                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1561
  //  |                                      |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1562
  //  --  <-- stack_reserved_zone_base()    ---      ---
38734
69ced2325f58 8156922: [ppc] Implement template interpreter stack overflow checks as on x86/sparc.
goetz
parents: 38697
diff changeset
  1563
  //                                                 /|\  shadow     <--  stack_overflow_limit() (somewhere in here)
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1564
  //                                                  |   zone
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1565
  //                                                 \|/  size
38734
69ced2325f58 8156922: [ppc] Implement template interpreter stack overflow checks as on x86/sparc.
goetz
parents: 38697
diff changeset
  1566
  //  some untouched memory                          ---
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1567
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1568
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1569
  //  --
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1570
  //  |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1571
  //  |  shadow zone
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1572
  //  |
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1573
  //  --
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1574
  //  x    frame n
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1575
  //  --
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1576
  //  x    frame n-1
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1577
  //  x
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1578
  //  --
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1579
  //  ...
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1580
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1581
  //  --
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1582
  //  x    frame 0
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1583
  //  --  <-- stack_base()
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1584
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1585
  //  (large addresses)
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1586
  //
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1587
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1588
 private:
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1589
  // These values are derived from flags StackRedPages, StackYellowPages,
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1590
  // StackReservedPages and StackShadowPages. The zone size is determined
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1591
  // ergonomically if page_size > 4K.
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1592
  static size_t _stack_red_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1593
  static size_t _stack_yellow_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1594
  static size_t _stack_reserved_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1595
  static size_t _stack_shadow_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1596
 public:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1597
  inline size_t stack_available(address cur_sp);
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1598
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1599
  static size_t stack_red_zone_size() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1600
    assert(_stack_red_zone_size > 0, "Don't call this before the field is initialized.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1601
    return _stack_red_zone_size;
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1602
  }
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1603
  static void set_stack_red_zone_size(size_t s) {
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 41084
diff changeset
  1604
    assert(is_aligned(s, os::vm_page_size()),
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1605
           "We can not protect if the red zone size is not page aligned.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1606
    assert(_stack_red_zone_size == 0, "This should be called only once.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1607
    _stack_red_zone_size = s;
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1608
  }
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1609
  address stack_red_zone_base() {
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1610
    return (address)(stack_end() + stack_red_zone_size());
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1611
  }
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1612
  bool in_stack_red_zone(address a) {
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1613
    return a <= stack_red_zone_base() && a >= stack_end();
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1614
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1615
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1616
  static size_t stack_yellow_zone_size() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1617
    assert(_stack_yellow_zone_size > 0, "Don't call this before the field is initialized.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1618
    return _stack_yellow_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1619
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1620
  static void set_stack_yellow_zone_size(size_t s) {
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 41084
diff changeset
  1621
    assert(is_aligned(s, os::vm_page_size()),
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1622
           "We can not protect if the yellow zone size is not page aligned.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1623
    assert(_stack_yellow_zone_size == 0, "This should be called only once.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1624
    _stack_yellow_zone_size = s;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1625
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1626
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1627
  static size_t stack_reserved_zone_size() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1628
    // _stack_reserved_zone_size may be 0. This indicates the feature is off.
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1629
    return _stack_reserved_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1630
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1631
  static void set_stack_reserved_zone_size(size_t s) {
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 41084
diff changeset
  1632
    assert(is_aligned(s, os::vm_page_size()),
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1633
           "We can not protect if the reserved zone size is not page aligned.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1634
    assert(_stack_reserved_zone_size == 0, "This should be called only once.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1635
    _stack_reserved_zone_size = s;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1636
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1637
  address stack_reserved_zone_base() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1638
    return (address)(stack_end() +
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1639
                     (stack_red_zone_size() + stack_yellow_zone_size() + stack_reserved_zone_size()));
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1640
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1641
  bool in_stack_reserved_zone(address a) {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1642
    return (a <= stack_reserved_zone_base()) &&
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1643
           (a >= (address)((intptr_t)stack_reserved_zone_base() - stack_reserved_zone_size()));
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1644
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1645
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1646
  static size_t stack_yellow_reserved_zone_size() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1647
    return _stack_yellow_zone_size + _stack_reserved_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1648
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1649
  bool in_stack_yellow_reserved_zone(address a) {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1650
    return (a <= stack_reserved_zone_base()) && (a >= stack_red_zone_base());
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1651
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1652
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1653
  // Size of red + yellow + reserved zones.
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1654
  static size_t stack_guard_zone_size() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1655
    return stack_red_zone_size() + stack_yellow_reserved_zone_size();
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1656
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1657
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1658
  static size_t stack_shadow_zone_size() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1659
    assert(_stack_shadow_zone_size > 0, "Don't call this before the field is initialized.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1660
    return _stack_shadow_zone_size;
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1661
  }
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1662
  static void set_stack_shadow_zone_size(size_t s) {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1663
    // The shadow area is not allocated or protected, so
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1664
    // it needs not be page aligned.
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1665
    // But the stack bang currently assumes that it is a
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1666
    // multiple of page size. This guarantees that the bang
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1667
    // loop touches all pages in the shadow zone.
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1668
    // This can be guaranteed differently, as well.  E.g., if
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1669
    // the page size is a multiple of 4K, banging in 4K steps
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1670
    // suffices to touch all pages. (Some pages are banged
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1671
    // several times, though.)
46619
a3919f5e8d2b 8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents: 41084
diff changeset
  1672
    assert(is_aligned(s, os::vm_page_size()),
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1673
           "Stack bang assumes multiple of page size.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1674
    assert(_stack_shadow_zone_size == 0, "This should be called only once.");
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1675
    _stack_shadow_zone_size = s;
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1676
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1678
  void create_stack_guard_pages();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
  void remove_stack_guard_pages();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1681
  void enable_stack_reserved_zone();
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1682
  void disable_stack_reserved_zone();
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1683
  void enable_stack_yellow_reserved_zone();
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1684
  void disable_stack_yellow_reserved_zone();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
  void enable_stack_red_zone();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
  void disable_stack_red_zone();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1687
15926
8e87d545195f 7107135: Stack guard pages are no more protected after loading a shared library with executable stack
iklam
parents: 15482
diff changeset
  1688
  inline bool stack_guard_zone_unused();
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1689
  inline bool stack_yellow_reserved_zone_disabled();
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1690
  inline bool stack_reserved_zone_disabled();
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1691
  inline bool stack_guards_enabled();
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1692
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1693
  address reserved_stack_activation() const { return _reserved_stack_activation; }
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
  1694
  void set_reserved_stack_activation(address addr) {
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1695
    assert(_reserved_stack_activation == stack_base()
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1696
            || _reserved_stack_activation == NULL
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1697
            || addr == stack_base(), "Must not be set twice");
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1698
    _reserved_stack_activation = addr;
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1699
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1700
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
  // Attempt to reguard the stack after a stack overflow may have occurred.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1702
  // Returns true if (a) guard pages are not needed on this thread, (b) the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1703
  // pages are already guarded, or (c) the pages were successfully reguarded.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1704
  // Returns false if there is not enough stack space to reguard the pages, in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1705
  // which case the caller should unwind a frame and try again.  The argument
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1706
  // should be the caller's (approximate) sp.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1707
  bool reguard_stack(address cur_sp);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1708
  // Similar to above but see if current stackpoint is out of the guard area
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1709
  // and reguard if possible.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1710
  bool reguard_stack(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1711
22810
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1712
  address stack_overflow_limit() { return _stack_overflow_limit; }
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1713
  void set_stack_overflow_limit() {
38734
69ced2325f58 8156922: [ppc] Implement template interpreter stack overflow checks as on x86/sparc.
goetz
parents: 38697
diff changeset
  1714
    _stack_overflow_limit =
69ced2325f58 8156922: [ppc] Implement template interpreter stack overflow checks as on x86/sparc.
goetz
parents: 38697
diff changeset
  1715
      stack_end() + MAX2(JavaThread::stack_guard_zone_size(), JavaThread::stack_shadow_zone_size());
22810
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1716
  }
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1717
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1718
  // Misc. accessors/mutators
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1719
  void set_do_not_unlock(void)                   { _do_not_unlock_if_synchronized = true; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1720
  void clr_do_not_unlock(void)                   { _do_not_unlock_if_synchronized = false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1721
  bool do_not_unlock(void)                       { return _do_not_unlock_if_synchronized; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1722
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1723
  // For assembly stub generation
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1724
  static ByteSize threadObj_offset()             { return byte_offset_of(JavaThread, _threadObj); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1725
  static ByteSize jni_environment_offset()       { return byte_offset_of(JavaThread, _jni_environment); }
41084
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1726
  static ByteSize pending_jni_exception_check_fn_offset() {
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1727
    return byte_offset_of(JavaThread, _pending_jni_exception_check_fn);
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1728
  }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1729
  static ByteSize last_Java_sp_offset() {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1730
    return byte_offset_of(JavaThread, _anchor) + JavaFrameAnchor::last_Java_sp_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1731
  }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1732
  static ByteSize last_Java_pc_offset() {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1733
    return byte_offset_of(JavaThread, _anchor) + JavaFrameAnchor::last_Java_pc_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1734
  }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1735
  static ByteSize frame_anchor_offset() {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1736
    return byte_offset_of(JavaThread, _anchor);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1737
  }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1738
  static ByteSize callee_target_offset()         { return byte_offset_of(JavaThread, _callee_target); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1739
  static ByteSize vm_result_offset()             { return byte_offset_of(JavaThread, _vm_result); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1740
  static ByteSize vm_result_2_offset()           { return byte_offset_of(JavaThread, _vm_result_2); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1741
  static ByteSize thread_state_offset()          { return byte_offset_of(JavaThread, _thread_state); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1742
  static ByteSize saved_exception_pc_offset()    { return byte_offset_of(JavaThread, _saved_exception_pc); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1743
  static ByteSize osthread_offset()              { return byte_offset_of(JavaThread, _osthread); }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1744
#if INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1745
  static ByteSize pending_deoptimization_offset() { return byte_offset_of(JavaThread, _pending_deoptimization); }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1746
  static ByteSize pending_monitorenter_offset()  { return byte_offset_of(JavaThread, _pending_monitorenter); }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1747
  static ByteSize pending_failed_speculation_offset() { return byte_offset_of(JavaThread, _pending_failed_speculation); }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1748
  static ByteSize jvmci_alternate_call_target_offset() { return byte_offset_of(JavaThread, _jvmci._alternate_call_target); }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1749
  static ByteSize jvmci_implicit_exception_pc_offset() { return byte_offset_of(JavaThread, _jvmci._implicit_exception_pc); }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1750
  static ByteSize jvmci_counters_offset()        { return byte_offset_of(JavaThread, _jvmci_counters); }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  1751
#endif // INCLUDE_JVMCI
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1752
  static ByteSize exception_oop_offset()         { return byte_offset_of(JavaThread, _exception_oop); }
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1753
  static ByteSize exception_pc_offset()          { return byte_offset_of(JavaThread, _exception_pc); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1754
  static ByteSize exception_handler_pc_offset()  { return byte_offset_of(JavaThread, _exception_handler_pc); }
22810
3a4dae5224c7 8017313: PPC64 (part 6): stack handling improvements
goetz
parents: 18025
diff changeset
  1755
  static ByteSize stack_overflow_limit_offset()  { return byte_offset_of(JavaThread, _stack_overflow_limit); }
5252
58f23871a5b6 6941529: SharedRuntime::raw_exception_handler_for_return_address must reset thread MethodHandle flag
twisti
parents: 4761
diff changeset
  1756
  static ByteSize is_method_handle_return_offset() { return byte_offset_of(JavaThread, _is_method_handle_return); }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1757
  static ByteSize stack_guard_state_offset()     { return byte_offset_of(JavaThread, _stack_guard_state); }
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34666
diff changeset
  1758
  static ByteSize reserved_stack_activation_offset() { return byte_offset_of(JavaThread, _reserved_stack_activation); }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1759
  static ByteSize suspend_flags_offset()         { return byte_offset_of(JavaThread, _suspend_flags); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1760
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1761
  static ByteSize do_not_unlock_if_synchronized_offset() { return byte_offset_of(JavaThread, _do_not_unlock_if_synchronized); }
4761
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1762
  static ByteSize should_post_on_exceptions_flag_offset() {
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1763
    return byte_offset_of(JavaThread, _should_post_on_exceptions_flag);
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1764
  }
55490
3f3dc00a69a5 8191278: MappedByteBuffer bulk access memory failures are not handled gracefully
jcm
parents: 55479
diff changeset
  1765
  static ByteSize doing_unsafe_access_offset() { return byte_offset_of(JavaThread, _doing_unsafe_access); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1766
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1767
  // Returns the jni environment for this thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1768
  JNIEnv* jni_environment()                      { return &_jni_environment; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
  static JavaThread* thread_from_jni_environment(JNIEnv* env) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1771
    JavaThread *thread_from_jni_env = (JavaThread*)((intptr_t)env - in_bytes(jni_environment_offset()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1772
    // Only return NULL if thread is off the thread list; starting to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1773
    // exit should not return NULL.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1774
    if (thread_from_jni_env->is_terminated()) {
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  1775
      thread_from_jni_env->block_if_vm_exited();
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  1776
      return NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1777
    } else {
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  1778
      return thread_from_jni_env;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1779
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1780
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1781
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1782
  // JNI critical regions. These can nest.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1783
  bool in_critical()    { return _jni_active_critical > 0; }
11631
33813f69207b 7129164: JNI Get/ReleasePrimitiveArrayCritical doesn't scale
never
parents: 11480
diff changeset
  1784
  bool in_last_critical()  { return _jni_active_critical == 1; }
52673
61b3b58a1d1d 8214181: safepoint header cleanup
rehn
parents: 52431
diff changeset
  1785
  inline void enter_critical();
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1786
  void exit_critical() {
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1787
    assert(Thread::current() == this, "this must be current thread");
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1788
    _jni_active_critical--;
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1789
    assert(_jni_active_critical >= 0, "JNI critical nesting problem?");
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1790
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1791
41084
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1792
  // Checked JNI: is the programmer required to check for exceptions, if so specify
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1793
  // which function name. Returning to a Java frame should implicitly clear the
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1794
  // pending check, this is done for Native->Java transitions (i.e. user JNI code).
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1795
  // VM->Java transistions are not cleared, it is expected that JNI code enclosed
fc5db29fa08e 8164086: Checked JNI pending exception check should be cleared when returning to Java frame
dsimms
parents: 40010
diff changeset
  1796
  // within ThreadToNativeFromVM makes proper exception checks (i.e. VM internal).
25058
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1797
  bool is_pending_jni_exception_check() const { return _pending_jni_exception_check_fn != NULL; }
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1798
  void clear_pending_jni_exception_check() { _pending_jni_exception_check_fn = NULL; }
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1799
  const char* get_pending_jni_exception_check() const { return _pending_jni_exception_check_fn; }
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1800
  void set_pending_jni_exception_check(const char* fn_name) { _pending_jni_exception_check_fn = (char*) fn_name; }
4542f853c2ac 8043224: -Xcheck:jni improvements to exception checking and excessive local refs
dsimms
parents: 24424
diff changeset
  1801
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1802
  // For deadlock detection
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1803
  int depth_first_number() { return _depth_first_number; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1804
  void set_depth_first_number(int dfn) { _depth_first_number = dfn; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1805
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1806
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1807
  void set_monitor_chunks(MonitorChunk* monitor_chunks) { _monitor_chunks = monitor_chunks; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1808
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1809
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1810
  MonitorChunk* monitor_chunks() const           { return _monitor_chunks; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1811
  void add_monitor_chunk(MonitorChunk* chunk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1812
  void remove_monitor_chunk(MonitorChunk* chunk);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1813
  bool in_deopt_handler() const                  { return _in_deopt_handler > 0; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1814
  void inc_in_deopt_handler()                    { _in_deopt_handler++; }
25064
244218e6ec0a 8046758: cleanup non-indent white space issues prior to Contended Locking cleanup bucket
dcubed
parents: 25058
diff changeset
  1815
  void dec_in_deopt_handler() {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1816
    assert(_in_deopt_handler > 0, "mismatched deopt nesting");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1817
    if (_in_deopt_handler > 0) { // robustness
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1818
      _in_deopt_handler--;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1819
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1820
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1821
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1822
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1823
  void set_entry_point(ThreadFunction entry_point) { _entry_point = entry_point; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1824
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1825
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1826
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1827
  // Frame iteration; calls the function f for all frames on the stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1828
  void frames_do(void f(frame*, const RegisterMap*));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1829
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1830
  // Memory operations
38074
8475fdc6dcc3 8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents: 37474
diff changeset
  1831
  void oops_do(OopClosure* f, CodeBlobClosure* cf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1832
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1833
  // Sweeper operations
37288
a31d47bbbdf6 8074553: Crash with assert(!is_unloaded()) failed: should not call follow on unloaded nmethod
thartmann
parents: 36384
diff changeset
  1834
  virtual void nmethods_do(CodeBlobClosure* cf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1835
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1836
  // RedefineClasses Support
54150
5529640c5f67 8220512: Deoptimize redefinition functions that have dirty ICs
coleenp
parents: 54015
diff changeset
  1837
  void metadata_do(MetadataClosure* f);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1838
54278
16999bd91ba6 8220774: Add HandshakeALot diag option
rehn
parents: 54259
diff changeset
  1839
  // Debug method asserting thread states are correct during a handshake operation.
16999bd91ba6 8220774: Add HandshakeALot diag option
rehn
parents: 54259
diff changeset
  1840
  DEBUG_ONLY(void verify_states_for_handshake();)
16999bd91ba6 8220774: Add HandshakeALot diag option
rehn
parents: 54259
diff changeset
  1841
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1842
  // Misc. operations
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1843
  char* name() const { return (char*)get_thread_name(); }
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
  1844
  void print_on(outputStream* st, bool print_extended_info) const;
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
  1845
  void print_on(outputStream* st) const { print_on(st, false); }
54807
33fe50b6d707 8223626: move print() functions to cpp files
coleenp
parents: 54732
diff changeset
  1846
  void print() const;
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  1847
  void print_thread_state_on(outputStream*) const      PRODUCT_RETURN;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1848
  void print_on_error(outputStream* st, char* buf, int buflen) const;
35825
7c7652ee137b 8063112: Compiler diagnostic commands should have locking instead of safepoint
neliasso
parents: 35495
diff changeset
  1849
  void print_name_on_error(outputStream* st, char* buf, int buflen) const;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1850
  void verify();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1851
  const char* get_thread_name() const;
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
  1852
 protected:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1853
  // factor out low-level mechanics for use in both normal and error cases
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
  1854
  virtual const char* get_thread_name_string(char* buf = NULL, int buflen = 0) const;
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  1855
 public:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1856
  // Accessing frames
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1857
  frame last_frame() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1858
    _anchor.make_walkable(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1859
    return pd_last_frame();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1860
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1861
  javaVFrame* last_java_vframe(RegisterMap* reg_map);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1862
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1863
  // Returns method at 'depth' java or native frames down the stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1864
  // Used for security checks
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1865
  Klass* security_get_caller_class(int depth);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1866
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1867
  // Print stack trace in external format
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1868
  void print_stack_on(outputStream* st);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1869
  void print_stack() { print_stack_on(tty); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1870
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1871
  // Print stack traces in various internal formats
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1872
  void trace_stack()                             PRODUCT_RETURN;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1873
  void trace_stack_from(vframe* start_vf)        PRODUCT_RETURN;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1874
  void trace_frames()                            PRODUCT_RETURN;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1875
9437
9981851b4b8c 7009361: JSR 292 Invalid value on stack on solaris-sparc with -Xcomp
never
parents: 8110
diff changeset
  1876
  // Print an annotated view of the stack frames
9942
2e86734ba620 6996747: SIGSEGV in nmethod::cleanup_inline_caches / CompiledIC::verify
never
parents: 9437
diff changeset
  1877
  void print_frame_layout(int depth = 0, bool validate_only = false) NOT_DEBUG_RETURN;
9437
9981851b4b8c 7009361: JSR 292 Invalid value on stack on solaris-sparc with -Xcomp
never
parents: 8110
diff changeset
  1878
  void validate_frame_layout() {
9981851b4b8c 7009361: JSR 292 Invalid value on stack on solaris-sparc with -Xcomp
never
parents: 8110
diff changeset
  1879
    print_frame_layout(0, true);
9981851b4b8c 7009361: JSR 292 Invalid value on stack on solaris-sparc with -Xcomp
never
parents: 8110
diff changeset
  1880
  }
9981851b4b8c 7009361: JSR 292 Invalid value on stack on solaris-sparc with -Xcomp
never
parents: 8110
diff changeset
  1881
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1882
  // Function for testing deoptimization
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1883
  void deoptimize();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1884
  void make_zombies();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1885
58226
408c445d04e8 8226705: [REDO] Deoptimize with handshakes
rehn
parents: 58196
diff changeset
  1886
  void deoptimize_marked_methods();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1887
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1888
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1889
  // Returns the running thread as a JavaThread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1890
  static inline JavaThread* current();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1891
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1892
  // Returns the active Java thread.  Do not use this if you know you are calling
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1893
  // from a JavaThread, as it's slower than JavaThread::current.  If called from
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1894
  // the VMThread, it also returns the JavaThread that instigated the VMThread's
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1895
  // operation.  You may not want that either.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1896
  static JavaThread* active();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1897
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1898
  inline CompilerThread* as_CompilerThread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1899
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
  1900
 protected:
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
  1901
  virtual void pre_run();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1902
  virtual void run();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1903
  void thread_main_inner();
53103
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
  1904
  virtual void post_run();
67e3a8b3449c 8214097: Rework thread initialization and teardown logic
dholmes
parents: 53084
diff changeset
  1905
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1906
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1907
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1908
  GrowableArray<oop>* _array_for_gc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1909
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1910
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1911
  void register_array_for_gc(GrowableArray<oop>* array) { _array_for_gc = array; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1912
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1913
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1914
  // Thread local information maintained by JVMTI.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1915
  void set_jvmti_thread_state(JvmtiThreadState *value)                           { _jvmti_thread_state = value; }
2135
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1916
  // A JvmtiThreadState is lazily allocated. This jvmti_thread_state()
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1917
  // getter is used to get this JavaThread's JvmtiThreadState if it has
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1918
  // one which means NULL can be returned. JvmtiThreadState::state_for()
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1919
  // is used to get the specified JavaThread's JvmtiThreadState if it has
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1920
  // one or it allocates a new JvmtiThreadState for the JavaThread and
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1921
  // returns it. JvmtiThreadState::state_for() will return NULL only if
f82c3012ec86 6800721: 3/4 JavaThread::jvmti_thread_state() and JvmtiThreadState::state_for() robustness
dcubed
parents: 1623
diff changeset
  1922
  // the specified JavaThread is exiting.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1923
  JvmtiThreadState *jvmti_thread_state() const                                   { return _jvmti_thread_state; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1924
  static ByteSize jvmti_thread_state_offset()                                    { return byte_offset_of(JavaThread, _jvmti_thread_state); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1925
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1926
  // JVMTI PopFrame support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1927
  // Setting and clearing popframe_condition
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1928
  // All of these enumerated values are bits. popframe_pending
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1929
  // indicates that a PopFrame() has been requested and not yet been
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1930
  // completed. popframe_processing indicates that that PopFrame() is in
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1931
  // the process of being completed. popframe_force_deopt_reexecution_bit
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1932
  // indicates that special handling is required when returning to a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1933
  // deoptimized caller.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1934
  enum PopCondition {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1935
    popframe_inactive                      = 0x00,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1936
    popframe_pending_bit                   = 0x01,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1937
    popframe_processing_bit                = 0x02,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1938
    popframe_force_deopt_reexecution_bit   = 0x04
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1939
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1940
  PopCondition popframe_condition()                   { return (PopCondition) _popframe_condition; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1941
  void set_popframe_condition(PopCondition c)         { _popframe_condition = c; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1942
  void set_popframe_condition_bit(PopCondition c)     { _popframe_condition |= c; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1943
  void clear_popframe_condition()                     { _popframe_condition = popframe_inactive; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1944
  static ByteSize popframe_condition_offset()         { return byte_offset_of(JavaThread, _popframe_condition); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1945
  bool has_pending_popframe()                         { return (popframe_condition() & popframe_pending_bit) != 0; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1946
  bool popframe_forcing_deopt_reexecution()           { return (popframe_condition() & popframe_force_deopt_reexecution_bit) != 0; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1947
  void clear_popframe_forcing_deopt_reexecution()     { _popframe_condition &= ~popframe_force_deopt_reexecution_bit; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1948
#ifdef CC_INTERP
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1949
  bool pop_frame_pending(void)                        { return ((_popframe_condition & popframe_pending_bit) != 0); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1950
  void clr_pop_frame_pending(void)                    { _popframe_condition = popframe_inactive; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1951
  bool pop_frame_in_process(void)                     { return ((_popframe_condition & popframe_processing_bit) != 0); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1952
  void set_pop_frame_in_process(void)                 { _popframe_condition |= popframe_processing_bit; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1953
  void clr_pop_frame_in_process(void)                 { _popframe_condition &= ~popframe_processing_bit; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1954
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1955
28039
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1956
  int frames_to_pop_failed_realloc() const            { return _frames_to_pop_failed_realloc; }
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1957
  void set_frames_to_pop_failed_realloc(int nb)       { _frames_to_pop_failed_realloc = nb; }
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1958
  void dec_frames_to_pop_failed_realloc()             { _frames_to_pop_failed_realloc--; }
bf5a8340bf8a 6898462: The escape analysis with G1 cause crash assertion src/share/vm/runtime/vframeArray.cpp:94
roland
parents: 27917
diff changeset
  1959
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1960
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1961
  // Saved incoming arguments to popped frame.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1962
  // Used only when popped interpreted frame returns to deoptimized frame.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1963
  void*    _popframe_preserved_args;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1964
  int      _popframe_preserved_args_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1965
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1966
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1967
  void  popframe_preserve_args(ByteSize size_in_bytes, void* start);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1968
  void* popframe_preserved_args();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1969
  ByteSize popframe_preserved_args_size();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1970
  WordSize popframe_preserved_args_size_in_words();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1971
  void  popframe_free_preserved_args();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1972
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1973
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1974
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1975
  JvmtiThreadState *_jvmti_thread_state;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1976
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1977
  // Used by the interpreter in fullspeed mode for frame pop, method
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1978
  // entry, method exit and single stepping support. This field is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1979
  // only set to non-zero by the VM_EnterInterpOnlyMode VM operation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1980
  // It can be set to zero asynchronously (i.e., without a VM operation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1981
  // or a lock) so we have to be very careful.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1982
  int               _interp_only_mode;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1983
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1984
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1985
  // used by the interpreter for fullspeed debugging support (see above)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1986
  static ByteSize interp_only_mode_offset() { return byte_offset_of(JavaThread, _interp_only_mode); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1987
  bool is_interp_only_mode()                { return (_interp_only_mode != 0); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1988
  int get_interp_only_mode()                { return _interp_only_mode; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1989
  void increment_interp_only_mode()         { ++_interp_only_mode; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1990
  void decrement_interp_only_mode()         { --_interp_only_mode; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1991
4761
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1992
  // support for cached flag that indicates whether exceptions need to be posted for this thread
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1993
  // if this is false, we can avoid deoptimizing when events are thrown
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1994
  // this gets set to reflect whether jvmtiExport::post_exception_throw would actually do anything
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1995
 private:
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1996
  int    _should_post_on_exceptions_flag;
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1997
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1998
 public:
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  1999
  int   should_post_on_exceptions_flag()  { return _should_post_on_exceptions_flag; }
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  2000
  void  set_should_post_on_exceptions_flag(int val)  { _should_post_on_exceptions_flag = val; }
bdb7375a1fee 6902182: 4/4 Starting with jdwp agent should not incur performance penalty
dcubed
parents: 4573
diff changeset
  2001
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2002
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2003
  ThreadStatistics *_thread_stat;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2004
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2005
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2006
  ThreadStatistics* get_thread_stat() const    { return _thread_stat; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2007
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2008
  // Return a blocker object for which this thread is blocked parking.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2009
  oop current_park_blocker();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2010
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2011
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2012
  static size_t _stack_size_at_create;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2013
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2014
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2015
  static inline size_t stack_size_at_create(void) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2016
    return _stack_size_at_create;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2017
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2018
  static inline void set_stack_size_at_create(size_t value) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2019
    _stack_size_at_create = value;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2020
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2021
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2022
  // Machine dependent stuff
40010
e32d5e545789 8161258: Simplify including platform files.
goetz
parents: 38734
diff changeset
  2023
#include OS_CPU_HEADER(thread)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2024
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2025
  // JSR166 per-thread parker
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2026
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2027
  Parker*    _parker;
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2028
 public:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2029
  Parker*     parker() { return _parker; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2030
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2031
  // Biased locking support
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2032
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2033
  GrowableArray<MonitorInfo*>* _cached_monitor_info;
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2034
 public:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2035
  GrowableArray<MonitorInfo*>* cached_monitor_info() { return _cached_monitor_info; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2036
  void set_cached_monitor_info(GrowableArray<MonitorInfo*>* info) { _cached_monitor_info = info; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2037
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2038
  // clearing/querying jni attach status
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2039
  bool is_attaching_via_jni() const { return _jni_attach_state == _attaching_via_jni; }
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2040
  bool has_attached_via_jni() const { return is_attaching_via_jni() || _jni_attach_state == _attached_via_jni; }
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 23855
diff changeset
  2041
  inline void set_done_attaching_via_jni();
53305
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2042
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2043
  // Stack dump assistance:
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2044
  // Track the class we want to initialize but for which we have to wait
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2045
  // on its init_lock() because it is already being initialized.
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2046
  void set_class_to_be_initialized(InstanceKlass* k);
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2047
  InstanceKlass* class_to_be_initialized() const;
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2048
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2049
private:
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2050
  InstanceKlass* _class_to_be_initialized;
d193d58ae79d 8213397: Stack dump should show more clearly when a thread is blocked on a class initialization monitor
dholmes
parents: 53244
diff changeset
  2051
58095
adc72cd1d1f2 8230423: Move os::sleep to JavaThread::sleep
dholmes
parents: 57906
diff changeset
  2052
  // java.lang.Thread.sleep support
58196
cea6839598e8 8230424: Use platform independent code for Thread.interrupt support
dholmes
parents: 58124
diff changeset
  2053
  ParkEvent * _SleepEvent;
58095
adc72cd1d1f2 8230423: Move os::sleep to JavaThread::sleep
dholmes
parents: 57906
diff changeset
  2054
public:
adc72cd1d1f2 8230423: Move os::sleep to JavaThread::sleep
dholmes
parents: 57906
diff changeset
  2055
  bool sleep(jlong millis);
58196
cea6839598e8 8230424: Use platform independent code for Thread.interrupt support
dholmes
parents: 58124
diff changeset
  2056
cea6839598e8 8230424: Use platform independent code for Thread.interrupt support
dholmes
parents: 58124
diff changeset
  2057
  // java.lang.Thread interruption support
cea6839598e8 8230424: Use platform independent code for Thread.interrupt support
dholmes
parents: 58124
diff changeset
  2058
  void interrupt();
cea6839598e8 8230424: Use platform independent code for Thread.interrupt support
dholmes
parents: 58124
diff changeset
  2059
  bool is_interrupted(bool clear_interrupted);
cea6839598e8 8230424: Use platform independent code for Thread.interrupt support
dholmes
parents: 58124
diff changeset
  2060
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2061
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2062
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2063
// Inline implementation of JavaThread::current
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2064
inline JavaThread* JavaThread::current() {
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
  2065
  Thread* thread = Thread::current();
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 33792
diff changeset
  2066
  assert(thread->is_Java_thread(), "just checking");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2067
  return (JavaThread*)thread;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2068
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2070
inline CompilerThread* JavaThread::as_CompilerThread() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2071
  assert(is_Compiler_thread(), "just checking");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2072
  return (CompilerThread*)this;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2073
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2074
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2075
// Dedicated thread to sweep the code cache
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2076
class CodeCacheSweeperThread : public JavaThread {
38133
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  2077
  CompiledMethod*       _scanned_compiled_method; // nmethod being scanned by the sweeper
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2078
 public:
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2079
  CodeCacheSweeperThread();
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2080
  // Track the nmethod currently being scanned by the sweeper
38133
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  2081
  void set_scanned_compiled_method(CompiledMethod* cm) {
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  2082
    assert(_scanned_compiled_method == NULL || cm == NULL, "should reset to NULL before writing a new value");
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  2083
    _scanned_compiled_method = cm;
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2084
  }
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2085
27433
b276c91c1264 8062284: Sweeper thread should not be visible when calling Thread.getAllStackTraces()
anoll
parents: 27429
diff changeset
  2086
  // Hide sweeper thread from external view.
b276c91c1264 8062284: Sweeper thread should not be visible when calling Thread.getAllStackTraces()
anoll
parents: 27429
diff changeset
  2087
  bool is_hidden_from_external_view() const { return true; }
b276c91c1264 8062284: Sweeper thread should not be visible when calling Thread.getAllStackTraces()
anoll
parents: 27429
diff changeset
  2088
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2089
  bool is_Code_cache_sweeper_thread() const { return true; }
37288
a31d47bbbdf6 8074553: Crash with assert(!is_unloaded()) failed: should not call follow on unloaded nmethod
thartmann
parents: 36384
diff changeset
  2090
38133
78b95467b9f1 8151956: Support non-continuous CodeBlobs in HotSpot
rbackman
parents: 37474
diff changeset
  2091
  // Prevent GC from unloading _scanned_compiled_method
38074
8475fdc6dcc3 8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents: 37474
diff changeset
  2092
  void oops_do(OopClosure* f, CodeBlobClosure* cf);
37288
a31d47bbbdf6 8074553: Crash with assert(!is_unloaded()) failed: should not call follow on unloaded nmethod
thartmann
parents: 36384
diff changeset
  2093
  void nmethods_do(CodeBlobClosure* cf);
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2094
};
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2095
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2096
// A thread used for Compilation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2097
class CompilerThread : public JavaThread {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2098
  friend class VMStructs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2099
 private:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2100
  CompilerCounters* _counters;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2101
48428
e569e83139fd 8194482: Fix SIGSEGV in print_threads_compiling.
goetz
parents: 48312
diff changeset
  2102
  ciEnv*                _env;
e569e83139fd 8194482: Fix SIGSEGV in print_threads_compiling.
goetz
parents: 48312
diff changeset
  2103
  CompileLog*           _log;
e569e83139fd 8194482: Fix SIGSEGV in print_threads_compiling.
goetz
parents: 48312
diff changeset
  2104
  CompileTask* volatile _task;  // print_threads_compiling can read this concurrently.
e569e83139fd 8194482: Fix SIGSEGV in print_threads_compiling.
goetz
parents: 48312
diff changeset
  2105
  CompileQueue*         _queue;
e569e83139fd 8194482: Fix SIGSEGV in print_threads_compiling.
goetz
parents: 48312
diff changeset
  2106
  BufferBlob*           _buffer_blob;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2107
48428
e569e83139fd 8194482: Fix SIGSEGV in print_threads_compiling.
goetz
parents: 48312
diff changeset
  2108
  AbstractCompiler*     _compiler;
49848
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2109
  TimeStamp             _idle_time;
9942
2e86734ba620 6996747: SIGSEGV in nmethod::cleanup_inline_caches / CompiledIC::verify
never
parents: 9437
diff changeset
  2110
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2111
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2112
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2113
  static CompilerThread* current();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2114
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2115
  CompilerThread(CompileQueue* queue, CompilerCounters* counters);
49848
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2116
  ~CompilerThread();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2117
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2118
  bool is_Compiler_thread() const                { return true; }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  2119
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  2120
  virtual bool can_call_java() const;
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  2121
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  2122
  // Hide native compiler threads from external view.
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32575
diff changeset
  2123
  bool is_hidden_from_external_view() const      { return !can_call_java(); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2124
20707
b3b658c6d1f8 8023014: CodeSweeperSweepNoFlushTest.java fails with HS crash
anoll
parents: 20703
diff changeset
  2125
  void set_compiler(AbstractCompiler* c)         { _compiler = c; }
b3b658c6d1f8 8023014: CodeSweeperSweepNoFlushTest.java fails with HS crash
anoll
parents: 20703
diff changeset
  2126
  AbstractCompiler* compiler() const             { return _compiler; }
b3b658c6d1f8 8023014: CodeSweeperSweepNoFlushTest.java fails with HS crash
anoll
parents: 20703
diff changeset
  2127
b3b658c6d1f8 8023014: CodeSweeperSweepNoFlushTest.java fails with HS crash
anoll
parents: 20703
diff changeset
  2128
  CompileQueue* queue()        const             { return _queue; }
b3b658c6d1f8 8023014: CodeSweeperSweepNoFlushTest.java fails with HS crash
anoll
parents: 20703
diff changeset
  2129
  CompilerCounters* counters() const             { return _counters; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2130
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2131
  // Get/set the thread's compilation environment.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2132
  ciEnv*        env()                            { return _env; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2133
  void          set_env(ciEnv* env)              { _env = env; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2134
20707
b3b658c6d1f8 8023014: CodeSweeperSweepNoFlushTest.java fails with HS crash
anoll
parents: 20703
diff changeset
  2135
  BufferBlob*   get_buffer_blob() const          { return _buffer_blob; }
26684
d1221849ea3d 8057109: manual cleanup of white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 26683
diff changeset
  2136
  void          set_buffer_blob(BufferBlob* b)   { _buffer_blob = b; }
5707
6c66849ed24e 6958292: C1: Enable parallel compilation
iveresov
parents: 5547
diff changeset
  2137
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2138
  // Get/set the thread's logging information
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2139
  CompileLog*   log()                            { return _log; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2140
  void          init_log(CompileLog* log) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2141
    // Set once, for good.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2142
    assert(_log == NULL, "set only once");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2143
    _log = log;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2144
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2145
49848
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2146
  void start_idle_timer()                        { _idle_time.update(); }
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2147
  jlong idle_time_millis() {
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2148
    return TimeHelper::counter_to_millis(_idle_time.ticks_since_update());
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2149
  }
fcd5df7aa235 8198756: Lazy allocation of compiler threads
mdoerr
parents: 49800
diff changeset
  2150
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2151
#ifndef PRODUCT
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2152
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2153
  IdealGraphPrinter *_ideal_graph_printer;
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2154
 public:
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2155
  IdealGraphPrinter *ideal_graph_printer()           { return _ideal_graph_printer; }
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2156
  void set_ideal_graph_printer(IdealGraphPrinter *n) { _ideal_graph_printer = n; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2157
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2158
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2159
  // Get/set the thread's current task
27420
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2160
  CompileTask* task()                      { return _task; }
04e6f914cce1 8046809: vm/mlvm/meth/stress/compiler/deoptimize CodeCache is full.
anoll
parents: 26834
diff changeset
  2161
  void         set_task(CompileTask* task) { _task = task; }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2162
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2163
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2164
inline CompilerThread* CompilerThread::current() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2165
  return JavaThread::current()->as_CompilerThread();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2166
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2167
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2168
// The active thread queue. It also keeps track of the current used
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2169
// thread priorities.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2170
class Threads: AllStatic {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2171
  friend class VMStructs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2172
 private:
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
  2173
  static int         _number_of_threads;
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
  2174
  static int         _number_of_non_daemon_threads;
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
  2175
  static int         _return_code;
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2176
  static uintx       _thread_claim_token;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2177
#ifdef ASSERT
48312
2a1413298af0 8191789: migrate more Thread-SMR stuff from thread.[ch]pp -> threadSMR.[ch]pp
dcubed
parents: 48173
diff changeset
  2178
  static bool        _vm_complete;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2179
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2180
22539
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 20707
diff changeset
  2181
  static void initialize_java_lang_classes(JavaThread* main_thread, TRAPS);
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 20707
diff changeset
  2182
  static void initialize_jsr292_core_classes(TRAPS);
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2183
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2184
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2185
  // Thread management
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2186
  // force_daemon is a concession to JNI, where we may need to add a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2187
  // thread to the thread list before allocating its thread object
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2188
  static void add(JavaThread* p, bool force_daemon = false);
54416
b788c494aa46 8218483: Crash in "assert(_daemon_threads_count->get_value() > daemon_count) failed: thread count mismatch 5 : 5"
dholmes
parents: 54385
diff changeset
  2189
  static void remove(JavaThread* p, bool is_daemon);
49756
129d60b5dac7 8200374: Add ThreadsSMRSupport::verify_hazard_pointer_scanned() to verify threads_do().
dcubed
parents: 49752
diff changeset
  2190
  static void non_java_threads_do(ThreadClosure* tc);
50058
f7e564cacfbc 8202649: Move the Parallel GC specific task creation functions out of Threads
stefank
parents: 49982
diff changeset
  2191
  static void java_threads_do(ThreadClosure* tc);
f7e564cacfbc 8202649: Move the Parallel GC specific task creation functions out of Threads
stefank
parents: 49982
diff changeset
  2192
  static void java_threads_and_vm_thread_do(ThreadClosure* tc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2193
  static void threads_do(ThreadClosure* tc);
47637
87141990dde5 8185580: Refactor Threads::possibly_parallel_oops_do() to use Threads::parallel_java_threads_do()
rkennke
parents: 47216
diff changeset
  2194
  static void possibly_parallel_threads_do(bool is_par, ThreadClosure* tc);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2195
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2196
  // Initializes the vm and creates the vm thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2197
  static jint create_vm(JavaVMInitArgs* args, bool* canTryAgain);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2198
  static void convert_vm_init_libraries_to_agents();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2199
  static void create_vm_init_libraries();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2200
  static void create_vm_init_agents();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2201
  static void shutdown_vm_agents();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2202
  static bool destroy_vm();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2203
  // Supported VM versions via JNI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2204
  // Includes JNI_VERSION_1_1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2205
  static jboolean is_supported_jni_version_including_1_1(jint version);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2206
  // Does not include JNI_VERSION_1_1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2207
  static jboolean is_supported_jni_version(jint version);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2208
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2209
  // The "thread claim token" provides a way for threads to be claimed
30153
596ed88949ad 8076289: Move the StrongRootsScope out of SharedHeap
brutisso
parents: 30147
diff changeset
  2210
  // by parallel worker tasks.
596ed88949ad 8076289: Move the StrongRootsScope out of SharedHeap
brutisso
parents: 30147
diff changeset
  2211
  //
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2212
  // Each thread contains a "token" field. A task will claim the
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2213
  // thread only if its token is different from the global token,
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2214
  // which is updated by calling change_thread_claim_token().  When
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2215
  // a thread is claimed, it's token is set to the global token value
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2216
  // so other threads in the same iteration pass won't claim it.
30153
596ed88949ad 8076289: Move the StrongRootsScope out of SharedHeap
brutisso
parents: 30147
diff changeset
  2217
  //
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2218
  // For this to work change_thread_claim_token() needs to be called
30153
596ed88949ad 8076289: Move the StrongRootsScope out of SharedHeap
brutisso
parents: 30147
diff changeset
  2219
  // exactly once in sequential code before starting parallel tasks
596ed88949ad 8076289: Move the StrongRootsScope out of SharedHeap
brutisso
parents: 30147
diff changeset
  2220
  // that should claim threads.
596ed88949ad 8076289: Move the StrongRootsScope out of SharedHeap
brutisso
parents: 30147
diff changeset
  2221
  //
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2222
  // New threads get their token set to 0 and change_thread_claim_token()
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2223
  // never sets the global token to 0.
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2224
  static uintx thread_claim_token() { return _thread_claim_token; }
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2225
  static void change_thread_claim_token();
30174
01b674a7cb8f 8077301: Optimized build is broken
jmasa
parents: 30153
diff changeset
  2226
  static void assert_all_threads_claimed() NOT_DEBUG_RETURN;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2227
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2228
  // Apply "f->do_oop" to all root oops in all threads.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2229
  // This version may only be called by sequential code.
38074
8475fdc6dcc3 8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents: 37474
diff changeset
  2230
  static void oops_do(OopClosure* f, CodeBlobClosure* cf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2231
  // This version may be called by sequential or parallel code.
38074
8475fdc6dcc3 8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents: 37474
diff changeset
  2232
  static void possibly_parallel_oops_do(bool is_par, OopClosure* f, CodeBlobClosure* cf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2233
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2234
  // Sweeper
3908
24b55ad4c228 6863023: need non-perm oops in code cache for JSR 292
jrose
parents: 3261
diff changeset
  2235
  static void nmethods_do(CodeBlobClosure* cf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2236
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2237
  // RedefineClasses support
54150
5529640c5f67 8220512: Deoptimize redefinition functions that have dirty ICs
coleenp
parents: 54015
diff changeset
  2238
  static void metadata_do(MetadataClosure* f);
29576
c223b0a9872e 8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents: 29362
diff changeset
  2239
  static void metadata_handles_do(void f(Metadata*));
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2240
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2241
#ifdef ASSERT
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2242
  static bool is_vm_complete() { return _vm_complete; }
51600
56309b1b9d9b 8209975: Some GCThreadLocalData not initialized
kbarrett
parents: 51548
diff changeset
  2243
#endif // ASSERT
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2244
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2245
  // Verification
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2246
  static void verify();
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
  2247
  static void print_on(outputStream* st, bool print_stacks, bool internal_format, bool print_concurrent_locks, bool print_extended_info);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2248
  static void print(bool print_stacks, bool internal_format) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2249
    // this function is only used by debug.cpp
50785
d1b24f2ceca5 8200720: Print additional information in thread dump (times, allocated bytes etc.)
ghaug
parents: 50578
diff changeset
  2250
    print_on(tty, print_stacks, internal_format, false /* no concurrent lock printed */, false /* simple format */);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2251
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2252
  static void print_on_error(outputStream* st, Thread* current, char* buf, int buflen);
37474
5d721e36f744 8152905: hs_err file is missing gc threads
drwhite
parents: 37466
diff changeset
  2253
  static void print_on_error(Thread* this_thread, outputStream* st, Thread* current, char* buf,
5d721e36f744 8152905: hs_err file is missing gc threads
drwhite
parents: 37466
diff changeset
  2254
                             int buflen, bool* found_current);
54015
cd701366fcf8 8163511: Allocation of compile task fails with assert: "Leaking compilation tasks?"
thartmann
parents: 53775
diff changeset
  2255
  static void print_threads_compiling(outputStream* st, char* buf, int buflen, bool short_form = false);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2256
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2257
  // Get Java threads that are waiting to enter a monitor.
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2258
  static GrowableArray<JavaThread*>* get_pending_threads(ThreadsList * t_list,
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2259
                                                         int count, address monitor);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2260
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2261
  // Get owning Java thread from the monitor's owner field.
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2262
  static JavaThread *owning_thread_from_monitor_owner(ThreadsList * t_list,
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47881
diff changeset
  2263
                                                      address owner);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2264
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2265
  // Number of threads on the active threads list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2266
  static int number_of_threads()                 { return _number_of_threads; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2267
  // Number of non-daemon threads on the active threads list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2268
  static int number_of_non_daemon_threads()      { return _number_of_non_daemon_threads; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2269
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2270
  // Deoptimizes all frames tied to marked nmethods
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2271
  static void deoptimized_wrt_marked_nmethods();
54385
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2272
9559ba212c18 8221102: Allow GC threads to participate in threads claiming protocol
kbarrett
parents: 54278
diff changeset
  2273
  struct Test;                  // For private gtest access.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2274
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2275
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2276
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2277
// Thread iterator
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2278
class ThreadClosure: public StackObj {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2279
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2280
  virtual void do_thread(Thread* thread) = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2281
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2282
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2283
class SignalHandlerMark: public StackObj {
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2284
 private:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2285
  Thread* _thread;
26683
a02753d5a0b2 8057107: cleanup indent white space issues prior to Contended Locking reorder and cache line bucket
dcubed
parents: 25946
diff changeset
  2286
 public:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2287
  SignalHandlerMark(Thread* t) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2288
    _thread = t;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2289
    if (_thread) _thread->enter_signal_handler();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2290
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2291
  ~SignalHandlerMark() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2292
    if (_thread) _thread->leave_signal_handler();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2293
    _thread = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2294
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2295
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2296
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6975
diff changeset
  2297
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53149
diff changeset
  2298
#endif // SHARE_RUNTIME_THREAD_HPP