Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
c341e695
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看板
提交
c341e695
编写于
4月 16, 2013
作者:
R
rdurbin
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
e24568e9
73c87a69
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
27 addition
and
26 deletion
+27
-26
src/share/vm/runtime/thread.hpp
src/share/vm/runtime/thread.hpp
+2
-2
src/share/vm/services/memTrackWorker.cpp
src/share/vm/services/memTrackWorker.cpp
+5
-6
src/share/vm/services/memTrackWorker.hpp
src/share/vm/services/memTrackWorker.hpp
+3
-1
src/share/vm/services/memTracker.cpp
src/share/vm/services/memTracker.cpp
+13
-13
src/share/vm/services/memTracker.hpp
src/share/vm/services/memTracker.hpp
+4
-4
未找到文件。
src/share/vm/runtime/thread.hpp
浏览文件 @
c341e695
...
@@ -1056,11 +1056,11 @@ class JavaThread: public Thread {
...
@@ -1056,11 +1056,11 @@ class JavaThread: public Thread {
#if INCLUDE_NMT
#if INCLUDE_NMT
// native memory tracking
// native memory tracking
inline
MemRecorder
*
get_recorder
()
const
{
return
(
MemRecorder
*
)
_recorder
;
}
inline
MemRecorder
*
get_recorder
()
const
{
return
(
MemRecorder
*
)
_recorder
;
}
inline
void
set_recorder
(
MemRecorder
*
rc
)
{
_recorder
=
(
volatile
MemRecorder
*
)
rc
;
}
inline
void
set_recorder
(
MemRecorder
*
rc
)
{
_recorder
=
rc
;
}
private:
private:
// per-thread memory recorder
// per-thread memory recorder
volatile
MemRecorder
*
_recorder
;
MemRecorder
*
volatile
_recorder
;
#endif // INCLUDE_NMT
#endif // INCLUDE_NMT
// Suspend/resume support for JavaThread
// Suspend/resume support for JavaThread
...
...
src/share/vm/services/memTrackWorker.cpp
浏览文件 @
c341e695
...
@@ -39,7 +39,7 @@ void GenerationData::reset() {
...
@@ -39,7 +39,7 @@ void GenerationData::reset() {
}
}
}
}
MemTrackWorker
::
MemTrackWorker
()
{
MemTrackWorker
::
MemTrackWorker
(
MemSnapshot
*
snapshot
)
:
_snapshot
(
snapshot
)
{
// create thread uses cgc thread type for now. We should revisit
// create thread uses cgc thread type for now. We should revisit
// the option, or create new thread type.
// the option, or create new thread type.
_has_error
=
!
os
::
create_thread
(
this
,
os
::
cgc_thread
);
_has_error
=
!
os
::
create_thread
(
this
,
os
::
cgc_thread
);
...
@@ -88,8 +88,7 @@ void MemTrackWorker::run() {
...
@@ -88,8 +88,7 @@ void MemTrackWorker::run() {
assert
(
MemTracker
::
is_on
(),
"native memory tracking is off"
);
assert
(
MemTracker
::
is_on
(),
"native memory tracking is off"
);
this
->
initialize_thread_local_storage
();
this
->
initialize_thread_local_storage
();
this
->
record_stack_base_and_size
();
this
->
record_stack_base_and_size
();
MemSnapshot
*
snapshot
=
MemTracker
::
get_snapshot
();
assert
(
_snapshot
!=
NULL
,
"Worker should not be started"
);
assert
(
snapshot
!=
NULL
,
"Worker should not be started"
);
MemRecorder
*
rec
;
MemRecorder
*
rec
;
unsigned
long
processing_generation
=
0
;
unsigned
long
processing_generation
=
0
;
bool
worker_idle
=
false
;
bool
worker_idle
=
false
;
...
@@ -109,7 +108,7 @@ void MemTrackWorker::run() {
...
@@ -109,7 +108,7 @@ void MemTrackWorker::run() {
}
}
// merge the recorder into staging area
// merge the recorder into staging area
if
(
!
snapshot
->
merge
(
rec
))
{
if
(
!
_
snapshot
->
merge
(
rec
))
{
MemTracker
::
shutdown
(
MemTracker
::
NMT_out_of_memory
);
MemTracker
::
shutdown
(
MemTracker
::
NMT_out_of_memory
);
}
else
{
}
else
{
NOT_PRODUCT
(
_merge_count
++
;)
NOT_PRODUCT
(
_merge_count
++
;)
...
@@ -132,7 +131,7 @@ void MemTrackWorker::run() {
...
@@ -132,7 +131,7 @@ void MemTrackWorker::run() {
_head
=
(
_head
+
1
)
%
MAX_GENERATIONS
;
_head
=
(
_head
+
1
)
%
MAX_GENERATIONS
;
}
}
// promote this generation data to snapshot
// promote this generation data to snapshot
if
(
!
snapshot
->
promote
(
number_of_classes
))
{
if
(
!
_
snapshot
->
promote
(
number_of_classes
))
{
// failed to promote, means out of memory
// failed to promote, means out of memory
MemTracker
::
shutdown
(
MemTracker
::
NMT_out_of_memory
);
MemTracker
::
shutdown
(
MemTracker
::
NMT_out_of_memory
);
}
}
...
@@ -140,7 +139,7 @@ void MemTrackWorker::run() {
...
@@ -140,7 +139,7 @@ void MemTrackWorker::run() {
// worker thread is idle
// worker thread is idle
worker_idle
=
true
;
worker_idle
=
true
;
MemTracker
::
report_worker_idle
();
MemTracker
::
report_worker_idle
();
snapshot
->
wait
(
1000
);
_
snapshot
->
wait
(
1000
);
ThreadCritical
tc
;
ThreadCritical
tc
;
// check if more data arrived
// check if more data arrived
if
(
!
_gen
[
_head
].
has_more_recorder
())
{
if
(
!
_gen
[
_head
].
has_more_recorder
())
{
...
...
src/share/vm/services/memTrackWorker.hpp
浏览文件 @
c341e695
...
@@ -85,8 +85,10 @@ class MemTrackWorker : public NamedThread {
...
@@ -85,8 +85,10 @@ class MemTrackWorker : public NamedThread {
bool
_has_error
;
bool
_has_error
;
MemSnapshot
*
_snapshot
;
public:
public:
MemTrackWorker
();
MemTrackWorker
(
MemSnapshot
*
snapshot
);
~
MemTrackWorker
();
~
MemTrackWorker
();
_NOINLINE_
void
*
operator
new
(
size_t
size
);
_NOINLINE_
void
*
operator
new
(
size_t
size
);
_NOINLINE_
void
*
operator
new
(
size_t
size
,
const
std
::
nothrow_t
&
nothrow_constant
);
_NOINLINE_
void
*
operator
new
(
size_t
size
,
const
std
::
nothrow_t
&
nothrow_constant
);
...
...
src/share/vm/services/memTracker.cpp
浏览文件 @
c341e695
...
@@ -53,12 +53,12 @@ void SyncThreadRecorderClosure::do_thread(Thread* thread) {
...
@@ -53,12 +53,12 @@ void SyncThreadRecorderClosure::do_thread(Thread* thread) {
}
}
MemRecorder
*
MemTracker
::
_global_recorder
=
NULL
;
MemRecorder
*
volatile
MemTracker
::
_global_recorder
=
NULL
;
MemSnapshot
*
MemTracker
::
_snapshot
=
NULL
;
MemSnapshot
*
MemTracker
::
_snapshot
=
NULL
;
MemBaseline
MemTracker
::
_baseline
;
MemBaseline
MemTracker
::
_baseline
;
Mutex
*
MemTracker
::
_query_lock
=
NULL
;
Mutex
*
MemTracker
::
_query_lock
=
NULL
;
volatile
MemRecorder
*
MemTracker
::
_merge_pending_queue
=
NULL
;
MemRecorder
*
volatile
MemTracker
::
_merge_pending_queue
=
NULL
;
volatile
MemRecorder
*
MemTracker
::
_pooled_recorders
=
NULL
;
MemRecorder
*
volatile
MemTracker
::
_pooled_recorders
=
NULL
;
MemTrackWorker
*
MemTracker
::
_worker_thread
=
NULL
;
MemTrackWorker
*
MemTracker
::
_worker_thread
=
NULL
;
int
MemTracker
::
_sync_point_skip_count
=
0
;
int
MemTracker
::
_sync_point_skip_count
=
0
;
MemTracker
::
NMTLevel
MemTracker
::
_tracking_level
=
MemTracker
::
NMT_off
;
MemTracker
::
NMTLevel
MemTracker
::
_tracking_level
=
MemTracker
::
NMT_off
;
...
@@ -128,7 +128,7 @@ void MemTracker::start() {
...
@@ -128,7 +128,7 @@ void MemTracker::start() {
_snapshot
=
new
(
std
::
nothrow
)
MemSnapshot
();
_snapshot
=
new
(
std
::
nothrow
)
MemSnapshot
();
if
(
_snapshot
!=
NULL
)
{
if
(
_snapshot
!=
NULL
)
{
if
(
!
_snapshot
->
out_of_memory
()
&&
start_worker
())
{
if
(
!
_snapshot
->
out_of_memory
()
&&
start_worker
(
_snapshot
))
{
_state
=
NMT_started
;
_state
=
NMT_started
;
NMT_track_callsite
=
(
_tracking_level
==
NMT_detail
&&
can_walk_stack
());
NMT_track_callsite
=
(
_tracking_level
==
NMT_detail
&&
can_walk_stack
());
return
;
return
;
...
@@ -209,7 +209,7 @@ void MemTracker::final_shutdown() {
...
@@ -209,7 +209,7 @@ void MemTracker::final_shutdown() {
// delete all pooled recorders
// delete all pooled recorders
void
MemTracker
::
delete_all_pooled_recorders
()
{
void
MemTracker
::
delete_all_pooled_recorders
()
{
// free all pooled recorders
// free all pooled recorders
volatile
MemRecorder
*
cur_head
=
_pooled_recorders
;
MemRecorder
*
volatile
cur_head
=
_pooled_recorders
;
if
(
cur_head
!=
NULL
)
{
if
(
cur_head
!=
NULL
)
{
MemRecorder
*
null_ptr
=
NULL
;
MemRecorder
*
null_ptr
=
NULL
;
while
(
cur_head
!=
NULL
&&
(
void
*
)
cur_head
!=
Atomic
::
cmpxchg_ptr
((
void
*
)
null_ptr
,
while
(
cur_head
!=
NULL
&&
(
void
*
)
cur_head
!=
Atomic
::
cmpxchg_ptr
((
void
*
)
null_ptr
,
...
@@ -543,14 +543,14 @@ void MemTracker::sync() {
...
@@ -543,14 +543,14 @@ void MemTracker::sync() {
/*
/*
* Start worker thread.
* Start worker thread.
*/
*/
bool
MemTracker
::
start_worker
()
{
bool
MemTracker
::
start_worker
(
MemSnapshot
*
snapshot
)
{
assert
(
_worker_thread
==
NULL
,
"Just Check"
);
assert
(
_worker_thread
==
NULL
&&
_snapshot
!=
NULL
,
"Just Check"
);
_worker_thread
=
new
(
std
::
nothrow
)
MemTrackWorker
();
_worker_thread
=
new
(
std
::
nothrow
)
MemTrackWorker
(
snapshot
);
if
(
_worker_thread
==
NULL
||
_worker_thread
->
has_error
())
{
if
(
_worker_thread
==
NULL
)
{
if
(
_worker_thread
!=
NULL
)
{
return
false
;
}
else
if
(
_worker_thread
->
has_error
())
{
delete
_worker_thread
;
delete
_worker_thread
;
_worker_thread
=
NULL
;
_worker_thread
=
NULL
;
}
return
false
;
return
false
;
}
}
_worker_thread
->
start
();
_worker_thread
->
start
();
...
...
src/share/vm/services/memTracker.hpp
浏览文件 @
c341e695
...
@@ -421,7 +421,7 @@ class MemTracker : AllStatic {
...
@@ -421,7 +421,7 @@ class MemTracker : AllStatic {
private:
private:
// start native memory tracking worker thread
// start native memory tracking worker thread
static
bool
start_worker
();
static
bool
start_worker
(
MemSnapshot
*
snapshot
);
// called by worker thread to complete shutdown process
// called by worker thread to complete shutdown process
static
void
final_shutdown
();
static
void
final_shutdown
();
...
@@ -475,18 +475,18 @@ class MemTracker : AllStatic {
...
@@ -475,18 +475,18 @@ class MemTracker : AllStatic {
// a thread can start to allocate memory before it is attached
// a thread can start to allocate memory before it is attached
// to VM 'Thread', those memory activities are recorded here.
// to VM 'Thread', those memory activities are recorded here.
// ThreadCritical is required to guard this global recorder.
// ThreadCritical is required to guard this global recorder.
static
MemRecorder
*
_global_recorder
;
static
MemRecorder
*
volatile
_global_recorder
;
// main thread id
// main thread id
debug_only
(
static
intx
_main_thread_tid
;)
debug_only
(
static
intx
_main_thread_tid
;)
// pending recorders to be merged
// pending recorders to be merged
static
volatile
MemRecorder
*
_merge_pending_queue
;
static
MemRecorder
*
volatile
_merge_pending_queue
;
NOT_PRODUCT
(
static
volatile
jint
_pending_recorder_count
;)
NOT_PRODUCT
(
static
volatile
jint
_pending_recorder_count
;)
// pooled memory recorders
// pooled memory recorders
static
volatile
MemRecorder
*
_pooled_recorders
;
static
MemRecorder
*
volatile
_pooled_recorders
;
// memory recorder pool management, uses following
// memory recorder pool management, uses following
// counter to determine if a released memory recorder
// counter to determine if a released memory recorder
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录