Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_hotspot
提交
6e2eba06
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看板
提交
6e2eba06
编写于
1月 16, 2015
作者:
A
amurillo
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
aa7a73ca
85c9dee2
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
39 addition
and
21 deletion
+39
-21
make/hotspot_version
make/hotspot_version
+1
-1
src/share/vm/gc_implementation/g1/g1PageBasedVirtualSpace.cpp
...share/vm/gc_implementation/g1/g1PageBasedVirtualSpace.cpp
+26
-12
src/share/vm/gc_implementation/g1/g1PageBasedVirtualSpace.hpp
...share/vm/gc_implementation/g1/g1PageBasedVirtualSpace.hpp
+9
-4
src/share/vm/gc_implementation/g1/g1RegionToSpaceMapper.cpp
src/share/vm/gc_implementation/g1/g1RegionToSpaceMapper.cpp
+3
-4
未找到文件。
make/hotspot_version
浏览文件 @
6e2eba06
...
@@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2014
...
@@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2014
HS_MAJOR_VER=25
HS_MAJOR_VER=25
HS_MINOR_VER=40
HS_MINOR_VER=40
HS_BUILD_NUMBER=2
4
HS_BUILD_NUMBER=2
5
JDK_MAJOR_VER=1
JDK_MAJOR_VER=1
JDK_MINOR_VER=8
JDK_MINOR_VER=8
...
...
src/share/vm/gc_implementation/g1/g1PageBasedVirtualSpace.cpp
浏览文件 @
6e2eba06
...
@@ -45,7 +45,8 @@
...
@@ -45,7 +45,8 @@
#include "utilities/bitMap.inline.hpp"
#include "utilities/bitMap.inline.hpp"
G1PageBasedVirtualSpace
::
G1PageBasedVirtualSpace
()
:
_low_boundary
(
NULL
),
G1PageBasedVirtualSpace
::
G1PageBasedVirtualSpace
()
:
_low_boundary
(
NULL
),
_high_boundary
(
NULL
),
_committed
(),
_page_size
(
0
),
_special
(
false
),
_executable
(
false
)
{
_high_boundary
(
NULL
),
_committed
(),
_page_size
(
0
),
_special
(
false
),
_dirty
(),
_executable
(
false
)
{
}
}
bool
G1PageBasedVirtualSpace
::
initialize_with_granularity
(
ReservedSpace
rs
,
size_t
page_size
)
{
bool
G1PageBasedVirtualSpace
::
initialize_with_granularity
(
ReservedSpace
rs
,
size_t
page_size
)
{
...
@@ -66,6 +67,9 @@ bool G1PageBasedVirtualSpace::initialize_with_granularity(ReservedSpace rs, size
...
@@ -66,6 +67,9 @@ bool G1PageBasedVirtualSpace::initialize_with_granularity(ReservedSpace rs, size
assert
(
_committed
.
size
()
==
0
,
"virtual space initialized more than once"
);
assert
(
_committed
.
size
()
==
0
,
"virtual space initialized more than once"
);
uintx
size_in_bits
=
rs
.
size
()
/
page_size
;
uintx
size_in_bits
=
rs
.
size
()
/
page_size
;
_committed
.
resize
(
size_in_bits
,
/* in_resource_area */
false
);
_committed
.
resize
(
size_in_bits
,
/* in_resource_area */
false
);
if
(
_special
)
{
_dirty
.
resize
(
size_in_bits
,
/* in_resource_area */
false
);
}
return
true
;
return
true
;
}
}
...
@@ -84,6 +88,7 @@ void G1PageBasedVirtualSpace::release() {
...
@@ -84,6 +88,7 @@ void G1PageBasedVirtualSpace::release() {
_executable
=
false
;
_executable
=
false
;
_page_size
=
0
;
_page_size
=
0
;
_committed
.
resize
(
0
,
false
);
_committed
.
resize
(
0
,
false
);
_dirty
.
resize
(
0
,
false
);
}
}
size_t
G1PageBasedVirtualSpace
::
committed_size
()
const
{
size_t
G1PageBasedVirtualSpace
::
committed_size
()
const
{
...
@@ -120,31 +125,40 @@ size_t G1PageBasedVirtualSpace::byte_size_for_pages(size_t num) {
...
@@ -120,31 +125,40 @@ size_t G1PageBasedVirtualSpace::byte_size_for_pages(size_t num) {
return
num
*
_page_size
;
return
num
*
_page_size
;
}
}
MemRegion
G1PageBasedVirtualSpace
::
commit
(
uintptr_t
start
,
size_t
size_in_pages
)
{
bool
G1PageBasedVirtualSpace
::
commit
(
uintptr_t
start
,
size_t
size_in_pages
)
{
// We need to make sure to commit all pages covered by the given area.
// We need to make sure to commit all pages covered by the given area.
guarantee
(
is_area_uncommitted
(
start
,
size_in_pages
),
"Specified area is not uncommitted"
);
guarantee
(
is_area_uncommitted
(
start
,
size_in_pages
),
"Specified area is not uncommitted"
);
if
(
!
_special
)
{
bool
zero_filled
=
true
;
uintptr_t
end
=
start
+
size_in_pages
;
if
(
_special
)
{
// Check for dirty pages and update zero_filled if any found.
if
(
_dirty
.
get_next_one_offset
(
start
,
end
)
<
end
)
{
zero_filled
=
false
;
_dirty
.
clear_range
(
start
,
end
);
}
}
else
{
os
::
commit_memory_or_exit
(
page_start
(
start
),
byte_size_for_pages
(
size_in_pages
),
_executable
,
os
::
commit_memory_or_exit
(
page_start
(
start
),
byte_size_for_pages
(
size_in_pages
),
_executable
,
err_msg
(
"Failed to commit pages from "
SIZE_FORMAT
" of length "
SIZE_FORMAT
,
start
,
size_in_pages
));
err_msg
(
"Failed to commit pages from "
SIZE_FORMAT
" of length "
SIZE_FORMAT
,
start
,
size_in_pages
));
}
}
_committed
.
set_range
(
start
,
start
+
size_in_pages
);
_committed
.
set_range
(
start
,
end
);
MemRegion
result
((
HeapWord
*
)
page_start
(
start
),
byte_size_for_pages
(
size_in_pages
)
/
HeapWordSize
);
return
zero_filled
;
return
result
;
}
}
MemRegion
G1PageBasedVirtualSpace
::
uncommit
(
uintptr_t
start
,
size_t
size_in_pages
)
{
void
G1PageBasedVirtualSpace
::
uncommit
(
uintptr_t
start
,
size_t
size_in_pages
)
{
guarantee
(
is_area_committed
(
start
,
size_in_pages
),
"checking"
);
guarantee
(
is_area_committed
(
start
,
size_in_pages
),
"checking"
);
if
(
!
_special
)
{
if
(
_special
)
{
// Mark that memory is dirty. If committed again the memory might
// need to be cleared explicitly.
_dirty
.
set_range
(
start
,
start
+
size_in_pages
);
}
else
{
os
::
uncommit_memory
(
page_start
(
start
),
byte_size_for_pages
(
size_in_pages
));
os
::
uncommit_memory
(
page_start
(
start
),
byte_size_for_pages
(
size_in_pages
));
}
}
_committed
.
clear_range
(
start
,
start
+
size_in_pages
);
_committed
.
clear_range
(
start
,
start
+
size_in_pages
);
MemRegion
result
((
HeapWord
*
)
page_start
(
start
),
byte_size_for_pages
(
size_in_pages
)
/
HeapWordSize
);
return
result
;
}
}
bool
G1PageBasedVirtualSpace
::
contains
(
const
void
*
p
)
const
{
bool
G1PageBasedVirtualSpace
::
contains
(
const
void
*
p
)
const
{
...
@@ -154,7 +168,7 @@ bool G1PageBasedVirtualSpace::contains(const void* p) const {
...
@@ -154,7 +168,7 @@ bool G1PageBasedVirtualSpace::contains(const void* p) const {
#ifndef PRODUCT
#ifndef PRODUCT
void
G1PageBasedVirtualSpace
::
print_on
(
outputStream
*
out
)
{
void
G1PageBasedVirtualSpace
::
print_on
(
outputStream
*
out
)
{
out
->
print
(
"Virtual space:"
);
out
->
print
(
"Virtual space:"
);
if
(
special
()
)
out
->
print
(
" (pinned in memory)"
);
if
(
_special
)
out
->
print
(
" (pinned in memory)"
);
out
->
cr
();
out
->
cr
();
out
->
print_cr
(
" - committed: "
SIZE_FORMAT
,
committed_size
());
out
->
print_cr
(
" - committed: "
SIZE_FORMAT
,
committed_size
());
out
->
print_cr
(
" - reserved: "
SIZE_FORMAT
,
reserved_size
());
out
->
print_cr
(
" - reserved: "
SIZE_FORMAT
,
reserved_size
());
...
...
src/share/vm/gc_implementation/g1/g1PageBasedVirtualSpace.hpp
浏览文件 @
6e2eba06
...
@@ -49,6 +49,12 @@ class G1PageBasedVirtualSpace VALUE_OBJ_CLASS_SPEC {
...
@@ -49,6 +49,12 @@ class G1PageBasedVirtualSpace VALUE_OBJ_CLASS_SPEC {
// Bitmap used for verification of commit/uncommit operations.
// Bitmap used for verification of commit/uncommit operations.
BitMap
_committed
;
BitMap
_committed
;
// Bitmap used to keep track of which pages are dirty or not for _special
// spaces. This is needed because for those spaces the underlying memory
// will only be zero filled the first time it is committed. Calls to commit
// will use this bitmap and return whether or not the memory is zero filled.
BitMap
_dirty
;
// Indicates that the entire space has been committed and pinned in memory,
// Indicates that the entire space has been committed and pinned in memory,
// os::commit_memory() or os::uncommit_memory() have no function.
// os::commit_memory() or os::uncommit_memory() have no function.
bool
_special
;
bool
_special
;
...
@@ -71,12 +77,11 @@ class G1PageBasedVirtualSpace VALUE_OBJ_CLASS_SPEC {
...
@@ -71,12 +77,11 @@ class G1PageBasedVirtualSpace VALUE_OBJ_CLASS_SPEC {
public:
public:
// Commit the given area of pages starting at start being size_in_pages large.
// Commit the given area of pages starting at start being size_in_pages large.
MemRegion
commit
(
uintptr_t
start
,
size_t
size_in_pages
);
// Returns true if the given area is zero filled upon completion.
bool
commit
(
uintptr_t
start
,
size_t
size_in_pages
);
// Uncommit the given area of pages starting at start being size_in_pages large.
// Uncommit the given area of pages starting at start being size_in_pages large.
MemRegion
uncommit
(
uintptr_t
start
,
size_t
size_in_pages
);
void
uncommit
(
uintptr_t
start
,
size_t
size_in_pages
);
bool
special
()
const
{
return
_special
;
}
// Initialization
// Initialization
G1PageBasedVirtualSpace
();
G1PageBasedVirtualSpace
();
...
...
src/share/vm/gc_implementation/g1/g1RegionToSpaceMapper.cpp
浏览文件 @
6e2eba06
...
@@ -67,9 +67,9 @@ class G1RegionsLargerThanCommitSizeMapper : public G1RegionToSpaceMapper {
...
@@ -67,9 +67,9 @@ class G1RegionsLargerThanCommitSizeMapper : public G1RegionToSpaceMapper {
}
}
virtual
void
commit_regions
(
uintptr_t
start_idx
,
size_t
num_regions
)
{
virtual
void
commit_regions
(
uintptr_t
start_idx
,
size_t
num_regions
)
{
_storage
.
commit
(
start_idx
*
_pages_per_region
,
num_regions
*
_pages_per_region
);
bool
zero_filled
=
_storage
.
commit
(
start_idx
*
_pages_per_region
,
num_regions
*
_pages_per_region
);
_commit_map
.
set_range
(
start_idx
,
start_idx
+
num_regions
);
_commit_map
.
set_range
(
start_idx
,
start_idx
+
num_regions
);
fire_on_commit
(
start_idx
,
num_regions
,
true
);
fire_on_commit
(
start_idx
,
num_regions
,
zero_filled
);
}
}
virtual
void
uncommit_regions
(
uintptr_t
start_idx
,
size_t
num_regions
)
{
virtual
void
uncommit_regions
(
uintptr_t
start_idx
,
size_t
num_regions
)
{
...
@@ -117,8 +117,7 @@ class G1RegionsSmallerThanCommitSizeMapper : public G1RegionToSpaceMapper {
...
@@ -117,8 +117,7 @@ class G1RegionsSmallerThanCommitSizeMapper : public G1RegionToSpaceMapper {
uint
old_refcount
=
_refcounts
.
get_by_index
(
idx
);
uint
old_refcount
=
_refcounts
.
get_by_index
(
idx
);
bool
zero_filled
=
false
;
bool
zero_filled
=
false
;
if
(
old_refcount
==
0
)
{
if
(
old_refcount
==
0
)
{
_storage
.
commit
(
idx
,
1
);
zero_filled
=
_storage
.
commit
(
idx
,
1
);
zero_filled
=
true
;
}
}
_refcounts
.
set_by_index
(
idx
,
old_refcount
+
1
);
_refcounts
.
set_by_index
(
idx
,
old_refcount
+
1
);
_commit_map
.
set_bit
(
i
);
_commit_map
.
set_bit
(
i
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录