Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
0c235037
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看板
提交
0c235037
编写于
3月 25, 2009
作者:
A
apetrusenko
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6543938: G1: remove the concept of popularity
Reviewed-by: iveresov, tonyp
上级
c59f1c5c
变更
19
展开全部
显示空白变更内容
内联
并排
Showing
19 changed file
with
101 addition
and
1074 deletion
+101
-1074
src/cpu/sparc/vm/assembler_sparc.cpp
src/cpu/sparc/vm/assembler_sparc.cpp
+2
-9
src/share/vm/gc_implementation/g1/collectionSetChooser.cpp
src/share/vm/gc_implementation/g1/collectionSetChooser.cpp
+0
-2
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
+20
-479
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
+2
-82
src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp
src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp
+46
-251
src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp
src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp
+10
-69
src/share/vm/gc_implementation/g1/g1MarkSweep.cpp
src/share/vm/gc_implementation/g1/g1MarkSweep.cpp
+9
-36
src/share/vm/gc_implementation/g1/g1RemSet.cpp
src/share/vm/gc_implementation/g1/g1RemSet.cpp
+2
-5
src/share/vm/gc_implementation/g1/g1RemSet.inline.hpp
src/share/vm/gc_implementation/g1/g1RemSet.inline.hpp
+2
-8
src/share/vm/gc_implementation/g1/g1_globals.hpp
src/share/vm/gc_implementation/g1/g1_globals.hpp
+0
-16
src/share/vm/gc_implementation/g1/heapRegion.cpp
src/share/vm/gc_implementation/g1/heapRegion.cpp
+0
-4
src/share/vm/gc_implementation/g1/heapRegion.hpp
src/share/vm/gc_implementation/g1/heapRegion.hpp
+0
-30
src/share/vm/gc_implementation/g1/heapRegionRemSet.hpp
src/share/vm/gc_implementation/g1/heapRegionRemSet.hpp
+2
-44
src/share/vm/gc_implementation/g1/heapRegionSeq.cpp
src/share/vm/gc_implementation/g1/heapRegionSeq.cpp
+2
-12
src/share/vm/gc_implementation/g1/heapRegionSeq.hpp
src/share/vm/gc_implementation/g1/heapRegionSeq.hpp
+2
-3
src/share/vm/gc_implementation/g1/vm_operations_g1.cpp
src/share/vm/gc_implementation/g1/vm_operations_g1.cpp
+1
-8
src/share/vm/gc_implementation/g1/vm_operations_g1.hpp
src/share/vm/gc_implementation/g1/vm_operations_g1.hpp
+0
-14
src/share/vm/gc_interface/gcCause.hpp
src/share/vm/gc_interface/gcCause.hpp
+1
-1
src/share/vm/runtime/vm_operations.hpp
src/share/vm/runtime/vm_operations.hpp
+0
-1
未找到文件。
src/cpu/sparc/vm/assembler_sparc.cpp
浏览文件 @
0c235037
...
...
@@ -4234,7 +4234,6 @@ void MacroAssembler::g1_write_barrier_pre(Register obj, Register index, int offs
static
jint
num_ct_writes
=
0
;
static
jint
num_ct_writes_filtered_in_hr
=
0
;
static
jint
num_ct_writes_filtered_null
=
0
;
static
jint
num_ct_writes_filtered_pop
=
0
;
static
G1CollectedHeap
*
g1
=
NULL
;
static
Thread
*
count_ct_writes
(
void
*
filter_val
,
void
*
new_val
)
{
...
...
@@ -4247,25 +4246,19 @@ static Thread* count_ct_writes(void* filter_val, void* new_val) {
if
(
g1
==
NULL
)
{
g1
=
G1CollectedHeap
::
heap
();
}
if
((
HeapWord
*
)
new_val
<
g1
->
popular_object_boundary
())
{
Atomic
::
inc
(
&
num_ct_writes_filtered_pop
);
}
}
if
((
num_ct_writes
%
1000000
)
==
0
)
{
jint
num_ct_writes_filtered
=
num_ct_writes_filtered_in_hr
+
num_ct_writes_filtered_null
+
num_ct_writes_filtered_pop
;
num_ct_writes_filtered_null
;
tty
->
print_cr
(
"%d potential CT writes: %5.2f%% filtered
\n
"
" (%5.2f%% intra-HR, %5.2f%% null
, %5.2f%% popular
)."
,
" (%5.2f%% intra-HR, %5.2f%% null)."
,
num_ct_writes
,
100.0
*
(
float
)
num_ct_writes_filtered
/
(
float
)
num_ct_writes
,
100.0
*
(
float
)
num_ct_writes_filtered_in_hr
/
(
float
)
num_ct_writes
,
100.0
*
(
float
)
num_ct_writes_filtered_null
/
(
float
)
num_ct_writes
,
100.0
*
(
float
)
num_ct_writes_filtered_pop
/
(
float
)
num_ct_writes
);
}
return
Thread
::
current
();
...
...
src/share/vm/gc_implementation/g1/collectionSetChooser.cpp
浏览文件 @
0c235037
...
...
@@ -277,8 +277,6 @@ printHeapRegion(HeapRegion *hr) {
gclog_or_tty
->
print
(
"H: "
);
if
(
hr
->
in_collection_set
())
gclog_or_tty
->
print
(
"CS: "
);
if
(
hr
->
popular
())
gclog_or_tty
->
print
(
"pop: "
);
gclog_or_tty
->
print_cr
(
"Region "
PTR_FORMAT
" (%s%s) "
"["
PTR_FORMAT
", "
PTR_FORMAT
"] "
"Used: "
SIZE_FORMAT
"K, garbage: "
SIZE_FORMAT
"K."
,
...
...
src/share/vm/gc_implementation/g1/g1CollectedHeap.cpp
浏览文件 @
0c235037
此差异已折叠。
点击以展开。
src/share/vm/gc_implementation/g1/g1CollectedHeap.hpp
浏览文件 @
0c235037
...
...
@@ -29,7 +29,6 @@
class
HeapRegion
;
class
HeapRegionSeq
;
class
HeapRegionList
;
class
PermanentGenerationSpec
;
class
GenerationSpec
;
class
OopsInHeapRegionClosure
;
...
...
@@ -143,7 +142,6 @@ class G1CollectedHeap : public SharedHeap {
friend
class
VM_GenCollectForPermanentAllocation
;
friend
class
VM_G1CollectFull
;
friend
class
VM_G1IncCollectionPause
;
friend
class
VM_G1PopRegionCollectionPause
;
friend
class
VMStructs
;
// Closures used in implementation.
...
...
@@ -253,10 +251,6 @@ private:
// than the current allocation region.
size_t
_summary_bytes_used
;
// Summary information about popular objects; method to print it.
NumberSeq
_pop_obj_rc_at_copy
;
void
print_popularity_summary_info
()
const
;
// This is used for a quick test on whether a reference points into
// the collection set or not. Basically, we have an array, with one
// byte per region, and that byte denotes whether the corresponding
...
...
@@ -447,10 +441,8 @@ protected:
virtual
void
do_collection_pause
();
// The guts of the incremental collection pause, executed by the vm
// thread. If "popular_region" is non-NULL, this pause should evacuate
// this single region whose remembered set has gotten large, moving
// any popular objects to one of the popular regions.
virtual
void
do_collection_pause_at_safepoint
(
HeapRegion
*
popular_region
);
// thread.
virtual
void
do_collection_pause_at_safepoint
();
// Actually do the work of evacuating the collection set.
virtual
void
evacuate_collection_set
();
...
...
@@ -625,67 +617,10 @@ protected:
SubTasksDone
*
_process_strong_tasks
;
// Allocate space to hold a popular object. Result is guaranteed below
// "popular_object_boundary()". Note: CURRENTLY halts the system if we
// run out of space to hold popular objects.
HeapWord
*
allocate_popular_object
(
size_t
word_size
);
// The boundary between popular and non-popular objects.
HeapWord
*
_popular_object_boundary
;
HeapRegionList
*
_popular_regions_to_be_evacuated
;
// Compute which objects in "single_region" are popular. If any are,
// evacuate them to a popular region, leaving behind forwarding pointers,
// and select "popular_region" as the single collection set region.
// Otherwise, leave the collection set null.
void
popularity_pause_preamble
(
HeapRegion
*
populer_region
);
// Compute which objects in "single_region" are popular, and evacuate
// them to a popular region, leaving behind forwarding pointers.
// Returns "true" if at least one popular object is discovered and
// evacuated. In any case, "*max_rc" is set to the maximum reference
// count of an object in the region.
bool
compute_reference_counts_and_evac_popular
(
HeapRegion
*
populer_region
,
size_t
*
max_rc
);
// Subroutines used in the above.
bool
_rc_region_above
;
size_t
_rc_region_diff
;
jint
*
obj_rc_addr
(
oop
obj
)
{
uintptr_t
obj_addr
=
(
uintptr_t
)
obj
;
if
(
_rc_region_above
)
{
jint
*
res
=
(
jint
*
)(
obj_addr
+
_rc_region_diff
);
assert
((
uintptr_t
)
res
>
obj_addr
,
"RC region is above."
);
return
res
;
}
else
{
jint
*
res
=
(
jint
*
)(
obj_addr
-
_rc_region_diff
);
assert
((
uintptr_t
)
res
<
obj_addr
,
"RC region is below."
);
return
res
;
}
}
jint
obj_rc
(
oop
obj
)
{
return
*
obj_rc_addr
(
obj
);
}
void
inc_obj_rc
(
oop
obj
)
{
(
*
obj_rc_addr
(
obj
))
++
;
}
void
atomic_inc_obj_rc
(
oop
obj
);
// Number of popular objects and bytes (latter is cheaper!).
size_t
pop_object_used_objs
();
size_t
pop_object_used_bytes
();
// Index of the popular region in which allocation is currently being
// done.
int
_cur_pop_hr_index
;
// List of regions which require zero filling.
UncleanRegionList
_unclean_region_list
;
bool
_unclean_regions_coming
;
bool
check_age_cohort_well_formed_work
(
int
a
,
HeapRegion
*
hr
);
public:
void
set_refine_cte_cl_concurrency
(
bool
concurrent
);
...
...
@@ -1066,21 +1001,6 @@ public:
// words.
virtual
size_t
large_typearray_limit
();
// All popular objects are guaranteed to have addresses below this
// boundary.
HeapWord
*
popular_object_boundary
()
{
return
_popular_object_boundary
;
}
// Declare the region as one that should be evacuated because its
// remembered set is too large.
void
schedule_popular_region_evac
(
HeapRegion
*
r
);
// If there is a popular region to evacuate it, remove it from the list
// and return it.
HeapRegion
*
popular_region_to_evac
();
// Evacuate the given popular region.
void
evac_popular_region
(
HeapRegion
*
r
);
// Returns "true" iff the given word_size is "very large".
static
bool
isHumongous
(
size_t
word_size
)
{
return
word_size
>=
VeryLargeInWords
;
...
...
src/share/vm/gc_implementation/g1/g1CollectorPolicy.cpp
浏览文件 @
0c235037
...
...
@@ -91,10 +91,8 @@ G1CollectorPolicy::G1CollectorPolicy() :
_all_mod_union_times_ms
(
new
NumberSeq
()),
_non_pop_summary
(
new
NonPopSummary
()),
_pop_summary
(
new
PopSummary
()),
_non_pop_abandoned_summary
(
new
NonPopAbandonedSummary
()),
_pop_abandoned_summary
(
new
PopAbandonedSummary
()),
_summary
(
new
Summary
()),
_abandoned_summary
(
new
AbandonedSummary
()),
_cur_clear_ct_time_ms
(
0.0
),
...
...
@@ -109,9 +107,6 @@ G1CollectorPolicy::G1CollectorPolicy() :
_cur_aux_times_ms
(
new
double
[
_aux_num
]),
_cur_aux_times_set
(
new
bool
[
_aux_num
]),
_pop_compute_rc_start
(
0.0
),
_pop_evac_start
(
0.0
),
_concurrent_mark_init_times_ms
(
new
TruncatedSeq
(
NumPrevPausesForHeuristics
)),
_concurrent_mark_remark_times_ms
(
new
TruncatedSeq
(
NumPrevPausesForHeuristics
)),
_concurrent_mark_cleanup_times_ms
(
new
TruncatedSeq
(
NumPrevPausesForHeuristics
)),
...
...
@@ -224,16 +219,6 @@ G1CollectorPolicy::G1CollectorPolicy() :
_par_last_termination_times_ms
=
new
double
[
_parallel_gc_threads
];
// we store the data from the first pass during popularity pauses
_pop_par_last_update_rs_start_times_ms
=
new
double
[
_parallel_gc_threads
];
_pop_par_last_update_rs_times_ms
=
new
double
[
_parallel_gc_threads
];
_pop_par_last_update_rs_processed_buffers
=
new
double
[
_parallel_gc_threads
];
_pop_par_last_scan_rs_start_times_ms
=
new
double
[
_parallel_gc_threads
];
_pop_par_last_scan_rs_times_ms
=
new
double
[
_parallel_gc_threads
];
_pop_par_last_closure_app_times_ms
=
new
double
[
_parallel_gc_threads
];
// start conservatively
_expensive_region_limit_ms
=
0.5
*
(
double
)
G1MaxPauseTimeMS
;
...
...
@@ -1047,23 +1032,6 @@ void G1CollectorPolicy::record_full_collection_end() {
calculate_young_list_target_config
();
}
void
G1CollectorPolicy
::
record_pop_compute_rc_start
()
{
_pop_compute_rc_start
=
os
::
elapsedTime
();
}
void
G1CollectorPolicy
::
record_pop_compute_rc_end
()
{
double
ms
=
(
os
::
elapsedTime
()
-
_pop_compute_rc_start
)
*
1000.0
;
_cur_popular_compute_rc_time_ms
=
ms
;
_pop_compute_rc_start
=
0.0
;
}
void
G1CollectorPolicy
::
record_pop_evac_start
()
{
_pop_evac_start
=
os
::
elapsedTime
();
}
void
G1CollectorPolicy
::
record_pop_evac_end
()
{
double
ms
=
(
os
::
elapsedTime
()
-
_pop_evac_start
)
*
1000.0
;
_cur_popular_evac_time_ms
=
ms
;
_pop_evac_start
=
0.0
;
}
void
G1CollectorPolicy
::
record_before_bytes
(
size_t
bytes
)
{
_bytes_in_to_space_before_gc
+=
bytes
;
}
...
...
@@ -1120,13 +1088,6 @@ void G1CollectorPolicy::record_collection_pause_start(double start_time_sec,
_par_last_scan_new_refs_times_ms
[
i
]
=
-
666.0
;
_par_last_obj_copy_times_ms
[
i
]
=
-
666.0
;
_par_last_termination_times_ms
[
i
]
=
-
666.0
;
_pop_par_last_update_rs_start_times_ms
[
i
]
=
-
666.0
;
_pop_par_last_update_rs_times_ms
[
i
]
=
-
666.0
;
_pop_par_last_update_rs_processed_buffers
[
i
]
=
-
666.0
;
_pop_par_last_scan_rs_start_times_ms
[
i
]
=
-
666.0
;
_pop_par_last_scan_rs_times_ms
[
i
]
=
-
666.0
;
_pop_par_last_closure_app_times_ms
[
i
]
=
-
666.0
;
}
#endif
...
...
@@ -1185,25 +1146,6 @@ void G1CollectorPolicy::tag_scan_only(size_t short_lived_scan_only_length) {
guarantee
(
false
,
"we should never reach here"
);
}
void
G1CollectorPolicy
::
record_popular_pause_preamble_start
()
{
_cur_popular_preamble_start_ms
=
os
::
elapsedTime
()
*
1000.0
;
}
void
G1CollectorPolicy
::
record_popular_pause_preamble_end
()
{
_cur_popular_preamble_time_ms
=
(
os
::
elapsedTime
()
*
1000.0
)
-
_cur_popular_preamble_start_ms
;
// copy the recorded statistics of the first pass to temporary arrays
for
(
int
i
=
0
;
i
<
_parallel_gc_threads
;
++
i
)
{
_pop_par_last_update_rs_start_times_ms
[
i
]
=
_par_last_update_rs_start_times_ms
[
i
];
_pop_par_last_update_rs_times_ms
[
i
]
=
_par_last_update_rs_times_ms
[
i
];
_pop_par_last_update_rs_processed_buffers
[
i
]
=
_par_last_update_rs_processed_buffers
[
i
];
_pop_par_last_scan_rs_start_times_ms
[
i
]
=
_par_last_scan_rs_start_times_ms
[
i
];
_pop_par_last_scan_rs_times_ms
[
i
]
=
_par_last_scan_rs_times_ms
[
i
];
_pop_par_last_closure_app_times_ms
[
i
]
=
_par_last_obj_copy_times_ms
[
i
];
}
}
void
G1CollectorPolicy
::
record_mark_closure_time
(
double
mark_closure_time_ms
)
{
_mark_closure_time_ms
=
mark_closure_time_ms
;
}
...
...
@@ -1465,8 +1407,7 @@ double G1CollectorPolicy::max_sum (double* data1,
// Anything below that is considered to be zero
#define MIN_TIMER_GRANULARITY 0.0000001
void
G1CollectorPolicy
::
record_collection_pause_end
(
bool
popular
,
bool
abandoned
)
{
void
G1CollectorPolicy
::
record_collection_pause_end
(
bool
abandoned
)
{
double
end_time_sec
=
os
::
elapsedTime
();
double
elapsed_ms
=
_last_pause_time_ms
;
bool
parallel
=
ParallelGCThreads
>
0
;
...
...
@@ -1587,42 +1528,10 @@ void G1CollectorPolicy::record_collection_pause_end(bool popular,
}
PauseSummary
*
summary
;
if
(
!
abandoned
&&
!
popular
)
summary
=
_non_pop_summary
;
else
if
(
!
abandoned
&&
popular
)
summary
=
_pop_summary
;
else
if
(
abandoned
&&
!
popular
)
summary
=
_non_pop_abandoned_summary
;
else
if
(
abandoned
&&
popular
)
summary
=
_pop_abandoned_summary
;
else
guarantee
(
false
,
"should not get here!"
);
double
pop_update_rs_time
;
double
pop_update_rs_processed_buffers
;
double
pop_scan_rs_time
;
double
pop_closure_app_time
;
double
pop_other_time
;
if
(
popular
)
{
PopPreambleSummary
*
preamble_summary
=
summary
->
pop_preamble_summary
();
guarantee
(
preamble_summary
!=
NULL
,
"should not be null!"
);
pop_update_rs_time
=
avg_value
(
_pop_par_last_update_rs_times_ms
);
pop_update_rs_processed_buffers
=
sum_of_values
(
_pop_par_last_update_rs_processed_buffers
);
pop_scan_rs_time
=
avg_value
(
_pop_par_last_scan_rs_times_ms
);
pop_closure_app_time
=
avg_value
(
_pop_par_last_closure_app_times_ms
);
pop_other_time
=
_cur_popular_preamble_time_ms
-
(
pop_update_rs_time
+
pop_scan_rs_time
+
pop_closure_app_time
+
_cur_popular_evac_time_ms
);
preamble_summary
->
record_pop_preamble_time_ms
(
_cur_popular_preamble_time_ms
);
preamble_summary
->
record_pop_update_rs_time_ms
(
pop_update_rs_time
);
preamble_summary
->
record_pop_scan_rs_time_ms
(
pop_scan_rs_time
);
preamble_summary
->
record_pop_closure_app_time_ms
(
pop_closure_app_time
);
preamble_summary
->
record_pop_evacuation_time_ms
(
_cur_popular_evac_time_ms
);
preamble_summary
->
record_pop_other_time_ms
(
pop_other_time
);
if
(
abandoned
)
{
summary
=
_abandoned_summary
;
}
else
{
summary
=
_summary
;
}
double
ext_root_scan_time
=
avg_value
(
_par_last_ext_root_scan_times_ms
);
...
...
@@ -1694,8 +1603,6 @@ void G1CollectorPolicy::record_collection_pause_end(bool popular,
}
double
other_time_ms
=
elapsed_ms
;
if
(
popular
)
other_time_ms
-=
_cur_popular_preamble_time_ms
;
if
(
!
abandoned
)
{
if
(
_satb_drain_time_set
)
...
...
@@ -1712,41 +1619,24 @@ void G1CollectorPolicy::record_collection_pause_end(bool popular,
if
(
PrintGCDetails
)
{
gclog_or_tty
->
print_cr
(
"%s%s, %1.8lf secs]"
,
(
popular
&&
!
abandoned
)
?
" (popular)"
:
(
!
popular
&&
abandoned
)
?
" (abandoned)"
:
(
popular
&&
abandoned
)
?
" (popular/abandoned)"
:
""
,
abandoned
?
" (abandoned)"
:
""
,
(
last_pause_included_initial_mark
)
?
" (initial-mark)"
:
""
,
elapsed_ms
/
1000.0
);
if
(
!
abandoned
)
{
if
(
_satb_drain_time_set
)
if
(
_satb_drain_time_set
)
{
print_stats
(
1
,
"SATB Drain Time"
,
_cur_satb_drain_time_ms
);
if
(
_last_satb_drain_processed_buffers
>=
0
)
}
if
(
_last_satb_drain_processed_buffers
>=
0
)
{
print_stats
(
2
,
"Processed Buffers"
,
_last_satb_drain_processed_buffers
);
}
if
(
popular
)
print_stats
(
1
,
"Popularity Preamble"
,
_cur_popular_preamble_time_ms
);
if
(
parallel
)
{
if
(
popular
)
{
print_par_stats
(
2
,
"Update RS (Start)"
,
_pop_par_last_update_rs_start_times_ms
,
false
);
print_par_stats
(
2
,
"Update RS"
,
_pop_par_last_update_rs_times_ms
);
if
(
G1RSBarrierUseQueue
)
print_par_buffers
(
3
,
"Processed Buffers"
,
_pop_par_last_update_rs_processed_buffers
,
true
);
print_par_stats
(
2
,
"Scan RS"
,
_pop_par_last_scan_rs_times_ms
);
print_par_stats
(
2
,
"Closure app"
,
_pop_par_last_closure_app_times_ms
);
print_stats
(
2
,
"Evacuation"
,
_cur_popular_evac_time_ms
);
print_stats
(
2
,
"Other"
,
pop_other_time
);
}
if
(
!
abandoned
)
{
print_stats
(
1
,
"Parallel Time"
,
_cur_collection_par_time_ms
);
if
(
!
popular
)
{
print_par_stats
(
2
,
"Update RS (Start)"
,
_par_last_update_rs_start_times_ms
,
false
);
print_par_stats
(
2
,
"Update RS"
,
_par_last_update_rs_times_ms
);
if
(
G1RSBarrierUseQueue
)
print_par_buffers
(
3
,
"Processed Buffers"
,
_par_last_update_rs_processed_buffers
,
true
);
}
print_par_stats
(
2
,
"Ext Root Scanning"
,
_par_last_ext_root_scan_times_ms
);
print_par_stats
(
2
,
"Mark Stack Scanning"
,
_par_last_mark_stack_scan_times_ms
);
print_par_stats
(
2
,
"Scan-Only Scanning"
,
_par_last_scan_only_times_ms
);
...
...
@@ -1757,25 +1647,11 @@ void G1CollectorPolicy::record_collection_pause_end(bool popular,
print_par_stats
(
2
,
"Termination"
,
_par_last_termination_times_ms
);
print_stats
(
2
,
"Other"
,
parallel_other_time
);
print_stats
(
1
,
"Clear CT"
,
_cur_clear_ct_time_ms
);
}
}
else
{
if
(
popular
)
{
print_stats
(
2
,
"Update RS"
,
pop_update_rs_time
);
if
(
G1RSBarrierUseQueue
)
print_stats
(
3
,
"Processed Buffers"
,
(
int
)
pop_update_rs_processed_buffers
);
print_stats
(
2
,
"Scan RS"
,
pop_scan_rs_time
);
print_stats
(
2
,
"Closure App"
,
pop_closure_app_time
);
print_stats
(
2
,
"Evacuation"
,
_cur_popular_evac_time_ms
);
print_stats
(
2
,
"Other"
,
pop_other_time
);
}
if
(
!
abandoned
)
{
if
(
!
popular
)
{
print_stats
(
1
,
"Update RS"
,
update_rs_time
);
if
(
G1RSBarrierUseQueue
)
print_stats
(
2
,
"Processed Buffers"
,
(
int
)
update_rs_processed_buffers
);
}
print_stats
(
1
,
"Ext Root Scanning"
,
ext_root_scan_time
);
print_stats
(
1
,
"Mark Stack Scanning"
,
mark_stack_scan_time
);
print_stats
(
1
,
"Scan-Only Scanning"
,
scan_only_time
);
...
...
@@ -1855,7 +1731,7 @@ void G1CollectorPolicy::record_collection_pause_end(bool popular,
// <NEW PREDICTION>
if
(
!
popular
&&
update_stats
)
{
if
(
update_stats
)
{
double
pause_time_ms
=
elapsed_ms
;
size_t
diff
=
0
;
...
...
@@ -2454,36 +2330,8 @@ void G1CollectorPolicy::check_other_times(int level,
void
G1CollectorPolicy
::
print_summary
(
PauseSummary
*
summary
)
const
{
bool
parallel
=
ParallelGCThreads
>
0
;
MainBodySummary
*
body_summary
=
summary
->
main_body_summary
();
PopPreambleSummary
*
preamble_summary
=
summary
->
pop_preamble_summary
();
if
(
summary
->
get_total_seq
()
->
num
()
>
0
)
{
print_summary_sd
(
0
,
(
preamble_summary
==
NULL
)
?
"Non-Popular Pauses"
:
"Popular Pauses"
,
summary
->
get_total_seq
());
if
(
preamble_summary
!=
NULL
)
{
print_summary
(
1
,
"Popularity Preamble"
,
preamble_summary
->
get_pop_preamble_seq
());
print_summary
(
2
,
"Update RS"
,
preamble_summary
->
get_pop_update_rs_seq
());
print_summary
(
2
,
"Scan RS"
,
preamble_summary
->
get_pop_scan_rs_seq
());
print_summary
(
2
,
"Closure App"
,
preamble_summary
->
get_pop_closure_app_seq
());
print_summary
(
2
,
"Evacuation"
,
preamble_summary
->
get_pop_evacuation_seq
());
print_summary
(
2
,
"Other"
,
preamble_summary
->
get_pop_other_seq
());
{
NumberSeq
*
other_parts
[]
=
{
preamble_summary
->
get_pop_update_rs_seq
(),
preamble_summary
->
get_pop_scan_rs_seq
(),
preamble_summary
->
get_pop_closure_app_seq
(),
preamble_summary
->
get_pop_evacuation_seq
()
};
NumberSeq
calc_other_times_ms
(
preamble_summary
->
get_pop_preamble_seq
(),
4
,
other_parts
);
check_other_times
(
2
,
preamble_summary
->
get_pop_other_seq
(),
&
calc_other_times_ms
);
}
}
print_summary_sd
(
0
,
"Evacuation Pauses"
,
summary
->
get_total_seq
());
if
(
body_summary
!=
NULL
)
{
print_summary
(
1
,
"SATB Drain"
,
body_summary
->
get_satb_drain_seq
());
if
(
parallel
)
{
...
...
@@ -2537,19 +2385,15 @@ void G1CollectorPolicy::print_summary(PauseSummary* summary) const {
// parallel
NumberSeq
*
other_parts
[]
=
{
body_summary
->
get_satb_drain_seq
(),
(
preamble_summary
==
NULL
)
?
NULL
:
preamble_summary
->
get_pop_preamble_seq
(),
body_summary
->
get_parallel_seq
(),
body_summary
->
get_clear_ct_seq
()
};
calc_other_times_ms
=
NumberSeq
(
summary
->
get_total_seq
(),
4
,
other_parts
);
calc_other_times_ms
=
NumberSeq
(
summary
->
get_total_seq
(),
3
,
other_parts
);
}
else
{
// serial
NumberSeq
*
other_parts
[]
=
{
body_summary
->
get_satb_drain_seq
(),
(
preamble_summary
==
NULL
)
?
NULL
:
preamble_summary
->
get_pop_preamble_seq
(),
body_summary
->
get_update_rs_seq
(),
body_summary
->
get_ext_root_scan_seq
(),
body_summary
->
get_mark_stack_scan_seq
(),
...
...
@@ -2558,16 +2402,11 @@ void G1CollectorPolicy::print_summary(PauseSummary* summary) const {
body_summary
->
get_obj_copy_seq
()
};
calc_other_times_ms
=
NumberSeq
(
summary
->
get_total_seq
(),
8
,
other_parts
);
7
,
other_parts
);
}
}
else
{
// abandoned
NumberSeq
*
other_parts
[]
=
{
(
preamble_summary
==
NULL
)
?
NULL
:
preamble_summary
->
get_pop_preamble_seq
()
};
calc_other_times_ms
=
NumberSeq
(
summary
->
get_total_seq
(),
1
,
other_parts
);
calc_other_times_ms
=
NumberSeq
();
}
check_other_times
(
1
,
summary
->
get_other_seq
(),
&
calc_other_times_ms
);
}
...
...
@@ -2579,18 +2418,12 @@ void G1CollectorPolicy::print_summary(PauseSummary* summary) const {
}
void
G1CollectorPolicy
::
print_abandoned_summary
(
PauseSummary
*
non_pop_summary
,
PauseSummary
*
pop_summary
)
const
{
G1CollectorPolicy
::
print_abandoned_summary
(
PauseSummary
*
summary
)
const
{
bool
printed
=
false
;
if
(
non_pop_summary
->
get_total_seq
()
->
num
()
>
0
)
{
printed
=
true
;
print_summary
(
non_pop_summary
);
}
if
(
pop_summary
->
get_total_seq
()
->
num
()
>
0
)
{
if
(
summary
->
get_total_seq
()
->
num
()
>
0
)
{
printed
=
true
;
print_summary
(
pop_
summary
);
print_summary
(
summary
);
}
if
(
!
printed
)
{
print_indent
(
0
);
gclog_or_tty
->
print_cr
(
"none"
);
...
...
@@ -2608,15 +2441,11 @@ void G1CollectorPolicy::print_tracing_info() const {
gclog_or_tty
->
print_cr
(
" Partial Young GC Pauses: %8d"
,
_partial_young_pause_num
);
gclog_or_tty
->
print_cr
(
""
);
gclog_or_tty
->
print_cr
(
"NON-POPULAR PAUSES"
);
print_summary
(
_non_pop_summary
);
gclog_or_tty
->
print_cr
(
"POPULAR PAUSES"
);
print_summary
(
_pop_summary
);
gclog_or_tty
->
print_cr
(
"EVACUATION PAUSES"
);
print_summary
(
_summary
);
gclog_or_tty
->
print_cr
(
"ABANDONED PAUSES"
);
print_abandoned_summary
(
_non_pop_abandoned_summary
,
_pop_abandoned_summary
);
print_abandoned_summary
(
_abandoned_summary
);
gclog_or_tty
->
print_cr
(
"MISC"
);
print_summary_sd
(
0
,
"Stop World"
,
_all_stop_world_times_ms
);
...
...
@@ -2702,14 +2531,6 @@ void G1CollectorPolicy::update_conc_refine_data() {
_conc_refine_enabled
++
;
}
void
G1CollectorPolicy
::
set_single_region_collection_set
(
HeapRegion
*
hr
)
{
assert
(
collection_set
()
==
NULL
,
"Must be no current CS."
);
_collection_set_size
=
0
;
_collection_set_bytes_used_before
=
0
;
add_to_collection_set
(
hr
);
count_CS_bytes_used
();
}
bool
G1CollectorPolicy
::
should_add_next_region_to_young_list
()
{
assert
(
in_young_gc_mode
(),
"should be in young GC mode"
);
...
...
@@ -2787,15 +2608,6 @@ void G1CollectorPolicy::calculate_survivors_policy()
}
}
void
G1CollectorPolicy_BestRegionsFirst
::
set_single_region_collection_set
(
HeapRegion
*
hr
)
{
G1CollectorPolicy
::
set_single_region_collection_set
(
hr
);
_collectionSetChooser
->
removeRegion
(
hr
);
}
bool
G1CollectorPolicy_BestRegionsFirst
::
should_do_collection_pause
(
size_t
word_size
)
{
...
...
@@ -3061,19 +2873,13 @@ add_to_collection_set(HeapRegion* hr) {
void
G1CollectorPolicy_BestRegionsFirst
::
choose_collection_set
(
HeapRegion
*
pop_region
)
{
choose_collection_set
()
{
double
non_young_start_time_sec
;
start_recording_regions
();
if
(
pop_region
!=
NULL
)
{
_target_pause_time_ms
=
(
double
)
G1MaxPauseTimeMS
;
}
else
{
guarantee
(
_target_pause_time_ms
>
-
1.0
,
"_target_pause_time_ms should have been set!"
);
}
// pop region is either null (and so is CS), or else it *is* the CS.
assert
(
_collection_set
==
pop_region
,
"Precondition"
);
assert
(
_collection_set
==
NULL
,
"Precondition"
);
double
base_time_ms
=
predict_base_elapsed_time_ms
(
_pending_cards
);
double
predicted_pause_time_ms
=
base_time_ms
;
...
...
@@ -3100,15 +2906,13 @@ choose_collection_set(HeapRegion* pop_region) {
size_t
expansion_bytes
=
_g1
->
expansion_regions
()
*
HeapRegion
::
GrainBytes
;
if
(
pop_region
==
NULL
)
{
_collection_set_bytes_used_before
=
0
;
_collection_set_size
=
0
;
}
// Adjust for expansion and slop.
max_live_bytes
=
max_live_bytes
+
expansion_bytes
;
assert
(
pop_region
!=
NULL
||
_g1
->
regions_accounted_for
(),
"Region leakage!"
);
assert
(
_g1
->
regions_accounted_for
(),
"Region leakage!"
);
HeapRegion
*
hr
;
if
(
in_young_gc_mode
())
{
...
...
@@ -3135,14 +2939,9 @@ choose_collection_set(HeapRegion* pop_region) {
double
predicted_time_ms
=
predict_region_elapsed_time_ms
(
hr
,
true
);
time_remaining_ms
-=
predicted_time_ms
;
predicted_pause_time_ms
+=
predicted_time_ms
;
if
(
hr
==
pop_region
)
{
// The popular region was young. Skip over it.
assert
(
hr
->
in_collection_set
(),
"It's the pop region."
);
}
else
{
assert
(
!
hr
->
in_collection_set
(),
"It's not the pop region."
);
assert
(
!
hr
->
in_collection_set
(),
"invariant"
);
add_to_collection_set
(
hr
);
record_cset_region
(
hr
,
true
);
}
max_live_bytes
-=
MIN2
(
hr
->
max_live_bytes
(),
max_live_bytes
);
if
(
G1PolicyVerbose
>
0
)
{
gclog_or_tty
->
print_cr
(
" Added ["
PTR_FORMAT
", "
PTR_FORMAT
") to CS."
,
...
...
@@ -3165,10 +2964,6 @@ choose_collection_set(HeapRegion* pop_region) {
// don't bother adding more regions...
goto
choose_collection_set_end
;
}
}
else
if
(
pop_region
!=
NULL
)
{
// We're not in young mode, and we chose a popular region; don't choose
// any more.
return
;
}
if
(
!
in_young_gc_mode
()
||
!
full_young_gcs
())
{
...
...
@@ -3178,7 +2973,7 @@ choose_collection_set(HeapRegion* pop_region) {
do
{
hr
=
_collectionSetChooser
->
getNextMarkedRegion
(
time_remaining_ms
,
avg_prediction
);
if
(
hr
!=
NULL
&&
!
hr
->
popular
()
)
{
if
(
hr
!=
NULL
)
{
double
predicted_time_ms
=
predict_region_elapsed_time_ms
(
hr
,
false
);
time_remaining_ms
-=
predicted_time_ms
;
predicted_pause_time_ms
+=
predicted_time_ms
;
...
...
@@ -3225,8 +3020,8 @@ expand_if_possible(size_t numRegions) {
}
void
G1CollectorPolicy_BestRegionsFirst
::
record_collection_pause_end
(
bool
popular
,
bool
abandoned
)
{
G1CollectorPolicy
::
record_collection_pause_end
(
popular
,
abandoned
);
record_collection_pause_end
(
bool
abandoned
)
{
G1CollectorPolicy
::
record_collection_pause_end
(
abandoned
);
assert
(
assertMarkedBytesDataOK
(),
"Marked regions not OK at pause end."
);
}
...
...
src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp
浏览文件 @
0c235037
...
...
@@ -47,7 +47,6 @@ public: \
}
class
MainBodySummary
;
class
PopPreambleSummary
;
class
PauseSummary
:
public
CHeapObj
{
define_num_seq
(
total
)
...
...
@@ -55,7 +54,6 @@ class PauseSummary: public CHeapObj {
public:
virtual
MainBodySummary
*
main_body_summary
()
{
return
NULL
;
}
virtual
PopPreambleSummary
*
pop_preamble_summary
()
{
return
NULL
;
}
};
class
MainBodySummary
:
public
CHeapObj
{
...
...
@@ -75,36 +73,13 @@ class MainBodySummary: public CHeapObj {
define_num_seq
(
clear_ct
)
// parallel only
};
class
PopPreambleSummary
:
public
CHeapObj
{
define_num_seq
(
pop_preamble
)
define_num_seq
(
pop_update_rs
)
define_num_seq
(
pop_scan_rs
)
define_num_seq
(
pop_closure_app
)
define_num_seq
(
pop_evacuation
)
define_num_seq
(
pop_other
)
};
class
NonPopSummary
:
public
PauseSummary
,
class
Summary
:
public
PauseSummary
,
public
MainBodySummary
{
public:
virtual
MainBodySummary
*
main_body_summary
()
{
return
this
;
}
};
class
PopSummary
:
public
PauseSummary
,
public
MainBodySummary
,
public
PopPreambleSummary
{
public:
virtual
MainBodySummary
*
main_body_summary
()
{
return
this
;
}
virtual
PopPreambleSummary
*
pop_preamble_summary
()
{
return
this
;
}
};
class
NonPopAbandonedSummary
:
public
PauseSummary
{
};
class
PopAbandonedSummary
:
public
PauseSummary
,
public
PopPreambleSummary
{
public:
virtual
PopPreambleSummary
*
pop_preamble_summary
()
{
return
this
;
}
class
AbandonedSummary
:
public
PauseSummary
{
};
class
G1CollectorPolicy
:
public
CollectorPolicy
{
...
...
@@ -146,10 +121,6 @@ protected:
double
_cur_satb_drain_time_ms
;
double
_cur_clear_ct_time_ms
;
bool
_satb_drain_time_set
;
double
_cur_popular_preamble_start_ms
;
double
_cur_popular_preamble_time_ms
;
double
_cur_popular_compute_rc_time_ms
;
double
_cur_popular_evac_time_ms
;
double
_cur_CH_strong_roots_end_sec
;
double
_cur_CH_strong_roots_dur_ms
;
...
...
@@ -173,10 +144,8 @@ protected:
TruncatedSeq
*
_concurrent_mark_remark_times_ms
;
TruncatedSeq
*
_concurrent_mark_cleanup_times_ms
;
NonPopSummary
*
_non_pop_summary
;
PopSummary
*
_pop_summary
;
NonPopAbandonedSummary
*
_non_pop_abandoned_summary
;
PopAbandonedSummary
*
_pop_abandoned_summary
;
Summary
*
_summary
;
AbandonedSummary
*
_abandoned_summary
;
NumberSeq
*
_all_pause_times_ms
;
NumberSeq
*
_all_full_gc_times_ms
;
...
...
@@ -210,18 +179,6 @@ protected:
double
*
_par_last_obj_copy_times_ms
;
double
*
_par_last_termination_times_ms
;
// there are two pases during popular pauses, so we need to store
// somewhere the results of the first pass
double
*
_pop_par_last_update_rs_start_times_ms
;
double
*
_pop_par_last_update_rs_times_ms
;
double
*
_pop_par_last_update_rs_processed_buffers
;
double
*
_pop_par_last_scan_rs_start_times_ms
;
double
*
_pop_par_last_scan_rs_times_ms
;
double
*
_pop_par_last_closure_app_times_ms
;
double
_pop_compute_rc_start
;
double
_pop_evac_start
;
// indicates that we are in young GC mode
bool
_in_young_gc_mode
;
...
...
@@ -634,8 +591,7 @@ protected:
NumberSeq
*
calc_other_times_ms
)
const
;
void
print_summary
(
PauseSummary
*
stats
)
const
;
void
print_abandoned_summary
(
PauseSummary
*
non_pop_summary
,
PauseSummary
*
pop_summary
)
const
;
void
print_abandoned_summary
(
PauseSummary
*
summary
)
const
;
void
print_summary
(
int
level
,
const
char
*
str
,
NumberSeq
*
seq
)
const
;
void
print_summary_sd
(
int
level
,
const
char
*
str
,
NumberSeq
*
seq
)
const
;
...
...
@@ -856,9 +812,6 @@ public:
virtual
void
record_collection_pause_start
(
double
start_time_sec
,
size_t
start_used
);
virtual
void
record_popular_pause_preamble_start
();
virtual
void
record_popular_pause_preamble_end
();
// Must currently be called while the world is stopped.
virtual
void
record_concurrent_mark_init_start
();
virtual
void
record_concurrent_mark_init_end
();
...
...
@@ -881,7 +834,7 @@ public:
virtual
void
record_collection_pause_end_CH_strong_roots
();
virtual
void
record_collection_pause_end_G1_strong_roots
();
virtual
void
record_collection_pause_end
(
bool
popular
,
bool
abandoned
);
virtual
void
record_collection_pause_end
(
bool
abandoned
);
// Record the fact that a full collection occurred.
virtual
void
record_full_collection_start
();
...
...
@@ -990,12 +943,6 @@ public:
_cur_aux_times_ms
[
i
]
+=
ms
;
}
void
record_pop_compute_rc_start
();
void
record_pop_compute_rc_end
();
void
record_pop_evac_start
();
void
record_pop_evac_end
();
// Record the fact that "bytes" bytes allocated in a region.
void
record_before_bytes
(
size_t
bytes
);
void
record_after_bytes
(
size_t
bytes
);
...
...
@@ -1008,9 +955,7 @@ public:
// Choose a new collection set. Marks the chosen regions as being
// "in_collection_set", and links them together. The head and number of
// the collection set are available via access methods.
// If "pop_region" is non-NULL, it is a popular region that has already
// been added to the collection set.
virtual
void
choose_collection_set
(
HeapRegion
*
pop_region
=
NULL
)
=
0
;
virtual
void
choose_collection_set
()
=
0
;
void
clear_collection_set
()
{
_collection_set
=
NULL
;
}
...
...
@@ -1018,9 +963,6 @@ public:
// current collection set.
HeapRegion
*
collection_set
()
{
return
_collection_set
;
}
// Sets the collection set to the given single region.
virtual
void
set_single_region_collection_set
(
HeapRegion
*
hr
);
// The number of elements in the current collection set.
size_t
collection_set_size
()
{
return
_collection_set_size
;
}
...
...
@@ -1203,7 +1145,7 @@ class G1CollectorPolicy_BestRegionsFirst: public G1CollectorPolicy {
// If the estimated is less then desirable, resize if possible.
void
expand_if_possible
(
size_t
numRegions
);
virtual
void
choose_collection_set
(
HeapRegion
*
pop_region
=
NULL
);
virtual
void
choose_collection_set
();
virtual
void
record_collection_pause_start
(
double
start_time_sec
,
size_t
start_used
);
virtual
void
record_concurrent_mark_cleanup_end
(
size_t
freed_bytes
,
...
...
@@ -1214,9 +1156,8 @@ public:
G1CollectorPolicy_BestRegionsFirst
()
{
_collectionSetChooser
=
new
CollectionSetChooser
();
}
void
record_collection_pause_end
(
bool
popular
,
bool
abandoned
);
void
record_collection_pause_end
(
bool
abandoned
);
bool
should_do_collection_pause
(
size_t
word_size
);
virtual
void
set_single_region_collection_set
(
HeapRegion
*
hr
);
// This is not needed any more, after the CSet choosing code was
// changed to use the pause prediction work. But let's leave the
// hook in just in case.
...
...
src/share/vm/gc_implementation/g1/g1MarkSweep.cpp
浏览文件 @
0c235037
...
...
@@ -157,7 +157,6 @@ void G1MarkSweep::mark_sweep_phase1(bool& marked_for_unloading,
class
G1PrepareCompactClosure
:
public
HeapRegionClosure
{
ModRefBarrierSet
*
_mrbs
;
CompactPoint
_cp
;
bool
_popular_only
;
void
free_humongous_region
(
HeapRegion
*
hr
)
{
HeapWord
*
bot
=
hr
->
bottom
();
...
...
@@ -172,17 +171,11 @@ class G1PrepareCompactClosure: public HeapRegionClosure {
}
public:
G1PrepareCompactClosure
(
CompactibleSpace
*
cs
,
bool
popular_only
)
:
G1PrepareCompactClosure
(
CompactibleSpace
*
cs
)
:
_cp
(
NULL
,
cs
,
cs
->
initialize_threshold
()),
_mrbs
(
G1CollectedHeap
::
heap
()
->
mr_bs
()),
_popular_only
(
popular_only
)
_mrbs
(
G1CollectedHeap
::
heap
()
->
mr_bs
())
{}
bool
doHeapRegion
(
HeapRegion
*
hr
)
{
if
(
_popular_only
&&
!
hr
->
popular
())
return
true
;
// terminate early
else
if
(
!
_popular_only
&&
hr
->
popular
())
return
false
;
// skip this one.
if
(
hr
->
isHumongous
())
{
if
(
hr
->
startsHumongous
())
{
oop
obj
=
oop
(
hr
->
bottom
());
...
...
@@ -203,20 +196,15 @@ public:
return
false
;
}
};
// Stolen verbatim from g1CollectedHeap.cpp
// Finds the first HeapRegion.
class
FindFirstRegionClosure
:
public
HeapRegionClosure
{
HeapRegion
*
_a_region
;
bool
_find_popular
;
public:
FindFirstRegionClosure
(
bool
find_popular
)
:
_a_region
(
NULL
),
_find_popular
(
find_popular
)
{}
FindFirstRegionClosure
()
:
_a_region
(
NULL
)
{}
bool
doHeapRegion
(
HeapRegion
*
r
)
{
if
(
r
->
popular
()
==
_find_popular
)
{
_a_region
=
r
;
return
true
;
}
else
{
return
false
;
}
}
HeapRegion
*
result
()
{
return
_a_region
;
}
};
...
...
@@ -242,30 +230,15 @@ void G1MarkSweep::mark_sweep_phase2() {
TraceTime
tm
(
"phase 2"
,
PrintGC
&&
Verbose
,
true
,
gclog_or_tty
);
GenMarkSweep
::
trace
(
"2"
);
// First we compact the popular regions.
if
(
G1NumPopularRegions
>
0
)
{
CompactibleSpace
*
sp
=
g1h
->
first_compactible_space
();
FindFirstRegionClosure
cl
(
true
/*find_popular*/
);
g1h
->
heap_region_iterate
(
&
cl
);
HeapRegion
*
r
=
cl
.
result
();
assert
(
r
->
popular
(),
"should have found a popular region."
);
assert
(
r
==
sp
,
"first popular heap region should "
"== first compactible space"
);
G1PrepareCompactClosure
blk
(
sp
,
true
/*popular_only*/
);
g1h
->
heap_region_iterate
(
&
blk
);
}
// Now we do the regular regions.
FindFirstRegionClosure
cl
(
false
/*find_popular*/
);
FindFirstRegionClosure
cl
;
g1h
->
heap_region_iterate
(
&
cl
);
HeapRegion
*
r
=
cl
.
result
();
assert
(
!
r
->
popular
(),
"should have founda non-popular region."
);
CompactibleSpace
*
sp
=
r
;
if
(
r
->
isHumongous
()
&&
oop
(
r
->
bottom
())
->
is_gc_marked
())
{
sp
=
r
->
next_compaction_space
();
}
G1PrepareCompactClosure
blk
(
sp
,
false
/*popular_only*/
);
G1PrepareCompactClosure
blk
(
sp
);
g1h
->
heap_region_iterate
(
&
blk
);
CompactPoint
perm_cp
(
pg
,
NULL
,
NULL
);
...
...
src/share/vm/gc_implementation/g1/g1RemSet.cpp
浏览文件 @
0c235037
...
...
@@ -580,9 +580,7 @@ public:
virtual
void
do_oop
(
oop
*
p
)
{
HeapRegion
*
to
=
_g1
->
heap_region_containing
(
*
p
);
if
(
to
->
in_collection_set
())
{
if
(
to
->
rem_set
()
->
add_reference
(
p
,
0
))
{
_g1
->
schedule_popular_region_evac
(
to
);
}
to
->
rem_set
()
->
add_reference
(
p
,
0
);
}
}
};
...
...
@@ -1024,9 +1022,8 @@ void HRInto_G1RemSet::print_summary_info() {
gclog_or_tty
->
print_cr
(
" %d occupied cards represented."
,
blk
.
occupied
());
gclog_or_tty
->
print_cr
(
" Max sz region = ["
PTR_FORMAT
", "
PTR_FORMAT
" )"
"
%s
, cap = "
SIZE_FORMAT
"K, occ = "
SIZE_FORMAT
"K."
,
", cap = "
SIZE_FORMAT
"K, occ = "
SIZE_FORMAT
"K."
,
blk
.
max_mem_sz_region
()
->
bottom
(),
blk
.
max_mem_sz_region
()
->
end
(),
(
blk
.
max_mem_sz_region
()
->
popular
()
?
"POP"
:
""
),
(
blk
.
max_mem_sz_region
()
->
rem_set
()
->
mem_size
()
+
K
-
1
)
/
K
,
(
blk
.
max_mem_sz_region
()
->
rem_set
()
->
occupied
()
+
K
-
1
)
/
K
);
gclog_or_tty
->
print_cr
(
" Did %d coarsenings."
,
...
...
src/share/vm/gc_implementation/g1/g1RemSet.inline.hpp
浏览文件 @
0c235037
...
...
@@ -65,7 +65,6 @@ inline void HRInto_G1RemSet::par_write_ref(HeapRegion* from, oop* p, int tid) {
HeapRegion
*
to
=
_g1
->
heap_region_containing
(
obj
);
// The test below could be optimized by applying a bit op to to and from.
if
(
to
!=
NULL
&&
from
!=
NULL
&&
from
!=
to
)
{
bool
update_delayed
=
false
;
// There is a tricky infinite loop if we keep pushing
// self forwarding pointers onto our _new_refs list.
// The _par_traversal_in_progress flag is true during the collection pause,
...
...
@@ -77,10 +76,7 @@ inline void HRInto_G1RemSet::par_write_ref(HeapRegion* from, oop* p, int tid) {
// or processed (if an evacuation failure occurs) at the end
// of the collection.
// See HRInto_G1RemSet::cleanup_after_oops_into_collection_set_do().
update_delayed
=
true
;
}
if
(
!
to
->
popular
()
&&
!
update_delayed
)
{
}
else
{
#if G1_REM_SET_LOGGING
gclog_or_tty
->
print_cr
(
"Adding "
PTR_FORMAT
" ("
PTR_FORMAT
") to RS"
" for region ["
PTR_FORMAT
", "
PTR_FORMAT
")"
,
...
...
@@ -88,9 +84,7 @@ inline void HRInto_G1RemSet::par_write_ref(HeapRegion* from, oop* p, int tid) {
to
->
bottom
(),
to
->
end
());
#endif
assert
(
to
->
rem_set
()
!=
NULL
,
"Need per-region 'into' remsets."
);
if
(
to
->
rem_set
()
->
add_reference
(
p
,
tid
))
{
_g1
->
schedule_popular_region_evac
(
to
);
}
to
->
rem_set
()
->
add_reference
(
p
,
tid
);
}
}
}
...
...
src/share/vm/gc_implementation/g1/g1_globals.hpp
浏览文件 @
0c235037
...
...
@@ -185,15 +185,9 @@
product(intx, G1InefficientPausePct, 80, \
"Threshold of an 'inefficient' pauses (as % of cum efficiency.") \
\
product(intx, G1RSPopLimit, 32768, \
"Limit that defines popularity. Should go away! XXX") \
\
develop(bool, G1RSCountHisto, false, \
"If true, print a histogram of RS occupancies after each pause") \
\
product(intx, G1ObjPopLimit, 256, \
"Limit that defines popularity for an object.") \
\
product(bool, G1TraceFileOverwrite, false, \
"Allow the trace file to be overwritten") \
\
...
...
@@ -201,16 +195,6 @@
"When > 0, print the occupancies of the <n> best and worst" \
"regions.") \
\
develop(bool, G1TracePopularity, false, \
"When true, provide detailed tracing of popularity.") \
\
product(bool, G1SummarizePopularity, false, \
"When true, provide end-of-run-summarization of popularity.") \
\
product(intx, G1NumPopularRegions, 1, \
"Number of regions reserved to hold popular objects. " \
"Should go away later.") \
\
develop(bool, G1PrintParCleanupStats, false, \
"When true, print extra stats about parallel cleanup.") \
\
...
...
src/share/vm/gc_implementation/g1/heapRegion.cpp
浏览文件 @
0c235037
...
...
@@ -104,7 +104,6 @@ public:
HeapRegion
*
to
=
_g1h
->
heap_region_containing
(
*
p
);
if
(
from
!=
NULL
&&
to
!=
NULL
&&
from
!=
to
&&
!
to
->
popular
()
&&
!
to
->
isHumongous
())
{
jbyte
cv_obj
=
*
_bs
->
byte_for_const
(
_containing_obj
);
jbyte
cv_field
=
*
_bs
->
byte_for_const
(
p
);
...
...
@@ -285,8 +284,6 @@ void HeapRegion::hr_clear(bool par, bool clear_space) {
}
zero_marked_bytes
();
set_sort_index
(
-
1
);
if
((
uintptr_t
)
bottom
()
>=
(
uintptr_t
)
g1h
->
popular_object_boundary
())
set_popular
(
false
);
_offsets
.
resize
(
HeapRegion
::
GrainWords
);
init_top_at_mark_start
();
...
...
@@ -371,7 +368,6 @@ HeapRegion(G1BlockOffsetSharedArray* sharedOffsetArray,
_next_in_special_set
(
NULL
),
_orig_end
(
NULL
),
_claimed
(
InitialClaimValue
),
_evacuation_failed
(
false
),
_prev_marked_bytes
(
0
),
_next_marked_bytes
(
0
),
_sort_index
(
-
1
),
_popularity
(
NotPopular
),
_young_type
(
NotYoung
),
_next_young_region
(
NULL
),
_young_index_in_cset
(
-
1
),
_surv_rate_group
(
NULL
),
_age_index
(
-
1
),
_rem_set
(
NULL
),
_zfs
(
NotZeroFilled
)
...
...
src/share/vm/gc_implementation/g1/heapRegion.hpp
浏览文件 @
0c235037
...
...
@@ -238,15 +238,6 @@ class HeapRegion: public G1OffsetTableContigSpace {
// See "sort_index" method. -1 means is not in the array.
int
_sort_index
;
// Means it has (or at least had) a very large RS, and should not be
// considered for membership in a collection set.
enum
PopularityState
{
NotPopular
,
PopularPending
,
Popular
};
PopularityState
_popularity
;
// <PREDICTION>
double
_gc_efficiency
;
// </PREDICTION>
...
...
@@ -433,10 +424,6 @@ class HeapRegion: public G1OffsetTableContigSpace {
_next_in_special_set
=
r
;
}
bool
is_reserved
()
{
return
popular
();
}
bool
is_on_free_list
()
{
return
_is_on_free_list
;
}
...
...
@@ -609,23 +596,6 @@ class HeapRegion: public G1OffsetTableContigSpace {
init_top_at_mark_start
();
}
bool
popular
()
{
return
_popularity
==
Popular
;
}
void
set_popular
(
bool
b
)
{
if
(
b
)
{
_popularity
=
Popular
;
}
else
{
_popularity
=
NotPopular
;
}
}
bool
popular_pending
()
{
return
_popularity
==
PopularPending
;
}
void
set_popular_pending
(
bool
b
)
{
if
(
b
)
{
_popularity
=
PopularPending
;
}
else
{
_popularity
=
NotPopular
;
}
}
// <PREDICTION>
void
calc_gc_efficiency
(
void
);
double
gc_efficiency
()
{
return
_gc_efficiency
;}
...
...
src/share/vm/gc_implementation/g1/heapRegionRemSet.hpp
浏览文件 @
0c235037
...
...
@@ -188,32 +188,6 @@ private:
// the _outgoing_region_map.
void
clear_outgoing_entries
();
#if MAYBE
// Audit the given card index.
void
audit_card
(
size_t
card_num
,
HeapRegion
*
hr
,
u2
*
rc_arr
,
HeapRegionRemSet
*
empty_cards
,
size_t
*
one_obj_cards
);
// Assumes that "audit_stage1" has been called for "hr", to set up
// "shadow" and "new_rs" appropriately. Identifies individual popular
// objects; returns "true" if any are found.
bool
audit_find_pop
(
HeapRegion
*
hr
,
u2
*
rc_arr
);
// Assumes that "audit_stage1" has been called for "hr", to set up
// "shadow" and "new_rs" appropriately. Identifies individual popular
// objects, and determines the number of entries in "new_rs" if any such
// popular objects are ignored. If this is sufficiently small, returns
// "false" to indicate that a constraint should not be introduced.
// Otherwise, returns "true" to indicate that we should go ahead with
// adding the constraint.
bool
audit_stag
(
HeapRegion
*
hr
,
u2
*
rc_arr
);
u2
*
alloc_rc_array
();
SeqHeapRegionRemSet
*
audit_post
(
u2
*
rc_arr
,
size_t
multi_obj_crds
,
SeqHeapRegionRemSet
*
empty_cards
);
#endif
enum
ParIterState
{
Unclaimed
,
Claimed
,
Complete
};
ParIterState
_iter_state
;
...
...
@@ -261,16 +235,14 @@ public:
/* Used in the sequential case. Returns "true" iff this addition causes
the size limit to be reached. */
bool
add_reference
(
oop
*
from
)
{
void
add_reference
(
oop
*
from
)
{
_other_regions
.
add_reference
(
from
);
return
false
;
}
/* Used in the parallel case. Returns "true" iff this addition causes
the size limit to be reached. */
bool
add_reference
(
oop
*
from
,
int
tid
)
{
void
add_reference
(
oop
*
from
,
int
tid
)
{
_other_regions
.
add_reference
(
from
,
tid
);
return
false
;
}
// Records the fact that the current region contains an outgoing
...
...
@@ -338,20 +310,6 @@ public:
}
void
print
()
const
;
#if MAYBE
// We are about to introduce a constraint, requiring the collection time
// of the region owning this RS to be <= "hr", and forgetting pointers
// from the owning region to "hr." Before doing so, examines this rem
// set for pointers to "hr", possibly identifying some popular objects.,
// and possibly finding some cards to no longer contain pointers to "hr",
//
// These steps may prevent the the constraint from being necessary; in
// which case returns a set of cards now thought to contain no pointers
// into HR. In the normal (I assume) case, returns NULL, indicating that
// we should go ahead and add the constraint.
virtual
SeqHeapRegionRemSet
*
audit
(
HeapRegion
*
hr
)
=
0
;
#endif
// Called during a stop-world phase to perform any deferred cleanups.
// The second version may be called by parallel threads after then finish
// collection work.
...
...
src/share/vm/gc_implementation/g1/heapRegionSeq.cpp
浏览文件 @
0c235037
...
...
@@ -74,7 +74,6 @@ HeapRegionSeq::alloc_obj_from_region_index(int ind, size_t word_size) {
// [first, cur)
HeapRegion
*
curhr
=
_regions
.
at
(
cur
);
if
(
curhr
->
is_empty
()
&&
!
curhr
->
is_reserved
()
&&
(
first
==
cur
||
(
_regions
.
at
(
cur
-
1
)
->
end
()
==
curhr
->
bottom
())))
{
...
...
@@ -121,35 +120,27 @@ HeapRegionSeq::alloc_obj_from_region_index(int ind, size_t word_size) {
}
}
void
HeapRegionSeq
::
print_empty_runs
(
bool
reserved_are_empty
)
{
void
HeapRegionSeq
::
print_empty_runs
()
{
int
empty_run
=
0
;
int
n_empty
=
0
;
bool
at_least_one_reserved
=
false
;
int
empty_run_start
;
for
(
int
i
=
0
;
i
<
_regions
.
length
();
i
++
)
{
HeapRegion
*
r
=
_regions
.
at
(
i
);
if
(
r
->
continuesHumongous
())
continue
;
if
(
r
->
is_empty
()
&&
(
reserved_are_empty
||
!
r
->
is_reserved
())
)
{
if
(
r
->
is_empty
())
{
assert
(
!
r
->
isHumongous
(),
"H regions should not be empty."
);
if
(
empty_run
==
0
)
empty_run_start
=
i
;
empty_run
++
;
n_empty
++
;
if
(
r
->
is_reserved
())
{
at_least_one_reserved
=
true
;
}
}
else
{
if
(
empty_run
>
0
)
{
gclog_or_tty
->
print
(
" %d:%d"
,
empty_run_start
,
empty_run
);
if
(
reserved_are_empty
&&
at_least_one_reserved
)
gclog_or_tty
->
print
(
"(R)"
);
empty_run
=
0
;
at_least_one_reserved
=
false
;
}
}
}
if
(
empty_run
>
0
)
{
gclog_or_tty
->
print
(
" %d:%d"
,
empty_run_start
,
empty_run
);
if
(
reserved_are_empty
&&
at_least_one_reserved
)
gclog_or_tty
->
print
(
"(R)"
);
}
gclog_or_tty
->
print_cr
(
" [tot = %d]"
,
n_empty
);
}
...
...
@@ -193,7 +184,6 @@ size_t HeapRegionSeq::free_suffix() {
int
cur
=
first
;
while
(
cur
>=
0
&&
(
_regions
.
at
(
cur
)
->
is_empty
()
&&
!
_regions
.
at
(
cur
)
->
is_reserved
()
&&
(
first
==
cur
||
(
_regions
.
at
(
cur
+
1
)
->
bottom
()
==
_regions
.
at
(
cur
)
->
end
()))))
{
...
...
src/share/vm/gc_implementation/g1/heapRegionSeq.hpp
浏览文件 @
0c235037
...
...
@@ -104,8 +104,7 @@ class HeapRegionSeq: public CHeapObj {
void
print
();
// Prints out runs of empty regions. If the arg is "true" reserved
// (popular regions are considered "empty".
void
print_empty_runs
(
bool
reserved_are_empty
);
// Prints out runs of empty regions.
void
print_empty_runs
();
};
src/share/vm/gc_implementation/g1/vm_operations_g1.cpp
浏览文件 @
0c235037
...
...
@@ -43,16 +43,9 @@ void VM_G1IncCollectionPause::doit() {
JvmtiGCForAllocationMarker
jgcm
;
G1CollectedHeap
*
g1h
=
G1CollectedHeap
::
heap
();
GCCauseSetter
x
(
g1h
,
GCCause
::
_g1_inc_collection_pause
);
g1h
->
do_collection_pause_at_safepoint
(
NULL
);
g1h
->
do_collection_pause_at_safepoint
();
}
void
VM_G1PopRegionCollectionPause
::
doit
()
{
JvmtiGCForAllocationMarker
jgcm
;
G1CollectedHeap
*
g1h
=
G1CollectedHeap
::
heap
();
g1h
->
do_collection_pause_at_safepoint
(
_pop_region
);
}
void
VM_CGC_Operation
::
doit
()
{
gclog_or_tty
->
date_stamp
(
PrintGC
&&
PrintGCDateStamps
);
TraceCPUTime
tcpu
(
PrintGCDetails
,
true
,
gclog_or_tty
);
...
...
src/share/vm/gc_implementation/g1/vm_operations_g1.hpp
浏览文件 @
0c235037
...
...
@@ -77,20 +77,6 @@ class VM_G1IncCollectionPause: public VM_GC_Operation {
}
};
class
VM_G1PopRegionCollectionPause
:
public
VM_GC_Operation
{
HeapRegion
*
_pop_region
;
public:
VM_G1PopRegionCollectionPause
(
int
gc_count_before
,
HeapRegion
*
pop_region
)
:
VM_GC_Operation
(
gc_count_before
),
_pop_region
(
pop_region
)
{}
virtual
VMOp_Type
type
()
const
{
return
VMOp_G1PopRegionCollectionPause
;
}
virtual
void
doit
();
virtual
const
char
*
name
()
const
{
return
"garbage-first popular region collection pause"
;
}
};
// Concurrent GC stop-the-world operations such as initial and final mark;
// consider sharing these with CMS's counterparts.
class
VM_CGC_Operation
:
public
VM_Operation
{
...
...
src/share/vm/gc_interface/gcCause.hpp
浏览文件 @
0c235037
...
...
@@ -60,7 +60,7 @@ class GCCause : public AllStatic {
_old_generation_too_full_to_scavenge
,
_adaptive_size_policy
,
_g1_inc_collection_pause
,
_g1_pop_region_collection_pause
,
_g1_inc_collection_pause
,
_last_ditch_collection
,
_last_gc_cause
...
...
src/share/vm/runtime/vm_operations.hpp
浏览文件 @
0c235037
...
...
@@ -59,7 +59,6 @@
template(G1CollectFull) \
template(G1CollectForAllocation) \
template(G1IncCollectionPause) \
template(G1PopRegionCollectionPause) \
template(EnableBiasedLocking) \
template(RevokeBias) \
template(BulkRevokeBias) \
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录