Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
e3a20f79
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看板
提交
e3a20f79
编写于
12月 19, 2011
作者:
P
phh
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
118aa27b
b3b77fee
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
29 addition
and
5 deletion
+29
-5
.hgtags
.hgtags
+3
-0
make/hotspot_version
make/hotspot_version
+1
-1
src/cpu/x86/vm/assembler_x86.cpp
src/cpu/x86/vm/assembler_x86.cpp
+3
-1
src/share/vm/gc_implementation/parallelScavenge/gcTaskManager.cpp
...e/vm/gc_implementation/parallelScavenge/gcTaskManager.cpp
+14
-1
src/share/vm/gc_implementation/parallelScavenge/gcTaskThread.cpp
...re/vm/gc_implementation/parallelScavenge/gcTaskThread.cpp
+8
-2
未找到文件。
.hgtags
浏览文件 @
e3a20f79
...
...
@@ -201,4 +201,7 @@ b92ca8e229d29004f840c67e620833d23a346761 jdk8-b13
088d09a130ff02d8f5f05e92256baabe412f0439 jdk8-b14
6c2a55d4902f202e1c2de1df17b7da083a2c31e8 hs23-b06
fde2a39ed7f39233b287fbc278f437aac06c275b jdk8-b15
d1f29d4e0bc60e8bd7ae961f1306d8ab33290212 jdk8-b17
d1f29d4e0bc60e8bd7ae961f1306d8ab33290212 jdk8-b16
6de8c9ba5907e4c5ca05ac4b8d84a8e2cbd92399 hs23-b07
a2fef924d8e6f37dac2a887315e3502876cc8e24 hs23-b08
make/hotspot_version
浏览文件 @
e3a20f79
...
...
@@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2011
HS_MAJOR_VER=23
HS_MINOR_VER=0
HS_BUILD_NUMBER=0
8
HS_BUILD_NUMBER=0
9
JDK_MAJOR_VER=1
JDK_MINOR_VER=8
...
...
src/cpu/x86/vm/assembler_x86.cpp
浏览文件 @
e3a20f79
...
...
@@ -5968,7 +5968,9 @@ void MacroAssembler::call_VM_base(Register oop_result,
assert
(
number_of_arguments
>=
0
,
"cannot have negative number of arguments"
);
LP64_ONLY
(
assert
(
java_thread
==
r15_thread
,
"unexpected register"
));
#ifdef ASSERT
LP64_ONLY
(
if
(
UseCompressedOops
)
verify_heapbase
(
"call_VM_base"
);)
// TraceBytecodes does not use r12 but saves it over the call, so don't verify
// r12 is the heapbase.
LP64_ONLY
(
if
(
UseCompressedOops
&&
!
TraceBytecodes
)
verify_heapbase
(
"call_VM_base"
);)
#endif // ASSERT
assert
(
java_thread
!=
oop_result
,
"cannot use the same register for java_thread & oop_result"
);
...
...
src/share/vm/gc_implementation/parallelScavenge/gcTaskManager.cpp
浏览文件 @
e3a20f79
/*
* Copyright (c) 2002, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2002, 201
1
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -53,6 +53,9 @@ const char* GCTask::Kind::to_string(kind value) {
case
noop_task
:
result
=
"noop task"
;
break
;
case
idle_task
:
result
=
"idle task"
;
break
;
}
return
result
;
};
...
...
@@ -782,6 +785,12 @@ void GCTaskManager::note_release(uint which) {
void
GCTaskManager
::
execute_and_wait
(
GCTaskQueue
*
list
)
{
WaitForBarrierGCTask
*
fin
=
WaitForBarrierGCTask
::
create
();
list
->
enqueue
(
fin
);
// The barrier task will be read by one of the GC
// workers once it is added to the list of tasks.
// Be sure that is globally visible before the
// GC worker reads it (which is after the task is added
// to the list of tasks below).
OrderAccess
::
storestore
();
add_list
(
list
);
fin
->
wait_for
(
true
/* reset */
);
// We have to release the barrier tasks!
...
...
@@ -833,11 +842,15 @@ void NoopGCTask::destruct() {
IdleGCTask
*
IdleGCTask
::
create
()
{
IdleGCTask
*
result
=
new
IdleGCTask
(
false
);
assert
(
UseDynamicNumberOfGCThreads
,
"Should only be used with dynamic GC thread"
);
return
result
;
}
IdleGCTask
*
IdleGCTask
::
create_on_c_heap
()
{
IdleGCTask
*
result
=
new
(
ResourceObj
::
C_HEAP
)
IdleGCTask
(
true
);
assert
(
UseDynamicNumberOfGCThreads
,
"Should only be used with dynamic GC thread"
);
return
result
;
}
...
...
src/share/vm/gc_implementation/parallelScavenge/gcTaskThread.cpp
浏览文件 @
e3a20f79
/*
* Copyright (c) 2002, 201
0
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2002, 201
1
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
...
...
@@ -129,6 +129,8 @@ void GCTaskThread::run() {
for
(;
/* break */
;
)
{
// This will block until there is a task to be gotten.
GCTask
*
task
=
manager
()
->
get_task
(
which
());
// Record if this is an idle task for later use.
bool
is_idle_task
=
task
->
is_idle_task
();
// In case the update is costly
if
(
PrintGCTaskTimeStamps
)
{
timer
.
update
();
...
...
@@ -137,9 +139,13 @@ void GCTaskThread::run() {
jlong
entry_time
=
timer
.
ticks
();
char
*
name
=
task
->
name
();
// If this is the barrier task, it can be destroyed
// by the GC task manager once the do_it() executes.
task
->
do_it
(
manager
(),
which
());
if
(
!
task
->
is_idle_task
())
{
// Use the saved value of is_idle_task because references
// using "task" are not reliable for the barrier task.
if
(
!
is_idle_task
)
{
manager
()
->
note_completion
(
which
());
if
(
PrintGCTaskTimeStamps
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录