Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
534a7740
D
dragonwell8_hotspot
项目概览
openanolis
/
dragonwell8_hotspot
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_hotspot
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
534a7740
编写于
12月 19, 2014
作者:
D
dholmes
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
23fcb666
6329dbea
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
50 addition
and
11 deletion
+50
-11
src/share/vm/prims/unsafe.cpp
src/share/vm/prims/unsafe.cpp
+39
-11
src/share/vm/runtime/mutexLocker.cpp
src/share/vm/runtime/mutexLocker.cpp
+7
-0
src/share/vm/runtime/mutexLocker.hpp
src/share/vm/runtime/mutexLocker.hpp
+4
-0
未找到文件。
src/share/vm/prims/unsafe.cpp
浏览文件 @
534a7740
...
...
@@ -322,10 +322,33 @@ UNSAFE_ENTRY(void, Unsafe_SetObjectVolatile(JNIEnv *env, jobject unsafe, jobject
UNSAFE_END
#ifndef SUPPORTS_NATIVE_CX8
// Keep old code for platforms which may not have atomic jlong (8 bytes) instructions
// Volatile long versions must use locks if !VM_Version::supports_cx8().
// support_cx8 is a surrogate for 'supports atomic long memory ops'.
// VM_Version::supports_cx8() is a surrogate for 'supports atomic long memory ops'.
//
// On platforms which do not support atomic compare-and-swap of jlong (8 byte)
// values we have to use a lock-based scheme to enforce atomicity. This has to be
// applied to all Unsafe operations that set the value of a jlong field. Even so
// the compareAndSwapLong operation will not be atomic with respect to direct stores
// to the field from Java code. It is important therefore that any Java code that
// utilizes these Unsafe jlong operations does not perform direct stores. To permit
// direct loads of the field from Java code we must also use Atomic::store within the
// locked regions. And for good measure, in case there are direct stores, we also
// employ Atomic::load within those regions. Note that the field in question must be
// volatile and so must have atomic load/store accesses applied at the Java level.
//
// The locking scheme could utilize a range of strategies for controlling the locking
// granularity: from a lock per-field through to a single global lock. The latter is
// the simplest and is used for the current implementation. Note that the Java object
// that contains the field, can not, in general, be used for locking. To do so can lead
// to deadlocks as we may introduce locking into what appears to the Java code to be a
// lock-free path.
//
// As all the locked-regions are very short and themselves non-blocking we can treat
// them as leaf routines and elide safepoint checks (ie we don't perform any thread
// state transitions even when blocking for the lock). Note that if we do choose to
// add safepoint checks and thread state transitions, we must ensure that we calculate
// the address of the field _after_ we have acquired the lock, else the object may have
// been moved by the GC
UNSAFE_ENTRY
(
jlong
,
Unsafe_GetLongVolatile
(
JNIEnv
*
env
,
jobject
unsafe
,
jobject
obj
,
jlong
offset
))
UnsafeWrapper
(
"Unsafe_GetLongVolatile"
);
...
...
@@ -337,8 +360,8 @@ UNSAFE_ENTRY(jlong, Unsafe_GetLongVolatile(JNIEnv *env, jobject unsafe, jobject
else
{
Handle
p
(
THREAD
,
JNIHandles
::
resolve
(
obj
));
jlong
*
addr
=
(
jlong
*
)(
index_oop_from_field_offset_long
(
p
(),
offset
));
ObjectLocker
ol
(
p
,
THREAD
);
jlong
value
=
*
addr
;
MutexLockerEx
mu
(
UnsafeJlong_lock
,
Mutex
::
_no_safepoint_check_flag
);
jlong
value
=
Atomic
::
load
(
addr
)
;
return
value
;
}
}
...
...
@@ -353,8 +376,8 @@ UNSAFE_ENTRY(void, Unsafe_SetLongVolatile(JNIEnv *env, jobject unsafe, jobject o
else
{
Handle
p
(
THREAD
,
JNIHandles
::
resolve
(
obj
));
jlong
*
addr
=
(
jlong
*
)(
index_oop_from_field_offset_long
(
p
(),
offset
));
ObjectLocker
ol
(
p
,
THREAD
);
*
addr
=
x
;
MutexLockerEx
mu
(
UnsafeJlong_lock
,
Mutex
::
_no_safepoint_check_flag
);
Atomic
::
store
(
x
,
addr
)
;
}
}
UNSAFE_END
...
...
@@ -463,8 +486,8 @@ UNSAFE_ENTRY(void, Unsafe_SetOrderedLong(JNIEnv *env, jobject unsafe, jobject ob
else
{
Handle
p
(
THREAD
,
JNIHandles
::
resolve
(
obj
));
jlong
*
addr
=
(
jlong
*
)(
index_oop_from_field_offset_long
(
p
(),
offset
));
ObjectLocker
ol
(
p
,
THREAD
);
*
addr
=
x
;
MutexLockerEx
mu
(
UnsafeJlong_lock
,
Mutex
::
_no_safepoint_check_flag
);
Atomic
::
store
(
x
,
addr
)
;
}
}
#endif
...
...
@@ -1213,14 +1236,19 @@ UNSAFE_ENTRY(jboolean, Unsafe_CompareAndSwapLong(JNIEnv *env, jobject unsafe, jo
UnsafeWrapper
(
"Unsafe_CompareAndSwapLong"
);
Handle
p
(
THREAD
,
JNIHandles
::
resolve
(
obj
));
jlong
*
addr
=
(
jlong
*
)(
index_oop_from_field_offset_long
(
p
(),
offset
));
#ifdef SUPPORTS_NATIVE_CX8
return
(
jlong
)(
Atomic
::
cmpxchg
(
x
,
addr
,
e
))
==
e
;
#else
if
(
VM_Version
::
supports_cx8
())
return
(
jlong
)(
Atomic
::
cmpxchg
(
x
,
addr
,
e
))
==
e
;
else
{
jboolean
success
=
false
;
ObjectLocker
ol
(
p
,
THREAD
);
if
(
*
addr
==
e
)
{
*
addr
=
x
;
success
=
true
;
}
MutexLockerEx
mu
(
UnsafeJlong_lock
,
Mutex
::
_no_safepoint_check_flag
);
jlong
val
=
Atomic
::
load
(
addr
);
if
(
val
==
e
)
{
Atomic
::
store
(
x
,
addr
);
success
=
true
;
}
return
success
;
}
#endif
UNSAFE_END
UNSAFE_ENTRY
(
void
,
Unsafe_Park
(
JNIEnv
*
env
,
jobject
unsafe
,
jboolean
isAbsolute
,
jlong
time
))
...
...
src/share/vm/runtime/mutexLocker.cpp
浏览文件 @
534a7740
...
...
@@ -135,6 +135,10 @@ Mutex* JfrStream_lock = NULL;
Mutex
*
JfrThreadGroups_lock
=
NULL
;
#endif
#ifndef SUPPORTS_NATIVE_CX8
Mutex
*
UnsafeJlong_lock
=
NULL
;
#endif
#define MAX_NUM_MUTEX 128
static
Monitor
*
_mutex_array
[
MAX_NUM_MUTEX
];
static
int
_num_mutex
;
...
...
@@ -286,6 +290,9 @@ void mutex_init() {
def
(
JfrStacktrace_lock
,
Mutex
,
special
,
true
);
#endif
#ifndef SUPPORTS_NATIVE_CX8
def
(
UnsafeJlong_lock
,
Mutex
,
special
,
false
);
#endif
}
GCMutexLocker
::
GCMutexLocker
(
Monitor
*
mutex
)
{
...
...
src/share/vm/runtime/mutexLocker.hpp
浏览文件 @
534a7740
...
...
@@ -151,6 +151,10 @@ extern Mutex* JfrStream_lock; // protects JFR stream access
extern
Mutex
*
JfrThreadGroups_lock
;
// protects JFR access to Thread Groups
#endif
#ifndef SUPPORTS_NATIVE_CX8
extern
Mutex
*
UnsafeJlong_lock
;
// provides Unsafe atomic updates to jlongs on platforms that don't support cx8
#endif
// A MutexLocker provides mutual exclusion with respect to a given mutex
// for the scope which contains the locker. The lock is an OS lock, not
// an object lock, and the two do not interoperate. Do not use Mutex-based
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录