src/hotspot/share/runtime/thread.inline.hpp
author coleenp
Wed, 06 Jun 2018 10:45:40 -0400
changeset 50429 83aec1d357d4
parent 49982 9042ffe5b7fe
child 50921 7f462e8383f6
permissions -rw-r--r--
8204301: Make OrderAccess functions available to hpp rather than inline.hpp files Summary: move orderAccess.inline.hpp into orderAccess.hpp and remove os.hpp inclusion and conditional os::is_MP() for fence on x86 platforms Reviewed-by: dholmes, hseigel
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     1
/*
48955
e22914003cf0 8194691: Cleanup unnecessary casts in Atomic/OrderAccess uses
kbarrett
parents: 48312
diff changeset
     2
 * Copyright (c) 2012, 2018, Oracle and/or its affiliates. All rights reserved.
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     4
 *
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     7
 * published by the Free Software Foundation.
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     8
 *
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    13
 * accompanied this code).
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    14
 *
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    18
 *
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    21
 * questions.
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    22
 *
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    23
 */
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    24
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    25
#ifndef SHARE_VM_RUNTIME_THREAD_INLINE_HPP
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    26
#define SHARE_VM_RUNTIME_THREAD_INLINE_HPP
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    27
40655
9f644073d3a0 8157907: Incorrect inclusion of atomic.hpp instead of atomic.inline.hpp
dholmes
parents: 39220
diff changeset
    28
#include "runtime/atomic.hpp"
49982
9042ffe5b7fe 8200729: Conditional compilation of GCs
stefank
parents: 49480
diff changeset
    29
#include "runtime/globals.hpp"
50429
83aec1d357d4 8204301: Make OrderAccess functions available to hpp rather than inline.hpp files
coleenp
parents: 49982
diff changeset
    30
#include "runtime/orderAccess.hpp"
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
    31
