src/hotspot/share/runtime/thread.inline.hpp
author kbarrett
Sun, 11 Feb 2018 03:12:15 -0500
changeset 48955 e22914003cf0
parent 48312 2a1413298af0
child 49480 d7df2dd501ce
permissions -rw-r--r--
8194691: Cleanup unnecessary casts in Atomic/OrderAccess uses Summary: Removed unnecessary casts. Reviewed-by: coleenp, tschatzl
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"
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
    29
#include "runtime/os.inline.hpp"
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    30
#include "runtime/thread.hpp"
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
    31
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    32
inline void Thread::set_suspend_flag(SuspendFlags f) {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    33
  uint32_t flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    34
  do {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    35
    flags = _suspend_flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    36
  }
48955
e22914003cf0 8194691: Cleanup unnecessary casts in Atomic/OrderAccess uses
kbarrett
parents: 48312
diff changeset
    37
  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
    38
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    39
inline void Thread::clear_suspend_flag(SuspendFlags f) {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    40
  uint32_t flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    41
  do {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    42
    flags = _suspend_flags;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    43
  }
48955
e22914003cf0 8194691: Cleanup unnecessary casts in Atomic/OrderAccess uses
kbarrett
parents: 48312
diff changeset
    44
  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
    45
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    46
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    47
inline void Thread::set_has_async_exception() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    48
  set_suspend_flag(_has_async_exception);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    49
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    50
inline void Thread::clear_has_async_exception() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    51
  clear_suspend_flag(_has_async_exception);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    52
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    53
inline void Thread::set_critical_native_unlock() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    54
  set_suspend_flag(_critical_native_unlock);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    55
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    56
inline void Thread::clear_critical_native_unlock() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    57
  clear_suspend_flag(_critical_native_unlock);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    58
}
46643
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    59
inline void Thread::set_trace_flag() {
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    60
  set_suspend_flag(_trace_flag);
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    61
}
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    62
inline void Thread::clear_trace_flag() {
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    63
  clear_suspend_flag(_trace_flag);
cb5f289ba033 8183545: Event tracing, transition hooks
rehn
parents: 40655
diff changeset
    64
}
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    65
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    66
inline jlong Thread::cooked_allocated_bytes() {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    67
  jlong allocated_bytes = OrderAccess::load_acquire(&_allocated_bytes);
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    68
  if (UseTLAB) {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    69
    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
    70
    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
    71
      // 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
    72
      // 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
    73
      // 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
    74
      // 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
    75
      // cause double counting in rare cases.
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    76
      return allocated_bytes + used_bytes;
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    77
    }
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    78
  }
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
    79
  return allocated_bytes;
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
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    82
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
    83
  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
    84
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    85
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    86
inline ThreadsList* Thread::get_threads_hazard_ptr() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    87
  return (ThreadsList*)OrderAccess::load_acquire(&_threads_hazard_ptr);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    88
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    89
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    90
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
    91
  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
    92
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
    93
25351
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    94
inline void JavaThread::set_ext_suspended() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    95
  set_suspend_flag (_ext_suspended);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    96
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    97
inline void JavaThread::clear_ext_suspended() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    98
  clear_suspend_flag(_ext_suspended);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
    99
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   100
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   101
inline void JavaThread::set_external_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   102
  set_suspend_flag(_external_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   103
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   104
inline void JavaThread::clear_external_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   105
  clear_suspend_flag(_external_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   106
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   107
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   108
inline void JavaThread::set_deopt_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   109
  set_suspend_flag(_deopt_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   110
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   111
inline void JavaThread::clear_deopt_suspend() {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   112
  clear_suspend_flag(_deopt_suspend);
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   113
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   114
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   115
inline void JavaThread::set_pending_async_exception(oop e) {
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   116
  _pending_async_exception = e;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   117
  _special_runtime_exit_condition = _async_exception;
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   118
  set_has_async_exception();
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   119
}
7c198a690050 8044775: Improve usage of umbrella header atomic.inline.hpp.
goetz
parents: 24351
diff changeset
   120
29186
d5e61d9743aa 8069593: Changes to JavaThread::_thread_state must use acquire and release
aph
parents: 25468
diff changeset
   121
#if defined(PPC64) || defined (AARCH64)
24351
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   122
inline JavaThreadState JavaThread::thread_state() const    {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   123
  return (JavaThreadState) OrderAccess::load_acquire((volatile jint*)&_thread_state);
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   124
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   125
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   126
inline void JavaThread::set_thread_state(JavaThreadState s) {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   127
  OrderAccess::release_store((volatile jint*)&_thread_state, (jint)s);
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   128
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   129
#endif
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
inline void JavaThread::set_done_attaching_via_jni() {
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   132
  _jni_attach_state = _attached_via_jni;
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   133
  OrderAccess::fence();
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   134
}
61b33cc6d3cf 8042195: Introduce umbrella header orderAccess.inline.hpp.
goetz
parents: 22827
diff changeset
   135
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   136
inline bool JavaThread::stack_guard_zone_unused() {
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   137
  return _stack_guard_state == stack_guard_unused;
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   138
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   139
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   140
inline bool JavaThread::stack_yellow_reserved_zone_disabled() {
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   141
  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
   142
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   143
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   144
inline bool JavaThread::stack_reserved_zone_disabled() {
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   145
  return _stack_guard_state == stack_guard_reserved_disabled;
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   146
}
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   147
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   148
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
   149
  // This code assumes java stacks grow down
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   150
  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
   151
  if (_stack_guard_state == stack_guard_unused) {
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   152
    low_addr = stack_end();
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   153
  } else {
35201
996db89f378e 8139864: Improve handling of stack protection zones.
goetz
parents: 35071
diff changeset
   154
    low_addr = stack_reserved_zone_base();
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   155
  }
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   156
  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
   157
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   158
35071
a0910b1d3e0d 8046936: JEP 270: Reserved Stack Areas for Critical Sections
fparain
parents: 34633
diff changeset
   159
inline bool JavaThread::stack_guards_enabled() {
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   160
#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
   161
  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
   162
      !(DisablePrimordialThreadGuardPages && os::is_primordial_thread())) {
25468
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   163
    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
   164
  }
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   165
#endif
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   166
  return _stack_guard_state == stack_guard_enabled;
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   167
}
5331df506290 8048241: Introduce umbrella header os.inline.hpp and clean up includes
goetz
parents: 25351
diff changeset
   168
47881
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   169
// 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
   170
// operation or global state
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   171
inline void JavaThread::set_polling_page(void* poll_value) {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   172
  OrderAccess::release_store(polling_page_addr(), poll_value);
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   173
}
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   174
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   175
// The aqcquire make sure reading of polling page is done before
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   176
// the reading the handshake operation or the global state
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   177
inline volatile void* JavaThread::get_polling_page() {
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   178
  return OrderAccess::load_acquire(polling_page_addr());
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   179
}
0ce0ac68ace7 8189941: Implementation JEP 312: Thread-local handshake
rehn
parents: 47216
diff changeset
   180
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   181
inline bool JavaThread::is_exiting() const {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   182
  // 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
   183
  // JavaThread::exit() is seen more quickly.
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   184
  TerminatedTypes l_terminated = (TerminatedTypes)
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   185
      OrderAccess::load_acquire((volatile jint *) &_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   186
  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
   187
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   188
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   189
inline bool JavaThread::is_terminated() const {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   190
  // 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
   191
  // JavaThread::exit() is seen more quickly.
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   192
  TerminatedTypes l_terminated = (TerminatedTypes)
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   193
      OrderAccess::load_acquire((volatile jint *) &_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   194
  return check_is_terminated(l_terminated);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   195
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   196
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   197
inline void JavaThread::set_terminated(TerminatedTypes t) {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   198
  // 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
   199
  OrderAccess::release_store((volatile jint *) &_terminated, (jint) t);
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   200
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   201
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   202
// special for Threads::remove() which is static:
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   203
inline void JavaThread::set_terminated_value() {
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   204
  // 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
   205
  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
   206
}
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 48005
diff changeset
   207
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents:
diff changeset
   208
#endif // SHARE_VM_RUNTIME_THREAD_INLINE_HPP