Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
b68bb1c3
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看板
提交
b68bb1c3
编写于
3月 03, 2009
作者:
J
jcoomes
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
6810474: par compact - crash in summary_phase with very full heap
Reviewed-by: tonyp
上级
c4b16995
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
3 addition
and
4 deletion
+3
-4
src/share/vm/gc_implementation/parallelScavenge/psParallelCompact.cpp
.../gc_implementation/parallelScavenge/psParallelCompact.cpp
+3
-4
未找到文件。
src/share/vm/gc_implementation/parallelScavenge/psParallelCompact.cpp
浏览文件 @
b68bb1c3
...
@@ -508,6 +508,7 @@ ParallelCompactData::summarize_split_space(size_t src_region,
...
@@ -508,6 +508,7 @@ ParallelCompactData::summarize_split_space(size_t src_region,
assert
(
destination
<=
target_end
,
"sanity"
);
assert
(
destination
<=
target_end
,
"sanity"
);
assert
(
destination
+
_region_data
[
src_region
].
data_size
()
>
target_end
,
assert
(
destination
+
_region_data
[
src_region
].
data_size
()
>
target_end
,
"region should not fit into target space"
);
"region should not fit into target space"
);
assert
(
is_region_aligned
(
target_end
),
"sanity"
);
size_t
split_region
=
src_region
;
size_t
split_region
=
src_region
;
HeapWord
*
split_destination
=
destination
;
HeapWord
*
split_destination
=
destination
;
...
@@ -538,14 +539,12 @@ ParallelCompactData::summarize_split_space(size_t src_region,
...
@@ -538,14 +539,12 @@ ParallelCompactData::summarize_split_space(size_t src_region,
// max(top, max(new_top, clear_top))
// max(top, max(new_top, clear_top))
//
//
// where clear_top is a new field in SpaceInfo. Would have to set clear_top
// where clear_top is a new field in SpaceInfo. Would have to set clear_top
// to destination + partial_obj_size, where both have the values passed to
// to target_end.
// this routine.
const
RegionData
*
const
sr
=
region
(
split_region
);
const
RegionData
*
const
sr
=
region
(
split_region
);
const
size_t
beg_idx
=
const
size_t
beg_idx
=
addr_to_region_idx
(
region_align_up
(
sr
->
destination
()
+
addr_to_region_idx
(
region_align_up
(
sr
->
destination
()
+
sr
->
partial_obj_size
()));
sr
->
partial_obj_size
()));
const
size_t
end_idx
=
const
size_t
end_idx
=
addr_to_region_idx
(
target_end
);
addr_to_region_idx
(
region_align_up
(
destination
+
partial_obj_size
));
if
(
TraceParallelOldGCSummaryPhase
)
{
if
(
TraceParallelOldGCSummaryPhase
)
{
gclog_or_tty
->
print_cr
(
"split: clearing source_region field in ["
gclog_or_tty
->
print_cr
(
"split: clearing source_region field in ["
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录