#include "runtime/os.inline.hpp"
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    32
#include "runtime/thread.hpp"
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    33
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    34
inline void Thread::set_suspend_flag(SuspendFlags f) {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    35
  uint32_t flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    36
  do {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    37
    flags = _suspend_flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    38
  }
48955
e22914003cf0 8194691: Cleanup unnecessary casts in Atomic/OrderAccess uses
kbarrett
parents: 48312
diff changeset
    39
  while (Atomic::cmpxchg((flags | f), &_suspend_flags, flags) != flags);
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    40
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    41
inline void Thread::clear_suspend_flag(SuspendFlags f) {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    42
  uint32_t flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    43
  do {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    44
    flags = _suspend_flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    45
  }
48955
e22914003cf0 8194691: Cleanup unnecessary casts in Atomic/OrderAccess uses
kbarrett
parents: 48312
diff changeset
    46
  while (Atomic::cmpxchg((flags & ~f), &_suspend_flags, flags) != flags);
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    47
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    48
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    49
inline void Thread::set_has_async_exception() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    50
  set_suspend_flag(_has_async_exception);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    51
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    52
inline void Thread::clear_has_async_exception() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    53
  clear_suspend_flag(_has_async_exception);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    54
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    55
inline void Thread::set_critical_native_unlock() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    56
  set_suspend_flag(_critical_native_unlock);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    57
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    58
inline void Thread::clear_critical_native_unlock() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    59
  clear_suspend_flag(_critical_native_unlock);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    60
}
46643
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    61
inline void Thread::set_trace_flag() {
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    62
  set_suspend_flag(_trace_flag);
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    63
}
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    64
inline void Thread::clear_trace_flag() {
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    65
  clear_suspend_flag(_trace_flag);
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    66
}
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    67
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    68
inline jlong Thread::cooked_allocated_bytes() {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    69
  jlong allocated_bytes = OrderAccess::load_acquire(&_allocated_bytes);
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    70
  if (UseTLAB) {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    71
    size_t used_bytes = tlab().used_bytes();
39220
f08faf525113 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB
sjohanss
parents: 35201
diff changeset
    72
    if (used_bytes <= ThreadLocalAllocBuffer::max_size_in_bytes()) {
f08faf525113 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB
sjohanss
parents: 35201
diff changeset
    73
      // Comparing used_bytes with the maximum allowed size will ensure
f08faf525113 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB
sjohanss
parents: 35201
diff changeset
    74
      // that we don't add the used bytes from a semi-initialized TLAB
f08faf525113 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB
sjohanss
parents: 35201
diff changeset
    75
      // ending up with incorrect values. There is still a race between
f08faf525113 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB
sjohanss
parents: 35201
diff changeset
    76
      // incrementing _allocated_bytes and clearing the TLAB, that might
f08faf525113 8149085: IntegrationTest1.java fails intermittently due to use of semi-initialized TLAB
sjohanss
parents: 35201
diff changeset
    77
      // cause double counting in rare cases.
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    78
      return allocated_bytes + used_bytes;
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    79
    }
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    80
  }
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    81
  return allocated_bytes;
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    82
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    83
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    84
inline ThreadsList* Thread::cmpxchg_threads_hazard_ptr(ThreadsList* exchange_value, ThreadsList* compare_value) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    85
  return (ThreadsList*)Atomic::cmpxchg(exchange_value, &_threads_hazard_ptr, compare_value);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    86
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    87
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    88
inline ThreadsList* Thread::get_threads_hazard_ptr() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    89
  return (ThreadsList*)OrderAccess::load_acquire(&_threads_hazard_ptr);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    90
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    91
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    92
inline void Thread::set_threads_hazard_ptr(ThreadsList* new_list) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    93
  OrderAccess::release_store_fence(&_threads_hazard_ptr, new_list);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    94
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    95
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    96
inline void JavaThread::set_ext_suspended() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    97
  set_suspend_flag (_ext_suspended);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    98
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    99
inline void JavaThread::clear_ext_suspended() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   100
  clear_suspend_flag(_ext_suspended);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   101
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   102
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   103
inline void JavaThread::set_external_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   104
  set_suspend_flag(_external_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   105
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   106
inline void JavaThread::clear_external_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   107
  clear_suspend_flag(_external_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   108
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   109
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   110
inline void JavaThread::set_deopt_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   111
  set_suspend_flag(_deopt_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   112
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   113
inline void JavaThread::clear_deopt_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   114
  clear_suspend_flag(_deopt_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   115
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   116
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   117
inline void JavaThread::set_pending_async_exception(oop e) {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   118
  _pending_async_exception = e;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   119
  _special_runtime_exit_condition = _async_exception;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   120
  set_has_async_exception();
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   121
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   122
29186
d5e61d9743aa 8069593: Changes to JavaThread::_thread_state must use acquire and release
aph
parents: 25468
diff changeset
   123
#if defined(PPC64) || defined (AARCH64)
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   124
inline JavaThreadState JavaThread::thread_state() const    {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   125
  return (JavaThreadState) OrderAccess::load_acquire((volatile jint*)&_thread_state);
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   126
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   127
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   128
inline void JavaThread::set_thread_state(JavaThreadState s) {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   129
  OrderAccess::release_store((volatile jint*)&_thread_state, (jint)s);
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   130
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   131
#endif
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   132
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   133
inline void JavaThread::set_done_attaching_via_jni() {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   134
  _jni_attach_state = _attached_via_jni;
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   135
  OrderAccess::fence();
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   136
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   137
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   138
inline bool JavaThread::stack_guard_zone_unused() {
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   139
  return _stack_guard_state == stack_guard_unused;
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   140
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   141
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   142
inline bool JavaThread::stack_yellow_reserved_zone_disabled() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   143
  return _stack_guard_state == stack_guard_yellow_reserved_disabled;
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   144
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   145
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   146
inline bool JavaThread::stack_reserved_zone_disabled() {
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   147
  return _stack_guard_state == stack_guard_reserved_disabled;
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   148
}
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   149
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   150
inline size_t JavaThread::stack_available(address cur_sp) {
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   151
  // This code assumes java stacks grow down
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   152
  address low_addr; // Limit on the address for deepest stack depth
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   153
  if (_stack_guard_state == stack_guard_unused) {
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   154
    low_addr = stack_end();
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   155
  } else {
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   156
    low_addr = stack_reserved_zone_base();
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   157
  }
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   158
  return cur_sp > low_addr ? cur_sp - low_addr : 0;
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   159
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   160
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   161
inline bool JavaThread::stack_guards_enabled() {
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   162
#ifdef ASSERT
48005
9fd89aabb6cd 8189170: Add option to disable stack overflow checking in primordial thread for use with JNI_CreateJavaJVM
dholmes
parents: 47881
diff changeset
   163
  if (os::uses_stack_guard_pages() &&
9fd89aabb6cd 8189170: Add option to disable stack overflow checking in primordial thread for use with JNI_CreateJavaJVM
dholmes
parents: 47881
diff changeset
   164
      !(DisablePrimordialThreadGuardPages && os::is_primordial_thread())) {
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   165
    assert(_stack_guard_state != stack_guard_unused, "guard pages must be in use");
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   166
  }
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   167
#endif
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   168
  return _stack_guard_state == stack_guard_enabled;
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   169
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   170
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   171
// The release make sure this store is done after storing the handshake
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   172
// operation or global state
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   173
inline void JavaThread::set_polling_page(void* poll_value) {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   174
  OrderAccess::release_store(polling_page_addr(), poll_value);
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   175
}
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   176
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   177
// The aqcquire make sure reading of polling page is done before
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   178
// the reading the handshake operation or the global state
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   179
inline volatile void* JavaThread::get_polling_page() {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   180
  return OrderAccess::load_acquire(polling_page_addr());
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   181
}
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   182
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   183
inline bool JavaThread::is_exiting() const {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   184
  // Use load-acquire so that setting of _terminated by
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   185
  // JavaThread::exit() is seen more quickly.
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   186
  TerminatedTypes l_terminated = (TerminatedTypes)
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   187
      OrderAccess::load_acquire((volatile jint *) &_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   188
  return l_terminated == _thread_exiting || check_is_terminated(l_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   189
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   190
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   191
inline bool JavaThread::is_terminated() const {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   192
  // Use load-acquire so that setting of _terminated by
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   193
  // JavaThread::exit() is seen more quickly.
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   194
  TerminatedTypes l_terminated = (TerminatedTypes)
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   195
      OrderAccess::load_acquire((volatile jint *) &_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   196
  return check_is_terminated(l_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   197
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   198
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   199
inline void JavaThread::set_terminated(TerminatedTypes t) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   200
  // use release-store so the setting of _terminated is seen more quickly
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   201
  OrderAccess::release_store((volatile jint *) &_terminated, (jint) t);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   202
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   203
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   204
// special for Threads::remove() which is static:
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   205
inline void JavaThread::set_terminated_value() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   206
  // use release-store so the setting of _terminated is seen more quickly
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   207
  OrderAccess::release_store((volatile jint *) &_terminated, (jint) _thread_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   208
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   209
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
   210
#endif // SHARE_VM_RUNTIME_THREAD_INLINE_HPP